Re: [PATCH][RFC 23/23]: Support for zero-copy TCP transmit of userspace data

From: Jeremy Fitzhardinge
Date: Fri Dec 19 2008 - 17:21:38 EST


Evgeniy Polyakov wrote:
On Fri, Dec 19, 2008 at 12:21:41PM -0800, Jeremy Fitzhardinge (jeremy@xxxxxxxx) wrote:
I think Rusty has a patch to put some kind of put notifier in struct skb_shared_info, but I'm not sure of the details.

Yes, he added destructor callback into shared info.

There maybe a problem though, if iscsi will run over xen network, but in
this case xen may copy the data, or iscsi may do that after determining
that underlying network device does not allow shared info destructor
(vis device/route flag for example).

Xen only needs the callback in the case of traffic originating in another Xen domain. If iscsi is involved, it will be running in the other domain, and so all its callbacks and so on will happen there. There's no conflict.

Wouldn't you only need to do the lookup on the last put?

An external lookup table might well for for us, if the net_put_page() change is acceptable to the network folk.

That sounds like the best solution for this problem.

An external lookup would just need to change put_page -> net_put_page, I think.

David, will you accept shared info destructor?

I'm not very familiar with the network stack, but am I right in assuming that the shared_info destructor would be called when the network stack has finished with all the pages it refers to? And those pages could be the combination of pages separately submitted in different skbs?

J
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/