From patchwork Mon Jan 6 20:02:51 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= X-Patchwork-Id: 855281 Delivered-To: patch@linaro.org Received: by 2002:a5d:4888:0:b0:385:e875:8a9e with SMTP id g8csp9620684wrq; Mon, 6 Jan 2025 12:04:12 -0800 (PST) X-Forwarded-Encrypted: i=2; AJvYcCUe9HuAG2TMqvY+cAyTTAjUUmXXTc4an890+8VAejKVp42BHyNBHsKuC4NBBJEI6o1tDvMRgA==@linaro.org X-Google-Smtp-Source: AGHT+IGiUUkJ1h61wALSuwi2SsLKLVyosilSQkhyvJbaIrKtpOJNqFVJmaQCxoAsKXvc9Aaf9ZYZ X-Received: by 2002:a05:6102:568d:b0:4af:adf8:523f with SMTP id ada2fe7eead31-4b2cc35f0f9mr45916924137.9.1736193851744; Mon, 06 Jan 2025 12:04:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1736193851; cv=none; d=google.com; s=arc-20240605; b=C98OE2oNF36WgIduuJkf1T2a5pbUiWIgZYRKe188hx1wCAmjVzqzX71NGzqOCVCiBu gXth/3GwKmFkwQfAMm7fhewjZGCQJadLTt1nvLeQ4tMVa+d08gTtyfUEEgkQkRMTHN9p KQ2kZUpK+SSZFLs3G/g2Wmg5HoZ3mMQJdgEJpV0Wl0qWJuJTn6LCyo2wUM+2L1as+Wjs MppNXS0WPr8j5k7lG0gBdY1muqhJ/xXNRGHtDFbCqwFBZCivU3bjGu8+VNYGYyVU53RH osCPjW8nTv99gn0r2C+717xoTSr2ozrKcUZn9wPdpax1hSE3ButKFhYO3ce+yDcAuZtG R/7g== 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=IVQDyU0aZGqnbGo58WYklNw0MeL8aFrKkG5Vri/XHzI=; fh=YIGq2OjjvJJvfOLa9lPT9cLAg4GPwPsWWWag+t9HO1Y=; b=FYgBZ2XOkfUoKmO6YqaCLXTL+QzHuwAvS3DT/JQX9SHx2/VRlDefDFnysDHZjLf6zP /AfFB1L9rJPrKfFuDQv5gQFWrkbrHQ4/tlUdrguGTVWWHYWm7T8wPgMuLvKqswdPhpWH tXA2dO9g8p8fIixs72FDLorPIWIZbK6dhSNGfbqOtu/xRJ2DDjtIwIKTayPaOvyNAR2g weB/Wp1PCbJvahPKmXS6+UDzpDP9QhSsEsd//cG9c5NSxdsIvo+NoSnPf9KATM/S7PPq P0YkaFa0yswmpQ96eXgAh2H5jAjLlQlNXPd3nQlOyI+YoLB5VQJSfvZfalPSu0WpMDen fe9w==; dara=google.com ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=kUQtZ8mm; 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 ada2fe7eead31-4b2bf992ccfsi9430762137.13.2025.01.06.12.04.11 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Mon, 06 Jan 2025 12:04:11 -0800 (PST) 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=kUQtZ8mm; 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 1tUtJd-0002W6-82; Mon, 06 Jan 2025 15:03:09 -0500 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 1tUtJb-0002Va-Bf for qemu-devel@nongnu.org; Mon, 06 Jan 2025 15:03:07 -0500 Received: from mail-wm1-x334.google.com ([2a00:1450:4864:20::334]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1tUtJZ-000395-FC for qemu-devel@nongnu.org; Mon, 06 Jan 2025 15:03:06 -0500 Received: by mail-wm1-x334.google.com with SMTP id 5b1f17b1804b1-4362bae4d7dso106046805e9.1 for ; Mon, 06 Jan 2025 12:03:05 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1736193783; x=1736798583; 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=IVQDyU0aZGqnbGo58WYklNw0MeL8aFrKkG5Vri/XHzI=; b=kUQtZ8mmiPkdHTlMB9xdpp65ITppnr/j+WZjxIM5eLAr0oncSaXmdo7H30QnAtUOzx gG//LNx4FJRJ2X2uEYupahCpsyBxYVArR4GG6WMPmup6JnyxgiCd795I4AKMqOq1Tl2r iSUeJNzRLhot8RuggB37lPQBdBW9oIJkCZauQTSg8h+vwddIdlR/VBbLQ7POM7qb9H2G c+70FtlruxCFmA3UOh+yaugrBrm5oKGBHalcZt1DeYn8qKX1u2Gh1B3KCSmnA84MTaPh 5bLHcCYp6zvcAo9MwLtXgKMdhSj+ZaaNmXJHxHQLC0xA/OHUsvzM5m4pB0S6jaXk8XA1 aOMQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1736193783; x=1736798583; 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=IVQDyU0aZGqnbGo58WYklNw0MeL8aFrKkG5Vri/XHzI=; b=s3HFWStX/WdlVW4wucaSAVhtC29EczENzma80PqrYRgzuWucWJGUy8YkO5DDoptG58 dDabavnZh/1ofO8LcCZjFm97a7xobz7BigT9wCUqo3d838xNzc4vidyYJcyO9gpTyJDO WXUMXSBIbFszt5msom4uqeWad87rtj/ouWNDS4CbKLrTlBDNKRK8vzn14Mi8DiX4ec1K HKo9deDe8Ym3bttkNoHeGIIkXg1F97yVdzUK/EDC6UXCLTAQ5x6e8KoGbtpp6KJg7ipR 5nX7X1B22KwTC/xViBTvEZFVPDSPTd2CIZqSK6bFXCBz2PEqjt8RVCGX6pembKnSTVP+ jKSA== X-Gm-Message-State: AOJu0YwnjQZcOL0i7fQVcbZnRQT62lYjSndcJQP/qNtsos+wmqr+JpdK MuyOP09HteaIbCx+IdMJECIYt+tryIndyR4eqKux3fD91boB1O+FToTm1aPe5TkaGc0Q46FBZd0 8zZM= X-Gm-Gg: ASbGnct5nkTaiiPpChdbWDYBDTGgYLxSx9IB+O1Ar9BfJorZH+ewpPN9qHip5FF4ov/ x3vsg7EKGGlQALMHskaeeNjfuhu3+3qbgWruRc4V4Eb6q0eVIb1etj8fz8i1fyhwDkhECGLhcr6 hCcw5bg/6dUUIi+ufAH7QdpJQwkAUjd41H2QXcWtLgukTNuNhyBKCg0RnhgogUplqifPvPthqqs KF/bdGctpMwJ4o/KaTYMWaX1ORhF/wLN6uXECMiBTNXt9SqedZnAuVhJyfM7uC+G6uJGpAAgKSY edFHepgQb1GzFU7Cu/pwF1SqrqjAkAg= X-Received: by 2002:a05:600c:450f:b0:434:fb65:ebbb with SMTP id 5b1f17b1804b1-436686461cbmr539399575e9.17.1736193783280; Mon, 06 Jan 2025 12:03:03 -0800 (PST) Received: from localhost.localdomain (88-187-86-199.subs.proxad.net. [88.187.86.199]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-43656b3b2a4sm611962245e9.27.2025.01.06.12.02.59 (version=TLS1_3 cipher=TLS_CHACHA20_POLY1305_SHA256 bits=256/256); Mon, 06 Jan 2025 12:03:01 -0800 (PST) From: =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= To: qemu-devel@nongnu.org Cc: Daniel Henrique Barboza , =?utf-8?b?RnLDqWQ=?= =?utf-8?b?w6lyaWMgQmFycmF0?= , Stefano Stabellini , Ilya Leoshkevich , Cameron Esfahani , Paolo Bonzini , kvm@vger.kernel.org, Alexander Graf , Paul Durrant , David Hildenbrand , Halil Pasic , =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= , Marcel Apfelbaum , xen-devel@lists.xenproject.org, qemu-arm@nongnu.org, =?utf-8?q?C=C3=A9dric_?= =?utf-8?q?Le_Goater?= , Yanan Wang , Reinoud Zandijk , Peter Maydell , qemu-s390x@nongnu.org, Riku Voipio , Anthony PERARD , Alistair Francis , Sunil Muthuswamy , Christian Borntraeger , Nicholas Piggin , Richard Henderson , Marcelo Tosatti , Thomas Huth , Roman Bolshakov , "Edgar E . Iglesias" , Zhao Liu , Phil Dennis-Jordan , David Woodhouse , Harsh Prateek Bora , Nina Schoetterl-Glausch , "Edgar E. Iglesias" , Eduardo Habkost , qemu-ppc@nongnu.org, Daniel Henrique Barboza , "Michael S. Tsirkin" , Anton Johansson Subject: [RFC PATCH 0/7] accel: Add per-accelerator vCPUs queue Date: Mon, 6 Jan 2025 21:02:51 +0100 Message-ID: <20250106200258.37008-1-philmd@linaro.org> X-Mailer: git-send-email 2.47.1 MIME-Version: 1.0 Received-SPF: pass client-ip=2a00:1450:4864:20::334; envelope-from=philmd@linaro.org; helo=mail-wm1-x334.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 Hi, Currently we register all vCPUs to the global 'cpus_queue' queue, however we can not discriminate per accelerator or per target architecture (which might happen in a soon future). This series tries to add an accelerator discriminator, so accelerator specific code can iterate on its own vCPUs. This is required to run a pair of HW + SW accelerators like the (HVF, TCG) or (KVM, TCG) combinations. Otherwise, i.e. the HVF core code could iterate on TCG vCPUs... To keep it simple and not refactor heavily the code base, we introduce the CPU_FOREACH_TCG/HVF/KVM() macros, only defined for each accelerator. This is just a RFC to get some thoughts whether this is heading in the correct direction or not ;) Regards, Phil. Philippe Mathieu-Daudé (7): cpus: Restrict CPU_FOREACH_SAFE() to user emulation cpus: Introduce AccelOpsClass::get_cpus_queue() accel/tcg: Implement tcg_get_cpus_queue() accel/tcg: Use CPU_FOREACH_TCG() accel/hw: Implement hw_accel_get_cpus_queue() accel/hvf: Use CPU_FOREACH_HVF() accel/kvm: Use CPU_FOREACH_KVM() accel/tcg/tcg-accel-ops.h | 10 ++++++++++ include/hw/core/cpu.h | 11 +++++++++++ include/system/accel-ops.h | 6 ++++++ include/system/hvf_int.h | 4 ++++ include/system/hw_accel.h | 9 +++++++++ include/system/kvm_int.h | 3 +++ accel/accel-system.c | 8 ++++++++ accel/hvf/hvf-accel-ops.c | 9 +++++---- accel/kvm/kvm-accel-ops.c | 1 + accel/kvm/kvm-all.c | 14 +++++++------- accel/tcg/cputlb.c | 7 ++++--- accel/tcg/monitor.c | 3 ++- accel/tcg/tb-maint.c | 7 ++++--- accel/tcg/tcg-accel-ops-rr.c | 10 +++++----- accel/tcg/tcg-accel-ops.c | 16 ++++++++++++---- accel/tcg/user-exec-stub.c | 5 +++++ accel/xen/xen-all.c | 1 + cpu-common.c | 10 ++++++++++ hw/i386/kvm/clock.c | 3 ++- hw/intc/spapr_xive_kvm.c | 5 +++-- hw/intc/xics_kvm.c | 5 +++-- system/cpus.c | 5 +++++ target/arm/hvf/hvf.c | 4 ++-- target/i386/kvm/kvm.c | 4 ++-- target/i386/kvm/xen-emu.c | 2 +- target/i386/nvmm/nvmm-accel-ops.c | 1 + target/i386/whpx/whpx-accel-ops.c | 1 + target/s390x/kvm/kvm.c | 2 +- target/s390x/kvm/stsi-topology.c | 3 ++- 29 files changed, 130 insertions(+), 39 deletions(-) Reviewed-by: Daniel Henrique Barboza