[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <m362moao1m.fsf@intrepid.localdomain>
Date: Tue, 26 Jul 2011 20:34:45 +0200
From: Krzysztof Halasa <khc@...waw.pl>
To: Neil Horman <nhorman@...driver.com>
Cc: netdev@...r.kernel.org, Karsten Keil <isdn@...ux-pingi.de>,
"David S. Miller" <davem@...emloft.net>,
Jay Vosburgh <fubar@...ibm.com>,
Andy Gospodarek <andy@...yhouse.net>,
Patrick McHardy <kaber@...sh.net>,
"John W. Linville" <linville@...driver.com>,
Greg Kroah-Hartman <gregkh@...e.de>,
Marcel Holtmann <marcel@...tmann.org>,
Johannes Berg <johannes@...solutions.net>
Subject: Re: [PATCH 2/2] net: Audit drivers to identify those needing IFF_TX_SKB_SHARING cleared
Neil Horman <nhorman@...driver.com> writes:
> After the last patch, We are left in a state in which only drivers calling
> ether_setup have IFF_TX_SKB_SHARING set (we assume that drivers touching real
> hardware call ether_setup for their net_devices and don't hold any state in
> their skbs. There are a handful of drivers that violate this assumption of
> course, and need to be fixed up. This patch identifies those drivers, and marks
> them as not being able to support the safe transmission of skbs by clearning the
> IFF_TX_SKB_SHARING flag in priv_flags
> --- a/drivers/net/wan/hdlc_fr.c
> +++ b/drivers/net/wan/hdlc_fr.c
> @@ -1074,9 +1074,10 @@ static int fr_add_pvc(struct net_device *frad, unsigned int dlci, int type)
>
> used = pvc_is_used(pvc);
>
> - if (type == ARPHRD_ETHER)
> + if (type == ARPHRD_ETHER) {
> dev = alloc_netdev(0, "pvceth%d", ether_setup);
> - else
> + dev->priv_flags &= ~IFF_TX_SKB_SHARING;
> + } else
> dev = alloc_netdev(0, "pvc%d", pvc_setup);
>
> if (!dev) {
That's right, hdlc_fr has to add an additional header.
Acked-by: Krzysztof HaĆasa <khc@...waw.pl>
--
Krzysztof Halasa
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists