From patchwork Wed May 14 23:40:56 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Pierrick Bouvier X-Patchwork-Id: 889898 Delivered-To: patch@linaro.org Received: by 2002:adf:fd8a:0:b0:3a1:f579:ae88 with SMTP id d10csp2876062wrr; Wed, 14 May 2025 16:43:43 -0700 (PDT) X-Forwarded-Encrypted: i=2; AJvYcCUyPge/RCRJfZOBoiYQhyEp90smFi7jkIGnQ1Y+hXmynzQm7ZG0hPONWF7deNfgmAm2uoa1BA==@linaro.org X-Google-Smtp-Source: AGHT+IELsFlUVu0yLEOIHLswB0s2cv/tLlmdF/uMzE/oBJXkwlzjU3bIV3X/MUoCQok1lzdls+cr X-Received: by 2002:a05:622a:2296:b0:475:b03:a054 with SMTP id d75a77b69052e-49495cc2e7amr77814071cf.25.1747266223232; Wed, 14 May 2025 16:43:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1747266223; cv=none; d=google.com; s=arc-20240605; b=C8OA/rrfC/7VdqhV9y2vaG5Pg+pEJApkQZl/FWO1Nyis16/jTV/fPSJaDpK/KwdbWN mEXn8oFYsFPOJI8sKHxY/QRojzl9CDDGGaQNgYsJ+76Obbnkk+5jCCbwhUxPiZraWgGX rVv4hDX7iUGG1dmFkXAZn+6Jut+tuetV55vGef6CvVBY3JIgI9YNECkZevdNMmkOKYo1 BNDVXw+JmsUq1OQCEyaxjT6SGEegLCoMuyLPS1biE1Icw10+zLtTP46I2wf9lv0NdQgZ Zf3Fz/2T4sapOtkOO/u7mUWtMKNiV0KSwFuNkPWWUC3cEtMa+sTkUUGCVyYK6kwckT9p A61Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20240605; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:message-id:date:subject:cc:to:from:dkim-signature; bh=hV+Eqa8t8C/H2nvJsqD+sk8+D76UncNSLAFm8m6dk08=; fh=VLmoI/6EX8QpenFjusv8qhWaEfIPciazAbyYTbMJFJo=; b=hh6uWJpJLzZq9VrGe4QrsDnjbwaCu+2P+biefzh0HnyHI1l8VjT9wiJ9YM8UNTIdHx DQQLKTUCkFjOYIdFTwE5ceXLMEnpOneGx9pjTlrK087pqq0bmGLHdVuBxa4hDXCdJ6nB aKJPZOktKwd4Y2NJY12yAm7uVChsri6d/osHsVsnN/Ksrg206PxCV6mwzhl9UUj80q3J orQmsPLarSTNgbEhKcEqpcoO/sc9o/EMdLCP41Q/VlKuLI3Pqfcp++S+saKcSM0iL0mV Uizgj6ChJO0Z0Gk0wN/rc1OYL3+hesMBN6ih3zH6jpuRD9Q1jzNH9o7wIiew0sSKucDk 0eqA==; dara=google.com ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=K5HDoJlS; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org; dara=neutral header.i=@linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id d75a77b69052e-49452479846si152891531cf.159.2025.05.14.16.43.43 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Wed, 14 May 2025 16:43:43 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=K5HDoJlS; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org; dara=neutral header.i=@linaro.org Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1uFLj1-0001O3-AB; Wed, 14 May 2025 19:41:23 -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 1uFLiy-0001GJ-7P for qemu-devel@nongnu.org; Wed, 14 May 2025 19:41:20 -0400 Received: from mail-pg1-x529.google.com ([2607:f8b0:4864:20::529]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1uFLiw-00031j-9P for qemu-devel@nongnu.org; Wed, 14 May 2025 19:41:19 -0400 Received: by mail-pg1-x529.google.com with SMTP id 41be03b00d2f7-af51596da56so213443a12.0 for ; Wed, 14 May 2025 16:41:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1747266076; x=1747870876; darn=nongnu.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=hV+Eqa8t8C/H2nvJsqD+sk8+D76UncNSLAFm8m6dk08=; b=K5HDoJlSwIbV/BfhN/HJi+2QyX1QGAVVjL4es3t/LZUszgA4rw7JTWLOE8TNt9mjPJ gy+ujpbmqrj6Sb5O+ord1iradwGoLO7C/kN1XeaR+GjAaL5XS5N0F6OTgXD3yOTFT1Dm IM1gMZaaxxi+zkK9l8F9JWaQLfbCXjBBn681l07M4b7sft/TFzZafdJceHntb2Q+THET KjO5nLKOyzcepTC5n6ExEXaJH/zHpW3Fjz3ckbPC+MDEhLOqDuXqHSBt3oEsKBleASN8 sV/MRmXFTzUMm/y/5Y9xLH5Y6rKTgrIlWPGRt01jXPcsi4i26hAFECEizrlABndbk1Cw VRYQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1747266076; x=1747870876; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=hV+Eqa8t8C/H2nvJsqD+sk8+D76UncNSLAFm8m6dk08=; b=B6tILBizDZZ7nWJFYGmknA1RenuMvaZ61dfhLbg+Q0AUy7uZI/dNwupg7raBAVLnUP R7AqftnAcv86J7w8mMCoQ7JmIH0xtFMwYNHhXXBHfj5x10TtjoaJtyBbmnlHfB6qVmZ6 JMH9HtXi7qOIa7LLgXKCt6szTzD/g+g2L3YQo2l3JgnwCc97Xf7clXjO6X21ATF7MsFk alUmIG70u6QBeGabXHoTBmOvi/yiFQVPlhNdHCCNfuVz5uV6N+vxUe6Qc7tx6o1xSyIj xdKwIUSASeVUYup6KfA/0AObEl+GAmU5AwyCigsatcYYkiF4J378wybbSeQ5PxMhbAmF p9ZA== X-Gm-Message-State: AOJu0Yw7OMzb+/aa76H7eGjbEFhvCuTsi23m03OkYH3KVjTSXd7rJhHu y2k1uos/FHuabzz3KdDRJEdBejbDKLkZIGkpopbC05yI5AcmRf9Xz2oV44fbFxjbh5/kJHKeu/T 1VDU= X-Gm-Gg: ASbGncs0MVyetf+5ZMZpZeYNIAZUr5KeGCGUez3l9hbNAm7EN6zCtWxQFefokXf0ZK2 Aykc0QnylzA2N1VbRTHOUykIUD5UOLGABaBaxKpYDpJ6H+8jRXm6zlY3Kujq3EO1+7IFowKTp8V hHfGE7uWD7081xy0PL70m2yPpQ1skJ4YnVuHVov5Ri7OW4YUNqT7kowbG0ucdwcnSzd/83dHSNG t9BbVp3VYr6DAOLXM3bHfM2FjjfTlnQBB1O+m4RiAVpSLXxFhbmkSr3o95r/2sO9xaZlrjw6hZW jitUshtR3w9YLpVG6KbubXpeURsIvq5ubXU3BJZWuNDYonVqL/w= X-Received: by 2002:a17:903:2349:b0:21f:4649:fd49 with SMTP id d9443c01a7336-231982c6f68mr74745145ad.49.1747266075787; Wed, 14 May 2025 16:41:15 -0700 (PDT) Received: from pc.. ([38.41.223.211]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-22fc828b4e4sm104583615ad.182.2025.05.14.16.41.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 14 May 2025 16:41:15 -0700 (PDT) From: Pierrick Bouvier To: qemu-devel@nongnu.org Cc: Pierrick Bouvier , Michael Roth , alex.bennee@linaro.org, Paolo Bonzini , Thomas Huth , berrange@redhat.com, Richard Henderson , peter.maydell@linaro.org, Markus Armbruster , =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= Subject: [PATCH 00/12] qapi: remove all TARGET_* conditionals from the schema Date: Wed, 14 May 2025 16:40:56 -0700 Message-ID: <20250514234108.3746675-1-pierrick.bouvier@linaro.org> X-Mailer: git-send-email 2.47.2 MIME-Version: 1.0 Received-SPF: pass client-ip=2607:f8b0:4864:20::529; envelope-from=pierrick.bouvier@linaro.org; helo=mail-pg1-x529.google.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, 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+patch=linaro.org@nongnu.org Sender: qemu-devel-bounces+patch=linaro.org@nongnu.org This series exposes all qmp commands for any target unconditionally, allowing to compile QAPI generated code without any TARGET conditionals. Based on original RFC from Daniel P. Berrangé: https://lore.kernel.org/qemu-devel/20250508135816.673087-1-berrange@redhat.com/ v1 Reviewed-by: Richard Henderson --- - remove file qapi/misc-target.json (Markus) - remove qapi/*-target.json from MAINTAINERS (Markus) - remove qapi_specific_outputs from qapi/meson.build (Markus) - update comment in rtc-reset-reinjection stub (Markus) - build QAPI generated code only once Daniel P. Berrangé (9): qapi: expose rtc-reset-reinjection command unconditionally qapi: expand docs for SEV commands qapi: make SEV commands unconditionally available qapi: expose query-gic-capability command unconditionally qapi: make SGX commands unconditionally available qapi: make Xen event commands unconditionally available qapi: remove the misc-target.json file qapi: make most CPU commands unconditionally available qapi: make s390x specific CPU commands unconditionally available Philippe Mathieu-Daudé (1): qapi: Make CpuModelExpansionInfo::deprecated-props optional and generic Pierrick Bouvier (2): qapi: remove qapi_specific_outputs from meson.build qapi: make all generated files common MAINTAINERS | 1 - qapi/machine-s390x.json | 121 +++++ qapi/machine-target.json | 523 ---------------------- qapi/machine.json | 363 +++++++++++++++ qapi/misc-arm.json | 49 ++ qapi/{misc-target.json => misc-i386.json} | 154 +++---- qapi/qapi-schema.json | 5 +- include/hw/s390x/cpu-topology.h | 2 +- hw/i386/kvm/xen-stubs.c | 13 - hw/i386/kvm/xen_evtchn.c | 2 +- hw/i386/monitor.c | 2 +- hw/i386/sgx-stub.c | 13 - hw/i386/sgx.c | 2 +- hw/s390x/cpu-topology.c | 4 +- hw/s390x/s390-skeys.c | 1 - stubs/monitor-arm-gic.c | 12 + stubs/monitor-cpu-s390x-kvm.c | 22 + stubs/monitor-cpu-s390x.c | 23 + stubs/monitor-cpu.c | 21 + stubs/monitor-i386-rtc.c | 14 + stubs/monitor-i386-sev.c | 36 ++ stubs/monitor-i386-sgx.c | 17 + stubs/monitor-i386-xen.c | 16 + target/arm/arm-qmp-cmds.c | 4 +- target/i386/cpu-system.c | 2 +- target/i386/cpu.c | 2 +- target/i386/monitor.c | 1 - target/i386/sev-system-stub.c | 32 -- target/i386/sev.c | 2 +- target/loongarch/loongarch-qmp-cmds.c | 2 +- target/mips/system/mips-qmp-cmds.c | 12 +- target/ppc/ppc-qmp-cmds.c | 12 +- target/riscv/riscv-qmp-cmds.c | 2 +- target/s390x/cpu_models_system.c | 2 +- tests/qtest/qmp-cmd-test.c | 1 + qapi/meson.build | 18 +- stubs/meson.build | 8 + 37 files changed, 811 insertions(+), 705 deletions(-) create mode 100644 qapi/machine-s390x.json delete mode 100644 qapi/machine-target.json create mode 100644 qapi/misc-arm.json rename qapi/{misc-target.json => misc-i386.json} (76%) create mode 100644 stubs/monitor-arm-gic.c create mode 100644 stubs/monitor-cpu-s390x-kvm.c create mode 100644 stubs/monitor-cpu-s390x.c create mode 100644 stubs/monitor-cpu.c create mode 100644 stubs/monitor-i386-rtc.c create mode 100644 stubs/monitor-i386-sev.c create mode 100644 stubs/monitor-i386-sgx.c create mode 100644 stubs/monitor-i386-xen.c