xref: /freebsd/sys/dev/igc/igc_mac.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
1*517904deSPeter Grehan /*-
2*517904deSPeter Grehan  * Copyright 2021 Intel Corp
3*517904deSPeter Grehan  * Copyright 2021 Rubicon Communications, LLC (Netgate)
4*517904deSPeter Grehan  * SPDX-License-Identifier: BSD-3-Clause
5*517904deSPeter Grehan  */
6*517904deSPeter Grehan 
7*517904deSPeter Grehan #ifndef _IGC_MAC_H_
8*517904deSPeter Grehan #define _IGC_MAC_H_
9*517904deSPeter Grehan 
10*517904deSPeter Grehan void igc_init_mac_ops_generic(struct igc_hw *hw);
11*517904deSPeter Grehan void igc_null_mac_generic(struct igc_hw *hw);
12*517904deSPeter Grehan s32  igc_null_ops_generic(struct igc_hw *hw);
13*517904deSPeter Grehan s32  igc_null_link_info(struct igc_hw *hw, u16 *s, u16 *d);
14*517904deSPeter Grehan bool igc_null_mng_mode(struct igc_hw *hw);
15*517904deSPeter Grehan void igc_null_update_mc(struct igc_hw *hw, u8 *h, u32 a);
16*517904deSPeter Grehan void igc_null_write_vfta(struct igc_hw *hw, u32 a, u32 b);
17*517904deSPeter Grehan int  igc_null_rar_set(struct igc_hw *hw, u8 *h, u32 a);
18*517904deSPeter Grehan s32  igc_check_for_copper_link_generic(struct igc_hw *hw);
19*517904deSPeter Grehan s32  igc_config_fc_after_link_up_generic(struct igc_hw *hw);
20*517904deSPeter Grehan s32  igc_disable_pcie_master_generic(struct igc_hw *hw);
21*517904deSPeter Grehan s32  igc_force_mac_fc_generic(struct igc_hw *hw);
22*517904deSPeter Grehan s32  igc_get_auto_rd_done_generic(struct igc_hw *hw);
23*517904deSPeter Grehan s32  igc_get_bus_info_pcie_generic(struct igc_hw *hw);
24*517904deSPeter Grehan void igc_set_lan_id_single_port(struct igc_hw *hw);
25*517904deSPeter Grehan s32  igc_get_hw_semaphore_generic(struct igc_hw *hw);
26*517904deSPeter Grehan s32  igc_get_speed_and_duplex_copper_generic(struct igc_hw *hw, u16 *speed,
27*517904deSPeter Grehan 					       u16 *duplex);
28*517904deSPeter Grehan void igc_update_mc_addr_list_generic(struct igc_hw *hw,
29*517904deSPeter Grehan 				       u8 *mc_addr_list, u32 mc_addr_count);
30*517904deSPeter Grehan int igc_rar_set_generic(struct igc_hw *hw, u8 *addr, u32 index);
31*517904deSPeter Grehan s32  igc_set_fc_watermarks_generic(struct igc_hw *hw);
32*517904deSPeter Grehan s32  igc_setup_link_generic(struct igc_hw *hw);
33*517904deSPeter Grehan s32  igc_validate_mdi_setting_crossover_generic(struct igc_hw *hw);
34*517904deSPeter Grehan 
35*517904deSPeter Grehan u32  igc_hash_mc_addr_generic(struct igc_hw *hw, u8 *mc_addr);
36*517904deSPeter Grehan 
37*517904deSPeter Grehan void igc_clear_hw_cntrs_base_generic(struct igc_hw *hw);
38*517904deSPeter Grehan void igc_clear_vfta_generic(struct igc_hw *hw);
39*517904deSPeter Grehan void igc_init_rx_addrs_generic(struct igc_hw *hw, u16 rar_count);
40*517904deSPeter Grehan void igc_pcix_mmrbc_workaround_generic(struct igc_hw *hw);
41*517904deSPeter Grehan void igc_put_hw_semaphore_generic(struct igc_hw *hw);
42*517904deSPeter Grehan s32  igc_check_alt_mac_addr_generic(struct igc_hw *hw);
43*517904deSPeter Grehan void igc_set_pcie_no_snoop_generic(struct igc_hw *hw, u32 no_snoop);
44*517904deSPeter Grehan void igc_write_vfta_generic(struct igc_hw *hw, u32 offset, u32 value);
45*517904deSPeter Grehan 
46*517904deSPeter Grehan #endif
47