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
Kirill Smelkov
linux
Commits
fa88c854
Commit
fa88c854
authored
Jul 29, 2004
by
Ganesh Venkatesan
Committed by
Jeff Garzik
Jul 29, 2004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] e1000 - white space and related cleanup
parent
88966993
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
97 additions
and
131 deletions
+97
-131
drivers/net/e1000/e1000.h
drivers/net/e1000/e1000.h
+7
-9
drivers/net/e1000/e1000_hw.c
drivers/net/e1000/e1000_hw.c
+1
-1
drivers/net/e1000/e1000_hw.h
drivers/net/e1000/e1000_hw.h
+0
-1
drivers/net/e1000/e1000_main.c
drivers/net/e1000/e1000_main.c
+65
-98
drivers/net/e1000/e1000_param.c
drivers/net/e1000/e1000_param.c
+24
-22
No files found.
drivers/net/e1000/e1000.h
View file @
fa88c854
...
@@ -102,11 +102,12 @@ struct e1000_adapter;
...
@@ -102,11 +102,12 @@ struct e1000_adapter;
#define E1000_MAX_INTR 10
#define E1000_MAX_INTR 10
/*
How many descriptors for TX and RX ?
*/
/*
TX/RX descriptor defines
*/
#define E1000_DEFAULT_TXD 256
#define E1000_DEFAULT_TXD 256
#define E1000_MAX_TXD 256
#define E1000_MAX_TXD 256
#define E1000_MIN_TXD 80
#define E1000_MIN_TXD 80
#define E1000_MAX_82544_TXD 4096
#define E1000_MAX_82544_TXD 4096
#define E1000_DEFAULT_RXD 256
#define E1000_DEFAULT_RXD 256
#define E1000_MAX_RXD 256
#define E1000_MAX_RXD 256
#define E1000_MIN_RXD 80
#define E1000_MIN_RXD 80
...
@@ -127,14 +128,11 @@ struct e1000_adapter;
...
@@ -127,14 +128,11 @@ struct e1000_adapter;
#define E1000_TX_HEAD_ADDR_SHIFT 7
#define E1000_TX_HEAD_ADDR_SHIFT 7
#define E1000_PBA_TX_MASK 0xFFFF0000
#define E1000_PBA_TX_MASK 0xFFFF0000
/* Flow Control High-Watermark: 5688 bytes below Rx FIFO size */
/* Flow Control Watermarks */
#define E1000_FC_HIGH_DIFF 0x1638
#define E1000_FC_HIGH_DIFF 0x1638
/* High: 5688 bytes below Rx FIFO size */
#define E1000_FC_LOW_DIFF 0x1640
/* Low: 5696 bytes below Rx FIFO size */
/* Flow Control Low-Watermark: 5696 bytes below Rx FIFO size */
#define E1000_FC_LOW_DIFF 0x1640
/* Flow Control Pause Time: 858 usec */
#define E1000_FC_PAUSE_TIME 0x0680
/* 858 usec */
#define E1000_FC_PAUSE_TIME 0x0680
/* How many Tx Descriptors do we need to call netif_wake_queue ? */
/* How many Tx Descriptors do we need to call netif_wake_queue ? */
#define E1000_TX_QUEUE_WAKE 16
#define E1000_TX_QUEUE_WAKE 16
...
...
drivers/net/e1000/e1000_hw.c
View file @
fa88c854
...
@@ -3445,7 +3445,6 @@ e1000_read_eeprom(struct e1000_hw *hw,
...
@@ -3445,7 +3445,6 @@ e1000_read_eeprom(struct e1000_hw *hw,
uint32_t
i
=
0
;
uint32_t
i
=
0
;
DEBUGFUNC
(
"e1000_read_eeprom"
);
DEBUGFUNC
(
"e1000_read_eeprom"
);
/* A check for invalid values: offset too large, too many words, and not
/* A check for invalid values: offset too large, too many words, and not
* enough words.
* enough words.
*/
*/
...
@@ -5216,3 +5215,4 @@ e1000_enable_mng_pass_thru(struct e1000_hw *hw)
...
@@ -5216,3 +5215,4 @@ e1000_enable_mng_pass_thru(struct e1000_hw *hw)
}
}
return
FALSE
;
return
FALSE
;
}
}
drivers/net/e1000/e1000_hw.h
View file @
fa88c854
...
@@ -1043,7 +1043,6 @@ struct e1000_hw {
...
@@ -1043,7 +1043,6 @@ struct e1000_hw {
#define E1000_EEPROM_SWDPIN0 0x0001
/* SWDPIN 0 EEPROM Value */
#define E1000_EEPROM_SWDPIN0 0x0001
/* SWDPIN 0 EEPROM Value */
#define E1000_EEPROM_LED_LOGIC 0x0020
/* Led Logic Word */
#define E1000_EEPROM_LED_LOGIC 0x0020
/* Led Logic Word */
/* Register Bit Masks */
/* Register Bit Masks */
/* Device Control */
/* Device Control */
#define E1000_CTRL_FD 0x00000001
/* Full duplex.0=half; 1=full */
#define E1000_CTRL_FD 0x00000001
/* Full duplex.0=half; 1=full */
...
...
drivers/net/e1000/e1000_main.c
View file @
fa88c854
...
@@ -168,7 +168,7 @@ static int e1000_resume(struct pci_dev *pdev);
...
@@ -168,7 +168,7 @@ static int e1000_resume(struct pci_dev *pdev);
#ifdef CONFIG_NET_POLL_CONTROLLER
#ifdef CONFIG_NET_POLL_CONTROLLER
/* for netdump / net console */
/* for netdump / net console */
static
void
e1000_netpoll
(
struct
net_device
*
dev
);
static
void
e1000_netpoll
(
struct
net_device
*
net
dev
);
#endif
#endif
struct
notifier_block
e1000_notifier_reboot
=
{
struct
notifier_block
e1000_notifier_reboot
=
{
...
@@ -181,7 +181,6 @@ struct notifier_block e1000_notifier_reboot = {
...
@@ -181,7 +181,6 @@ struct notifier_block e1000_notifier_reboot = {
extern
void
e1000_check_options
(
struct
e1000_adapter
*
adapter
);
extern
void
e1000_check_options
(
struct
e1000_adapter
*
adapter
);
static
struct
pci_driver
e1000_driver
=
{
static
struct
pci_driver
e1000_driver
=
{
.
name
=
e1000_driver_name
,
.
name
=
e1000_driver_name
,
.
id_table
=
e1000_pci_tbl
,
.
id_table
=
e1000_pci_tbl
,
...
@@ -336,10 +335,10 @@ e1000_reset(struct e1000_adapter *adapter)
...
@@ -336,10 +335,10 @@ e1000_reset(struct e1000_adapter *adapter)
E1000_WRITE_REG
(
&
adapter
->
hw
,
PBA
,
pba
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
PBA
,
pba
);
/* flow control settings */
/* flow control settings */
adapter
->
hw
.
fc_high_water
=
adapter
->
hw
.
fc_high_water
=
(
pba
<<
E1000_PBA_BYTES_SHIFT
)
-
(
pba
<<
E1000_PBA_BYTES_SHIFT
)
-
E1000_FC_HIGH_DIFF
;
E1000_FC_HIGH_DIFF
;
adapter
->
hw
.
fc_low_water
=
adapter
->
hw
.
fc_low_water
=
(
pba
<<
E1000_PBA_BYTES_SHIFT
)
-
(
pba
<<
E1000_PBA_BYTES_SHIFT
)
-
E1000_FC_LOW_DIFF
;
E1000_FC_LOW_DIFF
;
adapter
->
hw
.
fc_pause_time
=
E1000_FC_PAUSE_TIME
;
adapter
->
hw
.
fc_pause_time
=
E1000_FC_PAUSE_TIME
;
adapter
->
hw
.
fc_send_xon
=
1
;
adapter
->
hw
.
fc_send_xon
=
1
;
adapter
->
hw
.
fc
=
adapter
->
hw
.
original_fc
;
adapter
->
hw
.
fc
=
adapter
->
hw
.
original_fc
;
...
@@ -424,8 +423,8 @@ e1000_probe(struct pci_dev *pdev,
...
@@ -424,8 +423,8 @@ e1000_probe(struct pci_dev *pdev,
adapter
->
msg_enable
=
(
1
<<
debug
)
-
1
;
adapter
->
msg_enable
=
(
1
<<
debug
)
-
1
;
rtnl_lock
();
rtnl_lock
();
/* we need to set the name early
since the DPRINTK macro needs it set
*/
/* we need to set the name early
for the DPRINTK macro
*/
if
(
dev_alloc_name
(
netdev
,
netdev
->
name
)
<
0
)
if
(
dev_alloc_name
(
netdev
,
netdev
->
name
)
<
0
)
goto
err_free_unlock
;
goto
err_free_unlock
;
mmio_start
=
pci_resource_start
(
pdev
,
BAR_0
);
mmio_start
=
pci_resource_start
(
pdev
,
BAR_0
);
...
@@ -583,10 +582,9 @@ e1000_probe(struct pci_dev *pdev,
...
@@ -583,10 +582,9 @@ e1000_probe(struct pci_dev *pdev,
adapter
->
wol
|=
E1000_WUFC_MAG
;
adapter
->
wol
|=
E1000_WUFC_MAG
;
/* reset the hardware with the new settings */
/* reset the hardware with the new settings */
e1000_reset
(
adapter
);
e1000_reset
(
adapter
);
/*
since we are holding the rtnl lock already,
call the no-lock version */
/*
We're already holding the rtnl lock;
call the no-lock version */
if
((
err
=
register_netdevice
(
netdev
)))
if
((
err
=
register_netdevice
(
netdev
)))
goto
err_register
;
goto
err_register
;
...
@@ -677,7 +675,7 @@ e1000_sw_init(struct e1000_adapter *adapter)
...
@@ -677,7 +675,7 @@ e1000_sw_init(struct e1000_adapter *adapter)
/* identify the MAC */
/* identify the MAC */
if
(
e1000_set_mac_type
(
hw
))
{
if
(
e1000_set_mac_type
(
hw
))
{
DPRINTK
(
PROBE
,
ERR
,
"Unknown MAC Type
\n
"
);
DPRINTK
(
PROBE
,
ERR
,
"Unknown MAC Type
\n
"
);
return
-
EIO
;
return
-
EIO
;
}
}
...
@@ -975,7 +973,9 @@ e1000_setup_rctl(struct e1000_adapter *adapter)
...
@@ -975,7 +973,9 @@ e1000_setup_rctl(struct e1000_adapter *adapter)
else
else
rctl
&=
~
E1000_RCTL_SBP
;
rctl
&=
~
E1000_RCTL_SBP
;
/* Setup buffer sizes */
rctl
&=
~
(
E1000_RCTL_SZ_4096
);
rctl
&=
~
(
E1000_RCTL_SZ_4096
);
rctl
|=
(
E1000_RCTL_BSEX
|
E1000_RCTL_LPE
);
switch
(
adapter
->
rx_buffer_len
)
{
switch
(
adapter
->
rx_buffer_len
)
{
case
E1000_RXBUFFER_2048
:
case
E1000_RXBUFFER_2048
:
default:
default:
...
@@ -983,13 +983,13 @@ e1000_setup_rctl(struct e1000_adapter *adapter)
...
@@ -983,13 +983,13 @@ e1000_setup_rctl(struct e1000_adapter *adapter)
rctl
&=
~
(
E1000_RCTL_BSEX
|
E1000_RCTL_LPE
);
rctl
&=
~
(
E1000_RCTL_BSEX
|
E1000_RCTL_LPE
);
break
;
break
;
case
E1000_RXBUFFER_4096
:
case
E1000_RXBUFFER_4096
:
rctl
|=
E1000_RCTL_SZ_4096
|
E1000_RCTL_BSEX
|
E1000_RCTL_LPE
;
rctl
|=
E1000_RCTL_SZ_4096
;
break
;
break
;
case
E1000_RXBUFFER_8192
:
case
E1000_RXBUFFER_8192
:
rctl
|=
E1000_RCTL_SZ_8192
|
E1000_RCTL_BSEX
|
E1000_RCTL_LPE
;
rctl
|=
E1000_RCTL_SZ_8192
;
break
;
break
;
case
E1000_RXBUFFER_16384
:
case
E1000_RXBUFFER_16384
:
rctl
|=
E1000_RCTL_SZ_16384
|
E1000_RCTL_BSEX
|
E1000_RCTL_LPE
;
rctl
|=
E1000_RCTL_SZ_16384
;
break
;
break
;
}
}
...
@@ -1011,13 +1011,11 @@ e1000_configure_rx(struct e1000_adapter *adapter)
...
@@ -1011,13 +1011,11 @@ e1000_configure_rx(struct e1000_adapter *adapter)
uint32_t
rctl
;
uint32_t
rctl
;
uint32_t
rxcsum
;
uint32_t
rxcsum
;
/* make sure receives are disabled while setting up the descriptors */
/* disable receives while setting up the descriptors */
rctl
=
E1000_READ_REG
(
&
adapter
->
hw
,
RCTL
);
rctl
=
E1000_READ_REG
(
&
adapter
->
hw
,
RCTL
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
&
~
E1000_RCTL_EN
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
&
~
E1000_RCTL_EN
);
/* set the Receive Delay Timer Register */
/* set the Receive Delay Timer Register */
E1000_WRITE_REG
(
&
adapter
->
hw
,
RDTR
,
adapter
->
rx_int_delay
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
RDTR
,
adapter
->
rx_int_delay
);
if
(
adapter
->
hw
.
mac_type
>=
e1000_82540
)
{
if
(
adapter
->
hw
.
mac_type
>=
e1000_82540
)
{
...
@@ -1028,7 +1026,6 @@ e1000_configure_rx(struct e1000_adapter *adapter)
...
@@ -1028,7 +1026,6 @@ e1000_configure_rx(struct e1000_adapter *adapter)
}
}
/* Setup the Base and Length of the Rx Descriptor Ring */
/* Setup the Base and Length of the Rx Descriptor Ring */
E1000_WRITE_REG
(
&
adapter
->
hw
,
RDBAL
,
(
rdba
&
0x00000000ffffffffULL
));
E1000_WRITE_REG
(
&
adapter
->
hw
,
RDBAL
,
(
rdba
&
0x00000000ffffffffULL
));
E1000_WRITE_REG
(
&
adapter
->
hw
,
RDBAH
,
(
rdba
>>
32
));
E1000_WRITE_REG
(
&
adapter
->
hw
,
RDBAH
,
(
rdba
>>
32
));
...
@@ -1047,7 +1044,6 @@ e1000_configure_rx(struct e1000_adapter *adapter)
...
@@ -1047,7 +1044,6 @@ e1000_configure_rx(struct e1000_adapter *adapter)
}
}
/* Enable Receives */
/* Enable Receives */
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
);
}
}
...
@@ -1168,7 +1164,6 @@ e1000_clean_rx_ring(struct e1000_adapter *adapter)
...
@@ -1168,7 +1164,6 @@ e1000_clean_rx_ring(struct e1000_adapter *adapter)
PCI_DMA_FROMDEVICE
);
PCI_DMA_FROMDEVICE
);
dev_kfree_skb
(
buffer_info
->
skb
);
dev_kfree_skb
(
buffer_info
->
skb
);
buffer_info
->
skb
=
NULL
;
buffer_info
->
skb
=
NULL
;
}
}
}
}
...
@@ -1334,7 +1329,8 @@ e1000_set_multi(struct net_device *netdev)
...
@@ -1334,7 +1329,8 @@ e1000_set_multi(struct net_device *netdev)
e1000_leave_82542_rst
(
adapter
);
e1000_leave_82542_rst
(
adapter
);
}
}
/* need to wait a few seconds after link up to get diagnostic information from the phy */
/* Need to wait a few seconds after link up to get diagnostic information from
* the phy */
static
void
static
void
e1000_update_phy_info
(
unsigned
long
data
)
e1000_update_phy_info
(
unsigned
long
data
)
...
@@ -1590,7 +1586,6 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb,
...
@@ -1590,7 +1586,6 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb,
unsigned
int
f
;
unsigned
int
f
;
len
-=
skb
->
data_len
;
len
-=
skb
->
data_len
;
i
=
tx_ring
->
next_to_use
;
i
=
tx_ring
->
next_to_use
;
while
(
len
)
{
while
(
len
)
{
...
@@ -1662,6 +1657,7 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb,
...
@@ -1662,6 +1657,7 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb,
if
(
unlikely
(
++
i
==
tx_ring
->
count
))
i
=
0
;
if
(
unlikely
(
++
i
==
tx_ring
->
count
))
i
=
0
;
}
}
}
}
i
=
(
i
==
0
)
?
tx_ring
->
count
-
1
:
i
-
1
;
i
=
(
i
==
0
)
?
tx_ring
->
count
-
1
:
i
-
1
;
tx_ring
->
buffer_info
[
i
].
skb
=
skb
;
tx_ring
->
buffer_info
[
i
].
skb
=
skb
;
tx_ring
->
buffer_info
[
first
].
next_to_watch
=
i
;
tx_ring
->
buffer_info
[
first
].
next_to_watch
=
i
;
...
@@ -1764,14 +1760,15 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
...
@@ -1764,14 +1760,15 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
unsigned
int
first
,
max_per_txd
=
E1000_MAX_DATA_PER_TXD
;
unsigned
int
first
,
max_per_txd
=
E1000_MAX_DATA_PER_TXD
;
unsigned
int
max_txd_pwr
=
E1000_MAX_TXD_PWR
;
unsigned
int
max_txd_pwr
=
E1000_MAX_TXD_PWR
;
unsigned
int
tx_flags
=
0
;
unsigned
int
tx_flags
=
0
;
unsigned
long
flags
;
unsigned
int
len
=
skb
->
len
;
unsigned
int
len
=
skb
->
len
;
int
count
=
0
;
unsigned
long
flags
;
unsigned
int
mss
=
0
;
unsigned
int
nr_frags
=
0
;
unsigned
int
nr_frags
=
0
;
unsigned
int
mss
=
0
;
int
count
=
0
;
unsigned
int
f
;
unsigned
int
f
;
nr_frags
=
skb_shinfo
(
skb
)
->
nr_frags
;
nr_frags
=
skb_shinfo
(
skb
)
->
nr_frags
;
len
-=
skb
->
data_len
;
len
-=
skb
->
data_len
;
if
(
unlikely
(
skb
->
len
<=
0
))
{
if
(
unlikely
(
skb
->
len
<=
0
))
{
dev_kfree_skb_any
(
skb
);
dev_kfree_skb_any
(
skb
);
return
0
;
return
0
;
...
@@ -1789,15 +1786,16 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
...
@@ -1789,15 +1786,16 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
max_per_txd
=
min
(
mss
<<
2
,
max_per_txd
);
max_per_txd
=
min
(
mss
<<
2
,
max_per_txd
);
max_txd_pwr
=
fls
(
max_per_txd
)
-
1
;
max_txd_pwr
=
fls
(
max_per_txd
)
-
1
;
}
}
if
((
mss
)
||
(
skb
->
ip_summed
==
CHECKSUM_HW
))
if
((
mss
)
||
(
skb
->
ip_summed
==
CHECKSUM_HW
))
count
++
;
count
++
;
count
++
;
/*
for sentinel desc
*/
count
++
;
/*
for sentinel desc
*/
#else
#else
if
(
skb
->
ip_summed
==
CHECKSUM_HW
)
if
(
skb
->
ip_summed
==
CHECKSUM_HW
)
count
++
;
count
++
;
#endif
#endif
count
+=
TXD_USE_COUNT
(
len
,
max_txd_pwr
);
count
+=
TXD_USE_COUNT
(
len
,
max_txd_pwr
);
if
(
adapter
->
pcix_82544
)
if
(
adapter
->
pcix_82544
)
count
++
;
count
++
;
...
@@ -1809,13 +1807,15 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
...
@@ -1809,13 +1807,15 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
count
+=
nr_frags
;
count
+=
nr_frags
;
spin_lock_irqsave
(
&
adapter
->
tx_lock
,
flags
);
spin_lock_irqsave
(
&
adapter
->
tx_lock
,
flags
);
/* need: count + 2 desc gap to keep tail from touching
/* need: count + 2 desc gap to keep tail from touching
* head, otherwise try next time */
* head, otherwise try next time */
if
(
E1000_DESC_UNUSED
(
&
adapter
->
tx_ring
)
<
count
+
2
)
{
if
(
E1000_DESC_UNUSED
(
&
adapter
->
tx_ring
)
<
count
+
2
)
{
netif_stop_queue
(
netdev
);
netif_stop_queue
(
netdev
);
spin_unlock_irqrestore
(
&
adapter
->
tx_lock
,
flags
);
spin_unlock_irqrestore
(
&
adapter
->
tx_lock
,
flags
);
return
1
;
return
1
;
}
}
spin_unlock_irqrestore
(
&
adapter
->
tx_lock
,
flags
);
spin_unlock_irqrestore
(
&
adapter
->
tx_lock
,
flags
);
if
(
unlikely
(
adapter
->
hw
.
mac_type
==
e1000_82547
))
{
if
(
unlikely
(
adapter
->
hw
.
mac_type
==
e1000_82547
))
{
...
@@ -1926,7 +1926,6 @@ e1000_change_mtu(struct net_device *netdev, int new_mtu)
...
@@ -1926,7 +1926,6 @@ e1000_change_mtu(struct net_device *netdev, int new_mtu)
}
}
if
(
old_mtu
!=
adapter
->
rx_buffer_len
&&
netif_running
(
netdev
))
{
if
(
old_mtu
!=
adapter
->
rx_buffer_len
&&
netif_running
(
netdev
))
{
e1000_down
(
adapter
);
e1000_down
(
adapter
);
e1000_up
(
adapter
);
e1000_up
(
adapter
);
}
}
...
@@ -1972,8 +1971,6 @@ e1000_update_stats(struct e1000_adapter *adapter)
...
@@ -1972,8 +1971,6 @@ e1000_update_stats(struct e1000_adapter *adapter)
adapter
->
stats
.
prc1023
+=
E1000_READ_REG
(
hw
,
PRC1023
);
adapter
->
stats
.
prc1023
+=
E1000_READ_REG
(
hw
,
PRC1023
);
adapter
->
stats
.
prc1522
+=
E1000_READ_REG
(
hw
,
PRC1522
);
adapter
->
stats
.
prc1522
+=
E1000_READ_REG
(
hw
,
PRC1522
);
/* the rest of the counters are only modified here */
adapter
->
stats
.
symerrs
+=
E1000_READ_REG
(
hw
,
SYMERRS
);
adapter
->
stats
.
symerrs
+=
E1000_READ_REG
(
hw
,
SYMERRS
);
adapter
->
stats
.
mpc
+=
E1000_READ_REG
(
hw
,
MPC
);
adapter
->
stats
.
mpc
+=
E1000_READ_REG
(
hw
,
MPC
);
adapter
->
stats
.
scc
+=
E1000_READ_REG
(
hw
,
SCC
);
adapter
->
stats
.
scc
+=
E1000_READ_REG
(
hw
,
SCC
);
...
@@ -2180,8 +2177,8 @@ e1000_clean(struct net_device *netdev, int *budget)
...
@@ -2180,8 +2177,8 @@ e1000_clean(struct net_device *netdev, int *budget)
return
(
work_done
>=
work_to_do
);
return
(
work_done
>=
work_to_do
);
}
}
#endif
#endif
/**
/**
* e1000_clean_tx_irq - Reclaim resources after transmit completes
* e1000_clean_tx_irq - Reclaim resources after transmit completes
* @adapter: board private structure
* @adapter: board private structure
...
@@ -2198,31 +2195,25 @@ e1000_clean_tx_irq(struct e1000_adapter *adapter)
...
@@ -2198,31 +2195,25 @@ e1000_clean_tx_irq(struct e1000_adapter *adapter)
unsigned
int
i
,
eop
;
unsigned
int
i
,
eop
;
boolean_t
cleaned
=
FALSE
;
boolean_t
cleaned
=
FALSE
;
i
=
tx_ring
->
next_to_clean
;
i
=
tx_ring
->
next_to_clean
;
eop
=
tx_ring
->
buffer_info
[
i
].
next_to_watch
;
eop
=
tx_ring
->
buffer_info
[
i
].
next_to_watch
;
eop_desc
=
E1000_TX_DESC
(
*
tx_ring
,
eop
);
eop_desc
=
E1000_TX_DESC
(
*
tx_ring
,
eop
);
while
(
eop_desc
->
upper
.
data
&
cpu_to_le32
(
E1000_TXD_STAT_DD
))
{
while
(
eop_desc
->
upper
.
data
&
cpu_to_le32
(
E1000_TXD_STAT_DD
))
{
for
(
cleaned
=
FALSE
;
!
cleaned
;
)
{
for
(
cleaned
=
FALSE
;
!
cleaned
;
)
{
tx_desc
=
E1000_TX_DESC
(
*
tx_ring
,
i
);
tx_desc
=
E1000_TX_DESC
(
*
tx_ring
,
i
);
buffer_info
=
&
tx_ring
->
buffer_info
[
i
];
buffer_info
=
&
tx_ring
->
buffer_info
[
i
];
if
(
likely
(
buffer_info
->
dma
))
{
if
(
likely
(
buffer_info
->
dma
))
{
pci_unmap_page
(
pdev
,
pci_unmap_page
(
pdev
,
buffer_info
->
dma
,
buffer_info
->
dma
,
buffer_info
->
length
,
buffer_info
->
length
,
PCI_DMA_TODEVICE
);
PCI_DMA_TODEVICE
);
buffer_info
->
dma
=
0
;
buffer_info
->
dma
=
0
;
}
}
if
(
buffer_info
->
skb
)
{
if
(
buffer_info
->
skb
)
{
dev_kfree_skb_any
(
buffer_info
->
skb
);
dev_kfree_skb_any
(
buffer_info
->
skb
);
buffer_info
->
skb
=
NULL
;
buffer_info
->
skb
=
NULL
;
}
}
...
@@ -2252,7 +2243,7 @@ e1000_clean_tx_irq(struct e1000_adapter *adapter)
...
@@ -2252,7 +2243,7 @@ e1000_clean_tx_irq(struct e1000_adapter *adapter)
}
}
/**
/**
* e1000_clean_rx_irq - Send received data up the network stack
,
* e1000_clean_rx_irq - Send received data up the network stack
* @adapter: board private structure
* @adapter: board private structure
**/
**/
...
@@ -2281,14 +2272,11 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter)
...
@@ -2281,14 +2272,11 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter)
while
(
rx_desc
->
status
&
E1000_RXD_STAT_DD
)
{
while
(
rx_desc
->
status
&
E1000_RXD_STAT_DD
)
{
buffer_info
=
&
rx_ring
->
buffer_info
[
i
];
buffer_info
=
&
rx_ring
->
buffer_info
[
i
];
#ifdef CONFIG_E1000_NAPI
#ifdef CONFIG_E1000_NAPI
if
(
*
work_done
>=
work_to_do
)
if
(
*
work_done
>=
work_to_do
)
break
;
break
;
(
*
work_done
)
++
;
(
*
work_done
)
++
;
#endif
#endif
cleaned
=
TRUE
;
cleaned
=
TRUE
;
pci_unmap_single
(
pdev
,
pci_unmap_single
(
pdev
,
...
@@ -2299,40 +2287,27 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter)
...
@@ -2299,40 +2287,27 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter)
skb
=
buffer_info
->
skb
;
skb
=
buffer_info
->
skb
;
length
=
le16_to_cpu
(
rx_desc
->
length
);
length
=
le16_to_cpu
(
rx_desc
->
length
);
if
(
unlikely
(
!
(
rx_desc
->
status
&
E1000_RXD_STAT_EOP
)))
{
if
(
unlikely
(
!
(
rx_desc
->
status
&
E1000_RXD_STAT_EOP
)))
{
/* All receives must fit into a single buffer */
/* All receives must fit into a single buffer */
E1000_DBG
(
"%s: Receive packet consumed multiple"
E1000_DBG
(
"%s: Receive packet consumed multiple buffers
\n
"
,
" buffers
\n
"
,
netdev
->
name
);
netdev
->
name
);
dev_kfree_skb_irq
(
skb
);
dev_kfree_skb_irq
(
skb
);
goto
next_desc
;
goto
next_desc
;
}
}
if
(
unlikely
(
rx_desc
->
errors
&
E1000_RXD_ERR_FRAME_ERR_MASK
))
{
if
(
unlikely
(
rx_desc
->
errors
&
E1000_RXD_ERR_FRAME_ERR_MASK
))
{
last_byte
=
*
(
skb
->
data
+
length
-
1
);
last_byte
=
*
(
skb
->
data
+
length
-
1
);
if
(
TBI_ACCEPT
(
&
adapter
->
hw
,
rx_desc
->
status
,
if
(
TBI_ACCEPT
(
&
adapter
->
hw
,
rx_desc
->
status
,
rx_desc
->
errors
,
length
,
last_byte
))
{
rx_desc
->
errors
,
length
,
last_byte
))
{
spin_lock_irqsave
(
&
adapter
->
stats_lock
,
flags
);
spin_lock_irqsave
(
&
adapter
->
stats_lock
,
flags
);
e1000_tbi_adjust_stats
(
&
adapter
->
hw
,
e1000_tbi_adjust_stats
(
&
adapter
->
hw
,
&
adapter
->
stats
,
&
adapter
->
stats
,
length
,
skb
->
data
);
length
,
skb
->
data
);
spin_unlock_irqrestore
(
&
adapter
->
stats_lock
,
spin_unlock_irqrestore
(
&
adapter
->
stats_lock
,
flags
);
flags
);
length
--
;
length
--
;
}
else
{
}
else
{
dev_kfree_skb_irq
(
skb
);
dev_kfree_skb_irq
(
skb
);
goto
next_desc
;
goto
next_desc
;
}
}
}
}
...
@@ -2368,7 +2343,6 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter)
...
@@ -2368,7 +2343,6 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter)
next_desc:
next_desc:
rx_desc
->
status
=
0
;
rx_desc
->
status
=
0
;
buffer_info
->
skb
=
NULL
;
buffer_info
->
skb
=
NULL
;
if
(
unlikely
(
++
i
==
rx_ring
->
count
))
i
=
0
;
if
(
unlikely
(
++
i
==
rx_ring
->
count
))
i
=
0
;
rx_desc
=
E1000_RX_DESC
(
*
rx_ring
,
i
);
rx_desc
=
E1000_RX_DESC
(
*
rx_ring
,
i
);
...
@@ -2418,8 +2392,7 @@ e1000_alloc_rx_buffers(struct e1000_adapter *adapter)
...
@@ -2418,8 +2392,7 @@ e1000_alloc_rx_buffers(struct e1000_adapter *adapter)
buffer_info
->
skb
=
skb
;
buffer_info
->
skb
=
skb
;
buffer_info
->
length
=
adapter
->
rx_buffer_len
;
buffer_info
->
length
=
adapter
->
rx_buffer_len
;
buffer_info
->
dma
=
buffer_info
->
dma
=
pci_map_single
(
pdev
,
pci_map_single
(
pdev
,
skb
->
data
,
skb
->
data
,
adapter
->
rx_buffer_len
,
adapter
->
rx_buffer_len
,
PCI_DMA_FROMDEVICE
);
PCI_DMA_FROMDEVICE
);
...
@@ -2556,24 +2529,24 @@ e1000_mii_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd)
...
@@ -2556,24 +2529,24 @@ e1000_mii_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd)
return
-
EFAULT
;
return
-
EFAULT
;
mii_reg
=
data
->
val_in
;
mii_reg
=
data
->
val_in
;
if
(
e1000_write_phy_reg
(
&
adapter
->
hw
,
data
->
reg_num
,
if
(
e1000_write_phy_reg
(
&
adapter
->
hw
,
data
->
reg_num
,
data
->
val_in
))
mii_reg
))
return
-
EIO
;
return
-
EIO
;
if
(
adapter
->
hw
.
phy_type
==
e1000_phy_m88
)
{
if
(
adapter
->
hw
.
phy_type
==
e1000_phy_m88
)
{
switch
(
data
->
reg_num
)
{
switch
(
data
->
reg_num
)
{
case
PHY_CTRL
:
case
PHY_CTRL
:
if
(
data
->
val_in
&
MII_CR_AUTO_NEG_EN
)
{
if
(
mii_reg
&
MII_CR_POWER_DOWN
)
if
(
mii_reg
&
MII_CR_POWER_DOWN
)
break
;
break
;
if
(
mii_reg
&
MII_CR_AUTO_NEG_EN
)
{
adapter
->
hw
.
autoneg
=
1
;
adapter
->
hw
.
autoneg
=
1
;
adapter
->
hw
.
autoneg_advertised
=
0x2F
;
adapter
->
hw
.
autoneg_advertised
=
0x2F
;
}
else
{
}
else
{
if
(
data
->
val_in
&
0x40
)
if
(
mii_reg
&
0x40
)
spddplx
=
SPEED_1000
;
spddplx
=
SPEED_1000
;
else
if
(
data
->
val_in
&
0x2000
)
else
if
(
mii_reg
&
0x2000
)
spddplx
=
SPEED_100
;
spddplx
=
SPEED_100
;
else
else
spddplx
=
SPEED_10
;
spddplx
=
SPEED_10
;
spddplx
+=
(
data
->
val_in
&
0x100
)
spddplx
+=
(
mii_reg
&
0x100
)
?
FULL_DUPLEX
:
?
FULL_DUPLEX
:
HALF_DUPLEX
;
HALF_DUPLEX
;
retval
=
e1000_set_spd_dplx
(
adapter
,
retval
=
e1000_set_spd_dplx
(
adapter
,
...
@@ -2704,26 +2677,22 @@ e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
...
@@ -2704,26 +2677,22 @@ e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
if
(
grp
)
{
if
(
grp
)
{
/* enable VLAN tag insert/strip */
/* enable VLAN tag insert/strip */
ctrl
=
E1000_READ_REG
(
&
adapter
->
hw
,
CTRL
);
ctrl
=
E1000_READ_REG
(
&
adapter
->
hw
,
CTRL
);
ctrl
|=
E1000_CTRL_VME
;
ctrl
|=
E1000_CTRL_VME
;
E1000_WRITE_REG
(
&
adapter
->
hw
,
CTRL
,
ctrl
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
CTRL
,
ctrl
);
/* enable VLAN receive filtering */
/* enable VLAN receive filtering */
rctl
=
E1000_READ_REG
(
&
adapter
->
hw
,
RCTL
);
rctl
=
E1000_READ_REG
(
&
adapter
->
hw
,
RCTL
);
rctl
|=
E1000_RCTL_VFE
;
rctl
|=
E1000_RCTL_VFE
;
rctl
&=
~
E1000_RCTL_CFIEN
;
rctl
&=
~
E1000_RCTL_CFIEN
;
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
);
}
else
{
}
else
{
/* disable VLAN tag insert/strip */
/* disable VLAN tag insert/strip */
ctrl
=
E1000_READ_REG
(
&
adapter
->
hw
,
CTRL
);
ctrl
=
E1000_READ_REG
(
&
adapter
->
hw
,
CTRL
);
ctrl
&=
~
E1000_CTRL_VME
;
ctrl
&=
~
E1000_CTRL_VME
;
E1000_WRITE_REG
(
&
adapter
->
hw
,
CTRL
,
ctrl
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
CTRL
,
ctrl
);
/* disable VLAN filtering */
/* disable VLAN filtering */
rctl
=
E1000_READ_REG
(
&
adapter
->
hw
,
RCTL
);
rctl
=
E1000_READ_REG
(
&
adapter
->
hw
,
RCTL
);
rctl
&=
~
E1000_RCTL_VFE
;
rctl
&=
~
E1000_RCTL_VFE
;
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
);
E1000_WRITE_REG
(
&
adapter
->
hw
,
RCTL
,
rctl
);
...
@@ -2739,7 +2708,6 @@ e1000_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
...
@@ -2739,7 +2708,6 @@ e1000_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
uint32_t
vfta
,
index
;
uint32_t
vfta
,
index
;
/* add VID to filter table */
/* add VID to filter table */
index
=
(
vid
>>
5
)
&
0x7F
;
index
=
(
vid
>>
5
)
&
0x7F
;
vfta
=
E1000_READ_REG_ARRAY
(
&
adapter
->
hw
,
VFTA
,
index
);
vfta
=
E1000_READ_REG_ARRAY
(
&
adapter
->
hw
,
VFTA
,
index
);
vfta
|=
(
1
<<
(
vid
&
0x1F
));
vfta
|=
(
1
<<
(
vid
&
0x1F
));
...
@@ -2759,8 +2727,7 @@ e1000_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid)
...
@@ -2759,8 +2727,7 @@ e1000_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid)
e1000_irq_enable
(
adapter
);
e1000_irq_enable
(
adapter
);
/* remove VID from filter table*/
/* remove VID from filter table */
index
=
(
vid
>>
5
)
&
0x7F
;
index
=
(
vid
>>
5
)
&
0x7F
;
vfta
=
E1000_READ_REG_ARRAY
(
&
adapter
->
hw
,
VFTA
,
index
);
vfta
=
E1000_READ_REG_ARRAY
(
&
adapter
->
hw
,
VFTA
,
index
);
vfta
&=
~
(
1
<<
(
vid
&
0x1F
));
vfta
&=
~
(
1
<<
(
vid
&
0x1F
));
...
@@ -2949,12 +2916,12 @@ e1000_resume(struct pci_dev *pdev)
...
@@ -2949,12 +2916,12 @@ e1000_resume(struct pci_dev *pdev)
* without having to re-enable interrupts. It's not called while
* without having to re-enable interrupts. It's not called while
* the interrupt routine is executing.
* the interrupt routine is executing.
*/
*/
static
void
static
void
e1000_netpoll
(
struct
net_device
*
dev
)
e1000_netpoll
(
struct
net_device
*
net
dev
)
{
{
struct
e1000_adapter
*
adapter
=
dev
->
priv
;
struct
e1000_adapter
*
adapter
=
net
dev
->
priv
;
disable_irq
(
adapter
->
pdev
->
irq
);
disable_irq
(
adapter
->
pdev
->
irq
);
e1000_intr
(
adapter
->
pdev
->
irq
,
dev
,
NULL
);
e1000_intr
(
adapter
->
pdev
->
irq
,
net
dev
,
NULL
);
enable_irq
(
adapter
->
pdev
->
irq
);
enable_irq
(
adapter
->
pdev
->
irq
);
}
}
#endif
#endif
...
...
drivers/net/e1000/e1000_param.c
View file @
fa88c854
...
@@ -449,8 +449,7 @@ e1000_check_options(struct e1000_adapter *adapter)
...
@@ -449,8 +449,7 @@ e1000_check_options(struct e1000_adapter *adapter)
DPRINTK
(
PROBE
,
INFO
,
"%s turned off
\n
"
,
opt
.
name
);
DPRINTK
(
PROBE
,
INFO
,
"%s turned off
\n
"
,
opt
.
name
);
break
;
break
;
case
1
:
case
1
:
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"%s set to dynamic mode
\n
"
,
opt
.
name
);
"%s set to dynamic mode
\n
"
,
opt
.
name
);
break
;
break
;
default:
default:
e1000_validate_option
(
&
adapter
->
itr
,
&
opt
,
adapter
);
e1000_validate_option
(
&
adapter
->
itr
,
&
opt
,
adapter
);
...
@@ -493,8 +492,9 @@ e1000_check_fiber_options(struct e1000_adapter *adapter)
...
@@ -493,8 +492,9 @@ e1000_check_fiber_options(struct e1000_adapter *adapter)
"parameter ignored
\n
"
);
"parameter ignored
\n
"
);
}
}
if
((
AutoNeg
[
bd
]
!=
OPTION_UNSET
)
&&
(
AutoNeg
[
bd
]
!=
0x20
))
{
if
((
AutoNeg
[
bd
]
!=
OPTION_UNSET
)
&&
(
AutoNeg
[
bd
]
!=
0x20
))
{
DPRINTK
(
PROBE
,
INFO
,
"AutoNeg other than Full/1000 is "
DPRINTK
(
PROBE
,
INFO
,
"AutoNeg other than 1000/Full is "
"not valid for fiber adapters, parameter ignored
\n
"
);
"not valid for fiber adapters, "
"parameter ignored
\n
"
);
}
}
}
}
...
@@ -611,24 +611,24 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
...
@@ -611,24 +611,24 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
break
;
break
;
case
HALF_DUPLEX
:
case
HALF_DUPLEX
:
DPRINTK
(
PROBE
,
INFO
,
"Half Duplex specified without Speed
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
"Half Duplex specified without Speed
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"Using Autonegotiation at "
"
Using Autonegotiation at
Half Duplex only
\n
"
);
"Half Duplex only
\n
"
);
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_10_HALF
|
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_10_HALF
|
ADVERTISE_100_HALF
;
ADVERTISE_100_HALF
;
break
;
break
;
case
FULL_DUPLEX
:
case
FULL_DUPLEX
:
DPRINTK
(
PROBE
,
INFO
,
"Full Duplex specified without Speed
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
"Full Duplex specified without Speed
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"Using Autonegotiation at "
"
Using Autonegotiation at
Full Duplex only
\n
"
);
"Full Duplex only
\n
"
);
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_10_FULL
|
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_10_FULL
|
ADVERTISE_100_FULL
|
ADVERTISE_100_FULL
|
ADVERTISE_1000_FULL
;
ADVERTISE_1000_FULL
;
break
;
break
;
case
SPEED_10
:
case
SPEED_10
:
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"10 Mbps Speed specified "
"
10 Mbps Speed specified
without Duplex
\n
"
);
"without Duplex
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
"Using Autonegotiation at 10 Mbps only
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
"Using Autonegotiation at 10 Mbps only
\n
"
);
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_10_HALF
|
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_10_HALF
|
...
@@ -647,10 +647,10 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
...
@@ -647,10 +647,10 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
adapter
->
hw
.
autoneg_advertised
=
0
;
adapter
->
hw
.
autoneg_advertised
=
0
;
break
;
break
;
case
SPEED_100
:
case
SPEED_100
:
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"100 Mbps Speed specified "
"
100 Mbps Speed specified
without Duplex
\n
"
);
"without Duplex
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"Using Autonegotiation at "
"
Using Autonegotiation at
100 Mbps only
\n
"
);
"100 Mbps only
\n
"
);
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_100_HALF
|
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_100_HALF
|
ADVERTISE_100_FULL
;
ADVERTISE_100_FULL
;
...
@@ -668,10 +668,11 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
...
@@ -668,10 +668,11 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
adapter
->
hw
.
autoneg_advertised
=
0
;
adapter
->
hw
.
autoneg_advertised
=
0
;
break
;
break
;
case
SPEED_1000
:
case
SPEED_1000
:
DPRINTK
(
PROBE
,
INFO
,
"1000 Mbps Speed specified without "
"Duplex
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"1000 Mbps Speed specified without Duplex
\n
"
);
"Using Autonegotiation at 1000 Mbps "
DPRINTK
(
PROBE
,
INFO
,
"Full Duplex only
\n
"
);
"Using Autonegotiation at 1000 Mbps Full Duplex only
\n
"
);
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_1000_FULL
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_1000_FULL
;
break
;
break
;
...
@@ -679,7 +680,8 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
...
@@ -679,7 +680,8 @@ e1000_check_copper_options(struct e1000_adapter *adapter)
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"Half Duplex is not supported at 1000 Mbps
\n
"
);
"Half Duplex is not supported at 1000 Mbps
\n
"
);
DPRINTK
(
PROBE
,
INFO
,
DPRINTK
(
PROBE
,
INFO
,
"Using Autonegotiation at 1000 Mbps Full Duplex only
\n
"
);
"Using Autonegotiation at 1000 Mbps "
"Full Duplex only
\n
"
);
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg
=
adapter
->
fc_autoneg
=
1
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_1000_FULL
;
adapter
->
hw
.
autoneg_advertised
=
ADVERTISE_1000_FULL
;
break
;
break
;
...
...
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