Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
1a950599
Commit
1a950599
authored
Jun 04, 2005
by
Committed by
Jeff Garzik
Jun 04, 2005
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of /spare/repo/netdev-2.6 branch smc91x
parents
bdb7a342
ea937560
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
37 additions
and
36 deletions
+37
-36
drivers/net/smc91x.c
drivers/net/smc91x.c
+33
-25
drivers/net/smc91x.h
drivers/net/smc91x.h
+4
-11
No files found.
drivers/net/smc91x.c
View file @
1a950599
...
@@ -129,7 +129,7 @@ MODULE_PARM_DESC(nowait, "set to 1 for no wait state");
...
@@ -129,7 +129,7 @@ MODULE_PARM_DESC(nowait, "set to 1 for no wait state");
/*
/*
* Transmit timeout, default 5 seconds.
* Transmit timeout, default 5 seconds.
*/
*/
static
int
watchdog
=
5
000
;
static
int
watchdog
=
1
000
;
module_param
(
watchdog
,
int
,
0400
);
module_param
(
watchdog
,
int
,
0400
);
MODULE_PARM_DESC
(
watchdog
,
"transmit timeout in milliseconds"
);
MODULE_PARM_DESC
(
watchdog
,
"transmit timeout in milliseconds"
);
...
@@ -660,15 +660,14 @@ static void smc_hardware_send_pkt(unsigned long data)
...
@@ -660,15 +660,14 @@ static void smc_hardware_send_pkt(unsigned long data)
SMC_outw
(((
len
&
1
)
?
(
0x2000
|
buf
[
len
-
1
])
:
0
),
ioaddr
,
DATA_REG
);
SMC_outw
(((
len
&
1
)
?
(
0x2000
|
buf
[
len
-
1
])
:
0
),
ioaddr
,
DATA_REG
);
/*
/*
* If THROTTLE_TX_PKTS is set, we look at the TX_EMPTY flag
* If THROTTLE_TX_PKTS is set, we stop the queue here. This will
* before queueing this packet for TX, and if it's clear then
* have the effect of having at most one packet queued for TX
* we stop the queue here. This will have the effect of
* in the chip's memory at all time.
* having at most 2 packets queued for TX in the chip's memory
*
* at all time. If THROTTLE_TX_PKTS is not set then the queue
* If THROTTLE_TX_PKTS is not set then the queue is stopped only
* is stopped only when memory allocation (MC_ALLOC) does not
* when memory allocation (MC_ALLOC) does not succeed right away.
* succeed right away.
*/
*/
if
(
THROTTLE_TX_PKTS
)
if
(
THROTTLE_TX_PKTS
&&
!
(
SMC_GET_INT
()
&
IM_TX_EMPTY_INT
))
netif_stop_queue
(
dev
);
netif_stop_queue
(
dev
);
/* queue the packet for TX */
/* queue the packet for TX */
...
@@ -792,17 +791,20 @@ static void smc_tx(struct net_device *dev)
...
@@ -792,17 +791,20 @@ static void smc_tx(struct net_device *dev)
DBG
(
2
,
"%s: TX STATUS 0x%04x PNR 0x%02x
\n
"
,
DBG
(
2
,
"%s: TX STATUS 0x%04x PNR 0x%02x
\n
"
,
dev
->
name
,
tx_status
,
packet_no
);
dev
->
name
,
tx_status
,
packet_no
);
if
(
!
(
tx_status
&
TS_SUCCESS
))
if
(
!
(
tx_status
&
ES_TX_SUC
))
lp
->
stats
.
tx_errors
++
;
lp
->
stats
.
tx_errors
++
;
if
(
tx_status
&
TS_LOSTCAR
)
if
(
tx_status
&
ES_LOSTCARR
)
lp
->
stats
.
tx_carrier_errors
++
;
lp
->
stats
.
tx_carrier_errors
++
;
if
(
tx_status
&
TS_LATCOL
)
{
if
(
tx_status
&
(
ES_LATCOL
|
ES_16COL
))
{
PRINTK
(
"%s: late collision occurred on last xmit
\n
"
,
dev
->
name
);
PRINTK
(
"%s: %s occurred on last xmit
\n
"
,
dev
->
name
,
(
tx_status
&
ES_LATCOL
)
?
"late collision"
:
"too many collisions"
);
lp
->
stats
.
tx_window_errors
++
;
lp
->
stats
.
tx_window_errors
++
;
if
(
!
(
lp
->
stats
.
tx_window_errors
&
63
)
&&
net_ratelimit
())
{
if
(
!
(
lp
->
stats
.
tx_window_errors
&
63
)
&&
net_ratelimit
())
{
printk
(
KERN_INFO
"%s: unexpectedly large number
s
of "
printk
(
KERN_INFO
"%s: unexpectedly large number of "
"
late
collisions. Please check duplex "
"
bad
collisions. Please check duplex "
"setting.
\n
"
,
dev
->
name
);
"setting.
\n
"
,
dev
->
name
);
}
}
}
}
...
@@ -1236,7 +1238,7 @@ static void smc_10bt_check_media(struct net_device *dev, int init)
...
@@ -1236,7 +1238,7 @@ static void smc_10bt_check_media(struct net_device *dev, int init)
old_carrier
=
netif_carrier_ok
(
dev
)
?
1
:
0
;
old_carrier
=
netif_carrier_ok
(
dev
)
?
1
:
0
;
SMC_SELECT_BANK
(
0
);
SMC_SELECT_BANK
(
0
);
new_carrier
=
SMC_inw
(
ioaddr
,
EPH_STATUS_REG
)
&
ES_LINK_OK
?
1
:
0
;
new_carrier
=
(
SMC_GET_EPH_STATUS
()
&
ES_LINK_OK
)
?
1
:
0
;
SMC_SELECT_BANK
(
2
);
SMC_SELECT_BANK
(
2
);
if
(
init
||
(
old_carrier
!=
new_carrier
))
{
if
(
init
||
(
old_carrier
!=
new_carrier
))
{
...
@@ -1308,15 +1310,16 @@ static irqreturn_t smc_interrupt(int irq, void *dev_id, struct pt_regs *regs)
...
@@ -1308,15 +1310,16 @@ static irqreturn_t smc_interrupt(int irq, void *dev_id, struct pt_regs *regs)
if
(
!
status
)
if
(
!
status
)
break
;
break
;
if
(
status
&
IM_RCV_INT
)
{
if
(
status
&
IM_TX_INT
)
{
DBG
(
3
,
"%s: RX irq
\n
"
,
dev
->
name
);
/* do this before RX as it will free memory quickly */
smc_rcv
(
dev
);
}
else
if
(
status
&
IM_TX_INT
)
{
DBG
(
3
,
"%s: TX int
\n
"
,
dev
->
name
);
DBG
(
3
,
"%s: TX int
\n
"
,
dev
->
name
);
smc_tx
(
dev
);
smc_tx
(
dev
);
SMC_ACK_INT
(
IM_TX_INT
);
SMC_ACK_INT
(
IM_TX_INT
);
if
(
THROTTLE_TX_PKTS
)
if
(
THROTTLE_TX_PKTS
)
netif_wake_queue
(
dev
);
netif_wake_queue
(
dev
);
}
else
if
(
status
&
IM_RCV_INT
)
{
DBG
(
3
,
"%s: RX irq
\n
"
,
dev
->
name
);
smc_rcv
(
dev
);
}
else
if
(
status
&
IM_ALLOC_INT
)
{
}
else
if
(
status
&
IM_ALLOC_INT
)
{
DBG
(
3
,
"%s: Allocation irq
\n
"
,
dev
->
name
);
DBG
(
3
,
"%s: Allocation irq
\n
"
,
dev
->
name
);
tasklet_hi_schedule
(
&
lp
->
tx_task
);
tasklet_hi_schedule
(
&
lp
->
tx_task
);
...
@@ -1337,7 +1340,10 @@ static irqreturn_t smc_interrupt(int irq, void *dev_id, struct pt_regs *regs)
...
@@ -1337,7 +1340,10 @@ static irqreturn_t smc_interrupt(int irq, void *dev_id, struct pt_regs *regs)
/* multiple collisions */
/* multiple collisions */
lp
->
stats
.
collisions
+=
card_stats
&
0xF
;
lp
->
stats
.
collisions
+=
card_stats
&
0xF
;
}
else
if
(
status
&
IM_RX_OVRN_INT
)
{
}
else
if
(
status
&
IM_RX_OVRN_INT
)
{
DBG
(
1
,
"%s: RX overrun
\n
"
,
dev
->
name
);
DBG
(
1
,
"%s: RX overrun (EPH_ST 0x%04x)
\n
"
,
dev
->
name
,
({
int
eph_st
;
SMC_SELECT_BANK
(
0
);
eph_st
=
SMC_GET_EPH_STATUS
();
SMC_SELECT_BANK
(
2
);
eph_st
;
})
);
SMC_ACK_INT
(
IM_RX_OVRN_INT
);
SMC_ACK_INT
(
IM_RX_OVRN_INT
);
lp
->
stats
.
rx_errors
++
;
lp
->
stats
.
rx_errors
++
;
lp
->
stats
.
rx_fifo_errors
++
;
lp
->
stats
.
rx_fifo_errors
++
;
...
@@ -1389,7 +1395,7 @@ static void smc_timeout(struct net_device *dev)
...
@@ -1389,7 +1395,7 @@ static void smc_timeout(struct net_device *dev)
{
{
struct
smc_local
*
lp
=
netdev_priv
(
dev
);
struct
smc_local
*
lp
=
netdev_priv
(
dev
);
void
__iomem
*
ioaddr
=
lp
->
base
;
void
__iomem
*
ioaddr
=
lp
->
base
;
int
status
,
mask
,
meminfo
,
fifo
;
int
status
,
mask
,
eph_st
,
meminfo
,
fifo
;
DBG
(
2
,
"%s: %s
\n
"
,
dev
->
name
,
__FUNCTION__
);
DBG
(
2
,
"%s: %s
\n
"
,
dev
->
name
,
__FUNCTION__
);
...
@@ -1398,11 +1404,13 @@ static void smc_timeout(struct net_device *dev)
...
@@ -1398,11 +1404,13 @@ static void smc_timeout(struct net_device *dev)
mask
=
SMC_GET_INT_MASK
();
mask
=
SMC_GET_INT_MASK
();
fifo
=
SMC_GET_FIFO
();
fifo
=
SMC_GET_FIFO
();
SMC_SELECT_BANK
(
0
);
SMC_SELECT_BANK
(
0
);
eph_st
=
SMC_GET_EPH_STATUS
();
meminfo
=
SMC_GET_MIR
();
meminfo
=
SMC_GET_MIR
();
SMC_SELECT_BANK
(
2
);
SMC_SELECT_BANK
(
2
);
spin_unlock_irq
(
&
lp
->
lock
);
spin_unlock_irq
(
&
lp
->
lock
);
PRINTK
(
"%s: INT 0x%02x MASK 0x%02x MEM 0x%04x FIFO 0x%04x
\n
"
,
PRINTK
(
"%s: TX timeout (INT 0x%02x INTMASK 0x%02x "
dev
->
name
,
status
,
mask
,
meminfo
,
fifo
);
"MEM 0x%04x FIFO 0x%04x EPH_ST 0x%04x)
\n
"
,
dev
->
name
,
status
,
mask
,
meminfo
,
fifo
,
eph_st
);
smc_reset
(
dev
);
smc_reset
(
dev
);
smc_enable
(
dev
);
smc_enable
(
dev
);
...
@@ -1863,7 +1871,7 @@ static int __init smc_probe(struct net_device *dev, void __iomem *ioaddr)
...
@@ -1863,7 +1871,7 @@ static int __init smc_probe(struct net_device *dev, void __iomem *ioaddr)
SMC_SELECT_BANK
(
1
);
SMC_SELECT_BANK
(
1
);
val
=
SMC_GET_BASE
();
val
=
SMC_GET_BASE
();
val
=
((
val
&
0x1F00
)
>>
3
)
<<
SMC_IO_SHIFT
;
val
=
((
val
&
0x1F00
)
>>
3
)
<<
SMC_IO_SHIFT
;
if
(((
unsigned
long
)
ioaddr
&
((
PAGE_SIZE
-
1
)
<<
SMC_IO_SHIFT
))
!=
val
)
{
/*XXX: WTF? */
if
(((
unsigned
int
)
ioaddr
&
(
0x3e0
<<
SMC_IO_SHIFT
))
!=
val
)
{
printk
(
"%s: IOADDR %p doesn't match configuration (%x).
\n
"
,
printk
(
"%s: IOADDR %p doesn't match configuration (%x).
\n
"
,
CARDNAME
,
ioaddr
,
val
);
CARDNAME
,
ioaddr
,
val
);
}
}
...
...
drivers/net/smc91x.h
View file @
1a950599
...
@@ -151,7 +151,7 @@
...
@@ -151,7 +151,7 @@
/* We actually can't write halfwords properly if not word aligned */
/* We actually can't write halfwords properly if not word aligned */
static
inline
void
static
inline
void
SMC_outw
(
u16
val
,
unsigned
long
ioaddr
,
int
reg
)
SMC_outw
(
u16
val
,
void
__iomem
*
ioaddr
,
int
reg
)
{
{
if
(
reg
&
2
)
{
if
(
reg
&
2
)
{
unsigned
int
v
=
val
<<
16
;
unsigned
int
v
=
val
<<
16
;
...
@@ -317,7 +317,7 @@ static inline void SMC_outsw (unsigned long a, int r, unsigned char* p, int l)
...
@@ -317,7 +317,7 @@ static inline void SMC_outsw (unsigned long a, int r, unsigned char* p, int l)
#define SMC_insl(a, r, p, l) \
#define SMC_insl(a, r, p, l) \
smc_pxa_dma_insl(a, lp->physaddr, r, dev->dma, p, l)
smc_pxa_dma_insl(a, lp->physaddr, r, dev->dma, p, l)
static
inline
void
static
inline
void
smc_pxa_dma_insl
(
u_long
ioaddr
,
u_long
physaddr
,
int
reg
,
int
dma
,
smc_pxa_dma_insl
(
void
__iomem
*
ioaddr
,
u_long
physaddr
,
int
reg
,
int
dma
,
u_char
*
buf
,
int
len
)
u_char
*
buf
,
int
len
)
{
{
dma_addr_t
dmabuf
;
dma_addr_t
dmabuf
;
...
@@ -355,7 +355,7 @@ smc_pxa_dma_insl(u_long ioaddr, u_long physaddr, int reg, int dma,
...
@@ -355,7 +355,7 @@ smc_pxa_dma_insl(u_long ioaddr, u_long physaddr, int reg, int dma,
#define SMC_insw(a, r, p, l) \
#define SMC_insw(a, r, p, l) \
smc_pxa_dma_insw(a, lp->physaddr, r, dev->dma, p, l)
smc_pxa_dma_insw(a, lp->physaddr, r, dev->dma, p, l)
static
inline
void
static
inline
void
smc_pxa_dma_insw
(
u_long
ioaddr
,
u_long
physaddr
,
int
reg
,
int
dma
,
smc_pxa_dma_insw
(
void
__iomem
*
ioaddr
,
u_long
physaddr
,
int
reg
,
int
dma
,
u_char
*
buf
,
int
len
)
u_char
*
buf
,
int
len
)
{
{
dma_addr_t
dmabuf
;
dma_addr_t
dmabuf
;
...
@@ -680,14 +680,6 @@ static const char * chip_ids[ 16 ] = {
...
@@ -680,14 +680,6 @@ static const char * chip_ids[ 16 ] = {
NULL
,
NULL
,
NULL
};
NULL
,
NULL
,
NULL
};
/*
. Transmit status bits
*/
#define TS_SUCCESS 0x0001
#define TS_LOSTCAR 0x0400
#define TS_LATCOL 0x0200
#define TS_16COL 0x0010
/*
/*
. Receive status bits
. Receive status bits
*/
*/
...
@@ -845,6 +837,7 @@ static const char * chip_ids[ 16 ] = {
...
@@ -845,6 +837,7 @@ static const char * chip_ids[ 16 ] = {
#define SMC_GET_FIFO() SMC_inw( ioaddr, FIFO_REG )
#define SMC_GET_FIFO() SMC_inw( ioaddr, FIFO_REG )
#define SMC_GET_PTR() SMC_inw( ioaddr, PTR_REG )
#define SMC_GET_PTR() SMC_inw( ioaddr, PTR_REG )
#define SMC_SET_PTR(x) SMC_outw( x, ioaddr, PTR_REG )
#define SMC_SET_PTR(x) SMC_outw( x, ioaddr, PTR_REG )
#define SMC_GET_EPH_STATUS() SMC_inw( ioaddr, EPH_STATUS_REG )
#define SMC_GET_RCR() SMC_inw( ioaddr, RCR_REG )
#define SMC_GET_RCR() SMC_inw( ioaddr, RCR_REG )
#define SMC_SET_RCR(x) SMC_outw( x, ioaddr, RCR_REG )
#define SMC_SET_RCR(x) SMC_outw( x, ioaddr, RCR_REG )
#define SMC_GET_REV() SMC_inw( ioaddr, REV_REG )
#define SMC_GET_REV() SMC_inw( ioaddr, REV_REG )
...
...
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