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
31d881c7
Commit
31d881c7
authored
Jan 24, 2005
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://kernel.bkbits.net/davem/net-2.6
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
11828b23
79476f70
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
29 additions
and
13 deletions
+29
-13
drivers/net/tg3.c
drivers/net/tg3.c
+26
-13
drivers/net/tg3.h
drivers/net/tg3.h
+1
-0
net/ipv4/ip_output.c
net/ipv4/ip_output.c
+1
-0
net/ipv6/ip6_output.c
net/ipv6/ip6_output.c
+1
-0
No files found.
drivers/net/tg3.c
View file @
31d881c7
...
@@ -60,8 +60,8 @@
...
@@ -60,8 +60,8 @@
#define DRV_MODULE_NAME "tg3"
#define DRV_MODULE_NAME "tg3"
#define PFX DRV_MODULE_NAME ": "
#define PFX DRV_MODULE_NAME ": "
#define DRV_MODULE_VERSION "3.1
7
"
#define DRV_MODULE_VERSION "3.1
8
"
#define DRV_MODULE_RELDATE "January 2
2
, 2005"
#define DRV_MODULE_RELDATE "January 2
4
, 2005"
#define TG3_DEF_MAC_MODE 0
#define TG3_DEF_MAC_MODE 0
#define TG3_DEF_RX_MODE 0
#define TG3_DEF_RX_MODE 0
...
@@ -3111,11 +3111,19 @@ static int tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -3111,11 +3111,19 @@ static int tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
skb
->
nh
.
iph
->
check
=
0
;
skb
->
nh
.
iph
->
check
=
0
;
skb
->
nh
.
iph
->
tot_len
=
ntohs
(
mss
+
ip_tcp_len
+
tcp_opt_len
);
skb
->
nh
.
iph
->
tot_len
=
ntohs
(
mss
+
ip_tcp_len
+
tcp_opt_len
);
skb
->
h
.
th
->
check
=
~
csum_tcpudp_magic
(
skb
->
nh
.
iph
->
saddr
,
if
(
tp
->
tg3_flags2
&
TG3_FLG2_HW_TSO
)
{
skb
->
h
.
th
->
check
=
0
;
base_flags
&=
~
TXD_FLAG_TCPUDP_CSUM
;
}
else
{
skb
->
h
.
th
->
check
=
~
csum_tcpudp_magic
(
skb
->
nh
.
iph
->
saddr
,
skb
->
nh
.
iph
->
daddr
,
skb
->
nh
.
iph
->
daddr
,
0
,
IPPROTO_TCP
,
0
);
0
,
IPPROTO_TCP
,
0
);
}
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5705
)
{
if
((
tp
->
tg3_flags2
&
TG3_FLG2_HW_TSO
)
||
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5705
))
{
if
(
tcp_opt_len
||
skb
->
nh
.
iph
->
ihl
>
5
)
{
if
(
tcp_opt_len
||
skb
->
nh
.
iph
->
ihl
>
5
)
{
int
tsflags
;
int
tsflags
;
...
@@ -3182,7 +3190,7 @@ static int tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
...
@@ -3182,7 +3190,7 @@ static int tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
would_hit_hwbug
=
entry
+
1
;
would_hit_hwbug
=
entry
+
1
;
}
}
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5750
)
if
(
tp
->
tg3_flags2
&
TG3_FLG2_HW_TSO
)
tg3_set_txd
(
tp
,
entry
,
mapping
,
len
,
tg3_set_txd
(
tp
,
entry
,
mapping
,
len
,
base_flags
,
(
i
==
last
)
|
(
mss
<<
1
));
base_flags
,
(
i
==
last
)
|
(
mss
<<
1
));
else
else
...
@@ -4774,7 +4782,7 @@ static int tg3_load_tso_firmware(struct tg3 *tp)
...
@@ -4774,7 +4782,7 @@ static int tg3_load_tso_firmware(struct tg3 *tp)
unsigned
long
cpu_base
,
cpu_scratch_base
,
cpu_scratch_size
;
unsigned
long
cpu_base
,
cpu_scratch_base
,
cpu_scratch_size
;
int
err
,
i
;
int
err
,
i
;
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5750
)
if
(
tp
->
tg3_flags2
&
TG3_FLG2_HW_TSO
)
return
0
;
return
0
;
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5705
)
{
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5705
)
{
...
@@ -5208,7 +5216,7 @@ static int tg3_reset_hw(struct tg3 *tp)
...
@@ -5208,7 +5216,7 @@ static int tg3_reset_hw(struct tg3 *tp)
}
}
#if TG3_TSO_SUPPORT != 0
#if TG3_TSO_SUPPORT != 0
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5750
)
if
(
tp
->
tg3_flags2
&
TG3_FLG2_HW_TSO
)
rdmac_mode
|=
(
1
<<
27
);
rdmac_mode
|=
(
1
<<
27
);
#endif
#endif
...
@@ -5358,7 +5366,7 @@ static int tg3_reset_hw(struct tg3 *tp)
...
@@ -5358,7 +5366,7 @@ static int tg3_reset_hw(struct tg3 *tp)
tw32
(
RCVDBDI_MODE
,
RCVDBDI_MODE_ENABLE
|
RCVDBDI_MODE_INV_RING_SZ
);
tw32
(
RCVDBDI_MODE
,
RCVDBDI_MODE_ENABLE
|
RCVDBDI_MODE_INV_RING_SZ
);
tw32
(
SNDDATAI_MODE
,
SNDDATAI_MODE_ENABLE
);
tw32
(
SNDDATAI_MODE
,
SNDDATAI_MODE_ENABLE
);
#if TG3_TSO_SUPPORT != 0
#if TG3_TSO_SUPPORT != 0
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5750
)
if
(
tp
->
tg3_flags2
&
TG3_FLG2_HW_TSO
)
tw32
(
SNDDATAI_MODE
,
SNDDATAI_MODE_ENABLE
|
0x8
);
tw32
(
SNDDATAI_MODE
,
SNDDATAI_MODE_ENABLE
|
0x8
);
#endif
#endif
tw32
(
SNDBDI_MODE
,
SNDBDI_MODE_ENABLE
|
SNDBDI_MODE_ATTN_ENABLE
);
tw32
(
SNDBDI_MODE
,
SNDBDI_MODE_ENABLE
|
SNDBDI_MODE_ATTN_ENABLE
);
...
@@ -7867,6 +7875,9 @@ static int __devinit tg3_get_invariants(struct tg3 *tp)
...
@@ -7867,6 +7875,9 @@ static int __devinit tg3_get_invariants(struct tg3 *tp)
tp
->
pci_hdr_type
=
(
cacheline_sz_reg
>>
16
)
&
0xff
;
tp
->
pci_hdr_type
=
(
cacheline_sz_reg
>>
16
)
&
0xff
;
tp
->
pci_bist
=
(
cacheline_sz_reg
>>
24
)
&
0xff
;
tp
->
pci_bist
=
(
cacheline_sz_reg
>>
24
)
&
0xff
;
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5750
)
tp
->
tg3_flags2
|=
TG3_FLG2_HW_TSO
;
if
(
pci_find_capability
(
tp
->
pdev
,
PCI_CAP_ID_EXP
)
!=
0
)
if
(
pci_find_capability
(
tp
->
pdev
,
PCI_CAP_ID_EXP
)
!=
0
)
tp
->
tg3_flags2
|=
TG3_FLG2_PCI_EXPRESS
;
tp
->
tg3_flags2
|=
TG3_FLG2_PCI_EXPRESS
;
...
@@ -8762,11 +8773,13 @@ static int __devinit tg3_init_one(struct pci_dev *pdev,
...
@@ -8762,11 +8773,13 @@ static int __devinit tg3_init_one(struct pci_dev *pdev,
}
}
#if TG3_TSO_SUPPORT != 0
#if TG3_TSO_SUPPORT != 0
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5700
||
if
(
tp
->
tg3_flags2
&
TG3_FLG2_HW_TSO
)
{
tp
->
tg3_flags2
|=
TG3_FLG2_TSO_CAPABLE
;
}
else
if
(
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5700
||
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5701
||
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
==
ASIC_REV_5701
||
tp
->
pci_chip_rev_id
==
CHIPREV_ID_5705_A0
||
tp
->
pci_chip_rev_id
==
CHIPREV_ID_5705_A0
||
((
tp
->
tg3_flags
&
TG3_FLAG_ENABLE_ASF
)
!=
0
&&
(
tp
->
tg3_flags
&
TG3_FLAG_ENABLE_ASF
)
!=
0
)
{
GET_ASIC_REV
(
tp
->
pci_chip_rev_id
)
!=
ASIC_REV_5750
))
{
tp
->
tg3_flags2
&=
~
TG3_FLG2_TSO_CAPABLE
;
tp
->
tg3_flags2
&=
~
TG3_FLG2_TSO_CAPABLE
;
}
else
{
}
else
{
tp
->
tg3_flags2
|=
TG3_FLG2_TSO_CAPABLE
;
tp
->
tg3_flags2
|=
TG3_FLG2_TSO_CAPABLE
;
...
...
drivers/net/tg3.h
View file @
31d881c7
...
@@ -2105,6 +2105,7 @@ struct tg3 {
...
@@ -2105,6 +2105,7 @@ struct tg3 {
#define TG3_FLG2_PHY_SERDES 0x00002000
#define TG3_FLG2_PHY_SERDES 0x00002000
#define TG3_FLG2_CAPACITIVE_COUPLING 0x00004000
#define TG3_FLG2_CAPACITIVE_COUPLING 0x00004000
#define TG3_FLG2_FLASH 0x00008000
#define TG3_FLG2_FLASH 0x00008000
#define TG3_FLG2_HW_TSO 0x00010000
u32
split_mode_max_reqs
;
u32
split_mode_max_reqs
;
#define SPLIT_MODE_5704_MAX_REQ 3
#define SPLIT_MODE_5704_MAX_REQ 3
...
...
net/ipv4/ip_output.c
View file @
31d881c7
...
@@ -504,6 +504,7 @@ int ip_fragment(struct sk_buff *skb, int (*output)(struct sk_buff*))
...
@@ -504,6 +504,7 @@ int ip_fragment(struct sk_buff *skb, int (*output)(struct sk_buff*))
/* Prepare header of the next frame,
/* Prepare header of the next frame,
* before previous one went down. */
* before previous one went down. */
if
(
frag
)
{
if
(
frag
)
{
frag
->
ip_summed
=
CHECKSUM_NONE
;
frag
->
h
.
raw
=
frag
->
data
;
frag
->
h
.
raw
=
frag
->
data
;
frag
->
nh
.
raw
=
__skb_push
(
frag
,
hlen
);
frag
->
nh
.
raw
=
__skb_push
(
frag
,
hlen
);
memcpy
(
frag
->
nh
.
raw
,
iph
,
hlen
);
memcpy
(
frag
->
nh
.
raw
,
iph
,
hlen
);
...
...
net/ipv6/ip6_output.c
View file @
31d881c7
...
@@ -592,6 +592,7 @@ static int ip6_fragment(struct sk_buff *skb, int (*output)(struct sk_buff *))
...
@@ -592,6 +592,7 @@ static int ip6_fragment(struct sk_buff *skb, int (*output)(struct sk_buff *))
/* Prepare header of the next frame,
/* Prepare header of the next frame,
* before previous one went down. */
* before previous one went down. */
if
(
frag
)
{
if
(
frag
)
{
frag
->
ip_summed
=
CHECKSUM_NONE
;
frag
->
h
.
raw
=
frag
->
data
;
frag
->
h
.
raw
=
frag
->
data
;
fh
=
(
struct
frag_hdr
*
)
__skb_push
(
frag
,
sizeof
(
struct
frag_hdr
));
fh
=
(
struct
frag_hdr
*
)
__skb_push
(
frag
,
sizeof
(
struct
frag_hdr
));
frag
->
nh
.
raw
=
__skb_push
(
frag
,
hlen
);
frag
->
nh
.
raw
=
__skb_push
(
frag
,
hlen
);
...
...
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