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