1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2018-2021 Beijing WangXun Technology Co., Ltd.
3 * Copyright(c) 2010-2017 Intel Corporation
11 #define NGBE_EM_MAX_TX_QUEUES 8
12 #define NGBE_EM_MAX_RX_QUEUES 8
13 #define NGBE_EM_RAR_ENTRIES 32
14 #define NGBE_EM_MC_TBL_SIZE 32
15 #define NGBE_EM_VFT_TBL_SIZE 128
17 s32 ngbe_init_hw(struct ngbe_hw *hw);
18 s32 ngbe_start_hw(struct ngbe_hw *hw);
19 s32 ngbe_reset_hw_em(struct ngbe_hw *hw);
20 s32 ngbe_stop_hw(struct ngbe_hw *hw);
21 s32 ngbe_clear_hw_cntrs(struct ngbe_hw *hw);
22 s32 ngbe_get_mac_addr(struct ngbe_hw *hw, u8 *mac_addr);
24 void ngbe_set_lan_id_multi_port(struct ngbe_hw *hw);
26 s32 ngbe_check_mac_link_em(struct ngbe_hw *hw, u32 *speed,
27 bool *link_up, bool link_up_wait_to_complete);
28 s32 ngbe_get_link_capabilities_em(struct ngbe_hw *hw,
31 s32 ngbe_setup_mac_link_em(struct ngbe_hw *hw,
33 bool autoneg_wait_to_complete);
35 s32 ngbe_set_rar(struct ngbe_hw *hw, u32 index, u8 *addr, u32 vmdq,
37 s32 ngbe_clear_rar(struct ngbe_hw *hw, u32 index);
38 s32 ngbe_init_rx_addrs(struct ngbe_hw *hw);
39 s32 ngbe_update_mc_addr_list(struct ngbe_hw *hw, u8 *mc_addr_list,
41 ngbe_mc_addr_itr func, bool clear);
42 s32 ngbe_disable_sec_rx_path(struct ngbe_hw *hw);
43 s32 ngbe_enable_sec_rx_path(struct ngbe_hw *hw);
45 s32 ngbe_validate_mac_addr(u8 *mac_addr);
46 s32 ngbe_acquire_swfw_sync(struct ngbe_hw *hw, u32 mask);
47 void ngbe_release_swfw_sync(struct ngbe_hw *hw, u32 mask);
49 s32 ngbe_set_vmdq(struct ngbe_hw *hw, u32 rar, u32 vmdq);
50 s32 ngbe_clear_vmdq(struct ngbe_hw *hw, u32 rar, u32 vmdq);
51 s32 ngbe_init_uta_tables(struct ngbe_hw *hw);
52 s32 ngbe_clear_vfta(struct ngbe_hw *hw);
54 void ngbe_set_mac_anti_spoofing(struct ngbe_hw *hw, bool enable, int vf);
55 void ngbe_set_vlan_anti_spoofing(struct ngbe_hw *hw, bool enable, int vf);
56 s32 ngbe_init_thermal_sensor_thresh(struct ngbe_hw *hw);
57 s32 ngbe_mac_check_overtemp(struct ngbe_hw *hw);
58 void ngbe_disable_rx(struct ngbe_hw *hw);
59 void ngbe_enable_rx(struct ngbe_hw *hw);
60 void ngbe_set_mta(struct ngbe_hw *hw, u8 *mc_addr);
61 s32 ngbe_init_shared_code(struct ngbe_hw *hw);
62 s32 ngbe_set_mac_type(struct ngbe_hw *hw);
63 s32 ngbe_init_ops_pf(struct ngbe_hw *hw);
64 s32 ngbe_init_phy(struct ngbe_hw *hw);
65 s32 ngbe_enable_rx_dma(struct ngbe_hw *hw, u32 regval);
66 void ngbe_map_device_id(struct ngbe_hw *hw);
68 #endif /* _NGBE_HW_H_ */