1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2015-2020
8 #include "txgbe_type.h"
10 s32 txgbe_init_hw(struct txgbe_hw *hw);
11 s32 txgbe_start_hw(struct txgbe_hw *hw);
12 s32 txgbe_stop_hw(struct txgbe_hw *hw);
13 s32 txgbe_start_hw_gen2(struct txgbe_hw *hw);
14 s32 txgbe_get_mac_addr(struct txgbe_hw *hw, u8 *mac_addr);
16 void txgbe_set_lan_id_multi_port(struct txgbe_hw *hw);
18 s32 txgbe_set_rar(struct txgbe_hw *hw, u32 index, u8 *addr, u32 vmdq,
20 s32 txgbe_clear_rar(struct txgbe_hw *hw, u32 index);
21 s32 txgbe_init_rx_addrs(struct txgbe_hw *hw);
22 s32 txgbe_update_mc_addr_list(struct txgbe_hw *hw, u8 *mc_addr_list,
24 txgbe_mc_addr_itr func, bool clear);
25 s32 txgbe_disable_sec_rx_path(struct txgbe_hw *hw);
26 s32 txgbe_enable_sec_rx_path(struct txgbe_hw *hw);
27 s32 txgbe_disable_sec_tx_path(struct txgbe_hw *hw);
28 s32 txgbe_enable_sec_tx_path(struct txgbe_hw *hw);
30 s32 txgbe_validate_mac_addr(u8 *mac_addr);
32 s32 txgbe_get_san_mac_addr(struct txgbe_hw *hw, u8 *san_mac_addr);
33 s32 txgbe_set_san_mac_addr(struct txgbe_hw *hw, u8 *san_mac_addr);
35 s32 txgbe_init_uta_tables(struct txgbe_hw *hw);
36 s32 txgbe_check_mac_link(struct txgbe_hw *hw,
38 bool *link_up, bool link_up_wait_to_complete);
40 s32 txgbe_get_device_caps(struct txgbe_hw *hw, u16 *device_caps);
41 void txgbe_clear_tx_pending(struct txgbe_hw *hw);
43 s32 txgbe_reset_pipeline_raptor(struct txgbe_hw *hw);
45 void txgbe_disable_rx(struct txgbe_hw *hw);
46 void txgbe_enable_rx(struct txgbe_hw *hw);
47 s32 txgbe_setup_mac_link_multispeed_fiber(struct txgbe_hw *hw,
49 bool autoneg_wait_to_complete);
50 void txgbe_set_mta(struct txgbe_hw *hw, u8 *mc_addr);
51 s32 txgbe_init_shared_code(struct txgbe_hw *hw);
52 s32 txgbe_set_mac_type(struct txgbe_hw *hw);
53 s32 txgbe_init_ops_pf(struct txgbe_hw *hw);
54 s32 txgbe_get_link_capabilities_raptor(struct txgbe_hw *hw,
55 u32 *speed, bool *autoneg);
56 u32 txgbe_get_media_type_raptor(struct txgbe_hw *hw);
57 void txgbe_disable_tx_laser_multispeed_fiber(struct txgbe_hw *hw);
58 void txgbe_enable_tx_laser_multispeed_fiber(struct txgbe_hw *hw);
59 void txgbe_flap_tx_laser_multispeed_fiber(struct txgbe_hw *hw);
60 void txgbe_set_hard_rate_select_speed(struct txgbe_hw *hw,
62 s32 txgbe_setup_mac_link_smartspeed(struct txgbe_hw *hw,
64 bool autoneg_wait_to_complete);
65 s32 txgbe_start_mac_link_raptor(struct txgbe_hw *hw,
66 bool autoneg_wait_to_complete);
67 s32 txgbe_setup_mac_link(struct txgbe_hw *hw, u32 speed,
68 bool autoneg_wait_to_complete);
69 s32 txgbe_setup_sfp_modules(struct txgbe_hw *hw);
70 void txgbe_init_mac_link_ops(struct txgbe_hw *hw);
71 s32 txgbe_reset_hw(struct txgbe_hw *hw);
72 s32 txgbe_start_hw_raptor(struct txgbe_hw *hw);
73 s32 txgbe_init_phy_raptor(struct txgbe_hw *hw);
74 s32 txgbe_enable_rx_dma_raptor(struct txgbe_hw *hw, u32 regval);
75 bool txgbe_verify_lesm_fw_enabled_raptor(struct txgbe_hw *hw);
76 #endif /* _TXGBE_HW_H_ */