From: Jay Cliburn <jacliburn@bellsouth.net>
To: Kevin Hao <kexin.hao@windriver.com>
Cc: Jeff Garzik <jgarzik@redhat.com>, Chris Snook <csnook@redhat.com>,
netdev@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH] net: remove LLTX in atl2 driver
Date: Thu, 25 Sep 2008 20:24:49 -0500 [thread overview]
Message-ID: <20080925202449.340fcfef@osprey.hogchain.net> (raw)
In-Reply-To: <1222302922-13200-1-git-send-email-kexin.hao@windriver.com>
On Thu, 25 Sep 2008 08:35:22 +0800
Kevin Hao <kexin.hao@windriver.com> wrote:
> When NETIF_F_LLTX is set, the atlx driver will use a private lock.
> But in recent kernels this implementation seems redundant and
> can cause problems where AF_PACKET sees things twice. Since
> NETIF_F_LLTX is marked as deprecated and shouldn't be used in
> new driver, this patch removes NETIF_F_LLTX and adds a mmiowb
> before sending packet.
>
> Signed-off-by: Kevin Hao <kexin.hao@windriver.com>
Seems to work fine with large file (3.5 GiB) two-way scp and two-way
iperf runs.
[root@osprey ~]# ifconfig eth1
eth1 Link encap:Ethernet HWaddr 00:13:74:00:5C:38
inet addr:192.168.1.33 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::213:74ff:fe00:5c38/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1492 Metric:1
RX packets:10054352 errors:0 dropped:0 overruns:0 frame:1
TX packets:12364268 errors:0 dropped:0 overruns:0 carrier:6
collisions:0 txqueuelen:1000
RX bytes:11990462653 (11.1 GiB) TX bytes:12351847745 (11.5 GiB)
Memory:dbfc0000-dc000000
Acked-by: Jay Cliburn <jacliburn@bellsouth.net>
> ---
> drivers/net/atlx/atl2.c | 24 +-----------------------
> drivers/net/atlx/atl2.h | 1 -
> 2 files changed, 1 insertions(+), 24 deletions(-)
>
> diff --git a/drivers/net/atlx/atl2.c b/drivers/net/atlx/atl2.c
> index b2995ac..3df4ee1 100644
> --- a/drivers/net/atlx/atl2.c
> +++ b/drivers/net/atlx/atl2.c
> @@ -116,7 +116,6 @@ static int __devinit atl2_sw_init(struct
> atl2_adapter *adapter) hw->max_frame_size = adapter->netdev->mtu;
>
> spin_lock_init(&adapter->stats_lock);
> - spin_lock_init(&adapter->tx_lock);
>
> set_bit(__ATL2_DOWN, &adapter->flags);
>
> @@ -749,11 +748,7 @@ static void atl2_down(struct atl2_adapter
> *adapter)
> * reschedule our watchdog timer */
> set_bit(__ATL2_DOWN, &adapter->flags);
>
> -#ifdef NETIF_F_LLTX
> - netif_stop_queue(netdev);
> -#else
> netif_tx_disable(netdev);
> -#endif
>
> /* reset MAC to disable all RX/TX */
> atl2_reset_hw(&adapter->hw);
> @@ -829,7 +824,6 @@ static inline int TxdFreeBytes(struct
> atl2_adapter *adapter) static int atl2_xmit_frame(struct sk_buff
> *skb, struct net_device *netdev) {
> struct atl2_adapter *adapter = netdev_priv(netdev);
> - unsigned long flags;
> struct tx_pkt_header *txph;
> u32 offset, copy_len;
> int txs_unused;
> @@ -845,16 +839,6 @@ static int atl2_xmit_frame(struct sk_buff *skb,
> struct net_device *netdev) return NETDEV_TX_OK;
> }
>
> -#ifdef NETIF_F_LLTX
> - local_irq_save(flags);
> - if (!spin_trylock(&adapter->tx_lock)) {
> - /* Collision - tell upper layer to requeue */
> - local_irq_restore(flags);
> - return NETDEV_TX_LOCKED;
> - }
> -#else
> - spin_lock_irqsave(&adapter->tx_lock, flags);
> -#endif
> txs_unused = TxsFreeUnit(adapter);
> txbuf_unused = TxdFreeBytes(adapter);
>
> @@ -862,7 +846,6 @@ static int atl2_xmit_frame(struct sk_buff *skb,
> struct net_device *netdev) txs_unused < 1) {
> /* not enough resources */
> netif_stop_queue(netdev);
> - spin_unlock_irqrestore(&adapter->tx_lock, flags);
> return NETDEV_TX_BUSY;
> }
>
> @@ -908,8 +891,7 @@ static int atl2_xmit_frame(struct sk_buff *skb,
> struct net_device *netdev) ATL2_WRITE_REGW(&adapter->hw,
> REG_MB_TXD_WR_IDX, (adapter->txd_write_ptr >> 2));
>
> - spin_unlock_irqrestore(&adapter->tx_lock, flags);
> -
> + mmiowb();
> netdev->trans_start = jiffies;
> dev_kfree_skb_any(skb);
> return NETDEV_TX_OK;
> @@ -1447,10 +1429,6 @@ static int __devinit atl2_probe(struct pci_dev
> *pdev, netdev->features |= (NETIF_F_HW_VLAN_TX | NETIF_F_HW_VLAN_RX);
> #endif
>
> -#ifdef NETIF_F_LLTX
> - netdev->features |= NETIF_F_LLTX;
> -#endif
> -
> /* Init PHY as early as possible due to power saving issue
> */ atl2_phy_init(&adapter->hw);
>
> diff --git a/drivers/net/atlx/atl2.h b/drivers/net/atlx/atl2.h
> index 6e1f28f..09974df 100644
> --- a/drivers/net/atlx/atl2.h
> +++ b/drivers/net/atlx/atl2.h
> @@ -462,7 +462,6 @@ struct atl2_adapter {
> u16 link_duplex;
>
> spinlock_t stats_lock;
> - spinlock_t tx_lock;
>
> struct work_struct reset_task;
> struct work_struct link_chg_task;
prev parent reply other threads:[~2008-09-26 1:24 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-09-25 0:35 [PATCH] net: remove LLTX in atl2 driver Kevin Hao
2008-09-25 20:30 ` Chris Snook
2008-09-25 20:55 ` Jeff Garzik
2008-09-25 22:34 ` Chris Snook
2008-09-25 23:58 ` Jay Cliburn
2008-09-26 1:20 ` Kevin Hao
2008-09-26 1:24 ` Chris Snook
2008-09-26 2:20 ` Kevin Hao
2008-09-26 1:24 ` Jay Cliburn [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=20080925202449.340fcfef@osprey.hogchain.net \
--to=jacliburn@bellsouth.net \
--cc=csnook@redhat.com \
--cc=jgarzik@redhat.com \
--cc=kexin.hao@windriver.com \
--cc=linux-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.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).