On 11/20/2013 09:34 AM, Michael Dalton wrote: > Hi, > > After further reflection I think we're looking at two related issues: > (a) a memory leak that Jason has identified that occurs when a memory > allocation fails in receive_mergeable. Jasons commit solves this issue. > (b) virtio-net does not dequeue all buffers for a packet in the > case that an error occurs on receive and mergeable receive buffers is > enabled. > > For (a), this bug is new and due to changes in 2613af0ed18a, and the > net impact is memory leak on the physical page. However, I believe (b) > has always been possible in some form because if page_to_skb() returns > NULL (e.g., due to SKB allocation failure), receive_mergeable is never > called. AFAICT this is also the behavior prior to 2613af0ed18a. > > The net impact of (b) would be that virtio-net would interpret a packet > buffer that is in the middle of a mergeable packet as the start of a > new packet, which is definitely also a bug (and the buffer contents > could contain bytes that resembled a valid virtio-net header). > > A solution for (b) will require handling both the page_to_skb memory > allocation failures and the memory allocation failures in > receive_mergeable introduced by 2613af0ed18a. Ture, so we first need a patch to solve page_to_skb() failure which could be used for stable tree prior to 2613af0ed18a. Then another patch to solve the issue introduced by 2613af0ed18a which could be only used for 3.12 stable. Will draft patches for them. Thanks > > Best, > > Mike _______________________________________________ Virtualization mailing list Virtualization@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/virtualization