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