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
e05d5feb
Commit
e05d5feb
authored
Mar 19, 2002
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Plain Diff
Merge mandrakesoft.com:/home/jgarzik/vanilla/linus-2.5
into mandrakesoft.com:/home/jgarzik/repo/net-drivers-2.5
parents
085c9a18
89907949
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
21 additions
and
37 deletions
+21
-37
drivers/net/acenic.c
drivers/net/acenic.c
+17
-32
drivers/net/acenic.h
drivers/net/acenic.h
+4
-5
No files found.
drivers/net/acenic.c
View file @
e05d5feb
...
@@ -65,7 +65,10 @@
...
@@ -65,7 +65,10 @@
#include <linux/mm.h>
#include <linux/mm.h>
#include <linux/highmem.h>
#include <linux/highmem.h>
#include <linux/sockios.h>
#include <linux/sockios.h>
#if defined(CONFIG_VLAN_8021Q) || defined(CONFIG_VLAN_8021Q_MODULE)
#include <linux/if_vlan.h>
#include <linux/if_vlan.h>
#endif
#ifdef SIOCETHTOOL
#ifdef SIOCETHTOOL
#include <linux/ethtool.h>
#include <linux/ethtool.h>
...
@@ -320,9 +323,11 @@ static inline void tasklet_init(struct tasklet_struct *tasklet,
...
@@ -320,9 +323,11 @@ static inline void tasklet_init(struct tasklet_struct *tasklet,
#if (defined(CONFIG_VLAN_8021Q) || defined(CONFIG_VLAN_8021Q_MODULE)) && \
#if (defined(CONFIG_VLAN_8021Q) || defined(CONFIG_VLAN_8021Q_MODULE)) && \
defined(NETIF_F_HW_VLAN_RX)
defined(NETIF_F_HW_VLAN_RX)
#define ACENIC_DO_VLAN 1
#define ACENIC_DO_VLAN 1
#define ACE_RCB_VLAN_FLAG RCB_FLG_VLAN_ASSIST
#else
#else
#define ACENIC_DO_VLAN 0
#define ACENIC_DO_VLAN 0
#define ACE_RCB_VLAN_FLAG 0
#endif
#endif
#include "acenic.h"
#include "acenic.h"
...
@@ -563,7 +568,7 @@ static int tx_ratio[ACE_MAX_MOD_PARMS];
...
@@ -563,7 +568,7 @@ static int tx_ratio[ACE_MAX_MOD_PARMS];
static
int
dis_pci_mem_inval
[
ACE_MAX_MOD_PARMS
]
=
{
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
};
static
int
dis_pci_mem_inval
[
ACE_MAX_MOD_PARMS
]
=
{
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
};
static
char
version
[]
__initdata
=
static
char
version
[]
__initdata
=
"acenic.c: v0.8
8 03/14
/2002 Jes Sorensen, linux-acenic@SunSITE.dk
\n
"
"acenic.c: v0.8
9 03/15
/2002 Jes Sorensen, linux-acenic@SunSITE.dk
\n
"
" http://home.cern.ch/~jes/gige/acenic.html
\n
"
;
" http://home.cern.ch/~jes/gige/acenic.html
\n
"
;
static
struct
net_device
*
root_dev
;
static
struct
net_device
*
root_dev
;
...
@@ -1461,10 +1466,8 @@ static int __init ace_init(struct net_device *dev)
...
@@ -1461,10 +1466,8 @@ static int __init ace_init(struct net_device *dev)
set_aceaddr
(
&
info
->
rx_std_ctrl
.
rngptr
,
ap
->
rx_ring_base_dma
);
set_aceaddr
(
&
info
->
rx_std_ctrl
.
rngptr
,
ap
->
rx_ring_base_dma
);
info
->
rx_std_ctrl
.
max_len
=
ACE_STD_MTU
+
ETH_HLEN
+
4
;
info
->
rx_std_ctrl
.
max_len
=
ACE_STD_MTU
+
ETH_HLEN
+
4
;
info
->
rx_std_ctrl
.
flags
=
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
;
info
->
rx_std_ctrl
.
flags
=
#if ACENIC_DO_VLAN
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
|
ACE_RCB_VLAN_FLAG
;
info
->
rx_std_ctrl
.
flags
|=
RCB_FLG_VLAN_ASSIST
;
#endif
memset
(
ap
->
rx_std_ring
,
0
,
memset
(
ap
->
rx_std_ring
,
0
,
RX_STD_RING_ENTRIES
*
sizeof
(
struct
rx_desc
));
RX_STD_RING_ENTRIES
*
sizeof
(
struct
rx_desc
));
...
@@ -1479,10 +1482,8 @@ static int __init ace_init(struct net_device *dev)
...
@@ -1479,10 +1482,8 @@ static int __init ace_init(struct net_device *dev)
(
ap
->
rx_ring_base_dma
+
(
ap
->
rx_ring_base_dma
+
(
sizeof
(
struct
rx_desc
)
*
RX_STD_RING_ENTRIES
)));
(
sizeof
(
struct
rx_desc
)
*
RX_STD_RING_ENTRIES
)));
info
->
rx_jumbo_ctrl
.
max_len
=
0
;
info
->
rx_jumbo_ctrl
.
max_len
=
0
;
info
->
rx_jumbo_ctrl
.
flags
=
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
;
info
->
rx_jumbo_ctrl
.
flags
=
#if ACENIC_DO_VLAN
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
|
ACE_RCB_VLAN_FLAG
;
info
->
rx_jumbo_ctrl
.
flags
|=
RCB_FLG_VLAN_ASSIST
;
#endif
memset
(
ap
->
rx_jumbo_ring
,
0
,
memset
(
ap
->
rx_jumbo_ring
,
0
,
RX_JUMBO_RING_ENTRIES
*
sizeof
(
struct
rx_desc
));
RX_JUMBO_RING_ENTRIES
*
sizeof
(
struct
rx_desc
));
...
@@ -1504,10 +1505,7 @@ static int __init ace_init(struct net_device *dev)
...
@@ -1504,10 +1505,7 @@ static int __init ace_init(struct net_device *dev)
RX_JUMBO_RING_ENTRIES
))));
RX_JUMBO_RING_ENTRIES
))));
info
->
rx_mini_ctrl
.
max_len
=
ACE_MINI_SIZE
;
info
->
rx_mini_ctrl
.
max_len
=
ACE_MINI_SIZE
;
info
->
rx_mini_ctrl
.
flags
=
info
->
rx_mini_ctrl
.
flags
=
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
;
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
|
ACE_RCB_VLAN_FLAG
;
#if ACENIC_DO_VLAN
info
->
rx_mini_ctrl
.
flags
|=
RCB_FLG_VLAN_ASSIST
;
#endif
for
(
i
=
0
;
i
<
RX_MINI_RING_ENTRIES
;
i
++
)
for
(
i
=
0
;
i
<
RX_MINI_RING_ENTRIES
;
i
++
)
ap
->
rx_mini_ring
[
i
].
flags
=
ap
->
rx_mini_ring
[
i
].
flags
=
...
@@ -1554,7 +1552,7 @@ static int __init ace_init(struct net_device *dev)
...
@@ -1554,7 +1552,7 @@ static int __init ace_init(struct net_device *dev)
}
}
info
->
tx_ctrl
.
max_len
=
ACE_TX_RING_ENTRIES
(
ap
);
info
->
tx_ctrl
.
max_len
=
ACE_TX_RING_ENTRIES
(
ap
);
tmp
=
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
;
tmp
=
RCB_FLG_TCP_UDP_SUM
|
RCB_FLG_NO_PSEUDO_HDR
|
ACE_RCB_VLAN_FLAG
;
/*
/*
* The Tigon I does not like having the TX ring in host memory ;-(
* The Tigon I does not like having the TX ring in host memory ;-(
...
@@ -1563,9 +1561,6 @@ static int __init ace_init(struct net_device *dev)
...
@@ -1563,9 +1561,6 @@ static int __init ace_init(struct net_device *dev)
tmp
|=
RCB_FLG_TX_HOST_RING
;
tmp
|=
RCB_FLG_TX_HOST_RING
;
#if TX_COAL_INTS_ONLY
#if TX_COAL_INTS_ONLY
tmp
|=
RCB_FLG_COAL_INT_ONLY
;
tmp
|=
RCB_FLG_COAL_INT_ONLY
;
#endif
#if ACENIC_DO_VLAN
tmp
|=
RCB_FLG_VLAN_ASSIST
;
#endif
#endif
info
->
tx_ctrl
.
flags
=
tmp
;
info
->
tx_ctrl
.
flags
=
tmp
;
...
@@ -1592,7 +1587,7 @@ static int __init ace_init(struct net_device *dev)
...
@@ -1592,7 +1587,7 @@ static int __init ace_init(struct net_device *dev)
ace_set_rxtx_parms
(
dev
,
0
);
ace_set_rxtx_parms
(
dev
,
0
);
if
(
board_idx
==
BOARD_IDX_OVERFLOW
)
{
if
(
board_idx
==
BOARD_IDX_OVERFLOW
)
{
printk
(
KERN_WARNING
"%s: more th
e
n %i NICs detected, "
printk
(
KERN_WARNING
"%s: more th
a
n %i NICs detected, "
"ignoring module parameters!
\n
"
,
"ignoring module parameters!
\n
"
,
dev
->
name
,
ACE_MAX_MOD_PARMS
);
dev
->
name
,
ACE_MAX_MOD_PARMS
);
}
else
if
(
board_idx
>=
0
)
{
}
else
if
(
board_idx
>=
0
)
{
...
@@ -2181,14 +2176,6 @@ static u32 ace_handle_event(struct net_device *dev, u32 evtcsm, u32 evtprd)
...
@@ -2181,14 +2176,6 @@ static u32 ace_handle_event(struct net_device *dev, u32 evtcsm, u32 evtprd)
}
}
#if ACENIC_DO_VLAN
static
int
ace_vlan_rx
(
struct
ace_private
*
ap
,
struct
sk_buff
*
skb
,
u16
vlan_tag
)
{
return
vlan_hwaccel_rx
(
skb
,
ap
->
vlgrp
,
vlan_tag
);
}
#endif
static
void
ace_rx_int
(
struct
net_device
*
dev
,
u32
rxretprd
,
u32
rxretcsm
)
static
void
ace_rx_int
(
struct
net_device
*
dev
,
u32
rxretprd
,
u32
rxretcsm
)
{
{
struct
ace_private
*
ap
=
dev
->
priv
;
struct
ace_private
*
ap
=
dev
->
priv
;
...
@@ -2274,11 +2261,9 @@ static void ace_rx_int(struct net_device *dev, u32 rxretprd, u32 rxretcsm)
...
@@ -2274,11 +2261,9 @@ static void ace_rx_int(struct net_device *dev, u32 rxretprd, u32 rxretcsm)
}
}
/* send it up */
/* send it up */
#if ACENIC_DO_VLAN
#if ACENIC_DO_VLAN
if
(
ap
->
vlgrp
!=
NULL
&&
if
(
ap
->
vlgrp
&&
(
bd_flags
&
BD_FLG_VLAN_TAG
))
{
(
bd_flags
&
BD_FLG_VLAN_TAG
))
{
vlan_hwaccel_rx
(
skb
,
ap
->
vlgrp
,
retdesc
->
vlan
);
ace_vlan_rx
(
ap
,
skb
,
retdesc
->
vlan
);
}
else
}
else
#endif
#endif
netif_rx
(
skb
);
netif_rx
(
skb
);
...
...
drivers/net/acenic.h
View file @
e05d5feb
...
@@ -642,10 +642,6 @@ struct ace_private
...
@@ -642,10 +642,6 @@ struct ace_private
struct
ace_skb
*
skb
;
struct
ace_skb
*
skb
;
dma_addr_t
info_dma
;
/* 32/64 bit */
dma_addr_t
info_dma
;
/* 32/64 bit */
#if ACENIC_DO_VLAN
struct
vlan_group
*
vlgrp
;
#endif
int
version
,
link
;
int
version
,
link
;
int
promisc
,
mcast_all
;
int
promisc
,
mcast_all
;
...
@@ -655,7 +651,6 @@ struct ace_private
...
@@ -655,7 +651,6 @@ struct ace_private
struct
tx_desc
*
tx_ring
;
struct
tx_desc
*
tx_ring
;
u32
tx_prd
;
u32
tx_prd
;
volatile
u32
tx_ret_csm
;
volatile
u32
tx_ret_csm
;
struct
timer_list
timer
;
int
tx_ring_entries
;
int
tx_ring_entries
;
/*
/*
...
@@ -675,6 +670,10 @@ struct ace_private
...
@@ -675,6 +670,10 @@ struct ace_private
struct
rx_desc
*
rx_mini_ring
;
struct
rx_desc
*
rx_mini_ring
;
struct
rx_desc
*
rx_return_ring
;
struct
rx_desc
*
rx_return_ring
;
#if ACENIC_DO_VLAN
struct
vlan_group
*
vlgrp
;
#endif
int
tasklet_pending
,
jumbo
;
int
tasklet_pending
,
jumbo
;
struct
tasklet_struct
ace_tasklet
;
struct
tasklet_struct
ace_tasklet
;
...
...
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