diff --git a/[refs] b/[refs] index 7345a9de50ad..0a1b21c89287 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: db7530797992bb2be703f9f3cc69b1a578f812f8 +refs/heads/master: af191367a752625b9f05a25a9a76c727b9b17cab diff --git a/trunk/net/core/dev.c b/trunk/net/core/dev.c index 42344d903692..7bd4cd4502c4 100644 --- a/trunk/net/core/dev.c +++ b/trunk/net/core/dev.c @@ -1214,6 +1214,19 @@ int __skb_linearize(struct sk_buff *skb, int gfp_mask) * A negative errno code is returned on a failure. A success does not * guarantee the frame will be transmitted as it may be dropped due * to congestion or traffic shaping. + * + * ----------------------------------------------------------------------------------- + * I notice this method can also return errors from the queue disciplines, + * including NET_XMIT_DROP, which is a positive value. So, errors can also + * be positive. + * + * Regardless of the return value, the skb is consumed, so it is currently + * difficult to retry a send to this method. (You can bump the ref count + * before sending to hold a reference for retry if you are careful.) + * + * When calling this method, interrupts MUST be enabled. This is because + * the BH enable code must have IRQs enabled so that it will not deadlock. + * --BLG */ int dev_queue_xmit(struct sk_buff *skb)