xref: /freebsd/sys/dev/dpaa/if_dtsec_rm.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
1*0aeed3e9SJustin Hibbits /*-
2*0aeed3e9SJustin Hibbits  * Copyright (c) 2012 Semihalf.
3*0aeed3e9SJustin Hibbits  * All rights reserved.
4*0aeed3e9SJustin Hibbits  *
5*0aeed3e9SJustin Hibbits  * Redistribution and use in source and binary forms, with or without
6*0aeed3e9SJustin Hibbits  * modification, are permitted provided that the following conditions
7*0aeed3e9SJustin Hibbits  * are met:
8*0aeed3e9SJustin Hibbits  * 1. Redistributions of source code must retain the above copyright
9*0aeed3e9SJustin Hibbits  *    notice, this list of conditions and the following disclaimer.
10*0aeed3e9SJustin Hibbits  * 2. Redistributions in binary form must reproduce the above copyright
11*0aeed3e9SJustin Hibbits  *    notice, this list of conditions and the following disclaimer in the
12*0aeed3e9SJustin Hibbits  *    documentation and/or other materials provided with the distribution.
13*0aeed3e9SJustin Hibbits  *
14*0aeed3e9SJustin Hibbits  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15*0aeed3e9SJustin Hibbits  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16*0aeed3e9SJustin Hibbits  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17*0aeed3e9SJustin Hibbits  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18*0aeed3e9SJustin Hibbits  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19*0aeed3e9SJustin Hibbits  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20*0aeed3e9SJustin Hibbits  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21*0aeed3e9SJustin Hibbits  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22*0aeed3e9SJustin Hibbits  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23*0aeed3e9SJustin Hibbits  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24*0aeed3e9SJustin Hibbits  * SUCH DAMAGE.
25*0aeed3e9SJustin Hibbits  */
26*0aeed3e9SJustin Hibbits 
27*0aeed3e9SJustin Hibbits #ifndef IF_DTSEC_RM_H_
28*0aeed3e9SJustin Hibbits #define IF_DTSEC_RM_H_
29*0aeed3e9SJustin Hibbits 
30*0aeed3e9SJustin Hibbits /**
31*0aeed3e9SJustin Hibbits  * @group dTSEC Regular Mode API.
32*0aeed3e9SJustin Hibbits  * @{
33*0aeed3e9SJustin Hibbits  */
34*0aeed3e9SJustin Hibbits int	dtsec_rm_fm_port_rx_init(struct dtsec_softc *sc, int unit);
35*0aeed3e9SJustin Hibbits int	dtsec_rm_fm_port_tx_init(struct dtsec_softc *sc, int unit);
36*0aeed3e9SJustin Hibbits 
37*0aeed3e9SJustin Hibbits void	dtsec_rm_if_start_locked(struct dtsec_softc *sc);
38*0aeed3e9SJustin Hibbits 
39*0aeed3e9SJustin Hibbits int	dtsec_rm_pool_rx_init(struct dtsec_softc *sc);
40*0aeed3e9SJustin Hibbits void	dtsec_rm_pool_rx_free(struct dtsec_softc *sc);
41*0aeed3e9SJustin Hibbits 
42*0aeed3e9SJustin Hibbits int	dtsec_rm_fi_pool_init(struct dtsec_softc *sc);
43*0aeed3e9SJustin Hibbits void	dtsec_rm_fi_pool_free(struct dtsec_softc *sc);
44*0aeed3e9SJustin Hibbits 
45*0aeed3e9SJustin Hibbits int	dtsec_rm_fqr_rx_init(struct dtsec_softc *sc);
46*0aeed3e9SJustin Hibbits int	dtsec_rm_fqr_tx_init(struct dtsec_softc *sc);
47*0aeed3e9SJustin Hibbits void	dtsec_rm_fqr_rx_free(struct dtsec_softc *sc);
48*0aeed3e9SJustin Hibbits void	dtsec_rm_fqr_tx_free(struct dtsec_softc *sc);
49*0aeed3e9SJustin Hibbits /** @} */
50*0aeed3e9SJustin Hibbits 
51*0aeed3e9SJustin Hibbits #endif /* IF_DTSEC_RM_H_ */
52