DPDK logo

Elixir Cross Referencer

/* SPDX-License-Identifier: BSD-3-Clause
 * Copyright(c) 2001-2020 Intel Corporation
 */

#ifndef _IGC_API_H_
#define _IGC_API_H_

#include "igc_hw.h"

/* I2C SDA and SCL timing parameters for standard mode */
#define IGC_I2C_T_HD_STA	4
#define IGC_I2C_T_LOW		5
#define IGC_I2C_T_HIGH		4
#define IGC_I2C_T_SU_STA	5
#define IGC_I2C_T_HD_DATA	5
#define IGC_I2C_T_SU_DATA	1
#define IGC_I2C_T_RISE		1
#define IGC_I2C_T_FALL		1
#define IGC_I2C_T_SU_STO	4
#define IGC_I2C_T_BUF		5

s32 igc_set_i2c_bb(struct igc_hw *hw);
s32 igc_read_i2c_byte_generic(struct igc_hw *hw, u8 byte_offset,
				u8 dev_addr, u8 *data);
s32 igc_write_i2c_byte_generic(struct igc_hw *hw, u8 byte_offset,
				 u8 dev_addr, u8 data);
void igc_i2c_bus_clear(struct igc_hw *hw);

void igc_init_function_pointers_82542(struct igc_hw *hw);
void igc_init_function_pointers_82543(struct igc_hw *hw);
void igc_init_function_pointers_82540(struct igc_hw *hw);
void igc_init_function_pointers_82571(struct igc_hw *hw);
void igc_init_function_pointers_82541(struct igc_hw *hw);
void igc_init_function_pointers_80003es2lan(struct igc_hw *hw);
void igc_init_function_pointers_ich8lan(struct igc_hw *hw);
void igc_init_function_pointers_82575(struct igc_hw *hw);
void igc_init_function_pointers_vf(struct igc_hw *hw);
void igc_power_up_fiber_serdes_link(struct igc_hw *hw);
void igc_shutdown_fiber_serdes_link(struct igc_hw *hw);
void igc_init_function_pointers_i210(struct igc_hw *hw);
void igc_init_function_pointers_i225(struct igc_hw *hw);

s32 igc_set_obff_timer(struct igc_hw *hw, u32 itr);
s32 igc_set_mac_type(struct igc_hw *hw);
s32 igc_setup_init_funcs(struct igc_hw *hw, bool init_device);
s32 igc_init_mac_params(struct igc_hw *hw);
s32 igc_init_nvm_params(struct igc_hw *hw);
s32 igc_init_phy_params(struct igc_hw *hw);
s32 igc_init_mbx_params(struct igc_hw *hw);
s32 igc_get_bus_info(struct igc_hw *hw);
void igc_clear_vfta(struct igc_hw *hw);
void igc_write_vfta(struct igc_hw *hw, u32 offset, u32 value);
s32 igc_force_mac_fc(struct igc_hw *hw);
s32 igc_check_for_link(struct igc_hw *hw);
s32 igc_reset_hw(struct igc_hw *hw);
s32 igc_init_hw(struct igc_hw *hw);
s32 igc_setup_link(struct igc_hw *hw);
s32 igc_get_speed_and_duplex(struct igc_hw *hw, u16 *speed, u16 *duplex);
s32 igc_disable_pcie_master(struct igc_hw *hw);
void igc_config_collision_dist(struct igc_hw *hw);
int igc_rar_set(struct igc_hw *hw, u8 *addr, u32 index);
u32 igc_hash_mc_addr(struct igc_hw *hw, u8 *mc_addr);
void igc_update_mc_addr_list(struct igc_hw *hw, u8 *mc_addr_list,
			       u32 mc_addr_count);
s32 igc_setup_led(struct igc_hw *hw);
s32 igc_cleanup_led(struct igc_hw *hw);
s32 igc_check_reset_block(struct igc_hw *hw);
s32 igc_blink_led(struct igc_hw *hw);
s32 igc_led_on(struct igc_hw *hw);
s32 igc_led_off(struct igc_hw *hw);
s32 igc_id_led_init(struct igc_hw *hw);
void igc_reset_adaptive(struct igc_hw *hw);
void igc_update_adaptive(struct igc_hw *hw);
s32 igc_get_cable_length(struct igc_hw *hw);
s32 igc_validate_mdi_setting(struct igc_hw *hw);
s32 igc_read_phy_reg(struct igc_hw *hw, u32 offset, u16 *data);
s32 igc_write_phy_reg(struct igc_hw *hw, u32 offset, u16 data);
s32 igc_write_8bit_ctrl_reg(struct igc_hw *hw, u32 reg, u32 offset,
			      u8 data);
s32 igc_get_phy_info(struct igc_hw *hw);
void igc_release_phy(struct igc_hw *hw);
s32 igc_acquire_phy(struct igc_hw *hw);
s32 igc_cfg_on_link_up(struct igc_hw *hw);
s32 igc_phy_hw_reset(struct igc_hw *hw);
s32 igc_phy_commit(struct igc_hw *hw);
void igc_power_up_phy(struct igc_hw *hw);
void igc_power_down_phy(struct igc_hw *hw);
s32 igc_read_mac_addr(struct igc_hw *hw);
s32 igc_read_pba_num(struct igc_hw *hw, u32 *part_num);
s32 igc_read_pba_string(struct igc_hw *hw, u8 *pba_num, u32 pba_num_size);
s32 igc_read_pba_length(struct igc_hw *hw, u32 *pba_num_size);
void igc_reload_nvm(struct igc_hw *hw);
s32 igc_update_nvm_checksum(struct igc_hw *hw);
s32 igc_validate_nvm_checksum(struct igc_hw *hw);
s32 igc_read_nvm(struct igc_hw *hw, u16 offset, u16 words, u16 *data);
s32 igc_read_kmrn_reg(struct igc_hw *hw, u32 offset, u16 *data);
s32 igc_write_kmrn_reg(struct igc_hw *hw, u32 offset, u16 data);
s32 igc_write_nvm(struct igc_hw *hw, u16 offset, u16 words, u16 *data);
s32 igc_set_d3_lplu_state(struct igc_hw *hw, bool active);
s32 igc_set_d0_lplu_state(struct igc_hw *hw, bool active);
bool igc_check_mng_mode(struct igc_hw *hw);
bool igc_enable_tx_pkt_filtering(struct igc_hw *hw);
s32 igc_mng_enable_host_if(struct igc_hw *hw);
s32 igc_mng_host_if_write(struct igc_hw *hw, u8 *buffer, u16 length,
			    u16 offset, u8 *sum);
s32 igc_mng_write_cmd_header(struct igc_hw *hw,
			       struct igc_host_mng_command_header *hdr);
s32 igc_mng_write_dhcp_info(struct igc_hw *hw, u8 *buffer, u16 length);
u32  igc_translate_register_82542(u32 reg);

#endif /* _IGC_API_H_ */