From: Zhao Liu Date: Tue, 18 Mar 2025 13:02:07 +0000 (+0800) Subject: rust/vmstate: Fix num field when varray flags are set X-Git-Tag: v10.0.0-rc1~2^2~13 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c3d80af5ecf4f00db4a8d3ac5eca6edc0c9f061e;p=thirdparty%2Fqemu.git rust/vmstate: Fix num field when varray flags are set Array type vmstate has the VMStateField with `num` equals its length. When the varray vmstate is built based a array type, the `num` field should be cleaned to 0, because varray uses `num_offset` instead of `num` to store elements number information. Signed-off-by: Zhao Liu Link: https://lore.kernel.org/r/20250318130219.1799170-4-zhao1.liu@intel.com Signed-off-by: Paolo Bonzini --- diff --git a/rust/qemu-api/src/vmstate.rs b/rust/qemu-api/src/vmstate.rs index 9533b1250f..e3233303f2 100644 --- a/rust/qemu-api/src/vmstate.rs +++ b/rust/qemu-api/src/vmstate.rs @@ -275,6 +275,7 @@ impl VMStateField { assert!((self.flags.0 & VMStateFlags::VMS_ARRAY.0) != 0); self.flags = VMStateFlags(self.flags.0 & !VMStateFlags::VMS_ARRAY.0); self.flags = VMStateFlags(self.flags.0 | flag.0); + self.num = 0; // varray uses num_offset instead of num. self }