2018-03-23 01:08:48 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2018-04-26 23:08:09 +08:00
|
|
|
/* Copyright(c) 2007 - 2018 Intel Corporation. */
|
2008-01-24 18:22:38 +08:00
|
|
|
|
|
|
|
#ifndef _E1000_NVM_H_
|
|
|
|
#define _E1000_NVM_H_
|
|
|
|
|
|
|
|
s32 igb_acquire_nvm(struct e1000_hw *hw);
|
|
|
|
void igb_release_nvm(struct e1000_hw *hw);
|
|
|
|
s32 igb_read_mac_addr(struct e1000_hw *hw);
|
|
|
|
s32 igb_read_part_num(struct e1000_hw *hw, u32 *part_num);
|
2010-11-23 01:17:21 +08:00
|
|
|
s32 igb_read_part_string(struct e1000_hw *hw, u8 *part_num,
|
2014-04-11 09:45:34 +08:00
|
|
|
u32 part_num_size);
|
2008-01-24 18:22:38 +08:00
|
|
|
s32 igb_read_nvm_eerd(struct e1000_hw *hw, u16 offset, u16 words, u16 *data);
|
2011-03-12 12:43:18 +08:00
|
|
|
s32 igb_read_nvm_spi(struct e1000_hw *hw, u16 offset, u16 words, u16 *data);
|
2008-01-24 18:22:38 +08:00
|
|
|
s32 igb_write_nvm_spi(struct e1000_hw *hw, u16 offset, u16 words, u16 *data);
|
|
|
|
s32 igb_validate_nvm_checksum(struct e1000_hw *hw);
|
|
|
|
s32 igb_update_nvm_checksum(struct e1000_hw *hw);
|
|
|
|
|
2012-10-18 15:16:19 +08:00
|
|
|
struct e1000_fw_version {
|
|
|
|
u32 etrack_id;
|
|
|
|
u16 eep_major;
|
|
|
|
u16 eep_minor;
|
2013-07-17 03:25:33 +08:00
|
|
|
u16 eep_build;
|
2012-10-18 15:16:19 +08:00
|
|
|
|
|
|
|
u8 invm_major;
|
|
|
|
u8 invm_minor;
|
|
|
|
u8 invm_img_type;
|
|
|
|
|
|
|
|
bool or_valid;
|
|
|
|
u16 or_major;
|
|
|
|
u16 or_build;
|
|
|
|
u16 or_patch;
|
|
|
|
};
|
|
|
|
void igb_get_fw_version(struct e1000_hw *hw, struct e1000_fw_version *fw_vers);
|
|
|
|
|
2008-01-24 18:22:38 +08:00
|
|
|
#endif
|