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
f3b197ac
Commit
f3b197ac
authored
May 26, 2006
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[netdrvr] trim trailing whitespace: 8139*.c, epic100, forcedeth, tulip/*
parent
4c0c2fd4
Changes
16
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
686 additions
and
686 deletions
+686
-686
drivers/net/8139cp.c
drivers/net/8139cp.c
+7
-7
drivers/net/8139too.c
drivers/net/8139too.c
+7
-7
drivers/net/epic100.c
drivers/net/epic100.c
+28
-28
drivers/net/forcedeth.c
drivers/net/forcedeth.c
+20
-20
drivers/net/tulip/de2104x.c
drivers/net/tulip/de2104x.c
+29
-29
drivers/net/tulip/de4x5.c
drivers/net/tulip/de4x5.c
+358
-358
drivers/net/tulip/de4x5.h
drivers/net/tulip/de4x5.h
+7
-7
drivers/net/tulip/dmfe.c
drivers/net/tulip/dmfe.c
+1
-1
drivers/net/tulip/eeprom.c
drivers/net/tulip/eeprom.c
+4
-4
drivers/net/tulip/interrupt.c
drivers/net/tulip/interrupt.c
+63
-63
drivers/net/tulip/media.c
drivers/net/tulip/media.c
+1
-1
drivers/net/tulip/tulip.h
drivers/net/tulip/tulip.h
+1
-1
drivers/net/tulip/tulip_core.c
drivers/net/tulip/tulip_core.c
+3
-3
drivers/net/tulip/uli526x.c
drivers/net/tulip/uli526x.c
+40
-40
drivers/net/tulip/winbond-840.c
drivers/net/tulip/winbond-840.c
+13
-13
drivers/net/tulip/xircom_cb.c
drivers/net/tulip/xircom_cb.c
+104
-104
No files found.
drivers/net/8139cp.c
View file @
f3b197ac
...
@@ -19,11 +19,11 @@
...
@@ -19,11 +19,11 @@
See the file COPYING in this distribution for more information.
See the file COPYING in this distribution for more information.
Contributors:
Contributors:
Wake-on-LAN support - Felipe Damasio <felipewd@terra.com.br>
Wake-on-LAN support - Felipe Damasio <felipewd@terra.com.br>
PCI suspend/resume - Felipe Damasio <felipewd@terra.com.br>
PCI suspend/resume - Felipe Damasio <felipewd@terra.com.br>
LinkChg interrupt - Felipe Damasio <felipewd@terra.com.br>
LinkChg interrupt - Felipe Damasio <felipewd@terra.com.br>
TODO:
TODO:
* Test Tx checksumming thoroughly
* Test Tx checksumming thoroughly
* Implement dev->tx_timeout
* Implement dev->tx_timeout
...
@@ -461,7 +461,7 @@ static void cp_vlan_rx_kill_vid(struct net_device *dev, unsigned short vid)
...
@@ -461,7 +461,7 @@ static void cp_vlan_rx_kill_vid(struct net_device *dev, unsigned short vid)
static
inline
void
cp_set_rxbufsize
(
struct
cp_private
*
cp
)
static
inline
void
cp_set_rxbufsize
(
struct
cp_private
*
cp
)
{
{
unsigned
int
mtu
=
cp
->
dev
->
mtu
;
unsigned
int
mtu
=
cp
->
dev
->
mtu
;
if
(
mtu
>
ETH_DATA_LEN
)
if
(
mtu
>
ETH_DATA_LEN
)
/* MTU + ethernet header + FCS + optional VLAN tag */
/* MTU + ethernet header + FCS + optional VLAN tag */
cp
->
rx_buf_sz
=
mtu
+
ETH_HLEN
+
8
;
cp
->
rx_buf_sz
=
mtu
+
ETH_HLEN
+
8
;
...
@@ -510,7 +510,7 @@ static void cp_rx_err_acct (struct cp_private *cp, unsigned rx_tail,
...
@@ -510,7 +510,7 @@ static void cp_rx_err_acct (struct cp_private *cp, unsigned rx_tail,
static
inline
unsigned
int
cp_rx_csum_ok
(
u32
status
)
static
inline
unsigned
int
cp_rx_csum_ok
(
u32
status
)
{
{
unsigned
int
protocol
=
(
status
>>
16
)
&
0x3
;
unsigned
int
protocol
=
(
status
>>
16
)
&
0x3
;
if
(
likely
((
protocol
==
RxProtoTCP
)
&&
(
!
(
status
&
TCPFail
))))
if
(
likely
((
protocol
==
RxProtoTCP
)
&&
(
!
(
status
&
TCPFail
))))
return
1
;
return
1
;
else
if
((
protocol
==
RxProtoUDP
)
&&
(
!
(
status
&
UDPFail
)))
else
if
((
protocol
==
RxProtoUDP
)
&&
(
!
(
status
&
UDPFail
)))
...
@@ -1061,7 +1061,7 @@ static void cp_init_hw (struct cp_private *cp)
...
@@ -1061,7 +1061,7 @@ static void cp_init_hw (struct cp_private *cp)
cpw8
(
Config3
,
PARMEnable
);
cpw8
(
Config3
,
PARMEnable
);
cp
->
wol_enabled
=
0
;
cp
->
wol_enabled
=
0
;
cpw8
(
Config5
,
cpr8
(
Config5
)
&
PMEStatus
);
cpw8
(
Config5
,
cpr8
(
Config5
)
&
PMEStatus
);
cpw32_f
(
HiTxRingAddr
,
0
);
cpw32_f
(
HiTxRingAddr
,
0
);
cpw32_f
(
HiTxRingAddr
+
4
,
0
);
cpw32_f
(
HiTxRingAddr
+
4
,
0
);
...
@@ -1351,7 +1351,7 @@ static void netdev_get_wol (struct cp_private *cp,
...
@@ -1351,7 +1351,7 @@ static void netdev_get_wol (struct cp_private *cp,
WAKE_MCAST
|
WAKE_UCAST
;
WAKE_MCAST
|
WAKE_UCAST
;
/* We don't need to go on if WOL is disabled */
/* We don't need to go on if WOL is disabled */
if
(
!
cp
->
wol_enabled
)
return
;
if
(
!
cp
->
wol_enabled
)
return
;
options
=
cpr8
(
Config3
);
options
=
cpr8
(
Config3
);
if
(
options
&
LinkUp
)
wol
->
wolopts
|=
WAKE_PHY
;
if
(
options
&
LinkUp
)
wol
->
wolopts
|=
WAKE_PHY
;
if
(
options
&
MagicPacket
)
wol
->
wolopts
|=
WAKE_MAGIC
;
if
(
options
&
MagicPacket
)
wol
->
wolopts
|=
WAKE_MAGIC
;
...
@@ -1919,7 +1919,7 @@ static int cp_resume (struct pci_dev *pdev)
...
@@ -1919,7 +1919,7 @@ static int cp_resume (struct pci_dev *pdev)
mii_check_media
(
&
cp
->
mii_if
,
netif_msg_link
(
cp
),
FALSE
);
mii_check_media
(
&
cp
->
mii_if
,
netif_msg_link
(
cp
),
FALSE
);
spin_unlock_irqrestore
(
&
cp
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
cp
->
lock
,
flags
);
return
0
;
return
0
;
}
}
#endif
/* CONFIG_PM */
#endif
/* CONFIG_PM */
...
...
drivers/net/8139too.c
View file @
f3b197ac
...
@@ -165,7 +165,7 @@ static int multicast_filter_limit = 32;
...
@@ -165,7 +165,7 @@ static int multicast_filter_limit = 32;
static
int
debug
=
-
1
;
static
int
debug
=
-
1
;
/*
/*
* Receive ring size
* Receive ring size
* Warning: 64K ring has hardware issues and may lock up.
* Warning: 64K ring has hardware issues and may lock up.
*/
*/
#if defined(CONFIG_SH_DREAMCAST)
#if defined(CONFIG_SH_DREAMCAST)
...
@@ -257,7 +257,7 @@ static struct pci_device_id rtl8139_pci_tbl[] = {
...
@@ -257,7 +257,7 @@ static struct pci_device_id rtl8139_pci_tbl[] = {
{
0x018a
,
0x0106
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
{
0x018a
,
0x0106
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
{
0x126c
,
0x1211
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
{
0x126c
,
0x1211
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
{
0x1743
,
0x8139
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
{
0x1743
,
0x8139
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
{
0x021b
,
0x8139
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
{
0x021b
,
0x8139
,
PCI_ANY_ID
,
PCI_ANY_ID
,
0
,
0
,
RTL8139
},
#ifdef CONFIG_SH_SECUREEDGE5410
#ifdef CONFIG_SH_SECUREEDGE5410
/* Bogus 8139 silicon reports 8129 without external PROM :-( */
/* Bogus 8139 silicon reports 8129 without external PROM :-( */
...
@@ -1824,7 +1824,7 @@ static void rtl8139_rx_err (u32 rx_status, struct net_device *dev,
...
@@ -1824,7 +1824,7 @@ static void rtl8139_rx_err (u32 rx_status, struct net_device *dev,
int
tmp_work
;
int
tmp_work
;
#endif
#endif
if
(
netif_msg_rx_err
(
tp
))
if
(
netif_msg_rx_err
(
tp
))
printk
(
KERN_DEBUG
"%s: Ethernet frame had errors, status %8.8x.
\n
"
,
printk
(
KERN_DEBUG
"%s: Ethernet frame had errors, status %8.8x.
\n
"
,
dev
->
name
,
rx_status
);
dev
->
name
,
rx_status
);
tp
->
stats
.
rx_errors
++
;
tp
->
stats
.
rx_errors
++
;
...
@@ -1944,7 +1944,7 @@ static int rtl8139_rx(struct net_device *dev, struct rtl8139_private *tp,
...
@@ -1944,7 +1944,7 @@ static int rtl8139_rx(struct net_device *dev, struct rtl8139_private *tp,
RTL_R16
(
RxBufAddr
),
RTL_R16
(
RxBufAddr
),
RTL_R16
(
RxBufPtr
),
RTL_R8
(
ChipCmd
));
RTL_R16
(
RxBufPtr
),
RTL_R8
(
ChipCmd
));
while
(
netif_running
(
dev
)
&&
received
<
budget
while
(
netif_running
(
dev
)
&&
received
<
budget
&&
(
RTL_R8
(
ChipCmd
)
&
RxBufEmpty
)
==
0
)
{
&&
(
RTL_R8
(
ChipCmd
)
&
RxBufEmpty
)
==
0
)
{
u32
ring_offset
=
cur_rx
%
RX_BUF_LEN
;
u32
ring_offset
=
cur_rx
%
RX_BUF_LEN
;
u32
rx_status
;
u32
rx_status
;
...
@@ -2031,7 +2031,7 @@ static int rtl8139_rx(struct net_device *dev, struct rtl8139_private *tp,
...
@@ -2031,7 +2031,7 @@ static int rtl8139_rx(struct net_device *dev, struct rtl8139_private *tp,
netif_receive_skb
(
skb
);
netif_receive_skb
(
skb
);
}
else
{
}
else
{
if
(
net_ratelimit
())
if
(
net_ratelimit
())
printk
(
KERN_WARNING
printk
(
KERN_WARNING
"%s: Memory squeeze, dropping packet.
\n
"
,
"%s: Memory squeeze, dropping packet.
\n
"
,
dev
->
name
);
dev
->
name
);
...
@@ -2158,13 +2158,13 @@ static irqreturn_t rtl8139_interrupt (int irq, void *dev_instance,
...
@@ -2158,13 +2158,13 @@ static irqreturn_t rtl8139_interrupt (int irq, void *dev_instance,
status
=
RTL_R16
(
IntrStatus
);
status
=
RTL_R16
(
IntrStatus
);
/* shared irq? */
/* shared irq? */
if
(
unlikely
((
status
&
rtl8139_intr_mask
)
==
0
))
if
(
unlikely
((
status
&
rtl8139_intr_mask
)
==
0
))
goto
out
;
goto
out
;
handled
=
1
;
handled
=
1
;
/* h/w no longer present (hotplug?) or major error, bail */
/* h/w no longer present (hotplug?) or major error, bail */
if
(
unlikely
(
status
==
0xFFFF
))
if
(
unlikely
(
status
==
0xFFFF
))
goto
out
;
goto
out
;
/* close possible race's with dev_close */
/* close possible race's with dev_close */
...
...
drivers/net/epic100.c
View file @
f3b197ac
...
@@ -21,15 +21,15 @@
...
@@ -21,15 +21,15 @@
http://www.scyld.com/network/epic100.html
http://www.scyld.com/network/epic100.html
---------------------------------------------------------------------
---------------------------------------------------------------------
Linux kernel-specific changes:
Linux kernel-specific changes:
LK1.1.2 (jgarzik):
LK1.1.2 (jgarzik):
* Merge becker version 1.09 (4/08/2000)
* Merge becker version 1.09 (4/08/2000)
LK1.1.3:
LK1.1.3:
* Major bugfix to 1.09 driver (Francis Romieu)
* Major bugfix to 1.09 driver (Francis Romieu)
LK1.1.4 (jgarzik):
LK1.1.4 (jgarzik):
* Merge becker test version 1.09 (5/29/2000)
* Merge becker test version 1.09 (5/29/2000)
...
@@ -66,7 +66,7 @@
...
@@ -66,7 +66,7 @@
LK1.1.14 (Kryzsztof Halasa):
LK1.1.14 (Kryzsztof Halasa):
* fix spurious bad initializations
* fix spurious bad initializations
* pound phy a la SMSC's app note on the subject
* pound phy a la SMSC's app note on the subject
AC1.1.14ac
AC1.1.14ac
* fix power up/down for ethtool that broke in 1.11
* fix power up/down for ethtool that broke in 1.11
...
@@ -244,7 +244,7 @@ static struct pci_device_id epic_pci_tbl[] = {
...
@@ -244,7 +244,7 @@ static struct pci_device_id epic_pci_tbl[] = {
};
};
MODULE_DEVICE_TABLE
(
pci
,
epic_pci_tbl
);
MODULE_DEVICE_TABLE
(
pci
,
epic_pci_tbl
);
#ifndef USE_IO_OPS
#ifndef USE_IO_OPS
#undef inb
#undef inb
#undef inw
#undef inw
...
@@ -370,7 +370,7 @@ static int epic_close(struct net_device *dev);
...
@@ -370,7 +370,7 @@ static int epic_close(struct net_device *dev);
static
struct
net_device_stats
*
epic_get_stats
(
struct
net_device
*
dev
);
static
struct
net_device_stats
*
epic_get_stats
(
struct
net_device
*
dev
);
static
void
set_rx_mode
(
struct
net_device
*
dev
);
static
void
set_rx_mode
(
struct
net_device
*
dev
);
static
int
__devinit
epic_init_one
(
struct
pci_dev
*
pdev
,
static
int
__devinit
epic_init_one
(
struct
pci_dev
*
pdev
,
const
struct
pci_device_id
*
ent
)
const
struct
pci_device_id
*
ent
)
...
@@ -392,9 +392,9 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
...
@@ -392,9 +392,9 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
printk
(
KERN_INFO
"%s"
KERN_INFO
"%s"
KERN_INFO
"%s"
,
printk
(
KERN_INFO
"%s"
KERN_INFO
"%s"
KERN_INFO
"%s"
,
version
,
version2
,
version3
);
version
,
version2
,
version3
);
#endif
#endif
card_idx
++
;
card_idx
++
;
ret
=
pci_enable_device
(
pdev
);
ret
=
pci_enable_device
(
pdev
);
if
(
ret
)
if
(
ret
)
goto
out
;
goto
out
;
...
@@ -405,7 +405,7 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
...
@@ -405,7 +405,7 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
ret
=
-
ENODEV
;
ret
=
-
ENODEV
;
goto
err_out_disable
;
goto
err_out_disable
;
}
}
pci_set_master
(
pdev
);
pci_set_master
(
pdev
);
ret
=
pci_request_regions
(
pdev
,
DRV_NAME
);
ret
=
pci_request_regions
(
pdev
,
DRV_NAME
);
...
@@ -498,7 +498,7 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
...
@@ -498,7 +498,7 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
ep
->
pci_dev
=
pdev
;
ep
->
pci_dev
=
pdev
;
ep
->
chip_id
=
chip_idx
;
ep
->
chip_id
=
chip_idx
;
ep
->
chip_flags
=
pci_id_tbl
[
chip_idx
].
drv_flags
;
ep
->
chip_flags
=
pci_id_tbl
[
chip_idx
].
drv_flags
;
ep
->
irq_mask
=
ep
->
irq_mask
=
(
ep
->
chip_flags
&
TYPE2_INTR
?
PCIBusErr175
:
PCIBusErr170
)
(
ep
->
chip_flags
&
TYPE2_INTR
?
PCIBusErr175
:
PCIBusErr170
)
|
CntFull
|
TxUnderrun
|
EpicNapiEvent
;
|
CntFull
|
TxUnderrun
|
EpicNapiEvent
;
...
@@ -587,7 +587,7 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
...
@@ -587,7 +587,7 @@ static int __devinit epic_init_one (struct pci_dev *pdev,
pci_disable_device
(
pdev
);
pci_disable_device
(
pdev
);
goto
out
;
goto
out
;
}
}
/* Serial EEPROM section. */
/* Serial EEPROM section. */
/* EEPROM_Ctrl bits. */
/* EEPROM_Ctrl bits. */
...
@@ -709,7 +709,7 @@ static void mdio_write(struct net_device *dev, int phy_id, int loc, int value)
...
@@ -709,7 +709,7 @@ static void mdio_write(struct net_device *dev, int phy_id, int loc, int value)
outw
(
value
,
ioaddr
+
MIIData
);
outw
(
value
,
ioaddr
+
MIIData
);
outl
((
phy_id
<<
9
)
|
(
loc
<<
4
)
|
MII_WRITEOP
,
ioaddr
+
MIICtrl
);
outl
((
phy_id
<<
9
)
|
(
loc
<<
4
)
|
MII_WRITEOP
,
ioaddr
+
MIICtrl
);
for
(
i
=
10000
;
i
>
0
;
i
--
)
{
for
(
i
=
10000
;
i
>
0
;
i
--
)
{
barrier
();
barrier
();
if
((
inl
(
ioaddr
+
MIICtrl
)
&
MII_WRITEOP
)
==
0
)
if
((
inl
(
ioaddr
+
MIICtrl
)
&
MII_WRITEOP
)
==
0
)
break
;
break
;
...
@@ -717,7 +717,7 @@ static void mdio_write(struct net_device *dev, int phy_id, int loc, int value)
...
@@ -717,7 +717,7 @@ static void mdio_write(struct net_device *dev, int phy_id, int loc, int value)
return
;
return
;
}
}
static
int
epic_open
(
struct
net_device
*
dev
)
static
int
epic_open
(
struct
net_device
*
dev
)
{
{
struct
epic_private
*
ep
=
dev
->
priv
;
struct
epic_private
*
ep
=
dev
->
priv
;
...
@@ -760,7 +760,7 @@ static int epic_open(struct net_device *dev)
...
@@ -760,7 +760,7 @@ static int epic_open(struct net_device *dev)
#endif
#endif
udelay
(
20
);
/* Looks like EPII needs that if you want reliable RX init. FIXME: pci posting bug? */
udelay
(
20
);
/* Looks like EPII needs that if you want reliable RX init. FIXME: pci posting bug? */
for
(
i
=
0
;
i
<
3
;
i
++
)
for
(
i
=
0
;
i
<
3
;
i
++
)
outl
(
cpu_to_le16
(((
u16
*
)
dev
->
dev_addr
)[
i
]),
ioaddr
+
LAN0
+
i
*
4
);
outl
(
cpu_to_le16
(((
u16
*
)
dev
->
dev_addr
)[
i
]),
ioaddr
+
LAN0
+
i
*
4
);
...
@@ -803,7 +803,7 @@ static int epic_open(struct net_device *dev)
...
@@ -803,7 +803,7 @@ static int epic_open(struct net_device *dev)
/* Enable interrupts by setting the interrupt mask. */
/* Enable interrupts by setting the interrupt mask. */
outl
((
ep
->
chip_flags
&
TYPE2_INTR
?
PCIBusErr175
:
PCIBusErr170
)
outl
((
ep
->
chip_flags
&
TYPE2_INTR
?
PCIBusErr175
:
PCIBusErr170
)
|
CntFull
|
TxUnderrun
|
CntFull
|
TxUnderrun
|
RxError
|
RxHeader
|
EpicNapiEvent
,
ioaddr
+
INTMASK
);
|
RxError
|
RxHeader
|
EpicNapiEvent
,
ioaddr
+
INTMASK
);
if
(
debug
>
1
)
if
(
debug
>
1
)
...
@@ -831,7 +831,7 @@ static void epic_pause(struct net_device *dev)
...
@@ -831,7 +831,7 @@ static void epic_pause(struct net_device *dev)
struct
epic_private
*
ep
=
dev
->
priv
;
struct
epic_private
*
ep
=
dev
->
priv
;
netif_stop_queue
(
dev
);
netif_stop_queue
(
dev
);
/* Disable interrupts by clearing the interrupt mask. */
/* Disable interrupts by clearing the interrupt mask. */
outl
(
0x00000000
,
ioaddr
+
INTMASK
);
outl
(
0x00000000
,
ioaddr
+
INTMASK
);
/* Stop the chip's Tx and Rx DMA processes. */
/* Stop the chip's Tx and Rx DMA processes. */
...
@@ -987,7 +987,7 @@ static void epic_init_ring(struct net_device *dev)
...
@@ -987,7 +987,7 @@ static void epic_init_ring(struct net_device *dev)
for
(
i
=
0
;
i
<
RX_RING_SIZE
;
i
++
)
{
for
(
i
=
0
;
i
<
RX_RING_SIZE
;
i
++
)
{
ep
->
rx_ring
[
i
].
rxstatus
=
0
;
ep
->
rx_ring
[
i
].
rxstatus
=
0
;
ep
->
rx_ring
[
i
].
buflength
=
cpu_to_le32
(
ep
->
rx_buf_sz
);
ep
->
rx_ring
[
i
].
buflength
=
cpu_to_le32
(
ep
->
rx_buf_sz
);
ep
->
rx_ring
[
i
].
next
=
ep
->
rx_ring_dma
+
ep
->
rx_ring
[
i
].
next
=
ep
->
rx_ring_dma
+
(
i
+
1
)
*
sizeof
(
struct
epic_rx_desc
);
(
i
+
1
)
*
sizeof
(
struct
epic_rx_desc
);
ep
->
rx_skbuff
[
i
]
=
NULL
;
ep
->
rx_skbuff
[
i
]
=
NULL
;
}
}
...
@@ -1002,7 +1002,7 @@ static void epic_init_ring(struct net_device *dev)
...
@@ -1002,7 +1002,7 @@ static void epic_init_ring(struct net_device *dev)
break
;
break
;
skb
->
dev
=
dev
;
/* Mark as being used by this device. */
skb
->
dev
=
dev
;
/* Mark as being used by this device. */
skb_reserve
(
skb
,
2
);
/* 16 byte align the IP header. */
skb_reserve
(
skb
,
2
);
/* 16 byte align the IP header. */
ep
->
rx_ring
[
i
].
bufaddr
=
pci_map_single
(
ep
->
pci_dev
,
ep
->
rx_ring
[
i
].
bufaddr
=
pci_map_single
(
ep
->
pci_dev
,
skb
->
data
,
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
skb
->
data
,
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
ep
->
rx_ring
[
i
].
rxstatus
=
cpu_to_le32
(
DescOwn
);
ep
->
rx_ring
[
i
].
rxstatus
=
cpu_to_le32
(
DescOwn
);
}
}
...
@@ -1013,7 +1013,7 @@ static void epic_init_ring(struct net_device *dev)
...
@@ -1013,7 +1013,7 @@ static void epic_init_ring(struct net_device *dev)
for
(
i
=
0
;
i
<
TX_RING_SIZE
;
i
++
)
{
for
(
i
=
0
;
i
<
TX_RING_SIZE
;
i
++
)
{
ep
->
tx_skbuff
[
i
]
=
NULL
;
ep
->
tx_skbuff
[
i
]
=
NULL
;
ep
->
tx_ring
[
i
].
txstatus
=
0x0000
;
ep
->
tx_ring
[
i
].
txstatus
=
0x0000
;
ep
->
tx_ring
[
i
].
next
=
ep
->
tx_ring_dma
+
ep
->
tx_ring
[
i
].
next
=
ep
->
tx_ring_dma
+
(
i
+
1
)
*
sizeof
(
struct
epic_tx_desc
);
(
i
+
1
)
*
sizeof
(
struct
epic_tx_desc
);
}
}
ep
->
tx_ring
[
i
-
1
].
next
=
ep
->
tx_ring_dma
;
ep
->
tx_ring
[
i
-
1
].
next
=
ep
->
tx_ring_dma
;
...
@@ -1026,7 +1026,7 @@ static int epic_start_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -1026,7 +1026,7 @@ static int epic_start_xmit(struct sk_buff *skb, struct net_device *dev)
int
entry
,
free_count
;
int
entry
,
free_count
;
u32
ctrl_word
;
u32
ctrl_word
;
unsigned
long
flags
;
unsigned
long
flags
;
if
(
skb
->
len
<
ETH_ZLEN
)
{
if
(
skb
->
len
<
ETH_ZLEN
)
{
skb
=
skb_padto
(
skb
,
ETH_ZLEN
);
skb
=
skb_padto
(
skb
,
ETH_ZLEN
);
if
(
skb
==
NULL
)
if
(
skb
==
NULL
)
...
@@ -1042,7 +1042,7 @@ static int epic_start_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -1042,7 +1042,7 @@ static int epic_start_xmit(struct sk_buff *skb, struct net_device *dev)
entry
=
ep
->
cur_tx
%
TX_RING_SIZE
;
entry
=
ep
->
cur_tx
%
TX_RING_SIZE
;
ep
->
tx_skbuff
[
entry
]
=
skb
;
ep
->
tx_skbuff
[
entry
]
=
skb
;
ep
->
tx_ring
[
entry
].
bufaddr
=
pci_map_single
(
ep
->
pci_dev
,
skb
->
data
,
ep
->
tx_ring
[
entry
].
bufaddr
=
pci_map_single
(
ep
->
pci_dev
,
skb
->
data
,
skb
->
len
,
PCI_DMA_TODEVICE
);
skb
->
len
,
PCI_DMA_TODEVICE
);
if
(
free_count
<
TX_QUEUE_LEN
/
2
)
{
/* Typical path */
if
(
free_count
<
TX_QUEUE_LEN
/
2
)
{
/* Typical path */
ctrl_word
=
cpu_to_le32
(
0x100000
);
/* No interrupt */
ctrl_word
=
cpu_to_le32
(
0x100000
);
/* No interrupt */
...
@@ -1126,7 +1126,7 @@ static void epic_tx(struct net_device *dev, struct epic_private *ep)
...
@@ -1126,7 +1126,7 @@ static void epic_tx(struct net_device *dev, struct epic_private *ep)
/* Free the original skb. */
/* Free the original skb. */
skb
=
ep
->
tx_skbuff
[
entry
];
skb
=
ep
->
tx_skbuff
[
entry
];
pci_unmap_single
(
ep
->
pci_dev
,
ep
->
tx_ring
[
entry
].
bufaddr
,
pci_unmap_single
(
ep
->
pci_dev
,
ep
->
tx_ring
[
entry
].
bufaddr
,
skb
->
len
,
PCI_DMA_TODEVICE
);
skb
->
len
,
PCI_DMA_TODEVICE
);
dev_kfree_skb_irq
(
skb
);
dev_kfree_skb_irq
(
skb
);
ep
->
tx_skbuff
[
entry
]
=
NULL
;
ep
->
tx_skbuff
[
entry
]
=
NULL
;
...
@@ -1281,8 +1281,8 @@ static int epic_rx(struct net_device *dev, int budget)
...
@@ -1281,8 +1281,8 @@ static int epic_rx(struct net_device *dev, int budget)
ep
->
rx_buf_sz
,
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
PCI_DMA_FROMDEVICE
);
}
else
{
}
else
{
pci_unmap_single
(
ep
->
pci_dev
,
pci_unmap_single
(
ep
->
pci_dev
,
ep
->
rx_ring
[
entry
].
bufaddr
,
ep
->
rx_ring
[
entry
].
bufaddr
,
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
skb_put
(
skb
=
ep
->
rx_skbuff
[
entry
],
pkt_len
);
skb_put
(
skb
=
ep
->
rx_skbuff
[
entry
],
pkt_len
);
ep
->
rx_skbuff
[
entry
]
=
NULL
;
ep
->
rx_skbuff
[
entry
]
=
NULL
;
...
@@ -1307,7 +1307,7 @@ static int epic_rx(struct net_device *dev, int budget)
...
@@ -1307,7 +1307,7 @@ static int epic_rx(struct net_device *dev, int budget)
break
;
break
;
skb
->
dev
=
dev
;
/* Mark as being used by this device. */
skb
->
dev
=
dev
;
/* Mark as being used by this device. */
skb_reserve
(
skb
,
2
);
/* Align IP on 16 byte boundaries */
skb_reserve
(
skb
,
2
);
/* Align IP on 16 byte boundaries */
ep
->
rx_ring
[
entry
].
bufaddr
=
pci_map_single
(
ep
->
pci_dev
,
ep
->
rx_ring
[
entry
].
bufaddr
=
pci_map_single
(
ep
->
pci_dev
,
skb
->
data
,
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
skb
->
data
,
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
work_done
++
;
work_done
++
;
}
}
...
@@ -1403,7 +1403,7 @@ static int epic_close(struct net_device *dev)
...
@@ -1403,7 +1403,7 @@ static int epic_close(struct net_device *dev)
ep
->
rx_ring
[
i
].
rxstatus
=
0
;
/* Not owned by Epic chip. */
ep
->
rx_ring
[
i
].
rxstatus
=
0
;
/* Not owned by Epic chip. */
ep
->
rx_ring
[
i
].
buflength
=
0
;
ep
->
rx_ring
[
i
].
buflength
=
0
;
if
(
skb
)
{
if
(
skb
)
{
pci_unmap_single
(
ep
->
pci_dev
,
ep
->
rx_ring
[
i
].
bufaddr
,
pci_unmap_single
(
ep
->
pci_dev
,
ep
->
rx_ring
[
i
].
bufaddr
,
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
ep
->
rx_buf_sz
,
PCI_DMA_FROMDEVICE
);
dev_kfree_skb
(
skb
);
dev_kfree_skb
(
skb
);
}
}
...
@@ -1414,7 +1414,7 @@ static int epic_close(struct net_device *dev)
...
@@ -1414,7 +1414,7 @@ static int epic_close(struct net_device *dev)
ep
->
tx_skbuff
[
i
]
=
NULL
;
ep
->
tx_skbuff
[
i
]
=
NULL
;
if
(
!
skb
)
if
(
!
skb
)
continue
;
continue
;
pci_unmap_single
(
ep
->
pci_dev
,
ep
->
tx_ring
[
i
].
bufaddr
,
pci_unmap_single
(
ep
->
pci_dev
,
ep
->
tx_ring
[
i
].
bufaddr
,
skb
->
len
,
PCI_DMA_TODEVICE
);
skb
->
len
,
PCI_DMA_TODEVICE
);
dev_kfree_skb
(
skb
);
dev_kfree_skb
(
skb
);
}
}
...
@@ -1607,7 +1607,7 @@ static void __devexit epic_remove_one (struct pci_dev *pdev)
...
@@ -1607,7 +1607,7 @@ static void __devexit epic_remove_one (struct pci_dev *pdev)
{
{
struct
net_device
*
dev
=
pci_get_drvdata
(
pdev
);
struct
net_device
*
dev
=
pci_get_drvdata
(
pdev
);
struct
epic_private
*
ep
=
dev
->
priv
;
struct
epic_private
*
ep
=
dev
->
priv
;
pci_free_consistent
(
pdev
,
TX_TOTAL_SIZE
,
ep
->
tx_ring
,
ep
->
tx_ring_dma
);
pci_free_consistent
(
pdev
,
TX_TOTAL_SIZE
,
ep
->
tx_ring
,
ep
->
tx_ring_dma
);
pci_free_consistent
(
pdev
,
RX_TOTAL_SIZE
,
ep
->
rx_ring
,
ep
->
rx_ring_dma
);
pci_free_consistent
(
pdev
,
RX_TOTAL_SIZE
,
ep
->
rx_ring
,
ep
->
rx_ring_dma
);
unregister_netdev
(
dev
);
unregister_netdev
(
dev
);
...
...
drivers/net/forcedeth.c
View file @
f3b197ac
...
@@ -458,7 +458,7 @@ typedef union _ring_type {
...
@@ -458,7 +458,7 @@ typedef union _ring_type {
#define RX_RING 128
#define RX_RING 128
#define TX_RING 256
#define TX_RING 256
/*
/*
* If your nic mysteriously hangs then try to reduce the limits
* If your nic mysteriously hangs then try to reduce the limits
* to 1/0: It might be required to set NV_TX_LASTPACKET in the
* to 1/0: It might be required to set NV_TX_LASTPACKET in the
* last valid ring entry. But this would be impossible to
* last valid ring entry. But this would be impossible to
...
@@ -480,7 +480,7 @@ typedef union _ring_type {
...
@@ -480,7 +480,7 @@ typedef union _ring_type {
#define POLL_WAIT (1+HZ/100)
#define POLL_WAIT (1+HZ/100)
#define LINK_TIMEOUT (3*HZ)
#define LINK_TIMEOUT (3*HZ)
/*
/*
* desc_ver values:
* desc_ver values:
* The nic supports three different descriptor types:
* The nic supports three different descriptor types:
* - DESC_VER_1: Original
* - DESC_VER_1: Original
...
@@ -619,7 +619,7 @@ static int max_interrupt_work = 5;
...
@@ -619,7 +619,7 @@ static int max_interrupt_work = 5;
/*
/*
* Optimization can be either throuput mode or cpu mode
* Optimization can be either throuput mode or cpu mode
*
*
* Throughput Mode: Every tx and rx packet will generate an interrupt.
* Throughput Mode: Every tx and rx packet will generate an interrupt.
* CPU Mode: Interrupts are controlled by a timer.
* CPU Mode: Interrupts are controlled by a timer.
*/
*/
...
@@ -1119,7 +1119,7 @@ static void nv_do_rx_refill(unsigned long data)
...
@@ -1119,7 +1119,7 @@ static void nv_do_rx_refill(unsigned long data)
}
}
}
}
static
void
nv_init_rx
(
struct
net_device
*
dev
)
static
void
nv_init_rx
(
struct
net_device
*
dev
)
{
{
struct
fe_priv
*
np
=
netdev_priv
(
dev
);
struct
fe_priv
*
np
=
netdev_priv
(
dev
);
int
i
;
int
i
;
...
@@ -1183,7 +1183,7 @@ static void nv_drain_tx(struct net_device *dev)
...
@@ -1183,7 +1183,7 @@ static void nv_drain_tx(struct net_device *dev)
{
{
struct
fe_priv
*
np
=
netdev_priv
(
dev
);
struct
fe_priv
*
np
=
netdev_priv
(
dev
);
unsigned
int
i
;
unsigned
int
i
;
for
(
i
=
0
;
i
<
TX_RING
;
i
++
)
{
for
(
i
=
0
;
i
<
TX_RING
;
i
++
)
{
if
(
np
->
desc_ver
==
DESC_VER_1
||
np
->
desc_ver
==
DESC_VER_2
)
if
(
np
->
desc_ver
==
DESC_VER_1
||
np
->
desc_ver
==
DESC_VER_2
)
np
->
tx_ring
.
orig
[
i
].
FlagLen
=
0
;
np
->
tx_ring
.
orig
[
i
].
FlagLen
=
0
;
...
@@ -1329,7 +1329,7 @@ static int nv_start_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -1329,7 +1329,7 @@ static int nv_start_xmit(struct sk_buff *skb, struct net_device *dev)
}
else
{
}
else
{
np
->
tx_ring
.
ex
[
start_nr
].
TxVlan
=
cpu_to_le32
(
tx_flags_vlan
);
np
->
tx_ring
.
ex
[
start_nr
].
TxVlan
=
cpu_to_le32
(
tx_flags_vlan
);
np
->
tx_ring
.
ex
[
start_nr
].
FlagLen
|=
cpu_to_le32
(
tx_flags
|
tx_flags_extra
);
np
->
tx_ring
.
ex
[
start_nr
].
FlagLen
|=
cpu_to_le32
(
tx_flags
|
tx_flags_extra
);
}
}
dprintk
(
KERN_DEBUG
"%s: nv_start_xmit: packet %d (entries %d) queued for transmission. tx_flags_extra: %x
\n
"
,
dprintk
(
KERN_DEBUG
"%s: nv_start_xmit: packet %d (entries %d) queued for transmission. tx_flags_extra: %x
\n
"
,
dev
->
name
,
np
->
next_tx
,
entries
,
tx_flags_extra
);
dev
->
name
,
np
->
next_tx
,
entries
,
tx_flags_extra
);
...
@@ -1404,7 +1404,7 @@ static void nv_tx_done(struct net_device *dev)
...
@@ -1404,7 +1404,7 @@ static void nv_tx_done(struct net_device *dev)
}
else
{
}
else
{
np
->
stats
.
tx_packets
++
;
np
->
stats
.
tx_packets
++
;
np
->
stats
.
tx_bytes
+=
skb
->
len
;
np
->
stats
.
tx_bytes
+=
skb
->
len
;
}
}
}
}
}
}
nv_release_txskb
(
dev
,
i
);
nv_release_txskb
(
dev
,
i
);
...
@@ -1450,7 +1450,7 @@ static void nv_tx_timeout(struct net_device *dev)
...
@@ -1450,7 +1450,7 @@ static void nv_tx_timeout(struct net_device *dev)
for
(
i
=
0
;
i
<
TX_RING
;
i
+=
4
)
{
for
(
i
=
0
;
i
<
TX_RING
;
i
+=
4
)
{
if
(
np
->
desc_ver
==
DESC_VER_1
||
np
->
desc_ver
==
DESC_VER_2
)
{
if
(
np
->
desc_ver
==
DESC_VER_1
||
np
->
desc_ver
==
DESC_VER_2
)
{
printk
(
KERN_INFO
"%03x: %08x %08x // %08x %08x // %08x %08x // %08x %08x
\n
"
,
printk
(
KERN_INFO
"%03x: %08x %08x // %08x %08x // %08x %08x // %08x %08x
\n
"
,
i
,
i
,
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
].
PacketBuffer
),
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
].
PacketBuffer
),
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
].
FlagLen
),
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
].
FlagLen
),
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
+
1
].
PacketBuffer
),
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
+
1
].
PacketBuffer
),
...
@@ -1461,7 +1461,7 @@ static void nv_tx_timeout(struct net_device *dev)
...
@@ -1461,7 +1461,7 @@ static void nv_tx_timeout(struct net_device *dev)
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
+
3
].
FlagLen
));
le32_to_cpu
(
np
->
tx_ring
.
orig
[
i
+
3
].
FlagLen
));
}
else
{
}
else
{
printk
(
KERN_INFO
"%03x: %08x %08x %08x // %08x %08x %08x // %08x %08x %08x // %08x %08x %08x
\n
"
,
printk
(
KERN_INFO
"%03x: %08x %08x %08x // %08x %08x %08x // %08x %08x %08x // %08x %08x %08x
\n
"
,
i
,
i
,
le32_to_cpu
(
np
->
tx_ring
.
ex
[
i
].
PacketBufferHigh
),
le32_to_cpu
(
np
->
tx_ring
.
ex
[
i
].
PacketBufferHigh
),
le32_to_cpu
(
np
->
tx_ring
.
ex
[
i
].
PacketBufferLow
),
le32_to_cpu
(
np
->
tx_ring
.
ex
[
i
].
PacketBufferLow
),
le32_to_cpu
(
np
->
tx_ring
.
ex
[
i
].
FlagLen
),
le32_to_cpu
(
np
->
tx_ring
.
ex
[
i
].
FlagLen
),
...
@@ -2067,7 +2067,7 @@ static int nv_update_linkspeed(struct net_device *dev)
...
@@ -2067,7 +2067,7 @@ static int nv_update_linkspeed(struct net_device *dev)
if
(
lpa_pause
==
LPA_PAUSE_ASYM
)
if
(
lpa_pause
==
LPA_PAUSE_ASYM
)
{
{
np
->
pause_flags
|=
NV_PAUSEFRAME_RX_ENABLE
;
np
->
pause_flags
|=
NV_PAUSEFRAME_RX_ENABLE
;
}
}
break
;
break
;
}
}
}
}
...
@@ -2086,7 +2086,7 @@ static int nv_update_linkspeed(struct net_device *dev)
...
@@ -2086,7 +2086,7 @@ static int nv_update_linkspeed(struct net_device *dev)
writel
(
regmisc
|
NVREG_MISC1_PAUSE_TX
,
base
+
NvRegMisc1
);
writel
(
regmisc
|
NVREG_MISC1_PAUSE_TX
,
base
+
NvRegMisc1
);
}
else
{
}
else
{
writel
(
NVREG_TX_PAUSEFRAME_DISABLE
,
base
+
NvRegTxPauseFrame
);
writel
(
NVREG_TX_PAUSEFRAME_DISABLE
,
base
+
NvRegTxPauseFrame
);
writel
(
regmisc
,
base
+
NvRegMisc1
);
writel
(
regmisc
,
base
+
NvRegMisc1
);
}
}
}
}
...
@@ -2150,7 +2150,7 @@ static irqreturn_t nv_nic_irq(int foo, void *data, struct pt_regs *regs)
...
@@ -2150,7 +2150,7 @@ static irqreturn_t nv_nic_irq(int foo, void *data, struct pt_regs *regs)
spin_lock
(
&
np
->
lock
);
spin_lock
(
&
np
->
lock
);
nv_tx_done
(
dev
);
nv_tx_done
(
dev
);
spin_unlock
(
&
np
->
lock
);
spin_unlock
(
&
np
->
lock
);
nv_rx_process
(
dev
);
nv_rx_process
(
dev
);
if
(
nv_alloc_rx
(
dev
))
{
if
(
nv_alloc_rx
(
dev
))
{
spin_lock
(
&
np
->
lock
);
spin_lock
(
&
np
->
lock
);
...
@@ -2158,7 +2158,7 @@ static irqreturn_t nv_nic_irq(int foo, void *data, struct pt_regs *regs)
...
@@ -2158,7 +2158,7 @@ static irqreturn_t nv_nic_irq(int foo, void *data, struct pt_regs *regs)
mod_timer
(
&
np
->
oom_kick
,
jiffies
+
OOM_REFILL
);
mod_timer
(
&
np
->
oom_kick
,
jiffies
+
OOM_REFILL
);
spin_unlock
(
&
np
->
lock
);
spin_unlock
(
&
np
->
lock
);
}
}
if
(
events
&
NVREG_IRQ_LINK
)
{
if
(
events
&
NVREG_IRQ_LINK
)
{
spin_lock
(
&
np
->
lock
);
spin_lock
(
&
np
->
lock
);
nv_link_irq
(
dev
);
nv_link_irq
(
dev
);
...
@@ -2223,7 +2223,7 @@ static irqreturn_t nv_nic_irq_tx(int foo, void *data, struct pt_regs *regs)
...
@@ -2223,7 +2223,7 @@ static irqreturn_t nv_nic_irq_tx(int foo, void *data, struct pt_regs *regs)
spin_lock_irq
(
&
np
->
lock
);
spin_lock_irq
(
&
np
->
lock
);
nv_tx_done
(
dev
);
nv_tx_done
(
dev
);
spin_unlock_irq
(
&
np
->
lock
);
spin_unlock_irq
(
&
np
->
lock
);
if
(
events
&
(
NVREG_IRQ_TX_ERR
))
{
if
(
events
&
(
NVREG_IRQ_TX_ERR
))
{
dprintk
(
KERN_DEBUG
"%s: received irq with events 0x%x. Probably TX fail.
\n
"
,
dprintk
(
KERN_DEBUG
"%s: received irq with events 0x%x. Probably TX fail.
\n
"
,
dev
->
name
,
events
);
dev
->
name
,
events
);
...
@@ -2266,7 +2266,7 @@ static irqreturn_t nv_nic_irq_rx(int foo, void *data, struct pt_regs *regs)
...
@@ -2266,7 +2266,7 @@ static irqreturn_t nv_nic_irq_rx(int foo, void *data, struct pt_regs *regs)
dprintk
(
KERN_DEBUG
"%s: rx irq: %08x
\n
"
,
dev
->
name
,
events
);
dprintk
(
KERN_DEBUG
"%s: rx irq: %08x
\n
"
,
dev
->
name
,
events
);
if
(
!
(
events
&
np
->
irqmask
))
if
(
!
(
events
&
np
->
irqmask
))
break
;
break
;
nv_rx_process
(
dev
);
nv_rx_process
(
dev
);
if
(
nv_alloc_rx
(
dev
))
{
if
(
nv_alloc_rx
(
dev
))
{
spin_lock_irq
(
&
np
->
lock
);
spin_lock_irq
(
&
np
->
lock
);
...
@@ -2274,7 +2274,7 @@ static irqreturn_t nv_nic_irq_rx(int foo, void *data, struct pt_regs *regs)
...
@@ -2274,7 +2274,7 @@ static irqreturn_t nv_nic_irq_rx(int foo, void *data, struct pt_regs *regs)
mod_timer
(
&
np
->
oom_kick
,
jiffies
+
OOM_REFILL
);
mod_timer
(
&
np
->
oom_kick
,
jiffies
+
OOM_REFILL
);
spin_unlock_irq
(
&
np
->
lock
);
spin_unlock_irq
(
&
np
->
lock
);
}
}
if
(
i
>
max_interrupt_work
)
{
if
(
i
>
max_interrupt_work
)
{
spin_lock_irq
(
&
np
->
lock
);
spin_lock_irq
(
&
np
->
lock
);
/* disable interrupts on the nic */
/* disable interrupts on the nic */
...
@@ -2313,7 +2313,7 @@ static irqreturn_t nv_nic_irq_other(int foo, void *data, struct pt_regs *regs)
...
@@ -2313,7 +2313,7 @@ static irqreturn_t nv_nic_irq_other(int foo, void *data, struct pt_regs *regs)
dprintk
(
KERN_DEBUG
"%s: irq: %08x
\n
"
,
dev
->
name
,
events
);
dprintk
(
KERN_DEBUG
"%s: irq: %08x
\n
"
,
dev
->
name
,
events
);
if
(
!
(
events
&
np
->
irqmask
))
if
(
!
(
events
&
np
->
irqmask
))
break
;
break
;
if
(
events
&
NVREG_IRQ_LINK
)
{
if
(
events
&
NVREG_IRQ_LINK
)
{
spin_lock_irq
(
&
np
->
lock
);
spin_lock_irq
(
&
np
->
lock
);
nv_link_irq
(
dev
);
nv_link_irq
(
dev
);
...
@@ -2386,7 +2386,7 @@ static void nv_do_nic_poll(unsigned long data)
...
@@ -2386,7 +2386,7 @@ static void nv_do_nic_poll(unsigned long data)
np
->
nic_poll_irq
=
0
;
np
->
nic_poll_irq
=
0
;
/* FIXME: Do we need synchronize_irq(dev->irq) here? */
/* FIXME: Do we need synchronize_irq(dev->irq) here? */
writel
(
mask
,
base
+
NvRegIrqMask
);
writel
(
mask
,
base
+
NvRegIrqMask
);
pci_push
(
base
);
pci_push
(
base
);
...
@@ -3165,7 +3165,7 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i
...
@@ -3165,7 +3165,7 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i
if
(
id
->
driver_data
&
DEV_HAS_PAUSEFRAME_TX
)
{
if
(
id
->
driver_data
&
DEV_HAS_PAUSEFRAME_TX
)
{
np
->
pause_flags
|=
NV_PAUSEFRAME_TX_CAPABLE
;
np
->
pause_flags
|=
NV_PAUSEFRAME_TX_CAPABLE
;
}
}
err
=
-
ENOMEM
;
err
=
-
ENOMEM
;
np
->
base
=
ioremap
(
addr
,
np
->
register_size
);
np
->
base
=
ioremap
(
addr
,
np
->
register_size
);
...
@@ -3313,7 +3313,7 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i
...
@@ -3313,7 +3313,7 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i
pci_name
(
pci_dev
));
pci_name
(
pci_dev
));
goto
out_freering
;
goto
out_freering
;
}
}
/* reset it */
/* reset it */
phy_init
(
dev
);
phy_init
(
dev
);
...
...
drivers/net/tulip/de2104x.c
View file @
f3b197ac
...
@@ -227,12 +227,12 @@ enum {
...
@@ -227,12 +227,12 @@ enum {
SROMC0InfoLeaf
=
27
,
SROMC0InfoLeaf
=
27
,
MediaBlockMask
=
0x3f
,
MediaBlockMask
=
0x3f
,
MediaCustomCSRs
=
(
1
<<
6
),
MediaCustomCSRs
=
(
1
<<
6
),
/* PCIPM bits */
/* PCIPM bits */
PM_Sleep
=
(
1
<<
31
),
PM_Sleep
=
(
1
<<
31
),
PM_Snooze
=
(
1
<<
30
),
PM_Snooze
=
(
1
<<
30
),
PM_Mask
=
PM_Sleep
|
PM_Snooze
,
PM_Mask
=
PM_Sleep
|
PM_Snooze
,
/* SIAStatus bits */
/* SIAStatus bits */
NWayState
=
(
1
<<
14
)
|
(
1
<<
13
)
|
(
1
<<
12
),
NWayState
=
(
1
<<
14
)
|
(
1
<<
13
)
|
(
1
<<
12
),
NWayRestart
=
(
1
<<
12
),
NWayRestart
=
(
1
<<
12
),
...
@@ -858,7 +858,7 @@ static void de_stop_rxtx (struct de_private *de)
...
@@ -858,7 +858,7 @@ static void de_stop_rxtx (struct de_private *de)
return
;
return
;
cpu_relax
();
cpu_relax
();
}
}
printk
(
KERN_WARNING
"%s: timeout expired stopping DMA
\n
"
,
de
->
dev
->
name
);
printk
(
KERN_WARNING
"%s: timeout expired stopping DMA
\n
"
,
de
->
dev
->
name
);
}
}
...
@@ -931,7 +931,7 @@ static void de_set_media (struct de_private *de)
...
@@ -931,7 +931,7 @@ static void de_set_media (struct de_private *de)
macmode
|=
FullDuplex
;
macmode
|=
FullDuplex
;
else
else
macmode
&=
~
FullDuplex
;
macmode
&=
~
FullDuplex
;
if
(
netif_msg_link
(
de
))
{
if
(
netif_msg_link
(
de
))
{
printk
(
KERN_INFO
"%s: set link %s
\n
"
printk
(
KERN_INFO
"%s: set link %s
\n
"
KERN_INFO
"%s: mode 0x%x, sia 0x%x,0x%x,0x%x,0x%x
\n
"
KERN_INFO
"%s: mode 0x%x, sia 0x%x,0x%x,0x%x,0x%x
\n
"
...
@@ -966,9 +966,9 @@ static void de21040_media_timer (unsigned long data)
...
@@ -966,9 +966,9 @@ static void de21040_media_timer (unsigned long data)
u32
status
=
dr32
(
SIAStatus
);
u32
status
=
dr32
(
SIAStatus
);
unsigned
int
carrier
;
unsigned
int
carrier
;
unsigned
long
flags
;
unsigned
long
flags
;
carrier
=
(
status
&
NetCxnErr
)
?
0
:
1
;
carrier
=
(
status
&
NetCxnErr
)
?
0
:
1
;
if
(
carrier
)
{
if
(
carrier
)
{
if
(
de
->
media_type
!=
DE_MEDIA_AUI
&&
(
status
&
LinkFailStatus
))
if
(
de
->
media_type
!=
DE_MEDIA_AUI
&&
(
status
&
LinkFailStatus
))
goto
no_link_yet
;
goto
no_link_yet
;
...
@@ -985,7 +985,7 @@ static void de21040_media_timer (unsigned long data)
...
@@ -985,7 +985,7 @@ static void de21040_media_timer (unsigned long data)
return
;
return
;
}
}
de_link_down
(
de
);
de_link_down
(
de
);
if
(
de
->
media_lock
)
if
(
de
->
media_lock
)
return
;
return
;
...
@@ -1039,7 +1039,7 @@ static unsigned int de_ok_to_advertise (struct de_private *de, u32 new_media)
...
@@ -1039,7 +1039,7 @@ static unsigned int de_ok_to_advertise (struct de_private *de, u32 new_media)
return
0
;
return
0
;
break
;
break
;
}
}
return
1
;
return
1
;
}
}
...
@@ -1050,9 +1050,9 @@ static void de21041_media_timer (unsigned long data)
...
@@ -1050,9 +1050,9 @@ static void de21041_media_timer (unsigned long data)
u32
status
=
dr32
(
SIAStatus
);
u32
status
=
dr32
(
SIAStatus
);
unsigned
int
carrier
;
unsigned
int
carrier
;
unsigned
long
flags
;
unsigned
long
flags
;
carrier
=
(
status
&
NetCxnErr
)
?
0
:
1
;
carrier
=
(
status
&
NetCxnErr
)
?
0
:
1
;
if
(
carrier
)
{
if
(
carrier
)
{
if
((
de
->
media_type
==
DE_MEDIA_TP_AUTO
||
if
((
de
->
media_type
==
DE_MEDIA_TP_AUTO
||
de
->
media_type
==
DE_MEDIA_TP
||
de
->
media_type
==
DE_MEDIA_TP
||
...
@@ -1072,7 +1072,7 @@ static void de21041_media_timer (unsigned long data)
...
@@ -1072,7 +1072,7 @@ static void de21041_media_timer (unsigned long data)
return
;
return
;
}
}
de_link_down
(
de
);
de_link_down
(
de
);
/* if media type locked, don't switch media */
/* if media type locked, don't switch media */
if
(
de
->
media_lock
)
if
(
de
->
media_lock
)
...
@@ -1124,7 +1124,7 @@ static void de21041_media_timer (unsigned long data)
...
@@ -1124,7 +1124,7 @@ static void de21041_media_timer (unsigned long data)
u32
next_states
[]
=
{
DE_MEDIA_AUI
,
DE_MEDIA_BNC
,
DE_MEDIA_TP_AUTO
};
u32
next_states
[]
=
{
DE_MEDIA_AUI
,
DE_MEDIA_BNC
,
DE_MEDIA_TP_AUTO
};
de_next_media
(
de
,
next_states
,
ARRAY_SIZE
(
next_states
));
de_next_media
(
de
,
next_states
,
ARRAY_SIZE
(
next_states
));
}
}
set_media:
set_media:
spin_lock_irqsave
(
&
de
->
lock
,
flags
);
spin_lock_irqsave
(
&
de
->
lock
,
flags
);
de_stop_rxtx
(
de
);
de_stop_rxtx
(
de
);
...
@@ -1148,7 +1148,7 @@ static void de_media_interrupt (struct de_private *de, u32 status)
...
@@ -1148,7 +1148,7 @@ static void de_media_interrupt (struct de_private *de, u32 status)
mod_timer
(
&
de
->
media_timer
,
jiffies
+
DE_TIMER_LINK
);
mod_timer
(
&
de
->
media_timer
,
jiffies
+
DE_TIMER_LINK
);
return
;
return
;
}
}
BUG_ON
(
!
(
status
&
LinkFail
));
BUG_ON
(
!
(
status
&
LinkFail
));
if
(
netif_carrier_ok
(
de
->
dev
))
{
if
(
netif_carrier_ok
(
de
->
dev
))
{
...
@@ -1227,7 +1227,7 @@ static int de_init_hw (struct de_private *de)
...
@@ -1227,7 +1227,7 @@ static int de_init_hw (struct de_private *de)
int
rc
;
int
rc
;
de_adapter_wake
(
de
);
de_adapter_wake
(
de
);
macmode
=
dr32
(
MacMode
)
&
~
MacModeClear
;
macmode
=
dr32
(
MacMode
)
&
~
MacModeClear
;
rc
=
de_reset_mac
(
de
);
rc
=
de_reset_mac
(
de
);
...
@@ -1413,7 +1413,7 @@ static int de_close (struct net_device *dev)
...
@@ -1413,7 +1413,7 @@ static int de_close (struct net_device *dev)
netif_stop_queue
(
dev
);
netif_stop_queue
(
dev
);
netif_carrier_off
(
dev
);
netif_carrier_off
(
dev
);
spin_unlock_irqrestore
(
&
de
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
de
->
lock
,
flags
);
free_irq
(
dev
->
irq
,
dev
);
free_irq
(
dev
->
irq
,
dev
);
de_free_rings
(
de
);
de_free_rings
(
de
);
...
@@ -1441,7 +1441,7 @@ static void de_tx_timeout (struct net_device *dev)
...
@@ -1441,7 +1441,7 @@ static void de_tx_timeout (struct net_device *dev)
spin_unlock_irq
(
&
de
->
lock
);
spin_unlock_irq
(
&
de
->
lock
);
enable_irq
(
dev
->
irq
);
enable_irq
(
dev
->
irq
);
/* Update the error counts. */
/* Update the error counts. */
__de_get_stats
(
de
);
__de_get_stats
(
de
);
...
@@ -1451,7 +1451,7 @@ static void de_tx_timeout (struct net_device *dev)
...
@@ -1451,7 +1451,7 @@ static void de_tx_timeout (struct net_device *dev)
de_init_rings
(
de
);
de_init_rings
(
de
);
de_init_hw
(
de
);
de_init_hw
(
de
);
netif_wake_queue
(
dev
);
netif_wake_queue
(
dev
);
}
}
...
@@ -1459,7 +1459,7 @@ static void __de_get_regs(struct de_private *de, u8 *buf)
...
@@ -1459,7 +1459,7 @@ static void __de_get_regs(struct de_private *de, u8 *buf)
{
{
int
i
;
int
i
;
u32
*
rbuf
=
(
u32
*
)
buf
;
u32
*
rbuf
=
(
u32
*
)
buf
;
/* read all CSRs */
/* read all CSRs */
for
(
i
=
0
;
i
<
DE_NUM_REGS
;
i
++
)
for
(
i
=
0
;
i
<
DE_NUM_REGS
;
i
++
)
rbuf
[
i
]
=
dr32
(
i
*
8
);
rbuf
[
i
]
=
dr32
(
i
*
8
);
...
@@ -1474,7 +1474,7 @@ static int __de_get_settings(struct de_private *de, struct ethtool_cmd *ecmd)
...
@@ -1474,7 +1474,7 @@ static int __de_get_settings(struct de_private *de, struct ethtool_cmd *ecmd)
ecmd
->
transceiver
=
XCVR_INTERNAL
;
ecmd
->
transceiver
=
XCVR_INTERNAL
;
ecmd
->
phy_address
=
0
;
ecmd
->
phy_address
=
0
;
ecmd
->
advertising
=
de
->
media_advertise
;
ecmd
->
advertising
=
de
->
media_advertise
;
switch
(
de
->
media_type
)
{
switch
(
de
->
media_type
)
{
case
DE_MEDIA_AUI
:
case
DE_MEDIA_AUI
:
ecmd
->
port
=
PORT_AUI
;
ecmd
->
port
=
PORT_AUI
;
...
@@ -1489,7 +1489,7 @@ static int __de_get_settings(struct de_private *de, struct ethtool_cmd *ecmd)
...
@@ -1489,7 +1489,7 @@ static int __de_get_settings(struct de_private *de, struct ethtool_cmd *ecmd)
ecmd
->
speed
=
SPEED_10
;
ecmd
->
speed
=
SPEED_10
;
break
;
break
;
}
}
if
(
dr32
(
MacMode
)
&
FullDuplex
)
if
(
dr32
(
MacMode
)
&
FullDuplex
)
ecmd
->
duplex
=
DUPLEX_FULL
;
ecmd
->
duplex
=
DUPLEX_FULL
;
else
else
...
@@ -1529,7 +1529,7 @@ static int __de_set_settings(struct de_private *de, struct ethtool_cmd *ecmd)
...
@@ -1529,7 +1529,7 @@ static int __de_set_settings(struct de_private *de, struct ethtool_cmd *ecmd)
if
(
ecmd
->
autoneg
==
AUTONEG_ENABLE
&&
if
(
ecmd
->
autoneg
==
AUTONEG_ENABLE
&&
(
!
(
ecmd
->
advertising
&
ADVERTISED_Autoneg
)))
(
!
(
ecmd
->
advertising
&
ADVERTISED_Autoneg
)))
return
-
EINVAL
;
return
-
EINVAL
;
switch
(
ecmd
->
port
)
{
switch
(
ecmd
->
port
)
{
case
PORT_AUI
:
case
PORT_AUI
:
new_media
=
DE_MEDIA_AUI
;
new_media
=
DE_MEDIA_AUI
;
...
@@ -1554,22 +1554,22 @@ static int __de_set_settings(struct de_private *de, struct ethtool_cmd *ecmd)
...
@@ -1554,22 +1554,22 @@ static int __de_set_settings(struct de_private *de, struct ethtool_cmd *ecmd)
return
-
EINVAL
;
return
-
EINVAL
;
break
;
break
;
}
}
media_lock
=
(
ecmd
->
autoneg
==
AUTONEG_ENABLE
)
?
0
:
1
;
media_lock
=
(
ecmd
->
autoneg
==
AUTONEG_ENABLE
)
?
0
:
1
;
if
((
new_media
==
de
->
media_type
)
&&
if
((
new_media
==
de
->
media_type
)
&&
(
media_lock
==
de
->
media_lock
)
&&
(
media_lock
==
de
->
media_lock
)
&&
(
ecmd
->
advertising
==
de
->
media_advertise
))
(
ecmd
->
advertising
==
de
->
media_advertise
))
return
0
;
/* nothing to change */
return
0
;
/* nothing to change */
de_link_down
(
de
);
de_link_down
(
de
);
de_stop_rxtx
(
de
);
de_stop_rxtx
(
de
);
de
->
media_type
=
new_media
;
de
->
media_type
=
new_media
;
de
->
media_lock
=
media_lock
;
de
->
media_lock
=
media_lock
;
de
->
media_advertise
=
ecmd
->
advertising
;
de
->
media_advertise
=
ecmd
->
advertising
;
de_set_media
(
de
);
de_set_media
(
de
);
return
0
;
return
0
;
}
}
...
@@ -1817,7 +1817,7 @@ static void __init de21041_get_srom_info (struct de_private *de)
...
@@ -1817,7 +1817,7 @@ static void __init de21041_get_srom_info (struct de_private *de)
case
0x0204
:
de
->
media_type
=
DE_MEDIA_TP_FD
;
break
;
case
0x0204
:
de
->
media_type
=
DE_MEDIA_TP_FD
;
break
;
default:
de
->
media_type
=
DE_MEDIA_TP_AUTO
;
break
;
default:
de
->
media_type
=
DE_MEDIA_TP_AUTO
;
break
;
}
}
if
(
netif_msg_probe
(
de
))
if
(
netif_msg_probe
(
de
))
printk
(
KERN_INFO
"de%d: SROM leaf offset %u, default media %s
\n
"
,
printk
(
KERN_INFO
"de%d: SROM leaf offset %u, default media %s
\n
"
,
de
->
board_idx
,
ofs
,
de
->
board_idx
,
ofs
,
...
@@ -1886,7 +1886,7 @@ static void __init de21041_get_srom_info (struct de_private *de)
...
@@ -1886,7 +1886,7 @@ static void __init de21041_get_srom_info (struct de_private *de)
de
->
media
[
idx
].
csr13
,
de
->
media
[
idx
].
csr13
,
de
->
media
[
idx
].
csr14
,
de
->
media
[
idx
].
csr14
,
de
->
media
[
idx
].
csr15
);
de
->
media
[
idx
].
csr15
);
}
else
if
(
netif_msg_probe
(
de
))
}
else
if
(
netif_msg_probe
(
de
))
printk
(
"
\n
"
);
printk
(
"
\n
"
);
...
@@ -2118,7 +2118,7 @@ static int de_suspend (struct pci_dev *pdev, pm_message_t state)
...
@@ -2118,7 +2118,7 @@ static int de_suspend (struct pci_dev *pdev, pm_message_t state)
spin_unlock_irq
(
&
de
->
lock
);
spin_unlock_irq
(
&
de
->
lock
);
enable_irq
(
dev
->
irq
);
enable_irq
(
dev
->
irq
);
/* Update the error counts. */
/* Update the error counts. */
__de_get_stats
(
de
);
__de_get_stats
(
de
);
...
...
drivers/net/tulip/de4x5.c
View file @
f3b197ac
This diff is collapsed.
Click to expand it.
drivers/net/tulip/de4x5.h
View file @
f3b197ac
...
@@ -38,11 +38,11 @@
...
@@ -38,11 +38,11 @@
/*
/*
** EISA Register Address Map
** EISA Register Address Map
*/
*/
#define EISA_ID iobase+0x0c80
/* EISA ID Registers */
#define EISA_ID iobase+0x0c80
/* EISA ID Registers */
#define EISA_ID0 iobase+0x0c80
/* EISA ID Register 0 */
#define EISA_ID0 iobase+0x0c80
/* EISA ID Register 0 */
#define EISA_ID1 iobase+0x0c81
/* EISA ID Register 1 */
#define EISA_ID1 iobase+0x0c81
/* EISA ID Register 1 */
#define EISA_ID2 iobase+0x0c82
/* EISA ID Register 2 */
#define EISA_ID2 iobase+0x0c82
/* EISA ID Register 2 */
#define EISA_ID3 iobase+0x0c83
/* EISA ID Register 3 */
#define EISA_ID3 iobase+0x0c83
/* EISA ID Register 3 */
#define EISA_CR iobase+0x0c84
/* EISA Control Register */
#define EISA_CR iobase+0x0c84
/* EISA Control Register */
#define EISA_REG0 iobase+0x0c88
/* EISA Configuration Register 0 */
#define EISA_REG0 iobase+0x0c88
/* EISA Configuration Register 0 */
#define EISA_REG1 iobase+0x0c89
/* EISA Configuration Register 1 */
#define EISA_REG1 iobase+0x0c89
/* EISA Configuration Register 1 */
...
@@ -1008,8 +1008,8 @@ struct de4x5_ioctl {
...
@@ -1008,8 +1008,8 @@ struct de4x5_ioctl {
unsigned
char
__user
*
data
;
/* Pointer to the data buffer */
unsigned
char
__user
*
data
;
/* Pointer to the data buffer */
};
};
/*
/*
** Recognised commands for the driver
** Recognised commands for the driver
*/
*/
#define DE4X5_GET_HWADDR 0x01
/* Get the hardware address */
#define DE4X5_GET_HWADDR 0x01
/* Get the hardware address */
#define DE4X5_SET_HWADDR 0x02
/* Set the hardware address */
#define DE4X5_SET_HWADDR 0x02
/* Set the hardware address */
...
...
drivers/net/tulip/dmfe.c
View file @
f3b197ac
...
@@ -50,7 +50,7 @@
...
@@ -50,7 +50,7 @@
forget to unmap PCI mapped skbs.
forget to unmap PCI mapped skbs.
Alan Cox <alan@redhat.com>
Alan Cox <alan@redhat.com>
Added new PCI identifiers provided by Clear Zhang at ALi
Added new PCI identifiers provided by Clear Zhang at ALi
for their 1563 ethernet device.
for their 1563 ethernet device.
TODO
TODO
...
...
drivers/net/tulip/eeprom.c
View file @
f3b197ac
...
@@ -96,11 +96,11 @@ static const char *block_name[] __devinitdata = {
...
@@ -96,11 +96,11 @@ static const char *block_name[] __devinitdata = {
* tulip_build_fake_mediatable - Build a fake mediatable entry.
* tulip_build_fake_mediatable - Build a fake mediatable entry.
* @tp: Ptr to the tulip private data.
* @tp: Ptr to the tulip private data.
*
*
* Some cards like the 3x5 HSC cards (J3514A) do not have a standard
* Some cards like the 3x5 HSC cards (J3514A) do not have a standard
* srom and can not be handled under the fixup routine. These cards
* srom and can not be handled under the fixup routine. These cards
* still need a valid mediatable entry for correct csr12 setup and
* still need a valid mediatable entry for correct csr12 setup and
* mii handling.
* mii handling.
*
*
* Since this is currently a parisc-linux specific function, the
* Since this is currently a parisc-linux specific function, the
* #ifdef __hppa__ should completely optimize this function away for
* #ifdef __hppa__ should completely optimize this function away for
* non-parisc hardware.
* non-parisc hardware.
...
@@ -140,7 +140,7 @@ static void __devinit tulip_build_fake_mediatable(struct tulip_private *tp)
...
@@ -140,7 +140,7 @@ static void __devinit tulip_build_fake_mediatable(struct tulip_private *tp)
tp
->
flags
|=
HAS_PHY_IRQ
;
tp
->
flags
|=
HAS_PHY_IRQ
;
tp
->
csr12_shadow
=
-
1
;
tp
->
csr12_shadow
=
-
1
;
}
}
#endif
#endif
}
}
void
__devinit
tulip_parse_eeprom
(
struct
net_device
*
dev
)
void
__devinit
tulip_parse_eeprom
(
struct
net_device
*
dev
)
...
...
drivers/net/tulip/interrupt.c
View file @
f3b197ac
...
@@ -139,22 +139,22 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -139,22 +139,22 @@ int tulip_poll(struct net_device *dev, int *budget)
}
}
/* Acknowledge current RX interrupt sources. */
/* Acknowledge current RX interrupt sources. */
iowrite32
((
RxIntr
|
RxNoBuf
),
tp
->
base_addr
+
CSR5
);
iowrite32
((
RxIntr
|
RxNoBuf
),
tp
->
base_addr
+
CSR5
);
/* If we own the next entry, it is a new packet. Send it up. */
/* If we own the next entry, it is a new packet. Send it up. */
while
(
!
(
tp
->
rx_ring
[
entry
].
status
&
cpu_to_le32
(
DescOwned
)))
{
while
(
!
(
tp
->
rx_ring
[
entry
].
status
&
cpu_to_le32
(
DescOwned
)))
{
s32
status
=
le32_to_cpu
(
tp
->
rx_ring
[
entry
].
status
);
s32
status
=
le32_to_cpu
(
tp
->
rx_ring
[
entry
].
status
);
if
(
tp
->
dirty_rx
+
RX_RING_SIZE
==
tp
->
cur_rx
)
if
(
tp
->
dirty_rx
+
RX_RING_SIZE
==
tp
->
cur_rx
)
break
;
break
;
if
(
tulip_debug
>
5
)
if
(
tulip_debug
>
5
)
printk
(
KERN_DEBUG
"%s: In tulip_rx(), entry %d %8.8x.
\n
"
,
printk
(
KERN_DEBUG
"%s: In tulip_rx(), entry %d %8.8x.
\n
"
,
dev
->
name
,
entry
,
status
);
dev
->
name
,
entry
,
status
);
if
(
--
rx_work_limit
<
0
)
if
(
--
rx_work_limit
<
0
)
goto
not_done
;
goto
not_done
;
if
((
status
&
0x38008300
)
!=
0x0300
)
{
if
((
status
&
0x38008300
)
!=
0x0300
)
{
if
((
status
&
0x38000300
)
!=
0x0300
)
{
if
((
status
&
0x38000300
)
!=
0x0300
)
{
/* Ingore earlier buffers. */
/* Ingore earlier buffers. */
...
@@ -180,7 +180,7 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -180,7 +180,7 @@ int tulip_poll(struct net_device *dev, int *budget)
/* Omit the four octet CRC from the length. */
/* Omit the four octet CRC from the length. */
short
pkt_len
=
((
status
>>
16
)
&
0x7ff
)
-
4
;
short
pkt_len
=
((
status
>>
16
)
&
0x7ff
)
-
4
;
struct
sk_buff
*
skb
;
struct
sk_buff
*
skb
;
#ifndef final_version
#ifndef final_version
if
(
pkt_len
>
1518
)
{
if
(
pkt_len
>
1518
)
{
printk
(
KERN_WARNING
"%s: Bogus packet size of %d (%#x).
\n
"
,
printk
(
KERN_WARNING
"%s: Bogus packet size of %d (%#x).
\n
"
,
...
@@ -213,7 +213,7 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -213,7 +213,7 @@ int tulip_poll(struct net_device *dev, int *budget)
}
else
{
/* Pass up the skb already on the Rx ring. */
}
else
{
/* Pass up the skb already on the Rx ring. */
char
*
temp
=
skb_put
(
skb
=
tp
->
rx_buffers
[
entry
].
skb
,
char
*
temp
=
skb_put
(
skb
=
tp
->
rx_buffers
[
entry
].
skb
,
pkt_len
);
pkt_len
);
#ifndef final_version
#ifndef final_version
if
(
tp
->
rx_buffers
[
entry
].
mapping
!=
if
(
tp
->
rx_buffers
[
entry
].
mapping
!=
le32_to_cpu
(
tp
->
rx_ring
[
entry
].
buffer1
))
{
le32_to_cpu
(
tp
->
rx_ring
[
entry
].
buffer1
))
{
...
@@ -225,17 +225,17 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -225,17 +225,17 @@ int tulip_poll(struct net_device *dev, int *budget)
skb
->
head
,
temp
);
skb
->
head
,
temp
);
}
}
#endif
#endif
pci_unmap_single
(
tp
->
pdev
,
tp
->
rx_buffers
[
entry
].
mapping
,
pci_unmap_single
(
tp
->
pdev
,
tp
->
rx_buffers
[
entry
].
mapping
,
PKT_BUF_SZ
,
PCI_DMA_FROMDEVICE
);
PKT_BUF_SZ
,
PCI_DMA_FROMDEVICE
);
tp
->
rx_buffers
[
entry
].
skb
=
NULL
;
tp
->
rx_buffers
[
entry
].
skb
=
NULL
;
tp
->
rx_buffers
[
entry
].
mapping
=
0
;
tp
->
rx_buffers
[
entry
].
mapping
=
0
;
}
}
skb
->
protocol
=
eth_type_trans
(
skb
,
dev
);
skb
->
protocol
=
eth_type_trans
(
skb
,
dev
);
netif_receive_skb
(
skb
);
netif_receive_skb
(
skb
);
dev
->
last_rx
=
jiffies
;
dev
->
last_rx
=
jiffies
;
tp
->
stats
.
rx_packets
++
;
tp
->
stats
.
rx_packets
++
;
tp
->
stats
.
rx_bytes
+=
pkt_len
;
tp
->
stats
.
rx_bytes
+=
pkt_len
;
...
@@ -245,12 +245,12 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -245,12 +245,12 @@ int tulip_poll(struct net_device *dev, int *budget)
entry
=
(
++
tp
->
cur_rx
)
%
RX_RING_SIZE
;
entry
=
(
++
tp
->
cur_rx
)
%
RX_RING_SIZE
;
if
(
tp
->
cur_rx
-
tp
->
dirty_rx
>
RX_RING_SIZE
/
4
)
if
(
tp
->
cur_rx
-
tp
->
dirty_rx
>
RX_RING_SIZE
/
4
)
tulip_refill_rx
(
dev
);
tulip_refill_rx
(
dev
);
}
}
/* New ack strategy... irq does not ack Rx any longer
/* New ack strategy... irq does not ack Rx any longer
hopefully this helps */
hopefully this helps */
/* Really bad things can happen here... If new packet arrives
/* Really bad things can happen here... If new packet arrives
* and an irq arrives (tx or just due to occasionally unset
* and an irq arrives (tx or just due to occasionally unset
* mask), it will be acked by irq handler, but new thread
* mask), it will be acked by irq handler, but new thread
...
@@ -259,28 +259,28 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -259,28 +259,28 @@ int tulip_poll(struct net_device *dev, int *budget)
* tomorrow (night 011029). If it will not fail, we won
* tomorrow (night 011029). If it will not fail, we won
* finally: amount of IO did not increase at all. */
* finally: amount of IO did not increase at all. */
}
while
((
ioread32
(
tp
->
base_addr
+
CSR5
)
&
RxIntr
));
}
while
((
ioread32
(
tp
->
base_addr
+
CSR5
)
&
RxIntr
));
done:
done:
#ifdef CONFIG_TULIP_NAPI_HW_MITIGATION
#ifdef CONFIG_TULIP_NAPI_HW_MITIGATION
/* We use this simplistic scheme for IM. It's proven by
/* We use this simplistic scheme for IM. It's proven by
real life installations. We can have IM enabled
real life installations. We can have IM enabled
continuesly but this would cause unnecessary latency.
continuesly but this would cause unnecessary latency.
Unfortunely we can't use all the NET_RX_* feedback here.
Unfortunely we can't use all the NET_RX_* feedback here.
This would turn on IM for devices that is not contributing
This would turn on IM for devices that is not contributing
to backlog congestion with unnecessary latency.
to backlog congestion with unnecessary latency.
We monitor the the device RX-ring and have:
We monitor the the device RX-ring and have:
HW Interrupt Mitigation either ON or OFF.
HW Interrupt Mitigation either ON or OFF.
ON: More then 1 pkt received (per intr.) OR we are dropping
ON: More then 1 pkt received (per intr.) OR we are dropping
OFF: Only 1 pkt received
OFF: Only 1 pkt received
Note. We only use min and max (0, 15) settings from mit_table */
Note. We only use min and max (0, 15) settings from mit_table */
if
(
tp
->
flags
&
HAS_INTR_MITIGATION
)
{
if
(
tp
->
flags
&
HAS_INTR_MITIGATION
)
{
if
(
received
>
1
)
{
if
(
received
>
1
)
{
if
(
!
tp
->
mit_on
)
{
if
(
!
tp
->
mit_on
)
{
...
@@ -297,20 +297,20 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -297,20 +297,20 @@ int tulip_poll(struct net_device *dev, int *budget)
}
}
#endif
/* CONFIG_TULIP_NAPI_HW_MITIGATION */
#endif
/* CONFIG_TULIP_NAPI_HW_MITIGATION */
dev
->
quota
-=
received
;
dev
->
quota
-=
received
;
*
budget
-=
received
;
*
budget
-=
received
;
tulip_refill_rx
(
dev
);
tulip_refill_rx
(
dev
);
/* If RX ring is not full we are out of memory. */
/* If RX ring is not full we are out of memory. */
if
(
tp
->
rx_buffers
[
tp
->
dirty_rx
%
RX_RING_SIZE
].
skb
==
NULL
)
goto
oom
;
if
(
tp
->
rx_buffers
[
tp
->
dirty_rx
%
RX_RING_SIZE
].
skb
==
NULL
)
goto
oom
;
/* Remove us from polling list and enable RX intr. */
/* Remove us from polling list and enable RX intr. */
netif_rx_complete
(
dev
);
netif_rx_complete
(
dev
);
iowrite32
(
tulip_tbl
[
tp
->
chip_id
].
valid_intrs
,
tp
->
base_addr
+
CSR7
);
iowrite32
(
tulip_tbl
[
tp
->
chip_id
].
valid_intrs
,
tp
->
base_addr
+
CSR7
);
/* The last op happens after poll completion. Which means the following:
/* The last op happens after poll completion. Which means the following:
* 1. it can race with disabling irqs in irq handler
* 1. it can race with disabling irqs in irq handler
* 2. it can race with dise/enabling irqs in other poll threads
* 2. it can race with dise/enabling irqs in other poll threads
...
@@ -321,9 +321,9 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -321,9 +321,9 @@ int tulip_poll(struct net_device *dev, int *budget)
* due to races in masking and due to too late acking of already
* due to races in masking and due to too late acking of already
* processed irqs. But it must not result in losing events.
* processed irqs. But it must not result in losing events.
*/
*/
return
0
;
return
0
;
not_done:
not_done:
if
(
!
received
)
{
if
(
!
received
)
{
...
@@ -331,29 +331,29 @@ int tulip_poll(struct net_device *dev, int *budget)
...
@@ -331,29 +331,29 @@ int tulip_poll(struct net_device *dev, int *budget)
}
}
dev
->
quota
-=
received
;
dev
->
quota
-=
received
;
*
budget
-=
received
;
*
budget
-=
received
;
if
(
tp
->
cur_rx
-
tp
->
dirty_rx
>
RX_RING_SIZE
/
2
||
if
(
tp
->
cur_rx
-
tp
->
dirty_rx
>
RX_RING_SIZE
/
2
||
tp
->
rx_buffers
[
tp
->
dirty_rx
%
RX_RING_SIZE
].
skb
==
NULL
)
tp
->
rx_buffers
[
tp
->
dirty_rx
%
RX_RING_SIZE
].
skb
==
NULL
)
tulip_refill_rx
(
dev
);
tulip_refill_rx
(
dev
);
if
(
tp
->
rx_buffers
[
tp
->
dirty_rx
%
RX_RING_SIZE
].
skb
==
NULL
)
goto
oom
;
if
(
tp
->
rx_buffers
[
tp
->
dirty_rx
%
RX_RING_SIZE
].
skb
==
NULL
)
goto
oom
;
return
1
;
return
1
;
oom:
/* Executed with RX ints disabled */
oom:
/* Executed with RX ints disabled */
/* Start timer, stop polling, but do not enable rx interrupts. */
/* Start timer, stop polling, but do not enable rx interrupts. */
mod_timer
(
&
tp
->
oom_timer
,
jiffies
+
1
);
mod_timer
(
&
tp
->
oom_timer
,
jiffies
+
1
);
/* Think: timer_pending() was an explicit signature of bug.
/* Think: timer_pending() was an explicit signature of bug.
* Timer can be pending now but fired and completed
* Timer can be pending now but fired and completed
* before we did netif_rx_complete(). See? We would lose it. */
* before we did netif_rx_complete(). See? We would lose it. */
/* remove ourselves from the polling list */
/* remove ourselves from the polling list */
netif_rx_complete
(
dev
);
netif_rx_complete
(
dev
);
return
0
;
return
0
;
}
}
...
@@ -521,9 +521,9 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
...
@@ -521,9 +521,9 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
/* Let's see whether the interrupt really is for us */
/* Let's see whether the interrupt really is for us */
csr5
=
ioread32
(
ioaddr
+
CSR5
);
csr5
=
ioread32
(
ioaddr
+
CSR5
);
if
(
tp
->
flags
&
HAS_PHY_IRQ
)
if
(
tp
->
flags
&
HAS_PHY_IRQ
)
handled
=
phy_interrupt
(
dev
);
handled
=
phy_interrupt
(
dev
);
if
((
csr5
&
(
NormalIntr
|
AbnormalIntr
))
==
0
)
if
((
csr5
&
(
NormalIntr
|
AbnormalIntr
))
==
0
)
return
IRQ_RETVAL
(
handled
);
return
IRQ_RETVAL
(
handled
);
...
@@ -538,17 +538,17 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
...
@@ -538,17 +538,17 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
/* Mask RX intrs and add the device to poll list. */
/* Mask RX intrs and add the device to poll list. */
iowrite32
(
tulip_tbl
[
tp
->
chip_id
].
valid_intrs
&~
RxPollInt
,
ioaddr
+
CSR7
);
iowrite32
(
tulip_tbl
[
tp
->
chip_id
].
valid_intrs
&~
RxPollInt
,
ioaddr
+
CSR7
);
netif_rx_schedule
(
dev
);
netif_rx_schedule
(
dev
);
if
(
!
(
csr5
&~
(
AbnormalIntr
|
NormalIntr
|
RxPollInt
|
TPLnkPass
)))
if
(
!
(
csr5
&~
(
AbnormalIntr
|
NormalIntr
|
RxPollInt
|
TPLnkPass
)))
break
;
break
;
}
}
/* Acknowledge the interrupt sources we handle here ASAP
/* Acknowledge the interrupt sources we handle here ASAP
the poll function does Rx and RxNoBuf acking */
the poll function does Rx and RxNoBuf acking */
iowrite32
(
csr5
&
0x0001ff3f
,
ioaddr
+
CSR5
);
iowrite32
(
csr5
&
0x0001ff3f
,
ioaddr
+
CSR5
);
#else
#else
/* Acknowledge all of the current interrupt sources ASAP. */
/* Acknowledge all of the current interrupt sources ASAP. */
iowrite32
(
csr5
&
0x0001ffff
,
ioaddr
+
CSR5
);
iowrite32
(
csr5
&
0x0001ffff
,
ioaddr
+
CSR5
);
...
@@ -559,11 +559,11 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
...
@@ -559,11 +559,11 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
}
}
#endif
/* CONFIG_TULIP_NAPI */
#endif
/* CONFIG_TULIP_NAPI */
if
(
tulip_debug
>
4
)
if
(
tulip_debug
>
4
)
printk
(
KERN_DEBUG
"%s: interrupt csr5=%#8.8x new csr5=%#8.8x.
\n
"
,
printk
(
KERN_DEBUG
"%s: interrupt csr5=%#8.8x new csr5=%#8.8x.
\n
"
,
dev
->
name
,
csr5
,
ioread32
(
ioaddr
+
CSR5
));
dev
->
name
,
csr5
,
ioread32
(
ioaddr
+
CSR5
));
if
(
csr5
&
(
TxNoBuf
|
TxDied
|
TxIntr
|
TimerInt
))
{
if
(
csr5
&
(
TxNoBuf
|
TxDied
|
TxIntr
|
TimerInt
))
{
unsigned
int
dirty_tx
;
unsigned
int
dirty_tx
;
...
@@ -737,17 +737,17 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
...
@@ -737,17 +737,17 @@ irqreturn_t tulip_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
#ifdef CONFIG_TULIP_NAPI
#ifdef CONFIG_TULIP_NAPI
if
(
rxd
)
if
(
rxd
)
csr5
&=
~
RxPollInt
;
csr5
&=
~
RxPollInt
;
}
while
((
csr5
&
(
TxNoBuf
|
}
while
((
csr5
&
(
TxNoBuf
|
TxDied
|
TxDied
|
TxIntr
|
TxIntr
|
TimerInt
|
TimerInt
|
/* Abnormal intr. */
/* Abnormal intr. */
RxDied
|
RxDied
|
TxFIFOUnderflow
|
TxFIFOUnderflow
|
TxJabber
|
TxJabber
|
TPLnkFail
|
TPLnkFail
|
SytemError
))
!=
0
);
SytemError
))
!=
0
);
#else
#else
}
while
((
csr5
&
(
NormalIntr
|
AbnormalIntr
))
!=
0
);
}
while
((
csr5
&
(
NormalIntr
|
AbnormalIntr
))
!=
0
);
tulip_refill_rx
(
dev
);
tulip_refill_rx
(
dev
);
...
...
drivers/net/tulip/media.c
View file @
f3b197ac
...
@@ -140,7 +140,7 @@ void tulip_mdio_write(struct net_device *dev, int phy_id, int location, int val)
...
@@ -140,7 +140,7 @@ void tulip_mdio_write(struct net_device *dev, int phy_id, int location, int val)
spin_unlock_irqrestore
(
&
tp
->
mii_lock
,
flags
);
spin_unlock_irqrestore
(
&
tp
->
mii_lock
,
flags
);
return
;
return
;
}
}
/* Establish sync by sending 32 logic ones. */
/* Establish sync by sending 32 logic ones. */
for
(
i
=
32
;
i
>=
0
;
i
--
)
{
for
(
i
=
32
;
i
>=
0
;
i
--
)
{
iowrite32
(
MDIO_ENB
|
MDIO_DATA_WRITE1
,
mdio_addr
);
iowrite32
(
MDIO_ENB
|
MDIO_DATA_WRITE1
,
mdio_addr
);
...
...
drivers/net/tulip/tulip.h
View file @
f3b197ac
...
@@ -259,7 +259,7 @@ enum t21143_csr6_bits {
...
@@ -259,7 +259,7 @@ enum t21143_csr6_bits {
There are no ill effects from too-large receive rings. */
There are no ill effects from too-large receive rings. */
#define TX_RING_SIZE 32
#define TX_RING_SIZE 32
#define RX_RING_SIZE 128
#define RX_RING_SIZE 128
#define MEDIA_MASK 31
#define MEDIA_MASK 31
#define PKT_BUF_SZ 1536
/* Size of each temporary Rx buffer. */
#define PKT_BUF_SZ 1536
/* Size of each temporary Rx buffer. */
...
...
drivers/net/tulip/tulip_core.c
View file @
f3b197ac
...
@@ -1224,7 +1224,7 @@ static void __devinit tulip_mwi_config (struct pci_dev *pdev,
...
@@ -1224,7 +1224,7 @@ static void __devinit tulip_mwi_config (struct pci_dev *pdev,
* Chips that have the MRM/reserved bit quirk and the burst quirk. That
* Chips that have the MRM/reserved bit quirk and the burst quirk. That
* is the DM910X and the on chip ULi devices
* is the DM910X and the on chip ULi devices
*/
*/
static
int
tulip_uli_dm_quirk
(
struct
pci_dev
*
pdev
)
static
int
tulip_uli_dm_quirk
(
struct
pci_dev
*
pdev
)
{
{
if
(
pdev
->
vendor
==
0x1282
&&
pdev
->
device
==
0x9102
)
if
(
pdev
->
vendor
==
0x1282
&&
pdev
->
device
==
0x9102
)
...
@@ -1297,7 +1297,7 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
...
@@ -1297,7 +1297,7 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
*/
*/
/* 1. Intel Saturn. Switch to 8 long words burst, 8 long word cache
/* 1. Intel Saturn. Switch to 8 long words burst, 8 long word cache
aligned. Aries might need this too. The Saturn errata are not
aligned. Aries might need this too. The Saturn errata are not
pretty reading but thankfully it's an old 486 chipset.
pretty reading but thankfully it's an old 486 chipset.
2. The dreaded SiS496 486 chipset. Same workaround as Intel
2. The dreaded SiS496 486 chipset. Same workaround as Intel
...
@@ -1500,7 +1500,7 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
...
@@ -1500,7 +1500,7 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
}
}
#endif
#endif
#ifdef CONFIG_MIPS_COBALT
#ifdef CONFIG_MIPS_COBALT
if
((
pdev
->
bus
->
number
==
0
)
&&
if
((
pdev
->
bus
->
number
==
0
)
&&
((
PCI_SLOT
(
pdev
->
devfn
)
==
7
)
||
((
PCI_SLOT
(
pdev
->
devfn
)
==
7
)
||
(
PCI_SLOT
(
pdev
->
devfn
)
==
12
)))
{
(
PCI_SLOT
(
pdev
->
devfn
)
==
12
)))
{
/* Cobalt MAC address in first EEPROM locations. */
/* Cobalt MAC address in first EEPROM locations. */
...
...
drivers/net/tulip/uli526x.c
View file @
f3b197ac
...
@@ -9,7 +9,7 @@
...
@@ -9,7 +9,7 @@
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
GNU General Public License for more details.
*/
*/
#define DRV_NAME "uli526x"
#define DRV_NAME "uli526x"
...
@@ -185,7 +185,7 @@ struct uli526x_board_info {
...
@@ -185,7 +185,7 @@ struct uli526x_board_info {
/* NIC SROM data */
/* NIC SROM data */
unsigned
char
srom
[
128
];
unsigned
char
srom
[
128
];
u8
init
;
u8
init
;
};
};
enum
uli526x_offsets
{
enum
uli526x_offsets
{
...
@@ -258,7 +258,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
...
@@ -258,7 +258,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
struct
uli526x_board_info
*
db
;
/* board information structure */
struct
uli526x_board_info
*
db
;
/* board information structure */
struct
net_device
*
dev
;
struct
net_device
*
dev
;
int
i
,
err
;
int
i
,
err
;
ULI526X_DBUG
(
0
,
"uli526x_init_one()"
,
0
);
ULI526X_DBUG
(
0
,
"uli526x_init_one()"
,
0
);
if
(
!
printed_version
++
)
if
(
!
printed_version
++
)
...
@@ -316,7 +316,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
...
@@ -316,7 +316,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
err
=
-
ENOMEM
;
err
=
-
ENOMEM
;
goto
err_out_nomem
;
goto
err_out_nomem
;
}
}
db
->
first_tx_desc
=
(
struct
tx_desc
*
)
db
->
desc_pool_ptr
;
db
->
first_tx_desc
=
(
struct
tx_desc
*
)
db
->
desc_pool_ptr
;
db
->
first_tx_desc_dma
=
db
->
desc_pool_dma_ptr
;
db
->
first_tx_desc_dma
=
db
->
desc_pool_dma_ptr
;
db
->
buf_pool_start
=
db
->
buf_pool_ptr
;
db
->
buf_pool_start
=
db
->
buf_pool_ptr
;
...
@@ -324,14 +324,14 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
...
@@ -324,14 +324,14 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
db
->
chip_id
=
ent
->
driver_data
;
db
->
chip_id
=
ent
->
driver_data
;
db
->
ioaddr
=
pci_resource_start
(
pdev
,
0
);
db
->
ioaddr
=
pci_resource_start
(
pdev
,
0
);
db
->
pdev
=
pdev
;
db
->
pdev
=
pdev
;
db
->
init
=
1
;
db
->
init
=
1
;
dev
->
base_addr
=
db
->
ioaddr
;
dev
->
base_addr
=
db
->
ioaddr
;
dev
->
irq
=
pdev
->
irq
;
dev
->
irq
=
pdev
->
irq
;
pci_set_drvdata
(
pdev
,
dev
);
pci_set_drvdata
(
pdev
,
dev
);
/* Register some necessary functions */
/* Register some necessary functions */
dev
->
open
=
&
uli526x_open
;
dev
->
open
=
&
uli526x_open
;
dev
->
hard_start_xmit
=
&
uli526x_start_xmit
;
dev
->
hard_start_xmit
=
&
uli526x_start_xmit
;
...
@@ -341,7 +341,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
...
@@ -341,7 +341,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
dev
->
ethtool_ops
=
&
netdev_ethtool_ops
;
dev
->
ethtool_ops
=
&
netdev_ethtool_ops
;
spin_lock_init
(
&
db
->
lock
);
spin_lock_init
(
&
db
->
lock
);
/* read 64 word srom data */
/* read 64 word srom data */
for
(
i
=
0
;
i
<
64
;
i
++
)
for
(
i
=
0
;
i
<
64
;
i
++
)
((
u16
*
)
db
->
srom
)[
i
]
=
cpu_to_le16
(
read_srom_word
(
db
->
ioaddr
,
i
));
((
u16
*
)
db
->
srom
)[
i
]
=
cpu_to_le16
(
read_srom_word
(
db
->
ioaddr
,
i
));
...
@@ -374,7 +374,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
...
@@ -374,7 +374,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
goto
err_out_res
;
goto
err_out_res
;
printk
(
KERN_INFO
"%s: ULi M%04lx at pci%s,"
,
dev
->
name
,
ent
->
driver_data
>>
16
,
pci_name
(
pdev
));
printk
(
KERN_INFO
"%s: ULi M%04lx at pci%s,"
,
dev
->
name
,
ent
->
driver_data
>>
16
,
pci_name
(
pdev
));
for
(
i
=
0
;
i
<
6
;
i
++
)
for
(
i
=
0
;
i
<
6
;
i
++
)
printk
(
"%c%02x"
,
i
?
':'
:
' '
,
dev
->
dev_addr
[
i
]);
printk
(
"%c%02x"
,
i
?
':'
:
' '
,
dev
->
dev_addr
[
i
]);
printk
(
", irq %d.
\n
"
,
dev
->
irq
);
printk
(
", irq %d.
\n
"
,
dev
->
irq
);
...
@@ -389,7 +389,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
...
@@ -389,7 +389,7 @@ static int __devinit uli526x_init_one (struct pci_dev *pdev,
if
(
db
->
desc_pool_ptr
)
if
(
db
->
desc_pool_ptr
)
pci_free_consistent
(
pdev
,
sizeof
(
struct
tx_desc
)
*
DESC_ALL_CNT
+
0x20
,
pci_free_consistent
(
pdev
,
sizeof
(
struct
tx_desc
)
*
DESC_ALL_CNT
+
0x20
,
db
->
desc_pool_ptr
,
db
->
desc_pool_dma_ptr
);
db
->
desc_pool_ptr
,
db
->
desc_pool_dma_ptr
);
if
(
db
->
buf_pool_ptr
!=
NULL
)
if
(
db
->
buf_pool_ptr
!=
NULL
)
pci_free_consistent
(
pdev
,
TX_BUF_ALLOC
*
TX_DESC_CNT
+
4
,
pci_free_consistent
(
pdev
,
TX_BUF_ALLOC
*
TX_DESC_CNT
+
4
,
db
->
buf_pool_ptr
,
db
->
buf_pool_dma_ptr
);
db
->
buf_pool_ptr
,
db
->
buf_pool_dma_ptr
);
...
@@ -433,7 +433,7 @@ static int uli526x_open(struct net_device *dev)
...
@@ -433,7 +433,7 @@ static int uli526x_open(struct net_device *dev)
{
{
int
ret
;
int
ret
;
struct
uli526x_board_info
*
db
=
netdev_priv
(
dev
);
struct
uli526x_board_info
*
db
=
netdev_priv
(
dev
);
ULI526X_DBUG
(
0
,
"uli526x_open"
,
0
);
ULI526X_DBUG
(
0
,
"uli526x_open"
,
0
);
ret
=
request_irq
(
dev
->
irq
,
&
uli526x_interrupt
,
SA_SHIRQ
,
dev
->
name
,
dev
);
ret
=
request_irq
(
dev
->
irq
,
&
uli526x_interrupt
,
SA_SHIRQ
,
dev
->
name
,
dev
);
...
@@ -454,7 +454,7 @@ static int uli526x_open(struct net_device *dev)
...
@@ -454,7 +454,7 @@ static int uli526x_open(struct net_device *dev)
/* CR6 operation mode decision */
/* CR6 operation mode decision */
db
->
cr6_data
|=
ULI526X_TXTH_256
;
db
->
cr6_data
|=
ULI526X_TXTH_256
;
db
->
cr0_data
=
CR0_DEFAULT
;
db
->
cr0_data
=
CR0_DEFAULT
;
/* Initialize ULI526X board */
/* Initialize ULI526X board */
uli526x_init
(
dev
);
uli526x_init
(
dev
);
...
@@ -604,7 +604,7 @@ static int uli526x_start_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -604,7 +604,7 @@ static int uli526x_start_xmit(struct sk_buff *skb, struct net_device *dev)
/* Restore CR7 to enable interrupt */
/* Restore CR7 to enable interrupt */
spin_unlock_irqrestore
(
&
db
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
db
->
lock
,
flags
);
outl
(
db
->
cr7_data
,
dev
->
base_addr
+
DCR7
);
outl
(
db
->
cr7_data
,
dev
->
base_addr
+
DCR7
);
/* free this SKB */
/* free this SKB */
dev_kfree_skb
(
skb
);
dev_kfree_skb
(
skb
);
...
@@ -782,7 +782,7 @@ static void uli526x_rx_packet(struct net_device *dev, struct uli526x_board_info
...
@@ -782,7 +782,7 @@ static void uli526x_rx_packet(struct net_device *dev, struct uli526x_board_info
struct
sk_buff
*
skb
;
struct
sk_buff
*
skb
;
int
rxlen
;
int
rxlen
;
u32
rdes0
;
u32
rdes0
;
rxptr
=
db
->
rx_ready_ptr
;
rxptr
=
db
->
rx_ready_ptr
;
while
(
db
->
rx_avail_cnt
)
{
while
(
db
->
rx_avail_cnt
)
{
...
@@ -821,7 +821,7 @@ static void uli526x_rx_packet(struct net_device *dev, struct uli526x_board_info
...
@@ -821,7 +821,7 @@ static void uli526x_rx_packet(struct net_device *dev, struct uli526x_board_info
if
(
!
(
rdes0
&
0x8000
)
||
if
(
!
(
rdes0
&
0x8000
)
||
((
db
->
cr6_data
&
CR6_PM
)
&&
(
rxlen
>
6
))
)
{
((
db
->
cr6_data
&
CR6_PM
)
&&
(
rxlen
>
6
))
)
{
skb
=
rxptr
->
rx_skb_ptr
;
skb
=
rxptr
->
rx_skb_ptr
;
/* Good packet, send to upper layer */
/* Good packet, send to upper layer */
/* Shorst packet used new SKB */
/* Shorst packet used new SKB */
if
(
(
rxlen
<
RX_COPY_SIZE
)
&&
if
(
(
rxlen
<
RX_COPY_SIZE
)
&&
...
@@ -841,7 +841,7 @@ static void uli526x_rx_packet(struct net_device *dev, struct uli526x_board_info
...
@@ -841,7 +841,7 @@ static void uli526x_rx_packet(struct net_device *dev, struct uli526x_board_info
dev
->
last_rx
=
jiffies
;
dev
->
last_rx
=
jiffies
;
db
->
stats
.
rx_packets
++
;
db
->
stats
.
rx_packets
++
;
db
->
stats
.
rx_bytes
+=
rxlen
;
db
->
stats
.
rx_bytes
+=
rxlen
;
}
else
{
}
else
{
/* Reuse SKB buffer when the packet is error */
/* Reuse SKB buffer when the packet is error */
ULI526X_DBUG
(
0
,
"Reuse SK buffer, rdes0"
,
rdes0
);
ULI526X_DBUG
(
0
,
"Reuse SK buffer, rdes0"
,
rdes0
);
...
@@ -911,7 +911,7 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd)
...
@@ -911,7 +911,7 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd)
SUPPORTED_100baseT_Full
|
SUPPORTED_100baseT_Full
|
SUPPORTED_Autoneg
|
SUPPORTED_Autoneg
|
SUPPORTED_MII
);
SUPPORTED_MII
);
ecmd
->
advertising
=
(
ADVERTISED_10baseT_Half
|
ecmd
->
advertising
=
(
ADVERTISED_10baseT_Half
|
ADVERTISED_10baseT_Full
|
ADVERTISED_10baseT_Full
|
ADVERTISED_100baseT_Half
|
ADVERTISED_100baseT_Half
|
...
@@ -924,13 +924,13 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd)
...
@@ -924,13 +924,13 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd)
ecmd
->
phy_address
=
db
->
phy_addr
;
ecmd
->
phy_address
=
db
->
phy_addr
;
ecmd
->
transceiver
=
XCVR_EXTERNAL
;
ecmd
->
transceiver
=
XCVR_EXTERNAL
;
ecmd
->
speed
=
10
;
ecmd
->
speed
=
10
;
ecmd
->
duplex
=
DUPLEX_HALF
;
ecmd
->
duplex
=
DUPLEX_HALF
;
if
(
db
->
op_mode
==
ULI526X_100MHF
||
db
->
op_mode
==
ULI526X_100MFD
)
if
(
db
->
op_mode
==
ULI526X_100MHF
||
db
->
op_mode
==
ULI526X_100MFD
)
{
{
ecmd
->
speed
=
100
;
ecmd
->
speed
=
100
;
}
}
if
(
db
->
op_mode
==
ULI526X_10MFD
||
db
->
op_mode
==
ULI526X_100MFD
)
if
(
db
->
op_mode
==
ULI526X_10MFD
||
db
->
op_mode
==
ULI526X_100MFD
)
{
{
...
@@ -939,11 +939,11 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd)
...
@@ -939,11 +939,11 @@ ULi_ethtool_gset(struct uli526x_board_info *db, struct ethtool_cmd *ecmd)
if
(
db
->
link_failed
)
if
(
db
->
link_failed
)
{
{
ecmd
->
speed
=
-
1
;
ecmd
->
speed
=
-
1
;
ecmd
->
duplex
=
-
1
;
ecmd
->
duplex
=
-
1
;
}
}
if
(
db
->
media_mode
&
ULI526X_AUTO
)
if
(
db
->
media_mode
&
ULI526X_AUTO
)
{
{
ecmd
->
autoneg
=
AUTONEG_ENABLE
;
ecmd
->
autoneg
=
AUTONEG_ENABLE
;
}
}
}
}
...
@@ -964,15 +964,15 @@ static void netdev_get_drvinfo(struct net_device *dev,
...
@@ -964,15 +964,15 @@ static void netdev_get_drvinfo(struct net_device *dev,
static
int
netdev_get_settings
(
struct
net_device
*
dev
,
struct
ethtool_cmd
*
cmd
)
{
static
int
netdev_get_settings
(
struct
net_device
*
dev
,
struct
ethtool_cmd
*
cmd
)
{
struct
uli526x_board_info
*
np
=
netdev_priv
(
dev
);
struct
uli526x_board_info
*
np
=
netdev_priv
(
dev
);
ULi_ethtool_gset
(
np
,
cmd
);
ULi_ethtool_gset
(
np
,
cmd
);
return
0
;
return
0
;
}
}
static
u32
netdev_get_link
(
struct
net_device
*
dev
)
{
static
u32
netdev_get_link
(
struct
net_device
*
dev
)
{
struct
uli526x_board_info
*
np
=
netdev_priv
(
dev
);
struct
uli526x_board_info
*
np
=
netdev_priv
(
dev
);
if
(
np
->
link_failed
)
if
(
np
->
link_failed
)
return
0
;
return
0
;
else
else
...
@@ -1005,11 +1005,11 @@ static void uli526x_timer(unsigned long data)
...
@@ -1005,11 +1005,11 @@ static void uli526x_timer(unsigned long data)
struct
uli526x_board_info
*
db
=
netdev_priv
(
dev
);
struct
uli526x_board_info
*
db
=
netdev_priv
(
dev
);
unsigned
long
flags
;
unsigned
long
flags
;
u8
TmpSpeed
=
10
;
u8
TmpSpeed
=
10
;
//ULI526X_DBUG(0, "uli526x_timer()", 0);
//ULI526X_DBUG(0, "uli526x_timer()", 0);
spin_lock_irqsave
(
&
db
->
lock
,
flags
);
spin_lock_irqsave
(
&
db
->
lock
,
flags
);
/* Dynamic reset ULI526X : system error or transmit time-out */
/* Dynamic reset ULI526X : system error or transmit time-out */
tmp_cr8
=
inl
(
db
->
ioaddr
+
DCR8
);
tmp_cr8
=
inl
(
db
->
ioaddr
+
DCR8
);
if
(
(
db
->
interval_rx_cnt
==
0
)
&&
(
tmp_cr8
)
)
{
if
(
(
db
->
interval_rx_cnt
==
0
)
&&
(
tmp_cr8
)
)
{
...
@@ -1021,9 +1021,9 @@ static void uli526x_timer(unsigned long data)
...
@@ -1021,9 +1021,9 @@ static void uli526x_timer(unsigned long data)
/* TX polling kick monitor */
/* TX polling kick monitor */
if
(
db
->
tx_packet_cnt
&&
if
(
db
->
tx_packet_cnt
&&
time_after
(
jiffies
,
dev
->
trans_start
+
ULI526X_TX_KICK
)
)
{
time_after
(
jiffies
,
dev
->
trans_start
+
ULI526X_TX_KICK
)
)
{
outl
(
0x1
,
dev
->
base_addr
+
DCR1
);
// Tx polling again
outl
(
0x1
,
dev
->
base_addr
+
DCR1
);
// Tx polling again
// TX Timeout
// TX Timeout
if
(
time_after
(
jiffies
,
dev
->
trans_start
+
ULI526X_TX_TIMEOUT
)
)
{
if
(
time_after
(
jiffies
,
dev
->
trans_start
+
ULI526X_TX_TIMEOUT
)
)
{
db
->
reset_TXtimeout
++
;
db
->
reset_TXtimeout
++
;
db
->
wait_reset
=
1
;
db
->
wait_reset
=
1
;
...
@@ -1073,7 +1073,7 @@ static void uli526x_timer(unsigned long data)
...
@@ -1073,7 +1073,7 @@ static void uli526x_timer(unsigned long data)
uli526x_sense_speed
(
db
)
)
uli526x_sense_speed
(
db
)
)
db
->
link_failed
=
1
;
db
->
link_failed
=
1
;
uli526x_process_mode
(
db
);
uli526x_process_mode
(
db
);
if
(
db
->
link_failed
==
0
)
if
(
db
->
link_failed
==
0
)
{
{
if
(
db
->
op_mode
==
ULI526X_100MHF
||
db
->
op_mode
==
ULI526X_100MFD
)
if
(
db
->
op_mode
==
ULI526X_100MHF
||
db
->
op_mode
==
ULI526X_100MFD
)
...
@@ -1404,7 +1404,7 @@ static u8 uli526x_sense_speed(struct uli526x_board_info * db)
...
@@ -1404,7 +1404,7 @@ static u8 uli526x_sense_speed(struct uli526x_board_info * db)
phy_mode
=
phy_read
(
db
->
ioaddr
,
db
->
phy_addr
,
1
,
db
->
chip_id
);
phy_mode
=
phy_read
(
db
->
ioaddr
,
db
->
phy_addr
,
1
,
db
->
chip_id
);
if
(
(
phy_mode
&
0x24
)
==
0x24
)
{
if
(
(
phy_mode
&
0x24
)
==
0x24
)
{
phy_mode
=
((
phy_read
(
db
->
ioaddr
,
db
->
phy_addr
,
5
,
db
->
chip_id
)
&
0x01e0
)
<<
7
);
phy_mode
=
((
phy_read
(
db
->
ioaddr
,
db
->
phy_addr
,
5
,
db
->
chip_id
)
&
0x01e0
)
<<
7
);
if
(
phy_mode
&
0x8000
)
if
(
phy_mode
&
0x8000
)
phy_mode
=
0x8000
;
phy_mode
=
0x8000
;
...
@@ -1414,7 +1414,7 @@ static u8 uli526x_sense_speed(struct uli526x_board_info * db)
...
@@ -1414,7 +1414,7 @@ static u8 uli526x_sense_speed(struct uli526x_board_info * db)
phy_mode
=
0x2000
;
phy_mode
=
0x2000
;
else
else
phy_mode
=
0x1000
;
phy_mode
=
0x1000
;
/* printk(DRV_NAME ": Phy_mode %x ",phy_mode); */
/* printk(DRV_NAME ": Phy_mode %x ",phy_mode); */
switch
(
phy_mode
)
{
switch
(
phy_mode
)
{
case
0x1000
:
db
->
op_mode
=
ULI526X_10MHF
;
break
;
case
0x1000
:
db
->
op_mode
=
ULI526X_10MHF
;
break
;
...
@@ -1442,7 +1442,7 @@ static u8 uli526x_sense_speed(struct uli526x_board_info * db)
...
@@ -1442,7 +1442,7 @@ static u8 uli526x_sense_speed(struct uli526x_board_info * db)
static
void
uli526x_set_phyxcer
(
struct
uli526x_board_info
*
db
)
static
void
uli526x_set_phyxcer
(
struct
uli526x_board_info
*
db
)
{
{
u16
phy_reg
;
u16
phy_reg
;
/* Phyxcer capability setting */
/* Phyxcer capability setting */
phy_reg
=
phy_read
(
db
->
ioaddr
,
db
->
phy_addr
,
4
,
db
->
chip_id
)
&
~
0x01e0
;
phy_reg
=
phy_read
(
db
->
ioaddr
,
db
->
phy_addr
,
4
,
db
->
chip_id
)
&
~
0x01e0
;
...
@@ -1457,7 +1457,7 @@ static void uli526x_set_phyxcer(struct uli526x_board_info *db)
...
@@ -1457,7 +1457,7 @@ static void uli526x_set_phyxcer(struct uli526x_board_info *db)
case
ULI526X_100MHF
:
phy_reg
|=
0x80
;
break
;
case
ULI526X_100MHF
:
phy_reg
|=
0x80
;
break
;
case
ULI526X_100MFD
:
phy_reg
|=
0x100
;
break
;
case
ULI526X_100MFD
:
phy_reg
|=
0x100
;
break
;
}
}
}
}
/* Write new capability to Phyxcer Reg4 */
/* Write new capability to Phyxcer Reg4 */
...
@@ -1556,7 +1556,7 @@ static void phy_write(unsigned long iobase, u8 phy_addr, u8 offset, u16 phy_data
...
@@ -1556,7 +1556,7 @@ static void phy_write(unsigned long iobase, u8 phy_addr, u8 offset, u16 phy_data
/* Write a word data to PHY controller */
/* Write a word data to PHY controller */
for
(
i
=
0x8000
;
i
>
0
;
i
>>=
1
)
for
(
i
=
0x8000
;
i
>
0
;
i
>>=
1
)
phy_write_1bit
(
ioaddr
,
phy_data
&
i
?
PHY_DATA_1
:
PHY_DATA_0
,
chip_id
);
phy_write_1bit
(
ioaddr
,
phy_data
&
i
?
PHY_DATA_1
:
PHY_DATA_0
,
chip_id
);
}
}
...
@@ -1574,7 +1574,7 @@ static u16 phy_read(unsigned long iobase, u8 phy_addr, u8 offset, u32 chip_id)
...
@@ -1574,7 +1574,7 @@ static u16 phy_read(unsigned long iobase, u8 phy_addr, u8 offset, u32 chip_id)
return
phy_readby_cr10
(
iobase
,
phy_addr
,
offset
);
return
phy_readby_cr10
(
iobase
,
phy_addr
,
offset
);
/* M5261/M5263 Chip */
/* M5261/M5263 Chip */
ioaddr
=
iobase
+
DCR9
;
ioaddr
=
iobase
+
DCR9
;
/* Send 33 synchronization clock to Phy controller */
/* Send 33 synchronization clock to Phy controller */
for
(
i
=
0
;
i
<
35
;
i
++
)
for
(
i
=
0
;
i
<
35
;
i
++
)
phy_write_1bit
(
ioaddr
,
PHY_DATA_1
,
chip_id
);
phy_write_1bit
(
ioaddr
,
PHY_DATA_1
,
chip_id
);
...
@@ -1610,7 +1610,7 @@ static u16 phy_read(unsigned long iobase, u8 phy_addr, u8 offset, u32 chip_id)
...
@@ -1610,7 +1610,7 @@ static u16 phy_read(unsigned long iobase, u8 phy_addr, u8 offset, u32 chip_id)
static
u16
phy_readby_cr10
(
unsigned
long
iobase
,
u8
phy_addr
,
u8
offset
)
static
u16
phy_readby_cr10
(
unsigned
long
iobase
,
u8
phy_addr
,
u8
offset
)
{
{
unsigned
long
ioaddr
,
cr10_value
;
unsigned
long
ioaddr
,
cr10_value
;
ioaddr
=
iobase
+
DCR10
;
ioaddr
=
iobase
+
DCR10
;
cr10_value
=
phy_addr
;
cr10_value
=
phy_addr
;
cr10_value
=
(
cr10_value
<<
5
)
+
offset
;
cr10_value
=
(
cr10_value
<<
5
)
+
offset
;
...
@@ -1629,7 +1629,7 @@ static u16 phy_readby_cr10(unsigned long iobase, u8 phy_addr, u8 offset)
...
@@ -1629,7 +1629,7 @@ static u16 phy_readby_cr10(unsigned long iobase, u8 phy_addr, u8 offset)
static
void
phy_writeby_cr10
(
unsigned
long
iobase
,
u8
phy_addr
,
u8
offset
,
u16
phy_data
)
static
void
phy_writeby_cr10
(
unsigned
long
iobase
,
u8
phy_addr
,
u8
offset
,
u16
phy_data
)
{
{
unsigned
long
ioaddr
,
cr10_value
;
unsigned
long
ioaddr
,
cr10_value
;
ioaddr
=
iobase
+
DCR10
;
ioaddr
=
iobase
+
DCR10
;
cr10_value
=
phy_addr
;
cr10_value
=
phy_addr
;
cr10_value
=
(
cr10_value
<<
5
)
+
offset
;
cr10_value
=
(
cr10_value
<<
5
)
+
offset
;
...
@@ -1659,7 +1659,7 @@ static void phy_write_1bit(unsigned long ioaddr, u32 phy_data, u32 chip_id)
...
@@ -1659,7 +1659,7 @@ static void phy_write_1bit(unsigned long ioaddr, u32 phy_data, u32 chip_id)
static
u16
phy_read_1bit
(
unsigned
long
ioaddr
,
u32
chip_id
)
static
u16
phy_read_1bit
(
unsigned
long
ioaddr
,
u32
chip_id
)
{
{
u16
phy_data
;
u16
phy_data
;
outl
(
0x50000
,
ioaddr
);
outl
(
0x50000
,
ioaddr
);
udelay
(
1
);
udelay
(
1
);
phy_data
=
(
inl
(
ioaddr
)
>>
19
)
&
0x1
;
phy_data
=
(
inl
(
ioaddr
)
>>
19
)
&
0x1
;
...
...
drivers/net/tulip/winbond-840.c
View file @
f3b197ac
...
@@ -38,12 +38,12 @@
...
@@ -38,12 +38,12 @@
Copyright (C) 2001 Manfred Spraul
Copyright (C) 2001 Manfred Spraul
* ethtool support (jgarzik)
* ethtool support (jgarzik)
* Replace some MII-related magic numbers with constants (jgarzik)
* Replace some MII-related magic numbers with constants (jgarzik)
TODO:
TODO:
* enable pci_power_off
* enable pci_power_off
* Wake-On-LAN
* Wake-On-LAN
*/
*/
#define DRV_NAME "winbond-840"
#define DRV_NAME "winbond-840"
#define DRV_VERSION "1.01-d"
#define DRV_VERSION "1.01-d"
#define DRV_RELDATE "Nov-17-2001"
#define DRV_RELDATE "Nov-17-2001"
...
@@ -57,7 +57,7 @@ c-help-name: Winbond W89c840 PCI Ethernet support
...
@@ -57,7 +57,7 @@ c-help-name: Winbond W89c840 PCI Ethernet support
c-help-symbol: CONFIG_WINBOND_840
c-help-symbol: CONFIG_WINBOND_840
c-help: This driver is for the Winbond W89c840 chip. It also works with
c-help: This driver is for the Winbond W89c840 chip. It also works with
c-help: the TX9882 chip on the Compex RL100-ATX board.
c-help: the TX9882 chip on the Compex RL100-ATX board.
c-help: More specific information and updates are available from
c-help: More specific information and updates are available from
c-help: http://www.scyld.com/network/drivers.html
c-help: http://www.scyld.com/network/drivers.html
*/
*/
...
@@ -207,7 +207,7 @@ Test with 'ping -s 10000' on a fast computer.
...
@@ -207,7 +207,7 @@ Test with 'ping -s 10000' on a fast computer.
*/
*/
/*
/*
PCI probe table.
PCI probe table.
...
@@ -374,7 +374,7 @@ static int netdev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
...
@@ -374,7 +374,7 @@ static int netdev_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
static
struct
ethtool_ops
netdev_ethtool_ops
;
static
struct
ethtool_ops
netdev_ethtool_ops
;
static
int
netdev_close
(
struct
net_device
*
dev
);
static
int
netdev_close
(
struct
net_device
*
dev
);
static
int
__devinit
w840_probe1
(
struct
pci_dev
*
pdev
,
static
int
__devinit
w840_probe1
(
struct
pci_dev
*
pdev
,
const
struct
pci_device_id
*
ent
)
const
struct
pci_device_id
*
ent
)
...
@@ -434,7 +434,7 @@ static int __devinit w840_probe1 (struct pci_dev *pdev,
...
@@ -434,7 +434,7 @@ static int __devinit w840_probe1 (struct pci_dev *pdev,
np
->
mii_if
.
mdio_read
=
mdio_read
;
np
->
mii_if
.
mdio_read
=
mdio_read
;
np
->
mii_if
.
mdio_write
=
mdio_write
;
np
->
mii_if
.
mdio_write
=
mdio_write
;
np
->
base_addr
=
ioaddr
;
np
->
base_addr
=
ioaddr
;
pci_set_drvdata
(
pdev
,
dev
);
pci_set_drvdata
(
pdev
,
dev
);
if
(
dev
->
mem_start
)
if
(
dev
->
mem_start
)
...
@@ -510,7 +510,7 @@ static int __devinit w840_probe1 (struct pci_dev *pdev,
...
@@ -510,7 +510,7 @@ static int __devinit w840_probe1 (struct pci_dev *pdev,
return
-
ENODEV
;
return
-
ENODEV
;
}
}
/* Read the EEPROM and MII Management Data I/O (MDIO) interfaces. These are
/* Read the EEPROM and MII Management Data I/O (MDIO) interfaces. These are
often serial bit streams generated by the host processor.
often serial bit streams generated by the host processor.
The example below is for the common 93c46 EEPROM, 64 16 bit words. */
The example below is for the common 93c46 EEPROM, 64 16 bit words. */
...
@@ -660,7 +660,7 @@ static void mdio_write(struct net_device *dev, int phy_id, int location, int val
...
@@ -660,7 +660,7 @@ static void mdio_write(struct net_device *dev, int phy_id, int location, int val
return
;
return
;
}
}
static
int
netdev_open
(
struct
net_device
*
dev
)
static
int
netdev_open
(
struct
net_device
*
dev
)
{
{
struct
netdev_private
*
np
=
netdev_priv
(
dev
);
struct
netdev_private
*
np
=
netdev_priv
(
dev
);
...
@@ -731,7 +731,7 @@ static int update_link(struct net_device *dev)
...
@@ -731,7 +731,7 @@ static int update_link(struct net_device *dev)
dev
->
name
,
np
->
phys
[
0
]);
dev
->
name
,
np
->
phys
[
0
]);
netif_carrier_on
(
dev
);
netif_carrier_on
(
dev
);
}
}
if
((
np
->
mii
&
~
0xf
)
==
MII_DAVICOM_DM9101
)
{
if
((
np
->
mii
&
~
0xf
)
==
MII_DAVICOM_DM9101
)
{
/* If the link partner doesn't support autonegotiation
/* If the link partner doesn't support autonegotiation
* the MII detects it's abilities with the "parallel detection".
* the MII detects it's abilities with the "parallel detection".
...
@@ -761,7 +761,7 @@ static int update_link(struct net_device *dev)
...
@@ -761,7 +761,7 @@ static int update_link(struct net_device *dev)
result
|=
0x20000000
;
result
|=
0x20000000
;
if
(
result
!=
np
->
csr6
&&
debug
)
if
(
result
!=
np
->
csr6
&&
debug
)
printk
(
KERN_INFO
"%s: Setting %dMBit-%s-duplex based on MII#%d
\n
"
,
printk
(
KERN_INFO
"%s: Setting %dMBit-%s-duplex based on MII#%d
\n
"
,
dev
->
name
,
fasteth
?
100
:
10
,
dev
->
name
,
fasteth
?
100
:
10
,
duplex
?
"full"
:
"half"
,
np
->
phys
[
0
]);
duplex
?
"full"
:
"half"
,
np
->
phys
[
0
]);
return
result
;
return
result
;
}
}
...
@@ -947,7 +947,7 @@ static void init_registers(struct net_device *dev)
...
@@ -947,7 +947,7 @@ static void init_registers(struct net_device *dev)
iowrite32
(
i
,
ioaddr
+
PCIBusCfg
);
iowrite32
(
i
,
ioaddr
+
PCIBusCfg
);
np
->
csr6
=
0
;
np
->
csr6
=
0
;
/* 128 byte Tx threshold;
/* 128 byte Tx threshold;
Transmit on; Receive on; */
Transmit on; Receive on; */
update_csr6
(
dev
,
0x00022002
|
update_link
(
dev
)
|
__set_rx_mode
(
dev
));
update_csr6
(
dev
,
0x00022002
|
update_link
(
dev
)
|
__set_rx_mode
(
dev
));
...
@@ -1584,7 +1584,7 @@ static int netdev_close(struct net_device *dev)
...
@@ -1584,7 +1584,7 @@ static int netdev_close(struct net_device *dev)
static
void
__devexit
w840_remove1
(
struct
pci_dev
*
pdev
)
static
void
__devexit
w840_remove1
(
struct
pci_dev
*
pdev
)
{
{
struct
net_device
*
dev
=
pci_get_drvdata
(
pdev
);
struct
net_device
*
dev
=
pci_get_drvdata
(
pdev
);
if
(
dev
)
{
if
(
dev
)
{
struct
netdev_private
*
np
=
netdev_priv
(
dev
);
struct
netdev_private
*
np
=
netdev_priv
(
dev
);
unregister_netdev
(
dev
);
unregister_netdev
(
dev
);
...
@@ -1640,7 +1640,7 @@ static int w840_suspend (struct pci_dev *pdev, pm_message_t state)
...
@@ -1640,7 +1640,7 @@ static int w840_suspend (struct pci_dev *pdev, pm_message_t state)
spin_unlock_wait
(
&
dev
->
xmit_lock
);
spin_unlock_wait
(
&
dev
->
xmit_lock
);
synchronize_irq
(
dev
->
irq
);
synchronize_irq
(
dev
->
irq
);
np
->
stats
.
rx_missed_errors
+=
ioread32
(
ioaddr
+
RxMissed
)
&
0xffff
;
np
->
stats
.
rx_missed_errors
+=
ioread32
(
ioaddr
+
RxMissed
)
&
0xffff
;
/* no more hardware accesses behind this line. */
/* no more hardware accesses behind this line. */
...
...
drivers/net/tulip/xircom_cb.c
View file @
f3b197ac
This diff is collapsed.
Click to expand it.
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