aboutsummaryrefslogtreecommitdiff
path: root/src/drivers/net/e1000e/e1000e_nvm.h
blob: 1a8e0f3fc43c9da2e0b57a8eac77a8db7757c7dd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/*******************************************************************************

  Intel PRO/1000 Linux driver
  Copyright(c) 1999 - 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:
  Linux NICS <linux.nics@intel.com>
  e1000-devel Mailing List <e1000-devel@lists.sourceforge.net>
  Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497

*******************************************************************************/

FILE_LICENCE ( GPL2_OR_LATER );

#ifndef _E1000E_NVM_H_
#define _E1000E_NVM_H_

void e1000e_init_nvm_ops_generic(struct e1000_hw *hw);
s32  e1000e_acquire_nvm(struct e1000_hw *hw);

s32  e1000e_poll_eerd_eewr_done(struct e1000_hw *hw, int ee_reg);
s32  e1000e_read_mac_addr_generic(struct e1000_hw *hw);
s32  e1000e_read_pba_num(struct e1000_hw *hw, u32 *pba_num);
s32  e1000e_read_nvm_eerd(struct e1000_hw *hw, u16 offset, u16 words,
                         u16 *data);
s32  e1000e_valid_led_default(struct e1000_hw *hw, u16 *data);
s32  e1000e_validate_nvm_checksum_generic(struct e1000_hw *hw);
s32  e1000e_write_nvm_eewr(struct e1000_hw *hw, u16 offset,
                          u16 words, u16 *data);
s32  e1000e_write_nvm_spi(struct e1000_hw *hw, u16 offset, u16 words,
                         u16 *data);
s32  e1000e_update_nvm_checksum_generic(struct e1000_hw *hw);
void e1000e_release_nvm(struct e1000_hw *hw);

#define E1000_STM_OPCODE  0xDB00

#endif