xref: /freebsd/sys/dev/sfxge/common/ef10_impl.h (revision 15c433351f54e7cd5bec8d36c8e89e6a7fa55b26)
1 /*-
2  * Copyright (c) 2015 Solarflare Communications Inc.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice,
9  *    this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright notice,
11  *    this list of conditions and the following disclaimer in the documentation
12  *    and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
15  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
16  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
18  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
19  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
20  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
21  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
22  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
23  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
24  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  *
26  * The views and conclusions contained in the software and documentation are
27  * those of the authors and should not be interpreted as representing official
28  * policies, either expressed or implied, of the FreeBSD Project.
29  *
30  * $FreeBSD$
31  */
32 
33 #ifndef	_SYS_EF10_IMPL_H
34 #define	_SYS_EF10_IMPL_H
35 
36 #ifdef	__cplusplus
37 extern "C" {
38 #endif
39 
40 #if (EFSYS_OPT_HUNTINGTON && EFSYS_OPT_MEDFORD)
41 #define	EF10_MAX_PIOBUF_NBUFS	MAX(HUNT_PIOBUF_NBUFS, MEDFORD_PIOBUF_NBUFS)
42 #elif EFSYS_OPT_HUNTINGTON
43 #define	EF10_MAX_PIOBUF_NBUFS	HUNT_PIOBUF_NBUFS
44 #elif EFSYS_OPT_MEDFORD
45 #define	EF10_MAX_PIOBUF_NBUFS	MEDFORD_PIOBUF_NBUFS
46 #endif
47 
48 extern	__checkReturn	efx_rc_t
49 efx_mcdi_get_port_assignment(
50 	__in		efx_nic_t *enp,
51 	__out		uint32_t *portp);
52 
53 extern	__checkReturn	efx_rc_t
54 efx_mcdi_get_port_modes(
55 	__in		efx_nic_t *enp,
56 	__out		uint32_t *modesp);
57 
58 extern	__checkReturn	efx_rc_t
59 efx_mcdi_get_mac_address_pf(
60 	__in			efx_nic_t *enp,
61 	__out_ecount_opt(6)	uint8_t mac_addrp[6]);
62 
63 extern	__checkReturn	efx_rc_t
64 efx_mcdi_get_mac_address_vf(
65 	__in			efx_nic_t *enp,
66 	__out_ecount_opt(6)	uint8_t mac_addrp[6]);
67 
68 extern	__checkReturn	efx_rc_t
69 efx_mcdi_get_clock(
70 	__in		efx_nic_t *enp,
71 	__out		uint32_t *sys_freqp);
72 
73 extern	__checkReturn	efx_rc_t
74 efx_mcdi_get_vector_cfg(
75 	__in		efx_nic_t *enp,
76 	__out_opt	uint32_t *vec_basep,
77 	__out_opt	uint32_t *pf_nvecp,
78 	__out_opt	uint32_t *vf_nvecp);
79 
80 extern	__checkReturn	efx_rc_t
81 ef10_get_datapath_caps(
82 	__in		efx_nic_t *enp);
83 
84 extern	__checkReturn		efx_rc_t
85 ef10_get_privilege_mask(
86 	__in			efx_nic_t *enp,
87 	__out			uint32_t *maskp);
88 
89 extern	__checkReturn	efx_rc_t
90 ef10_external_port_mapping(
91 	__in		efx_nic_t *enp,
92 	__in		uint32_t port,
93 	__out		uint8_t *external_portp);
94 
95 
96 #ifdef	__cplusplus
97 }
98 #endif
99 
100 #endif	/* _SYS_EF10_IMPL_H */
101