From: Benjamin Herrenschmidt <benh@kernel.crashing.org>
To: Stephen Hemminger <shemminger@osdl.org>
Cc: netdev@vger.kernel.org
Subject: Re: sky2 problem on powerpc
Date: Wed, 06 Sep 2006 08:00:08 +1000 [thread overview]
Message-ID: <1157493608.22705.147.camel@localhost.localdomain> (raw)
In-Reply-To: <20060905143654.754da8ef@localhost.localdomain>
On Tue, 2006-09-05 at 14:36 -0700, Stephen Hemminger wrote:
> This is the reduced version of your patch, plus I got rid of the union
> in tx_le, it is a nuisance.
Thanks. I'll give it a go later today. The remaining nit is the
inconsitent swapping of the vlan tag which is manipulated at BE at times
and LE at others (later hapens in status_intr).
Ben.
> --- sky2.orig/drivers/net/sky2.c 2006-09-05 13:39:34.000000000 -0700
> +++ sky2/drivers/net/sky2.c 2006-09-05 13:57:44.000000000 -0700
> @@ -809,7 +809,7 @@
> struct sky2_rx_le *le;
>
> le = sky2_next_rx(sky2);
> - le->addr = (ETH_HLEN << 16) | ETH_HLEN;
> + le->addr = cpu_to_le32((ETH_HLEN << 16) | ETH_HLEN);
> le->ctrl = 0;
> le->opcode = OP_TCPSTART | HW_OWNER;
>
> @@ -1227,7 +1227,7 @@
> /* Send high bits if changed or crosses boundary */
> if (addr64 != sky2->tx_addr64 || high32(mapping + len) != sky2->tx_addr64) {
> le = get_tx_le(sky2);
> - le->tx.addr = cpu_to_le32(addr64);
> + le->addr = cpu_to_le32(addr64);
> le->ctrl = 0;
> le->opcode = OP_ADDR64 | HW_OWNER;
> sky2->tx_addr64 = high32(mapping + len);
> @@ -1242,8 +1242,7 @@
>
> if (mss != sky2->tx_last_mss) {
> le = get_tx_le(sky2);
> - le->tx.tso.size = cpu_to_le16(mss);
> - le->tx.tso.rsvd = 0;
> + le->addr = cpu_to_le32(mss);
> le->opcode = OP_LRGLEN | HW_OWNER;
> le->ctrl = 0;
> sky2->tx_last_mss = mss;
> @@ -1256,7 +1255,7 @@
> if (sky2->vlgrp && vlan_tx_tag_present(skb)) {
> if (!le) {
> le = get_tx_le(sky2);
> - le->tx.addr = 0;
> + le->addr = 0;
> le->opcode = OP_VLAN|HW_OWNER;
> le->ctrl = 0;
> } else
> @@ -1268,20 +1267,21 @@
>
> /* Handle TCP checksum offload */
> if (skb->ip_summed == CHECKSUM_HW) {
> - u16 hdr = skb->h.raw - skb->data;
> - u16 offset = hdr + skb->csum;
> + unsigned offset = skb->h.raw - skb->data;
> + u32 tcpsum;
> +
> + tcpsum = offset << 16; /* sum start */
> + tcpsum |= offset + skb->csum; /* sum write */
>
> ctrl = CALSUM | WR_SUM | INIT_SUM | LOCK_SUM;
> if (skb->nh.iph->protocol == IPPROTO_UDP)
> ctrl |= UDPTCP;
>
> - if (hdr != sky2->tx_csum_start || offset != sky2->tx_csum_offset) {
> - sky2->tx_csum_start = hdr;
> - sky2->tx_csum_offset = offset;
> + if (tcpsum != sky2->tx_tcpsum) {
> + sky2->tx_tcpsum = tcpsum;
>
> le = get_tx_le(sky2);
> - le->tx.csum.start = cpu_to_le16(hdr);
> - le->tx.csum.offset = cpu_to_le16(offset);
> + le->addr = cpu_to_le32(tcpsum);
> le->length = 0; /* initial checksum value */
> le->ctrl = 1; /* one packet */
> le->opcode = OP_TCPLISW | HW_OWNER;
> @@ -1289,7 +1289,7 @@
> }
>
> le = get_tx_le(sky2);
> - le->tx.addr = cpu_to_le32((u32) mapping);
> + le->addr = cpu_to_le32((u32) mapping);
> le->length = cpu_to_le16(len);
> le->ctrl = ctrl;
> le->opcode = mss ? (OP_LARGESEND | HW_OWNER) : (OP_PACKET | HW_OWNER);
> @@ -1307,14 +1307,14 @@
> addr64 = high32(mapping);
> if (addr64 != sky2->tx_addr64) {
> le = get_tx_le(sky2);
> - le->tx.addr = cpu_to_le32(addr64);
> + le->addr = cpu_to_le32(addr64);
> le->ctrl = 0;
> le->opcode = OP_ADDR64 | HW_OWNER;
> sky2->tx_addr64 = addr64;
> }
>
> le = get_tx_le(sky2);
> - le->tx.addr = cpu_to_le32((u32) mapping);
> + le->addr = cpu_to_le32((u32) mapping);
> le->length = cpu_to_le16(frag->size);
> le->ctrl = ctrl;
> le->opcode = OP_BUFFER | HW_OWNER;
> @@ -1919,8 +1919,8 @@
> dev = hw->dev[le->link];
>
> sky2 = netdev_priv(dev);
> - length = le->length;
> - status = le->status;
> + length = le16_to_cpu(le->length);
> + status = le32_to_cpu(le->status);
>
> switch (le->opcode & ~HW_OWNER) {
> case OP_RXSTAT:
> @@ -1964,7 +1964,7 @@
> case OP_RXCHKS:
> skb = sky2->rx_ring[sky2->rx_next].skb;
> skb->ip_summed = CHECKSUM_HW;
> - skb->csum = le16_to_cpu(status);
> + skb->csum = status & 0xffff;
> break;
>
> case OP_TXINDEXLE:
> @@ -3266,12 +3266,13 @@
> hw->pm_cap = pm_cap;
>
> #ifdef __BIG_ENDIAN
> - /* byte swap descriptors in hardware */
> + /* The sk98lin vendor driver uses hardware byte swapping but
> + * this driver uses software swapping.
> + */
> {
> u32 reg;
> -
> reg = sky2_pci_read32(hw, PCI_DEV_REG2);
> - reg |= PCI_REV_DESC;
> + reg &= ~PCI_REV_DESC;
> sky2_pci_write32(hw, PCI_DEV_REG2, reg);
> }
> #endif
> --- sky2.orig/drivers/net/sky2.h 2006-09-05 12:10:13.000000000 -0700
> +++ sky2/drivers/net/sky2.h 2006-09-05 13:55:55.000000000 -0700
> @@ -1783,21 +1783,9 @@
> OP_TXINDEXLE = 0x68,
> };
>
> -/* Yukon 2 hardware interface
> - * Not tested on big endian
> - */
> +/* Yukon 2 hardware interface */
> struct sky2_tx_le {
> - union {
> - __le32 addr;
> - struct {
> - __le16 offset;
> - __le16 start;
> - } csum __attribute((packed));
> - struct {
> - __le16 size;
> - __le16 rsvd;
> - } tso __attribute((packed));
> - } tx;
> + __le32 addr;
> __le16 length; /* also vlan tag or checksum start */
> u8 ctrl;
> u8 opcode;
> @@ -1843,8 +1831,7 @@
> u32 tx_addr64;
> u16 tx_pending;
> u16 tx_last_mss;
> - u16 tx_csum_start;
> - u16 tx_csum_offset;
> + u32 tx_tcpsum;
>
> struct ring_info *rx_ring ____cacheline_aligned_in_smp;
> struct sky2_rx_le *rx_le;
prev parent reply other threads:[~2006-09-05 22:00 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-09-04 5:24 sky2 problem on powerpc Benjamin Herrenschmidt
2006-09-04 7:21 ` Benjamin Herrenschmidt
2006-09-04 7:42 ` Benjamin Herrenschmidt
2006-09-04 21:05 ` Segher Boessenkool
2006-09-04 21:33 ` Benjamin Herrenschmidt
2006-09-05 3:41 ` Stephen Hemminger
2006-09-05 3:47 ` Benjamin Herrenschmidt
2006-09-05 4:15 ` Stephen Hemminger
2006-09-05 21:11 ` Benjamin Herrenschmidt
2006-09-05 21:36 ` Stephen Hemminger
2006-09-05 22:00 ` Benjamin Herrenschmidt [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1157493608.22705.147.camel@localhost.localdomain \
--to=benh@kernel.crashing.org \
--cc=netdev@vger.kernel.org \
--cc=shemminger@osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).