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
90babff0
Commit
90babff0
authored
Oct 24, 2004
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Plain Diff
Merge pobox.com:/garz/repo/netdev-2.6/e100
into pobox.com:/garz/repo/net-drivers-2.6
parents
80aca3e6
7e71c95d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
30 additions
and
21 deletions
+30
-21
drivers/net/e100.c
drivers/net/e100.c
+30
-21
No files found.
drivers/net/e100.c
View file @
90babff0
...
@@ -154,8 +154,8 @@
...
@@ -154,8 +154,8 @@
#define DRV_NAME "e100"
#define DRV_NAME "e100"
#define DRV_EXT
"-NAPI"
#define DRV_EXT "-NAPI"
#define DRV_VERSION "3.
0.27
-k2"DRV_EXT
#define DRV_VERSION "3.
2.3
-k2"DRV_EXT
#define DRV_DESCRIPTION "Intel(R) PRO/100 Network Driver"
#define DRV_DESCRIPTION "Intel(R) PRO/100 Network Driver"
#define DRV_COPYRIGHT "Copyright(c) 1999-2004 Intel Corporation"
#define DRV_COPYRIGHT "Copyright(c) 1999-2004 Intel Corporation"
#define PFX DRV_NAME ": "
#define PFX DRV_NAME ": "
...
@@ -574,13 +574,21 @@ static inline void e100_write_flush(struct nic *nic)
...
@@ -574,13 +574,21 @@ static inline void e100_write_flush(struct nic *nic)
static
inline
void
e100_enable_irq
(
struct
nic
*
nic
)
static
inline
void
e100_enable_irq
(
struct
nic
*
nic
)
{
{
unsigned
long
flags
;
spin_lock_irqsave
(
&
nic
->
cmd_lock
,
flags
);
writeb
(
irq_mask_none
,
&
nic
->
csr
->
scb
.
cmd_hi
);
writeb
(
irq_mask_none
,
&
nic
->
csr
->
scb
.
cmd_hi
);
spin_unlock_irqrestore
(
&
nic
->
cmd_lock
,
flags
);
e100_write_flush
(
nic
);
e100_write_flush
(
nic
);
}
}
static
inline
void
e100_disable_irq
(
struct
nic
*
nic
)
static
inline
void
e100_disable_irq
(
struct
nic
*
nic
)
{
{
unsigned
long
flags
;
spin_lock_irqsave
(
&
nic
->
cmd_lock
,
flags
);
writeb
(
irq_mask_all
,
&
nic
->
csr
->
scb
.
cmd_hi
);
writeb
(
irq_mask_all
,
&
nic
->
csr
->
scb
.
cmd_hi
);
spin_unlock_irqrestore
(
&
nic
->
cmd_lock
,
flags
);
e100_write_flush
(
nic
);
e100_write_flush
(
nic
);
}
}
...
@@ -595,16 +603,6 @@ static void e100_hw_reset(struct nic *nic)
...
@@ -595,16 +603,6 @@ static void e100_hw_reset(struct nic *nic)
writel
(
software_reset
,
&
nic
->
csr
->
port
);
writel
(
software_reset
,
&
nic
->
csr
->
port
);
e100_write_flush
(
nic
);
udelay
(
20
);
e100_write_flush
(
nic
);
udelay
(
20
);
/* TCO workaround - 82559 and greater */
if
(
nic
->
mac
>=
mac_82559_D101M
)
{
/* Issue a redundant CU load base without setting
* general pointer, and without waiting for scb to
* clear. This gets us into post-driver. Finally,
* wait 20 msec for reset to take effect. */
writeb
(
cuc_load_base
,
&
nic
->
csr
->
scb
.
cmd_lo
);
mdelay
(
20
);
}
/* Mask off our interrupt line - it's unmasked after reset */
/* Mask off our interrupt line - it's unmasked after reset */
e100_disable_irq
(
nic
);
e100_disable_irq
(
nic
);
}
}
...
@@ -1253,8 +1251,13 @@ static void e100_watchdog(unsigned long data)
...
@@ -1253,8 +1251,13 @@ static void e100_watchdog(unsigned long data)
mii_check_link
(
&
nic
->
mii
);
mii_check_link
(
&
nic
->
mii
);
/* Software generated interrupt to recover from (rare) Rx
/* Software generated interrupt to recover from (rare) Rx
* allocation failure */
* allocation failure.
writeb
(
irq_sw_gen
,
&
nic
->
csr
->
scb
.
cmd_hi
);
* Unfortunately have to use a spinlock to not re-enable interrupts
* accidentally, due to hardware that shares a register between the
* interrupt mask bit and the SW Interrupt generation bit */
spin_lock_irq
(
&
nic
->
cmd_lock
);
writeb
(
readb
(
&
nic
->
csr
->
scb
.
cmd_hi
)
|
irq_sw_gen
,
&
nic
->
csr
->
scb
.
cmd_hi
);
spin_unlock_irq
(
&
nic
->
cmd_lock
);
e100_write_flush
(
nic
);
e100_write_flush
(
nic
);
e100_update_stats
(
nic
);
e100_update_stats
(
nic
);
...
@@ -1304,6 +1307,7 @@ static int e100_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
...
@@ -1304,6 +1307,7 @@ static int e100_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
switch
(
err
)
{
switch
(
err
)
{
case
-
ENOSPC
:
case
-
ENOSPC
:
/* We queued the skb, but now we're out of space. */
/* We queued the skb, but now we're out of space. */
DPRINTK
(
TX_ERR
,
DEBUG
,
"No space for CB
\n
"
);
netif_stop_queue
(
netdev
);
netif_stop_queue
(
netdev
);
break
;
break
;
case
-
ENOMEM
:
case
-
ENOMEM
:
...
@@ -1424,14 +1428,12 @@ static inline void e100_start_receiver(struct nic *nic)
...
@@ -1424,14 +1428,12 @@ static inline void e100_start_receiver(struct nic *nic)
#define RFD_BUF_LEN (sizeof(struct rfd) + VLAN_ETH_FRAME_LEN)
#define RFD_BUF_LEN (sizeof(struct rfd) + VLAN_ETH_FRAME_LEN)
static
inline
int
e100_rx_alloc_skb
(
struct
nic
*
nic
,
struct
rx
*
rx
)
static
inline
int
e100_rx_alloc_skb
(
struct
nic
*
nic
,
struct
rx
*
rx
)
{
{
unsigned
int
rx_offset
=
2
;
/* u32 align protocol headers */
if
(
!
(
rx
->
skb
=
dev_alloc_skb
(
RFD_BUF_LEN
+
NET_IP_ALIGN
)))
if
(
!
(
rx
->
skb
=
dev_alloc_skb
(
RFD_BUF_LEN
+
rx_offset
)))
return
-
ENOMEM
;
return
-
ENOMEM
;
/* Align, init, and map the RFD. */
/* Align, init, and map the RFD. */
rx
->
skb
->
dev
=
nic
->
netdev
;
rx
->
skb
->
dev
=
nic
->
netdev
;
skb_reserve
(
rx
->
skb
,
rx_offset
);
skb_reserve
(
rx
->
skb
,
NET_IP_ALIGN
);
memcpy
(
rx
->
skb
->
data
,
&
nic
->
blank_rfd
,
sizeof
(
struct
rfd
));
memcpy
(
rx
->
skb
->
data
,
&
nic
->
blank_rfd
,
sizeof
(
struct
rfd
));
rx
->
dma_addr
=
pci_map_single
(
nic
->
pdev
,
rx
->
skb
->
data
,
rx
->
dma_addr
=
pci_map_single
(
nic
->
pdev
,
rx
->
skb
->
data
,
RFD_BUF_LEN
,
PCI_DMA_BIDIRECTIONAL
);
RFD_BUF_LEN
,
PCI_DMA_BIDIRECTIONAL
);
...
@@ -1470,7 +1472,7 @@ static inline int e100_rx_indicate(struct nic *nic, struct rx *rx,
...
@@ -1470,7 +1472,7 @@ static inline int e100_rx_indicate(struct nic *nic, struct rx *rx,
/* If data isn't ready, nothing to indicate */
/* If data isn't ready, nothing to indicate */
if
(
unlikely
(
!
(
rfd_status
&
cb_complete
)))
if
(
unlikely
(
!
(
rfd_status
&
cb_complete
)))
return
-
EAGAIN
;
return
-
EAGAIN
;
/* Get actual data size */
/* Get actual data size */
actual_size
=
le16_to_cpu
(
rfd
->
actual_size
)
&
0x3FFF
;
actual_size
=
le16_to_cpu
(
rfd
->
actual_size
)
&
0x3FFF
;
...
@@ -1762,7 +1764,7 @@ static int e100_loopback_test(struct nic *nic, enum loopback loopback_mode)
...
@@ -1762,7 +1764,7 @@ static int e100_loopback_test(struct nic *nic, enum loopback loopback_mode)
if
(
memcmp
(
nic
->
rx_to_clean
->
skb
->
data
+
sizeof
(
struct
rfd
),
if
(
memcmp
(
nic
->
rx_to_clean
->
skb
->
data
+
sizeof
(
struct
rfd
),
skb
->
data
,
ETH_DATA_LEN
))
skb
->
data
,
ETH_DATA_LEN
))
err
=
-
EAGAIN
;
err
=
-
EAGAIN
;
err_loopback_none:
err_loopback_none:
mdio_write
(
nic
->
netdev
,
nic
->
mii
.
phy_id
,
MII_BMCR
,
0
);
mdio_write
(
nic
->
netdev
,
nic
->
mii
.
phy_id
,
MII_BMCR
,
0
);
...
@@ -1955,12 +1957,17 @@ static int e100_set_ringparam(struct net_device *netdev,
...
@@ -1955,12 +1957,17 @@ static int e100_set_ringparam(struct net_device *netdev,
struct
param_range
*
rfds
=
&
nic
->
params
.
rfds
;
struct
param_range
*
rfds
=
&
nic
->
params
.
rfds
;
struct
param_range
*
cbs
=
&
nic
->
params
.
cbs
;
struct
param_range
*
cbs
=
&
nic
->
params
.
cbs
;
if
((
ring
->
rx_mini_pending
)
||
(
ring
->
rx_jumbo_pending
))
return
-
EINVAL
;
if
(
netif_running
(
netdev
))
if
(
netif_running
(
netdev
))
e100_down
(
nic
);
e100_down
(
nic
);
rfds
->
count
=
max
(
ring
->
rx_pending
,
rfds
->
min
);
rfds
->
count
=
max
(
ring
->
rx_pending
,
rfds
->
min
);
rfds
->
count
=
min
(
rfds
->
count
,
rfds
->
max
);
rfds
->
count
=
min
(
rfds
->
count
,
rfds
->
max
);
cbs
->
count
=
max
(
ring
->
tx_pending
,
cbs
->
min
);
cbs
->
count
=
max
(
ring
->
tx_pending
,
cbs
->
min
);
cbs
->
count
=
min
(
cbs
->
count
,
cbs
->
max
);
cbs
->
count
=
min
(
cbs
->
count
,
cbs
->
max
);
DPRINTK
(
DRV
,
INFO
,
"Ring Param settings: rx: %d, tx %d
\n
"
,
rfds
->
count
,
cbs
->
count
);
if
(
netif_running
(
netdev
))
if
(
netif_running
(
netdev
))
e100_up
(
nic
);
e100_up
(
nic
);
...
@@ -2172,6 +2179,7 @@ static int __devinit e100_probe(struct pci_dev *pdev,
...
@@ -2172,6 +2179,7 @@ static int __devinit e100_probe(struct pci_dev *pdev,
#ifdef CONFIG_NET_POLL_CONTROLLER
#ifdef CONFIG_NET_POLL_CONTROLLER
netdev
->
poll_controller
=
e100_netpoll
;
netdev
->
poll_controller
=
e100_netpoll
;
#endif
#endif
strcpy
(
netdev
->
name
,
pci_name
(
pdev
));
nic
=
netdev_priv
(
netdev
);
nic
=
netdev_priv
(
netdev
);
nic
->
netdev
=
netdev
;
nic
->
netdev
=
netdev
;
...
@@ -2255,6 +2263,7 @@ static int __devinit e100_probe(struct pci_dev *pdev,
...
@@ -2255,6 +2263,7 @@ static int __devinit e100_probe(struct pci_dev *pdev,
pci_enable_wake
(
pdev
,
0
,
nic
->
flags
&
(
wol_magic
|
e100_asf
(
nic
)));
pci_enable_wake
(
pdev
,
0
,
nic
->
flags
&
(
wol_magic
|
e100_asf
(
nic
)));
strcpy
(
netdev
->
name
,
"eth%d"
);
if
((
err
=
register_netdev
(
netdev
)))
{
if
((
err
=
register_netdev
(
netdev
)))
{
DPRINTK
(
PROBE
,
ERR
,
"Cannot register net device, aborting.
\n
"
);
DPRINTK
(
PROBE
,
ERR
,
"Cannot register net device, aborting.
\n
"
);
goto
err_out_free
;
goto
err_out_free
;
...
@@ -2351,7 +2360,7 @@ static int __init e100_init_module(void)
...
@@ -2351,7 +2360,7 @@ static int __init e100_init_module(void)
printk
(
KERN_INFO
PFX
"%s, %s
\n
"
,
DRV_DESCRIPTION
,
DRV_VERSION
);
printk
(
KERN_INFO
PFX
"%s, %s
\n
"
,
DRV_DESCRIPTION
,
DRV_VERSION
);
printk
(
KERN_INFO
PFX
"%s
\n
"
,
DRV_COPYRIGHT
);
printk
(
KERN_INFO
PFX
"%s
\n
"
,
DRV_COPYRIGHT
);
}
}
return
pci_module_init
(
&
e100_driver
);
return
pci_module_init
(
&
e100_driver
);
}
}
static
void
__exit
e100_cleanup_module
(
void
)
static
void
__exit
e100_cleanup_module
(
void
)
...
...
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