/******************************************************************************* Intel(R) Gigabit Ethernet Linux driver Copyright(c) 2007-2009 Intel Corporation. This program is free software; you can redistribute it and/or modify it under the terms and conditions of the GNU General Public License, version 2, as published by the Free Software Foundation. This program is distributed in the hope it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA. The full GNU General Public License is included in this distribution in the file called "COPYING". Contact Information: e1000-devel Mailing List Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497 *******************************************************************************/ FILE_LICENCE ( GPL2_ONLY ); #ifndef _IGB_MAC_H_ #define _IGB_MAC_H_ /* * Functions that should not be called directly from drivers but can be used * by other files in this 'shared code' */ void igb_init_mac_ops_generic(struct e1000_hw *hw); s32 igb_blink_led_generic(struct e1000_hw *hw); s32 igb_check_for_copper_link_generic(struct e1000_hw *hw); s32 igb_check_for_fiber_link_generic(struct e1000_hw *hw); s32 igb_check_for_serdes_link_generic(struct e1000_hw *hw); s32 igb_cleanup_led_generic(struct e1000_hw *hw); s32 igb_config_fc_after_link_up_generic(struct e1000_hw *hw); s32 igb_disable_pcie_master_generic(struct e1000_hw *hw); s32 igb_force_mac_fc_generic(struct e1000_hw *hw); s32 igb_get_auto_rd_done_generic(struct e1000_hw *hw); s32 igb_get_bus_info_pcie_generic(struct e1000_hw *hw); void igb_set_lan_id_single_port(struct e1000_hw *hw); s32 igb_get_hw_semaphore_generic(struct e1000_hw *hw); s32 igb_get_speed_and_duplex_copper_generic(struct e1000_hw *hw, u16 *speed, u16 *duplex); s32 igb_get_speed_and_duplex_fiber_serdes_generic(struct e1000_hw *hw, u16 *speed, u16 *duplex); s32 igb_id_led_init_generic(struct e1000_hw *hw); s32 igb_led_on_generic(struct e1000_hw *hw); s32 igb_led_off_generic(struct e1000_hw *hw); void igb_update_mc_addr_list_generic(struct e1000_hw *hw, u8 *mc_addr_list, u32 mc_addr_count); s32 igb_set_fc_watermarks_generic(struct e1000_hw *hw); s32 igb_setup_fiber_serdes_link_generic(struct e1000_hw *hw); s32 igb_setup_led_generic(struct e1000_hw *hw); s32 igb_setup_link_generic(struct e1000_hw *hw); s32 igb_write_8bit_ctrl_reg_generic(struct e1000_hw *hw, u32 reg, u32 offset, u8 data); u32 igb_hash_mc_addr_generic(struct e1000_hw *hw, u8 *mc_addr); void igb_clear_hw_cntrs_base_generic(struct e1000_hw *hw); void igb_clear_vfta_generic(struct e1000_hw *hw); void igb_config_collision_dist_generic(struct e1000_hw *hw); void igb_init_rx_addrs_generic(struct e1000_hw *hw, u16 rar_count); void igb_mta_set_generic(struct e1000_hw *hw, u32 hash_value); void igb_pcix_mmrbc_workaround_generic(struct e1000_hw *hw); void igb_put_hw_semaphore_generic(struct e1000_hw *hw); void igb_rar_set_generic(struct e1000_hw *hw, u8 *addr, u32 index); s32 igb_check_alt_mac_addr_generic(struct e1000_hw *hw); void igb_reset_adaptive_generic(struct e1000_hw *hw); void igb_set_pcie_no_snoop_generic(struct e1000_hw *hw, u32 no_snoop); void igb_update_adaptive_generic(struct e1000_hw *hw); void igb_write_vfta_generic(struct e1000_hw *hw, u32 offset, u32 value); #endif /* _IGB_MAC_H_ */