* [PATCH 0/2] pasemi_mac: two bugfixes for 2.6.24
@ 2007-11-07 4:20 Olof Johansson
2007-11-07 4:20 ` [PATCH 1/2] pasemi_mac: Don't set replace-source-address descriptor bits Olof Johansson
2007-11-07 4:21 ` [PATCH 2/2] pasemi_mac: Fix CRC checks Olof Johansson
0 siblings, 2 replies; 4+ messages in thread
From: Olof Johansson @ 2007-11-07 4:20 UTC (permalink / raw)
To: jgarzik; +Cc: netdev, linuxppc-dev
Hi Jeff,
Two bugfixes for pasemi_mac for 2.6.24:
[PATCH 1/2] pasemi_mac: Don't set replace-source-address descriptor bits
[PATCH 2/2] pasemi_mac: Fix CRC checks
Thanks,
-Olof
^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH 1/2] pasemi_mac: Don't set replace-source-address descriptor bits
2007-11-07 4:20 [PATCH 0/2] pasemi_mac: two bugfixes for 2.6.24 Olof Johansson
@ 2007-11-07 4:20 ` Olof Johansson
2007-11-08 17:47 ` Jeff Garzik
2007-11-07 4:21 ` [PATCH 2/2] pasemi_mac: Fix CRC checks Olof Johansson
1 sibling, 1 reply; 4+ messages in thread
From: Olof Johansson @ 2007-11-07 4:20 UTC (permalink / raw)
To: jgarzik; +Cc: netdev, linuxppc-dev
Don't use the "replace source address with local MAC address" bits, since
it causes problems on some variations of the hardware due to an erratum.
Signed-off-by: Olof Johansson <olof@lixom.net>
Index: k.org/drivers/net/pasemi_mac.c
===================================================================
--- k.org.orig/drivers/net/pasemi_mac.c
+++ k.org/drivers/net/pasemi_mac.c
@@ -1126,7 +1126,7 @@ static int pasemi_mac_start_tx(struct sk
unsigned long flags;
int i, nfrags;
- dflags = XCT_MACTX_O | XCT_MACTX_ST | XCT_MACTX_SS | XCT_MACTX_CRC_PAD;
+ dflags = XCT_MACTX_O | XCT_MACTX_ST | XCT_MACTX_CRC_PAD;
if (skb->ip_summed == CHECKSUM_PARTIAL) {
const unsigned char *nh = skb_network_header(skb);
^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH 2/2] pasemi_mac: Fix CRC checks
2007-11-07 4:20 [PATCH 0/2] pasemi_mac: two bugfixes for 2.6.24 Olof Johansson
2007-11-07 4:20 ` [PATCH 1/2] pasemi_mac: Don't set replace-source-address descriptor bits Olof Johansson
@ 2007-11-07 4:21 ` Olof Johansson
1 sibling, 0 replies; 4+ messages in thread
From: Olof Johansson @ 2007-11-07 4:21 UTC (permalink / raw)
To: jgarzik; +Cc: netdev, linuxppc-dev
Make sure we don't feed packets with bad CRC up the network stack,
and discount the packet length as reported from the MAC for the CRC
field.
Signed-off-by: Olof Johansson <olof@lixom.net>
Index: k.org/drivers/net/pasemi_mac.c
===================================================================
--- k.org.orig/drivers/net/pasemi_mac.c
+++ k.org/drivers/net/pasemi_mac.c
@@ -580,6 +580,16 @@ static int pasemi_mac_clean_rx(struct pa
len = (macrx & XCT_MACRX_LLEN_M) >> XCT_MACRX_LLEN_S;
+ pci_unmap_single(mac->dma_pdev, dma, len, PCI_DMA_FROMDEVICE);
+
+ if (macrx & XCT_MACRX_CRC) {
+ /* CRC error flagged */
+ mac->netdev->stats.rx_errors++;
+ mac->netdev->stats.rx_crc_errors++;
+ dev_kfree_skb_irq(skb);
+ goto next;
+ }
+
if (len < 256) {
struct sk_buff *new_skb;
@@ -595,11 +605,10 @@ static int pasemi_mac_clean_rx(struct pa
} else
info->skb = NULL;
- pci_unmap_single(mac->dma_pdev, dma, len, PCI_DMA_FROMDEVICE);
-
info->dma = 0;
- skb_put(skb, len);
+ /* Don't include CRC */
+ skb_put(skb, len-4);
if (likely((macrx & XCT_MACRX_HTY_M) == XCT_MACRX_HTY_IPV4_OK)) {
skb->ip_summed = CHECKSUM_UNNECESSARY;
@@ -614,6 +623,7 @@ static int pasemi_mac_clean_rx(struct pa
skb->protocol = eth_type_trans(skb, mac->netdev);
netif_receive_skb(skb);
+next:
RX_RING(mac, n) = 0;
RX_RING(mac, n+1) = 0;
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/2] pasemi_mac: Don't set replace-source-address descriptor bits
2007-11-07 4:20 ` [PATCH 1/2] pasemi_mac: Don't set replace-source-address descriptor bits Olof Johansson
@ 2007-11-08 17:47 ` Jeff Garzik
0 siblings, 0 replies; 4+ messages in thread
From: Jeff Garzik @ 2007-11-08 17:47 UTC (permalink / raw)
To: Olof Johansson; +Cc: netdev, jgarzik, linuxppc-dev
On Tue, Nov 06, 2007 at 10:20:39PM -0600, Olof Johansson wrote:
> Don't use the "replace source address with local MAC address" bits, since
> it causes problems on some variations of the hardware due to an erratum.
>
>
> Signed-off-by: Olof Johansson <olof@lixom.net>
applied 1-2
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2007-11-08 17:53 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-11-07 4:20 [PATCH 0/2] pasemi_mac: two bugfixes for 2.6.24 Olof Johansson
2007-11-07 4:20 ` [PATCH 1/2] pasemi_mac: Don't set replace-source-address descriptor bits Olof Johansson
2007-11-08 17:47 ` Jeff Garzik
2007-11-07 4:21 ` [PATCH 2/2] pasemi_mac: Fix CRC checks Olof Johansson
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).