Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
9df5b0d8
Commit
9df5b0d8
authored
Apr 27, 2003
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[netdrvr ixgb] use standard kernel u8/u16/u32 types
parent
ca247341
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
247 additions
and
247 deletions
+247
-247
drivers/net/ixgb/ixgb.h
drivers/net/ixgb/ixgb.h
+9
-9
drivers/net/ixgb/ixgb_ee.c
drivers/net/ixgb/ixgb_ee.c
+43
-43
drivers/net/ixgb/ixgb_ee.h
drivers/net/ixgb/ixgb_ee.h
+19
-19
drivers/net/ixgb/ixgb_ethtool.c
drivers/net/ixgb/ixgb_ethtool.c
+13
-13
drivers/net/ixgb/ixgb_hw.c
drivers/net/ixgb/ixgb_hw.c
+60
-60
drivers/net/ixgb/ixgb_hw.h
drivers/net/ixgb/ixgb_hw.h
+67
-67
drivers/net/ixgb/ixgb_main.c
drivers/net/ixgb/ixgb_main.c
+36
-36
No files found.
drivers/net/ixgb/ixgb.h
View file @
9df5b0d8
...
@@ -135,11 +135,11 @@ struct ixgb_adapter {
...
@@ -135,11 +135,11 @@ struct ixgb_adapter {
struct
timer_list
watchdog_timer
;
struct
timer_list
watchdog_timer
;
struct
vlan_group
*
vlgrp
;
struct
vlan_group
*
vlgrp
;
char
*
id_string
;
char
*
id_string
;
u
int32_t
bd_number
;
u
32
bd_number
;
u
int32_t
rx_buffer_len
;
u
32
rx_buffer_len
;
u
int32_t
part_num
;
u
32
part_num
;
u
int16_t
link_speed
;
u
16
link_speed
;
u
int16_t
link_duplex
;
u
16
link_duplex
;
atomic_t
irq_sem
;
atomic_t
irq_sem
;
struct
work_struct
tx_timeout_task
;
struct
work_struct
tx_timeout_task
;
...
@@ -154,19 +154,19 @@ struct ixgb_adapter {
...
@@ -154,19 +154,19 @@ struct ixgb_adapter {
/* TX */
/* TX */
struct
ixgb_desc_ring
tx_ring
;
struct
ixgb_desc_ring
tx_ring
;
unsigned
long
timeo_start
;
unsigned
long
timeo_start
;
u
int32_t
tx_cmd_type
;
u
32
tx_cmd_type
;
int
max_data_per_txd
;
int
max_data_per_txd
;
uint64_t
hw_csum_tx_good
;
uint64_t
hw_csum_tx_good
;
uint64_t
hw_csum_tx_error
;
uint64_t
hw_csum_tx_error
;
boolean_t
tx_csum
;
boolean_t
tx_csum
;
u
int32_t
tx_int_delay
;
u
32
tx_int_delay
;
boolean_t
tx_int_delay_enable
;
boolean_t
tx_int_delay_enable
;
/* RX */
/* RX */
struct
ixgb_desc_ring
rx_ring
;
struct
ixgb_desc_ring
rx_ring
;
uint64_t
hw_csum_rx_error
;
uint64_t
hw_csum_rx_error
;
uint64_t
hw_csum_rx_good
;
uint64_t
hw_csum_rx_good
;
u
int32_t
rx_int_delay
;
u
32
rx_int_delay
;
boolean_t
raidc
;
boolean_t
raidc
;
boolean_t
rx_csum
;
boolean_t
rx_csum
;
...
@@ -178,7 +178,7 @@ struct ixgb_adapter {
...
@@ -178,7 +178,7 @@ struct ixgb_adapter {
/* structs defined in ixgb_hw.h */
/* structs defined in ixgb_hw.h */
struct
ixgb_hw
hw
;
struct
ixgb_hw
hw
;
struct
ixgb_hw_stats
stats
;
struct
ixgb_hw_stats
stats
;
u
int32_t
pci_state
[
16
];
u
32
pci_state
[
16
];
char
ifname
[
IFNAMSIZ
];
char
ifname
[
IFNAMSIZ
];
};
};
...
...
drivers/net/ixgb/ixgb_ee.c
View file @
9df5b0d8
...
@@ -28,10 +28,10 @@
...
@@ -28,10 +28,10 @@
#include "ixgb_hw.h"
#include "ixgb_hw.h"
#include "ixgb_ee.h"
#include "ixgb_ee.h"
/* Local prototypes */
/* Local prototypes */
static
u
int16_t
ixgb_shift_in_bits
(
struct
ixgb_hw
*
hw
);
static
u
16
ixgb_shift_in_bits
(
struct
ixgb_hw
*
hw
);
static
void
ixgb_shift_out_bits
(
struct
ixgb_hw
*
hw
,
static
void
ixgb_shift_out_bits
(
struct
ixgb_hw
*
hw
,
u
int16_t
data
,
uint16_t
count
);
u
16
data
,
u16
count
);
static
void
ixgb_standby_eeprom
(
struct
ixgb_hw
*
hw
);
static
void
ixgb_standby_eeprom
(
struct
ixgb_hw
*
hw
);
static
boolean_t
ixgb_wait_eeprom_command
(
struct
ixgb_hw
*
hw
);
static
boolean_t
ixgb_wait_eeprom_command
(
struct
ixgb_hw
*
hw
);
...
@@ -45,7 +45,7 @@ static void ixgb_cleanup_eeprom(struct ixgb_hw *hw);
...
@@ -45,7 +45,7 @@ static void ixgb_cleanup_eeprom(struct ixgb_hw *hw);
* eecd_reg - EECD's current value
* eecd_reg - EECD's current value
*****************************************************************************/
*****************************************************************************/
static
void
static
void
ixgb_raise_clock
(
struct
ixgb_hw
*
hw
,
u
int32_t
*
eecd_reg
)
ixgb_raise_clock
(
struct
ixgb_hw
*
hw
,
u
32
*
eecd_reg
)
{
{
/* Raise the clock input to the EEPROM (by setting the SK bit), and then
/* Raise the clock input to the EEPROM (by setting the SK bit), and then
* wait 50 microseconds.
* wait 50 microseconds.
...
@@ -63,7 +63,7 @@ ixgb_raise_clock(struct ixgb_hw *hw, uint32_t * eecd_reg)
...
@@ -63,7 +63,7 @@ ixgb_raise_clock(struct ixgb_hw *hw, uint32_t * eecd_reg)
* eecd_reg - EECD's current value
* eecd_reg - EECD's current value
*****************************************************************************/
*****************************************************************************/
static
void
static
void
ixgb_lower_clock
(
struct
ixgb_hw
*
hw
,
u
int32_t
*
eecd_reg
)
ixgb_lower_clock
(
struct
ixgb_hw
*
hw
,
u
32
*
eecd_reg
)
{
{
/* Lower the clock input to the EEPROM (by clearing the SK bit), and then
/* Lower the clock input to the EEPROM (by clearing the SK bit), and then
* wait 50 microseconds.
* wait 50 microseconds.
...
@@ -82,10 +82,10 @@ ixgb_lower_clock(struct ixgb_hw *hw, uint32_t * eecd_reg)
...
@@ -82,10 +82,10 @@ ixgb_lower_clock(struct ixgb_hw *hw, uint32_t * eecd_reg)
* count - number of bits to shift out
* count - number of bits to shift out
*****************************************************************************/
*****************************************************************************/
static
void
static
void
ixgb_shift_out_bits
(
struct
ixgb_hw
*
hw
,
u
int16_t
data
,
uint16_t
count
)
ixgb_shift_out_bits
(
struct
ixgb_hw
*
hw
,
u
16
data
,
u16
count
)
{
{
u
int32_t
eecd_reg
;
u
32
eecd_reg
;
u
int32_t
mask
;
u
32
mask
;
/* We need to shift "count" bits out to the EEPROM. So, value in the
/* We need to shift "count" bits out to the EEPROM. So, value in the
* "data" parameter will be shifted out to the EEPROM one bit at a time.
* "data" parameter will be shifted out to the EEPROM one bit at a time.
...
@@ -127,12 +127,12 @@ ixgb_shift_out_bits(struct ixgb_hw *hw, uint16_t data, uint16_t count)
...
@@ -127,12 +127,12 @@ ixgb_shift_out_bits(struct ixgb_hw *hw, uint16_t data, uint16_t count)
*
*
* hw - Struct containing variables accessed by shared code
* hw - Struct containing variables accessed by shared code
*****************************************************************************/
*****************************************************************************/
static
u
int16_t
static
u
16
ixgb_shift_in_bits
(
struct
ixgb_hw
*
hw
)
ixgb_shift_in_bits
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
eecd_reg
;
u
32
eecd_reg
;
u
int32_t
i
;
u
32
i
;
u
int16_t
data
;
u
16
data
;
/* In order to read a register from the EEPROM, we need to shift 16 bits
/* In order to read a register from the EEPROM, we need to shift 16 bits
* in from the EEPROM. Bits are "shifted in" by raising the clock input to
* in from the EEPROM. Bits are "shifted in" by raising the clock input to
...
@@ -173,7 +173,7 @@ ixgb_shift_in_bits(struct ixgb_hw *hw)
...
@@ -173,7 +173,7 @@ ixgb_shift_in_bits(struct ixgb_hw *hw)
static
void
static
void
ixgb_setup_eeprom
(
struct
ixgb_hw
*
hw
)
ixgb_setup_eeprom
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
eecd_reg
;
u
32
eecd_reg
;
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
...
@@ -195,7 +195,7 @@ ixgb_setup_eeprom(struct ixgb_hw *hw)
...
@@ -195,7 +195,7 @@ ixgb_setup_eeprom(struct ixgb_hw *hw)
static
void
static
void
ixgb_standby_eeprom
(
struct
ixgb_hw
*
hw
)
ixgb_standby_eeprom
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
eecd_reg
;
u
32
eecd_reg
;
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
...
@@ -229,7 +229,7 @@ ixgb_standby_eeprom(struct ixgb_hw *hw)
...
@@ -229,7 +229,7 @@ ixgb_standby_eeprom(struct ixgb_hw *hw)
static
void
static
void
ixgb_clock_eeprom
(
struct
ixgb_hw
*
hw
)
ixgb_clock_eeprom
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
eecd_reg
;
u
32
eecd_reg
;
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
...
@@ -253,7 +253,7 @@ ixgb_clock_eeprom(struct ixgb_hw *hw)
...
@@ -253,7 +253,7 @@ ixgb_clock_eeprom(struct ixgb_hw *hw)
static
void
static
void
ixgb_cleanup_eeprom
(
struct
ixgb_hw
*
hw
)
ixgb_cleanup_eeprom
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
eecd_reg
;
u
32
eecd_reg
;
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
eecd_reg
=
IXGB_READ_REG
(
hw
,
EECD
);
...
@@ -279,8 +279,8 @@ ixgb_cleanup_eeprom(struct ixgb_hw *hw)
...
@@ -279,8 +279,8 @@ ixgb_cleanup_eeprom(struct ixgb_hw *hw)
static
boolean_t
static
boolean_t
ixgb_wait_eeprom_command
(
struct
ixgb_hw
*
hw
)
ixgb_wait_eeprom_command
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
eecd_reg
;
u
32
eecd_reg
;
u
int32_t
i
;
u
32
i
;
/* Toggle the CS line. This in effect tells to EEPROM to actually execute
/* Toggle the CS line. This in effect tells to EEPROM to actually execute
* the command in question.
* the command in question.
...
@@ -319,13 +319,13 @@ ixgb_wait_eeprom_command(struct ixgb_hw *hw)
...
@@ -319,13 +319,13 @@ ixgb_wait_eeprom_command(struct ixgb_hw *hw)
boolean_t
boolean_t
ixgb_validate_eeprom_checksum
(
struct
ixgb_hw
*
hw
)
ixgb_validate_eeprom_checksum
(
struct
ixgb_hw
*
hw
)
{
{
u
int16_t
checksum
=
0
;
u
16
checksum
=
0
;
u
int16_t
i
;
u
16
i
;
for
(
i
=
0
;
i
<
(
EEPROM_CHECKSUM_REG
+
1
);
i
++
)
for
(
i
=
0
;
i
<
(
EEPROM_CHECKSUM_REG
+
1
);
i
++
)
checksum
+=
ixgb_read_eeprom
(
hw
,
i
);
checksum
+=
ixgb_read_eeprom
(
hw
,
i
);
if
(
checksum
==
(
u
int16_t
)
EEPROM_SUM
)
if
(
checksum
==
(
u
16
)
EEPROM_SUM
)
return
(
TRUE
);
return
(
TRUE
);
else
else
return
(
FALSE
);
return
(
FALSE
);
...
@@ -342,13 +342,13 @@ ixgb_validate_eeprom_checksum(struct ixgb_hw * hw)
...
@@ -342,13 +342,13 @@ ixgb_validate_eeprom_checksum(struct ixgb_hw * hw)
void
void
ixgb_update_eeprom_checksum
(
struct
ixgb_hw
*
hw
)
ixgb_update_eeprom_checksum
(
struct
ixgb_hw
*
hw
)
{
{
u
int16_t
checksum
=
0
;
u
16
checksum
=
0
;
u
int16_t
i
;
u
16
i
;
for
(
i
=
0
;
i
<
EEPROM_CHECKSUM_REG
;
i
++
)
for
(
i
=
0
;
i
<
EEPROM_CHECKSUM_REG
;
i
++
)
checksum
+=
ixgb_read_eeprom
(
hw
,
i
);
checksum
+=
ixgb_read_eeprom
(
hw
,
i
);
checksum
=
(
u
int16_t
)
EEPROM_SUM
-
checksum
;
checksum
=
(
u
16
)
EEPROM_SUM
-
checksum
;
ixgb_write_eeprom
(
hw
,
EEPROM_CHECKSUM_REG
,
checksum
);
ixgb_write_eeprom
(
hw
,
EEPROM_CHECKSUM_REG
,
checksum
);
return
;
return
;
...
@@ -366,7 +366,7 @@ ixgb_update_eeprom_checksum(struct ixgb_hw *hw)
...
@@ -366,7 +366,7 @@ ixgb_update_eeprom_checksum(struct ixgb_hw *hw)
*
*
*****************************************************************************/
*****************************************************************************/
void
void
ixgb_write_eeprom
(
struct
ixgb_hw
*
hw
,
u
int16_t
offset
,
uint16_t
data
)
ixgb_write_eeprom
(
struct
ixgb_hw
*
hw
,
u
16
offset
,
u16
data
)
{
{
/* Prepare the EEPROM for writing */
/* Prepare the EEPROM for writing */
ixgb_setup_eeprom
(
hw
);
ixgb_setup_eeprom
(
hw
);
...
@@ -414,10 +414,10 @@ ixgb_write_eeprom(struct ixgb_hw *hw, uint16_t offset, uint16_t data)
...
@@ -414,10 +414,10 @@ ixgb_write_eeprom(struct ixgb_hw *hw, uint16_t offset, uint16_t data)
* Returns:
* Returns:
* The 16-bit value read from the eeprom
* The 16-bit value read from the eeprom
*****************************************************************************/
*****************************************************************************/
u
int16_t
u
16
ixgb_read_eeprom
(
struct
ixgb_hw
*
hw
,
u
int16_t
offset
)
ixgb_read_eeprom
(
struct
ixgb_hw
*
hw
,
u
16
offset
)
{
{
u
int16_t
data
;
u
16
data
;
/* Prepare the EEPROM for reading */
/* Prepare the EEPROM for reading */
ixgb_setup_eeprom
(
hw
);
ixgb_setup_eeprom
(
hw
);
...
@@ -451,8 +451,8 @@ ixgb_read_eeprom(struct ixgb_hw * hw, uint16_t offset)
...
@@ -451,8 +451,8 @@ ixgb_read_eeprom(struct ixgb_hw * hw, uint16_t offset)
boolean_t
boolean_t
ixgb_get_eeprom_data
(
struct
ixgb_hw
*
hw
)
ixgb_get_eeprom_data
(
struct
ixgb_hw
*
hw
)
{
{
u
int16_t
i
;
u
16
i
;
u
int16_t
checksum
=
0
;
u
16
checksum
=
0
;
struct
ixgb_ee_map_type
*
ee_map
;
struct
ixgb_ee_map_type
*
ee_map
;
DEBUGFUNC
(
"ixgb_get_eeprom_data"
);
DEBUGFUNC
(
"ixgb_get_eeprom_data"
);
...
@@ -461,13 +461,13 @@ ixgb_get_eeprom_data(struct ixgb_hw * hw)
...
@@ -461,13 +461,13 @@ ixgb_get_eeprom_data(struct ixgb_hw * hw)
DEBUGOUT
(
"ixgb_ee: Reading eeprom data
\n
"
);
DEBUGOUT
(
"ixgb_ee: Reading eeprom data
\n
"
);
for
(
i
=
0
;
i
<
IXGB_EEPROM_SIZE
;
i
++
)
{
for
(
i
=
0
;
i
<
IXGB_EEPROM_SIZE
;
i
++
)
{
u
int16_t
ee_data
;
u
16
ee_data
;
ee_data
=
ixgb_read_eeprom
(
hw
,
i
);
ee_data
=
ixgb_read_eeprom
(
hw
,
i
);
checksum
+=
ee_data
;
checksum
+=
ee_data
;
hw
->
eeprom
[
i
]
=
le16_to_cpu
(
ee_data
);
hw
->
eeprom
[
i
]
=
le16_to_cpu
(
ee_data
);
}
}
if
(
checksum
!=
(
u
int16_t
)
EEPROM_SUM
)
{
if
(
checksum
!=
(
u
16
)
EEPROM_SUM
)
{
DEBUGOUT
(
"ixgb_ee: Checksum invalid.
\n
"
);
DEBUGOUT
(
"ixgb_ee: Checksum invalid.
\n
"
);
return
(
FALSE
);
return
(
FALSE
);
}
}
...
@@ -514,7 +514,7 @@ ixgb_check_and_get_eeprom_data(struct ixgb_hw *hw)
...
@@ -514,7 +514,7 @@ ixgb_check_and_get_eeprom_data(struct ixgb_hw *hw)
* Returns: None.
* Returns: None.
******************************************************************************/
******************************************************************************/
void
void
ixgb_get_ee_mac_addr
(
struct
ixgb_hw
*
hw
,
u
int8_t
*
mac_addr
)
ixgb_get_ee_mac_addr
(
struct
ixgb_hw
*
hw
,
u
8
*
mac_addr
)
{
{
int
i
;
int
i
;
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -538,7 +538,7 @@ ixgb_get_ee_mac_addr(struct ixgb_hw *hw, uint8_t * mac_addr)
...
@@ -538,7 +538,7 @@ ixgb_get_ee_mac_addr(struct ixgb_hw *hw, uint8_t * mac_addr)
* Returns:
* Returns:
* compatibility flags if EEPROM contents are valid, 0 otherwise
* compatibility flags if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_compatibility
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_compatibility
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -558,7 +558,7 @@ ixgb_get_ee_compatibility(struct ixgb_hw *hw)
...
@@ -558,7 +558,7 @@ ixgb_get_ee_compatibility(struct ixgb_hw *hw)
* Returns:
* Returns:
* PBA number if EEPROM contents are valid, 0 otherwise
* PBA number if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int32_t
u
32
ixgb_get_ee_pba_number
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_pba_number
(
struct
ixgb_hw
*
hw
)
{
{
if
(
ixgb_check_and_get_eeprom_data
(
hw
)
==
TRUE
)
if
(
ixgb_check_and_get_eeprom_data
(
hw
)
==
TRUE
)
...
@@ -576,7 +576,7 @@ ixgb_get_ee_pba_number(struct ixgb_hw * hw)
...
@@ -576,7 +576,7 @@ ixgb_get_ee_pba_number(struct ixgb_hw * hw)
* Returns:
* Returns:
* Initialization Control Word 1 if EEPROM contents are valid, 0 otherwise
* Initialization Control Word 1 if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_init_ctrl_reg_1
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_init_ctrl_reg_1
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -596,7 +596,7 @@ ixgb_get_ee_init_ctrl_reg_1(struct ixgb_hw * hw)
...
@@ -596,7 +596,7 @@ ixgb_get_ee_init_ctrl_reg_1(struct ixgb_hw * hw)
* Returns:
* Returns:
* Initialization Control Word 2 if EEPROM contents are valid, 0 otherwise
* Initialization Control Word 2 if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_init_ctrl_reg_2
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_init_ctrl_reg_2
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -616,7 +616,7 @@ ixgb_get_ee_init_ctrl_reg_2(struct ixgb_hw * hw)
...
@@ -616,7 +616,7 @@ ixgb_get_ee_init_ctrl_reg_2(struct ixgb_hw * hw)
* Returns:
* Returns:
* Subsystem Id if EEPROM contents are valid, 0 otherwise
* Subsystem Id if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_subsystem_id
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_subsystem_id
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -636,7 +636,7 @@ ixgb_get_ee_subsystem_id(struct ixgb_hw * hw)
...
@@ -636,7 +636,7 @@ ixgb_get_ee_subsystem_id(struct ixgb_hw * hw)
* Returns:
* Returns:
* Sub Vendor Id if EEPROM contents are valid, 0 otherwise
* Sub Vendor Id if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_subvendor_id
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_subvendor_id
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -656,7 +656,7 @@ ixgb_get_ee_subvendor_id(struct ixgb_hw * hw)
...
@@ -656,7 +656,7 @@ ixgb_get_ee_subvendor_id(struct ixgb_hw * hw)
* Returns:
* Returns:
* Device Id if EEPROM contents are valid, 0 otherwise
* Device Id if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_device_id
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_device_id
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -676,7 +676,7 @@ ixgb_get_ee_device_id(struct ixgb_hw * hw)
...
@@ -676,7 +676,7 @@ ixgb_get_ee_device_id(struct ixgb_hw * hw)
* Returns:
* Returns:
* Device Id if EEPROM contents are valid, 0 otherwise
* Device Id if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_vendor_id
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_vendor_id
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -696,7 +696,7 @@ ixgb_get_ee_vendor_id(struct ixgb_hw * hw)
...
@@ -696,7 +696,7 @@ ixgb_get_ee_vendor_id(struct ixgb_hw * hw)
* Returns:
* Returns:
* SDP Register if EEPROM contents are valid, 0 otherwise
* SDP Register if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int16_t
u
16
ixgb_get_ee_swdpins_reg
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_swdpins_reg
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -716,7 +716,7 @@ ixgb_get_ee_swdpins_reg(struct ixgb_hw * hw)
...
@@ -716,7 +716,7 @@ ixgb_get_ee_swdpins_reg(struct ixgb_hw * hw)
* Returns:
* Returns:
* D3 Power Management Bits if EEPROM contents are valid, 0 otherwise
* D3 Power Management Bits if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int8_t
u
8
ixgb_get_ee_d3_power
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_d3_power
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
@@ -736,7 +736,7 @@ ixgb_get_ee_d3_power(struct ixgb_hw * hw)
...
@@ -736,7 +736,7 @@ ixgb_get_ee_d3_power(struct ixgb_hw * hw)
* Returns:
* Returns:
* D0 Power Management Bits if EEPROM contents are valid, 0 otherwise
* D0 Power Management Bits if EEPROM contents are valid, 0 otherwise
******************************************************************************/
******************************************************************************/
u
int8_t
u
8
ixgb_get_ee_d0_power
(
struct
ixgb_hw
*
hw
)
ixgb_get_ee_d0_power
(
struct
ixgb_hw
*
hw
)
{
{
struct
ixgb_ee_map_type
*
ee_map
=
struct
ixgb_ee_map_type
*
ee_map
=
...
...
drivers/net/ixgb/ixgb_ee.h
View file @
9df5b0d8
...
@@ -73,32 +73,32 @@
...
@@ -73,32 +73,32 @@
/* EEPROM structure */
/* EEPROM structure */
struct
ixgb_ee_map_type
{
struct
ixgb_ee_map_type
{
u
int8_t
mac_addr
[
IXGB_ETH_LENGTH_OF_ADDRESS
];
u
8
mac_addr
[
IXGB_ETH_LENGTH_OF_ADDRESS
];
u
int16_t
compatibility
;
u
16
compatibility
;
u
int16_t
reserved1
[
4
];
u
16
reserved1
[
4
];
u
int32_t
pba_number
;
u
32
pba_number
;
u
int16_t
init_ctrl_reg_1
;
u
16
init_ctrl_reg_1
;
u
int16_t
subsystem_id
;
u
16
subsystem_id
;
u
int16_t
subvendor_id
;
u
16
subvendor_id
;
u
int16_t
device_id
;
u
16
device_id
;
u
int16_t
vendor_id
;
u
16
vendor_id
;
u
int16_t
init_ctrl_reg_2
;
u
16
init_ctrl_reg_2
;
u
int16_t
oem_reserved
[
16
];
u
16
oem_reserved
[
16
];
u
int16_t
swdpins_reg
;
u
16
swdpins_reg
;
u
int16_t
circuit_ctrl_reg
;
u
16
circuit_ctrl_reg
;
u
int8_t
d3_power
;
u
8
d3_power
;
u
int8_t
d0_power
;
u
8
d0_power
;
u
int16_t
reserved2
[
28
];
u
16
reserved2
[
28
];
u
int16_t
checksum
;
u
16
checksum
;
};
};
/* EEPROM Functions */
/* EEPROM Functions */
u
int16_t
ixgb_read_eeprom
(
struct
ixgb_hw
*
hw
,
uint16_t
reg
);
u
16
ixgb_read_eeprom
(
struct
ixgb_hw
*
hw
,
u16
reg
);
boolean_t
ixgb_validate_eeprom_checksum
(
struct
ixgb_hw
*
hw
);
boolean_t
ixgb_validate_eeprom_checksum
(
struct
ixgb_hw
*
hw
);
void
ixgb_update_eeprom_checksum
(
struct
ixgb_hw
*
hw
);
void
ixgb_update_eeprom_checksum
(
struct
ixgb_hw
*
hw
);
void
ixgb_write_eeprom
(
struct
ixgb_hw
*
hw
,
u
int16_t
reg
,
uint16_t
data
);
void
ixgb_write_eeprom
(
struct
ixgb_hw
*
hw
,
u
16
reg
,
u16
data
);
#endif
/* IXGB_EE_H */
#endif
/* IXGB_EE_H */
drivers/net/ixgb/ixgb_ethtool.c
View file @
9df5b0d8
...
@@ -91,7 +91,7 @@ static int
...
@@ -91,7 +91,7 @@ static int
ixgb_ethtool_promiscuous(struct ixgb_adapter *adapter,
ixgb_ethtool_promiscuous(struct ixgb_adapter *adapter,
struct ethtool_pmode *pmode)
struct ethtool_pmode *pmode)
{
{
u
int32_t
rctl = IXGB_READ_REG(&adapter->hw, RCTL);
u
32
rctl = IXGB_READ_REG(&adapter->hw, RCTL);
pmode->rctl_old = rctl;
pmode->rctl_old = rctl;
if (pmode->upe)
if (pmode->upe)
...
@@ -112,7 +112,7 @@ ixgb_ethtool_promiscuous(struct ixgb_adapter *adapter,
...
@@ -112,7 +112,7 @@ ixgb_ethtool_promiscuous(struct ixgb_adapter *adapter,
}
}
#endif
#endif
#define IXGB_REG_DUMP_LEN 136*sizeof(u
int32_t
)
#define IXGB_REG_DUMP_LEN 136*sizeof(u
32
)
static
void
static
void
ixgb_ethtool_gdrvinfo
(
struct
ixgb_adapter
*
adapter
,
ixgb_ethtool_gdrvinfo
(
struct
ixgb_adapter
*
adapter
,
struct
ethtool_drvinfo
*
drvinfo
)
struct
ethtool_drvinfo
*
drvinfo
)
...
@@ -131,12 +131,12 @@ ixgb_ethtool_gdrvinfo(struct ixgb_adapter *adapter,
...
@@ -131,12 +131,12 @@ ixgb_ethtool_gdrvinfo(struct ixgb_adapter *adapter,
#define IXGB_GET_STAT(_A_, _R_) _A_->stats._R_
#define IXGB_GET_STAT(_A_, _R_) _A_->stats._R_
static
void
static
void
ixgb_ethtool_gregs
(
struct
ixgb_adapter
*
adapter
,
ixgb_ethtool_gregs
(
struct
ixgb_adapter
*
adapter
,
struct
ethtool_regs
*
regs
,
u
int8_t
*
regs_buff
)
struct
ethtool_regs
*
regs
,
u
8
*
regs_buff
)
{
{
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
u
int32_t
*
reg
=
(
uint32_t
*
)
regs_buff
;
u
32
*
reg
=
(
u32
*
)
regs_buff
;
u
int32_t
*
reg_start
=
reg
;
u
32
*
reg_start
=
reg
;
u
int8_t
i
;
u
8
i
;
regs
->
version
=
regs
->
version
=
(
adapter
->
hw
.
device_id
<<
16
)
|
adapter
->
hw
.
subsystem_id
;
(
adapter
->
hw
.
device_id
<<
16
)
|
adapter
->
hw
.
subsystem_id
;
...
@@ -273,13 +273,13 @@ ixgb_ethtool_gregs(struct ixgb_adapter *adapter,
...
@@ -273,13 +273,13 @@ ixgb_ethtool_gregs(struct ixgb_adapter *adapter,
#if 0
#if 0
#endif
#endif
regs
->
len
=
(
reg
-
reg_start
)
*
sizeof
(
u
int32_t
);
regs
->
len
=
(
reg
-
reg_start
)
*
sizeof
(
u
32
);
}
}
#endif
/* ETHTOOL_GREGS */
#endif
/* ETHTOOL_GREGS */
static
int
static
int
ixgb_ethtool_geeprom
(
struct
ixgb_adapter
*
adapter
,
ixgb_ethtool_geeprom
(
struct
ixgb_adapter
*
adapter
,
struct
ethtool_eeprom
*
eeprom
,
u
int16_t
*
eeprom_buff
)
struct
ethtool_eeprom
*
eeprom
,
u
16
*
eeprom_buff
)
{
{
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
int
i
,
max_len
,
first_word
,
last_word
;
int
i
,
max_len
,
first_word
,
last_word
;
...
@@ -315,7 +315,7 @@ ixgb_ethtool_seeprom(struct ixgb_adapter *adapter,
...
@@ -315,7 +315,7 @@ ixgb_ethtool_seeprom(struct ixgb_adapter *adapter,
struct
ethtool_eeprom
*
eeprom
,
void
*
user_data
)
struct
ethtool_eeprom
*
eeprom
,
void
*
user_data
)
{
{
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
u
int16_t
eeprom_buff
[
256
];
u
16
eeprom_buff
[
256
];
int
i
,
max_len
,
first_word
,
last_word
;
int
i
,
max_len
,
first_word
,
last_word
;
void
*
ptr
;
void
*
ptr
;
...
@@ -413,9 +413,9 @@ ixgb_ethtool_ioctl(struct net_device *netdev, struct ifreq *ifr)
...
@@ -413,9 +413,9 @@ ixgb_ethtool_ioctl(struct net_device *netdev, struct ifreq *ifr)
{
{
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
void
*
addr
=
ifr
->
ifr_data
;
void
*
addr
=
ifr
->
ifr_data
;
u
int32_t
cmd
;
u
32
cmd
;
if
(
get_user
(
cmd
,
(
u
int32_t
*
)
addr
))
if
(
get_user
(
cmd
,
(
u
32
*
)
addr
))
return
-
EFAULT
;
return
-
EFAULT
;
switch
(
cmd
)
{
switch
(
cmd
)
{
...
@@ -467,7 +467,7 @@ ixgb_ethtool_ioctl(struct net_device *netdev, struct ifreq *ifr)
...
@@ -467,7 +467,7 @@ ixgb_ethtool_ioctl(struct net_device *netdev, struct ifreq *ifr)
#if defined(ETHTOOL_GREGS) && defined(ETHTOOL_GEEPROM)
#if defined(ETHTOOL_GREGS) && defined(ETHTOOL_GEEPROM)
case
ETHTOOL_GREGS
:{
case
ETHTOOL_GREGS
:{
struct
ethtool_regs
regs
=
{
ETHTOOL_GREGS
};
struct
ethtool_regs
regs
=
{
ETHTOOL_GREGS
};
u
int8_t
regs_buff
[
IXGB_REG_DUMP_LEN
];
u
8
regs_buff
[
IXGB_REG_DUMP_LEN
];
ixgb_ethtool_gregs
(
adapter
,
&
regs
,
regs_buff
);
ixgb_ethtool_gregs
(
adapter
,
&
regs
,
regs_buff
);
...
@@ -513,7 +513,7 @@ ixgb_ethtool_ioctl(struct net_device *netdev, struct ifreq *ifr)
...
@@ -513,7 +513,7 @@ ixgb_ethtool_ioctl(struct net_device *netdev, struct ifreq *ifr)
case
ETHTOOL_GEEPROM
:{
case
ETHTOOL_GEEPROM
:{
struct
ethtool_eeprom
eeprom
=
{
ETHTOOL_GEEPROM
};
struct
ethtool_eeprom
eeprom
=
{
ETHTOOL_GEEPROM
};
u
int16_t
eeprom_buff
[
IXGB_EEPROM_SIZE
];
u
16
eeprom_buff
[
IXGB_EEPROM_SIZE
];
void
*
ptr
;
void
*
ptr
;
int
err
;
int
err
;
...
...
drivers/net/ixgb/ixgb_hw.c
View file @
9df5b0d8
...
@@ -34,24 +34,24 @@
...
@@ -34,24 +34,24 @@
/* Local function prototypes */
/* Local function prototypes */
static
u
int32_t
ixgb_hash_mc_addr
(
struct
ixgb_hw
*
hw
,
uint8_t
*
mc_addr
);
static
u
32
ixgb_hash_mc_addr
(
struct
ixgb_hw
*
hw
,
u8
*
mc_addr
);
static
void
ixgb_mta_set
(
struct
ixgb_hw
*
hw
,
u
int32_t
hash_value
);
static
void
ixgb_mta_set
(
struct
ixgb_hw
*
hw
,
u
32
hash_value
);
static
void
ixgb_get_bus_info
(
struct
ixgb_hw
*
hw
);
static
void
ixgb_get_bus_info
(
struct
ixgb_hw
*
hw
);
boolean_t
mac_addr_valid
(
u
int8_t
*
mac_addr
);
boolean_t
mac_addr_valid
(
u
8
*
mac_addr
);
static
boolean_t
ixgb_link_reset
(
struct
ixgb_hw
*
hw
);
static
boolean_t
ixgb_link_reset
(
struct
ixgb_hw
*
hw
);
static
void
ixgb_optics_reset
(
struct
ixgb_hw
*
hw
);
static
void
ixgb_optics_reset
(
struct
ixgb_hw
*
hw
);
u
int32_t
ixgb_mac_reset
(
struct
ixgb_hw
*
hw
);
u
32
ixgb_mac_reset
(
struct
ixgb_hw
*
hw
);
u
int32_t
u
32
ixgb_mac_reset
(
struct
ixgb_hw
*
hw
)
ixgb_mac_reset
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
ctrl_reg
;
u
32
ctrl_reg
;
/* Setup up hardware to known state with RESET. */
/* Setup up hardware to known state with RESET. */
ctrl_reg
=
IXGB_CTRL0_RST
|
IXGB_CTRL0_SDP3_DIR
|
/* All pins are Output=1 */
ctrl_reg
=
IXGB_CTRL0_RST
|
IXGB_CTRL0_SDP3_DIR
|
/* All pins are Output=1 */
...
@@ -84,8 +84,8 @@ ixgb_mac_reset(struct ixgb_hw *hw)
...
@@ -84,8 +84,8 @@ ixgb_mac_reset(struct ixgb_hw *hw)
boolean_t
boolean_t
ixgb_adapter_stop
(
struct
ixgb_hw
*
hw
)
ixgb_adapter_stop
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
ctrl_reg
;
u
32
ctrl_reg
;
u
int32_t
icr_reg
;
u
32
icr_reg
;
DEBUGFUNC
(
"ixgb_adapter_stop"
);
DEBUGFUNC
(
"ixgb_adapter_stop"
);
...
@@ -153,8 +153,8 @@ ixgb_adapter_stop(struct ixgb_hw * hw)
...
@@ -153,8 +153,8 @@ ixgb_adapter_stop(struct ixgb_hw * hw)
boolean_t
boolean_t
ixgb_init_hw
(
struct
ixgb_hw
*
hw
)
ixgb_init_hw
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
i
;
u
32
i
;
u
int32_t
ctrl_reg
;
u
32
ctrl_reg
;
boolean_t
status
;
boolean_t
status
;
DEBUGFUNC
(
"ixgb_init_hw"
);
DEBUGFUNC
(
"ixgb_init_hw"
);
...
@@ -235,7 +235,7 @@ ixgb_init_hw(struct ixgb_hw * hw)
...
@@ -235,7 +235,7 @@ ixgb_init_hw(struct ixgb_hw * hw)
void
void
ixgb_init_rx_addrs
(
struct
ixgb_hw
*
hw
)
ixgb_init_rx_addrs
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
i
;
u
32
i
;
DEBUGFUNC
(
"ixgb_init_rx_addrs"
);
DEBUGFUNC
(
"ixgb_init_rx_addrs"
);
...
@@ -294,12 +294,12 @@ ixgb_init_rx_addrs(struct ixgb_hw *hw)
...
@@ -294,12 +294,12 @@ ixgb_init_rx_addrs(struct ixgb_hw *hw)
*****************************************************************************/
*****************************************************************************/
void
void
ixgb_mc_addr_list_update
(
struct
ixgb_hw
*
hw
,
ixgb_mc_addr_list_update
(
struct
ixgb_hw
*
hw
,
u
int8_t
*
mc_addr_list
,
u
8
*
mc_addr_list
,
u
int32_t
mc_addr_count
,
uint32_t
pad
)
u
32
mc_addr_count
,
u32
pad
)
{
{
u
int32_t
hash_value
;
u
32
hash_value
;
u
int32_t
i
;
u
32
i
;
u
int32_t
rar_used_count
=
1
;
/* RAR[0] is used for our MAC address */
u
32
rar_used_count
=
1
;
/* RAR[0] is used for our MAC address */
DEBUGFUNC
(
"ixgb_mc_addr_list_update"
);
DEBUGFUNC
(
"ixgb_mc_addr_list_update"
);
...
@@ -371,10 +371,10 @@ ixgb_mc_addr_list_update(struct ixgb_hw *hw,
...
@@ -371,10 +371,10 @@ ixgb_mc_addr_list_update(struct ixgb_hw *hw,
* Returns:
* Returns:
* The hash value
* The hash value
*****************************************************************************/
*****************************************************************************/
static
u
int32_t
static
u
32
ixgb_hash_mc_addr
(
struct
ixgb_hw
*
hw
,
u
int8_t
*
mc_addr
)
ixgb_hash_mc_addr
(
struct
ixgb_hw
*
hw
,
u
8
*
mc_addr
)
{
{
u
int32_t
hash_value
=
0
;
u
32
hash_value
=
0
;
DEBUGFUNC
(
"ixgb_hash_mc_addr"
);
DEBUGFUNC
(
"ixgb_hash_mc_addr"
);
...
@@ -388,18 +388,18 @@ ixgb_hash_mc_addr(struct ixgb_hw *hw, uint8_t * mc_addr)
...
@@ -388,18 +388,18 @@ ixgb_hash_mc_addr(struct ixgb_hw *hw, uint8_t * mc_addr)
case
0
:
case
0
:
/* [47:36] i.e. 0x563 for above example address */
/* [47:36] i.e. 0x563 for above example address */
hash_value
=
hash_value
=
((
mc_addr
[
4
]
>>
4
)
|
(((
u
int16_t
)
mc_addr
[
5
])
<<
4
));
((
mc_addr
[
4
]
>>
4
)
|
(((
u
16
)
mc_addr
[
5
])
<<
4
));
break
;
break
;
case
1
:
/* [46:35] i.e. 0xAC6 for above example address */
case
1
:
/* [46:35] i.e. 0xAC6 for above example address */
hash_value
=
hash_value
=
((
mc_addr
[
4
]
>>
3
)
|
(((
u
int16_t
)
mc_addr
[
5
])
<<
5
));
((
mc_addr
[
4
]
>>
3
)
|
(((
u
16
)
mc_addr
[
5
])
<<
5
));
break
;
break
;
case
2
:
/* [45:34] i.e. 0x5D8 for above example address */
case
2
:
/* [45:34] i.e. 0x5D8 for above example address */
hash_value
=
hash_value
=
((
mc_addr
[
4
]
>>
2
)
|
(((
u
int16_t
)
mc_addr
[
5
])
<<
6
));
((
mc_addr
[
4
]
>>
2
)
|
(((
u
16
)
mc_addr
[
5
])
<<
6
));
break
;
break
;
case
3
:
/* [43:32] i.e. 0x634 for above example address */
case
3
:
/* [43:32] i.e. 0x634 for above example address */
hash_value
=
((
mc_addr
[
4
])
|
(((
u
int16_t
)
mc_addr
[
5
])
<<
8
));
hash_value
=
((
mc_addr
[
4
])
|
(((
u
16
)
mc_addr
[
5
])
<<
8
));
break
;
break
;
default:
default:
/* Invalid mc_filter_type, what should we do? */
/* Invalid mc_filter_type, what should we do? */
...
@@ -419,10 +419,10 @@ ixgb_hash_mc_addr(struct ixgb_hw *hw, uint8_t * mc_addr)
...
@@ -419,10 +419,10 @@ ixgb_hash_mc_addr(struct ixgb_hw *hw, uint8_t * mc_addr)
* hash_value - Multicast address hash value
* hash_value - Multicast address hash value
*****************************************************************************/
*****************************************************************************/
static
void
static
void
ixgb_mta_set
(
struct
ixgb_hw
*
hw
,
u
int32_t
hash_value
)
ixgb_mta_set
(
struct
ixgb_hw
*
hw
,
u
32
hash_value
)
{
{
u
int32_t
hash_bit
,
hash_reg
;
u
32
hash_bit
,
hash_reg
;
u
int32_t
mta_reg
;
u
32
mta_reg
;
/* The MTA is a register array of 128 32-bit registers.
/* The MTA is a register array of 128 32-bit registers.
* It is treated like an array of 4096 bits. We want to set
* It is treated like an array of 4096 bits. We want to set
...
@@ -452,21 +452,21 @@ ixgb_mta_set(struct ixgb_hw *hw, uint32_t hash_value)
...
@@ -452,21 +452,21 @@ ixgb_mta_set(struct ixgb_hw *hw, uint32_t hash_value)
* index - Receive address register to write
* index - Receive address register to write
*****************************************************************************/
*****************************************************************************/
void
void
ixgb_rar_set
(
struct
ixgb_hw
*
hw
,
u
int8_t
*
addr
,
uint32_t
index
)
ixgb_rar_set
(
struct
ixgb_hw
*
hw
,
u
8
*
addr
,
u32
index
)
{
{
u
int32_t
rar_low
,
rar_high
;
u
32
rar_low
,
rar_high
;
DEBUGFUNC
(
"ixgb_rar_set"
);
DEBUGFUNC
(
"ixgb_rar_set"
);
/* HW expects these in little endian so we reverse the byte order
/* HW expects these in little endian so we reverse the byte order
* from network order (big endian) to little endian
* from network order (big endian) to little endian
*/
*/
rar_low
=
((
u
int32_t
)
addr
[
0
]
|
rar_low
=
((
u
32
)
addr
[
0
]
|
((
u
int32_t
)
addr
[
1
]
<<
8
)
|
((
u
32
)
addr
[
1
]
<<
8
)
|
((
u
int32_t
)
addr
[
2
]
<<
16
)
|
((
uint32_t
)
addr
[
3
]
<<
24
));
((
u
32
)
addr
[
2
]
<<
16
)
|
((
u32
)
addr
[
3
]
<<
24
));
rar_high
=
((
u
int32_t
)
addr
[
4
]
|
rar_high
=
((
u
32
)
addr
[
4
]
|
((
u
int32_t
)
addr
[
5
]
<<
8
)
|
IXGB_RAH_AV
);
((
u
32
)
addr
[
5
]
<<
8
)
|
IXGB_RAH_AV
);
IXGB_WRITE_REG_ARRAY
(
hw
,
RA
,
(
index
<<
1
),
rar_low
);
IXGB_WRITE_REG_ARRAY
(
hw
,
RA
,
(
index
<<
1
),
rar_low
);
IXGB_WRITE_REG_ARRAY
(
hw
,
RA
,
((
index
<<
1
)
+
1
),
rar_high
);
IXGB_WRITE_REG_ARRAY
(
hw
,
RA
,
((
index
<<
1
)
+
1
),
rar_high
);
...
@@ -481,7 +481,7 @@ ixgb_rar_set(struct ixgb_hw *hw, uint8_t * addr, uint32_t index)
...
@@ -481,7 +481,7 @@ ixgb_rar_set(struct ixgb_hw *hw, uint8_t * addr, uint32_t index)
* value - Value to write into VLAN filter table
* value - Value to write into VLAN filter table
*****************************************************************************/
*****************************************************************************/
void
void
ixgb_write_vfta
(
struct
ixgb_hw
*
hw
,
u
int32_t
offset
,
uint32_t
value
)
ixgb_write_vfta
(
struct
ixgb_hw
*
hw
,
u
32
offset
,
u32
value
)
{
{
IXGB_WRITE_REG_ARRAY
(
hw
,
VFTA
,
offset
,
value
);
IXGB_WRITE_REG_ARRAY
(
hw
,
VFTA
,
offset
,
value
);
return
;
return
;
...
@@ -495,7 +495,7 @@ ixgb_write_vfta(struct ixgb_hw *hw, uint32_t offset, uint32_t value)
...
@@ -495,7 +495,7 @@ ixgb_write_vfta(struct ixgb_hw *hw, uint32_t offset, uint32_t value)
void
void
ixgb_clear_vfta
(
struct
ixgb_hw
*
hw
)
ixgb_clear_vfta
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
offset
;
u
32
offset
;
for
(
offset
=
0
;
offset
<
IXGB_VLAN_FILTER_TBL_SIZE
;
offset
++
)
for
(
offset
=
0
;
offset
<
IXGB_VLAN_FILTER_TBL_SIZE
;
offset
++
)
IXGB_WRITE_REG_ARRAY
(
hw
,
VFTA
,
offset
,
0
);
IXGB_WRITE_REG_ARRAY
(
hw
,
VFTA
,
offset
,
0
);
...
@@ -511,8 +511,8 @@ ixgb_clear_vfta(struct ixgb_hw *hw)
...
@@ -511,8 +511,8 @@ ixgb_clear_vfta(struct ixgb_hw *hw)
boolean_t
boolean_t
ixgb_setup_fc
(
struct
ixgb_hw
*
hw
)
ixgb_setup_fc
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
ctrl_reg
;
u
32
ctrl_reg
;
u
int32_t
pap_reg
=
0
;
/* by default, assume no pause time */
u
32
pap_reg
=
0
;
/* by default, assume no pause time */
boolean_t
status
=
TRUE
;
boolean_t
status
=
TRUE
;
DEBUGFUNC
(
"ixgb_setup_fc"
);
DEBUGFUNC
(
"ixgb_setup_fc"
);
...
@@ -607,14 +607,14 @@ ixgb_setup_fc(struct ixgb_hw * hw)
...
@@ -607,14 +607,14 @@ ixgb_setup_fc(struct ixgb_hw * hw)
* This requires that first an address cycle command is sent, followed by a
* This requires that first an address cycle command is sent, followed by a
* read command.
* read command.
*****************************************************************************/
*****************************************************************************/
u
int16_t
u
16
ixgb_read_phy_reg
(
struct
ixgb_hw
*
hw
,
ixgb_read_phy_reg
(
struct
ixgb_hw
*
hw
,
u
int32_t
reg_address
,
u
32
reg_address
,
u
int32_t
phy_address
,
uint32_t
device_type
)
u
32
phy_address
,
u32
device_type
)
{
{
u
int32_t
i
;
u
32
i
;
u
int32_t
data
;
u
32
data
;
u
int32_t
command
=
0
;
u
32
command
=
0
;
ASSERT
(
reg_address
<=
IXGB_MAX_PHY_REG_ADDRESS
);
ASSERT
(
reg_address
<=
IXGB_MAX_PHY_REG_ADDRESS
);
ASSERT
(
phy_address
<=
IXGB_MAX_PHY_ADDRESS
);
ASSERT
(
phy_address
<=
IXGB_MAX_PHY_ADDRESS
);
...
@@ -677,7 +677,7 @@ ixgb_read_phy_reg(struct ixgb_hw * hw,
...
@@ -677,7 +677,7 @@ ixgb_read_phy_reg(struct ixgb_hw * hw,
*/
*/
data
=
IXGB_READ_REG
(
hw
,
MSRWD
);
data
=
IXGB_READ_REG
(
hw
,
MSRWD
);
data
>>=
IXGB_MSRWD_READ_DATA_SHIFT
;
data
>>=
IXGB_MSRWD_READ_DATA_SHIFT
;
return
((
u
int16_t
)
data
);
return
((
u
16
)
data
);
}
}
/******************************************************************************
/******************************************************************************
...
@@ -698,18 +698,18 @@ ixgb_read_phy_reg(struct ixgb_hw * hw,
...
@@ -698,18 +698,18 @@ ixgb_read_phy_reg(struct ixgb_hw * hw,
*****************************************************************************/
*****************************************************************************/
void
void
ixgb_write_phy_reg
(
struct
ixgb_hw
*
hw
,
ixgb_write_phy_reg
(
struct
ixgb_hw
*
hw
,
u
int32_t
reg_address
,
u
32
reg_address
,
u
int32_t
phy_address
,
uint32_t
device_type
,
uint16_t
data
)
u
32
phy_address
,
u32
device_type
,
u16
data
)
{
{
u
int32_t
i
;
u
32
i
;
u
int32_t
command
=
0
;
u
32
command
=
0
;
ASSERT
(
reg_address
<=
IXGB_MAX_PHY_REG_ADDRESS
);
ASSERT
(
reg_address
<=
IXGB_MAX_PHY_REG_ADDRESS
);
ASSERT
(
phy_address
<=
IXGB_MAX_PHY_ADDRESS
);
ASSERT
(
phy_address
<=
IXGB_MAX_PHY_ADDRESS
);
ASSERT
(
device_type
<=
IXGB_MAX_PHY_DEV_TYPE
);
ASSERT
(
device_type
<=
IXGB_MAX_PHY_DEV_TYPE
);
/* Put the data in the MDIO Read/Write Data register */
/* Put the data in the MDIO Read/Write Data register */
IXGB_WRITE_REG
(
hw
,
MSRWD
,
(
u
int32_t
)
data
);
IXGB_WRITE_REG
(
hw
,
MSRWD
,
(
u
32
)
data
);
/* Setup and write the address cycle command */
/* Setup and write the address cycle command */
command
=
((
reg_address
<<
IXGB_MSCA_NP_ADDR_SHIFT
)
|
command
=
((
reg_address
<<
IXGB_MSCA_NP_ADDR_SHIFT
)
|
...
@@ -776,8 +776,8 @@ ixgb_write_phy_reg(struct ixgb_hw *hw,
...
@@ -776,8 +776,8 @@ ixgb_write_phy_reg(struct ixgb_hw *hw,
void
void
ixgb_check_for_link
(
struct
ixgb_hw
*
hw
)
ixgb_check_for_link
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
status_reg
;
u
32
status_reg
;
u
int32_t
xpcss_reg
;
u
32
xpcss_reg
;
DEBUGFUNC
(
"ixgb_check_for_link"
);
DEBUGFUNC
(
"ixgb_check_for_link"
);
...
@@ -801,7 +801,7 @@ ixgb_check_for_link(struct ixgb_hw *hw)
...
@@ -801,7 +801,7 @@ ixgb_check_for_link(struct ixgb_hw *hw)
boolean_t
boolean_t
ixgb_check_for_bad_link
(
struct
ixgb_hw
*
hw
)
ixgb_check_for_bad_link
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
newLFC
,
newRFC
;
u
32
newLFC
,
newRFC
;
boolean_t
bad_link_returncode
=
FALSE
;
boolean_t
bad_link_returncode
=
FALSE
;
/* check for a bad reset that may have occured
/* check for a bad reset that may have occured
...
@@ -827,7 +827,7 @@ ixgb_check_for_bad_link(struct ixgb_hw *hw)
...
@@ -827,7 +827,7 @@ ixgb_check_for_bad_link(struct ixgb_hw *hw)
void
void
ixgb_clear_hw_cntrs
(
struct
ixgb_hw
*
hw
)
ixgb_clear_hw_cntrs
(
struct
ixgb_hw
*
hw
)
{
{
volatile
u
int32_t
temp_reg
;
volatile
u
32
temp_reg
;
DEBUGFUNC
(
"ixgb_clear_hw_cntrs"
);
DEBUGFUNC
(
"ixgb_clear_hw_cntrs"
);
...
@@ -908,7 +908,7 @@ ixgb_clear_hw_cntrs(struct ixgb_hw *hw)
...
@@ -908,7 +908,7 @@ ixgb_clear_hw_cntrs(struct ixgb_hw *hw)
void
void
ixgb_led_on
(
struct
ixgb_hw
*
hw
)
ixgb_led_on
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
ctrl0_reg
=
IXGB_READ_REG
(
hw
,
CTRL0
);
u
32
ctrl0_reg
=
IXGB_READ_REG
(
hw
,
CTRL0
);
/* To turn on the LED, clear software-definable pin 0 (SDP0). */
/* To turn on the LED, clear software-definable pin 0 (SDP0). */
ctrl0_reg
&=
~
IXGB_CTRL0_SDP0
;
ctrl0_reg
&=
~
IXGB_CTRL0_SDP0
;
...
@@ -924,7 +924,7 @@ ixgb_led_on(struct ixgb_hw *hw)
...
@@ -924,7 +924,7 @@ ixgb_led_on(struct ixgb_hw *hw)
void
void
ixgb_led_off
(
struct
ixgb_hw
*
hw
)
ixgb_led_off
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
ctrl0_reg
=
IXGB_READ_REG
(
hw
,
CTRL0
);
u
32
ctrl0_reg
=
IXGB_READ_REG
(
hw
,
CTRL0
);
/* To turn off the LED, set software-definable pin 0 (SDP0). */
/* To turn off the LED, set software-definable pin 0 (SDP0). */
ctrl0_reg
|=
IXGB_CTRL0_SDP0
;
ctrl0_reg
|=
IXGB_CTRL0_SDP0
;
...
@@ -940,7 +940,7 @@ ixgb_led_off(struct ixgb_hw *hw)
...
@@ -940,7 +940,7 @@ ixgb_led_off(struct ixgb_hw *hw)
static
void
static
void
ixgb_get_bus_info
(
struct
ixgb_hw
*
hw
)
ixgb_get_bus_info
(
struct
ixgb_hw
*
hw
)
{
{
u
int32_t
status_reg
;
u
32
status_reg
;
status_reg
=
IXGB_READ_REG
(
hw
,
STATUS
);
status_reg
=
IXGB_READ_REG
(
hw
,
STATUS
);
...
@@ -980,7 +980,7 @@ ixgb_get_bus_info(struct ixgb_hw *hw)
...
@@ -980,7 +980,7 @@ ixgb_get_bus_info(struct ixgb_hw *hw)
*
*
*****************************************************************************/
*****************************************************************************/
boolean_t
boolean_t
mac_addr_valid
(
u
int8_t
*
mac_addr
)
mac_addr_valid
(
u
8
*
mac_addr
)
{
{
boolean_t
is_valid
=
TRUE
;
boolean_t
is_valid
=
TRUE
;
DEBUGFUNC
(
"mac_addr_valid"
);
DEBUGFUNC
(
"mac_addr_valid"
);
...
@@ -1016,8 +1016,8 @@ boolean_t
...
@@ -1016,8 +1016,8 @@ boolean_t
ixgb_link_reset
(
struct
ixgb_hw
*
hw
)
ixgb_link_reset
(
struct
ixgb_hw
*
hw
)
{
{
boolean_t
link_status
=
FALSE
;
boolean_t
link_status
=
FALSE
;
u
int8_t
wait_retries
=
MAX_RESET_ITERATIONS
;
u
8
wait_retries
=
MAX_RESET_ITERATIONS
;
u
int8_t
lrst_retries
=
MAX_RESET_ITERATIONS
;
u
8
lrst_retries
=
MAX_RESET_ITERATIONS
;
do
{
do
{
IXGB_WRITE_REG
(
hw
,
CTRL0
,
IXGB_WRITE_REG
(
hw
,
CTRL0
,
...
@@ -1043,7 +1043,7 @@ ixgb_link_reset(struct ixgb_hw * hw)
...
@@ -1043,7 +1043,7 @@ ixgb_link_reset(struct ixgb_hw * hw)
void
void
ixgb_optics_reset
(
struct
ixgb_hw
*
hw
)
ixgb_optics_reset
(
struct
ixgb_hw
*
hw
)
{
{
u
int16_t
mdio_reg
;
u
16
mdio_reg
;
ixgb_write_phy_reg
(
hw
,
ixgb_write_phy_reg
(
hw
,
TXN17401_PMA_PMD_CR1
,
TXN17401_PMA_PMD_CR1
,
...
...
drivers/net/ixgb/ixgb_hw.h
View file @
9df5b0d8
...
@@ -367,11 +367,11 @@ typedef enum {
...
@@ -367,11 +367,11 @@ typedef enum {
struct
ixgb_rx_desc
{
struct
ixgb_rx_desc
{
uint64_t
buff_addr
;
uint64_t
buff_addr
;
u
int16_t
length
;
u
16
length
;
u
int16_t
reserved
;
u
16
reserved
;
u
int8_t
status
;
u
8
status
;
u
int8_t
errors
;
u
8
errors
;
u
int16_t
special
;
u
16
special
;
};
};
#define IXGB_RX_DESC_STATUS_DD 0x01
#define IXGB_RX_DESC_STATUS_DD 0x01
...
@@ -390,10 +390,10 @@ struct ixgb_rx_desc {
...
@@ -390,10 +390,10 @@ struct ixgb_rx_desc {
struct
ixgb_tx_desc
{
struct
ixgb_tx_desc
{
uint64_t
buff_addr
;
uint64_t
buff_addr
;
u
int32_t
cmd_type_len
;
u
32
cmd_type_len
;
u
int8_t
status
;
u
8
status
;
u
int8_t
popts
;
u
8
popts
;
u
int16_t
vlan
;
u
16
vlan
;
};
};
#define IXGB_TX_DESC_CMD_EOP 0x01000000
#define IXGB_TX_DESC_CMD_EOP 0x01000000
...
@@ -410,16 +410,16 @@ struct ixgb_tx_desc {
...
@@ -410,16 +410,16 @@ struct ixgb_tx_desc {
#define IXGB_TX_DESC_POPTS_TXSM 0x02
#define IXGB_TX_DESC_POPTS_TXSM 0x02
struct
ixgb_context_desc
{
struct
ixgb_context_desc
{
u
int8_t
ipcss
;
u
8
ipcss
;
u
int8_t
ipcso
;
u
8
ipcso
;
u
int16_t
ipcse
;
u
16
ipcse
;
u
int8_t
tucss
;
u
8
tucss
;
u
int8_t
tucso
;
u
8
tucso
;
u
int16_t
tucse
;
u
16
tucse
;
u
int32_t
cmd_type_len
;
u
32
cmd_type_len
;
u
int8_t
status
;
u
8
status
;
u
int8_t
hdr_len
;
u
8
hdr_len
;
u
int16_t
mss
;
u
16
mss
;
};
};
#define IXGB_CONTEXT_DESC_CMD_TCP 0x01000000
#define IXGB_CONTEXT_DESC_CMD_TCP 0x01000000
...
@@ -448,19 +448,19 @@ struct ixgb_context_desc {
...
@@ -448,19 +448,19 @@ struct ixgb_context_desc {
* This is a little-endian specific check.
* This is a little-endian specific check.
*/
*/
#define IS_MULTICAST(Address) \
#define IS_MULTICAST(Address) \
(boolean_t)(((u
int8_t *)(Address))[0] & ((uint8_t
)0x01))
(boolean_t)(((u
8 *)(Address))[0] & ((u8
)0x01))
/*
/*
* Check whether an address is broadcast.
* Check whether an address is broadcast.
*/
*/
#define IS_BROADCAST(Address) \
#define IS_BROADCAST(Address) \
((((u
int8_t *)(Address))[0] == ((uint8_t)0xff)) && (((uint8_t *)(Address))[1] == ((uint8_t
)0xff)))
((((u
8 *)(Address))[0] == ((u8)0xff)) && (((u8 *)(Address))[1] == ((u8
)0xff)))
/* Flow control parameters */
/* Flow control parameters */
struct
ixgb_fc
{
struct
ixgb_fc
{
u
int32_t
high_water
;
/* Flow Control High-water */
u
32
high_water
;
/* Flow Control High-water */
u
int32_t
low_water
;
/* Flow Control Low-water */
u
32
low_water
;
/* Flow Control Low-water */
u
int16_t
pause_time
;
/* Flow Control Pause timer */
u
16
pause_time
;
/* Flow Control Pause timer */
boolean_t
send_xon
;
/* Flow control send XON */
boolean_t
send_xon
;
/* Flow control send XON */
ixgb_fc_type
type
;
/* Type of flow control */
ixgb_fc_type
type
;
/* Type of flow control */
};
};
...
@@ -480,32 +480,32 @@ struct ixgb_bus {
...
@@ -480,32 +480,32 @@ struct ixgb_bus {
};
};
struct
ixgb_hw
{
struct
ixgb_hw
{
u
int8_t
*
hw_addr
;
/* Base Address of the hardware */
u
8
*
hw_addr
;
/* Base Address of the hardware */
void
*
back
;
/* Pointer to OS-dependent struct */
void
*
back
;
/* Pointer to OS-dependent struct */
struct
ixgb_fc
fc
;
/* Flow control parameters */
struct
ixgb_fc
fc
;
/* Flow control parameters */
struct
ixgb_bus
bus
;
/* Bus parameters */
struct
ixgb_bus
bus
;
/* Bus parameters */
u
int32_t
phy_id
;
/* Phy Identifier */
u
32
phy_id
;
/* Phy Identifier */
u
int32_t
phy_addr
;
/* XGMII address of Phy */
u
32
phy_addr
;
/* XGMII address of Phy */
ixgb_mac_type
mac_type
;
/* Identifier for MAC controller */
ixgb_mac_type
mac_type
;
/* Identifier for MAC controller */
u
int32_t
max_frame_size
;
/* Maximum frame size supported */
u
32
max_frame_size
;
/* Maximum frame size supported */
u
int32_t
mc_filter_type
;
/* Multicast filter hash type */
u
32
mc_filter_type
;
/* Multicast filter hash type */
u
int32_t
num_mc_addrs
;
/* Number of current Multicast addrs */
u
32
num_mc_addrs
;
/* Number of current Multicast addrs */
u
int8_t
curr_mac_addr
[
IXGB_ETH_LENGTH_OF_ADDRESS
];
/* Individual address currently programmed in MAC */
u
8
curr_mac_addr
[
IXGB_ETH_LENGTH_OF_ADDRESS
];
/* Individual address currently programmed in MAC */
u
int32_t
num_tx_desc
;
/* Number of Transmit descriptors */
u
32
num_tx_desc
;
/* Number of Transmit descriptors */
u
int32_t
num_rx_desc
;
/* Number of Receive descriptors */
u
32
num_rx_desc
;
/* Number of Receive descriptors */
u
int32_t
rx_buffer_size
;
/* Size of Receive buffer */
u
32
rx_buffer_size
;
/* Size of Receive buffer */
boolean_t
link_up
;
/* TRUE if link is valid */
boolean_t
link_up
;
/* TRUE if link is valid */
boolean_t
adapter_stopped
;
/* State of adapter */
boolean_t
adapter_stopped
;
/* State of adapter */
u
int16_t
device_id
;
/* device id from PCI configuration space */
u
16
device_id
;
/* device id from PCI configuration space */
u
int16_t
vendor_id
;
/* vendor id from PCI configuration space */
u
16
vendor_id
;
/* vendor id from PCI configuration space */
u
int8_t
revision_id
;
/* revision id from PCI configuration space */
u
8
revision_id
;
/* revision id from PCI configuration space */
u
int16_t
subsystem_vendor_id
;
/* subsystem vendor id from PCI configuration space */
u
16
subsystem_vendor_id
;
/* subsystem vendor id from PCI configuration space */
u
int16_t
subsystem_id
;
/* subsystem id from PCI configuration space */
u
16
subsystem_id
;
/* subsystem id from PCI configuration space */
u
int16_t
pci_cmd_word
;
/* PCI command register id from PCI configuration space */
u
16
pci_cmd_word
;
/* PCI command register id from PCI configuration space */
u
int16_t
eeprom
[
IXGB_EEPROM_SIZE
];
/* EEPROM contents read at init time */
u
16
eeprom
[
IXGB_EEPROM_SIZE
];
/* EEPROM contents read at init time */
uint64_t
io_base
;
/* Our I/O mapped location */
uint64_t
io_base
;
/* Our I/O mapped location */
u
int32_t
lastLFC
;
u
32
lastLFC
;
u
int32_t
lastRFC
;
u
32
lastRFC
;
};
};
struct
ixgb_hw_stats
{
struct
ixgb_hw_stats
{
...
@@ -580,48 +580,48 @@ extern void ixgb_check_for_link(struct ixgb_hw *hw);
...
@@ -580,48 +580,48 @@ extern void ixgb_check_for_link(struct ixgb_hw *hw);
extern
boolean_t
ixgb_check_for_bad_link
(
struct
ixgb_hw
*
hw
);
extern
boolean_t
ixgb_check_for_bad_link
(
struct
ixgb_hw
*
hw
);
extern
boolean_t
ixgb_setup_fc
(
struct
ixgb_hw
*
hw
);
extern
boolean_t
ixgb_setup_fc
(
struct
ixgb_hw
*
hw
);
extern
void
ixgb_clear_hw_cntrs
(
struct
ixgb_hw
*
hw
);
extern
void
ixgb_clear_hw_cntrs
(
struct
ixgb_hw
*
hw
);
extern
boolean_t
mac_addr_valid
(
u
int8_t
*
mac_addr
);
extern
boolean_t
mac_addr_valid
(
u
8
*
mac_addr
);
extern
u
int16_t
ixgb_read_phy_reg
(
struct
ixgb_hw
*
hw
,
extern
u
16
ixgb_read_phy_reg
(
struct
ixgb_hw
*
hw
,
u
int32_t
reg_addr
,
u
32
reg_addr
,
u
int32_t
phy_addr
,
uint32_t
device_type
);
u
32
phy_addr
,
u32
device_type
);
extern
void
ixgb_write_phy_reg
(
struct
ixgb_hw
*
hw
,
extern
void
ixgb_write_phy_reg
(
struct
ixgb_hw
*
hw
,
u
int32_t
reg_addr
,
u
32
reg_addr
,
u
int32_t
phy_addr
,
u
32
phy_addr
,
u
int32_t
device_type
,
uint16_t
data
);
u
32
device_type
,
u16
data
);
extern
void
ixgb_rar_set
(
struct
ixgb_hw
*
hw
,
u
int8_t
*
addr
,
uint32_t
index
);
extern
void
ixgb_rar_set
(
struct
ixgb_hw
*
hw
,
u
8
*
addr
,
u32
index
);
/* Filters (multicast, vlan, receive) */
/* Filters (multicast, vlan, receive) */
extern
void
ixgb_mc_addr_list_update
(
struct
ixgb_hw
*
hw
,
extern
void
ixgb_mc_addr_list_update
(
struct
ixgb_hw
*
hw
,
u
int8_t
*
mc_addr_list
,
u
8
*
mc_addr_list
,
u
int32_t
mc_addr_count
,
uint32_t
pad
);
u
32
mc_addr_count
,
u32
pad
);
/* Vfta functions */
/* Vfta functions */
extern
void
ixgb_write_vfta
(
struct
ixgb_hw
*
hw
,
extern
void
ixgb_write_vfta
(
struct
ixgb_hw
*
hw
,
u
int32_t
offset
,
uint32_t
value
);
u
32
offset
,
u32
value
);
extern
void
ixgb_clear_vfta
(
struct
ixgb_hw
*
hw
);
extern
void
ixgb_clear_vfta
(
struct
ixgb_hw
*
hw
);
/* Access functions to eeprom data */
/* Access functions to eeprom data */
void
ixgb_get_ee_mac_addr
(
struct
ixgb_hw
*
hw
,
u
int8_t
*
mac_addr
);
void
ixgb_get_ee_mac_addr
(
struct
ixgb_hw
*
hw
,
u
8
*
mac_addr
);
u
int16_t
ixgb_get_ee_compatibility
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_compatibility
(
struct
ixgb_hw
*
hw
);
u
int32_t
ixgb_get_ee_pba_number
(
struct
ixgb_hw
*
hw
);
u
32
ixgb_get_ee_pba_number
(
struct
ixgb_hw
*
hw
);
u
int16_t
ixgb_get_ee_init_ctrl_reg_1
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_init_ctrl_reg_1
(
struct
ixgb_hw
*
hw
);
u
int16_t
ixgb_get_ee_init_ctrl_reg_2
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_init_ctrl_reg_2
(
struct
ixgb_hw
*
hw
);
u
int16_t
ixgb_get_ee_subsystem_id
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_subsystem_id
(
struct
ixgb_hw
*
hw
);
u
int16_t
ixgb_get_ee_subvendor_id
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_subvendor_id
(
struct
ixgb_hw
*
hw
);
u
int16_t
ixgb_get_ee_device_id
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_device_id
(
struct
ixgb_hw
*
hw
);
u
int16_t
ixgb_get_ee_vendor_id
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_vendor_id
(
struct
ixgb_hw
*
hw
);
u
int16_t
ixgb_get_ee_swdpins_reg
(
struct
ixgb_hw
*
hw
);
u
16
ixgb_get_ee_swdpins_reg
(
struct
ixgb_hw
*
hw
);
u
int8_t
ixgb_get_ee_d3_power
(
struct
ixgb_hw
*
hw
);
u
8
ixgb_get_ee_d3_power
(
struct
ixgb_hw
*
hw
);
u
int8_t
ixgb_get_ee_d0_power
(
struct
ixgb_hw
*
hw
);
u
8
ixgb_get_ee_d0_power
(
struct
ixgb_hw
*
hw
);
boolean_t
ixgb_get_eeprom_data
(
struct
ixgb_hw
*
hw
);
boolean_t
ixgb_get_eeprom_data
(
struct
ixgb_hw
*
hw
);
/* Everything else */
/* Everything else */
void
ixgb_led_on
(
struct
ixgb_hw
*
hw
);
void
ixgb_led_on
(
struct
ixgb_hw
*
hw
);
void
ixgb_led_off
(
struct
ixgb_hw
*
hw
);
void
ixgb_led_off
(
struct
ixgb_hw
*
hw
);
void
ixgb_write_pci_cfg
(
struct
ixgb_hw
*
hw
,
u
int32_t
reg
,
uint16_t
*
value
);
void
ixgb_write_pci_cfg
(
struct
ixgb_hw
*
hw
,
u
32
reg
,
u16
*
value
);
#endif
/* _IXGB_HW_H_ */
#endif
/* _IXGB_HW_H_ */
drivers/net/ixgb/ixgb_main.c
View file @
9df5b0d8
...
@@ -95,8 +95,8 @@ static void ixgb_tx_timeout(struct net_device *netdev);
...
@@ -95,8 +95,8 @@ static void ixgb_tx_timeout(struct net_device *netdev);
static
void
ixgb_tx_timeout_task
(
struct
net_device
*
netdev
);
static
void
ixgb_tx_timeout_task
(
struct
net_device
*
netdev
);
static
void
ixgb_vlan_rx_register
(
struct
net_device
*
netdev
,
static
void
ixgb_vlan_rx_register
(
struct
net_device
*
netdev
,
struct
vlan_group
*
grp
);
struct
vlan_group
*
grp
);
static
void
ixgb_vlan_rx_add_vid
(
struct
net_device
*
netdev
,
u
int16_t
vid
);
static
void
ixgb_vlan_rx_add_vid
(
struct
net_device
*
netdev
,
u
16
vid
);
static
void
ixgb_vlan_rx_kill_vid
(
struct
net_device
*
netdev
,
u
int16_t
vid
);
static
void
ixgb_vlan_rx_kill_vid
(
struct
net_device
*
netdev
,
u
16
vid
);
static
void
ixgb_restore_vlan
(
struct
ixgb_adapter
*
adapter
);
static
void
ixgb_restore_vlan
(
struct
ixgb_adapter
*
adapter
);
static
struct
net_device_stats
*
ixgb_get_stats
(
struct
net_device
*
netdev
);
static
struct
net_device_stats
*
ixgb_get_stats
(
struct
net_device
*
netdev
);
static
int
ixgb_change_mtu
(
struct
net_device
*
netdev
,
int
new_mtu
);
static
int
ixgb_change_mtu
(
struct
net_device
*
netdev
,
int
new_mtu
);
...
@@ -118,7 +118,7 @@ static inline void ixgb_rx_checksum(struct ixgb_adapter *adapter,
...
@@ -118,7 +118,7 @@ static inline void ixgb_rx_checksum(struct ixgb_adapter *adapter,
struct
sk_buff
*
skb
);
struct
sk_buff
*
skb
);
static
int
ixgb_notify_reboot
(
struct
notifier_block
*
,
unsigned
long
event
,
static
int
ixgb_notify_reboot
(
struct
notifier_block
*
,
unsigned
long
event
,
void
*
ptr
);
void
*
ptr
);
static
int
ixgb_suspend
(
struct
pci_dev
*
pdev
,
u
int32_t
state
);
static
int
ixgb_suspend
(
struct
pci_dev
*
pdev
,
u
32
state
);
struct
notifier_block
ixgb_notifier_reboot
=
{
struct
notifier_block
ixgb_notifier_reboot
=
{
.
notifier_call
=
ixgb_notify_reboot
,
.
notifier_call
=
ixgb_notify_reboot
,
...
@@ -653,8 +653,8 @@ ixgb_setup_tx_resources(struct ixgb_adapter *adapter)
...
@@ -653,8 +653,8 @@ ixgb_setup_tx_resources(struct ixgb_adapter *adapter)
static
void
static
void
ixgb_configure_tx
(
struct
ixgb_adapter
*
adapter
)
ixgb_configure_tx
(
struct
ixgb_adapter
*
adapter
)
{
{
u
int32_t
tctl
;
u
32
tctl
;
u
int32_t
tdlen
=
adapter
->
tx_ring
.
count
*
sizeof
(
struct
ixgb_tx_desc
);
u
32
tdlen
=
adapter
->
tx_ring
.
count
*
sizeof
(
struct
ixgb_tx_desc
);
uint64_t
tdba
=
adapter
->
tx_ring
.
dma
;
uint64_t
tdba
=
adapter
->
tx_ring
.
dma
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
...
@@ -751,7 +751,7 @@ ixgb_setup_rx_resources(struct ixgb_adapter *adapter)
...
@@ -751,7 +751,7 @@ ixgb_setup_rx_resources(struct ixgb_adapter *adapter)
static
void
static
void
ixgb_setup_rctl
(
struct
ixgb_adapter
*
adapter
)
ixgb_setup_rctl
(
struct
ixgb_adapter
*
adapter
)
{
{
u
int32_t
rctl
;
u
32
rctl
;
rctl
=
IXGB_READ_REG
(
&
adapter
->
hw
,
RCTL
);
rctl
=
IXGB_READ_REG
(
&
adapter
->
hw
,
RCTL
);
...
@@ -795,10 +795,10 @@ static void
...
@@ -795,10 +795,10 @@ static void
ixgb_configure_rx
(
struct
ixgb_adapter
*
adapter
)
ixgb_configure_rx
(
struct
ixgb_adapter
*
adapter
)
{
{
uint64_t
rdba
=
adapter
->
rx_ring
.
dma
;
uint64_t
rdba
=
adapter
->
rx_ring
.
dma
;
u
int32_t
rdlen
=
adapter
->
rx_ring
.
count
*
sizeof
(
struct
ixgb_rx_desc
);
u
32
rdlen
=
adapter
->
rx_ring
.
count
*
sizeof
(
struct
ixgb_rx_desc
);
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
u
int32_t
rctl
;
u
32
rctl
;
u
int32_t
rxcsum
;
u
32
rxcsum
;
IXGB_DBG
(
"ixgb_configure_rx
\n
"
);
IXGB_DBG
(
"ixgb_configure_rx
\n
"
);
...
@@ -820,7 +820,7 @@ ixgb_configure_rx(struct ixgb_adapter *adapter)
...
@@ -820,7 +820,7 @@ ixgb_configure_rx(struct ixgb_adapter *adapter)
IXGB_WRITE_REG
(
hw
,
RDT
,
0
);
IXGB_WRITE_REG
(
hw
,
RDT
,
0
);
{
{
u
int32_t
rxdctl
;
u
32
rxdctl
;
/* burst 16 or burst when RXT0 */
/* burst 16 or burst when RXT0 */
rxdctl
=
RXDCTL_WTHRESH_DEFAULT
<<
IXGB_RXDCTL_WTHRESH_SHIFT
rxdctl
=
RXDCTL_WTHRESH_DEFAULT
<<
IXGB_RXDCTL_WTHRESH_SHIFT
|
RXDCTL_HTHRESH_DEFAULT
<<
IXGB_RXDCTL_HTHRESH_SHIFT
|
RXDCTL_HTHRESH_DEFAULT
<<
IXGB_RXDCTL_HTHRESH_SHIFT
...
@@ -829,8 +829,8 @@ ixgb_configure_rx(struct ixgb_adapter *adapter)
...
@@ -829,8 +829,8 @@ ixgb_configure_rx(struct ixgb_adapter *adapter)
}
}
if
(
adapter
->
raidc
)
{
if
(
adapter
->
raidc
)
{
u
int32_t
raidc
;
u
32
raidc
;
u
int8_t
poll_threshold
;
u
8
poll_threshold
;
/* Poll every rx_int_delay period, if RBD exists
/* Poll every rx_int_delay period, if RBD exists
* Receive Backlog Detection is set to <threshold>
* Receive Backlog Detection is set to <threshold>
...
@@ -1030,7 +1030,7 @@ ixgb_set_multi(struct net_device *netdev)
...
@@ -1030,7 +1030,7 @@ ixgb_set_multi(struct net_device *netdev)
{
{
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
u
int32_t
rctl
;
u
32
rctl
;
int
i
;
int
i
;
struct
dev_mc_list
*
mc_ptr
;
struct
dev_mc_list
*
mc_ptr
;
...
@@ -1053,7 +1053,7 @@ ixgb_set_multi(struct net_device *netdev)
...
@@ -1053,7 +1053,7 @@ ixgb_set_multi(struct net_device *netdev)
rctl
|=
IXGB_RCTL_MPE
;
rctl
|=
IXGB_RCTL_MPE
;
IXGB_WRITE_REG
(
hw
,
RCTL
,
rctl
);
IXGB_WRITE_REG
(
hw
,
RCTL
,
rctl
);
}
else
{
}
else
{
u
int8_t
mta
[
netdev
->
mc_count
*
IXGB_ETH_LENGTH_OF_ADDRESS
];
u
8
mta
[
netdev
->
mc_count
*
IXGB_ETH_LENGTH_OF_ADDRESS
];
IXGB_WRITE_REG
(
hw
,
RCTL
,
rctl
);
IXGB_WRITE_REG
(
hw
,
RCTL
,
rctl
);
...
@@ -1148,8 +1148,8 @@ ixgb_tso(struct ixgb_adapter *adapter, struct sk_buff *skb)
...
@@ -1148,8 +1148,8 @@ ixgb_tso(struct ixgb_adapter *adapter, struct sk_buff *skb)
#ifdef NETIF_F_TSO
#ifdef NETIF_F_TSO
struct
ixgb_context_desc
*
context_desc
;
struct
ixgb_context_desc
*
context_desc
;
int
i
;
int
i
;
u
int8_t
ipcss
,
ipcso
,
tucss
,
tucso
,
hdr_len
;
u
8
ipcss
,
ipcso
,
tucss
,
tucso
,
hdr_len
;
u
int16_t
ipcse
,
tucse
,
mss
;
u
16
ipcse
,
tucse
,
mss
;
if
(
likely
(
skb_shinfo
(
skb
)
->
tso_size
))
{
if
(
likely
(
skb_shinfo
(
skb
)
->
tso_size
))
{
hdr_len
=
((
skb
->
h
.
raw
-
skb
->
data
)
+
(
skb
->
h
.
th
->
doff
<<
2
));
hdr_len
=
((
skb
->
h
.
raw
-
skb
->
data
)
+
(
skb
->
h
.
th
->
doff
<<
2
));
...
@@ -1213,7 +1213,7 @@ ixgb_tx_csum(struct ixgb_adapter *adapter, struct sk_buff *skb)
...
@@ -1213,7 +1213,7 @@ ixgb_tx_csum(struct ixgb_adapter *adapter, struct sk_buff *skb)
{
{
struct
ixgb_context_desc
*
context_desc
;
struct
ixgb_context_desc
*
context_desc
;
int
i
;
int
i
;
u
int8_t
css
,
cso
;
u
8
css
,
cso
;
if
(
likely
(
skb
->
ip_summed
==
CHECKSUM_HW
))
{
if
(
likely
(
skb
->
ip_summed
==
CHECKSUM_HW
))
{
css
=
skb
->
h
.
raw
-
skb
->
data
;
css
=
skb
->
h
.
raw
-
skb
->
data
;
...
@@ -1225,7 +1225,7 @@ ixgb_tx_csum(struct ixgb_adapter *adapter, struct sk_buff *skb)
...
@@ -1225,7 +1225,7 @@ ixgb_tx_csum(struct ixgb_adapter *adapter, struct sk_buff *skb)
context_desc
->
tucso
=
cso
;
context_desc
->
tucso
=
cso
;
context_desc
->
tucse
=
0
;
context_desc
->
tucse
=
0
;
/* zero out any previously existing data in one instruction */
/* zero out any previously existing data in one instruction */
*
(
u
int32_t
*
)
&
(
context_desc
->
ipcss
)
=
0
;
*
(
u
32
*
)
&
(
context_desc
->
ipcss
)
=
0
;
context_desc
->
status
=
0
;
context_desc
->
status
=
0
;
context_desc
->
hdr_len
=
0
;
context_desc
->
hdr_len
=
0
;
context_desc
->
mss
=
0
;
context_desc
->
mss
=
0
;
...
@@ -1320,9 +1320,9 @@ ixgb_tx_queue(struct ixgb_adapter *adapter, int count, int vlan_id,
...
@@ -1320,9 +1320,9 @@ ixgb_tx_queue(struct ixgb_adapter *adapter, int count, int vlan_id,
{
{
struct
ixgb_desc_ring
*
tx_ring
=
&
adapter
->
tx_ring
;
struct
ixgb_desc_ring
*
tx_ring
=
&
adapter
->
tx_ring
;
struct
ixgb_tx_desc
*
tx_desc
=
NULL
;
struct
ixgb_tx_desc
*
tx_desc
=
NULL
;
u
int32_t
cmd_type_len
=
adapter
->
tx_cmd_type
;
u
32
cmd_type_len
=
adapter
->
tx_cmd_type
;
u
int8_t
status
=
0
;
u
8
status
=
0
;
u
int8_t
popts
=
0
;
u
8
popts
=
0
;
int
i
;
int
i
;
if
(
tx_flags
&
IXGB_TX_FLAGS_TSO
)
{
if
(
tx_flags
&
IXGB_TX_FLAGS_TSO
)
{
...
@@ -1486,7 +1486,7 @@ static int
...
@@ -1486,7 +1486,7 @@ static int
ixgb_change_mtu
(
struct
net_device
*
netdev
,
int
new_mtu
)
ixgb_change_mtu
(
struct
net_device
*
netdev
,
int
new_mtu
)
{
{
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
u
int32_t
old_mtu
=
adapter
->
rx_buffer_len
;
u
32
old_mtu
=
adapter
->
rx_buffer_len
;
int
max_frame
=
new_mtu
+
ENET_HEADER_SIZE
+
ENET_FCS_LENGTH
;
int
max_frame
=
new_mtu
+
ENET_HEADER_SIZE
+
ENET_FCS_LENGTH
;
IXGB_DBG
(
"ixgb_change_mtu
\n
"
);
IXGB_DBG
(
"ixgb_change_mtu
\n
"
);
...
@@ -1527,7 +1527,7 @@ ixgb_change_mtu(struct net_device *netdev, int new_mtu)
...
@@ -1527,7 +1527,7 @@ ixgb_change_mtu(struct net_device *netdev, int new_mtu)
if
(
hw
->
max_frame_size
>
if
(
hw
->
max_frame_size
>
IXGB_MAX_ENET_FRAME_SIZE_WITHOUT_FCS
+
ENET_FCS_LENGTH
)
{
IXGB_MAX_ENET_FRAME_SIZE_WITHOUT_FCS
+
ENET_FCS_LENGTH
)
{
u
int32_t
ctrl0
=
IXGB_READ_REG
(
hw
,
CTRL0
);
u
32
ctrl0
=
IXGB_READ_REG
(
hw
,
CTRL0
);
if
(
!
(
ctrl0
&
IXGB_CTRL0_JFE
))
{
if
(
!
(
ctrl0
&
IXGB_CTRL0_JFE
))
{
ctrl0
|=
IXGB_CTRL0_JFE
;
ctrl0
|=
IXGB_CTRL0_JFE
;
...
@@ -1727,7 +1727,7 @@ ixgb_intr(int irq, void *data, struct pt_regs *regs)
...
@@ -1727,7 +1727,7 @@ ixgb_intr(int irq, void *data, struct pt_regs *regs)
}
}
#else
#else
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
struct
ixgb_hw
*
hw
=
&
adapter
->
hw
;
u
int32_t
icr
;
u
32
icr
;
uint
i
=
IXGB_MAX_INTR
;
uint
i
=
IXGB_MAX_INTR
;
boolean_t
rxdmt0
=
FALSE
;
boolean_t
rxdmt0
=
FALSE
;
...
@@ -1763,7 +1763,7 @@ static int
...
@@ -1763,7 +1763,7 @@ static int
ixgb_process_intr
(
struct
net_device
*
netdev
)
ixgb_process_intr
(
struct
net_device
*
netdev
)
{
{
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
u
int32_t
icr
;
u
32
icr
;
int
i
=
IXGB_MAX_INTR
;
int
i
=
IXGB_MAX_INTR
;
int
hasReceived
=
0
;
int
hasReceived
=
0
;
...
@@ -1816,7 +1816,7 @@ ixgb_clean_tx_irq(struct ixgb_adapter *adapter)
...
@@ -1816,7 +1816,7 @@ ixgb_clean_tx_irq(struct ixgb_adapter *adapter)
tx_ring
->
buffer_info
[
i
].
skb
=
NULL
;
tx_ring
->
buffer_info
[
i
].
skb
=
NULL
;
}
}
*
(
u
int32_t
*
)
&
(
tx_desc
->
status
)
=
0
;
*
(
u
32
*
)
&
(
tx_desc
->
status
)
=
0
;
i
=
(
i
+
1
)
%
tx_ring
->
count
;
i
=
(
i
+
1
)
%
tx_ring
->
count
;
tx_desc
=
IXGB_TX_DESC
(
*
tx_ring
,
i
);
tx_desc
=
IXGB_TX_DESC
(
*
tx_ring
,
i
);
...
@@ -1840,7 +1840,7 @@ ixgb_poll(struct net_device *netdev, int *budget)
...
@@ -1840,7 +1840,7 @@ ixgb_poll(struct net_device *netdev, int *budget)
struct
pci_dev
*
pdev
=
adapter
->
pdev
;
struct
pci_dev
*
pdev
=
adapter
->
pdev
;
struct
ixgb_rx_desc
*
rx_desc
;
struct
ixgb_rx_desc
*
rx_desc
;
struct
sk_buff
*
skb
;
struct
sk_buff
*
skb
;
u
int32_t
length
;
u
32
length
;
int
i
;
int
i
;
int
received
=
0
;
int
received
=
0
;
int
rx_work_limit
=
*
budget
;
int
rx_work_limit
=
*
budget
;
...
@@ -1963,7 +1963,7 @@ ixgb_clean_rx_irq(struct ixgb_adapter *adapter)
...
@@ -1963,7 +1963,7 @@ ixgb_clean_rx_irq(struct ixgb_adapter *adapter)
struct
pci_dev
*
pdev
=
adapter
->
pdev
;
struct
pci_dev
*
pdev
=
adapter
->
pdev
;
struct
ixgb_rx_desc
*
rx_desc
;
struct
ixgb_rx_desc
*
rx_desc
;
struct
sk_buff
*
skb
;
struct
sk_buff
*
skb
;
u
int32_t
length
;
u
32
length
;
int
i
;
int
i
;
i
=
rx_ring
->
next_to_clean
;
i
=
rx_ring
->
next_to_clean
;
...
@@ -2146,7 +2146,7 @@ static void
...
@@ -2146,7 +2146,7 @@ static void
ixgb_vlan_rx_register
(
struct
net_device
*
netdev
,
struct
vlan_group
*
grp
)
ixgb_vlan_rx_register
(
struct
net_device
*
netdev
,
struct
vlan_group
*
grp
)
{
{
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
u
int32_t
ctrl
,
rctl
;
u
32
ctrl
,
rctl
;
ixgb_irq_disable
(
adapter
);
ixgb_irq_disable
(
adapter
);
adapter
->
vlgrp
=
grp
;
adapter
->
vlgrp
=
grp
;
...
@@ -2184,10 +2184,10 @@ ixgb_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
...
@@ -2184,10 +2184,10 @@ ixgb_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
**/
**/
static
void
static
void
ixgb_vlan_rx_add_vid
(
struct
net_device
*
netdev
,
u
int16_t
vid
)
ixgb_vlan_rx_add_vid
(
struct
net_device
*
netdev
,
u
16
vid
)
{
{
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
u
int32_t
vfta
,
index
;
u
32
vfta
,
index
;
/* add VID to filter table */
/* add VID to filter table */
...
@@ -2204,10 +2204,10 @@ ixgb_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
...
@@ -2204,10 +2204,10 @@ ixgb_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
**/
**/
static
void
static
void
ixgb_vlan_rx_kill_vid
(
struct
net_device
*
netdev
,
u
int16_t
vid
)
ixgb_vlan_rx_kill_vid
(
struct
net_device
*
netdev
,
u
16
vid
)
{
{
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
u
int32_t
vfta
,
index
;
u
32
vfta
,
index
;
ixgb_irq_disable
(
adapter
);
ixgb_irq_disable
(
adapter
);
...
@@ -2234,7 +2234,7 @@ ixgb_restore_vlan(struct ixgb_adapter *adapter)
...
@@ -2234,7 +2234,7 @@ ixgb_restore_vlan(struct ixgb_adapter *adapter)
ixgb_vlan_rx_register
(
adapter
->
netdev
,
adapter
->
vlgrp
);
ixgb_vlan_rx_register
(
adapter
->
netdev
,
adapter
->
vlgrp
);
if
(
adapter
->
vlgrp
)
{
if
(
adapter
->
vlgrp
)
{
u
int16_t
vid
;
u
16
vid
;
for
(
vid
=
0
;
vid
<
VLAN_GROUP_ARRAY_LEN
;
vid
++
)
{
for
(
vid
=
0
;
vid
<
VLAN_GROUP_ARRAY_LEN
;
vid
++
)
{
if
(
!
adapter
->
vlgrp
->
vlan_devices
[
vid
])
if
(
!
adapter
->
vlgrp
->
vlan_devices
[
vid
])
continue
;
continue
;
...
@@ -2285,7 +2285,7 @@ ixgb_rx_checksum(struct ixgb_adapter *adapter,
...
@@ -2285,7 +2285,7 @@ ixgb_rx_checksum(struct ixgb_adapter *adapter,
**/
**/
void
void
ixgb_write_pci_cfg
(
struct
ixgb_hw
*
hw
,
u
int32_t
reg
,
uint16_t
*
value
)
ixgb_write_pci_cfg
(
struct
ixgb_hw
*
hw
,
u
32
reg
,
u16
*
value
)
{
{
struct
ixgb_adapter
*
adapter
=
(
struct
ixgb_adapter
*
)
hw
->
back
;
struct
ixgb_adapter
*
adapter
=
(
struct
ixgb_adapter
*
)
hw
->
back
;
...
@@ -2321,7 +2321,7 @@ ixgb_notify_reboot(struct notifier_block *nb, unsigned long event, void *p)
...
@@ -2321,7 +2321,7 @@ ixgb_notify_reboot(struct notifier_block *nb, unsigned long event, void *p)
* @param state power state to enter
* @param state power state to enter
**/
**/
static
int
static
int
ixgb_suspend
(
struct
pci_dev
*
pdev
,
u
int32_t
state
)
ixgb_suspend
(
struct
pci_dev
*
pdev
,
u
32
state
)
{
{
struct
net_device
*
netdev
=
pci_get_drvdata
(
pdev
);
struct
net_device
*
netdev
=
pci_get_drvdata
(
pdev
);
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
struct
ixgb_adapter
*
adapter
=
netdev
->
priv
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment