From nobody Fri Apr 4 05:09:31 2025 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass header.i=@intel.com; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=intel.com ARC-Seal: i=1; a=rsa-sha256; t=1742223950; cv=none; d=zohomail.com; s=zohoarc; b=X2CauNy9/Vshtnb67PfD+mkUdifaoRw56u5ilfcXmeKNb39ffGkPViZ4xmwH956d500q17qNYdZs/eFTKpgTYVgtHhjcWPxVkChkD1ynUHQWgSruiAbgnYvKusPzFoOdR6q9HxMQFk5pSfsQ/zg6WCmiwH7oVt2nT3G9EXFPQ7c= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1742223950; h=Content-Transfer-Encoding:Cc:Cc:Date:Date:From:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:Subject:To:To:Message-Id:Reply-To; bh=+yu6+upg+1YCBu3ClROZSz+vH2Miz4wM7cy8tqPzf0I=; b=Q21P1gX7dR/byJcFuXlX8yQk+4mQqrsZIqsxpitg1ul7AcTkblibMcKfXdXYRLNZQ86eCG3c9B52rIZmmcOkI4kTdEobh5+pYpojsDA2y9Im9gv1tEMePFuP/s2dqzvssIZWhVcWA17COQ/5xIp7VQH59jZWrQmhhrySaFM5dk8= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass header.i=@intel.com; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass header.from= (p=none dis=none) Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1742223950743758.395115811385; Mon, 17 Mar 2025 08:05:50 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1tuBqc-0005EK-34; Mon, 17 Mar 2025 10:53:46 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1tuBpz-0004z4-TI; Mon, 17 Mar 2025 10:53:10 -0400 Received: from mgamail.intel.com ([192.198.163.10]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1tuBpv-00061l-MP; Mon, 17 Mar 2025 10:53:06 -0400 Received: from orviesa004.jf.intel.com ([10.64.159.144]) by fmvoesa104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Mar 2025 07:52:39 -0700 Received: from liuzhao-optiplex-7080.sh.intel.com ([10.239.160.39]) by orviesa004.jf.intel.com with ESMTP; 17 Mar 2025 07:52:38 -0700 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1742223184; x=1773759184; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=jlKXnezCHcjIhH3WjaMUbqvSVZ9t93vIsbszukrJ9VI=; b=aI4vBU5ZJCNcBv+lQsa8kcESs4Ej2gQiXTLmPjFLbTDqUR+NKFBDmOGV 5NNMzmzWbDCMJ6URrLj7dhkzxOXrTkaFb3Xb5PUHvbU/hQEyyMSVJZxX9 GySwSXAIwCZziYvvux/7T418oJQ0RjLsx9iw7zH/v8PSnM9rHzck3Z+IG i/U6hdM8N5dBeFCassGcWtK2Z4DcvaXcWXbSyM+baBJ9WjkSauYIhDGXF UOHJDAflb1bmxB3XOQKOvcAtbOMRk8biiwO6RKYq2dMKmde+iJLTxKJj8 ZSaY7HNcx+dcTaDbUlqcXdNT9vRHyta6ZiB+gWUvTBNcvHooqB1YxamFi A==; X-CSE-ConnectionGUID: l3eGhOZWSjSt6dx6Zh3WlQ== X-CSE-MsgGUID: mM7fj2amSWyAPdcCpuaxPQ== X-IronPort-AV: E=McAfee;i="6700,10204,11376"; a="54694608" X-IronPort-AV: E=Sophos;i="6.14,254,1736841600"; d="scan'208";a="54694608" X-CSE-ConnectionGUID: BgMRYzjmSuWDrG9U2pv3QA== X-CSE-MsgGUID: CKovuUqgSwibt5uVUay4gQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.14,254,1736841600"; d="scan'208";a="126988526" From: Zhao Liu To: Paolo Bonzini Cc: qemu-devel@nongnu.org, qemu-rust@nongnu.org, Zhao Liu Subject: [PATCH 09/17] rust/vmstate: Fix unnecessary VMState bound of with_varray_flag() Date: Mon, 17 Mar 2025 23:12:28 +0800 Message-Id: <20250317151236.536673-10-zhao1.liu@intel.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20250317151236.536673-1-zhao1.liu@intel.com> References: <20250317151236.536673-1-zhao1.liu@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=192.198.163.10; envelope-from=zhao1.liu@intel.com; helo=mgamail.intel.com X-Spam_score_int: -46 X-Spam_score: -4.7 X-Spam_bar: ---- X-Spam_report: (-4.7 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.335, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_MED=-2.3, RCVD_IN_VALIDITY_RPBL_BLOCKED=0.001, RCVD_IN_VALIDITY_SAFE_BLOCKED=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @intel.com) X-ZM-MESSAGEID: 1742223963590019100 Content-Type: text/plain; charset="utf-8" The VMState type bound is not used in with_varray_flag(). And for vmstate_struct, Rust cannot infer the type of `num` from the call_func_with_field(), so this causes the compiling error because it complains "cannot satisfy `_: VMState`" in with_varray_flag(). Note Rust can infer the type in vmstate_of macro so that with_varray_flag() can work at there. It is possible that the different initialization ways in the two macros cause differences in Rust's type inference. But in fact, the VMState type bound is not used in with_varray_flag() and vmstate_varray_flag() has already checked the VMState type, it's safe to drop VMState bound of with_varray_flag(), which can fix the above compiling error. Signed-off-by: Zhao Liu --- rust/qemu-api/src/vmstate.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rust/qemu-api/src/vmstate.rs b/rust/qemu-api/src/vmstate.rs index a9d97d9a856e..2749e8af2b5a 100644 --- a/rust/qemu-api/src/vmstate.rs +++ b/rust/qemu-api/src/vmstate.rs @@ -275,7 +275,7 @@ pub const fn with_pointer_flag(mut self) -> Self { } =20 #[must_use] - pub const fn with_varray_flag(mut self, flag: VMStateFlags= ) -> VMStateField { + pub const fn with_varray_flag(mut self, flag: VMStateFlags) -> VMState= Field { assert!((self.flags.0 & VMStateFlags::VMS_ARRAY.0) !=3D 0); self.flags =3D VMStateFlags(self.flags.0 & !VMStateFlags::VMS_ARRA= Y.0); self.flags =3D VMStateFlags(self.flags.0 | flag.0); --=20 2.34.1