All of lore.kernel.org
 help / color / mirror / Atom feed
From: Frediano Ziglio <freddy77@gmail.com>
To: xen-devel@lists.xenproject.org
Cc: "Frediano Ziglio" <frediano.ziglio@citrix.com>,
	"Jan Beulich" <jbeulich@suse.com>,
	"Andrew Cooper" <andrew.cooper3@citrix.com>,
	"Roger Pau Monné" <roger.pau@citrix.com>,
	"Teddy Astie" <teddy.astie@vates.tech>,
	"Anthony PERARD" <anthony.perard@vates.tech>,
	"Juergen Gross" <jgross@suse.com>
Subject: [PATCH v4 01/16] libs/guest: Reduce number of parts in write_split_record
Date: Wed,  3 Jun 2026 14:05:48 +0100	[thread overview]
Message-ID: <20260603130603.776452-2-frediano.ziglio@cloud.com> (raw)
In-Reply-To: <20260603130603.776452-1-frediano.ziglio@cloud.com>

From: Frediano Ziglio <frediano.ziglio@citrix.com>

Small optimization.
There's no much sense to split the header in 2 pieces, it will
just take more time and space to reassemble them in the final
buffer.
This also avoids truncating combined_length to 32 bit in case of
64 bit machines potentially avoiding following record_length check
(it could still be truncated writing it in xc_sr_rhdr structure
but the following check will catch it).
The function become more coherent with following read_record
function.

Signed-off-by: Frediano Ziglio <frediano.ziglio@citrix.com>
--
Changes since v2:
- change prefix in subject.

Changes since v3:
- clarify commit message.
---
 tools/libs/guest/xg_sr_common.c | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/tools/libs/guest/xg_sr_common.c b/tools/libs/guest/xg_sr_common.c
index 7ccdc3b1f6..86c148c62f 100644
--- a/tools/libs/guest/xg_sr_common.c
+++ b/tools/libs/guest/xg_sr_common.c
@@ -59,11 +59,11 @@ int write_split_record(struct xc_sr_context *ctx, struct xc_sr_record *rec,
     static const char zeroes[(1u << REC_ALIGN_ORDER) - 1] = { 0 };
 
     xc_interface *xch = ctx->xch;
-    typeof(rec->length) combined_length = rec->length + sz;
+    size_t combined_length = rec->length + sz;
     size_t record_length = ROUNDUP(combined_length, REC_ALIGN_ORDER);
+    struct xc_sr_rhdr rhdr = { rec->type, combined_length };
     struct iovec parts[] = {
-        { &rec->type,       sizeof(rec->type) },
-        { &combined_length, sizeof(combined_length) },
+        { &rhdr,            sizeof(rhdr) },
         { rec->data,        rec->length },
         { buf,              sz },
         { (void *)zeroes,   record_length - combined_length },
-- 
2.54.0



  reply	other threads:[~2026-06-03 13:06 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-06-03 13:05 [PATCH v4 00/16] xenguest optimisations Frediano Ziglio
2026-06-03 13:05 ` Frediano Ziglio [this message]
2026-06-08 14:22   ` [PATCH v4 01/16] libs/guest: Reduce number of parts in write_split_record Roger Pau Monné
2026-06-03 13:05 ` [PATCH v4 02/16] libs/guest: Reduce number of I/O vectors in write_batch Frediano Ziglio
2026-06-08 14:42   ` Roger Pau Monné
2026-06-03 13:05 ` [PATCH v4 03/16] " Frediano Ziglio
2026-06-08 15:03   ` Roger Pau Monné
2026-06-03 13:05 ` [PATCH v4 04/16] libs/guest: Use a single write_exact in write_headers Frediano Ziglio
2026-06-08 15:26   ` Roger Pau Monné
2026-06-03 13:05 ` [PATCH v4 05/16] libs/guest: allocate various migration arrays just once Frediano Ziglio
2026-06-08 15:36   ` Andrew Cooper
2026-06-08 15:50     ` Roger Pau Monné
2026-06-08 15:49   ` Roger Pau Monné
2026-06-08 16:24     ` Andrew Cooper
2026-06-03 13:05 ` [PATCH v4 06/16] libs/call: cache up to 4 pages in hypercall bounce buffers Frediano Ziglio
2026-06-03 13:05 ` [PATCH v4 07/16] libs/guest: avoids using 2 indexes Frediano Ziglio
2026-06-03 13:05 ` [PATCH v4 08/16] libs/guest: fill directly iov structure Frediano Ziglio
2026-06-03 13:05 ` [PATCH v4 09/16] libs/ctrl: Allows writev_exact to change iov array Frediano Ziglio
2026-06-03 13:05 ` [PATCH v4 10/16] libs/guest: add xg_foreignmemory_copy_{from,to} Frediano Ziglio
2026-06-03 13:05 ` [PATCH v4 11/16] PoC: libs/guest: use foreign copy during migration Frediano Ziglio
2026-06-03 14:09   ` Andrew Cooper
2026-06-04 14:51     ` Frediano Ziglio
2026-06-03 13:05 ` [PATCH v4 12/16] xen: implement new foreign copy hypercall Frediano Ziglio
2026-06-03 13:39   ` Jan Beulich
2026-06-03 14:00     ` Andrew Cooper
2026-06-08 14:59   ` Teddy Astie
2026-06-03 13:06 ` [PATCH v4 13/16] privcmd: Add definition for new Linux privcmd to access new Xen hypercall Frediano Ziglio
2026-06-03 13:06 ` [PATCH v4 14/16] libs/guest: use new hypercall if available Frediano Ziglio
2026-06-03 13:06 ` [PATCH v4 15/16] libs/guest: finalize PoC Frediano Ziglio
2026-06-03 13:06 ` [PATCH Linux v4 16/16] xen/privcmd: Add new ABI to allow copying foreign memory Frediano Ziglio

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20260603130603.776452-2-frediano.ziglio@cloud.com \
    --to=freddy77@gmail.com \
    --cc=andrew.cooper3@citrix.com \
    --cc=anthony.perard@vates.tech \
    --cc=frediano.ziglio@citrix.com \
    --cc=jbeulich@suse.com \
    --cc=jgross@suse.com \
    --cc=roger.pau@citrix.com \
    --cc=teddy.astie@vates.tech \
    --cc=xen-devel@lists.xenproject.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.