linux-block.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* transferring bvecs over the network in drbd
@ 2025-05-08  6:45 Christoph Hellwig
  2025-05-08  8:39 ` Lars Ellenberg
  0 siblings, 1 reply; 3+ messages in thread
From: Christoph Hellwig @ 2025-05-08  6:45 UTC (permalink / raw)
  To: Philipp Reisner, Lars Ellenberg, Christoph Böhmwalder
  Cc: drbd-dev, linux-block

Hi all,

I recently went over code that directly access the bio_vec bv_page/
bv_offset members and the code in _drbd_send_bio/_drbd_send_zc_bio
came to my attention.

It iterates the bio to kmap all segments, and then either does a
sock_sendmsg on a newly created kvec iter, or one one a new bvec iter
for each segment.  The former can't work on highmem systems and both
versions are rather inefficient.

What is preventing drbd from doing a single sock_sendmsg with the
bvec payload?  nvme-tcp (nvme_tcp_init_iter0 is a good example for
doing that, or the sunrpc svcsock code using it's local bvec list
(svc_tcp_sendmsg).

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2025-05-08 10:06 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-05-08  6:45 transferring bvecs over the network in drbd Christoph Hellwig
2025-05-08  8:39 ` Lars Ellenberg
2025-05-08 10:06   ` Christoph Hellwig

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).