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
b24fa762
Commit
b24fa762
authored
Oct 10, 2002
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support multiple cards in ewrk3 net driver
(contributed by Adam Kropelin)
parent
141f8870
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
62 additions
and
25 deletions
+62
-25
Documentation/networking/ewrk3.txt
Documentation/networking/ewrk3.txt
+1
-0
drivers/net/ewrk3.c
drivers/net/ewrk3.c
+61
-25
No files found.
Documentation/networking/ewrk3.txt
View file @
b24fa762
...
@@ -24,6 +24,7 @@ sequences). To utilise this ability, you have to do 8 things:
...
@@ -24,6 +24,7 @@ sequences). To utilise this ability, you have to do 8 things:
kernel with the ewrk3 configuration turned off and reboot.
kernel with the ewrk3 configuration turned off and reboot.
5) insmod ewrk3.o
5) insmod ewrk3.o
[Alan Cox: Changed this so you can insmod ewrk3.o irq=x io=y]
[Alan Cox: Changed this so you can insmod ewrk3.o irq=x io=y]
[Adam Kropelin: Multiple cards now supported by irq=x1,x2 io=y1,y2]
6) run the net startup bits for your new eth?? interface manually
6) run the net startup bits for your new eth?? interface manually
(usually /etc/rc.inet[12] at boot time).
(usually /etc/rc.inet[12] at boot time).
7) enjoy!
7) enjoy!
...
...
drivers/net/ewrk3.c
View file @
b24fa762
...
@@ -76,6 +76,7 @@
...
@@ -76,6 +76,7 @@
kernel with the ewrk3 configuration turned off and reboot.
kernel with the ewrk3 configuration turned off and reboot.
5) insmod ewrk3.o
5) insmod ewrk3.o
[Alan Cox: Changed this so you can insmod ewrk3.o irq=x io=y]
[Alan Cox: Changed this so you can insmod ewrk3.o irq=x io=y]
[Adam Kropelin: now accepts irq=x1,x2 io=y1,y2 for multiple cards]
6) run the net startup bits for your new eth?? interface manually
6) run the net startup bits for your new eth?? interface manually
(usually /etc/rc.inet[12] at boot time).
(usually /etc/rc.inet[12] at boot time).
7) enjoy!
7) enjoy!
...
@@ -130,10 +131,12 @@
...
@@ -130,10 +131,12 @@
Add new multicasting code.
Add new multicasting code.
0.41 20-Jan-96 Fix IRQ set up problem reported by
0.41 20-Jan-96 Fix IRQ set up problem reported by
<kenneth@bbs.sas.ntu.ac.sg>.
<kenneth@bbs.sas.ntu.ac.sg>.
0.42 22-Apr-96 Fix alloc_device() bug <jari@markkus2.fimr.fi>
0.42 22-Apr-96 Fix alloc_device() bug <jari@markkus2.fimr.fi>
0.43 16-Aug-96 Update alloc_device() to conform to de4x5.c
0.43 16-Aug-96 Update alloc_device() to conform to de4x5.c
0.44 08-Nov-01 use library crc32 functions <Matt_Domsch@dell.com>
0.44 08-Nov-01 use library crc32 functions <Matt_Domsch@dell.com>
0.45 19-Jul-02 fix unaligned access on alpha <martin@bruli.net>
0.45 19-Jul-02 fix unaligned access on alpha <martin@bruli.net>
0.46 10-Oct-02 cli/sti removal <VDA@port.imtp.ilyichevsk.odessa.ua>
Multiple NIC support when module <akropel1@rochester.rr.com>
=========================================================================
=========================================================================
*/
*/
...
@@ -167,7 +170,7 @@
...
@@ -167,7 +170,7 @@
#include "ewrk3.h"
#include "ewrk3.h"
static
char
version
[]
__initdata
=
static
char
version
[]
__initdata
=
"ewrk3.c:v0.4
3a 2001/02/04
davies@maniac.ultranet.com
\n
"
;
"ewrk3.c:v0.4
6 2002/10/09
davies@maniac.ultranet.com
\n
"
;
#ifdef EWRK3_DEBUG
#ifdef EWRK3_DEBUG
static
int
ewrk3_debug
=
EWRK3_DEBUG
;
static
int
ewrk3_debug
=
EWRK3_DEBUG
;
...
@@ -196,6 +199,7 @@ static int ewrk3_debug = 1;
...
@@ -196,6 +199,7 @@ static int ewrk3_debug = 1;
#define EWRK3_IOP_INC 0x20
/* I/O address increment */
#define EWRK3_IOP_INC 0x20
/* I/O address increment */
#define EWRK3_TOTAL_SIZE 0x20
/* required I/O address length */
#define EWRK3_TOTAL_SIZE 0x20
/* required I/O address length */
/* If you change this, remember to also change MODULE_PARM array limits */
#ifndef MAX_NUM_EWRK3S
#ifndef MAX_NUM_EWRK3S
#define MAX_NUM_EWRK3S 21
#define MAX_NUM_EWRK3S 21
#endif
#endif
...
@@ -1716,6 +1720,11 @@ static int ewrk3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
...
@@ -1716,6 +1720,11 @@ static int ewrk3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
break
;
break
;
case
EWRK3_SET_MCA
:
/* Set a multicast address */
case
EWRK3_SET_MCA
:
/* Set a multicast address */
if
(
capable
(
CAP_NET_ADMIN
))
{
if
(
capable
(
CAP_NET_ADMIN
))
{
if
(
ioc
->
len
>
1024
)
{
status
=
-
EINVAL
;
break
;
}
if
(
copy_from_user
(
tmp
->
addr
,
ioc
->
data
,
ETH_ALEN
*
ioc
->
len
))
{
if
(
copy_from_user
(
tmp
->
addr
,
ioc
->
data
,
ETH_ALEN
*
ioc
->
len
))
{
status
=
-
EFAULT
;
status
=
-
EFAULT
;
break
;
break
;
...
@@ -1843,35 +1852,62 @@ static int ewrk3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
...
@@ -1843,35 +1852,62 @@ static int ewrk3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
}
}
#ifdef MODULE
#ifdef MODULE
static
struct
net_device
thisEthwrk
;
static
struct
net_device
*
ewrk3_devs
[
MAX_NUM_EWRK3S
];
static
int
io
=
0x300
;
/* <--- EDIT THESE LINES FOR YOUR CONFIGURATION */
static
int
ndevs
;
static
int
irq
=
5
;
/* or use the insmod io= irq= options */
static
int
io
[
MAX_NUM_EWRK3S
+
1
]
=
{
0x300
,
0
,
};
/* <--- EDIT THESE LINES FOR YOUR CONFIGURATION */
static
int
irq
[
MAX_NUM_EWRK3S
+
1
]
=
{
5
,
0
,
};
/* or use the insmod io= irq= options */
MODULE_PARM
(
io
,
"i"
);
/* '21' below should really be 'MAX_NUM_EWRK3S' */
MODULE_PARM
(
irq
,
"i"
);
MODULE_PARM
(
io
,
"0-21i"
);
MODULE_PARM_DESC
(
io
,
"EtherWORKS 3 I/O base address"
);
MODULE_PARM
(
irq
,
"0-21i"
);
MODULE_PARM_DESC
(
irq
,
"EtherWORKS 3 IRQ number"
);
MODULE_PARM_DESC
(
io
,
"EtherWORKS 3 I/O base address(es)"
);
MODULE_PARM_DESC
(
irq
,
"EtherWORKS 3 IRQ number(s)"
);
int
init_module
(
void
)
int
init_module
(
void
)
{
{
thisEthwrk
.
base_addr
=
io
;
int
i
=
0
;
thisEthwrk
.
irq
=
irq
;
thisEthwrk
.
init
=
ewrk3_probe
;
while
(
io
[
i
]
&&
irq
[
i
]
)
{
if
(
register_netdev
(
&
thisEthwrk
)
!=
0
)
ewrk3_devs
[
ndevs
]
=
kmalloc
(
sizeof
(
struct
net_device
),
GFP_KERNEL
);
return
-
EIO
;
if
(
!
ewrk3_devs
[
ndevs
])
return
0
;
goto
error
;
memset
(
ewrk3_devs
[
ndevs
],
0
,
sizeof
(
struct
net_device
));
ewrk3_devs
[
ndevs
]
->
base_addr
=
io
[
i
];
ewrk3_devs
[
ndevs
]
->
irq
=
irq
[
i
];
ewrk3_devs
[
ndevs
]
->
init
=
ewrk3_probe
;
if
(
register_netdev
(
ewrk3_devs
[
ndevs
])
==
0
)
ndevs
++
;
else
kfree
(
ewrk3_devs
[
ndevs
]);
i
++
;
}
return
ndevs
?
0
:
-
EIO
;
error:
cleanup_module
();
return
-
ENOMEM
;
}
}
void
cleanup_module
(
void
)
void
cleanup_module
(
void
)
{
{
unregister_netdev
(
&
thisEthwrk
);
int
i
;
if
(
thisEthwrk
.
priv
)
{
kfree
(
thisEthwrk
.
priv
);
for
(
i
=
0
;
i
<
ndevs
;
i
++
)
thisEthwrk
.
priv
=
NULL
;
{
}
unregister_netdev
(
ewrk3_devs
[
i
]);
thisEthwrk
.
irq
=
0
;
if
(
ewrk3_devs
[
i
]
->
priv
)
{
kfree
(
ewrk3_devs
[
i
]
->
priv
);
ewrk3_devs
[
i
]
->
priv
=
NULL
;
}
ewrk3_devs
[
i
]
->
irq
=
0
;
release_region
(
thisEthwrk
.
base_addr
,
EWRK3_TOTAL_SIZE
);
release_region
(
ewrk3_devs
[
i
]
->
base_addr
,
EWRK3_TOTAL_SIZE
);
kfree
(
ewrk3_devs
[
i
]);
ewrk3_devs
[
i
]
=
NULL
;
}
}
}
#endif
/* MODULE */
#endif
/* MODULE */
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
...
...
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