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
eda8ba60
Commit
eda8ba60
authored
Jan 07, 2005
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Plain Diff
Merge pobox.com:/garz/repo/netdev-2.6/e1000
into pobox.com:/garz/repo/net-drivers-2.6
parents
582e0be9
712e3f22
Changes
7
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
289 additions
and
185 deletions
+289
-185
Documentation/networking/e1000.txt
Documentation/networking/e1000.txt
+16
-20
drivers/net/e1000/e1000_ethtool.c
drivers/net/e1000/e1000_ethtool.c
+40
-28
drivers/net/e1000/e1000_hw.c
drivers/net/e1000/e1000_hw.c
+109
-16
drivers/net/e1000/e1000_hw.h
drivers/net/e1000/e1000_hw.h
+8
-0
drivers/net/e1000/e1000_main.c
drivers/net/e1000/e1000_main.c
+111
-109
drivers/net/e1000/e1000_osdep.h
drivers/net/e1000/e1000_osdep.h
+2
-7
drivers/net/e1000/e1000_param.c
drivers/net/e1000/e1000_param.c
+3
-5
No files found.
Documentation/networking/e1000.txt
View file @
eda8ba60
Linux* Base Driver for the Intel(R) PRO/1000 Family of Adapters
===============================================================
September 13
, 2004
November 17
, 2004
Contents
...
...
@@ -20,8 +20,7 @@ In This Release
===============
This file describes the Linux* Base Driver for the Intel(R) PRO/1000 Family
of Adapters, version 5.x.x. This driver includes support for Itanium(TM)2
and EM64T systems.
of Adapters, version 5.x.x.
For questions related to hardware requirements, refer to the documentation
supplied with your Intel PRO/1000 adapter. All hardware requirements listed
...
...
@@ -145,9 +144,11 @@ Valid Range: 80-256 for 82542 and 82543-based adapters
Default Value: 256
This value is the number of receive descriptors allocated by the driver.
Increasing this value allows the driver to buffer more incoming packets.
Each descriptor is 16 bytes. A receive buffer is also allocated for each
descriptor and can be either 2048, 4096, 8192, or 16384 bytes, depending
on the MTU setting. The maximum MTU size is 16110.
Each descriptor is 16 bytes. A receive buffer is allocated for each
descriptor and can either be 2048 or 4096 bytes long, depending on the MTU
setting. An incoming packet can span one or more receive descriptors.
The maximum MTU size is 16110.
NOTE: MTU designates the frame size. It only needs to be set for Jumbo
Frames.
...
...
@@ -251,17 +252,16 @@ For copper-based boards, the keywords interact as follows:
also be forced.
The AutoNeg parameter is used when more control is required over the auto-
negotiation process.
When this parameter is used, Speed and Duplex must not
be specified. This parameter is a bitmap that specifies which speed and
duplex settings are advertised to the link partner.
negotiation process.
When this parameter is used, Speed and Duplex parameters
must not be specified. The following table describes supported values for the
AutoNeg parameter:
Bit 7 6 5 4 3 2 1
0
Speed (Mbps) N/A N/A 1000 N/A 100 100 10 10
Duplex Full Full Half Full Half
Speed (Mbps) 1000 100 100 10 1
0
Duplex Full Full Half Full Half
Value (in base 16) 0x20 0x08 0x04 0x02 0x01
For example to limit the negotiated speed/duplex on the interface to 10 Mbps
Half or Full duplex, set AutoNeg to 0x02:
insmod e1000 AutoNeg=0x02
Example: insmod e1000 AutoNeg=0x03, loads e1000 and specifies (10 full duplex,
10 half duplex) for negotiation with the peer.
Note that setting AutoNeg does not guarantee that the board will link at the
highest specified speed or duplex mode, but the board will link at the
...
...
@@ -333,11 +333,7 @@ Additional Configurations
version 1.6 or later is required for this functionality.
The latest release of ethtool can be found from
http://sf.net/projects/gkernel. After ethtool is installed,
ethtool-copy.h must be copied and renamed to ethtool.h in your kernel
source tree at <linux_kernel_src>/include/linux. Backup the original
ethtool.h as needed before copying. The driver then must be recompiled
in order to take advantage of the latest ethtool features.
http://sf.net/projects/gkernel.
NOTE: Ethtool 1.6 only supports a limited set of ethtool options. Support
for a more complete ethtool feature set can be enabled by upgrading
...
...
drivers/net/e1000/e1000_ethtool.c
View file @
eda8ba60
...
...
@@ -776,7 +776,7 @@ static int
e1000_intr_test
(
struct
e1000_adapter
*
adapter
,
uint64_t
*
data
)
{
struct
net_device
*
netdev
=
adapter
->
netdev
;
uint32_t
icr
,
mask
,
i
=
0
,
shared_int
=
TRUE
;
uint32_t
mask
,
i
=
0
,
shared_int
=
TRUE
;
uint32_t
irq
=
adapter
->
pdev
->
irq
;
*
data
=
0
;
...
...
@@ -784,7 +784,8 @@ e1000_intr_test(struct e1000_adapter *adapter, uint64_t *data)
/* Hook up test interrupt handler just for this test */
if
(
!
request_irq
(
irq
,
&
e1000_test_intr
,
0
,
netdev
->
name
,
netdev
))
{
shared_int
=
FALSE
;
}
else
if
(
request_irq
(
irq
,
&
e1000_test_intr
,
SA_SHIRQ
,
netdev
->
name
,
netdev
)){
}
else
if
(
request_irq
(
irq
,
&
e1000_test_intr
,
SA_SHIRQ
,
netdev
->
name
,
netdev
)){
*
data
=
1
;
return
-
1
;
}
...
...
@@ -793,21 +794,6 @@ e1000_intr_test(struct e1000_adapter *adapter, uint64_t *data)
E1000_WRITE_REG
(
&
adapter
->
hw
,
IMC
,
0xFFFFFFFF
);
msec_delay
(
10
);
/* Interrupts are disabled, so read interrupt cause
* register (icr) twice to verify that there are no interrupts
* pending. icr is clear on read.
*/
icr
=
E1000_READ_REG
(
&
adapter
->
hw
,
ICR
);
icr
=
E1000_READ_REG
(
&
adapter
->
hw
,
ICR
);
if
(
icr
!=
0
)
{
/* if icr is non-zero, there is no point
* running other interrupt tests.
*/
*
data
=
2
;
i
=
10
;
}
/* Test each interrupt */
for
(;
i
<
10
;
i
++
)
{
...
...
@@ -856,8 +842,10 @@ e1000_intr_test(struct e1000_adapter *adapter, uint64_t *data)
* test failed.
*/
adapter
->
test_icr
=
0
;
E1000_WRITE_REG
(
&
adapter
->
hw
,
IMC
,
~
mask
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
ICS
,
~
mask
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
IMC
,
(
~
mask
&
0x00007FFF
));
E1000_WRITE_REG
(
&
adapter
->
hw
,
ICS
,
(
~
mask
&
0x00007FFF
));
msec_delay
(
10
);
if
(
adapter
->
test_icr
)
{
...
...
@@ -1336,10 +1324,17 @@ e1000_run_loopback_test(struct e1000_adapter *adapter)
msec_delay
(
200
);
pci_dma_sync_single_for_cpu
(
pdev
,
rxdr
->
buffer_info
[
0
].
dma
,
rxdr
->
buffer_info
[
0
].
length
,
PCI_DMA_FROMDEVICE
);
i
=
0
;
do
{
pci_dma_sync_single_for_cpu
(
pdev
,
rxdr
->
buffer_info
[
i
].
dma
,
rxdr
->
buffer_info
[
i
].
length
,
PCI_DMA_FROMDEVICE
);
if
(
!
e1000_check_lbtest_frame
(
rxdr
->
buffer_info
[
i
++
].
skb
,
1024
))
return
0
;
}
while
(
i
<
64
);
return
e1000_check_lbtest_frame
(
rxdr
->
buffer_info
[
0
].
skb
,
1024
)
;
return
13
;
}
static
int
...
...
@@ -1358,10 +1353,27 @@ static int
e1000_link_test
(
struct
e1000_adapter
*
adapter
,
uint64_t
*
data
)
{
*
data
=
0
;
e1000_check_for_link
(
&
adapter
->
hw
);
if
(
!
(
E1000_READ_REG
(
&
adapter
->
hw
,
STATUS
)
&
E1000_STATUS_LU
))
{
*
data
=
1
;
if
(
adapter
->
hw
.
media_type
==
e1000_media_type_internal_serdes
)
{
int
i
=
0
;
adapter
->
hw
.
serdes_link_down
=
TRUE
;
/* on some blade server designs link establishment */
/* could take as long as 2-3 minutes. */
do
{
e1000_check_for_link
(
&
adapter
->
hw
);
if
(
adapter
->
hw
.
serdes_link_down
==
FALSE
)
return
*
data
;
msec_delay
(
20
);
}
while
(
i
++
<
3750
);
*
data
=
1
;
}
else
{
e1000_check_for_link
(
&
adapter
->
hw
);
if
(
!
(
E1000_READ_REG
(
&
adapter
->
hw
,
STATUS
)
&
E1000_STATUS_LU
))
{
*
data
=
1
;
}
}
return
*
data
;
}
...
...
@@ -1490,6 +1502,8 @@ e1000_set_wol(struct net_device *netdev, struct ethtool_wolinfo *wol)
case
E1000_DEV_ID_82543GC_COPPER
:
case
E1000_DEV_ID_82544EI_FIBER
:
case
E1000_DEV_ID_82546EB_QUAD_COPPER
:
case
E1000_DEV_ID_82545EM_FIBER
:
case
E1000_DEV_ID_82545EM_COPPER
:
return
wol
->
wolopts
?
-
EOPNOTSUPP
:
0
;
case
E1000_DEV_ID_82546EB_FIBER
:
...
...
@@ -1554,9 +1568,7 @@ e1000_phys_id(struct net_device *netdev, uint32_t data)
e1000_setup_led
(
&
adapter
->
hw
);
mod_timer
(
&
adapter
->
blink_timer
,
jiffies
);
set_current_state
(
TASK_INTERRUPTIBLE
);
schedule_timeout
(
data
*
HZ
);
msleep_interruptible
(
data
*
1000
);
del_timer_sync
(
&
adapter
->
blink_timer
);
e1000_led_off
(
&
adapter
->
hw
);
clear_bit
(
E1000_LED_ON
,
&
adapter
->
led_status
);
...
...
drivers/net/e1000/e1000_hw.c
View file @
eda8ba60
...
...
@@ -123,16 +123,31 @@ e1000_set_phy_type(struct e1000_hw *hw)
static
void
e1000_phy_init_script
(
struct
e1000_hw
*
hw
)
{
uint32_t
ret_val
;
uint16_t
phy_saved_data
;
DEBUGFUNC
(
"e1000_phy_init_script"
);
if
(
hw
->
phy_init_script
)
{
msec_delay
(
20
);
/* Save off the current value of register 0x2F5B to be restored at
* the end of this routine. */
ret_val
=
e1000_read_phy_reg
(
hw
,
0x2F5B
,
&
phy_saved_data
);
/* Disabled the PHY transmitter */
e1000_write_phy_reg
(
hw
,
0x2F5B
,
0x0003
);
msec_delay
(
20
);
e1000_write_phy_reg
(
hw
,
0x0000
,
0x0140
);
msec_delay
(
5
);
if
(
hw
->
mac_type
==
e1000_82541
||
hw
->
mac_type
==
e1000_82547
)
{
switch
(
hw
->
mac_type
)
{
case
e1000_82541
:
case
e1000_82547
:
e1000_write_phy_reg
(
hw
,
0x1F95
,
0x0001
);
e1000_write_phy_reg
(
hw
,
0x1F71
,
0xBD21
);
...
...
@@ -150,12 +165,23 @@ e1000_phy_init_script(struct e1000_hw *hw)
e1000_write_phy_reg
(
hw
,
0x1F96
,
0x003F
);
e1000_write_phy_reg
(
hw
,
0x2010
,
0x0008
);
}
else
{
break
;
case
e1000_82541_rev_2
:
case
e1000_82547_rev_2
:
e1000_write_phy_reg
(
hw
,
0x1F73
,
0x0099
);
break
;
default:
break
;
}
e1000_write_phy_reg
(
hw
,
0x0000
,
0x3300
);
msec_delay
(
20
);
/* Now enable the transmitter */
e1000_write_phy_reg
(
hw
,
0x2F5B
,
phy_saved_data
);
if
(
hw
->
mac_type
==
e1000_82547
)
{
uint16_t
fused
,
fine
,
coarse
;
...
...
@@ -244,6 +270,7 @@ e1000_set_mac_type(struct e1000_hw *hw)
case
E1000_DEV_ID_82546GB_COPPER
:
case
E1000_DEV_ID_82546GB_FIBER
:
case
E1000_DEV_ID_82546GB_SERDES
:
case
E1000_DEV_ID_82546GB_PCIE
:
hw
->
mac_type
=
e1000_82546_rev_3
;
break
;
case
E1000_DEV_ID_82541EI
:
...
...
@@ -967,7 +994,7 @@ e1000_setup_copper_link(struct e1000_hw *hw)
if
((
hw
->
mac_type
==
e1000_82541
)
||
(
hw
->
mac_type
==
e1000_82547
))
{
hw
->
dsp_config_state
=
e1000_dsp_config_disabled
;
/* Force MDI for
IGP B-0
PHY */
/* Force MDI for
earlier revs of the IGP
PHY */
phy_data
&=
~
(
IGP01E1000_PSCR_AUTO_MDIX
|
IGP01E1000_PSCR_FORCE_MDI_MDIX
);
hw
->
mdix
=
1
;
...
...
@@ -2111,7 +2138,7 @@ e1000_check_for_link(struct e1000_hw *hw)
* at gigabit speed, then TBI compatibility is not needed. If we are
* at gigabit speed, we turn on TBI compatibility.
*/
if
(
hw
->
tbi_compatibility_en
)
{
if
(
hw
->
tbi_compatibility_en
)
{
uint16_t
speed
,
duplex
;
e1000_get_speed_and_duplex
(
hw
,
&
speed
,
&
duplex
);
if
(
speed
!=
SPEED_1000
)
{
...
...
@@ -2466,12 +2493,14 @@ e1000_read_phy_reg(struct e1000_hw *hw,
DEBUGFUNC
(
"e1000_read_phy_reg"
);
if
(
hw
->
phy_type
==
e1000_phy_igp
&&
(
reg_addr
>
MAX_PHY_MULTI_PAGE_REG
))
{
ret_val
=
e1000_write_phy_reg_ex
(
hw
,
IGP01E1000_PHY_PAGE_SELECT
,
(
uint16_t
)
reg_addr
);
if
(
ret_val
)
if
(
ret_val
)
{
return
ret_val
;
}
}
ret_val
=
e1000_read_phy_reg_ex
(
hw
,
IGP01E1000_PHY_PAGE_SELECT
&
reg_addr
,
...
...
@@ -2570,12 +2599,14 @@ e1000_write_phy_reg(struct e1000_hw *hw,
DEBUGFUNC
(
"e1000_write_phy_reg"
);
if
(
hw
->
phy_type
==
e1000_phy_igp
&&
(
reg_addr
>
MAX_PHY_MULTI_PAGE_REG
))
{
ret_val
=
e1000_write_phy_reg_ex
(
hw
,
IGP01E1000_PHY_PAGE_SELECT
,
(
uint16_t
)
reg_addr
);
if
(
ret_val
)
if
(
ret_val
)
{
return
ret_val
;
}
}
ret_val
=
e1000_write_phy_reg_ex
(
hw
,
IGP01E1000_PHY_PAGE_SELECT
&
reg_addr
,
...
...
@@ -3478,7 +3509,7 @@ e1000_read_eeprom(struct e1000_hw *hw,
/* A check for invalid values: offset too large, too many words, and not
* enough words.
*/
if
((
offset
>
eeprom
->
word_size
)
||
(
words
>
eeprom
->
word_size
-
offset
)
||
if
((
offset
>
=
eeprom
->
word_size
)
||
(
words
>
eeprom
->
word_size
-
offset
)
||
(
words
==
0
))
{
DEBUGOUT
(
"
\"
words
\"
parameter out of bounds
\n
"
);
return
-
E1000_ERR_EEPROM
;
...
...
@@ -3626,7 +3657,7 @@ e1000_write_eeprom(struct e1000_hw *hw,
/* A check for invalid values: offset too large, too many words, and not
* enough words.
*/
if
((
offset
>
eeprom
->
word_size
)
||
(
words
>
eeprom
->
word_size
-
offset
)
||
if
((
offset
>
=
eeprom
->
word_size
)
||
(
words
>
eeprom
->
word_size
-
offset
)
||
(
words
==
0
))
{
DEBUGOUT
(
"
\"
words
\"
parameter out of bounds
\n
"
);
return
-
E1000_ERR_EEPROM
;
...
...
@@ -4918,7 +4949,7 @@ e1000_config_dsp_after_link_change(struct e1000_hw *hw,
boolean_t
link_up
)
{
int32_t
ret_val
;
uint16_t
phy_data
,
speed
,
duplex
,
i
;
uint16_t
phy_data
,
phy_saved_data
,
speed
,
duplex
,
i
;
uint16_t
dsp_reg_array
[
IGP01E1000_PHY_CHANNEL_NUM
]
=
{
IGP01E1000_PHY_AGC_PARAM_A
,
IGP01E1000_PHY_AGC_PARAM_B
,
...
...
@@ -4999,6 +5030,21 @@ e1000_config_dsp_after_link_change(struct e1000_hw *hw,
}
}
else
{
if
(
hw
->
dsp_config_state
==
e1000_dsp_config_activated
)
{
/* Save off the current value of register 0x2F5B to be restored at
* the end of the routines. */
ret_val
=
e1000_read_phy_reg
(
hw
,
0x2F5B
,
&
phy_saved_data
);
if
(
ret_val
)
return
ret_val
;
/* Disable the PHY transmitter */
ret_val
=
e1000_write_phy_reg
(
hw
,
0x2F5B
,
0x0003
);
if
(
ret_val
)
return
ret_val
;
msec_delay
(
20
);
ret_val
=
e1000_write_phy_reg
(
hw
,
0x0000
,
IGP01E1000_IEEE_FORCE_GIGA
);
if
(
ret_val
)
...
...
@@ -5021,10 +5067,33 @@ e1000_config_dsp_after_link_change(struct e1000_hw *hw,
if
(
ret_val
)
return
ret_val
;
msec_delay
(
20
);
/* Now enable the transmitter */
ret_val
=
e1000_write_phy_reg
(
hw
,
0x2F5B
,
phy_saved_data
);
if
(
ret_val
)
return
ret_val
;
hw
->
dsp_config_state
=
e1000_dsp_config_enabled
;
}
if
(
hw
->
ffe_config_state
==
e1000_ffe_config_active
)
{
/* Save off the current value of register 0x2F5B to be restored at
* the end of the routines. */
ret_val
=
e1000_read_phy_reg
(
hw
,
0x2F5B
,
&
phy_saved_data
);
if
(
ret_val
)
return
ret_val
;
/* Disable the PHY transmitter */
ret_val
=
e1000_write_phy_reg
(
hw
,
0x2F5B
,
0x0003
);
if
(
ret_val
)
return
ret_val
;
msec_delay
(
20
);
ret_val
=
e1000_write_phy_reg
(
hw
,
0x0000
,
IGP01E1000_IEEE_FORCE_GIGA
);
if
(
ret_val
)
...
...
@@ -5038,6 +5107,15 @@ e1000_config_dsp_after_link_change(struct e1000_hw *hw,
IGP01E1000_IEEE_RESTART_AUTONEG
);
if
(
ret_val
)
return
ret_val
;
msec_delay
(
20
);
/* Now enable the transmitter */
ret_val
=
e1000_write_phy_reg
(
hw
,
0x2F5B
,
phy_saved_data
);
if
(
ret_val
)
return
ret_val
;
hw
->
ffe_config_state
=
e1000_ffe_config_enabled
;
}
}
...
...
@@ -5126,14 +5204,29 @@ e1000_set_d3_lplu_state(struct e1000_hw *hw,
* Dx states where the power conservation is most important. During
* driver activity we should enable SmartSpeed, so performance is
* maintained. */
ret_val
=
e1000_read_phy_reg
(
hw
,
IGP01E1000_PHY_PORT_CONFIG
,
&
phy_data
);
if
(
ret_val
)
return
ret_val
;
if
(
hw
->
smart_speed
==
e1000_smart_speed_on
)
{
ret_val
=
e1000_read_phy_reg
(
hw
,
IGP01E1000_PHY_PORT_CONFIG
,
&
phy_data
);
if
(
ret_val
)
return
ret_val
;
phy_data
|=
IGP01E1000_PSCFR_SMART_SPEED
;
ret_val
=
e1000_write_phy_reg
(
hw
,
IGP01E1000_PHY_PORT_CONFIG
,
phy_data
);
if
(
ret_val
)
return
ret_val
;
phy_data
|=
IGP01E1000_PSCFR_SMART_SPEED
;
ret_val
=
e1000_write_phy_reg
(
hw
,
IGP01E1000_PHY_PORT_CONFIG
,
phy_data
);
if
(
ret_val
)
return
ret_val
;
}
else
if
(
hw
->
smart_speed
==
e1000_smart_speed_off
)
{
ret_val
=
e1000_read_phy_reg
(
hw
,
IGP01E1000_PHY_PORT_CONFIG
,
&
phy_data
);
if
(
ret_val
)
return
ret_val
;
phy_data
&=
~
IGP01E1000_PSCFR_SMART_SPEED
;
ret_val
=
e1000_write_phy_reg
(
hw
,
IGP01E1000_PHY_PORT_CONFIG
,
phy_data
);
if
(
ret_val
)
return
ret_val
;
}
}
else
if
((
hw
->
autoneg_advertised
==
AUTONEG_ADVERTISE_SPEED_DEFAULT
)
||
(
hw
->
autoneg_advertised
==
AUTONEG_ADVERTISE_10_ALL
)
||
...
...
drivers/net/e1000/e1000_hw.h
View file @
eda8ba60
...
...
@@ -167,6 +167,12 @@ typedef enum {
e1000_downshift_undefined
=
0xFF
}
e1000_downshift
;
typedef
enum
{
e1000_smart_speed_default
=
0
,
e1000_smart_speed_on
,
e1000_smart_speed_off
}
e1000_smart_speed
;
typedef
enum
{
e1000_polarity_reversal_enabled
=
0
,
e1000_polarity_reversal_disabled
,
...
...
@@ -361,6 +367,7 @@ int32_t e1000_set_d3_lplu_state(struct e1000_hw *hw, boolean_t active);
#define E1000_DEV_ID_82546GB_COPPER 0x1079
#define E1000_DEV_ID_82546GB_FIBER 0x107A
#define E1000_DEV_ID_82546GB_SERDES 0x107B
#define E1000_DEV_ID_82546GB_PCIE 0x108A
#define E1000_DEV_ID_82547EI 0x1019
#define NODE_ADDRESS_SIZE 6
#define ETH_LENGTH_OF_ADDRESS 6
...
...
@@ -1026,6 +1033,7 @@ struct e1000_hw {
uint8_t
perm_mac_addr
[
NODE_ADDRESS_SIZE
];
boolean_t
disable_polarity_correction
;
boolean_t
speed_downgraded
;
e1000_smart_speed
smart_speed
;
e1000_dsp_config
dsp_config_state
;
boolean_t
get_link_status
;
boolean_t
serdes_link_down
;
...
...
drivers/net/e1000/e1000_main.c
View file @
eda8ba60
This diff is collapsed.
Click to expand it.
drivers/net/e1000/e1000_osdep.h
View file @
eda8ba60
...
...
@@ -42,13 +42,8 @@
#include <linux/sched.h>
#ifndef msec_delay
#define msec_delay(x) do { if(in_interrupt()) { \
/* Don't mdelay in interrupt context! */
\
BUG(); \
} else { \
set_current_state(TASK_UNINTERRUPTIBLE); \
schedule_timeout((x * HZ)/1000 + 2); \
} } while(0)
#define msec_delay(x) msleep(x)
/* Some workarounds require millisecond delays and are run during interrupt
* context. Most notably, when establishing link, the phy may need tweaking
* but cannot process phy register reads/writes faster than millisecond
...
...
drivers/net/e1000/e1000_param.c
View file @
eda8ba60
...
...
@@ -47,7 +47,7 @@
#define E1000_PARAM(X, desc) \
static int __devinitdata X[E1000_MAX_NIC+1] = E1000_PARAM_INIT; \
static int num_##X = 0; \
module_param_array
(
X, int, &num_##X, 0); \
module_param_array
_named(X,
X, int, &num_##X, 0); \
MODULE_PARM_DESC(X, desc);
/* Transmit Descriptor Count
...
...
@@ -470,9 +470,6 @@ e1000_check_options(struct e1000_adapter *adapter)
if
(
num_InterruptThrottleRate
>
bd
)
{
adapter
->
itr
=
InterruptThrottleRate
[
bd
];
switch
(
adapter
->
itr
)
{
case
-
1
:
adapter
->
itr
=
1
;
break
;
case
0
:
DPRINTK
(
PROBE
,
INFO
,
"%s turned off
\n
"
,
opt
.
name
);
...
...
@@ -481,13 +478,14 @@ e1000_check_options(struct e1000_adapter *adapter)
DPRINTK
(
PROBE
,
INFO
,
"%s set to dynamic mode
\n
"
,
opt
.
name
);
break
;
case
-
1
:
default:
e1000_validate_option
(
&
adapter
->
itr
,
&
opt
,
adapter
);
break
;
}
}
else
{
adapter
->
itr
=
1
;
adapter
->
itr
=
opt
.
def
;
}
}
...
...
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