From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751423; cv=none; d=zohomail.com; s=zohoarc; b=ln3GlHiGFjQ78XKK7WOlZ+lkO8wG3a898l0Y1chGBpDwLF/+ZwOJ5rlzbOaRzXwiu3LnaCUh0q6pGFtV406WLyrGD1tKjmVM0NzlH7r1pp10NgQ+35D72ZtVxNMQW+1nuXW+jHoQ2su5n5nUanKeSdxWIlfn2b6HJEEBq8o5/BM= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751423; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=0JYOu0qx3JmQq4x7McLpyb3kJqh6JTUS1pVf9/nHHO0=; b=L5L35vqlSM12/j4zsW0mUyE5GrOelFcn2p8Qn5oU7nZJJny9E7vJcsqkwcGiUUImtrzTR3jQ+1cRbsNv7DHqXCX3P997gPr5eJn1ffaHwRnY/dOV9WCq/seg42sbIKKYtBCdZ2cUyFvBiHWx+BkAecj73Gu4T5DQcfYoXZLEkHs= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751423508844.8569021965017; Tue, 25 Oct 2022 19:30:23 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtK-0004dU-Rg; Tue, 25 Oct 2022 22:11:39 -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 1onVtJ-0004ZL-Gg for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:37 -0400 Received: from mail-pf1-x431.google.com ([2607:f8b0:4864:20::431]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtA-00010y-R4 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:34 -0400 Received: by mail-pf1-x431.google.com with SMTP id y13so9348991pfp.7 for ; Tue, 25 Oct 2022 19:11:27 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=0JYOu0qx3JmQq4x7McLpyb3kJqh6JTUS1pVf9/nHHO0=; b=ARaRD+18I8/Lz0AgLFMeefqlrvuy3f7RIENWwa0Nb8iYPcfEWfVLVFKLzg1McY7fuX pt+pS2tVg0iwMldpUOkkLz4BmULjmnHQh/IRbClkkBfCylUVbRhdVt1kuP5JfXJIfCeB IcV9MAdywYzJ273iDgquip2v867HEOl+Fb7uIna+OwCkkN9PlJ/vKAoGSbW+nhjFISLO 8ShmDBdJ0JOkQ6DywQ2umxySiO369kjz/FUMF+OIGqZRL9C3bpMaq16DFTHyqobrlXS2 Bw+RpW4rGNTa+o3l5qk5jih6Y7S+9/XYgyukrl1KAAkgg2glfCwsarlIoGurpExZGVnK HDDg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=0JYOu0qx3JmQq4x7McLpyb3kJqh6JTUS1pVf9/nHHO0=; b=S84WMr2N944vkCrndNVLX9H9ZPnXiqt8V0VraCWplLAToHaF8dEF8JSk6ltqXPS1dT iDidWTKeNg4ZusEQwIN2dXxZRkmaN1fzvcMX1yg2gDUap6YMTtdfbCoTyHDud/sA1W3x T+KG1yKTVaTIs2E9hbDD1F3fwUCISzmKgcboSqQh39uCJ2yiDND+YNic8RuYgNFsZTuA lvwG2sMaUvfaY3/uaszlAau57neUc5pMU6syyA26oISRu2P8z3HkCpk+H+gEOyBj0SHZ vxtCcbGCLlGD/oYxrpFyFI3hGTfy/JrI4c4TJ41Ab9pjvThh3wNVQC/bXqFH81SPjHUt zPxg== X-Gm-Message-State: ACrzQf3qQu1X5hEtfVYgFnWE27sG1/s55qC4PBeud988cFuGd4maUDca ioeudyXP680gJwoSL2hwRsXmtlbd5D5hFADp X-Google-Smtp-Source: AMsMyM5fn4//u03MaxE5mHF/0J3z4gFBSLF/6uaBnqwygsvxlLwz/rQOjRIRP7Ynu+NcRS3CWPxlBg== X-Received: by 2002:a63:2b4b:0:b0:46e:9363:d969 with SMTP id r72-20020a632b4b000000b0046e9363d969mr26636010pgr.168.1666750286726; Tue, 25 Oct 2022 19:11:26 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Peter Maydell , qemu-stable@nongnu.org, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 01/47] Revert "accel/tcg: Init TCG cflags in vCPU thread handler" Date: Wed, 26 Oct 2022 12:10:30 +1000 Message-Id: <20221026021116.1988449-2-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::431; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x431.google.com X-Spam_score_int: -16 X-Spam_score: -1.7 X-Spam_bar: - X-Spam_report: (-1.7 / 5.0 requ) BAYES_00=-1.9, DKIM_INVALID=0.1, DKIM_SIGNED=0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=no 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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751423835100002 From: Peter Maydell Commit a82fd5a4ec24d was intended to be a code cleanup, but unfortunately it has a bug. It moves the initialization of the TCG cflags from the "start a new vcpu" function to the thread handler; this is fine when each vcpu has its own thread, but when we are doing round-robin of vcpus on a single thread we end up only initializing the cflags for CPU 0, not for any of the others. The most obvious effect of this bug is that running in icount mode with more than one CPU is broken; typically the guest hangs shortly after it brings up the secondary CPUs. This reverts commit a82fd5a4ec24d923ff1e6da128c0fd4a74079d99. Cc: qemu-stable@nongnu.org Reviewed-by: Philippe Mathieu-Daud=C3=A9 Reviewed-by: Richard Henderson Signed-off-by: Peter Maydell Message-Id: <20221021163409.3674911-1-peter.maydell@linaro.org> Signed-off-by: Richard Henderson --- accel/tcg/tcg-accel-ops-mttcg.c | 5 +++-- accel/tcg/tcg-accel-ops-rr.c | 7 ++++--- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/accel/tcg/tcg-accel-ops-mttcg.c b/accel/tcg/tcg-accel-ops-mttc= g.c index ba997f6cfe..d50239e0e2 100644 --- a/accel/tcg/tcg-accel-ops-mttcg.c +++ b/accel/tcg/tcg-accel-ops-mttcg.c @@ -70,8 +70,6 @@ static void *mttcg_cpu_thread_fn(void *arg) assert(tcg_enabled()); g_assert(!icount_enabled()); =20 - tcg_cpu_init_cflags(cpu, current_machine->smp.max_cpus > 1); - rcu_register_thread(); force_rcu.notifier.notify =3D mttcg_force_rcu; force_rcu.cpu =3D cpu; @@ -141,6 +139,9 @@ void mttcg_start_vcpu_thread(CPUState *cpu) { char thread_name[VCPU_THREAD_NAME_SIZE]; =20 + g_assert(tcg_enabled()); + tcg_cpu_init_cflags(cpu, current_machine->smp.max_cpus > 1); + cpu->thread =3D g_new0(QemuThread, 1); cpu->halt_cond =3D g_malloc0(sizeof(QemuCond)); qemu_cond_init(cpu->halt_cond); diff --git a/accel/tcg/tcg-accel-ops-rr.c b/accel/tcg/tcg-accel-ops-rr.c index cc8adc2380..1a72149f0e 100644 --- a/accel/tcg/tcg-accel-ops-rr.c +++ b/accel/tcg/tcg-accel-ops-rr.c @@ -152,9 +152,7 @@ static void *rr_cpu_thread_fn(void *arg) Notifier force_rcu; CPUState *cpu =3D arg; =20 - g_assert(tcg_enabled()); - tcg_cpu_init_cflags(cpu, false); - + assert(tcg_enabled()); rcu_register_thread(); force_rcu.notify =3D rr_force_rcu; rcu_add_force_rcu_notifier(&force_rcu); @@ -277,6 +275,9 @@ void rr_start_vcpu_thread(CPUState *cpu) static QemuCond *single_tcg_halt_cond; static QemuThread *single_tcg_cpu_thread; =20 + g_assert(tcg_enabled()); + tcg_cpu_init_cflags(cpu, false); + if (!single_tcg_cpu_thread) { cpu->thread =3D g_new0(QemuThread, 1); cpu->halt_cond =3D g_new0(QemuCond, 1); --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751014; cv=none; d=zohomail.com; s=zohoarc; b=fE7NOUYwCQehZ5D8aNxJyo2nFHIs9uAcqrbn019q+S9EFXiP4JqVw4eovBqxhuazzFUTGNRgfIOIdrEBea93uLB3agAvjde5HSHigmnZ5lRWEZOvP2cjobU2SRGcDwqNB888Z2+1fqjZQpQnbDOHlW1/wpPSVgffQLh+LxgyYfI= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751014; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=xZ/+bIN9G+2jCCLtEbaCgiuaoUTd0+RhG3Uh+OtJwJs=; b=fxmFlFPD6LUmOQD1S1d3hSTw056EViUqLWqnTDYP6lk7HW9eUYSCTzaEcTzXpVADpaDUj7Smwe68LzLbBIa37NeYQRNJX2dHO8CzcRPRNbx0qGOwv88OcKAh0k0pWKlnfwfUS9/VDU1ekv5zgtwfAFiS5p6pfgYJTZ+6hyeMziE= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751014314738.2406909669883; Tue, 25 Oct 2022 19:23:34 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtO-0004kq-Uc; Tue, 25 Oct 2022 22:11:42 -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 1onVtJ-0004ZV-Hr for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:37 -0400 Received: from mail-pg1-x533.google.com ([2607:f8b0:4864:20::533]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtD-00011M-Cp for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:35 -0400 Received: by mail-pg1-x533.google.com with SMTP id 128so13465978pga.1 for ; Tue, 25 Oct 2022 19:11:30 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=xZ/+bIN9G+2jCCLtEbaCgiuaoUTd0+RhG3Uh+OtJwJs=; b=ttAzxVzUYa3XmqZaPasJF3jr2sYIklV6ZiUD1PPjsjnoZIPNmFFkSDwcXiwPMDrMro F20/ttfwxg6CQckB54Py0MXgoHQvEX/kiMrKzvyCiRqeo+pP4TWD8NFogzPP6ooIhoTO Ke4lfAlpXKH2ZJeFCTtnYwtKhJ+tLPO4ZlK4imFvGq8bEUTemHLut9K1ChTFpmPJsZYD 4XkuVWz2vaM3kKV9R0YkjCbopuHHlxh063h5DCUZSFieu07BklAdG6MeAFr6puzk1VqN NFRXmEp3+uExcpA1Dv7ozl8oTzrGH56MveBEaDUfsOgOW6duHK/g0hV/k35kB6gmSX8g WnjA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=xZ/+bIN9G+2jCCLtEbaCgiuaoUTd0+RhG3Uh+OtJwJs=; b=NEzAOiG1JfI9i7MIu5a6M7YlNdamVLKu7HiqstPe9fFz3yk8xWG7wLoUuPBEQUl/VP kyyNTQw+mWm6O4tE4K5HbnmHaql1d0giF1cM0E3kt89ea6aaz8UnSNiXM2Yls4ImoNvF 6HljS+/KAZEhkryNoD5fPkSK0q5yFkwbwW73xPsJpr+xUBfv3P1lqWgNTZ1a9Az8LLQh 8naSpaqepH2VbQC9HxC2Udg70kO/9c26wRwApqqkTZj9JpWjVl5uHp20xA39jGLQ86IF qL8zsWbI9sfUsqay7OyTWAdsR/xNFuEfb/PV/VXdzpujahvdZ0QzDT2yRPorljyqdcLL hsMw== X-Gm-Message-State: ACrzQf2jvOh3/6IsbseJ/s8wBlbYFyrIxrKcyeex0DxLrrj5pS7sqpGq 9YE+Kc/OTAY7i6PhnuM+2/hzA5ZrdDfU0PHX X-Google-Smtp-Source: AMsMyM6f8T21TL1eeZZgcAWKT14sJP6bcjS/45c+FsPFp9YygktJi1Gi473cEEc5fMHtypb8v0G5CQ== X-Received: by 2002:a05:6a00:189f:b0:56b:b192:cda with SMTP id x31-20020a056a00189f00b0056bb1920cdamr16155794pfh.2.1666750289804; Tue, 25 Oct 2022 19:11:29 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Qi Hu , WANG Xuerui Subject: [PULL 02/47] tcg/loongarch64: Add direct jump support Date: Wed, 26 Oct 2022 12:10:31 +1000 Message-Id: <20221026021116.1988449-3-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::533; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x533.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751015047100001 From: Qi Hu Similar to the ARM64, LoongArch has PC-relative instructions such as PCADDU18I. These instructions can be used to support direct jump for LoongArch. Additionally, if instruction "B offset" can cover the target address(target is within =C2=B1128MB range), a single "B offset" plus a nop will be used by "tb_target_set_jump_target". Signed-off-by: Qi Hu Reviewed-by: Richard Henderson Reviewed-by: WANG Xuerui Message-Id: <20221015092754.91971-1-huqi@loongson.cn> Signed-off-by: Richard Henderson --- tcg/loongarch64/tcg-target.h | 9 ++++-- tcg/loongarch64/tcg-target.c.inc | 48 +++++++++++++++++++++++++++++--- 2 files changed, 50 insertions(+), 7 deletions(-) diff --git a/tcg/loongarch64/tcg-target.h b/tcg/loongarch64/tcg-target.h index d58a6162f2..a659c8d6fd 100644 --- a/tcg/loongarch64/tcg-target.h +++ b/tcg/loongarch64/tcg-target.h @@ -42,7 +42,11 @@ =20 #define TCG_TARGET_INSN_UNIT_SIZE 4 #define TCG_TARGET_NB_REGS 32 -#define MAX_CODE_GEN_BUFFER_SIZE SIZE_MAX +/* + * PCADDU18I + JIRL sequence can give 20 + 16 + 2 =3D 38 bits + * signed offset, which is +/- 128 GiB. + */ +#define MAX_CODE_GEN_BUFFER_SIZE (128 * GiB) =20 typedef enum { TCG_REG_ZERO, @@ -123,7 +127,7 @@ typedef enum { #define TCG_TARGET_HAS_clz_i32 1 #define TCG_TARGET_HAS_ctz_i32 1 #define TCG_TARGET_HAS_ctpop_i32 0 -#define TCG_TARGET_HAS_direct_jump 0 +#define TCG_TARGET_HAS_direct_jump 1 #define TCG_TARGET_HAS_brcond2 0 #define TCG_TARGET_HAS_setcond2 0 #define TCG_TARGET_HAS_qemu_st8_i32 0 @@ -166,7 +170,6 @@ typedef enum { #define TCG_TARGET_HAS_muluh_i64 1 #define TCG_TARGET_HAS_mulsh_i64 1 =20 -/* not defined -- call should be eliminated at compile time */ void tb_target_set_jmp_target(uintptr_t, uintptr_t, uintptr_t, uintptr_t); =20 #define TCG_TARGET_DEFAULT_MO (0) diff --git a/tcg/loongarch64/tcg-target.c.inc b/tcg/loongarch64/tcg-target.= c.inc index a3debf6da7..d326e28740 100644 --- a/tcg/loongarch64/tcg-target.c.inc +++ b/tcg/loongarch64/tcg-target.c.inc @@ -1031,6 +1031,36 @@ static void tcg_out_qemu_st(TCGContext *s, const TCG= Arg *args) #endif } =20 +/* LoongArch uses `andi zero, zero, 0` as NOP. */ +#define NOP OPC_ANDI +static void tcg_out_nop(TCGContext *s) +{ + tcg_out32(s, NOP); +} + +void tb_target_set_jmp_target(uintptr_t tc_ptr, uintptr_t jmp_rx, + uintptr_t jmp_rw, uintptr_t addr) +{ + tcg_insn_unit i1, i2; + ptrdiff_t upper, lower; + ptrdiff_t offset =3D (ptrdiff_t)(addr - jmp_rx) >> 2; + + if (offset =3D=3D sextreg(offset, 0, 26)) { + i1 =3D encode_sd10k16_insn(OPC_B, offset); + i2 =3D NOP; + } else { + tcg_debug_assert(offset =3D=3D sextreg(offset, 0, 36)); + lower =3D (int16_t)offset; + upper =3D (offset - lower) >> 16; + + i1 =3D encode_dsj20_insn(OPC_PCADDU18I, TCG_REG_TMP0, upper); + i2 =3D encode_djsk16_insn(OPC_JIRL, TCG_REG_ZERO, TCG_REG_TMP0, lo= wer); + } + uint64_t pair =3D ((uint64_t)i2 << 32) | i1; + qatomic_set((uint64_t *)jmp_rw, pair); + flush_idcache_range(jmp_rx, jmp_rw, 8); +} + /* * Entry-points */ @@ -1058,10 +1088,20 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, break; =20 case INDEX_op_goto_tb: - assert(s->tb_jmp_insn_offset =3D=3D 0); - /* indirect jump method */ - tcg_out_ld(s, TCG_TYPE_PTR, TCG_REG_TMP0, TCG_REG_ZERO, - (uintptr_t)(s->tb_jmp_target_addr + a0)); + tcg_debug_assert(s->tb_jmp_insn_offset !=3D NULL); + /* + * Ensure that patch area is 8-byte aligned so that an + * atomic write can be used to patch the target address. + */ + if ((uintptr_t)s->code_ptr & 7) { + tcg_out_nop(s); + } + s->tb_jmp_insn_offset[a0] =3D tcg_current_code_size(s); + /* + * actual branch destination will be patched by + * tb_target_set_jmp_target later + */ + tcg_out_opc_pcaddu18i(s, TCG_REG_TMP0, 0); tcg_out_opc_jirl(s, TCG_REG_ZERO, TCG_REG_TMP0, 0); set_jmp_reset_offset(s, a0); break; --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751161; cv=none; d=zohomail.com; s=zohoarc; b=C+8aBwdNh1ZB29QGecyheYC20GrRr+1u/mVOrsfHcd0kriW4yhl3HaITJDYMCeWsTQt0u8idf7oDaOeNI8YQf0F9G9nSpoGDvXWVlS0dbFrNC+71KAPXOSeOiHSeXKv236jd3RqqU2YtXbpNaSA2c47BIYPm8c+1co2kDXaVIMg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751161; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=VEeh4cUnjW7mNJ8BWl6JcUo3gnq8r+qB7WZx+ISNj+A=; b=kxiU3jUNgqgKo56WHu6GzCXhUSFL7lAK0ohUCOas9LC7+JaI3GzopXAsAsnnuZjAvH/scFyxDTOCni/8tM8BVshUGoPWZVDgAlZH7cOdw9ZwEfwSA0doXCr0fu2Lp/OeK/DxC2hFv+tbjTzC9D4mVDgsdkGoXQ2j16g7qSm1ZJ0= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751161065664.1659216327524; Tue, 25 Oct 2022 19:26:01 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtW-0004qx-2F; Tue, 25 Oct 2022 22:11:50 -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 1onVtL-0004gO-DL for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:39 -0400 Received: from mail-pj1-x102e.google.com ([2607:f8b0:4864:20::102e]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtH-00011o-Ed for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:38 -0400 Received: by mail-pj1-x102e.google.com with SMTP id m6-20020a17090a5a4600b00212f8dffec9so876542pji.0 for ; Tue, 25 Oct 2022 19:11:34 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=VEeh4cUnjW7mNJ8BWl6JcUo3gnq8r+qB7WZx+ISNj+A=; b=f5yfGUy+IYzxXI0sOrRZvrBQ//q88TeeiBtIRZdkZ3luZKA2Sao3/B0iYH947DNLUg w8uWISDt2jkCsTq9eiySP2YjeuBkZz0xVw3jcB6PZuqM8cvdEDHIdicU4fTTkUg1UixR WATMJSbu3xvN1lGhCXJTCYgd35wWFyrRnSBoO5q0eOUKHGjvBuLhXTxQTqcWFnxRN5WI axU4/dyiMnXPGQC/TXMc33FLgufHOlso7ZCoox3OvRLW6SRpJ+dyr1jzvw2+YnsrNWSi 6byFJOH/i027ZnUptIch5hoPMY6oizTNvw6W151EUy5Y8jIBJw9kAo1oIu+xZVmy2E/0 61ig== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=VEeh4cUnjW7mNJ8BWl6JcUo3gnq8r+qB7WZx+ISNj+A=; b=7skYykGwb3/+JGxUgbXNI6eoeVJwX9/wptd55ej4JEiOiZ3wj2lCil5OuQjCUOaQsF EmbkjVIOBZNVO6T6mQZ4TZbX3sa80r75yiaprkhhugHIZLnXJbKhNEuck8t4/dGyof0V 8hQ9C/d8LntBf5Dcr8cQnAKGGlAkJwnsJrhRcBD35cEgSRkaWldnrwEXdvV6l0+tieap YEn9hdJUkAqLo/TG3LWZnmcrbFgMVq0gkPJpFZuszBN9Sx/p8nMYnBCzwjvENBrJF/kD ZuvPQ0EuoOUUf6de04gbwWE0fxp60JnoYjAQoWGPR1mIbamtX5HR4SYQt/dd92MN/sEG PVIw== X-Gm-Message-State: ACrzQf2WHo6e6rnjTb5GNCGkmKsOw6DcdywzaGNITF5zYZnmE9cBuZHl Pghl1OH5B2uoyJiFJKI1nyCYnj1BXevW+FRS X-Google-Smtp-Source: AMsMyM5wcG6a/tHpHrlleO8nQ1GoDWF1QYTDQjjKz50PrWJ4ClBbZMWB2UzwELcXfEXB+irCv4o7cw== X-Received: by 2002:a17:90b:954:b0:213:c01:b8ce with SMTP id dw20-20020a17090b095400b002130c01b8cemr1539423pjb.168.1666750293133; Tue, 25 Oct 2022 19:11:33 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Qi Hu , WANG Xuerui , =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 03/47] tcg/aarch64: Remove unused code in tcg_out_op Date: Wed, 26 Oct 2022 12:10:32 +1000 Message-Id: <20221026021116.1988449-4-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::102e; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x102e.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751162682100003 From: Qi Hu AArch64 defines the TCG_TARGET_HAS_direct_jump. So the "else" block is useless in the case of "INDEX_op_goto_tb" in function "tcg_out_op". Add an assertion and delete these codes for clarity. Suggested-by: WANG Xuerui Signed-off-by: Qi Hu Reviewed-by: Philippe Mathieu-Daud=C3=A9 Reviewed-by: Richard Henderson Message-Id: <20221017020826.990729-1-huqi@loongson.cn> Signed-off-by: Richard Henderson --- tcg/aarch64/tcg-target.c.inc | 31 ++++++++++++++----------------- 1 file changed, 14 insertions(+), 17 deletions(-) diff --git a/tcg/aarch64/tcg-target.c.inc b/tcg/aarch64/tcg-target.c.inc index d997f7922a..344b63e20f 100644 --- a/tcg/aarch64/tcg-target.c.inc +++ b/tcg/aarch64/tcg-target.c.inc @@ -1916,24 +1916,21 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc, break; =20 case INDEX_op_goto_tb: - if (s->tb_jmp_insn_offset !=3D NULL) { - /* TCG_TARGET_HAS_direct_jump */ - /* Ensure that ADRP+ADD are 8-byte aligned so that an atomic - write can be used to patch the target address. */ - if ((uintptr_t)s->code_ptr & 7) { - tcg_out32(s, NOP); - } - s->tb_jmp_insn_offset[a0] =3D tcg_current_code_size(s); - /* actual branch destination will be patched by - tb_target_set_jmp_target later. */ - tcg_out_insn(s, 3406, ADRP, TCG_REG_TMP, 0); - tcg_out_insn(s, 3401, ADDI, TCG_TYPE_I64, TCG_REG_TMP, TCG_REG= _TMP, 0); - } else { - /* !TCG_TARGET_HAS_direct_jump */ - tcg_debug_assert(s->tb_jmp_target_addr !=3D NULL); - intptr_t offset =3D tcg_pcrel_diff(s, (s->tb_jmp_target_addr += a0)) >> 2; - tcg_out_insn(s, 3305, LDR, offset, TCG_REG_TMP); + tcg_debug_assert(s->tb_jmp_insn_offset !=3D NULL); + /* + * Ensure that ADRP+ADD are 8-byte aligned so that an atomic + * write can be used to patch the target address. + */ + if ((uintptr_t)s->code_ptr & 7) { + tcg_out32(s, NOP); } + s->tb_jmp_insn_offset[a0] =3D tcg_current_code_size(s); + /* + * actual branch destination will be patched by + * tb_target_set_jmp_target later + */ + tcg_out_insn(s, 3406, ADRP, TCG_REG_TMP, 0); + tcg_out_insn(s, 3401, ADDI, TCG_TYPE_I64, TCG_REG_TMP, TCG_REG_TMP= , 0); tcg_out_insn(s, 3207, BR, TCG_REG_TMP); set_jmp_reset_offset(s, a0); break; --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750767; cv=none; d=zohomail.com; s=zohoarc; b=CuISG9T0Yg6hDpQUA1HFFku7cvngbo/83XZJ/U5qjDYW8DmZwbmzNwlvpj6bpM7tyfWuu4s2tsy8CPs+f9CC+jw4peNoKdqoS8WoOB9fZ5TrUyuMndtxko5SkmXgjoK2E0NVtADFdypclk1D7tJ0Y7A4H/rpS+hmDjvhO+/Xb60= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750767; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=cbu+XeGtZCwlJENuQOWLw8zlHTHpS+i5rpNgMNp+qA8=; b=QgSC5AmBpH+tQ959Lro+kIFheHDQsOdjIa28+83rotLGY2l+qgQ7Q+8fIzvuaX+W5ZY3VepQqj5UBxq0xPOCVicXxRbmxBWWexbgFQKpLSZ1JUSm/mUiSMLSGMbdTmRWqlEwDmNvqYbeMLD6yhpd2WH7+/roiTwv7FOi6tNjoJU= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750767883127.36834170609097; Tue, 25 Oct 2022 19:19:27 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtU-0004qY-M9; Tue, 25 Oct 2022 22:11:48 -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 1onVtL-0004gJ-D4 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:39 -0400 Received: from mail-pf1-x431.google.com ([2607:f8b0:4864:20::431]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtJ-00013O-BF for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:38 -0400 Received: by mail-pf1-x431.google.com with SMTP id d10so13895957pfh.6 for ; Tue, 25 Oct 2022 19:11:36 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=cbu+XeGtZCwlJENuQOWLw8zlHTHpS+i5rpNgMNp+qA8=; b=one/8hid87nUEQI2d4fPIVuOkq7zfO/4f2pqZ9K2ab8tVEqrLIXFG5519cC+EKnSuo KkbrawDMSx7mqCFXSI3MhUcFjGRpwaROd/zQas9iCmfmsKxja3031Y3P1I/4GOPQfpib oezjQSHzwvEwezz+/uJj84Ydl++B3ciWod8OMNbApl/o+o73h0GsFgkmwKIiUAluVKPX Lw4/V7luoodUsdNY8BuQzuQr2M4+AqZlu/BqH3TQ4XgLNWpco7Ka/MDuV+88Uc3fN+rG GlnFzQ/BWV+ZJnYY9ty9edJBNRIe2PZGK4Kzk2bJWeuK3VsCmXJVxOFsIhiy3kViIgch 9JKA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=cbu+XeGtZCwlJENuQOWLw8zlHTHpS+i5rpNgMNp+qA8=; b=UrdhSxmALw4YdRpBZaigIccnWhHkfcNDWqeyMzWmA+YKml5nZYu4YYZe/7EH27a4ID NK4O0rXSi5jHZ16BqFTvYRf019NeVsUaa6N2yJt7NXlIYHDqoWdguwt6PSs7ptDK6i+G F/rtDrZ+8OyXZF5J/3KHfNIQpOtHh9IaM7GYfNQEjx+YoS+lhQsMIoXdBPWJCz8Nl+J3 vupzPtNZwaaHjo+c5DFj8OYpsEIl2SL4mnCi9dngjV3aW8cb1PYvIWPgE7cKc5FiY1H1 KndcGtxuSAa4DX1FO/mpNJIr0ibCrUQ6QAAe4UDB9qpH+yCJ64NaR5z69Z7/pVDzFqic f6Rg== X-Gm-Message-State: ACrzQf3jG6pRZxtdo6lYXPBuVEP6EKmrm0nZQBIUA1M+eY5SRlMibYZK OrojxBFX4vfIKstJtktKs/2VQmaolgaUjRxD X-Google-Smtp-Source: AMsMyM6dP5hx/86GjXgMhNMGOT4Vx2Q7x+2iCFG/AKH9+9IHTHIYtqwg17rWc3AFL7jzoBUahVGwvw== X-Received: by 2002:a05:6a00:178a:b0:563:7ada:f70 with SMTP id s10-20020a056a00178a00b005637ada0f70mr41848574pfg.69.1666750295917; Tue, 25 Oct 2022 19:11:35 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Leandro Lupori Subject: [PULL 04/47] accel/tcg: Add a quicker check for breakpoints Date: Wed, 26 Oct 2022 12:10:33 +1000 Message-Id: <20221026021116.1988449-5-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> 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=2607:f8b0:4864:20::431; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x431.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750769647100003 Content-Type: text/plain; charset="utf-8" From: Leandro Lupori Profiling QEMU during Fedora 35 for PPC64 boot revealed that a considerable amount of time was being spent in check_for_breakpoints() (0.61% of total time on PPC64 and 2.19% on amd64), even though it was just checking that its queue was empty and returning, when no breakpoints were set. It turns out this function is not inlined by the compiler and it's always called by helper_lookup_tb_ptr(), one of the most called functions. By leaving only the check for empty queue in check_for_breakpoints() and moving the remaining code to check_for_breakpoints_slow(), called only when the queue is not empty, it's possible to avoid the call overhead. An improvement of about 3% in total time was measured on POWER9. Signed-off-by: Leandro Lupori Reviewed-by: Richard Henderson Message-Id: <20221025202424.195984-2-leandro.lupori@eldorado.org.br> Signed-off-by: Richard Henderson --- accel/tcg/cpu-exec.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/accel/tcg/cpu-exec.c b/accel/tcg/cpu-exec.c index f9e5cc9ba0..bb4b9e92ce 100644 --- a/accel/tcg/cpu-exec.c +++ b/accel/tcg/cpu-exec.c @@ -304,16 +304,12 @@ static void log_cpu_exec(target_ulong pc, CPUState *c= pu, } } =20 -static bool check_for_breakpoints(CPUState *cpu, target_ulong pc, - uint32_t *cflags) +static bool check_for_breakpoints_slow(CPUState *cpu, target_ulong pc, + uint32_t *cflags) { CPUBreakpoint *bp; bool match_page =3D false; =20 - if (likely(QTAILQ_EMPTY(&cpu->breakpoints))) { - return false; - } - /* * Singlestep overrides breakpoints. * This requirement is visible in the record-replay tests, where @@ -374,6 +370,13 @@ static bool check_for_breakpoints(CPUState *cpu, targe= t_ulong pc, return false; } =20 +static inline bool check_for_breakpoints(CPUState *cpu, target_ulong pc, + uint32_t *cflags) +{ + return unlikely(!QTAILQ_EMPTY(&cpu->breakpoints)) && + check_for_breakpoints_slow(cpu, pc, cflags); +} + /** * helper_lookup_tb_ptr: quick check for next tb * @env: current cpu state --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751147; cv=none; d=zohomail.com; s=zohoarc; b=CHKw1aOZaWcqRcF/ZVQMCJO5sJA2kIydwIkTxTe94HuQhlji8YuyJnu48krjhliSAmsw2sqoRcWPpKCInnPXCCrtSpFkk/A3wti84fq6Htd8p3x4CawGIWY+bz3a3WBQJ76DzUihq85tCj3BTgHjg1eVTJw5KFx/VUasyTj23Fo= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751147; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=w2X6gsd8PMcmjrRwm+ALtjbDa66PQBauc/+3lmBMcwY=; b=PbrxWrpX2jnhEjVoJJF/Yrxzp6LV3tMxgXLSOqmesrhFRaehhlyy7c4bhpFMwInE23hL4Gamj4tZd8R2oSvbp25sC0YvsRLQbl2nKt1jDwI/EZUfV12sq3RTaXJ0RvntFULLTNgcNto6H9b0Ul/sxYoxeUSz1qC2WA+gFx2upSI= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751147114996.827584723448; Tue, 25 Oct 2022 19:25:47 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtW-0004r0-Kt; Tue, 25 Oct 2022 22:11:50 -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 1onVtP-0004oV-2j for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:43 -0400 Received: from mail-pf1-x42c.google.com ([2607:f8b0:4864:20::42c]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtM-00015y-6l for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:42 -0400 Received: by mail-pf1-x42c.google.com with SMTP id e4so9967785pfl.2 for ; Tue, 25 Oct 2022 19:11:39 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=w2X6gsd8PMcmjrRwm+ALtjbDa66PQBauc/+3lmBMcwY=; b=zDU6duHfkG1yU2wM+HV3RNjISmRIzC1pAQLu4i8qAAxVmwvypm+qCIumbtzLcnfvZS FBg8HwDG7JrslisNat4l8cESKlk8tqZGqh9BdVSDC64BxvUVa8iL1y8IWHL0O8zDaeIs scJDjUqQZ5Tsr6n0Go6EaupPAPDAT2g/0JSRIJfSugz9K5E08QgrVTMAVLg6WHCzBdjJ KdEMNbprBQxUd9Tucz8dfBG/qswh5GOZkiP8dSGxjh/6MZFuJsmo4fQPS0Vgrjol8i1X mBPy5idT7cdn182SdPOb//VeVXI2Ev8x/OGhC6MhzZ15gYkFt0moIpigf4gsqxtGBsIv JX5g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=w2X6gsd8PMcmjrRwm+ALtjbDa66PQBauc/+3lmBMcwY=; b=oXbOPEyAAI6d43ArFkFAl4ZyChYlXbItlBS7gzM5H4Kilbl4jSWsaP5lrU9b9VxcDu 8G94VMZFDWhQ/awOZD/VwhLhC3jy84leRz9NbbNAt4i5E9OBzl0b4LmLT3bGxtgsXkgD 6ZO/dRFt62OUuBAiOqlAl7rRvRTYWA2wHZW9nAqAXrjQ93RvDOfV+eEI61Qr5BNuyLvQ nVmtqNl/rcnoS3r0jkJ8tDGY1KV0WWLhMF0nFbesVA7nCcZchh0Fj/seOSVlsqhd/+Rn wo6DY/qG+ZdyoRHyqOhtqbCeVJAm92GIP5EZPv55BkpT9p4iiOq2DzyfFDc4w/KxSfL/ u5rA== X-Gm-Message-State: ACrzQf1AXvg3/ZMW3BxfdXc9kj7M60S9eLMCQ7f/OEOIHUnUPdedNPdS oznZUn9hGsgJxCXeKh9xw3tKvjipVxSvD/cC X-Google-Smtp-Source: AMsMyM7CT4C6wGbp5Y33NW8FjWYnKPAZzOjnaa0XnNriHOjmWia1ZoMi60RUidbjKVp3x/07am3y7A== X-Received: by 2002:a65:5605:0:b0:46f:1e8d:ece9 with SMTP id l5-20020a655605000000b0046f1e8dece9mr8611000pgs.249.1666750298814; Tue, 25 Oct 2022 19:11:38 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Paolo Bonzini , =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 05/47] include/qemu/osdep: Add qemu_build_assert Date: Wed, 26 Oct 2022 12:10:34 +1000 Message-Id: <20221026021116.1988449-6-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42c; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42c.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751148479100003 This differs from assert, in that with optimization enabled it triggers at build-time. It differs from QEMU_BUILD_BUG_ON, aka _Static_assert, in that it is sensitive to control flow and is subject to dead-code elimination. Acked-by: Paolo Bonzini Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- include/qemu/osdep.h | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/include/qemu/osdep.h b/include/qemu/osdep.h index b1c161c035..2276094729 100644 --- a/include/qemu/osdep.h +++ b/include/qemu/osdep.h @@ -186,6 +186,14 @@ void QEMU_ERROR("code path is reachable") #define qemu_build_not_reached() g_assert_not_reached() #endif =20 +/** + * qemu_build_assert() + * + * The compiler, during optimization, is expected to prove that the + * assertion is true. + */ +#define qemu_build_assert(test) while (!(test)) qemu_build_not_reached() + /* * According to waitpid man page: * WCOREDUMP --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750820; cv=none; d=zohomail.com; s=zohoarc; b=h06tG3oJhdw9RrFEmmYCzMnaENYifgPJCym0XYci9+aOmlqHVc9HZ/aXZ9BcLM+o6sg5yvkF9+CfFBXGAEhRZfMmEXVxweqoK+9ut6/ql5nV2io1ScXoO0MrL7VE8xTuUoZSF7yf0M9T4chKxGgA8EHYdnmURyf9A1S1TgKs4eM= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750820; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=L+bQ8y2aE1cH3TKB7oyilRPItnm1DTZkui5P8deFPJQ=; b=ZK6F+CuWHlF+UzAyAD1kz32ZKgVH5R+kUa8soEGUppH40JubL3Boz/YV4Do2o/ciAM7elFRap3bAobKX8HqdlqnbkHukXFqy5TWXTEDLPIaI4ifK37fVHu7m92c1xfA6aC5PtdcMqLeDv38kxtv7CMOBPDJ6BdhyM5YQr0HNarQ= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750820412556.3279740927691; Tue, 25 Oct 2022 19:20:20 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtX-0004rF-4z; Tue, 25 Oct 2022 22:11:51 -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 1onVtU-0004qV-Es for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:48 -0400 Received: from mail-pg1-x531.google.com ([2607:f8b0:4864:20::531]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtP-000186-89 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:44 -0400 Received: by mail-pg1-x531.google.com with SMTP id b5so13437405pgb.6 for ; Tue, 25 Oct 2022 19:11:42 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=L+bQ8y2aE1cH3TKB7oyilRPItnm1DTZkui5P8deFPJQ=; b=C0QZ/r6zYkP/x74z2KIotNtqD88L5FBbh8BUgbNw+Eo4rH7bEs+BzXOkUGDYcrJu4o 8ahh3DdXr+M6zgWzinstMTyGMp4cIFQqXNr5mPGChzLEht8apIWiOY9fAdmOadkCjxvJ kKOqCu/WJ5qIYYhZ1xb2vxs+cmQHlZCmGVuJNsJrPlm5Ditx9+hBhlGbhucEEXUyX296 /55OxDNgcjTitjYwgIUDbswZ6kvDkBNnf/4QfE0Iy/BHZjtNS7urRAlDitmWZeL9x9fG PXuFaa/omYfAZiWCUuoqK/rak35UXK6AC8Vzm/SIpcE/Pwi/prc0V1AnNTAJWSVddH+8 8RfQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=L+bQ8y2aE1cH3TKB7oyilRPItnm1DTZkui5P8deFPJQ=; b=lLB2T3mjVOYwk3fy7rPIVohwx8qv/9Sz3IC1nkSKPPVoKRmSOW/J2ZrghOsXIdWHDl b8ITXeHDTYGURz8aQsEsxi98EMLJ71rYdsh5IFXbUUfV/2aZalJAxy9YHpk57Rpgk/Bc bspgOZoI06KDkRLpCIycmvMAZs+xJT8MAF92lY48fDcUH7WGWTHllq3HvcgZYR2d7uBi O8owrXSNKoFHCHoAlYAZuT89sYbeBFi1ClBL9raAjIGJLLKfiokXu5u64EKD4tfSWzE3 GArvE37c92uQv/lzJ4KRASKvDV0dynQclTDlrVh7RvoYRSCaA883IZmxg5+sZGJbmOec 4yGQ== X-Gm-Message-State: ACrzQf3F9jkXAkolvACbp1aGMZuvFuR8e6PtpINxyGu0ir9AsYJno6nT iaf8DIfJwFl1NnhTwy8NBCoah1tvXfkkuiPk X-Google-Smtp-Source: AMsMyM4KyGefwzhqgY4a8YpSJzQ4ubAL9IqPc1c4/9LZH5O6jo5BaCMdoCX9ZJ1J3GzicxGmNGz1Og== X-Received: by 2002:a63:86c3:0:b0:46f:33df:46b0 with SMTP id x186-20020a6386c3000000b0046f33df46b0mr4055007pgd.564.1666750301899; Tue, 25 Oct 2022 19:11:41 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Paolo Bonzini , =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 06/47] include/qemu/atomic: Use qemu_build_assert Date: Wed, 26 Oct 2022 12:10:35 +1000 Message-Id: <20221026021116.1988449-7-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::531; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x531.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750821903100001 Change from QEMU_BUILD_BUG_ON, which requires ifdefs to avoid problematic code, to qemu_build_assert, which can use C ifs. Acked-by: Paolo Bonzini Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- include/qemu/atomic.h | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/include/qemu/atomic.h b/include/qemu/atomic.h index 7e8fc8e7cd..874134fd19 100644 --- a/include/qemu/atomic.h +++ b/include/qemu/atomic.h @@ -133,7 +133,7 @@ =20 #define qatomic_read(ptr) \ ({ \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ qatomic_read__nocheck(ptr); \ }) =20 @@ -141,7 +141,7 @@ __atomic_store_n(ptr, i, __ATOMIC_RELAXED) =20 #define qatomic_set(ptr, i) do { \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ qatomic_set__nocheck(ptr, i); \ } while(0) =20 @@ -159,27 +159,27 @@ =20 #define qatomic_rcu_read(ptr) \ ({ \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ typeof_strip_qual(*ptr) _val; \ qatomic_rcu_read__nocheck(ptr, &_val); \ _val; \ }) =20 #define qatomic_rcu_set(ptr, i) do { \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ __atomic_store_n(ptr, i, __ATOMIC_RELEASE); \ } while(0) =20 #define qatomic_load_acquire(ptr) \ ({ \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ typeof_strip_qual(*ptr) _val; \ __atomic_load(ptr, &_val, __ATOMIC_ACQUIRE); \ _val; \ }) =20 #define qatomic_store_release(ptr, i) do { \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ __atomic_store_n(ptr, i, __ATOMIC_RELEASE); \ } while(0) =20 @@ -191,7 +191,7 @@ }) =20 #define qatomic_xchg(ptr, i) ({ \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ qatomic_xchg__nocheck(ptr, i); \ }) =20 @@ -204,7 +204,7 @@ }) =20 #define qatomic_cmpxchg(ptr, old, new) ({ \ - QEMU_BUILD_BUG_ON(sizeof(*ptr) > ATOMIC_REG_SIZE); \ + qemu_build_assert(sizeof(*ptr) <=3D ATOMIC_REG_SIZE); \ qatomic_cmpxchg__nocheck(ptr, old, new); \ }) =20 --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751092; cv=none; d=zohomail.com; s=zohoarc; b=nTkAJRZlY8sfL7ib+yX+D46oCM9aPdX2nvO0Vv8iFvnfITjyHvjC093XpNVunIoYmnIQwSrAss7ML4RBMfHV+ry4Nd43kkfLfhDT2MDE0ecEY0TaSqlA6EbklrdKU8QV4UvH3kZvXXQWqYVzxhT7c3QlHMPpe6Pf3KyYH9ESM38= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751092; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=5RUJyLcG6Hy9YMvmiQcSVrXQZZmnqOqzwc/5ZpYsi60=; b=Aenx6LSrDSa7azueam4skH7tjF4gKEcrnzHd/X/e7Qao2AlT2wyyNGwOwP3Dmjr9pResLj2WHhygmfaGE1iY48f2oacPtHyYD0qx0wWlEQhfcfSIZ4YT0oZax0EK+hJ51t8wmUpQUpK9jUV6EtqsB+4knGXY8LE696PX5WT514o= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751092379321.1925380620355; Tue, 25 Oct 2022 19:24:52 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtZ-0004s4-AE; Tue, 25 Oct 2022 22:11:53 -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 1onVtV-0004qp-QG for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:49 -0400 Received: from mail-pg1-x535.google.com ([2607:f8b0:4864:20::535]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtU-00010i-Cd for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:49 -0400 Received: by mail-pg1-x535.google.com with SMTP id f193so13495092pgc.0 for ; Tue, 25 Oct 2022 19:11:45 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=5RUJyLcG6Hy9YMvmiQcSVrXQZZmnqOqzwc/5ZpYsi60=; b=ITACuO04URowlNQjlwNEWeceyKpXcO7ZguZEvAA9Broy1i+b37HmtbUSbHCVEwEwjN BDOypPVGm6W1ZDFl8ox/pSID7QN+lEG6v3Gzlc5W4gXEQtsvvwibb9H2Wj4fljzSkGNP oZ0SGRzwLK1VyjMgfeFJXTpOprX+U2FLvc6fmjfjBTBKQHTeVuQIO+fKXrjzoip+FFPT ZPRvzA3XBnLWECZjZuPeK5WTKmTjn3kfwExcu7JpxIpGEa1qeoI1FQDuJOTbGW/Qsm7J VjtoVxONzsGnQSyJ/0yrXRcwuOPNHUPnurxkE9HlCl2VqnE84EAdtHAVg2m8hAeA0x0P eVUg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=5RUJyLcG6Hy9YMvmiQcSVrXQZZmnqOqzwc/5ZpYsi60=; b=L1loMfmg7IYC4L3OJSmHGqcnRUeCQjTJtqs56mraCEnGkNtfIfzOa0A9hPTpDyDkBH 7IoGtLaO+PiDnFdeydDpN0FzowtnkfNA5OXi4Duegf1W748jgwTFi3svcSGM32p/2SDc R8zgrNWWctgR/z/I+ZnPab6xTa/xtLmP9isuJNDO5+5xF41F20w+YUFs5G9hcNAislnp VZZl+IeasXmW8PCNf6K3sEivLCS8nR7vQYobs0AlZVkmmKJnN1hY0WRo9lNptvT8I7Wt pbjn80Wd13Ba562qAqWAVsKYMqpXrqP+qgNfChcAJqOw1MxUCSlXTDgaJWiIM6gFFHBI 6K+w== X-Gm-Message-State: ACrzQf11F1jYptd1FlUDFlMjZ68OjqUWYZGdM99K1P1IBo1DSq+RviMR eR9nZAvHfch5m4ECGyUFzfWJFV3YtGs61P6c X-Google-Smtp-Source: AMsMyM59eikQXzK1orXhuFwNBMyarR9zgFQ1L6Czm4oiZaFhOc1TJ2WFPTSVSJUPlzw7Sa3uwBqBTA== X-Received: by 2002:a63:ed18:0:b0:439:4176:3ea6 with SMTP id d24-20020a63ed18000000b0043941763ea6mr35169031pgi.363.1666750304810; Tue, 25 Oct 2022 19:11:44 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Paolo Bonzini Subject: [PULL 07/47] include/qemu/thread: Use qatomic_* functions Date: Wed, 26 Oct 2022 12:10:36 +1000 Message-Id: <20221026021116.1988449-8-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> 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=2607:f8b0:4864:20::535; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x535.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751093314100001 Content-Type: text/plain; charset="utf-8" Use qatomic_*, which expands to __atomic_* in preference to the "legacy" __sync_* functions. Acked-by: Paolo Bonzini Signed-off-by: Richard Henderson --- include/qemu/thread.h | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/include/qemu/thread.h b/include/qemu/thread.h index af19f2b3fc..20641e5844 100644 --- a/include/qemu/thread.h +++ b/include/qemu/thread.h @@ -227,7 +227,7 @@ struct QemuSpin { =20 static inline void qemu_spin_init(QemuSpin *spin) { - __sync_lock_release(&spin->value); + qatomic_set(&spin->value, 0); #ifdef CONFIG_TSAN __tsan_mutex_create(spin, __tsan_mutex_not_static); #endif @@ -246,7 +246,7 @@ static inline void qemu_spin_lock(QemuSpin *spin) #ifdef CONFIG_TSAN __tsan_mutex_pre_lock(spin, 0); #endif - while (unlikely(__sync_lock_test_and_set(&spin->value, true))) { + while (unlikely(qatomic_xchg(&spin->value, 1))) { while (qatomic_read(&spin->value)) { cpu_relax(); } @@ -261,7 +261,7 @@ static inline bool qemu_spin_trylock(QemuSpin *spin) #ifdef CONFIG_TSAN __tsan_mutex_pre_lock(spin, __tsan_mutex_try_lock); #endif - bool busy =3D __sync_lock_test_and_set(&spin->value, true); + bool busy =3D qatomic_xchg(&spin->value, true); #ifdef CONFIG_TSAN unsigned flags =3D __tsan_mutex_try_lock; flags |=3D busy ? __tsan_mutex_try_lock_failed : 0; @@ -280,7 +280,7 @@ static inline void qemu_spin_unlock(QemuSpin *spin) #ifdef CONFIG_TSAN __tsan_mutex_pre_unlock(spin, 0); #endif - __sync_lock_release(&spin->value); + qatomic_store_release(&spin->value, 0); #ifdef CONFIG_TSAN __tsan_mutex_post_unlock(spin, 0); #endif --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751401; cv=none; d=zohomail.com; s=zohoarc; b=fpbjWyzzySQ1vRbR8kazbn4si9jNSVMNIAniK7Ft21Wg5PEkKqOHcZbvn3q6meig8Em5vb0JGS0waNc/+U6ZjldBHEFO1PPZZPU6GO7301YvPDQdKQpsY/tmQaM9+ofFvHeePyKxnD9RB50WkUAl5OpyWsJkUaRLisPmEb/wZQ0= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751401; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=lr67oXB56bbJgvMwnludmlYvcig0N2zDKwaiJaZMxR8=; b=QEsGcgkwVoJb69Ch6LkQNRbf3U5AnkDxenw9e0bKDFEfDYd+aH+8FIbo7z7+kaooH9a6tsZLZI7+Yw2hneskeV/+nqGyrd1bxppCCvBsbuYiuN3EPgQey239xEXNqbLdOQvLXnyrpWccm3PO5xISEE7yVdgaBpraiTqaCoEJ0nc= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751401162828.5262479947079; Tue, 25 Oct 2022 19:30:01 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtY-0004rz-Ni; Tue, 25 Oct 2022 22:11:52 -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 1onVtX-0004rG-4R for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:51 -0400 Received: from mail-pf1-x430.google.com ([2607:f8b0:4864:20::430]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtU-00018k-Uc for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:50 -0400 Received: by mail-pf1-x430.google.com with SMTP id m6so13947143pfb.0 for ; Tue, 25 Oct 2022 19:11:48 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=lr67oXB56bbJgvMwnludmlYvcig0N2zDKwaiJaZMxR8=; b=aYoF6EIGRUXWjawAT0CGvM72eJeXJ8e5Tptg4gmSzD+wMBdF+A4SzhKy/MDnfVS7D7 4Y2cs+0FJjhoBy7x1C1YYJThylXKO/1Bk8h/kbOhTqjl8L02PwnVvnMw7F23vC1VrdUX QKGwI49M7OB358yxlHNETNAFXwSFuqbCCBlV2xrdkII+2FwckZjsU3gMjxOjUdvBaxwY bpDl/An87dP5FBqyQLzhxOXiADzRdHZ7FFtGnhOdXNs6DaEj66FMK7uxGr8WH4pSidJb +iFsjSw/xE/c2whODV5Aa/QRB1cLDJ/4uXcKp3HCJnHrQcXW4i+On2Gyh04f5IGX9QX+ kGtw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=lr67oXB56bbJgvMwnludmlYvcig0N2zDKwaiJaZMxR8=; b=MPUlZVoyYrQO7c9gu9uEnCGd1gNFt5mEeJ/5Fgb982YXHkEjLxbR0QZtv7v5OuhwtV UARbZE+5ehAEpsOcUe8TnO7rUwzIGyDU+/OSm/yLVciJ/8MPVTnmc4CC7UozaO2atDE4 +lJw+16NmZ557t72AJgzDYnoUmb8FNQe1p+ool5KmGQhfbJGIzSVRdWsw+o/KFRJ7jFy mefBPr4Btvm0OJfwbXNGk+v7GTXdXo7w0f3WWv6/iLoBHSJilpKe2Rw4zHqPbaTWS3Dr 9ZtFCe7bFEbLBlF5pBn2bDi/MJBMPHCWkrMhpMd5FLJBc2ZxenwfqtF4sM6mYVHRZBQp GZjw== X-Gm-Message-State: ACrzQf38GqoDIdcENfYwz3XvnkPmJvZ/nB9X4oxIFqVYKPOGUbIVrsh8 lHWum1FzEEc+xxVGNDhNaXfb+3askIRDVgjE X-Google-Smtp-Source: AMsMyM6iC7UCyxKbgswm/2A73noSbAD7ge6udQKLx7Nlgo15QJj0XDOo4W9vSdviFvUmgD6/YIImfw== X-Received: by 2002:a63:4d0c:0:b0:46f:932:450a with SMTP id a12-20020a634d0c000000b0046f0932450amr11556371pgb.204.1666750307517; Tue, 25 Oct 2022 19:11:47 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 08/47] accel/tcg: Make page_alloc_target_data allocation constant Date: Wed, 26 Oct 2022 12:10:37 +1000 Message-Id: <20221026021116.1988449-9-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::430; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x430.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751401752100002 Use a constant target data allocation size for all pages. This will be necessary to reduce overhead of page tracking. Since TARGET_PAGE_DATA_SIZE is now required, we can use this to omit data tracking for targets that don't require it. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- include/exec/cpu-all.h | 9 ++++----- target/arm/cpu.h | 8 ++++++++ target/arm/internals.h | 4 ---- accel/tcg/translate-all.c | 8 ++++++-- target/arm/mte_helper.c | 3 +-- 5 files changed, 19 insertions(+), 13 deletions(-) diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h index 16b7df41bf..854adc4ac2 100644 --- a/include/exec/cpu-all.h +++ b/include/exec/cpu-all.h @@ -281,19 +281,18 @@ void page_reset_target_data(target_ulong start, targe= t_ulong end); int page_check_range(target_ulong start, target_ulong len, int flags); =20 /** - * page_alloc_target_data(address, size) + * page_alloc_target_data(address) * @address: guest virtual address - * @size: size of data to allocate * - * Allocate @size bytes of out-of-band data to associate with the - * guest page at @address. If the page is not mapped, NULL will + * Allocate TARGET_PAGE_DATA_SIZE bytes of out-of-band data to associate + * with the guest page at @address. If the page is not mapped, NULL will * be returned. If there is existing data associated with @address, * no new memory will be allocated. * * The memory will be freed when the guest page is deallocated, * e.g. with the munmap system call. */ -void *page_alloc_target_data(target_ulong address, size_t size); +void *page_alloc_target_data(target_ulong address); =20 /** * page_get_target_data(address) diff --git a/target/arm/cpu.h b/target/arm/cpu.h index 64fc03214c..db9ec6a038 100644 --- a/target/arm/cpu.h +++ b/target/arm/cpu.h @@ -3410,6 +3410,14 @@ extern const uint64_t pred_esz_masks[5]; #define PAGE_MTE PAGE_TARGET_2 #define PAGE_TARGET_STICKY PAGE_MTE =20 +/* We associate one allocation tag per 16 bytes, the minimum. */ +#define LOG2_TAG_GRANULE 4 +#define TAG_GRANULE (1 << LOG2_TAG_GRANULE) + +#ifdef CONFIG_USER_ONLY +#define TARGET_PAGE_DATA_SIZE (TARGET_PAGE_SIZE >> (LOG2_TAG_GRANULE + 1)) +#endif + #ifdef TARGET_TAGGED_ADDRESSES /** * cpu_untagged_addr: diff --git a/target/arm/internals.h b/target/arm/internals.h index c3c3920ded..b26c9ca17b 100644 --- a/target/arm/internals.h +++ b/target/arm/internals.h @@ -1164,10 +1164,6 @@ void arm_log_exception(CPUState *cs); */ #define GMID_EL1_BS 6 =20 -/* We associate one allocation tag per 16 bytes, the minimum. */ -#define LOG2_TAG_GRANULE 4 -#define TAG_GRANULE (1 << LOG2_TAG_GRANULE) - /* * SVE predicates are 1/8 the size of SVE vectors, and cannot use * the same simd_desc() encoding due to restrictions on size. diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 4ed75a13e1..64a2601f9f 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -2271,6 +2271,7 @@ void page_set_flags(target_ulong start, target_ulong = end, int flags) =20 void page_reset_target_data(target_ulong start, target_ulong end) { +#ifdef TARGET_PAGE_DATA_SIZE target_ulong addr, len; =20 /* @@ -2293,15 +2294,17 @@ void page_reset_target_data(target_ulong start, tar= get_ulong end) g_free(p->target_data); p->target_data =3D NULL; } +#endif } =20 +#ifdef TARGET_PAGE_DATA_SIZE void *page_get_target_data(target_ulong address) { PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); return p ? p->target_data : NULL; } =20 -void *page_alloc_target_data(target_ulong address, size_t size) +void *page_alloc_target_data(target_ulong address) { PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); void *ret =3D NULL; @@ -2309,11 +2312,12 @@ void *page_alloc_target_data(target_ulong address, = size_t size) if (p->flags & PAGE_VALID) { ret =3D p->target_data; if (!ret) { - p->target_data =3D ret =3D g_malloc0(size); + p->target_data =3D ret =3D g_malloc0(TARGET_PAGE_DATA_SIZE); } } return ret; } +#endif /* TARGET_PAGE_DATA_SIZE */ =20 int page_check_range(target_ulong start, target_ulong len, int flags) { diff --git a/target/arm/mte_helper.c b/target/arm/mte_helper.c index e85208339e..a9c5fc2cb2 100644 --- a/target/arm/mte_helper.c +++ b/target/arm/mte_helper.c @@ -96,8 +96,7 @@ static uint8_t *allocation_tag_mem(CPUARMState *env, int = ptr_mmu_idx, =20 tags =3D page_get_target_data(clean_ptr); if (tags =3D=3D NULL) { - size_t alloc_size =3D TARGET_PAGE_SIZE >> (LOG2_TAG_GRANULE + 1); - tags =3D page_alloc_target_data(clean_ptr, alloc_size); + tags =3D page_alloc_target_data(clean_ptr); assert(tags !=3D NULL); } =20 --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751080; cv=none; d=zohomail.com; s=zohoarc; b=CHpLY4Ek1g9WB2OXJqO+xv5NEDBaNtYhKMGxuqAM2IaE960Njqr4m84yMNKiRRoqw3QSzJauWo7CBZHSWluadPzLyd7pKycBbN8bpgPsGW/LxtabjaqMBCZhokFYQe41g4fBpN04r1GAeganFZ2E5DbiB+AxSXw13k5Znzj6FLg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751080; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=BPiDOXuJlTG0AgncYY09MVfeOS94NwO0enHpea3qlzk=; b=BGT+eejog1fc9Dn5NrXkauCBzFH6NWx/AagdHluVYq+rBWzcM9nz+bY8Fdo1eabR07kpYWtXXvfUw5FOnmoGzOZmaGPsLd6KDIQHpukQs0YD6YJ43RjBFTl8DL1wXXjfUliDn5hZnkgj0IPHR30DgXL7WGpVQwbSezriM/2cC7Y= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751080211470.20953787939357; Tue, 25 Oct 2022 19:24:40 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVte-0004sV-MJ; Tue, 25 Oct 2022 22:11:58 -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 1onVtZ-0004s5-EM for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:53 -0400 Received: from mail-pg1-x531.google.com ([2607:f8b0:4864:20::531]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtX-00019J-NW for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:53 -0400 Received: by mail-pg1-x531.google.com with SMTP id 20so13456423pgc.5 for ; Tue, 25 Oct 2022 19:11:51 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=BPiDOXuJlTG0AgncYY09MVfeOS94NwO0enHpea3qlzk=; b=EmUxRxvV3dM6zYeIvTPiWxmehQUySmF4Eow8itRUX4BPO8AXhCauBjysF9qpwJvpW7 bWh72I+eWCVxV+qZgV4JvNFLX8lRss0gYBGRaEBXoH+BVsRFHzlMYK6Gt9ZEm6raXzek pqQVa7iM+SFXxYwldqldxitm1ivHYvosgt+KrwzBrmaBGcZJp+dWkEllsT9/xsOUUGUi HGsFQ2vXsi8Z42uJq2Wu4OhMpOvoN/9pZkcg3ag9qAk+TDa/4dZiy5iIRIssnJj+GWQh 9bPmp3nk7xaDKz+Dr1Gazrm9B4MwtEf0Z3n7i6UnAmKTYzMHue24PMcLNx5BmGU2M2f9 z/JQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=BPiDOXuJlTG0AgncYY09MVfeOS94NwO0enHpea3qlzk=; b=QeLxXmobquO+zpYQa3bvgHW3bodFZo5QWTouFa8Dm/8+Klr2dlzhGUz1RIz1itkGiY inbf03lMU32IGLP5qHfCdmiBhx1ad6oqMkLXVt+jYSv043//+dXGlClCeNrMbNxW/hCG 3xuz4TPQA3dI+IK2Qpac+ngLStqZEBXtn6A1e14R3OEqcApoe/6gMCr33B5lGlBhZJt7 R4DqlpcaiqDWifaBTe8Fli6/7PxBUluqudMN0SAs1875IAz8wsPto0qF4ixicK76pVFP fGBl1jbDvITicxKegNuNL5T6/GGF081r+Gali3AD5fc1an/XvyvvpxJAofZpFKVHLYho QFVg== X-Gm-Message-State: ACrzQf3NBsmKZ1edGe3HawbyE/7TL8+SOkeRI3chkFGJZRQZB5znaSGD mLo4sq88lk3MPumQwaMYXXTiRBoQ+vFVZT3u X-Google-Smtp-Source: AMsMyM4LsgTciDZGrim6Z5NyovjTD1Xy8H8TwLjVOOak175g2uY3P9dqmUq2wQtQji4ofs0ZFAQKhw== X-Received: by 2002:a63:5b53:0:b0:462:7149:2c54 with SMTP id l19-20020a635b53000000b0046271492c54mr34642091pgm.527.1666750310201; Tue, 25 Oct 2022 19:11:50 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 09/47] accel/tcg: Remove disabled debug in translate-all.c Date: Wed, 26 Oct 2022 12:10:38 +1000 Message-Id: <20221026021116.1988449-10-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::531; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x531.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751081289100001 These items printf, and could be replaced with proper tracepoints if we really cared. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/translate-all.c | 109 -------------------------------------- 1 file changed, 109 deletions(-) diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 64a2601f9f..42385fa032 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -63,33 +63,7 @@ #include "tb-context.h" #include "internal.h" =20 -/* #define DEBUG_TB_INVALIDATE */ -/* #define DEBUG_TB_FLUSH */ /* make various TB consistency checks */ -/* #define DEBUG_TB_CHECK */ - -#ifdef DEBUG_TB_INVALIDATE -#define DEBUG_TB_INVALIDATE_GATE 1 -#else -#define DEBUG_TB_INVALIDATE_GATE 0 -#endif - -#ifdef DEBUG_TB_FLUSH -#define DEBUG_TB_FLUSH_GATE 1 -#else -#define DEBUG_TB_FLUSH_GATE 0 -#endif - -#if !defined(CONFIG_USER_ONLY) -/* TB consistency checks only implemented for usermode emulation. */ -#undef DEBUG_TB_CHECK -#endif - -#ifdef DEBUG_TB_CHECK -#define DEBUG_TB_CHECK_GATE 1 -#else -#define DEBUG_TB_CHECK_GATE 0 -#endif =20 /* Access to the various translations structures need to be serialised via= locks * for consistency. @@ -940,15 +914,6 @@ static void page_flush_tb(void) } } =20 -static gboolean tb_host_size_iter(gpointer key, gpointer value, gpointer d= ata) -{ - const TranslationBlock *tb =3D value; - size_t *size =3D data; - - *size +=3D tb->tc.size; - return false; -} - /* flush all the translation blocks */ static void do_tb_flush(CPUState *cpu, run_on_cpu_data tb_flush_count) { @@ -963,15 +928,6 @@ static void do_tb_flush(CPUState *cpu, run_on_cpu_data= tb_flush_count) } did_flush =3D true; =20 - if (DEBUG_TB_FLUSH_GATE) { - size_t nb_tbs =3D tcg_nb_tbs(); - size_t host_size =3D 0; - - tcg_tb_foreach(tb_host_size_iter, &host_size); - printf("qemu: flush code_size=3D%zu nb_tbs=3D%zu avg_tb_size=3D%zu= \n", - tcg_code_size(), nb_tbs, nb_tbs > 0 ? host_size / nb_tbs : = 0); - } - CPU_FOREACH(cpu) { tcg_flush_jmp_cache(cpu); } @@ -1005,57 +961,6 @@ void tb_flush(CPUState *cpu) } } =20 -/* - * Formerly ifdef DEBUG_TB_CHECK. These debug functions are user-mode-only, - * so in order to prevent bit rot we compile them unconditionally in user-= mode, - * and let the optimizer get rid of them by wrapping their user-only calle= rs - * with if (DEBUG_TB_CHECK_GATE). - */ -#ifdef CONFIG_USER_ONLY - -static void do_tb_invalidate_check(void *p, uint32_t hash, void *userp) -{ - TranslationBlock *tb =3D p; - target_ulong addr =3D *(target_ulong *)userp; - - if (!(addr + TARGET_PAGE_SIZE <=3D tb_pc(tb) || - addr >=3D tb_pc(tb) + tb->size)) { - printf("ERROR invalidate: address=3D" TARGET_FMT_lx - " PC=3D%08lx size=3D%04x\n", addr, (long)tb_pc(tb), tb->siz= e); - } -} - -/* verify that all the pages have correct rights for code - * - * Called with mmap_lock held. - */ -static void tb_invalidate_check(target_ulong address) -{ - address &=3D TARGET_PAGE_MASK; - qht_iter(&tb_ctx.htable, do_tb_invalidate_check, &address); -} - -static void do_tb_page_check(void *p, uint32_t hash, void *userp) -{ - TranslationBlock *tb =3D p; - int flags1, flags2; - - flags1 =3D page_get_flags(tb_pc(tb)); - flags2 =3D page_get_flags(tb_pc(tb) + tb->size - 1); - if ((flags1 & PAGE_WRITE) || (flags2 & PAGE_WRITE)) { - printf("ERROR page flags: PC=3D%08lx size=3D%04x f1=3D%x f2=3D%x\n= ", - (long)tb_pc(tb), tb->size, flags1, flags2); - } -} - -/* verify that all the pages have correct rights for code */ -static void tb_page_check(void) -{ - qht_iter(&tb_ctx.htable, do_tb_page_check, NULL); -} - -#endif /* CONFIG_USER_ONLY */ - /* * user-mode: call with mmap_lock held * !user-mode: call with @pd->lock held @@ -1339,12 +1244,6 @@ tb_link_page(TranslationBlock *tb, tb_page_addr_t ph= ys_pc, page_unlock(p2); } page_unlock(p); - -#ifdef CONFIG_USER_ONLY - if (DEBUG_TB_CHECK_GATE) { - tb_page_check(); - } -#endif return tb; } =20 @@ -2400,9 +2299,6 @@ void page_protect(tb_page_addr_t page_addr) } mprotect(g2h_untagged(page_addr), qemu_host_page_size, (prot & PAGE_BITS) & ~PAGE_WRITE); - if (DEBUG_TB_INVALIDATE_GATE) { - printf("protecting code page: 0x" TB_PAGE_ADDR_FMT "\n", page_= addr); - } } } =20 @@ -2458,11 +2354,6 @@ int page_unprotect(target_ulong address, uintptr_t p= c) /* and since the content will be modified, we must invalid= ate the corresponding translated code. */ current_tb_invalidated |=3D tb_invalidate_phys_page(addr, = pc); -#ifdef CONFIG_USER_ONLY - if (DEBUG_TB_CHECK_GATE) { - tb_invalidate_check(addr); - } -#endif } mprotect((void *)g2h_untagged(host_start), qemu_host_page_size, prot & PAGE_BITS); --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750733; cv=none; d=zohomail.com; s=zohoarc; b=BQ1uIwm2tp3mvFvlnOpSELaJ2yV+HY+05ZRmv6LVzhQxcgyk5+Xar86rXVGWkV5BVEBssPM//jxf1NcP/fF9wCCeXhrcqKpzPF9ICQYU8tPttgO3BKqnDAikPPa6uDVV/83IOREinnWwgqs5O/vcnQVpQzam7C7eJBLlifcy/r4= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750733; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=2O2lTkgF9rzGFGHASrYzq+88u+IS7lRPeNlhOf/ZoVg=; b=TQu0WR64ZGWVrUkbPTJBf1NPrX5ZupmQVUyKEcj/QmPaUlmzRf0+XU/PeYysoIau9pUsWOMh3m9Nd16LTqmAlI3orWAz5GDrdnE7MmwVMkTA9btAMefo9JRlgV7gTd0hxDBZQGq4cy4XB2I5R4w8Z2AwoYkoPC/h2ixKsh6MRLA= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750733293258.0239082912226; Tue, 25 Oct 2022 19:18:53 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtf-0004t1-Pc; Tue, 25 Oct 2022 22:11:59 -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 1onVtb-0004sX-93 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:58 -0400 Received: from mail-pf1-x429.google.com ([2607:f8b0:4864:20::429]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtZ-00010z-Nb for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:11:55 -0400 Received: by mail-pf1-x429.google.com with SMTP id w189so12449432pfw.4 for ; Tue, 25 Oct 2022 19:11:53 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=2O2lTkgF9rzGFGHASrYzq+88u+IS7lRPeNlhOf/ZoVg=; b=mNLHtAwwYwZa7OlV3Z1/fw7UTst7REdsks7oNNGZT5/pB2TgCxmqoPyMVfY07CAvRq Lkrw3TCmDqh5r361smbgM8CDVC5XIWIsAVpWgKMKvQe/KBpxQj2muAF1lYyotGdyKLbl Asy+JtGtGiw9jUgg6c8p4sSF9DmjP4UggjIrZL/pZFrI2lxR+skmknDyRelmWPqMFUtb 6YlFr8QRfedH2vGUkHve0Xb7VVdoVI+xgEZDvAI0rfb2y6ntYFO49gF0yHapojH7eLpL Jz/cnacz3z1XkzHc4KardiVwR0zfwLvBT4642P89xtynb05dbMhuyE9Rx7SObwKKeYjA ciYQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=2O2lTkgF9rzGFGHASrYzq+88u+IS7lRPeNlhOf/ZoVg=; b=uFICcPGJi3ZVS4e7Fe3WxbcaTIeVEluOLjz02cRxrPuv6BYFPdEhHa82o+0VpYmIh6 gpZaFmhwby0XQsFjFdzsdHfZ9jkfHunnGQQOWaexBs4U0gYJmWJl0kE7XksguGMGhLcT ELRCYaXJm4BsCOThdpu/E2y6eL/sG5muSRXXppqh4nmpEFzVM6islujcjsAMsfZiMrNu ZjlhIxapbYX9yKW7lqTIWKSdKGQM5pG02HKsZ19OnCWGPA7fRsbXeqSBpOcK8Jfr1YWP 8cvRG88DvzDpHunGOXAE6S4vU7mPE09c6A+w9+AtOhoEoXuCS5zaHO6oCvqWYQnyihPP qpZA== X-Gm-Message-State: ACrzQf0yDFC3SIoq8NYNRcQ1wegbBOcWHDv50qZ9Rr4uBxrtc1SrfCPM +GNN4813p7840IjfgVoAzVrn/6cTu7BPHMaG X-Google-Smtp-Source: AMsMyM5CV1YoycRi/TuY9UtyaPi+GesRYBvNCx6Xs19TPASh3JfOaYPbdNsyK+uJYniZCRRJ+8rr1A== X-Received: by 2002:a05:6a00:1414:b0:563:ae66:3103 with SMTP id l20-20020a056a00141400b00563ae663103mr41258678pfu.17.1666750312851; Tue, 25 Oct 2022 19:11:52 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 10/47] accel/tcg: Split out PageDesc to internal.h Date: Wed, 26 Oct 2022 12:10:39 +1000 Message-Id: <20221026021116.1988449-11-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::429; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x429.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750735411100006 Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/internal.h | 31 +++++++++++++++++++++++++++++++ accel/tcg/translate-all.c | 31 +------------------------------ 2 files changed, 32 insertions(+), 30 deletions(-) diff --git a/accel/tcg/internal.h b/accel/tcg/internal.h index dc800fd485..62da49ed52 100644 --- a/accel/tcg/internal.h +++ b/accel/tcg/internal.h @@ -11,6 +11,37 @@ =20 #include "exec/exec-all.h" =20 +/* + * Access to the various translations structures need to be serialised + * via locks for consistency. In user-mode emulation access to the + * memory related structures are protected with mmap_lock. + * In !user-mode we use per-page locks. + */ +#ifdef CONFIG_SOFTMMU +#define assert_memory_lock() +#else +#define assert_memory_lock() tcg_debug_assert(have_mmap_lock()) +#endif + +typedef struct PageDesc { + /* list of TBs intersecting this ram page */ + uintptr_t first_tb; +#ifdef CONFIG_USER_ONLY + unsigned long flags; + void *target_data; +#endif +#ifdef CONFIG_SOFTMMU + QemuSpin lock; +#endif +} PageDesc; + +PageDesc *page_find_alloc(tb_page_addr_t index, bool alloc); + +static inline PageDesc *page_find(tb_page_addr_t index) +{ + return page_find_alloc(index, false); +} + TranslationBlock *tb_gen_code(CPUState *cpu, target_ulong pc, target_ulong cs_base, uint32_t flags, int cflags); diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 42385fa032..86848c6743 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -65,30 +65,6 @@ =20 /* make various TB consistency checks */ =20 -/* Access to the various translations structures need to be serialised via= locks - * for consistency. - * In user-mode emulation access to the memory related structures are prot= ected - * with mmap_lock. - * In !user-mode we use per-page locks. - */ -#ifdef CONFIG_SOFTMMU -#define assert_memory_lock() -#else -#define assert_memory_lock() tcg_debug_assert(have_mmap_lock()) -#endif - -typedef struct PageDesc { - /* list of TBs intersecting this ram page */ - uintptr_t first_tb; -#ifdef CONFIG_USER_ONLY - unsigned long flags; - void *target_data; -#endif -#ifdef CONFIG_SOFTMMU - QemuSpin lock; -#endif -} PageDesc; - /** * struct page_entry - page descriptor entry * @pd: pointer to the &struct PageDesc of the page this entry represe= nts @@ -445,7 +421,7 @@ void page_init(void) #endif } =20 -static PageDesc *page_find_alloc(tb_page_addr_t index, bool alloc) +PageDesc *page_find_alloc(tb_page_addr_t index, bool alloc) { PageDesc *pd; void **lp; @@ -511,11 +487,6 @@ static PageDesc *page_find_alloc(tb_page_addr_t index,= bool alloc) return pd + (index & (V_L2_SIZE - 1)); } =20 -static inline PageDesc *page_find(tb_page_addr_t index) -{ - return page_find_alloc(index, false); -} - static void page_lock_pair(PageDesc **ret_p1, tb_page_addr_t phys1, PageDesc **ret_p2, tb_page_addr_t phys2, bool a= lloc); =20 --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750820; cv=none; d=zohomail.com; s=zohoarc; b=KZKGZXvvfAGR3cY0nR9bySv/++K+FXmcc1+CPe4JkovyZsifRBYlfOFUK1Hz6JeB83jx4rrMBUMAH/sU2lTGEUZSGdsMVKh/UpfRcIU7hxtARdQ5PDsf+Q0N9W5dHTptYeiIdBzXF0cBv5/MlIAKHD6knYFe1cjWAxm20Ki9gxQ= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750820; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=fx9+PTiikrfDGE58PwgFEGGil2RpZm2a7709HEgNc5w=; b=XZKLsM65LcS7uifluYKcHAxRX/aPuDYjIt/gUfRbdjMlfPgvQjwk992Ibdf1FoHawJafrzZ3Yz+I7XIgNqvKcDbmqUOt4aCa4WLsRJkaW7G+iB0Wd7+z6mq8yxBNsbqu34gKex1CoLRpjmMQiQNi31Iu64p0IDbZ1j1UE/HPtZM= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750820471599.8430538200677; Tue, 25 Oct 2022 19:20:20 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtk-0004tt-0h; Tue, 25 Oct 2022 22:12:04 -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 1onVti-0004tR-Am for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:02 -0400 Received: from mail-pj1-x1036.google.com ([2607:f8b0:4864:20::1036]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtd-0001AB-Ns for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:02 -0400 Received: by mail-pj1-x1036.google.com with SMTP id h14so12686025pjv.4 for ; Tue, 25 Oct 2022 19:11:57 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=fx9+PTiikrfDGE58PwgFEGGil2RpZm2a7709HEgNc5w=; b=Ei3S0iz9uVJ6Kgr9QdI6KIBFbRkmBnihPTzoOwTQkMBrFHKR2zFGdAj7FQ8SuLfjba oqZVMDounT+APf/daP4gfvy4E7artxHXl1ylh9NA2VoQqcyMPg6M2NBGIXLS2muPRzbd +iISG3NdTjJiODi0k72/lUGUEm/I0cI3EC1n3cVWyylsyfbYjK0/RfQHTyHqiLPZDaHK Zf/zqQ12wYFhYd+vvfp3s3Gt3fzD/ZDsuMk33sO8IwtRhgENKxZzgu2kxjt7qUbuJqFN 125bXmDE08Oksi504rtc7Dlnl9Mf5MOzNsblXIOWUKFw0VkhUmJFkpyRtZMr276V3Mak 8o4g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=fx9+PTiikrfDGE58PwgFEGGil2RpZm2a7709HEgNc5w=; b=dYReUDzz/KwRnU5Yw0HcNAGy03LMHpww7hsbq9qpTY1N7qZPmn/t3tTd6jS/VbM6FE NDD7H95XuizW0ppmWGgtyA8YD04UMeMQhpqKY5C5fZ4POII/CGlUXsBzTiAbXBA8oGzD z9YXy8xuZ99iR22LpHYwqsWT/LyAVjj1VgKB8/65ACQu/ChQTEeYejTtULbxI5qXOAmF xliA4h1uH+YVYWT1HTGBLcLMbJVvxlALs6Z/H7AKfh4BVGIl2Kqa3uwH3ZgXvactrMQy heAP91d2TJRwIX5uIuCSq+44CMmhio6NrBbfk9sNgOe25M1uAVSNZaQZqW3ZZy/SVsyL z0GA== X-Gm-Message-State: ACrzQf2qRMoFjkX5Fjv1HuaeXb2rxneCl93LpZMjRWd/fDGzErvZwYbm IUxxuFvWgaw7j1DbSn+tQ+BEDo8egpAu7wfL X-Google-Smtp-Source: AMsMyM75mBoo+rE5lMj+z8y8bAejaYNDCmCOVTqB45RZUXVHCOqFO1EYU8t6tlesQrcpZY5TCLFscg== X-Received: by 2002:a17:90a:bf11:b0:211:84c5:42d7 with SMTP id c17-20020a17090abf1100b0021184c542d7mr1481818pjs.122.1666750315795; Tue, 25 Oct 2022 19:11:55 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 11/47] accel/tcg: Split out tb-maint.c Date: Wed, 26 Oct 2022 12:10:40 +1000 Message-Id: <20221026021116.1988449-12-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::1036; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x1036.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750821943100003 Move all of the TranslationBlock flushing and page linking code from translate-all.c to tb-maint.c. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/internal.h | 55 +++ accel/tcg/tb-maint.c | 735 ++++++++++++++++++++++++++++++++++++ accel/tcg/translate-all.c | 766 +------------------------------------- accel/tcg/meson.build | 1 + 4 files changed, 802 insertions(+), 755 deletions(-) create mode 100644 accel/tcg/tb-maint.c diff --git a/accel/tcg/internal.h b/accel/tcg/internal.h index 62da49ed52..a77b110b78 100644 --- a/accel/tcg/internal.h +++ b/accel/tcg/internal.h @@ -35,6 +35,27 @@ typedef struct PageDesc { #endif } PageDesc; =20 +/* Size of the L2 (and L3, etc) page tables. */ +#define V_L2_BITS 10 +#define V_L2_SIZE (1 << V_L2_BITS) + +/* + * L1 Mapping properties + */ +extern int v_l1_size; +extern int v_l1_shift; +extern int v_l2_levels; + +/* + * The bottom level has pointers to PageDesc, and is indexed by + * anything from 4 to (V_L2_BITS + 3) bits, depending on target page size. + */ +#define V_L1_MIN_BITS 4 +#define V_L1_MAX_BITS (V_L2_BITS + 3) +#define V_L1_MAX_SIZE (1 << V_L1_MAX_BITS) + +extern void *l1_map[V_L1_MAX_SIZE]; + PageDesc *page_find_alloc(tb_page_addr_t index, bool alloc); =20 static inline PageDesc *page_find(tb_page_addr_t index) @@ -42,12 +63,46 @@ static inline PageDesc *page_find(tb_page_addr_t index) return page_find_alloc(index, false); } =20 +/* list iterators for lists of tagged pointers in TranslationBlock */ +#define TB_FOR_EACH_TAGGED(head, tb, n, field) \ + for (n =3D (head) & 1, tb =3D (TranslationBlock *)((head) & ~1); = \ + tb; tb =3D (TranslationBlock *)tb->field[n], n =3D (uintptr_t)tb = & 1, \ + tb =3D (TranslationBlock *)((uintptr_t)tb & ~1)) + +#define PAGE_FOR_EACH_TB(pagedesc, tb, n) \ + TB_FOR_EACH_TAGGED((pagedesc)->first_tb, tb, n, page_next) + +#define TB_FOR_EACH_JMP(head_tb, tb, n) \ + TB_FOR_EACH_TAGGED((head_tb)->jmp_list_head, tb, n, jmp_list_next) + +/* In user-mode page locks aren't used; mmap_lock is enough */ +#ifdef CONFIG_USER_ONLY +#define assert_page_locked(pd) tcg_debug_assert(have_mmap_lock()) +static inline void page_lock(PageDesc *pd) { } +static inline void page_unlock(PageDesc *pd) { } +#else +#ifdef CONFIG_DEBUG_TCG +void do_assert_page_locked(const PageDesc *pd, const char *file, int line); +#define assert_page_locked(pd) do_assert_page_locked(pd, __FILE__, __LINE_= _) +#else +#define assert_page_locked(pd) +#endif +void page_lock(PageDesc *pd); +void page_unlock(PageDesc *pd); +#endif + TranslationBlock *tb_gen_code(CPUState *cpu, target_ulong pc, target_ulong cs_base, uint32_t flags, int cflags); G_NORETURN void cpu_io_recompile(CPUState *cpu, uintptr_t retaddr); void page_init(void); void tb_htable_init(void); +void tb_reset_jump(TranslationBlock *tb, int n); +TranslationBlock *tb_link_page(TranslationBlock *tb, tb_page_addr_t phys_p= c, + tb_page_addr_t phys_page2); +bool tb_invalidate_phys_page(tb_page_addr_t addr, uintptr_t pc); +int cpu_restore_state_from_tb(CPUState *cpu, TranslationBlock *tb, + uintptr_t searched_pc, bool reset_icount); =20 /* Return the current PC from CPU, which may be cached in TB. */ static inline target_ulong log_pc(CPUState *cpu, const TranslationBlock *t= b) diff --git a/accel/tcg/tb-maint.c b/accel/tcg/tb-maint.c new file mode 100644 index 0000000000..66c1900ae6 --- /dev/null +++ b/accel/tcg/tb-maint.c @@ -0,0 +1,735 @@ +/* + * Translation Block Maintaince + * + * Copyright (c) 2003 Fabrice Bellard + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, see . + */ + +#include "qemu/osdep.h" +#include "exec/cputlb.h" +#include "exec/log.h" +#include "exec/translate-all.h" +#include "sysemu/tcg.h" +#include "tcg/tcg.h" +#include "tb-hash.h" +#include "tb-context.h" +#include "internal.h" + +/* FIXME: tb_invalidate_phys_range is declared in different places. */ +#ifdef CONFIG_USER_ONLY +#include "exec/exec-all.h" +#else +#include "exec/ram_addr.h" +#endif + +static bool tb_cmp(const void *ap, const void *bp) +{ + const TranslationBlock *a =3D ap; + const TranslationBlock *b =3D bp; + + return ((TARGET_TB_PCREL || tb_pc(a) =3D=3D tb_pc(b)) && + a->cs_base =3D=3D b->cs_base && + a->flags =3D=3D b->flags && + (tb_cflags(a) & ~CF_INVALID) =3D=3D (tb_cflags(b) & ~CF_INVALI= D) && + a->trace_vcpu_dstate =3D=3D b->trace_vcpu_dstate && + a->page_addr[0] =3D=3D b->page_addr[0] && + a->page_addr[1] =3D=3D b->page_addr[1]); +} + +void tb_htable_init(void) +{ + unsigned int mode =3D QHT_MODE_AUTO_RESIZE; + + qht_init(&tb_ctx.htable, tb_cmp, CODE_GEN_HTABLE_SIZE, mode); +} + +/* Set to NULL all the 'first_tb' fields in all PageDescs. */ +static void page_flush_tb_1(int level, void **lp) +{ + int i; + + if (*lp =3D=3D NULL) { + return; + } + if (level =3D=3D 0) { + PageDesc *pd =3D *lp; + + for (i =3D 0; i < V_L2_SIZE; ++i) { + page_lock(&pd[i]); + pd[i].first_tb =3D (uintptr_t)NULL; + page_unlock(&pd[i]); + } + } else { + void **pp =3D *lp; + + for (i =3D 0; i < V_L2_SIZE; ++i) { + page_flush_tb_1(level - 1, pp + i); + } + } +} + +static void page_flush_tb(void) +{ + int i, l1_sz =3D v_l1_size; + + for (i =3D 0; i < l1_sz; i++) { + page_flush_tb_1(v_l2_levels, l1_map + i); + } +} + +/* flush all the translation blocks */ +static void do_tb_flush(CPUState *cpu, run_on_cpu_data tb_flush_count) +{ + bool did_flush =3D false; + + mmap_lock(); + /* If it is already been done on request of another CPU, just retry. */ + if (tb_ctx.tb_flush_count !=3D tb_flush_count.host_int) { + goto done; + } + did_flush =3D true; + + CPU_FOREACH(cpu) { + tcg_flush_jmp_cache(cpu); + } + + qht_reset_size(&tb_ctx.htable, CODE_GEN_HTABLE_SIZE); + page_flush_tb(); + + tcg_region_reset_all(); + /* XXX: flush processor icache at this point if cache flush is expensi= ve */ + qatomic_mb_set(&tb_ctx.tb_flush_count, tb_ctx.tb_flush_count + 1); + +done: + mmap_unlock(); + if (did_flush) { + qemu_plugin_flush_cb(); + } +} + +void tb_flush(CPUState *cpu) +{ + if (tcg_enabled()) { + unsigned tb_flush_count =3D qatomic_mb_read(&tb_ctx.tb_flush_count= ); + + if (cpu_in_exclusive_context(cpu)) { + do_tb_flush(cpu, RUN_ON_CPU_HOST_INT(tb_flush_count)); + } else { + async_safe_run_on_cpu(cpu, do_tb_flush, + RUN_ON_CPU_HOST_INT(tb_flush_count)); + } + } +} + +/* + * user-mode: call with mmap_lock held + * !user-mode: call with @pd->lock held + */ +static inline void tb_page_remove(PageDesc *pd, TranslationBlock *tb) +{ + TranslationBlock *tb1; + uintptr_t *pprev; + unsigned int n1; + + assert_page_locked(pd); + pprev =3D &pd->first_tb; + PAGE_FOR_EACH_TB(pd, tb1, n1) { + if (tb1 =3D=3D tb) { + *pprev =3D tb1->page_next[n1]; + return; + } + pprev =3D &tb1->page_next[n1]; + } + g_assert_not_reached(); +} + +/* remove @orig from its @n_orig-th jump list */ +static inline void tb_remove_from_jmp_list(TranslationBlock *orig, int n_o= rig) +{ + uintptr_t ptr, ptr_locked; + TranslationBlock *dest; + TranslationBlock *tb; + uintptr_t *pprev; + int n; + + /* mark the LSB of jmp_dest[] so that no further jumps can be inserted= */ + ptr =3D qatomic_or_fetch(&orig->jmp_dest[n_orig], 1); + dest =3D (TranslationBlock *)(ptr & ~1); + if (dest =3D=3D NULL) { + return; + } + + qemu_spin_lock(&dest->jmp_lock); + /* + * While acquiring the lock, the jump might have been removed if the + * destination TB was invalidated; check again. + */ + ptr_locked =3D qatomic_read(&orig->jmp_dest[n_orig]); + if (ptr_locked !=3D ptr) { + qemu_spin_unlock(&dest->jmp_lock); + /* + * The only possibility is that the jump was unlinked via + * tb_jump_unlink(dest). Seeing here another destination would be = a bug, + * because we set the LSB above. + */ + g_assert(ptr_locked =3D=3D 1 && dest->cflags & CF_INVALID); + return; + } + /* + * We first acquired the lock, and since the destination pointer match= es, + * we know for sure that @orig is in the jmp list. + */ + pprev =3D &dest->jmp_list_head; + TB_FOR_EACH_JMP(dest, tb, n) { + if (tb =3D=3D orig && n =3D=3D n_orig) { + *pprev =3D tb->jmp_list_next[n]; + /* no need to set orig->jmp_dest[n]; setting the LSB was enoug= h */ + qemu_spin_unlock(&dest->jmp_lock); + return; + } + pprev =3D &tb->jmp_list_next[n]; + } + g_assert_not_reached(); +} + +/* + * Reset the jump entry 'n' of a TB so that it is not chained to another T= B. + */ +void tb_reset_jump(TranslationBlock *tb, int n) +{ + uintptr_t addr =3D (uintptr_t)(tb->tc.ptr + tb->jmp_reset_offset[n]); + tb_set_jmp_target(tb, n, addr); +} + +/* remove any jumps to the TB */ +static inline void tb_jmp_unlink(TranslationBlock *dest) +{ + TranslationBlock *tb; + int n; + + qemu_spin_lock(&dest->jmp_lock); + + TB_FOR_EACH_JMP(dest, tb, n) { + tb_reset_jump(tb, n); + qatomic_and(&tb->jmp_dest[n], (uintptr_t)NULL | 1); + /* No need to clear the list entry; setting the dest ptr is enough= */ + } + dest->jmp_list_head =3D (uintptr_t)NULL; + + qemu_spin_unlock(&dest->jmp_lock); +} + +static void tb_jmp_cache_inval_tb(TranslationBlock *tb) +{ + CPUState *cpu; + + if (TARGET_TB_PCREL) { + /* A TB may be at any virtual address */ + CPU_FOREACH(cpu) { + tcg_flush_jmp_cache(cpu); + } + } else { + uint32_t h =3D tb_jmp_cache_hash_func(tb_pc(tb)); + + CPU_FOREACH(cpu) { + CPUJumpCache *jc =3D cpu->tb_jmp_cache; + + if (qatomic_read(&jc->array[h].tb) =3D=3D tb) { + qatomic_set(&jc->array[h].tb, NULL); + } + } + } +} + +/* + * In user-mode, call with mmap_lock held. + * In !user-mode, if @rm_from_page_list is set, call with the TB's pages' + * locks held. + */ +static void do_tb_phys_invalidate(TranslationBlock *tb, bool rm_from_page_= list) +{ + PageDesc *p; + uint32_t h; + tb_page_addr_t phys_pc; + uint32_t orig_cflags =3D tb_cflags(tb); + + assert_memory_lock(); + + /* make sure no further incoming jumps will be chained to this TB */ + qemu_spin_lock(&tb->jmp_lock); + qatomic_set(&tb->cflags, tb->cflags | CF_INVALID); + qemu_spin_unlock(&tb->jmp_lock); + + /* remove the TB from the hash list */ + phys_pc =3D tb->page_addr[0]; + h =3D tb_hash_func(phys_pc, (TARGET_TB_PCREL ? 0 : tb_pc(tb)), + tb->flags, orig_cflags, tb->trace_vcpu_dstate); + if (!qht_remove(&tb_ctx.htable, tb, h)) { + return; + } + + /* remove the TB from the page list */ + if (rm_from_page_list) { + p =3D page_find(tb->page_addr[0] >> TARGET_PAGE_BITS); + tb_page_remove(p, tb); + if (tb->page_addr[1] !=3D -1) { + p =3D page_find(tb->page_addr[1] >> TARGET_PAGE_BITS); + tb_page_remove(p, tb); + } + } + + /* remove the TB from the hash list */ + tb_jmp_cache_inval_tb(tb); + + /* suppress this TB from the two jump lists */ + tb_remove_from_jmp_list(tb, 0); + tb_remove_from_jmp_list(tb, 1); + + /* suppress any remaining jumps to this TB */ + tb_jmp_unlink(tb); + + qatomic_set(&tb_ctx.tb_phys_invalidate_count, + tb_ctx.tb_phys_invalidate_count + 1); +} + +static void tb_phys_invalidate__locked(TranslationBlock *tb) +{ + qemu_thread_jit_write(); + do_tb_phys_invalidate(tb, true); + qemu_thread_jit_execute(); +} + +static void page_lock_pair(PageDesc **ret_p1, tb_page_addr_t phys1, + PageDesc **ret_p2, tb_page_addr_t phys2, bool a= lloc) +{ + PageDesc *p1, *p2; + tb_page_addr_t page1; + tb_page_addr_t page2; + + assert_memory_lock(); + g_assert(phys1 !=3D -1); + + page1 =3D phys1 >> TARGET_PAGE_BITS; + page2 =3D phys2 >> TARGET_PAGE_BITS; + + p1 =3D page_find_alloc(page1, alloc); + if (ret_p1) { + *ret_p1 =3D p1; + } + if (likely(phys2 =3D=3D -1)) { + page_lock(p1); + return; + } else if (page1 =3D=3D page2) { + page_lock(p1); + if (ret_p2) { + *ret_p2 =3D p1; + } + return; + } + p2 =3D page_find_alloc(page2, alloc); + if (ret_p2) { + *ret_p2 =3D p2; + } + if (page1 < page2) { + page_lock(p1); + page_lock(p2); + } else { + page_lock(p2); + page_lock(p1); + } +} + +#ifdef CONFIG_USER_ONLY +static inline void page_lock_tb(const TranslationBlock *tb) { } +static inline void page_unlock_tb(const TranslationBlock *tb) { } +#else +/* lock the page(s) of a TB in the correct acquisition order */ +static void page_lock_tb(const TranslationBlock *tb) +{ + page_lock_pair(NULL, tb->page_addr[0], NULL, tb->page_addr[1], false); +} + +static void page_unlock_tb(const TranslationBlock *tb) +{ + PageDesc *p1 =3D page_find(tb->page_addr[0] >> TARGET_PAGE_BITS); + + page_unlock(p1); + if (unlikely(tb->page_addr[1] !=3D -1)) { + PageDesc *p2 =3D page_find(tb->page_addr[1] >> TARGET_PAGE_BITS); + + if (p2 !=3D p1) { + page_unlock(p2); + } + } +} +#endif + +/* + * Invalidate one TB. + * Called with mmap_lock held in user-mode. + */ +void tb_phys_invalidate(TranslationBlock *tb, tb_page_addr_t page_addr) +{ + if (page_addr =3D=3D -1 && tb->page_addr[0] !=3D -1) { + page_lock_tb(tb); + do_tb_phys_invalidate(tb, true); + page_unlock_tb(tb); + } else { + do_tb_phys_invalidate(tb, false); + } +} + +/* + * Add the tb in the target page and protect it if necessary. + * Called with mmap_lock held for user-mode emulation. + * Called with @p->lock held in !user-mode. + */ +static inline void tb_page_add(PageDesc *p, TranslationBlock *tb, + unsigned int n, tb_page_addr_t page_addr) +{ +#ifndef CONFIG_USER_ONLY + bool page_already_protected; +#endif + + assert_page_locked(p); + + tb->page_addr[n] =3D page_addr; + tb->page_next[n] =3D p->first_tb; +#ifndef CONFIG_USER_ONLY + page_already_protected =3D p->first_tb !=3D (uintptr_t)NULL; +#endif + p->first_tb =3D (uintptr_t)tb | n; + +#if defined(CONFIG_USER_ONLY) + /* translator_loop() must have made all TB pages non-writable */ + assert(!(p->flags & PAGE_WRITE)); +#else + /* + * If some code is already present, then the pages are already + * protected. So we handle the case where only the first TB is + * allocated in a physical page. + */ + if (!page_already_protected) { + tlb_protect_code(page_addr); + } +#endif +} + +/* + * Add a new TB and link it to the physical page tables. phys_page2 is + * (-1) to indicate that only one page contains the TB. + * + * Called with mmap_lock held for user-mode emulation. + * + * Returns a pointer @tb, or a pointer to an existing TB that matches @tb. + * Note that in !user-mode, another thread might have already added a TB + * for the same block of guest code that @tb corresponds to. In that case, + * the caller should discard the original @tb, and use instead the returne= d TB. + */ +TranslationBlock *tb_link_page(TranslationBlock *tb, tb_page_addr_t phys_p= c, + tb_page_addr_t phys_page2) +{ + PageDesc *p; + PageDesc *p2 =3D NULL; + void *existing_tb =3D NULL; + uint32_t h; + + assert_memory_lock(); + tcg_debug_assert(!(tb->cflags & CF_INVALID)); + + /* + * Add the TB to the page list, acquiring first the pages's locks. + * We keep the locks held until after inserting the TB in the hash tab= le, + * so that if the insertion fails we know for sure that the TBs are st= ill + * in the page descriptors. + * Note that inserting into the hash table first isn't an option, since + * we can only insert TBs that are fully initialized. + */ + page_lock_pair(&p, phys_pc, &p2, phys_page2, true); + tb_page_add(p, tb, 0, phys_pc); + if (p2) { + tb_page_add(p2, tb, 1, phys_page2); + } else { + tb->page_addr[1] =3D -1; + } + + /* add in the hash table */ + h =3D tb_hash_func(phys_pc, (TARGET_TB_PCREL ? 0 : tb_pc(tb)), + tb->flags, tb->cflags, tb->trace_vcpu_dstate); + qht_insert(&tb_ctx.htable, tb, h, &existing_tb); + + /* remove TB from the page(s) if we couldn't insert it */ + if (unlikely(existing_tb)) { + tb_page_remove(p, tb); + if (p2) { + tb_page_remove(p2, tb); + } + tb =3D existing_tb; + } + + if (p2 && p2 !=3D p) { + page_unlock(p2); + } + page_unlock(p); + return tb; +} + +/* + * @p must be non-NULL. + * user-mode: call with mmap_lock held. + * !user-mode: call with all @pages locked. + */ +static void +tb_invalidate_phys_page_range__locked(struct page_collection *pages, + PageDesc *p, tb_page_addr_t start, + tb_page_addr_t end, + uintptr_t retaddr) +{ + TranslationBlock *tb; + tb_page_addr_t tb_start, tb_end; + int n; +#ifdef TARGET_HAS_PRECISE_SMC + CPUState *cpu =3D current_cpu; + CPUArchState *env =3D NULL; + bool current_tb_not_found =3D retaddr !=3D 0; + bool current_tb_modified =3D false; + TranslationBlock *current_tb =3D NULL; + target_ulong current_pc =3D 0; + target_ulong current_cs_base =3D 0; + uint32_t current_flags =3D 0; +#endif /* TARGET_HAS_PRECISE_SMC */ + + assert_page_locked(p); + +#if defined(TARGET_HAS_PRECISE_SMC) + if (cpu !=3D NULL) { + env =3D cpu->env_ptr; + } +#endif + + /* + * We remove all the TBs in the range [start, end[. + * XXX: see if in some cases it could be faster to invalidate all the = code + */ + PAGE_FOR_EACH_TB(p, tb, n) { + assert_page_locked(p); + /* NOTE: this is subtle as a TB may span two physical pages */ + if (n =3D=3D 0) { + /* NOTE: tb_end may be after the end of the page, but + it is not a problem */ + tb_start =3D tb->page_addr[0]; + tb_end =3D tb_start + tb->size; + } else { + tb_start =3D tb->page_addr[1]; + tb_end =3D tb_start + ((tb->page_addr[0] + tb->size) + & ~TARGET_PAGE_MASK); + } + if (!(tb_end <=3D start || tb_start >=3D end)) { +#ifdef TARGET_HAS_PRECISE_SMC + if (current_tb_not_found) { + current_tb_not_found =3D false; + /* now we have a real cpu fault */ + current_tb =3D tcg_tb_lookup(retaddr); + } + if (current_tb =3D=3D tb && + (tb_cflags(current_tb) & CF_COUNT_MASK) !=3D 1) { + /* + * If we are modifying the current TB, we must stop + * its execution. We could be more precise by checking + * that the modification is after the current PC, but it + * would require a specialized function to partially + * restore the CPU state. + */ + current_tb_modified =3D true; + cpu_restore_state_from_tb(cpu, current_tb, retaddr, true); + cpu_get_tb_cpu_state(env, ¤t_pc, ¤t_cs_base, + ¤t_flags); + } +#endif /* TARGET_HAS_PRECISE_SMC */ + tb_phys_invalidate__locked(tb); + } + } +#if !defined(CONFIG_USER_ONLY) + /* if no code remaining, no need to continue to use slow writes */ + if (!p->first_tb) { + tlb_unprotect_code(start); + } +#endif +#ifdef TARGET_HAS_PRECISE_SMC + if (current_tb_modified) { + page_collection_unlock(pages); + /* Force execution of one insn next time. */ + cpu->cflags_next_tb =3D 1 | CF_NOIRQ | curr_cflags(cpu); + mmap_unlock(); + cpu_loop_exit_noexc(cpu); + } +#endif +} + +/* + * Invalidate all TBs which intersect with the target physical address ran= ge + * [start;end[. NOTE: start and end must refer to the *same* physical page. + * 'is_cpu_write_access' should be true if called from a real cpu write + * access: the virtual CPU will exit the current TB if code is modified in= side + * this TB. + * + * Called with mmap_lock held for user-mode emulation + */ +void tb_invalidate_phys_page_range(tb_page_addr_t start, tb_page_addr_t en= d) +{ + struct page_collection *pages; + PageDesc *p; + + assert_memory_lock(); + + p =3D page_find(start >> TARGET_PAGE_BITS); + if (p =3D=3D NULL) { + return; + } + pages =3D page_collection_lock(start, end); + tb_invalidate_phys_page_range__locked(pages, p, start, end, 0); + page_collection_unlock(pages); +} + +/* + * Invalidate all TBs which intersect with the target physical address ran= ge + * [start;end[. NOTE: start and end may refer to *different* physical page= s. + * 'is_cpu_write_access' should be true if called from a real cpu write + * access: the virtual CPU will exit the current TB if code is modified in= side + * this TB. + * + * Called with mmap_lock held for user-mode emulation. + */ +#ifdef CONFIG_SOFTMMU +void tb_invalidate_phys_range(ram_addr_t start, ram_addr_t end) +#else +void tb_invalidate_phys_range(target_ulong start, target_ulong end) +#endif +{ + struct page_collection *pages; + tb_page_addr_t next; + + assert_memory_lock(); + + pages =3D page_collection_lock(start, end); + for (next =3D (start & TARGET_PAGE_MASK) + TARGET_PAGE_SIZE; + start < end; + start =3D next, next +=3D TARGET_PAGE_SIZE) { + PageDesc *pd =3D page_find(start >> TARGET_PAGE_BITS); + tb_page_addr_t bound =3D MIN(next, end); + + if (pd =3D=3D NULL) { + continue; + } + tb_invalidate_phys_page_range__locked(pages, pd, start, bound, 0); + } + page_collection_unlock(pages); +} + +#ifdef CONFIG_SOFTMMU +/* + * len must be <=3D 8 and start must be a multiple of len. + * Called via softmmu_template.h when code areas are written to with + * iothread mutex not held. + * + * Call with all @pages in the range [@start, @start + len[ locked. + */ +void tb_invalidate_phys_page_fast(struct page_collection *pages, + tb_page_addr_t start, int len, + uintptr_t retaddr) +{ + PageDesc *p; + + assert_memory_lock(); + + p =3D page_find(start >> TARGET_PAGE_BITS); + if (!p) { + return; + } + + assert_page_locked(p); + tb_invalidate_phys_page_range__locked(pages, p, start, start + len, + retaddr); +} +#else +/* + * Called with mmap_lock held. If pc is not 0 then it indicates the + * host PC of the faulting store instruction that caused this invalidate. + * Returns true if the caller needs to abort execution of the current + * TB (because it was modified by this store and the guest CPU has + * precise-SMC semantics). + */ +bool tb_invalidate_phys_page(tb_page_addr_t addr, uintptr_t pc) +{ + TranslationBlock *tb; + PageDesc *p; + int n; +#ifdef TARGET_HAS_PRECISE_SMC + TranslationBlock *current_tb =3D NULL; + CPUState *cpu =3D current_cpu; + CPUArchState *env =3D NULL; + int current_tb_modified =3D 0; + target_ulong current_pc =3D 0; + target_ulong current_cs_base =3D 0; + uint32_t current_flags =3D 0; +#endif + + assert_memory_lock(); + + addr &=3D TARGET_PAGE_MASK; + p =3D page_find(addr >> TARGET_PAGE_BITS); + if (!p) { + return false; + } + +#ifdef TARGET_HAS_PRECISE_SMC + if (p->first_tb && pc !=3D 0) { + current_tb =3D tcg_tb_lookup(pc); + } + if (cpu !=3D NULL) { + env =3D cpu->env_ptr; + } +#endif + assert_page_locked(p); + PAGE_FOR_EACH_TB(p, tb, n) { +#ifdef TARGET_HAS_PRECISE_SMC + if (current_tb =3D=3D tb && + (tb_cflags(current_tb) & CF_COUNT_MASK) !=3D 1) { + /* + * If we are modifying the current TB, we must stop its execut= ion. + * We could be more precise by checking that the modification = is + * after the current PC, but it would require a specialized + * function to partially restore the CPU state. + */ + current_tb_modified =3D 1; + cpu_restore_state_from_tb(cpu, current_tb, pc, true); + cpu_get_tb_cpu_state(env, ¤t_pc, ¤t_cs_base, + ¤t_flags); + } +#endif /* TARGET_HAS_PRECISE_SMC */ + tb_phys_invalidate(tb, addr); + } + p->first_tb =3D (uintptr_t)NULL; +#ifdef TARGET_HAS_PRECISE_SMC + if (current_tb_modified) { + /* Force execution of one insn next time. */ + cpu->cflags_next_tb =3D 1 | CF_NOIRQ | curr_cflags(cpu); + return true; + } +#endif + + return false; +} +#endif diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 86848c6743..5e28e9fccd 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -109,18 +109,6 @@ struct page_collection { struct page_entry *max; }; =20 -/* list iterators for lists of tagged pointers in TranslationBlock */ -#define TB_FOR_EACH_TAGGED(head, tb, n, field) \ - for (n =3D (head) & 1, tb =3D (TranslationBlock *)((head) & ~1); = \ - tb; tb =3D (TranslationBlock *)tb->field[n], n =3D (uintptr_t)tb = & 1, \ - tb =3D (TranslationBlock *)((uintptr_t)tb & ~1)) - -#define PAGE_FOR_EACH_TB(pagedesc, tb, n) \ - TB_FOR_EACH_TAGGED((pagedesc)->first_tb, tb, n, page_next) - -#define TB_FOR_EACH_JMP(head_tb, tb, n) \ - TB_FOR_EACH_TAGGED((head_tb)->jmp_list_head, tb, n, jmp_list_next) - /* * In system mode we want L1_MAP to be based on ram offsets, * while in user mode we want it to be based on virtual addresses. @@ -138,10 +126,6 @@ struct page_collection { # define L1_MAP_ADDR_SPACE_BITS MIN(HOST_LONG_BITS, TARGET_ABI_BITS) #endif =20 -/* Size of the L2 (and L3, etc) page tables. */ -#define V_L2_BITS 10 -#define V_L2_SIZE (1 << V_L2_BITS) - /* Make sure all possible CPU event bits fit in tb->trace_vcpu_dstate */ QEMU_BUILD_BUG_ON(CPU_TRACE_DSTATE_MAX_EVENTS > sizeof_field(TranslationBlock, trace_vcpu_dstate) @@ -150,18 +134,11 @@ QEMU_BUILD_BUG_ON(CPU_TRACE_DSTATE_MAX_EVENTS > /* * L1 Mapping properties */ -static int v_l1_size; -static int v_l1_shift; -static int v_l2_levels; +int v_l1_size; +int v_l1_shift; +int v_l2_levels; =20 -/* The bottom level has pointers to PageDesc, and is indexed by - * anything from 4 to (V_L2_BITS + 3) bits, depending on target page size. - */ -#define V_L1_MIN_BITS 4 -#define V_L1_MAX_BITS (V_L2_BITS + 3) -#define V_L1_MAX_SIZE (1 << V_L1_MAX_BITS) - -static void *l1_map[V_L1_MAX_SIZE]; +void *l1_map[V_L1_MAX_SIZE]; =20 TBContext tb_ctx; =20 @@ -274,8 +251,8 @@ static int encode_search(TranslationBlock *tb, uint8_t = *block) * When reset_icount is true, current TB will be interrupted and * icount should be recalculated. */ -static int cpu_restore_state_from_tb(CPUState *cpu, TranslationBlock *tb, - uintptr_t searched_pc, bool reset_ico= unt) +int cpu_restore_state_from_tb(CPUState *cpu, TranslationBlock *tb, + uintptr_t searched_pc, bool reset_icount) { target_ulong data[TARGET_INSN_START_WORDS]; uintptr_t host_pc =3D (uintptr_t)tb->tc.ptr; @@ -487,26 +464,8 @@ PageDesc *page_find_alloc(tb_page_addr_t index, bool a= lloc) return pd + (index & (V_L2_SIZE - 1)); } =20 -static void page_lock_pair(PageDesc **ret_p1, tb_page_addr_t phys1, - PageDesc **ret_p2, tb_page_addr_t phys2, bool a= lloc); - /* In user-mode page locks aren't used; mmap_lock is enough */ #ifdef CONFIG_USER_ONLY - -#define assert_page_locked(pd) tcg_debug_assert(have_mmap_lock()) - -static inline void page_lock(PageDesc *pd) -{ } - -static inline void page_unlock(PageDesc *pd) -{ } - -static inline void page_lock_tb(const TranslationBlock *tb) -{ } - -static inline void page_unlock_tb(const TranslationBlock *tb) -{ } - struct page_collection * page_collection_lock(tb_page_addr_t start, tb_page_addr_t end) { @@ -555,8 +514,7 @@ static void page_unlock__debug(const PageDesc *pd) g_assert(removed); } =20 -static void -do_assert_page_locked(const PageDesc *pd, const char *file, int line) +void do_assert_page_locked(const PageDesc *pd, const char *file, int line) { if (unlikely(!page_is_locked(pd))) { error_report("assert_page_lock: PageDesc %p not locked @ %s:%d", @@ -565,8 +523,6 @@ do_assert_page_locked(const PageDesc *pd, const char *f= ile, int line) } } =20 -#define assert_page_locked(pd) do_assert_page_locked(pd, __FILE__, __LINE_= _) - void assert_no_pages_locked(void) { ht_pages_locked_debug_init(); @@ -575,50 +531,23 @@ void assert_no_pages_locked(void) =20 #else /* !CONFIG_DEBUG_TCG */ =20 -#define assert_page_locked(pd) - -static inline void page_lock__debug(const PageDesc *pd) -{ -} - -static inline void page_unlock__debug(const PageDesc *pd) -{ -} +static inline void page_lock__debug(const PageDesc *pd) { } +static inline void page_unlock__debug(const PageDesc *pd) { } =20 #endif /* CONFIG_DEBUG_TCG */ =20 -static inline void page_lock(PageDesc *pd) +void page_lock(PageDesc *pd) { page_lock__debug(pd); qemu_spin_lock(&pd->lock); } =20 -static inline void page_unlock(PageDesc *pd) +void page_unlock(PageDesc *pd) { qemu_spin_unlock(&pd->lock); page_unlock__debug(pd); } =20 -/* lock the page(s) of a TB in the correct acquisition order */ -static inline void page_lock_tb(const TranslationBlock *tb) -{ - page_lock_pair(NULL, tb->page_addr[0], NULL, tb->page_addr[1], false); -} - -static inline void page_unlock_tb(const TranslationBlock *tb) -{ - PageDesc *p1 =3D page_find(tb->page_addr[0] >> TARGET_PAGE_BITS); - - page_unlock(p1); - if (unlikely(tb->page_addr[1] !=3D -1)) { - PageDesc *p2 =3D page_find(tb->page_addr[1] >> TARGET_PAGE_BITS); - - if (p2 !=3D p1) { - page_unlock(p2); - } - } -} - static inline struct page_entry * page_entry_new(PageDesc *pd, tb_page_addr_t index) { @@ -790,434 +719,6 @@ void page_collection_unlock(struct page_collection *s= et) =20 #endif /* !CONFIG_USER_ONLY */ =20 -static void page_lock_pair(PageDesc **ret_p1, tb_page_addr_t phys1, - PageDesc **ret_p2, tb_page_addr_t phys2, bool a= lloc) -{ - PageDesc *p1, *p2; - tb_page_addr_t page1; - tb_page_addr_t page2; - - assert_memory_lock(); - g_assert(phys1 !=3D -1); - - page1 =3D phys1 >> TARGET_PAGE_BITS; - page2 =3D phys2 >> TARGET_PAGE_BITS; - - p1 =3D page_find_alloc(page1, alloc); - if (ret_p1) { - *ret_p1 =3D p1; - } - if (likely(phys2 =3D=3D -1)) { - page_lock(p1); - return; - } else if (page1 =3D=3D page2) { - page_lock(p1); - if (ret_p2) { - *ret_p2 =3D p1; - } - return; - } - p2 =3D page_find_alloc(page2, alloc); - if (ret_p2) { - *ret_p2 =3D p2; - } - if (page1 < page2) { - page_lock(p1); - page_lock(p2); - } else { - page_lock(p2); - page_lock(p1); - } -} - -static bool tb_cmp(const void *ap, const void *bp) -{ - const TranslationBlock *a =3D ap; - const TranslationBlock *b =3D bp; - - return ((TARGET_TB_PCREL || tb_pc(a) =3D=3D tb_pc(b)) && - a->cs_base =3D=3D b->cs_base && - a->flags =3D=3D b->flags && - (tb_cflags(a) & ~CF_INVALID) =3D=3D (tb_cflags(b) & ~CF_INVALI= D) && - a->trace_vcpu_dstate =3D=3D b->trace_vcpu_dstate && - a->page_addr[0] =3D=3D b->page_addr[0] && - a->page_addr[1] =3D=3D b->page_addr[1]); -} - -void tb_htable_init(void) -{ - unsigned int mode =3D QHT_MODE_AUTO_RESIZE; - - qht_init(&tb_ctx.htable, tb_cmp, CODE_GEN_HTABLE_SIZE, mode); -} - -/* Set to NULL all the 'first_tb' fields in all PageDescs. */ -static void page_flush_tb_1(int level, void **lp) -{ - int i; - - if (*lp =3D=3D NULL) { - return; - } - if (level =3D=3D 0) { - PageDesc *pd =3D *lp; - - for (i =3D 0; i < V_L2_SIZE; ++i) { - page_lock(&pd[i]); - pd[i].first_tb =3D (uintptr_t)NULL; - page_unlock(&pd[i]); - } - } else { - void **pp =3D *lp; - - for (i =3D 0; i < V_L2_SIZE; ++i) { - page_flush_tb_1(level - 1, pp + i); - } - } -} - -static void page_flush_tb(void) -{ - int i, l1_sz =3D v_l1_size; - - for (i =3D 0; i < l1_sz; i++) { - page_flush_tb_1(v_l2_levels, l1_map + i); - } -} - -/* flush all the translation blocks */ -static void do_tb_flush(CPUState *cpu, run_on_cpu_data tb_flush_count) -{ - bool did_flush =3D false; - - mmap_lock(); - /* If it is already been done on request of another CPU, - * just retry. - */ - if (tb_ctx.tb_flush_count !=3D tb_flush_count.host_int) { - goto done; - } - did_flush =3D true; - - CPU_FOREACH(cpu) { - tcg_flush_jmp_cache(cpu); - } - - qht_reset_size(&tb_ctx.htable, CODE_GEN_HTABLE_SIZE); - page_flush_tb(); - - tcg_region_reset_all(); - /* XXX: flush processor icache at this point if cache flush is - expensive */ - qatomic_mb_set(&tb_ctx.tb_flush_count, tb_ctx.tb_flush_count + 1); - -done: - mmap_unlock(); - if (did_flush) { - qemu_plugin_flush_cb(); - } -} - -void tb_flush(CPUState *cpu) -{ - if (tcg_enabled()) { - unsigned tb_flush_count =3D qatomic_mb_read(&tb_ctx.tb_flush_count= ); - - if (cpu_in_exclusive_context(cpu)) { - do_tb_flush(cpu, RUN_ON_CPU_HOST_INT(tb_flush_count)); - } else { - async_safe_run_on_cpu(cpu, do_tb_flush, - RUN_ON_CPU_HOST_INT(tb_flush_count)); - } - } -} - -/* - * user-mode: call with mmap_lock held - * !user-mode: call with @pd->lock held - */ -static inline void tb_page_remove(PageDesc *pd, TranslationBlock *tb) -{ - TranslationBlock *tb1; - uintptr_t *pprev; - unsigned int n1; - - assert_page_locked(pd); - pprev =3D &pd->first_tb; - PAGE_FOR_EACH_TB(pd, tb1, n1) { - if (tb1 =3D=3D tb) { - *pprev =3D tb1->page_next[n1]; - return; - } - pprev =3D &tb1->page_next[n1]; - } - g_assert_not_reached(); -} - -/* remove @orig from its @n_orig-th jump list */ -static inline void tb_remove_from_jmp_list(TranslationBlock *orig, int n_o= rig) -{ - uintptr_t ptr, ptr_locked; - TranslationBlock *dest; - TranslationBlock *tb; - uintptr_t *pprev; - int n; - - /* mark the LSB of jmp_dest[] so that no further jumps can be inserted= */ - ptr =3D qatomic_or_fetch(&orig->jmp_dest[n_orig], 1); - dest =3D (TranslationBlock *)(ptr & ~1); - if (dest =3D=3D NULL) { - return; - } - - qemu_spin_lock(&dest->jmp_lock); - /* - * While acquiring the lock, the jump might have been removed if the - * destination TB was invalidated; check again. - */ - ptr_locked =3D qatomic_read(&orig->jmp_dest[n_orig]); - if (ptr_locked !=3D ptr) { - qemu_spin_unlock(&dest->jmp_lock); - /* - * The only possibility is that the jump was unlinked via - * tb_jump_unlink(dest). Seeing here another destination would be = a bug, - * because we set the LSB above. - */ - g_assert(ptr_locked =3D=3D 1 && dest->cflags & CF_INVALID); - return; - } - /* - * We first acquired the lock, and since the destination pointer match= es, - * we know for sure that @orig is in the jmp list. - */ - pprev =3D &dest->jmp_list_head; - TB_FOR_EACH_JMP(dest, tb, n) { - if (tb =3D=3D orig && n =3D=3D n_orig) { - *pprev =3D tb->jmp_list_next[n]; - /* no need to set orig->jmp_dest[n]; setting the LSB was enoug= h */ - qemu_spin_unlock(&dest->jmp_lock); - return; - } - pprev =3D &tb->jmp_list_next[n]; - } - g_assert_not_reached(); -} - -/* reset the jump entry 'n' of a TB so that it is not chained to - another TB */ -static inline void tb_reset_jump(TranslationBlock *tb, int n) -{ - uintptr_t addr =3D (uintptr_t)(tb->tc.ptr + tb->jmp_reset_offset[n]); - tb_set_jmp_target(tb, n, addr); -} - -/* remove any jumps to the TB */ -static inline void tb_jmp_unlink(TranslationBlock *dest) -{ - TranslationBlock *tb; - int n; - - qemu_spin_lock(&dest->jmp_lock); - - TB_FOR_EACH_JMP(dest, tb, n) { - tb_reset_jump(tb, n); - qatomic_and(&tb->jmp_dest[n], (uintptr_t)NULL | 1); - /* No need to clear the list entry; setting the dest ptr is enough= */ - } - dest->jmp_list_head =3D (uintptr_t)NULL; - - qemu_spin_unlock(&dest->jmp_lock); -} - -static void tb_jmp_cache_inval_tb(TranslationBlock *tb) -{ - CPUState *cpu; - - if (TARGET_TB_PCREL) { - /* A TB may be at any virtual address */ - CPU_FOREACH(cpu) { - tcg_flush_jmp_cache(cpu); - } - } else { - uint32_t h =3D tb_jmp_cache_hash_func(tb_pc(tb)); - - CPU_FOREACH(cpu) { - CPUJumpCache *jc =3D cpu->tb_jmp_cache; - - if (qatomic_read(&jc->array[h].tb) =3D=3D tb) { - qatomic_set(&jc->array[h].tb, NULL); - } - } - } -} - -/* - * In user-mode, call with mmap_lock held. - * In !user-mode, if @rm_from_page_list is set, call with the TB's pages' - * locks held. - */ -static void do_tb_phys_invalidate(TranslationBlock *tb, bool rm_from_page_= list) -{ - PageDesc *p; - uint32_t h; - tb_page_addr_t phys_pc; - uint32_t orig_cflags =3D tb_cflags(tb); - - assert_memory_lock(); - - /* make sure no further incoming jumps will be chained to this TB */ - qemu_spin_lock(&tb->jmp_lock); - qatomic_set(&tb->cflags, tb->cflags | CF_INVALID); - qemu_spin_unlock(&tb->jmp_lock); - - /* remove the TB from the hash list */ - phys_pc =3D tb->page_addr[0]; - h =3D tb_hash_func(phys_pc, (TARGET_TB_PCREL ? 0 : tb_pc(tb)), - tb->flags, orig_cflags, tb->trace_vcpu_dstate); - if (!qht_remove(&tb_ctx.htable, tb, h)) { - return; - } - - /* remove the TB from the page list */ - if (rm_from_page_list) { - p =3D page_find(tb->page_addr[0] >> TARGET_PAGE_BITS); - tb_page_remove(p, tb); - if (tb->page_addr[1] !=3D -1) { - p =3D page_find(tb->page_addr[1] >> TARGET_PAGE_BITS); - tb_page_remove(p, tb); - } - } - - /* remove the TB from the hash list */ - tb_jmp_cache_inval_tb(tb); - - /* suppress this TB from the two jump lists */ - tb_remove_from_jmp_list(tb, 0); - tb_remove_from_jmp_list(tb, 1); - - /* suppress any remaining jumps to this TB */ - tb_jmp_unlink(tb); - - qatomic_set(&tb_ctx.tb_phys_invalidate_count, - tb_ctx.tb_phys_invalidate_count + 1); -} - -static void tb_phys_invalidate__locked(TranslationBlock *tb) -{ - qemu_thread_jit_write(); - do_tb_phys_invalidate(tb, true); - qemu_thread_jit_execute(); -} - -/* invalidate one TB - * - * Called with mmap_lock held in user-mode. - */ -void tb_phys_invalidate(TranslationBlock *tb, tb_page_addr_t page_addr) -{ - if (page_addr =3D=3D -1 && tb->page_addr[0] !=3D -1) { - page_lock_tb(tb); - do_tb_phys_invalidate(tb, true); - page_unlock_tb(tb); - } else { - do_tb_phys_invalidate(tb, false); - } -} - -/* add the tb in the target page and protect it if necessary - * - * Called with mmap_lock held for user-mode emulation. - * Called with @p->lock held in !user-mode. - */ -static inline void tb_page_add(PageDesc *p, TranslationBlock *tb, - unsigned int n, tb_page_addr_t page_addr) -{ -#ifndef CONFIG_USER_ONLY - bool page_already_protected; -#endif - - assert_page_locked(p); - - tb->page_addr[n] =3D page_addr; - tb->page_next[n] =3D p->first_tb; -#ifndef CONFIG_USER_ONLY - page_already_protected =3D p->first_tb !=3D (uintptr_t)NULL; -#endif - p->first_tb =3D (uintptr_t)tb | n; - -#if defined(CONFIG_USER_ONLY) - /* translator_loop() must have made all TB pages non-writable */ - assert(!(p->flags & PAGE_WRITE)); -#else - /* if some code is already present, then the pages are already - protected. So we handle the case where only the first TB is - allocated in a physical page */ - if (!page_already_protected) { - tlb_protect_code(page_addr); - } -#endif -} - -/* - * Add a new TB and link it to the physical page tables. phys_page2 is - * (-1) to indicate that only one page contains the TB. - * - * Called with mmap_lock held for user-mode emulation. - * - * Returns a pointer @tb, or a pointer to an existing TB that matches @tb. - * Note that in !user-mode, another thread might have already added a TB - * for the same block of guest code that @tb corresponds to. In that case, - * the caller should discard the original @tb, and use instead the returne= d TB. - */ -static TranslationBlock * -tb_link_page(TranslationBlock *tb, tb_page_addr_t phys_pc, - tb_page_addr_t phys_page2) -{ - PageDesc *p; - PageDesc *p2 =3D NULL; - void *existing_tb =3D NULL; - uint32_t h; - - assert_memory_lock(); - tcg_debug_assert(!(tb->cflags & CF_INVALID)); - - /* - * Add the TB to the page list, acquiring first the pages's locks. - * We keep the locks held until after inserting the TB in the hash tab= le, - * so that if the insertion fails we know for sure that the TBs are st= ill - * in the page descriptors. - * Note that inserting into the hash table first isn't an option, since - * we can only insert TBs that are fully initialized. - */ - page_lock_pair(&p, phys_pc, &p2, phys_page2, true); - tb_page_add(p, tb, 0, phys_pc); - if (p2) { - tb_page_add(p2, tb, 1, phys_page2); - } else { - tb->page_addr[1] =3D -1; - } - - /* add in the hash table */ - h =3D tb_hash_func(phys_pc, (TARGET_TB_PCREL ? 0 : tb_pc(tb)), - tb->flags, tb->cflags, tb->trace_vcpu_dstate); - qht_insert(&tb_ctx.htable, tb, h, &existing_tb); - - /* remove TB from the page(s) if we couldn't insert it */ - if (unlikely(existing_tb)) { - tb_page_remove(p, tb); - if (p2) { - tb_page_remove(p2, tb); - } - tb =3D existing_tb; - } - - if (p2 && p2 !=3D p) { - page_unlock(p2); - } - page_unlock(p); - return tb; -} - /* Called with mmap_lock held for user mode emulation. */ TranslationBlock *tb_gen_code(CPUState *cpu, target_ulong pc, target_ulong cs_base, @@ -1497,251 +998,6 @@ TranslationBlock *tb_gen_code(CPUState *cpu, return tb; } =20 -/* - * @p must be non-NULL. - * user-mode: call with mmap_lock held. - * !user-mode: call with all @pages locked. - */ -static void -tb_invalidate_phys_page_range__locked(struct page_collection *pages, - PageDesc *p, tb_page_addr_t start, - tb_page_addr_t end, - uintptr_t retaddr) -{ - TranslationBlock *tb; - tb_page_addr_t tb_start, tb_end; - int n; -#ifdef TARGET_HAS_PRECISE_SMC - CPUState *cpu =3D current_cpu; - CPUArchState *env =3D NULL; - bool current_tb_not_found =3D retaddr !=3D 0; - bool current_tb_modified =3D false; - TranslationBlock *current_tb =3D NULL; - target_ulong current_pc =3D 0; - target_ulong current_cs_base =3D 0; - uint32_t current_flags =3D 0; -#endif /* TARGET_HAS_PRECISE_SMC */ - - assert_page_locked(p); - -#if defined(TARGET_HAS_PRECISE_SMC) - if (cpu !=3D NULL) { - env =3D cpu->env_ptr; - } -#endif - - /* we remove all the TBs in the range [start, end[ */ - /* XXX: see if in some cases it could be faster to invalidate all - the code */ - PAGE_FOR_EACH_TB(p, tb, n) { - assert_page_locked(p); - /* NOTE: this is subtle as a TB may span two physical pages */ - if (n =3D=3D 0) { - /* NOTE: tb_end may be after the end of the page, but - it is not a problem */ - tb_start =3D tb->page_addr[0]; - tb_end =3D tb_start + tb->size; - } else { - tb_start =3D tb->page_addr[1]; - tb_end =3D tb_start + ((tb->page_addr[0] + tb->size) - & ~TARGET_PAGE_MASK); - } - if (!(tb_end <=3D start || tb_start >=3D end)) { -#ifdef TARGET_HAS_PRECISE_SMC - if (current_tb_not_found) { - current_tb_not_found =3D false; - /* now we have a real cpu fault */ - current_tb =3D tcg_tb_lookup(retaddr); - } - if (current_tb =3D=3D tb && - (tb_cflags(current_tb) & CF_COUNT_MASK) !=3D 1) { - /* - * If we are modifying the current TB, we must stop - * its execution. We could be more precise by checking - * that the modification is after the current PC, but it - * would require a specialized function to partially - * restore the CPU state. - */ - current_tb_modified =3D true; - cpu_restore_state_from_tb(cpu, current_tb, retaddr, true); - cpu_get_tb_cpu_state(env, ¤t_pc, ¤t_cs_base, - ¤t_flags); - } -#endif /* TARGET_HAS_PRECISE_SMC */ - tb_phys_invalidate__locked(tb); - } - } -#if !defined(CONFIG_USER_ONLY) - /* if no code remaining, no need to continue to use slow writes */ - if (!p->first_tb) { - tlb_unprotect_code(start); - } -#endif -#ifdef TARGET_HAS_PRECISE_SMC - if (current_tb_modified) { - page_collection_unlock(pages); - /* Force execution of one insn next time. */ - cpu->cflags_next_tb =3D 1 | CF_NOIRQ | curr_cflags(cpu); - mmap_unlock(); - cpu_loop_exit_noexc(cpu); - } -#endif -} - -/* - * Invalidate all TBs which intersect with the target physical address ran= ge - * [start;end[. NOTE: start and end must refer to the *same* physical page. - * 'is_cpu_write_access' should be true if called from a real cpu write - * access: the virtual CPU will exit the current TB if code is modified in= side - * this TB. - * - * Called with mmap_lock held for user-mode emulation - */ -void tb_invalidate_phys_page_range(tb_page_addr_t start, tb_page_addr_t en= d) -{ - struct page_collection *pages; - PageDesc *p; - - assert_memory_lock(); - - p =3D page_find(start >> TARGET_PAGE_BITS); - if (p =3D=3D NULL) { - return; - } - pages =3D page_collection_lock(start, end); - tb_invalidate_phys_page_range__locked(pages, p, start, end, 0); - page_collection_unlock(pages); -} - -/* - * Invalidate all TBs which intersect with the target physical address ran= ge - * [start;end[. NOTE: start and end may refer to *different* physical page= s. - * 'is_cpu_write_access' should be true if called from a real cpu write - * access: the virtual CPU will exit the current TB if code is modified in= side - * this TB. - * - * Called with mmap_lock held for user-mode emulation. - */ -#ifdef CONFIG_SOFTMMU -void tb_invalidate_phys_range(ram_addr_t start, ram_addr_t end) -#else -void tb_invalidate_phys_range(target_ulong start, target_ulong end) -#endif -{ - struct page_collection *pages; - tb_page_addr_t next; - - assert_memory_lock(); - - pages =3D page_collection_lock(start, end); - for (next =3D (start & TARGET_PAGE_MASK) + TARGET_PAGE_SIZE; - start < end; - start =3D next, next +=3D TARGET_PAGE_SIZE) { - PageDesc *pd =3D page_find(start >> TARGET_PAGE_BITS); - tb_page_addr_t bound =3D MIN(next, end); - - if (pd =3D=3D NULL) { - continue; - } - tb_invalidate_phys_page_range__locked(pages, pd, start, bound, 0); - } - page_collection_unlock(pages); -} - -#ifdef CONFIG_SOFTMMU -/* len must be <=3D 8 and start must be a multiple of len. - * Called via softmmu_template.h when code areas are written to with - * iothread mutex not held. - * - * Call with all @pages in the range [@start, @start + len[ locked. - */ -void tb_invalidate_phys_page_fast(struct page_collection *pages, - tb_page_addr_t start, int len, - uintptr_t retaddr) -{ - PageDesc *p; - - assert_memory_lock(); - - p =3D page_find(start >> TARGET_PAGE_BITS); - if (!p) { - return; - } - - assert_page_locked(p); - tb_invalidate_phys_page_range__locked(pages, p, start, start + len, - retaddr); -} -#else -/* Called with mmap_lock held. If pc is not 0 then it indicates the - * host PC of the faulting store instruction that caused this invalidate. - * Returns true if the caller needs to abort execution of the current - * TB (because it was modified by this store and the guest CPU has - * precise-SMC semantics). - */ -static bool tb_invalidate_phys_page(tb_page_addr_t addr, uintptr_t pc) -{ - TranslationBlock *tb; - PageDesc *p; - int n; -#ifdef TARGET_HAS_PRECISE_SMC - TranslationBlock *current_tb =3D NULL; - CPUState *cpu =3D current_cpu; - CPUArchState *env =3D NULL; - int current_tb_modified =3D 0; - target_ulong current_pc =3D 0; - target_ulong current_cs_base =3D 0; - uint32_t current_flags =3D 0; -#endif - - assert_memory_lock(); - - addr &=3D TARGET_PAGE_MASK; - p =3D page_find(addr >> TARGET_PAGE_BITS); - if (!p) { - return false; - } - -#ifdef TARGET_HAS_PRECISE_SMC - if (p->first_tb && pc !=3D 0) { - current_tb =3D tcg_tb_lookup(pc); - } - if (cpu !=3D NULL) { - env =3D cpu->env_ptr; - } -#endif - assert_page_locked(p); - PAGE_FOR_EACH_TB(p, tb, n) { -#ifdef TARGET_HAS_PRECISE_SMC - if (current_tb =3D=3D tb && - (tb_cflags(current_tb) & CF_COUNT_MASK) !=3D 1) { - /* If we are modifying the current TB, we must stop - its execution. We could be more precise by checking - that the modification is after the current PC, but it - would require a specialized function to partially - restore the CPU state */ - - current_tb_modified =3D 1; - cpu_restore_state_from_tb(cpu, current_tb, pc, true); - cpu_get_tb_cpu_state(env, ¤t_pc, ¤t_cs_base, - ¤t_flags); - } -#endif /* TARGET_HAS_PRECISE_SMC */ - tb_phys_invalidate(tb, addr); - } - p->first_tb =3D (uintptr_t)NULL; -#ifdef TARGET_HAS_PRECISE_SMC - if (current_tb_modified) { - /* Force execution of one insn next time. */ - cpu->cflags_next_tb =3D 1 | CF_NOIRQ | curr_cflags(cpu); - return true; - } -#endif - - return false; -} -#endif - /* user-mode: call with mmap_lock held */ void tb_check_watchpoint(CPUState *cpu, uintptr_t retaddr) { diff --git a/accel/tcg/meson.build b/accel/tcg/meson.build index 7a0a79d731..75e1dffb4d 100644 --- a/accel/tcg/meson.build +++ b/accel/tcg/meson.build @@ -3,6 +3,7 @@ tcg_ss.add(files( 'tcg-all.c', 'cpu-exec-common.c', 'cpu-exec.c', + 'tb-maint.c', 'tcg-runtime-gvec.c', 'tcg-runtime.c', 'translate-all.c', --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751428; cv=none; d=zohomail.com; s=zohoarc; b=I7GGN6h5gDFcMuSaQoujM+LdYJduAr70HJIbsRi16asK7sS3zbf8lkLQisIlJxq6NpQMuruRm/SB9UJn7r2ZRSCa820jpzAB5mD++hldaLrWQOXK9JHkUf/5gAin1XQH7fExjT2UgxdOpLRHBbrWbj2BxAkzAOn/zcmPvTqEACg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751428; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=ckxXpvB+UzHhX2Kt++OpD5XHQD1pSGLuWje3pRHkgZA=; b=dSZy2qjQEt4Ctp/bwla9W+7wIRM22uDBytYpK8nzQbdyibsos8SL7zkIycYY0WhxvesccPXPBWsoT0876+Q6tFK+uC6JHL42b3JHY/Ga3CecDXQVh7FTpel+cGRKn3gUg0CtoXh6bvkBL1JCg4NYvYRKwk7hchgUVL34EEKFiKE= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 166675142813549.01579947865832; Tue, 25 Oct 2022 19:30:28 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtj-0004to-E8; Tue, 25 Oct 2022 22:12:03 -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 1onVth-0004t8-Cn for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:01 -0400 Received: from mail-pj1-x1033.google.com ([2607:f8b0:4864:20::1033]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtf-0001AU-VG for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:01 -0400 Received: by mail-pj1-x1033.google.com with SMTP id m2so8713346pjr.3 for ; Tue, 25 Oct 2022 19:11:59 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:11:58 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=ckxXpvB+UzHhX2Kt++OpD5XHQD1pSGLuWje3pRHkgZA=; b=qyrLQh+Nxn9yseRBns42h+0Ji78k5h9kGM4iS8JoX2wzZOBXVpuShnwy3yUhNdHx3j NYhYiL8p/b+UkgTmE7bm/KI2w6QQ6BsQN4GJA4q0grV8kjg9dBAXLk7LShr02CVGnPIY /V58v/E/3mxe+XBOjbUFxwVD9zTcLRttXJOXb87sKTPG8JEuTIvEZVNP1qkD4NkV6mUS nJVViW03hzo9BpAsgLs+F3BIDY4CkdQerm6VZ5Pmmwp6s39kOqzZ+UALAD58s01fP/15 y66JAixHDdL6GXZpOBTFeFVTnAgTKIEPqMYHH7QLPOzoVf7JT3v4lHEopR0Ior/y1iFF aONg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=ckxXpvB+UzHhX2Kt++OpD5XHQD1pSGLuWje3pRHkgZA=; b=4YLpwoTrlmsmWg86yzDUpQYJezPYL239SzuQNopJgZWLWA8pVlYFaYydxk8Sv9mfNB /mb2JE5Ww+UnJDZYop5cdbHwbCKRnvtenglwQVHJtZWUU4OEngw+fRO6ABu0KLdLM8Gn kcFTQTxl3E3BTaoxjD91hPMyRzrz5ro3PmvvK31qLCzPwot1boaTpqDoYZhc5HGLRng1 /pme31cMpyXo7JoKmwTkcXDSzaSRUIUKL7HkmXUrhJfA6hYPLuETPMmYQck6lFq/Mrqx voWTsLTiFgk/syL64SnJ2VRn8gKafOC9rAnzBwrwbTVVFJU0eLXcPg0z2ImrJANtI/VP I1LQ== X-Gm-Message-State: ACrzQf1ewtlse3FFv2m4hEGEfaVnXtAFZsjt7ua6OECrl07iz+448Pts UV5xCmdPcXwQr1HaTnk/rXFPMWMoWPxjKDKy X-Google-Smtp-Source: AMsMyM5WQcjAOyBqg2+NdrCUVpMN+xlN3kstzSW/g39oETZFvTA3sz+qgOd8I/h4Njsdfm/I/Xu4xQ== X-Received: by 2002:a17:902:d2cf:b0:17f:7b65:862f with SMTP id n15-20020a170902d2cf00b0017f7b65862fmr41353203plc.168.1666750318621; Tue, 25 Oct 2022 19:11:58 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 12/47] accel/tcg: Move assert_no_pages_locked to internal.h Date: Wed, 26 Oct 2022 12:10:41 +1000 Message-Id: <20221026021116.1988449-13-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::1033; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x1033.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751429874100001 There are no users outside of accel/tcg; this function does not need to be defined in exec-all.h. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/internal.h | 5 +++++ include/exec/exec-all.h | 8 -------- 2 files changed, 5 insertions(+), 8 deletions(-) diff --git a/accel/tcg/internal.h b/accel/tcg/internal.h index a77b110b78..1a704ee14f 100644 --- a/accel/tcg/internal.h +++ b/accel/tcg/internal.h @@ -90,6 +90,11 @@ void do_assert_page_locked(const PageDesc *pd, const cha= r *file, int line); void page_lock(PageDesc *pd); void page_unlock(PageDesc *pd); #endif +#if !defined(CONFIG_USER_ONLY) && defined(CONFIG_DEBUG_TCG) +void assert_no_pages_locked(void); +#else +static inline void assert_no_pages_locked(void) { } +#endif =20 TranslationBlock *tb_gen_code(CPUState *cpu, target_ulong pc, target_ulong cs_base, uint32_t flags, diff --git a/include/exec/exec-all.h b/include/exec/exec-all.h index e5f8b224a5..b5bde1b56a 100644 --- a/include/exec/exec-all.h +++ b/include/exec/exec-all.h @@ -642,14 +642,6 @@ extern __thread uintptr_t tci_tb_ptr; smaller than 4 bytes, so we don't worry about special-casing this. */ #define GETPC_ADJ 2 =20 -#if !defined(CONFIG_USER_ONLY) && defined(CONFIG_DEBUG_TCG) -void assert_no_pages_locked(void); -#else -static inline void assert_no_pages_locked(void) -{ -} -#endif - #if !defined(CONFIG_USER_ONLY) =20 /** --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751401; cv=none; d=zohomail.com; s=zohoarc; b=NfjA6QjFf7LieaAHTSMkNpV77Av9ZX6b6u2E49nt5hPKgAL66k1fSSpSaFYq1R9FQz18tEQv2auW0NwkQ8Hk89bVl4YV/q8Cd3ZnJ2F/sQ/JKzAnubQ02Ftxs8/ijRj9gOT3JnwKE4QpcfsPVVmKP8mLfEJqaHD+RBgoq/vNlJA= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751401; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=+UKwi413u+Gz3fnOU9fgpeM4vpnF89V9H4chc4H5gVA=; b=F7Z4nzPU0GQA+DYNZ3g/Dtnr6QD/MTB5O2pjvoWVjyRH7S7lX8r18pcD51p/qV9ZVKgwf+DVno0O9yhy2Vh36c8ksdhnX+HpQTxaMDYFqxFyciE2q9LUNyTWHP2C7ljutauwmpJbxsyJbcQmi6BvC3pJU2RlLZIFLotSa240gQk= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751401203486.03417940974725; Tue, 25 Oct 2022 19:30:01 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtl-0004vR-Kx; Tue, 25 Oct 2022 22:12:05 -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 1onVtk-0004ug-EO for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:04 -0400 Received: from mail-pl1-x635.google.com ([2607:f8b0:4864:20::635]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVti-0001An-P0 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:04 -0400 Received: by mail-pl1-x635.google.com with SMTP id c2so4483223plz.11 for ; Tue, 25 Oct 2022 19:12:02 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.11.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=+UKwi413u+Gz3fnOU9fgpeM4vpnF89V9H4chc4H5gVA=; b=MiporuYqgLH6k/A8C0OoRjmhno8z1WI3ieu6lrDfImXr3wbX1FLs215L7mkfiVkvZA 6T56kzHVe26Ggg4J+y0ePkHDIsd95/WFbjWsq0wrFYCW3X4OHcoEIYIaI3yKdp1PIpJD mWUBA+EYQC5DzKAEK5Vz5/av3Dd3vVPXUzB0U6bVseH11ayRjSG0UIO8WJtwLjCGfrRO kDT+pJVIv8Fpzc6ax41o75jxJy9UuIdfBZkKGOCH+2LhnbyQkEAxnpu+MzMUNXOBal8c 5afTABT2FcTGW1rYo91O+z5LET72qzXonNIPDzDQp9lyWqEfMZZi70RU8wxdfMJ6PGOb U7iQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=+UKwi413u+Gz3fnOU9fgpeM4vpnF89V9H4chc4H5gVA=; b=ADzyB0n5crqcfDkiQ83OxLLfmP+gfMESUlhdfpLGUpl7gl88FcqxgR/WGG2F5Ca+zr YxYeNQcuguGWDkEZovLCC00/V5JF8sCs1I//NXzlRLMvE4Fs1JgLe2xuyoxRBzj8iPb2 nbvJyksr6LcwDO9dZ6DO2tn7NkBHb0L3lI+9a8aasr3n3lvShqizu8jLf+3rr2pKIhnx QPdJv8mdjAzB/pCVsY8os0DPOigM9uMAWANvp1tOUm6pfWe/DATubGHSxKJGq2gxNyni 0eeuk+rH+G0NZvhFkvMMVaMLjtrT8pEI9pyQdkx2hZsUrk/bMEqaHFv603bd0n/MNcxI 5ZJQ== X-Gm-Message-State: ACrzQf03lXyiKLW+Q46PUEfoK3wUWr01U/fPgwgwoSm5icMCk24xLOcL Exn5vDeRq+okxVG3VF0LfJVymBLwnQ9XRPnn X-Google-Smtp-Source: AMsMyM5uy2j1fB+P2S1XDlJcyeh/RIHxZeGJRdDnmSfJAhT1DryoVXhm1kSHj27Vy3SaXViD1V8Tig== X-Received: by 2002:a17:903:22c1:b0:185:5276:92e5 with SMTP id y1-20020a17090322c100b00185527692e5mr41556117plg.134.1666750321462; Tue, 25 Oct 2022 19:12:01 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 13/47] accel/tcg: Drop cpu_get_tb_cpu_state from TARGET_HAS_PRECISE_SMC Date: Wed, 26 Oct 2022 12:10:42 +1000 Message-Id: <20221026021116.1988449-14-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::635; envelope-from=richard.henderson@linaro.org; helo=mail-pl1-x635.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751401754100003 The results of the calls to cpu_get_tb_cpu_state, current_{pc,cs_base,flags}, are not used. In tb_invalidate_phys_page, use bool for current_tb_modified. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/tb-maint.c | 25 ++----------------------- 1 file changed, 2 insertions(+), 23 deletions(-) diff --git a/accel/tcg/tb-maint.c b/accel/tcg/tb-maint.c index 66c1900ae6..9af5cb49e0 100644 --- a/accel/tcg/tb-maint.c +++ b/accel/tcg/tb-maint.c @@ -502,23 +502,13 @@ tb_invalidate_phys_page_range__locked(struct page_col= lection *pages, int n; #ifdef TARGET_HAS_PRECISE_SMC CPUState *cpu =3D current_cpu; - CPUArchState *env =3D NULL; bool current_tb_not_found =3D retaddr !=3D 0; bool current_tb_modified =3D false; TranslationBlock *current_tb =3D NULL; - target_ulong current_pc =3D 0; - target_ulong current_cs_base =3D 0; - uint32_t current_flags =3D 0; #endif /* TARGET_HAS_PRECISE_SMC */ =20 assert_page_locked(p); =20 -#if defined(TARGET_HAS_PRECISE_SMC) - if (cpu !=3D NULL) { - env =3D cpu->env_ptr; - } -#endif - /* * We remove all the TBs in the range [start, end[. * XXX: see if in some cases it could be faster to invalidate all the = code @@ -554,8 +544,6 @@ tb_invalidate_phys_page_range__locked(struct page_colle= ction *pages, */ current_tb_modified =3D true; cpu_restore_state_from_tb(cpu, current_tb, retaddr, true); - cpu_get_tb_cpu_state(env, ¤t_pc, ¤t_cs_base, - ¤t_flags); } #endif /* TARGET_HAS_PRECISE_SMC */ tb_phys_invalidate__locked(tb); @@ -679,11 +667,7 @@ bool tb_invalidate_phys_page(tb_page_addr_t addr, uint= ptr_t pc) #ifdef TARGET_HAS_PRECISE_SMC TranslationBlock *current_tb =3D NULL; CPUState *cpu =3D current_cpu; - CPUArchState *env =3D NULL; - int current_tb_modified =3D 0; - target_ulong current_pc =3D 0; - target_ulong current_cs_base =3D 0; - uint32_t current_flags =3D 0; + bool current_tb_modified =3D false; #endif =20 assert_memory_lock(); @@ -698,9 +682,6 @@ bool tb_invalidate_phys_page(tb_page_addr_t addr, uintp= tr_t pc) if (p->first_tb && pc !=3D 0) { current_tb =3D tcg_tb_lookup(pc); } - if (cpu !=3D NULL) { - env =3D cpu->env_ptr; - } #endif assert_page_locked(p); PAGE_FOR_EACH_TB(p, tb, n) { @@ -713,10 +694,8 @@ bool tb_invalidate_phys_page(tb_page_addr_t addr, uint= ptr_t pc) * after the current PC, but it would require a specialized * function to partially restore the CPU state. */ - current_tb_modified =3D 1; + current_tb_modified =3D true; cpu_restore_state_from_tb(cpu, current_tb, pc, true); - cpu_get_tb_cpu_state(env, ¤t_pc, ¤t_cs_base, - ¤t_flags); } #endif /* TARGET_HAS_PRECISE_SMC */ tb_phys_invalidate(tb, addr); --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750941; cv=none; d=zohomail.com; s=zohoarc; b=F9y7gD01Tit7cff4jKJnhD1g7YG4NUYUE3nkRu8WsNHw7dsCZ+g95iFdQM2KIgmnJP58Cg2IYAC2OZimFVlViZ1GMJqkNjQ+3tZHIHTLWCjh67XwuM1A5vw+rK52/cXaC7o5n5TSfVcIw+LD/iCkjd8W9qoJIBDIFlekMp223rQ= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750941; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=gb/nMW+mdaB1UoEyVrxFQHTy4I+gWCCARfJVMhyCqRE=; b=CbMSYfe5Z/iTViJlZgvFPpSf64NZfTDHsDhhPldtEODmvZbGb7PWtc04Gq75zo9cM2swcaHLfbjWZchxoDAgh8qQPgWhta2lzgp/N/J8faNqdi2osEI+KGGBeQhLNtlTc7KVKAAOSyPiMv+3ZsWEWtesJsbnOjV2SvyHqY18Qmg= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750941281231.2612664313773; Tue, 25 Oct 2022 19:22:21 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVto-0004vp-CW; Tue, 25 Oct 2022 22:12:08 -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 1onVtm-0004vh-Sz for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:06 -0400 Received: from mail-pj1-x102f.google.com ([2607:f8b0:4864:20::102f]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtl-0001B8-Ct for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:06 -0400 Received: by mail-pj1-x102f.google.com with SMTP id v4-20020a17090a088400b00212cb0ed97eso833876pjc.5 for ; Tue, 25 Oct 2022 19:12:04 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=gb/nMW+mdaB1UoEyVrxFQHTy4I+gWCCARfJVMhyCqRE=; b=xfgq9ufMu9sH3CHQP1lLVsA1BtcE9DKpQwSnZHyHvAS3LHSPem1Jr3RAAKMyjXaRov HmucgTTv1hWmN7SAEJnQPXONB053IeUmvFrzbw4p/jrsGlw8UXIQej1e8jkVEEcEvupk VS6jAep9wWV6MsTxK/oIXGALN/WtIilkJvXhTetQEwaSm/a5lK7u2JSiX11rqUVGt0Wq AQ0bkGmEtM8Tl5zpUbX7ueBbU5/eKX5zrJ9Pkt72VYXLUD9usCuv7jNfgxLlPX47cmwd tkSN/QZqWeES3/xR0Mfg+SInXbnkZiH6CBd1mAAlmNWteIG/S1PDE4xLf3x02hoMdUZe mxDw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=gb/nMW+mdaB1UoEyVrxFQHTy4I+gWCCARfJVMhyCqRE=; b=Be4CB4APpchWc8fKSbYs+GrNqsfZCx3QsXSZ05kKPzU4RuGtd4LO9WAA56GgEFTsGV 08TCIwwIGManIWkw1jgZmFhr/ClQKDQfFkHN04zwdQdM7GquzbkZ/QvxwsQvsM2Wr9lC UhhdJQ76lI+GXSnlUzIDvkWIJ8x37EuWVpgfn4SHAUPG1RpHdaHnjrBLlzVyABVg0qQA Hd61bT5ulzeMT0/eVtSf5GQB7fB6esvx6UJ1XDTd4g2pyZHEcVW6DukVok+dhHHbjXJN laLiA7XH95mdtd7I5DE6qbAtMJtjQKCetcpFULs44QYuktMYVW+Gq7Gipbn6rNNZoHU7 8p4g== X-Gm-Message-State: ACrzQf3OmeQ0wnx8yEw9cZZNl6un6X2l6ebJVcU5H/mBAQpCzQ1kPhD3 4dcr+fifnaSkUuBaq/ekKFkWZiyvhpxOqGno X-Google-Smtp-Source: AMsMyM7aJBWuMbHqDbXfnXGd0kzbD36n8a965qGLJxiV0B0mqGKUjdNZ7WZfShf0hhO6d4DEg4Frhg== X-Received: by 2002:a17:903:40cb:b0:17f:6e08:6eac with SMTP id t11-20020a17090340cb00b0017f6e086eacmr41735848pld.80.1666750324097; Tue, 25 Oct 2022 19:12:04 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 14/47] accel/tcg: Remove duplicate store to tb->page_addr[] Date: Wed, 26 Oct 2022 12:10:43 +1000 Message-Id: <20221026021116.1988449-15-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::102f; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x102f.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750942586100001 When we added the fast path, we initialized page_addr[] early. These stores in and around tb_page_add() are redundant; remove them. Fixes: 50627f1b7b1 ("accel/tcg: Add fast path for translator_ld*") Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/tb-maint.c | 3 --- 1 file changed, 3 deletions(-) diff --git a/accel/tcg/tb-maint.c b/accel/tcg/tb-maint.c index 9af5cb49e0..7f4e1e1299 100644 --- a/accel/tcg/tb-maint.c +++ b/accel/tcg/tb-maint.c @@ -405,7 +405,6 @@ static inline void tb_page_add(PageDesc *p, Translation= Block *tb, =20 assert_page_locked(p); =20 - tb->page_addr[n] =3D page_addr; tb->page_next[n] =3D p->first_tb; #ifndef CONFIG_USER_ONLY page_already_protected =3D p->first_tb !=3D (uintptr_t)NULL; @@ -461,8 +460,6 @@ TranslationBlock *tb_link_page(TranslationBlock *tb, tb= _page_addr_t phys_pc, tb_page_add(p, tb, 0, phys_pc); if (p2) { tb_page_add(p2, tb, 1, phys_page2); - } else { - tb->page_addr[1] =3D -1; } =20 /* add in the hash table */ --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750480; cv=none; d=zohomail.com; s=zohoarc; b=dLLhBQCicY1mIbZn3R+jzZQGxpSoUAbsmEawjbQzIt3Dvuu4LB3lXY3CNco+jKIR5jRrnVmXj3IVwCuc26AtEz+svc+7q6tmOVxnfjfVCgBn0BdOUmwb6mfWmiRwq/BRbZ1JWDi7qMald04508jvZFgxcx6JT8L3i8dd0WHjO7k= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750480; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=YEu7C5O9uXiNgclmsb1i1sQgwnCujdvj8kY+wGSE9K4=; b=CK2jqLKmVydXqJ/LoOwA3/4K2hC6K8/dVQBAlYKeSbpj6Lw4f1BOfwYYlPJt9m35RC2q7brmXk3fP3MUD7LIzlvw9T3yO7Sz9ze7ZmD4kUbDdJnBAKzBgOPuFuHQ8gHjpy2BORlKyQtXH/k+AYeb3rpxQnloblWNd+9lDbnm3/I= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750480902893.9726457265282; Tue, 25 Oct 2022 19:14:40 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtr-0004wH-W7; Tue, 25 Oct 2022 22:12:12 -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 1onVtq-0004w6-Bd for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:10 -0400 Received: from mail-pj1-x102e.google.com ([2607:f8b0:4864:20::102e]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVto-0001BR-CS for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:10 -0400 Received: by mail-pj1-x102e.google.com with SMTP id pb15so12676948pjb.5 for ; Tue, 25 Oct 2022 19:12:07 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.04 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=YEu7C5O9uXiNgclmsb1i1sQgwnCujdvj8kY+wGSE9K4=; b=R3lSb694bFlXHCpzVjqpZFeQXmosTiciBA77olyH0SjIMPxcPPN2WdOti0JOg/plab L598Qwrjj/Qd2Y9sD7iUqEeH26/HEH/tJj9ISOr02akPgeYY2IAuaTtIs/XH+EWuiTgQ TnEQNxA8cmzFuiMz2PjTH/Lfo00Dzw/DO3u/Y3KMHHozQeB+Dd9IFq9vYqfZb7/VhN98 B1HERFKvdY6ngkGydJUaZINj6mDqXZwyQA7FeoVGw9onWlPApAB9p7UNhlYM7XJbvaSh 4gHq3ikUx1WISkW1YrAd/qGumJwXFJZP4ySMwJ71QAWHAQEKLD/UHCg/B+49ymg77wiO Zi1Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=YEu7C5O9uXiNgclmsb1i1sQgwnCujdvj8kY+wGSE9K4=; b=r3vHr51piw+sKsEzgtgY2izhgSXo+p0CIAgZK3EChmjfct6HPqTt0QNesbRJBIYv9d nO4rFLGuvva3UDLMub98vckNVqZRaDDS+3r3rn27igpkt7lea67BcNI74Mjb56uMHG5m cjlmdVXkaOBnD0GeMoVHbFu6wsM54Fx4EQ9JFqtWk9HIlHufUw0Mj3Z+UozEWVBl7CBh x+2VW5N3yPaXev5O4tbFRg1/hf0EoRNvbXDShWlWorcX0kh4kndMTEBtwp/j7QDRFi4R h95tz8Za+Hwu5QJMCcv6xvDIX0oK545rKF/2j1pZYFwiIrEJueHgKH8e37tLxaFbFjsH edIA== X-Gm-Message-State: ACrzQf2QptEe+VpX9DV5YEo1zdlxDsB3y13BdJXO1MMG0s2m0vmYFx6k GdG2qSw0yLr6rbWWEXPbl5QdYZahTfhpvRQC X-Google-Smtp-Source: AMsMyM7S3rdixOQb2NTmkaCGAJvto8NXOtAPqlRDqJjmsUwhJZolxHWAFcRgdsuT5FrUjKYB69ExmQ== X-Received: by 2002:a17:90b:3a88:b0:209:f35d:ad53 with SMTP id om8-20020a17090b3a8800b00209f35dad53mr1519661pjb.102.1666750326884; Tue, 25 Oct 2022 19:12:06 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 15/47] accel/tcg: Introduce tb_{set_}page_addr{0,1} Date: Wed, 26 Oct 2022 12:10:44 +1000 Message-Id: <20221026021116.1988449-16-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::102e; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x102e.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750481702100003 This data structure will be replaced for user-only: add accessors. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- include/exec/exec-all.h | 22 ++++++++++++++++++++++ accel/tcg/cpu-exec.c | 9 +++++---- accel/tcg/tb-maint.c | 29 +++++++++++++++-------------- accel/tcg/translate-all.c | 16 ++++++++-------- accel/tcg/translator.c | 9 +++++---- 5 files changed, 55 insertions(+), 30 deletions(-) diff --git a/include/exec/exec-all.h b/include/exec/exec-all.h index b5bde1b56a..5900f4637b 100644 --- a/include/exec/exec-all.h +++ b/include/exec/exec-all.h @@ -610,6 +610,28 @@ static inline uint32_t tb_cflags(const TranslationBloc= k *tb) return qatomic_read(&tb->cflags); } =20 +static inline tb_page_addr_t tb_page_addr0(const TranslationBlock *tb) +{ + return tb->page_addr[0]; +} + +static inline tb_page_addr_t tb_page_addr1(const TranslationBlock *tb) +{ + return tb->page_addr[1]; +} + +static inline void tb_set_page_addr0(TranslationBlock *tb, + tb_page_addr_t addr) +{ + tb->page_addr[0] =3D addr; +} + +static inline void tb_set_page_addr1(TranslationBlock *tb, + tb_page_addr_t addr) +{ + tb->page_addr[1] =3D addr; +} + /* current cflags for hashing/comparison */ uint32_t curr_cflags(CPUState *cpu); =20 diff --git a/accel/tcg/cpu-exec.c b/accel/tcg/cpu-exec.c index bb4b9e92ce..82b06c1824 100644 --- a/accel/tcg/cpu-exec.c +++ b/accel/tcg/cpu-exec.c @@ -187,13 +187,14 @@ static bool tb_lookup_cmp(const void *p, const void *= d) const struct tb_desc *desc =3D d; =20 if ((TARGET_TB_PCREL || tb_pc(tb) =3D=3D desc->pc) && - tb->page_addr[0] =3D=3D desc->page_addr0 && + tb_page_addr0(tb) =3D=3D desc->page_addr0 && tb->cs_base =3D=3D desc->cs_base && tb->flags =3D=3D desc->flags && tb->trace_vcpu_dstate =3D=3D desc->trace_vcpu_dstate && tb_cflags(tb) =3D=3D desc->cflags) { /* check next page if needed */ - if (tb->page_addr[1] =3D=3D -1) { + tb_page_addr_t tb_phys_page1 =3D tb_page_addr1(tb); + if (tb_phys_page1 =3D=3D -1) { return true; } else { tb_page_addr_t phys_page1; @@ -210,7 +211,7 @@ static bool tb_lookup_cmp(const void *p, const void *d) */ virt_page1 =3D TARGET_PAGE_ALIGN(desc->pc); phys_page1 =3D get_page_addr_code(desc->env, virt_page1); - if (tb->page_addr[1] =3D=3D phys_page1) { + if (tb_phys_page1 =3D=3D phys_page1) { return true; } } @@ -1019,7 +1020,7 @@ int cpu_exec(CPUState *cpu) * direct jump to a TB spanning two pages because the mapping * for the second page can change. */ - if (tb->page_addr[1] !=3D -1) { + if (tb_page_addr1(tb) !=3D -1) { last_tb =3D NULL; } #endif diff --git a/accel/tcg/tb-maint.c b/accel/tcg/tb-maint.c index 7f4e1e1299..15ec2f741d 100644 --- a/accel/tcg/tb-maint.c +++ b/accel/tcg/tb-maint.c @@ -44,8 +44,8 @@ static bool tb_cmp(const void *ap, const void *bp) a->flags =3D=3D b->flags && (tb_cflags(a) & ~CF_INVALID) =3D=3D (tb_cflags(b) & ~CF_INVALI= D) && a->trace_vcpu_dstate =3D=3D b->trace_vcpu_dstate && - a->page_addr[0] =3D=3D b->page_addr[0] && - a->page_addr[1] =3D=3D b->page_addr[1]); + tb_page_addr0(a) =3D=3D tb_page_addr0(b) && + tb_page_addr1(a) =3D=3D tb_page_addr1(b)); } =20 void tb_htable_init(void) @@ -273,7 +273,7 @@ static void do_tb_phys_invalidate(TranslationBlock *tb,= bool rm_from_page_list) qemu_spin_unlock(&tb->jmp_lock); =20 /* remove the TB from the hash list */ - phys_pc =3D tb->page_addr[0]; + phys_pc =3D tb_page_addr0(tb); h =3D tb_hash_func(phys_pc, (TARGET_TB_PCREL ? 0 : tb_pc(tb)), tb->flags, orig_cflags, tb->trace_vcpu_dstate); if (!qht_remove(&tb_ctx.htable, tb, h)) { @@ -282,10 +282,11 @@ static void do_tb_phys_invalidate(TranslationBlock *t= b, bool rm_from_page_list) =20 /* remove the TB from the page list */ if (rm_from_page_list) { - p =3D page_find(tb->page_addr[0] >> TARGET_PAGE_BITS); + p =3D page_find(phys_pc >> TARGET_PAGE_BITS); tb_page_remove(p, tb); - if (tb->page_addr[1] !=3D -1) { - p =3D page_find(tb->page_addr[1] >> TARGET_PAGE_BITS); + phys_pc =3D tb_page_addr1(tb); + if (phys_pc !=3D -1) { + p =3D page_find(phys_pc >> TARGET_PAGE_BITS); tb_page_remove(p, tb); } } @@ -358,16 +359,16 @@ static inline void page_unlock_tb(const TranslationBl= ock *tb) { } /* lock the page(s) of a TB in the correct acquisition order */ static void page_lock_tb(const TranslationBlock *tb) { - page_lock_pair(NULL, tb->page_addr[0], NULL, tb->page_addr[1], false); + page_lock_pair(NULL, tb_page_addr0(tb), NULL, tb_page_addr1(tb), false= ); } =20 static void page_unlock_tb(const TranslationBlock *tb) { - PageDesc *p1 =3D page_find(tb->page_addr[0] >> TARGET_PAGE_BITS); + PageDesc *p1 =3D page_find(tb_page_addr0(tb) >> TARGET_PAGE_BITS); =20 page_unlock(p1); - if (unlikely(tb->page_addr[1] !=3D -1)) { - PageDesc *p2 =3D page_find(tb->page_addr[1] >> TARGET_PAGE_BITS); + if (unlikely(tb_page_addr1(tb) !=3D -1)) { + PageDesc *p2 =3D page_find(tb_page_addr1(tb) >> TARGET_PAGE_BITS); =20 if (p2 !=3D p1) { page_unlock(p2); @@ -382,7 +383,7 @@ static void page_unlock_tb(const TranslationBlock *tb) */ void tb_phys_invalidate(TranslationBlock *tb, tb_page_addr_t page_addr) { - if (page_addr =3D=3D -1 && tb->page_addr[0] !=3D -1) { + if (page_addr =3D=3D -1 && tb_page_addr0(tb) !=3D -1) { page_lock_tb(tb); do_tb_phys_invalidate(tb, true); page_unlock_tb(tb); @@ -516,11 +517,11 @@ tb_invalidate_phys_page_range__locked(struct page_col= lection *pages, if (n =3D=3D 0) { /* NOTE: tb_end may be after the end of the page, but it is not a problem */ - tb_start =3D tb->page_addr[0]; + tb_start =3D tb_page_addr0(tb); tb_end =3D tb_start + tb->size; } else { - tb_start =3D tb->page_addr[1]; - tb_end =3D tb_start + ((tb->page_addr[0] + tb->size) + tb_start =3D tb_page_addr1(tb); + tb_end =3D tb_start + ((tb_page_addr0(tb) + tb->size) & ~TARGET_PAGE_MASK); } if (!(tb_end <=3D start || tb_start >=3D end)) { diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 5e28e9fccd..bef4c56cff 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -698,9 +698,9 @@ page_collection_lock(tb_page_addr_t start, tb_page_addr= _t end) } assert_page_locked(pd); PAGE_FOR_EACH_TB(pd, tb, n) { - if (page_trylock_add(set, tb->page_addr[0]) || - (tb->page_addr[1] !=3D -1 && - page_trylock_add(set, tb->page_addr[1]))) { + if (page_trylock_add(set, tb_page_addr0(tb)) || + (tb_page_addr1(tb) !=3D -1 && + page_trylock_add(set, tb_page_addr1(tb)))) { /* drop all locks, and reacquire in order */ g_tree_foreach(set->tree, page_entry_unlock, NULL); goto retry; @@ -771,8 +771,8 @@ TranslationBlock *tb_gen_code(CPUState *cpu, tb->flags =3D flags; tb->cflags =3D cflags; tb->trace_vcpu_dstate =3D *cpu->trace_dstate; - tb->page_addr[0] =3D phys_pc; - tb->page_addr[1] =3D -1; + tb_set_page_addr0(tb, phys_pc); + tb_set_page_addr1(tb, -1); tcg_ctx->tb_cflags =3D cflags; tb_overflow: =20 @@ -970,7 +970,7 @@ TranslationBlock *tb_gen_code(CPUState *cpu, * a temporary one-insn TB, and we have nothing left to do. Return ear= ly * before attempting to link to other TBs or add to the lookup table. */ - if (tb->page_addr[0] =3D=3D -1) { + if (tb_page_addr0(tb) =3D=3D -1) { return tb; } =20 @@ -985,7 +985,7 @@ TranslationBlock *tb_gen_code(CPUState *cpu, * No explicit memory barrier is required -- tb_link_page() makes the * TB visible in a consistent state. */ - existing_tb =3D tb_link_page(tb, tb->page_addr[0], tb->page_addr[1]); + existing_tb =3D tb_link_page(tb, tb_page_addr0(tb), tb_page_addr1(tb)); /* if the TB already exists, discard what we just translated */ if (unlikely(existing_tb !=3D tb)) { uintptr_t orig_aligned =3D (uintptr_t)gen_code_buf; @@ -1140,7 +1140,7 @@ static gboolean tb_tree_stats_iter(gpointer key, gpoi= nter value, gpointer data) if (tb->size > tst->max_target_size) { tst->max_target_size =3D tb->size; } - if (tb->page_addr[1] !=3D -1) { + if (tb_page_addr1(tb) !=3D -1) { tst->cross_page++; } if (tb->jmp_reset_offset[0] !=3D TB_JMP_RESET_OFFSET_INVALID) { diff --git a/accel/tcg/translator.c b/accel/tcg/translator.c index 8e78fd7a9c..061519691f 100644 --- a/accel/tcg/translator.c +++ b/accel/tcg/translator.c @@ -157,7 +157,7 @@ static void *translator_access(CPUArchState *env, Disas= ContextBase *db, tb =3D db->tb; =20 /* Use slow path if first page is MMIO. */ - if (unlikely(tb->page_addr[0] =3D=3D -1)) { + if (unlikely(tb_page_addr0(tb) =3D=3D -1)) { return NULL; } =20 @@ -169,13 +169,14 @@ static void *translator_access(CPUArchState *env, Dis= asContextBase *db, host =3D db->host_addr[1]; base =3D TARGET_PAGE_ALIGN(db->pc_first); if (host =3D=3D NULL) { - tb->page_addr[1] =3D + tb_page_addr_t phys_page =3D get_page_addr_code_hostp(env, base, &db->host_addr[1]); + /* We cannot handle MMIO as second page. */ + assert(phys_page !=3D -1); + tb_set_page_addr1(tb, phys_page); #ifdef CONFIG_USER_ONLY page_protect(end); #endif - /* We cannot handle MMIO as second page. */ - assert(tb->page_addr[1] !=3D -1); host =3D db->host_addr[1]; } =20 --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751095; cv=none; d=zohomail.com; s=zohoarc; b=HjDwyQCLdC1Q9L+7ZuvMVLXMigtabzkWa3VylQRGpg1Joi9F2HfZTEOBjkoIWH6c6b2Loc+E1UrWDcSxps6UH7CKlxIVaYtoqqZIDuPt5t1GEcIpqPDYnlfX08EqtZtEvIDkdO5LbE5FDSYBYiGSaPYniLlBFBxJ+kYht7nYQDo= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751095; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=tnT5+dpLTwN0CkZJHE3atGpGoan/sbArZdyzXxhv1mc=; b=ZpcSDjY5wDcsWXClALmyXTs6G8KlZ0YMcjFKWY9HGsUu4nBGwJbyYD1VFJLo+dG6+7M7pIJhpljoKHoslnayg87iwELAh1wqify07cMkWRGwr1MqMoKsV62IWMRiQYOCGjrQhcSLxtfWs/zI900eAghOBmNlacjwY5EqtrC8vK0= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 166675109573831.825614176205477; Tue, 25 Oct 2022 19:24:55 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtu-0004wq-KD; Tue, 25 Oct 2022 22:12:14 -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 1onVtt-0004wV-EL for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:13 -0400 Received: from mail-pj1-x102f.google.com ([2607:f8b0:4864:20::102f]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtq-0001Cl-Qv for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:12 -0400 Received: by mail-pj1-x102f.google.com with SMTP id r61-20020a17090a43c300b00212f4e9cccdso996897pjg.5 for ; Tue, 25 Oct 2022 19:12:10 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=tnT5+dpLTwN0CkZJHE3atGpGoan/sbArZdyzXxhv1mc=; b=vv9zT1+ZwaFK2G4sLMqNcH+SHmLthWCzV9G7PjabFA5ehZnDquHQ98J6ufrpdcgy84 kgPgn3CEres2ISA99iM7ew/UxKPhASnPuAgNylTR/oyl0Jv/03ijciN4+IV3gGkT/7R7 DCk14fEDiU7AjFRpLZOsuAC9wRj++UBv20NROoB/DdakYAiOZfT6oGZqPHbXC7vnxX0T MkNsYwLkS6hc1eZB056jb/15CIdhUZwo1Ch0tQV/nMhZ8Qohu+ucgDGEXJ0XIZSyB9gJ QXAZxqfyeRinqgrrws7+tEozebaEh3foRtwp28Gj6LdhACR6UDsFb/f70I2AM3iLWqSd VXSg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=tnT5+dpLTwN0CkZJHE3atGpGoan/sbArZdyzXxhv1mc=; b=V66mN2oUTZ3lEEZzUDq11ZFUOVZ2Uy33TpFQycWh0mRRV+PsLdCaBdJQ5o+DqhLSa0 JaCssVFKyD+X7KsmcSvUwUll0RN65DQ8sEtzPRV5ea9YWkO+S+Nimt2Jthe/EqFOrd7V qKnExUEcPCB2pZ7FagFSppRRqd26ONCGIcugj46MNKf8y7FEdbfkZNlmXUYZyZ+DNT7x cN+d3XZgwZGjrPPBtBWUdZjcvuXEBFmyrYTOPibq2rUBCSfqjiZvZ1zIR0/DOHJvNyUf zoL8FkDvJb3NURrR4zqGddhegyJLKTyqFKDljQoTSB+0DZgKHHP2WkbGjuS8ChSNdz6m /WFQ== X-Gm-Message-State: ACrzQf3hu64xVqTMm6wzQOF6X61+//e6czKWSO6x1RUuxkTGfLlvxbad quYemfA9XKwwUbe94ue7hhc+jczU9jKNNeqm X-Google-Smtp-Source: AMsMyM7Z+eLKcAvc1EzEm/rBGFuTuCH7uWy6Ia4rP+22U9b3dTdyXdf930jI8LF2Q8HADpphfWDcig== X-Received: by 2002:a17:90b:394:b0:212:19d7:9072 with SMTP id ga20-20020a17090b039400b0021219d79072mr1477820pjb.69.1666750329412; Tue, 25 Oct 2022 19:12:09 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 16/47] accel/tcg: Rename tb_invalidate_phys_page Date: Wed, 26 Oct 2022 12:10:45 +1000 Message-Id: <20221026021116.1988449-17-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::102f; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x102f.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751097282100013 Rename to tb_invalidate_phys_page_unwind to emphasize that we also detect invalidating the current TB, and also to free up that name for other usage. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/internal.h | 2 +- accel/tcg/tb-maint.c | 2 +- accel/tcg/translate-all.c | 5 +++-- 3 files changed, 5 insertions(+), 4 deletions(-) diff --git a/accel/tcg/internal.h b/accel/tcg/internal.h index 1a704ee14f..1227bb69bd 100644 --- a/accel/tcg/internal.h +++ b/accel/tcg/internal.h @@ -105,7 +105,7 @@ void tb_htable_init(void); void tb_reset_jump(TranslationBlock *tb, int n); TranslationBlock *tb_link_page(TranslationBlock *tb, tb_page_addr_t phys_p= c, tb_page_addr_t phys_page2); -bool tb_invalidate_phys_page(tb_page_addr_t addr, uintptr_t pc); +bool tb_invalidate_phys_page_unwind(tb_page_addr_t addr, uintptr_t pc); int cpu_restore_state_from_tb(CPUState *cpu, TranslationBlock *tb, uintptr_t searched_pc, bool reset_icount); =20 diff --git a/accel/tcg/tb-maint.c b/accel/tcg/tb-maint.c index 15ec2f741d..92170cbbc1 100644 --- a/accel/tcg/tb-maint.c +++ b/accel/tcg/tb-maint.c @@ -657,7 +657,7 @@ void tb_invalidate_phys_page_fast(struct page_collectio= n *pages, * TB (because it was modified by this store and the guest CPU has * precise-SMC semantics). */ -bool tb_invalidate_phys_page(tb_page_addr_t addr, uintptr_t pc) +bool tb_invalidate_phys_page_unwind(tb_page_addr_t addr, uintptr_t pc) { TranslationBlock *tb; PageDesc *p; diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index bef4c56cff..aa8d213514 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -1382,7 +1382,7 @@ void page_set_flags(target_ulong start, target_ulong = end, int flags) if (!(p->flags & PAGE_WRITE) && (flags & PAGE_WRITE) && p->first_tb) { - tb_invalidate_phys_page(addr, 0); + tb_invalidate_phys_page_unwind(addr, 0); } if (reset_target_data) { g_free(p->target_data); @@ -1580,7 +1580,8 @@ int page_unprotect(target_ulong address, uintptr_t pc) =20 /* and since the content will be modified, we must invalid= ate the corresponding translated code. */ - current_tb_invalidated |=3D tb_invalidate_phys_page(addr, = pc); + current_tb_invalidated |=3D + tb_invalidate_phys_page_unwind(addr, pc); } mprotect((void *)g2h_untagged(host_start), qemu_host_page_size, prot & PAGE_BITS); --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750864; cv=none; d=zohomail.com; s=zohoarc; b=JJbVlJjMb9XEK4TxzEdXfW/ypHOlgxHwfsRz5KCkKvAcp8oatZ1BNHiOAMwNWEG5SuFwSf5RyX9r5z40wiXRCEtClP9erEDdpyHHL3FN3ipbyLHvdBFrPBokYB3l0XYDX+dCRkZfP2CN0UnJiW4OZoXE1hkFjuHqMUARHpAXO9E= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750864; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=KvjMeVIEaU8EHUZx3hOOt4jSPjq3zK70k+5NK6+i9OM=; b=hMZ3cNXEt/6Bf9f8D3gp5XHjWMBN5sr5kWXTrC6FFuf/Sn93w0GqYRRbmbbD/YEJRQwI6HF0xkx1GMGbWsSEHNZfrfckRBP0W1CFBkg88482nO3XcvBJr1XBOB0kBPDqvkmX1351Bb8+FG4xdnkE71jEKXNPGhQdD2SpWA53+qo= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750864421386.5097010883668; Tue, 25 Oct 2022 19:21:04 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVtw-0004x0-9B; Tue, 25 Oct 2022 22:12:16 -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 1onVtv-0004ws-JW for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:15 -0400 Received: from mail-pg1-x531.google.com ([2607:f8b0:4864:20::531]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtu-00019J-29 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:15 -0400 Received: by mail-pg1-x531.google.com with SMTP id 20so13457167pgc.5 for ; Tue, 25 Oct 2022 19:12:12 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.09 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=KvjMeVIEaU8EHUZx3hOOt4jSPjq3zK70k+5NK6+i9OM=; b=WnkSuzekzt+8X5xxoOUlq3e9IAQzUUgG+v9U9kY5tC94ZsRGwsIEeQNBazcZbk1iYT 6euntrVfzZH7ae8vuii1rBEgVomBuviT7sj2v77BFqAjvltJ83TQxvXf0tRBscAdGhO+ 9RgmGihi3KlvikQG7w3u1/i9S9mPi1Pnpd8Giuqvg/NfAd6u2VgREitMvAHakOaz0KUq EaMCe967O++2bYr1jlL9UfjgqxO27H1IjtLdfQ1G80suLeq/wLPYuP4hdUU88UsZ70ln OO+n0cGGXwAqaUZ6XOtWZBl7Jf/d++e7800V+7ngSjpF/IkNh0friPp64zNtdRBICd7I QVTA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=KvjMeVIEaU8EHUZx3hOOt4jSPjq3zK70k+5NK6+i9OM=; b=12PqkSYgG17mkf9WCogmb2CbKyGATu2GKw7jakEHdA6oEVxv5imvlEG8SEfPxf/2lI 67dXA6F1tjsnkGidBaTMMq63kywFMleKaJ4Vx/HJawuvPuBx3wjzzPMPkOHmlZgIcpK8 oMhg0j7UBvhPVe9S6SSD/sJummwvpjT1tp0LCLsCNYMSJ42z+tU2pmi8YHZzaP+Y0LuI q6BYxSPIkQrAda94bkT45FcFj2YEsEx4sIqgk/el+nELmphKvXm4siBJmBwlnETpJgTh 6YFepKgIe5goSj1y/ODJcfDnE77ZqwOYZfEXGh9rvvWEjdjaEdi6LubpRaunQUy9cYE/ KoZA== X-Gm-Message-State: ACrzQf2CifarrvOHC/zdYhuGhZgi07SXm5AabqT12DyTj0/uRusYGSWs Y6JmBCeibheE1b6cjYAh81VMd8MTBEYsCqz8 X-Google-Smtp-Source: AMsMyM6FeHradWrBmN64CXdI8Fd5xIkDDM8DmCvK6mJIzEAD0pzD+wNp1LrgQ/P48guv/A/k3/NVFg== X-Received: by 2002:a65:5b0b:0:b0:462:da7a:1ded with SMTP id y11-20020a655b0b000000b00462da7a1dedmr18451669pgq.605.1666750332271; Tue, 25 Oct 2022 19:12:12 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 17/47] accel/tcg: Rename tb_invalidate_phys_page_range and drop end parameter Date: Wed, 26 Oct 2022 12:10:46 +1000 Message-Id: <20221026021116.1988449-18-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::531; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x531.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750866078100003 This function is is never called with a real range, only for a single page. Drop the second parameter and rename to tb_invalidate_phys_page. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- include/exec/translate-all.h | 2 +- accel/tcg/tb-maint.c | 15 ++++++++------- cpu.c | 4 ++-- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/include/exec/translate-all.h b/include/exec/translate-all.h index 9f646389af..3e9cb91565 100644 --- a/include/exec/translate-all.h +++ b/include/exec/translate-all.h @@ -29,7 +29,7 @@ void page_collection_unlock(struct page_collection *set); void tb_invalidate_phys_page_fast(struct page_collection *pages, tb_page_addr_t start, int len, uintptr_t retaddr); -void tb_invalidate_phys_page_range(tb_page_addr_t start, tb_page_addr_t en= d); +void tb_invalidate_phys_page(tb_page_addr_t addr); void tb_check_watchpoint(CPUState *cpu, uintptr_t retaddr); =20 #ifdef CONFIG_USER_ONLY diff --git a/accel/tcg/tb-maint.c b/accel/tcg/tb-maint.c index 92170cbbc1..bac43774c0 100644 --- a/accel/tcg/tb-maint.c +++ b/accel/tcg/tb-maint.c @@ -565,25 +565,26 @@ tb_invalidate_phys_page_range__locked(struct page_col= lection *pages, } =20 /* - * Invalidate all TBs which intersect with the target physical address ran= ge - * [start;end[. NOTE: start and end must refer to the *same* physical page. - * 'is_cpu_write_access' should be true if called from a real cpu write - * access: the virtual CPU will exit the current TB if code is modified in= side - * this TB. + * Invalidate all TBs which intersect with the target physical + * address page @addr. * * Called with mmap_lock held for user-mode emulation */ -void tb_invalidate_phys_page_range(tb_page_addr_t start, tb_page_addr_t en= d) +void tb_invalidate_phys_page(tb_page_addr_t addr) { struct page_collection *pages; + tb_page_addr_t start, end; PageDesc *p; =20 assert_memory_lock(); =20 - p =3D page_find(start >> TARGET_PAGE_BITS); + p =3D page_find(addr >> TARGET_PAGE_BITS); if (p =3D=3D NULL) { return; } + + start =3D addr & TARGET_PAGE_MASK; + end =3D start + TARGET_PAGE_SIZE; pages =3D page_collection_lock(start, end); tb_invalidate_phys_page_range__locked(pages, p, start, end, 0); page_collection_unlock(pages); diff --git a/cpu.c b/cpu.c index 14365e36f3..2a09b05205 100644 --- a/cpu.c +++ b/cpu.c @@ -277,7 +277,7 @@ void list_cpus(const char *optarg) void tb_invalidate_phys_addr(target_ulong addr) { mmap_lock(); - tb_invalidate_phys_page_range(addr, addr + 1); + tb_invalidate_phys_page(addr); mmap_unlock(); } #else @@ -298,7 +298,7 @@ void tb_invalidate_phys_addr(AddressSpace *as, hwaddr a= ddr, MemTxAttrs attrs) return; } ram_addr =3D memory_region_get_ram_addr(mr) + addr; - tb_invalidate_phys_page_range(ram_addr, ram_addr + 1); + tb_invalidate_phys_page(ram_addr); } #endif =20 --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751497; cv=none; d=zohomail.com; s=zohoarc; b=cs38tYibTVj/i+cfm4jcPD06sg4jNxhuyyS0tdTpXR+B3HhC6RZP2V8FBxjN3UADNhnVAgE/ll4fTloXre1YcTZbHNveo5svgkTaPFEzGC7DHCuxHVP/NUX6cf0T0xUklMHpf1ZDpzeyLdXBc3Mxs0gerH9LJtmsLRwkfbGlmqo= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751497; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=eijG0kSDPpiRBm8vllHxEuHeocUFGDghO4DAqpTBKuY=; b=DCNEPEBw+YVSlkf1+viaHgdN7GXHDchJvZN36aXWYdHiPeEcqdhEfCIx4AQ3zqE2pI1ivOAyN/mdL0R9Bd4qDChl1q/7m4Qjf7+AwL5LV75/B99F+n3J3GZyLoOndrf2QFjFGWwJk3qPbXsih+hONdcKEzRLN8RPy9pWgvz0xc4= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 166675149701370.6951821369347; Tue, 25 Oct 2022 19:31:37 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVty-0004xm-RT; Tue, 25 Oct 2022 22:12:18 -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 1onVtx-0004xI-8P for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:17 -0400 Received: from mail-pj1-x1033.google.com ([2607:f8b0:4864:20::1033]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVtv-0001AU-L2 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:17 -0400 Received: by mail-pj1-x1033.google.com with SMTP id m2so8713816pjr.3 for ; Tue, 25 Oct 2022 19:12:15 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=eijG0kSDPpiRBm8vllHxEuHeocUFGDghO4DAqpTBKuY=; b=Vn+XFUIqnxMIwC+VG0Di9Emya12isVwomC/eP9ULFaGbVe8ICDvZIFCjjm2HHyPFnk dQNVMylxuqIdxRxsKVFnjKwokkJsW4VJmZVphsQBOrE9fWwOUhYo9JFkAB2QtDvysKWt nwt89XJv6k84WHOZrMHbCpnTZ2VfxjVU2fKrWDOJpSqh3rN/tDfkoaLPH9tfoG7u3Hks qHZ19CU5LrpqrSSJehLVq/I8oCygOr6enkwfaO9IJv2lQGQyuLWmlJFc6ePBj7Q/xxlw s2tJ180TBXKyNnAzzVVyt8o4JGT3wsOQsWSpK5OH7wm+Zme6Gg5wSyZXd2VAGkkAZxBG 19Yw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=eijG0kSDPpiRBm8vllHxEuHeocUFGDghO4DAqpTBKuY=; b=jLnYqCFCStLIYxZ8JMeErvkgGr3Z6epDUNcsHcLnmXRNJQe7jM7fjaj3tzn+p5qrY0 PohoTnRlR8xD3jtfjNipmSgkietqYAKPnGnStmDMESfqMP4o92V1OMWOGqYGcITfxD71 hnAv4KJk84K4MvPeMZJ4N7KZCEooQxV3YxKX86ajE0xQZVhj++WEq6WhBw02zSYJVsev Z3Rsdshru4HwqiMahE2t64mOIEqnhUoO0EAazsKx1fid1HLNUSS/PCaffjp9iSOn8rlq wKAszxbTyHq7J1wgR+cuJ8AcxNj8oorcCAafKfBcma9sDXoyG43cq/StLR4ATrYayuhk cz5w== X-Gm-Message-State: ACrzQf2UAgeZ3t5BECZf5E1TI4yZ/AsHnFlmj3tosmuJpk8lOlfJFcFb fR5c6/ckKRRTZURt/o14cjapOiJuM33kmciW X-Google-Smtp-Source: AMsMyM53SfQ0nk/ZfLIAwQWf4zhO/SqquZwhvXJQ5al87ARcwRJPLF4mcxQk9cXLH6SSil1GzHu1tA== X-Received: by 2002:a17:902:b20a:b0:178:6f5b:f903 with SMTP id t10-20020a170902b20a00b001786f5bf903mr42806853plr.39.1666750334896; Tue, 25 Oct 2022 19:12:14 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 18/47] accel/tcg: Unify declarations of tb_invalidate_phys_range Date: Wed, 26 Oct 2022 12:10:47 +1000 Message-Id: <20221026021116.1988449-19-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::1033; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x1033.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751498157100001 We missed this function when we introduced tb_page_addr_t. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- include/exec/exec-all.h | 2 +- include/exec/ram_addr.h | 2 -- accel/tcg/tb-maint.c | 13 ++----------- 3 files changed, 3 insertions(+), 14 deletions(-) diff --git a/include/exec/exec-all.h b/include/exec/exec-all.h index 5900f4637b..5ae484e34d 100644 --- a/include/exec/exec-all.h +++ b/include/exec/exec-all.h @@ -638,12 +638,12 @@ uint32_t curr_cflags(CPUState *cpu); /* TranslationBlock invalidate API */ #if defined(CONFIG_USER_ONLY) void tb_invalidate_phys_addr(target_ulong addr); -void tb_invalidate_phys_range(target_ulong start, target_ulong end); #else void tb_invalidate_phys_addr(AddressSpace *as, hwaddr addr, MemTxAttrs att= rs); #endif void tb_flush(CPUState *cpu); void tb_phys_invalidate(TranslationBlock *tb, tb_page_addr_t page_addr); +void tb_invalidate_phys_range(tb_page_addr_t start, tb_page_addr_t end); void tb_set_jmp_target(TranslationBlock *tb, int n, uintptr_t addr); =20 /* GETPC is the true target of the return instruction that we'll execute. = */ diff --git a/include/exec/ram_addr.h b/include/exec/ram_addr.h index f3e0c78161..1500680458 100644 --- a/include/exec/ram_addr.h +++ b/include/exec/ram_addr.h @@ -147,8 +147,6 @@ static inline void qemu_ram_block_writeback(RAMBlock *b= lock) #define DIRTY_CLIENTS_ALL ((1 << DIRTY_MEMORY_NUM) - 1) #define DIRTY_CLIENTS_NOCODE (DIRTY_CLIENTS_ALL & ~(1 << DIRTY_MEMORY_COD= E)) =20 -void tb_invalidate_phys_range(ram_addr_t start, ram_addr_t end); - static inline bool cpu_physical_memory_get_dirty(ram_addr_t start, ram_addr_t length, unsigned client) diff --git a/accel/tcg/tb-maint.c b/accel/tcg/tb-maint.c index bac43774c0..c8e921089d 100644 --- a/accel/tcg/tb-maint.c +++ b/accel/tcg/tb-maint.c @@ -20,6 +20,7 @@ #include "qemu/osdep.h" #include "exec/cputlb.h" #include "exec/log.h" +#include "exec/exec-all.h" #include "exec/translate-all.h" #include "sysemu/tcg.h" #include "tcg/tcg.h" @@ -27,12 +28,6 @@ #include "tb-context.h" #include "internal.h" =20 -/* FIXME: tb_invalidate_phys_range is declared in different places. */ -#ifdef CONFIG_USER_ONLY -#include "exec/exec-all.h" -#else -#include "exec/ram_addr.h" -#endif =20 static bool tb_cmp(const void *ap, const void *bp) { @@ -599,11 +594,7 @@ void tb_invalidate_phys_page(tb_page_addr_t addr) * * Called with mmap_lock held for user-mode emulation. */ -#ifdef CONFIG_SOFTMMU -void tb_invalidate_phys_range(ram_addr_t start, ram_addr_t end) -#else -void tb_invalidate_phys_range(target_ulong start, target_ulong end) -#endif +void tb_invalidate_phys_range(tb_page_addr_t start, tb_page_addr_t end) { struct page_collection *pages; tb_page_addr_t next; --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750508; cv=none; d=zohomail.com; s=zohoarc; b=VKGCr3yg5tIOw2gZq4Rz9hqIAI0vP+/Cq7GEFQz2Shdyr3HbnMz0J/s1F+Nm5vlwDYG21XpBt7XVSLnbE2zQWvFpbLSBRY3U401qF6TDTTi4FzWCH45M2lBHOowEDyCc/e+u2suDNkPqE8uIoPy5p31KXPG3CMYm+/RKbBShd+c= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750508; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=aSrzPFoUs5rHEO8b0TFpGYbIjtXPckikapFmH/dF2+g=; b=MTYCn/HCBM4IxIpCaKFUpsdLus4cdunEWclpmNepTYIDTeCRDk1gImfa6dRZKpFSfQHNULXgmyfNosZUYJw95xO3KSFFPAbx0fW7Sx3vvxZ9L35JyEazicqO3Y18+n+GEGtXbPs17rHcP0WL444+vT0lCmAf8ipju6bJju+b1RI= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750508030328.1292364343668; Tue, 25 Oct 2022 19:15:08 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVu2-0004y3-DQ; Tue, 25 Oct 2022 22:12:22 -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 1onVu0-0004xt-Fi for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:20 -0400 Received: from mail-pj1-x1032.google.com ([2607:f8b0:4864:20::1032]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVty-0001Do-VD for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:20 -0400 Received: by mail-pj1-x1032.google.com with SMTP id z5-20020a17090a8b8500b00210a3a2364fso2719534pjn.0 for ; Tue, 25 Oct 2022 19:12:18 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=aSrzPFoUs5rHEO8b0TFpGYbIjtXPckikapFmH/dF2+g=; b=ypDTOC6fIscUE71M609XYpQx7RH5vKC9y8kQT9JUwgwwpcrqdj9mkooocHPMoahLv+ kSy2KLkvM2tgRWe4R3mkDUgY9qzL20i3cT7m1kKVpDy+J8hq0UpFZMK8XeaVCVQnitkM gaT8q1o4cGwAszXHvq6342U9wrlVaMBc5KvnLWz/V+izRrm3WVMyeKI80A7oHvRG2jzg rqfKZ++9ryhaZWBESfJ8ugnjN7BillOuiQ+Zyf1JEKACgRXRBGV3BE++n+nXFR8bXnh/ r8PzV3rzexh0bmtGn12HubMa/USvvuHJ6UqZhmW9xDTOgODLJEZpSYYT+oaPq2DhuZm8 9+HA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=aSrzPFoUs5rHEO8b0TFpGYbIjtXPckikapFmH/dF2+g=; b=yKBdeky0loln6PKRBqzYFsza1p34WC4ZljYmenQWI6J2wlN+aE8+RIy83mMSH8Fl7y XnyZQZplt99Pmk1pVEO1tbYRrjK5kPb2i52TeOtpbrmG8wxz1wy7gO6+KR5qcb1HrIwM DzpErHcDuT5SUwruKSyc/SY2KB9lZCSO0pi1iG/CGlyvtFi1+16NoW1H9yz4CeuTU5TY 2r6uLm13PR+/lF2JgCYibMqdMUdilLnXmZDKXDGlIA4tVdY1gqOaVCpPWUgSe6KX0kj/ rE3OpHLg8Yu+y4QO3f9E7DCK0jfEL1xVNk/3MVi2mnaIH9MDu7/dKVrQXkuTduS2HBDy 6H4w== X-Gm-Message-State: ACrzQf3kO8xh0GYjnm7MFr6CpahUiI+MiFQFUcoObkVneoZolmsv5vFr VTYsbkjKLf8zBfkyeFAVtGn2kylABeuf4ZI4 X-Google-Smtp-Source: AMsMyM68yRky23+zfv5rZaFU5cx5Cn0a4A1hMJPpk902v1ZOCCzx7zArFOBPt9FS6yk2M0GYDRhRNA== X-Received: by 2002:a17:90b:4c86:b0:20d:402d:6155 with SMTP id my6-20020a17090b4c8600b0020d402d6155mr1425007pjb.229.1666750337547; Tue, 25 Oct 2022 19:12:17 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 19/47] accel/tcg: Use tb_invalidate_phys_page in page_set_flags Date: Wed, 26 Oct 2022 12:10:48 +1000 Message-Id: <20221026021116.1988449-20-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::1032; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x1032.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750509876100003 We do not require detection of overlapping TBs here, so use the more appropriate function. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/translate-all.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index aa8d213514..8d5233fa9e 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -1382,7 +1382,7 @@ void page_set_flags(target_ulong start, target_ulong = end, int flags) if (!(p->flags & PAGE_WRITE) && (flags & PAGE_WRITE) && p->first_tb) { - tb_invalidate_phys_page_unwind(addr, 0); + tb_invalidate_phys_page(addr); } if (reset_target_data) { g_free(p->target_data); --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750967; cv=none; d=zohomail.com; s=zohoarc; b=djUOGuIy5KSYH7lGrqdOLGrwm5heRliAjFi6GeEq57LNQtIbFnFrg0af8xg9104dFWA+YqUWDmSYhF1wS2IlSPWErSzobzVFGD5E7y69GaGxKXdBKQXL4urFUIy4LPjjMC0mJl0TG7PaP1PlDiCkVxKrORWfNRckB/c/R4nHLRo= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750967; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=su7SRG6mA4EK+3Nl1nKtKV8hb+mbjAByRO+UTdDwjN0=; b=gofcQ9aLN/jZrtj6RlMeeWBzhyUbmJtNEZMWu8ogNktp4tvGrT6OnIwqnLVCB6BP9Mkn2To5YCmxDeUcni+7ynr6eqT/NcbRR16bznWQMunb3ok5OidafFskarcmP4D8bIHJ/VbpwMc9vA268XUMJV71+gZsvRRBQqUpEyagX0M= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750967441297.4631413414917; Tue, 25 Oct 2022 19:22:47 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVu4-0004yQ-Vj; Tue, 25 Oct 2022 22:12:25 -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 1onVu3-0004yG-2S for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:23 -0400 Received: from mail-pj1-x102c.google.com ([2607:f8b0:4864:20::102c]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVu1-0001EB-DR for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:22 -0400 Received: by mail-pj1-x102c.google.com with SMTP id m14-20020a17090a3f8e00b00212dab39bcdso1078581pjc.0 for ; Tue, 25 Oct 2022 19:12:21 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=su7SRG6mA4EK+3Nl1nKtKV8hb+mbjAByRO+UTdDwjN0=; b=AN5Sy4RY/pCtkYuTYQAYfVNLnO2S86ypK5qqiCs+TZUM3ZUCoqdIc7LOy2V01JSuYj K6ox1X7jnjZ3p6qV9rVsSiT4IeHYyCYlpba3aBXJt5589ew3wY1cZG8rQ2ZvRJjoZaTd ZtoHsTAowdwLttAGURgeFlXbWkv8QI2AR8w2633c42xyQxJTAB6hatEqGYAZ6ky2AMJ9 2r1XoPryPsCyAK60nW39+LYNiKDP7Y6JSZvUZia0D5US57iHe6qh0KcfcUgqEoPxQeyF 4ViaVD1ulyr4AjCsuRI/6+MfDmH1dVl+VD5qqplNSsXPX1+d0tbeJwfgg08GoptJoytK DTAw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=su7SRG6mA4EK+3Nl1nKtKV8hb+mbjAByRO+UTdDwjN0=; b=53Bw7depUD5agb7e6DbLSaCmDzdwHsGAf94ygC5naouh2OLt3Rgo41RMIlaODosIux 97sTpFeHChh6f6HgGmEwFxJNj7rlD2K70XO9R9VhVcJ0LEzh3ZVDuHi4Cn0fk34dsAqM iq2gcYbxB6qzSqUkB/LcajYk2kvh1+fUhIQfmSpWv4YpRJ2dlqKBqWGfgWFiCA5dOVVq lHuoPf4tqc+jsOvr3p7L9f7J0DB5EPkAVMplQdXC2gk+F4zaaXgShTwT7xca4+BH6Jbo r/N7hKvQUiY6/jxIbhuw0GgMFuMqATkw9q3DmIjzUxef9/q2UxrgiO+bTwcxrnG9HciI M5gQ== X-Gm-Message-State: ACrzQf3vfn0w9ZO9G52ZiWO/XPgs9eTYBwxW1VBwnUDNYwEIsq+3NxyI AYH+t28Y4FDCMXF/z0s308AMx/gQzmHjk4N6 X-Google-Smtp-Source: AMsMyM7kTe8TXoJ7GIw7xuoCeVFl0S57d7+pKwaX4uz9wjJj6mQJNt5Z0CQlDdDS36dIK0T7XAOi/g== X-Received: by 2002:a17:90b:4f8a:b0:213:48f0:296f with SMTP id qe10-20020a17090b4f8a00b0021348f0296fmr1520582pjb.140.1666750340051; Tue, 25 Oct 2022 19:12:20 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 20/47] accel/tcg: Call tb_invalidate_phys_page for PAGE_RESET Date: Wed, 26 Oct 2022 12:10:49 +1000 Message-Id: <20221026021116.1988449-21-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::102c; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x102c.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750968761100001 When PAGE_RESET is set, we are replacing pages with new content, which means that we need to invalidate existing cached data, such as TranslationBlocks. Perform the reset invalidate while we're doing other invalidates, which allows us to remove the separate invalidates from the user-only mmap/munmap/mprotect routines. In addition, restrict invalidation to PAGE_EXEC pages. Since cdf713085131, we have validated PAGE_EXEC is present before translation, which means we can assume that if the bit is not present, there are no translations to invalidate. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/translate-all.c | 19 +++++++++++-------- bsd-user/mmap.c | 2 -- linux-user/mmap.c | 4 ---- 3 files changed, 11 insertions(+), 14 deletions(-) diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 8d5233fa9e..478301f227 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -1352,7 +1352,7 @@ int page_get_flags(target_ulong address) void page_set_flags(target_ulong start, target_ulong end, int flags) { target_ulong addr, len; - bool reset_target_data; + bool reset; =20 /* This function should never be called with addresses outside the guest address space. If this assert fires, it probably indicates @@ -1369,7 +1369,7 @@ void page_set_flags(target_ulong start, target_ulong = end, int flags) if (flags & PAGE_WRITE) { flags |=3D PAGE_WRITE_ORG; } - reset_target_data =3D !(flags & PAGE_VALID) || (flags & PAGE_RESET); + reset =3D !(flags & PAGE_VALID) || (flags & PAGE_RESET); flags &=3D ~PAGE_RESET; =20 for (addr =3D start, len =3D end - start; @@ -1377,14 +1377,17 @@ void page_set_flags(target_ulong start, target_ulon= g end, int flags) len -=3D TARGET_PAGE_SIZE, addr +=3D TARGET_PAGE_SIZE) { PageDesc *p =3D page_find_alloc(addr >> TARGET_PAGE_BITS, true); =20 - /* If the write protection bit is set, then we invalidate - the code inside. */ - if (!(p->flags & PAGE_WRITE) && - (flags & PAGE_WRITE) && - p->first_tb) { + /* + * If the page was executable, but is reset, or is no longer + * executable, or has become writable, then invalidate any code. + */ + if ((p->flags & PAGE_EXEC) + && (reset || + !(flags & PAGE_EXEC) || + (flags & ~p->flags & PAGE_WRITE))) { tb_invalidate_phys_page(addr); } - if (reset_target_data) { + if (reset) { g_free(p->target_data); p->target_data =3D NULL; p->flags =3D flags; diff --git a/bsd-user/mmap.c b/bsd-user/mmap.c index e54e26de17..d6c5a344c9 100644 --- a/bsd-user/mmap.c +++ b/bsd-user/mmap.c @@ -663,7 +663,6 @@ abi_long target_mmap(abi_ulong start, abi_ulong len, in= t prot, page_dump(stdout); printf("\n"); #endif - tb_invalidate_phys_range(start, start + len); mmap_unlock(); return start; fail: @@ -769,7 +768,6 @@ int target_munmap(abi_ulong start, abi_ulong len) =20 if (ret =3D=3D 0) { page_set_flags(start, start + len, 0); - tb_invalidate_phys_range(start, start + len); } mmap_unlock(); return ret; diff --git a/linux-user/mmap.c b/linux-user/mmap.c index 28f3bc85ed..10f5079331 100644 --- a/linux-user/mmap.c +++ b/linux-user/mmap.c @@ -182,7 +182,6 @@ int target_mprotect(abi_ulong start, abi_ulong len, int= target_prot) } =20 page_set_flags(start, start + len, page_flags); - tb_invalidate_phys_range(start, start + len); ret =3D 0; =20 error: @@ -662,7 +661,6 @@ abi_long target_mmap(abi_ulong start, abi_ulong len, in= t target_prot, qemu_log_unlock(f); } } - tb_invalidate_phys_range(start, start + len); mmap_unlock(); return start; fail: @@ -766,7 +764,6 @@ int target_munmap(abi_ulong start, abi_ulong len) =20 if (ret =3D=3D 0) { page_set_flags(start, start + len, 0); - tb_invalidate_phys_range(start, start + len); } mmap_unlock(); return ret; @@ -856,7 +853,6 @@ abi_long target_mremap(abi_ulong old_addr, abi_ulong ol= d_size, page_set_flags(new_addr, new_addr + new_size, prot | PAGE_VALID | PAGE_RESET); } - tb_invalidate_phys_range(new_addr, new_addr + new_size); mmap_unlock(); return new_addr; } --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751218; cv=none; d=zohomail.com; s=zohoarc; b=ZhRHbvfzQMkNzRo9sXXc2ocgYb02CyRIFSYWmYCVfYYcZL16ds34114s35KPQ2fJDoZax0NqzSFP+AkQ6Gas4Bs2M7HgT5neeeoMJL1FlixR1t7rYc1VchP7bzypLHJ7I/6KoJMgiC06wDxOGUn9JeyHmU58NhFRSJceqnzkff8= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751218; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=9mIARIOtcJM7HMvAJdfElLQQ8Hp1LdQ57Vsk2P28m+M=; b=KoGmv/xHG5dfAiwFVrBaZh30p5vR9VAb1/PCGh+tQJvSJlc/TeCE5GJ5WpsjGt7fWx4wiuo/Ih+MTy4Gk6AC+Wih3npX4oCSSh/m+dB3rG5p74q3NbTpqNdT7qERSSaVNrbgWpDzU5IW7bhFfsdowgVxHawS8fIzkpavlmo4ln8= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751218656324.5364556477788; Tue, 25 Oct 2022 19:26:58 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVu7-0004yq-7C; Tue, 25 Oct 2022 22:12:27 -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 1onVu5-0004yf-QN for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:25 -0400 Received: from mail-pg1-x530.google.com ([2607:f8b0:4864:20::530]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVu4-0001Ed-A3 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:25 -0400 Received: by mail-pg1-x530.google.com with SMTP id 128so13467707pga.1 for ; Tue, 25 Oct 2022 19:12:23 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=9mIARIOtcJM7HMvAJdfElLQQ8Hp1LdQ57Vsk2P28m+M=; b=H6cAnz/rCHSbUukd9WRoUT31/7U9ER9wZTlvIPRxnPOr5vYfb/ItoEit3Vrf31aTdV AIijV28CcbDl+7W14qU1v26+tFlRH7hXEutBqNjMIHrmIP44hS/G8lDk5Z2N60LV+k9m FsKJwpEX5JmoMv7yo4ipqwY4dd9odkd8/M3N0dKXxut9yDGZZ6QiRG8t3Sb3cbiqUh45 2nieP5JmXxXUclnEtypO0iFvCuMCbMxXe/ZzmDJxSD21QVixIa4FrhzaTS/wVEwwykfo yReHTDKYbk+0b+jYmN4aX5oO7FsvciAuLOe4B6xIf42jqBqzY6oJCEUnFcDVD+f0sYGk Tm8Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=9mIARIOtcJM7HMvAJdfElLQQ8Hp1LdQ57Vsk2P28m+M=; b=KN9gyHhq62tnCVAXC2ixgJBz5N704qSNMp/iN27e8vYiJ8Dm56L7MldA4ppKBJrRZ/ JiCc1cTcdo4UNsUTk7+Hzcqb5596h4z5c4NOxbRHAVqMj2Wra4WMxe43gwoQEssM66lp NrLPLb2XNADcwHheHVFlZY8UkisGaZNm7L2h+IImAXMLjyX++SFndku6BmVD+331nI9S 6ctrfQ4kfpjmpz16I9AJW1w3XgWJk8sXrCGWY0k04z3GrgHhrljRdhNPVBg1spUl8fb9 pUe6VBgIvpnE4lBSmRObJixIr/B8tO9DrQ4qdZ8r1+HpHF4GDG1esGviEI5/e6TUQs3o Wixw== X-Gm-Message-State: ACrzQf2KlJfNgNa+a2XfUE4wt0nv2TcIde4pg+8h9tGhNjlsNqw1MlYf jp0xLvOFDVRg/vdqKGCK9w/h/Nd5PIeJdB4R X-Google-Smtp-Source: AMsMyM57uNBM006b137+D4vyMJgBgZ1Wk3b0O64plBiglHXcOF1qwuoJK8KjAfPN7L+50WIBLusbQg== X-Received: by 2002:a05:6a00:2485:b0:561:c0a5:88aa with SMTP id c5-20020a056a00248500b00561c0a588aamr41671510pfv.51.1666750342896; Tue, 25 Oct 2022 19:12:22 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 21/47] accel/tcg: Use page_reset_target_data in page_set_flags Date: Wed, 26 Oct 2022 12:10:50 +1000 Message-Id: <20221026021116.1988449-22-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::530; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x530.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751218866100001 Use the existing function for clearing target data. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/translate-all.c | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 478301f227..41b6d5fe26 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -1370,6 +1370,9 @@ void page_set_flags(target_ulong start, target_ulong = end, int flags) flags |=3D PAGE_WRITE_ORG; } reset =3D !(flags & PAGE_VALID) || (flags & PAGE_RESET); + if (reset) { + page_reset_target_data(start, end); + } flags &=3D ~PAGE_RESET; =20 for (addr =3D start, len =3D end - start; @@ -1387,14 +1390,8 @@ void page_set_flags(target_ulong start, target_ulong= end, int flags) (flags & ~p->flags & PAGE_WRITE))) { tb_invalidate_phys_page(addr); } - if (reset) { - g_free(p->target_data); - p->target_data =3D NULL; - p->flags =3D flags; - } else { - /* Using mprotect on a page does not change sticky bits. */ - p->flags =3D (p->flags & PAGE_STICKY) | flags; - } + /* Using mprotect on a page does not change sticky bits. */ + p->flags =3D (reset ? 0 : p->flags & PAGE_STICKY) | flags; } } =20 --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750430; cv=none; d=zohomail.com; s=zohoarc; b=l1C3l+eWK68zCv+iDRGILy6wRKUxjDNlVZqGQX4QJwvBhVcMqOEiYOCC+bs8NLhiCcWBO5iPsCJrnSG0BmzE7NlYpA+E2td9E5e658j4HDEx2ib1pfZVczkjK/111zc5saTbeYLGgiRGCC7shw065EXX/3tShq7IeixnIBrAyik= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750430; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=tOgmBaXKS/xi9ryJgDE8k+lfxN7FqNvokTcGz2ux3fA=; b=Gx9B07oJX0tFp+S3tBiQYNDNxQUi8PZgzOlS3JRy1W4KeyINujc16XFViV4VO19kxJMsBcWn3Vk1pvVqBDGeUcjIigA7CjrjNCfo3RbCEtL0SURw1Uwty8VSouhohNGeq4eETZbl5iq1TAeaZ5TTJHxzHyIraGmMzhRDPJ2kMwM= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750430492460.2630003026592; Tue, 25 Oct 2022 19:13:50 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVu9-0004zB-Nv; Tue, 25 Oct 2022 22:12:29 -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 1onVu8-0004z3-LQ for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:28 -0400 Received: from mail-pf1-x42e.google.com ([2607:f8b0:4864:20::42e]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVu6-0001Ey-Vq for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:28 -0400 Received: by mail-pf1-x42e.google.com with SMTP id y13so9351049pfp.7 for ; Tue, 25 Oct 2022 19:12:26 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=tOgmBaXKS/xi9ryJgDE8k+lfxN7FqNvokTcGz2ux3fA=; b=e9JYHcnw3UvO/s7NYw2kCNYgIpEwv/ipRVKhAeTy59sfcs6lMADLp/XvueYyG4WKam 99F+e13nOMl8NUtfwsubJcLXuk+IfvBRNN6l0m43YqWF9RTBYOccSRMyOXc8n2KK1PD+ 8R3uYaNF6p41a76nj3w37D1ZCS7fiM4TL2LihfCKzm2ANBX3VJ0khoDJ2Uu2vjMcMpzd 8rXTc1VYwNGx/RwGxjzyZRuQ3sJm9Vr+1aHBo9NHx2aIzSCwtf2m1OfhPkvVKc8p5RUk mwHuTgwYD0QxNRa0SzOXNdDSK+3ZGj1XNymsoUfpmJZrWVn6yi+lQoaVgfYYQA2g99KV 0RzA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=tOgmBaXKS/xi9ryJgDE8k+lfxN7FqNvokTcGz2ux3fA=; b=cz/nuoI2BUrQo8/tnuyEZLxBarmU7q9SEPNfl52cJwkVufeeT9t4lVNMaQycDDLlCO 5QB5qt69zsRn7bDZ2pyi7Oqx1QhZYMwPnq7UehJUeSvZg4QlHKfL82StOc9XDpnKmLni QlNNNQ9PKnoa9tVQ0UlpPX0pLhR93ERSZuQSckEGDz6gfS2j5+hxaMwxcL+aDaGSWa4z Rs0C7ULfulg93gzNMI/Qd7NW6u2dl5E6ixu5MNdRDNJz0PnpWxEyzKdH5r5OEo6YDR7K ps7g3+N85mlWMV5CaFEyXNNVcsvMFum+tO8P2Ki+clEVwSg9YSH+EKqzDkfk/H6oHsgm dEPw== X-Gm-Message-State: ACrzQf16krsiGKdmpRPYGhEIaceVNq6ojAd6bUHreAXeW9dMrVEeTD/0 gjpoFtb2f19mknZHGM3uB+mQXglwApccrlRL X-Google-Smtp-Source: AMsMyM4XnWroeyILf+LXOYFAg68Z0BXf89TQEhPIbE8u1UhW6rLcbpTKvPEPvzBeM49wck9AmCbcHA== X-Received: by 2002:a05:6a00:1781:b0:561:7f7f:dc38 with SMTP id s1-20020a056a00178100b005617f7fdc38mr42255840pfg.42.1666750345440; Tue, 25 Oct 2022 19:12:25 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 22/47] accel/tcg: Use tb_invalidate_phys_range in page_set_flags Date: Wed, 26 Oct 2022 12:10:51 +1000 Message-Id: <20221026021116.1988449-23-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42e; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42e.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750431594100003 Flush translation blocks in bulk, rather than page-by-page. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/translate-all.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 41b6d5fe26..eea24dea96 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -1352,7 +1352,7 @@ int page_get_flags(target_ulong address) void page_set_flags(target_ulong start, target_ulong end, int flags) { target_ulong addr, len; - bool reset; + bool reset, inval_tb =3D false; =20 /* This function should never be called with addresses outside the guest address space. If this assert fires, it probably indicates @@ -1388,11 +1388,15 @@ void page_set_flags(target_ulong start, target_ulon= g end, int flags) && (reset || !(flags & PAGE_EXEC) || (flags & ~p->flags & PAGE_WRITE))) { - tb_invalidate_phys_page(addr); + inval_tb =3D true; } /* Using mprotect on a page does not change sticky bits. */ p->flags =3D (reset ? 0 : p->flags & PAGE_STICKY) | flags; } + + if (inval_tb) { + tb_invalidate_phys_range(start, end); + } } =20 void page_reset_target_data(target_ulong start, target_ulong end) --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750715; cv=none; d=zohomail.com; s=zohoarc; b=nDP8Q2AMLROrafWszTNYNG/d189wUGXSHp4pOfMkTVQd+UMLXcgFjumBZX6soBztCeOLUNSOyhNG7/lwUZsVPPDbT/gSNno/34QysHXHbMrNov0MgkMmjoEvFjhFcjZ+a1lxOyPFwOioJjF1MpWvchBhI526luOGEPSshCQans4= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750715; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=7vkvjsyBKftxlM+MwiEXEaU+OzRW/iKjyp1yuoAXQHA=; b=Zc04wkQRQpY/KbLfactlrLOUaO+J7ajbDfDKXBGcYNNpsKEwZzxaexGRZ6SFpge44Ww3wW8QhDyCOAqc0BGgVHrkvUN7DT7bSQktrInU43F8DtfUsqsSit8XWwo+bfEOH06YXrbYQsfz8LTmG6R27nmU/OMgk88BwuiDDlMcvH0= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750715421588.1709724634686; Tue, 25 Oct 2022 19:18:35 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuD-00050n-7O; Tue, 25 Oct 2022 22:12:33 -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 1onVuB-0004zr-C5 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:31 -0400 Received: from mail-pg1-x52f.google.com ([2607:f8b0:4864:20::52f]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVu9-0001FG-JI for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:31 -0400 Received: by mail-pg1-x52f.google.com with SMTP id h185so13420011pgc.10 for ; Tue, 25 Oct 2022 19:12:29 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=7vkvjsyBKftxlM+MwiEXEaU+OzRW/iKjyp1yuoAXQHA=; b=KxbfJqICJahw+XEAcbJ6wv5tOkXv9OLgrzaTIRB+hNrzlYhCv9s3G/471BxtQAeSaB gcxgErEnuT4ke78j3u+iZUBAx8SIOCGhZW65xDjiUV5/T8u033/KbiL5pQ6jh+SInLSe OWHfLRAkmUWkloy/DXEcyAJM8Y8hnpe1/WsCFQi6NqSebLYm1juBu2jZSquN0PuGjUwX iFyKljJCV2tgXvmKGkqf5+8jvRlaGvg6vtDO1E1iRKtuCd3f91RQkr/j0JExm8NOaZ0E XeSgd4zZc2SGtrFrsla5iJsXs3+AH88FNmpvsMlX+5yDnrqqk+mnZYh/XA0SLwgLXG84 fxHA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=7vkvjsyBKftxlM+MwiEXEaU+OzRW/iKjyp1yuoAXQHA=; b=jHKjL5PAG9Law6MYui/kniB7bGlHaFH54dNh3bT+W3rxPBuk+bLqhFoniCZDh4suMM gkCn+SRKcx7Im3VhdaGsokFTW/mrbHOtHDzSIeH8Q3X7Dk+VkBHvIkOEV0A/MAQPRBkT yqMdCtH/SdvjeNlzDqZ2J1nyOdOsCwvtRbqEDSmVKpUnQr24vqhGnxlzYqW+6dSjbJ59 38hI+3XjUU0lc+Ki3ijZ5a86DiKTV5ZuyADXNy1z0uhV1ERUErctJw59YK3kN/CyE6sT 02k8hjOsiU37z5vhKvHoX3gjiXNeIHYecnrLqmH3FCqx6BZEwwtNBSVaBq54RmzrCMd6 xM2w== X-Gm-Message-State: ACrzQf0VySh3/WHp75DMVIzWNLP48q0mp3AIJouoR/nhUe8VyvvxmYiy id9nV73f/QWGN7pioxPvLuJbC6D8s3KAdlgL X-Google-Smtp-Source: AMsMyM4AAaNBeP0/NCEAUJRNiYcAR68ek+chScJtvWDZnnEurzkJ51qk+7K/PDryyt9VR4IbX1/3Kw== X-Received: by 2002:a05:6a00:e1b:b0:537:7c74:c405 with SMTP id bq27-20020a056a000e1b00b005377c74c405mr41845312pfb.43.1666750348141; Tue, 25 Oct 2022 19:12:28 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 23/47] accel/tcg: Move TARGET_PAGE_DATA_SIZE impl to user-exec.c Date: Wed, 26 Oct 2022 12:10:52 +1000 Message-Id: <20221026021116.1988449-24-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::52f; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x52f.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750717224100007 Since "target data" is always user-only, move it out of translate-all.c to user-exec.c. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- accel/tcg/translate-all.c | 50 --------------------------------------- accel/tcg/user-exec.c | 50 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 50 insertions(+), 50 deletions(-) diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index eea24dea96..433fa247f4 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -1399,56 +1399,6 @@ void page_set_flags(target_ulong start, target_ulong= end, int flags) } } =20 -void page_reset_target_data(target_ulong start, target_ulong end) -{ -#ifdef TARGET_PAGE_DATA_SIZE - target_ulong addr, len; - - /* - * This function should never be called with addresses outside the - * guest address space. If this assert fires, it probably indicates - * a missing call to h2g_valid. - */ - assert(end - 1 <=3D GUEST_ADDR_MAX); - assert(start < end); - assert_memory_lock(); - - start =3D start & TARGET_PAGE_MASK; - end =3D TARGET_PAGE_ALIGN(end); - - for (addr =3D start, len =3D end - start; - len !=3D 0; - len -=3D TARGET_PAGE_SIZE, addr +=3D TARGET_PAGE_SIZE) { - PageDesc *p =3D page_find_alloc(addr >> TARGET_PAGE_BITS, 1); - - g_free(p->target_data); - p->target_data =3D NULL; - } -#endif -} - -#ifdef TARGET_PAGE_DATA_SIZE -void *page_get_target_data(target_ulong address) -{ - PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); - return p ? p->target_data : NULL; -} - -void *page_alloc_target_data(target_ulong address) -{ - PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); - void *ret =3D NULL; - - if (p->flags & PAGE_VALID) { - ret =3D p->target_data; - if (!ret) { - p->target_data =3D ret =3D g_malloc0(TARGET_PAGE_DATA_SIZE); - } - } - return ret; -} -#endif /* TARGET_PAGE_DATA_SIZE */ - int page_check_range(target_ulong start, target_ulong len, int flags) { PageDesc *p; diff --git a/accel/tcg/user-exec.c b/accel/tcg/user-exec.c index 521aa8b61e..927b91900f 100644 --- a/accel/tcg/user-exec.c +++ b/accel/tcg/user-exec.c @@ -210,6 +210,56 @@ tb_page_addr_t get_page_addr_code_hostp(CPUArchState *= env, target_ulong addr, return addr; } =20 +void page_reset_target_data(target_ulong start, target_ulong end) +{ +#ifdef TARGET_PAGE_DATA_SIZE + target_ulong addr, len; + + /* + * This function should never be called with addresses outside the + * guest address space. If this assert fires, it probably indicates + * a missing call to h2g_valid. + */ + assert(end - 1 <=3D GUEST_ADDR_MAX); + assert(start < end); + assert_memory_lock(); + + start =3D start & TARGET_PAGE_MASK; + end =3D TARGET_PAGE_ALIGN(end); + + for (addr =3D start, len =3D end - start; + len !=3D 0; + len -=3D TARGET_PAGE_SIZE, addr +=3D TARGET_PAGE_SIZE) { + PageDesc *p =3D page_find_alloc(addr >> TARGET_PAGE_BITS, 1); + + g_free(p->target_data); + p->target_data =3D NULL; + } +#endif +} + +#ifdef TARGET_PAGE_DATA_SIZE +void *page_get_target_data(target_ulong address) +{ + PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); + return p ? p->target_data : NULL; +} + +void *page_alloc_target_data(target_ulong address) +{ + PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); + void *ret =3D NULL; + + if (p->flags & PAGE_VALID) { + ret =3D p->target_data; + if (!ret) { + p->target_data =3D ret =3D g_malloc0(TARGET_PAGE_DATA_SIZE); + } + } + return ret; +} +#endif + /* The softmmu versions of these helpers are in cputlb.c. */ =20 /* --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750486; cv=none; d=zohomail.com; s=zohoarc; b=j/MfCFGJthw6EA2o5A+3RpwlUL4n1PnbjJH958g6B2hzakCwzxxBJrysuBlmSwWbw9FdunM/GGLPB177v20j0n1X+7/YiYS25wk3wecb12c8l5DmDVvw+GJZJ7ASd+9Xcjvo2m4C2q/+rxzSgOnQL57kUeeGETW97e70nplimiI= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750486; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=Vryp12SHv8mRaikMdMN6WhOo1Wb00PiLQIFS7b2+pVU=; b=F8BbxiOXp0Edoj7P+BPT2o9VFxAF0Gmexcjox2owk7rf1rTc/o0/4ob1ixA6phFsu54Q0t+Mt5RXA8pZURyMzRWMBPlONEyRPcYHzf1YFpjq10tPErGlzYO3+wce5s3R/DaDcaCM5SJzDA9QO5S21vIS98Wal6QxHUZcKMOP0VI= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750486722608.8645238212831; Tue, 25 Oct 2022 19:14:46 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuF-0005Ar-Rq; Tue, 25 Oct 2022 22:12:35 -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 1onVuD-00053l-VB for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:33 -0400 Received: from mail-pg1-x535.google.com ([2607:f8b0:4864:20::535]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuC-0001Fb-6d for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:33 -0400 Received: by mail-pg1-x535.google.com with SMTP id f9so9052640pgj.2 for ; Tue, 25 Oct 2022 19:12:31 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=Vryp12SHv8mRaikMdMN6WhOo1Wb00PiLQIFS7b2+pVU=; b=iZhbpTRCT8I1b9yLHmfCO1uy5szw5kJ/tpiKmd83oDv48V7i5C3tjLeKeI/D2TCKvB mp6NQQ6G9Sb4deLlfXK1WWyV274hyg5Lp/2cuuZybhLPYN9D/evwopcmDKSDt02gjxOW fOTMUO/pGeVirRE0wI/S7vztstEcJyF9A94L15a67Mrs6X/R7PvqKd6ecGcF0fEmAPXh 2DNvI8dn9Sc1E3rhuVFuE6Z8kf6MzC4vc5gSbs2NB5ad5XyR7H2rk0Fz1Mv4bAFS+c+C MSUgsCLr1pqt8ldmKqmTT3CRH6pRV+RkPIZAu47HszT8QDMbXJG7HtjEPiUO0g3yf0YG 7s9A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=Vryp12SHv8mRaikMdMN6WhOo1Wb00PiLQIFS7b2+pVU=; b=JnTx3kwcQbQ1Ao7gcoZVGy3isKqkcvjUEaIyeikjSygx5OEAhVI/UZRrqPexR6wiiS BsP7XV+zMMpw4GnQb6CDGW5pdCM6+Nh3s0xoJKdKUHDshzw6WFkEJGVxFJEB/rERsRrh uVElJOY6ihGL0gGjwCNsZiAtt+qDlqkSo9cetqpPS1rlSa+qbQ4h3p4lmWDVuE+0Rxf3 OR0tTMCKmOMgBauQO/bFv8DyLLwFHhuEO1KdMU7JxM93ipQW5OtbpTddfwWfWvNUoOlj dBLBSeeGNBewk2KIaoeRhQpAnw1dnwvRof6F3idWpzkGamC1Ui88KJfsgM6GZXDWVVXZ Vezw== X-Gm-Message-State: ACrzQf3Vr83DlMSt88OY+KrAQ4crA7ygiAfKxlQWtto+oiqS/Dg+UG6N zETTGEEt3Chxf9VHfTivYPEPZkXjQbOtJvc+ X-Google-Smtp-Source: AMsMyM7f8brYSk/gMwOLPy0dVnpdbR5+SsEwF3812BkuEhazBv54ECie5/yDGYq7wUr3V/wGEQoW4w== X-Received: by 2002:a63:2b48:0:b0:434:eb45:9c6a with SMTP id r69-20020a632b48000000b00434eb459c6amr34521876pgr.508.1666750350808; Tue, 25 Oct 2022 19:12:30 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Alex=20Benn=C3=A9e?= Subject: [PULL 24/47] accel/tcg: Simplify page_get/alloc_target_data Date: Wed, 26 Oct 2022 12:10:53 +1000 Message-Id: <20221026021116.1988449-25-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::535; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x535.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750487716100001 Since the only user, Arm MTE, always requires allocation, merge the get and alloc functions to always produce a non-null result. Also assume that the user has already checked page validity. Reviewed-by: Alex Benn=C3=A9e Signed-off-by: Richard Henderson --- include/exec/cpu-all.h | 21 ++++++--------------- accel/tcg/user-exec.c | 16 ++++------------ target/arm/mte_helper.c | 4 ---- 3 files changed, 10 insertions(+), 31 deletions(-) diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h index 854adc4ac2..2eb1176538 100644 --- a/include/exec/cpu-all.h +++ b/include/exec/cpu-all.h @@ -281,27 +281,18 @@ void page_reset_target_data(target_ulong start, targe= t_ulong end); int page_check_range(target_ulong start, target_ulong len, int flags); =20 /** - * page_alloc_target_data(address) + * page_get_target_data(address) * @address: guest virtual address * - * Allocate TARGET_PAGE_DATA_SIZE bytes of out-of-band data to associate - * with the guest page at @address. If the page is not mapped, NULL will - * be returned. If there is existing data associated with @address, - * no new memory will be allocated. + * Return TARGET_PAGE_DATA_SIZE bytes of out-of-band data to associate + * with the guest page at @address, allocating it if necessary. The + * caller should already have verified that the address is valid. * * The memory will be freed when the guest page is deallocated, * e.g. with the munmap system call. */ -void *page_alloc_target_data(target_ulong address); - -/** - * page_get_target_data(address) - * @address: guest virtual address - * - * Return any out-of-bound memory assocated with the guest page - * at @address, as per page_alloc_target_data. - */ -void *page_get_target_data(target_ulong address); +void *page_get_target_data(target_ulong address) + __attribute__((returns_nonnull)); #endif =20 CPUArchState *cpu_copy(CPUArchState *env); diff --git a/accel/tcg/user-exec.c b/accel/tcg/user-exec.c index 927b91900f..fb7d6ee9e9 100644 --- a/accel/tcg/user-exec.c +++ b/accel/tcg/user-exec.c @@ -242,19 +242,11 @@ void page_reset_target_data(target_ulong start, targe= t_ulong end) void *page_get_target_data(target_ulong address) { PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); - return p ? p->target_data : NULL; -} + void *ret =3D p->target_data; =20 -void *page_alloc_target_data(target_ulong address) -{ - PageDesc *p =3D page_find(address >> TARGET_PAGE_BITS); - void *ret =3D NULL; - - if (p->flags & PAGE_VALID) { - ret =3D p->target_data; - if (!ret) { - p->target_data =3D ret =3D g_malloc0(TARGET_PAGE_DATA_SIZE); - } + if (!ret) { + ret =3D g_malloc0(TARGET_PAGE_DATA_SIZE); + p->target_data =3D ret; } return ret; } diff --git a/target/arm/mte_helper.c b/target/arm/mte_helper.c index a9c5fc2cb2..86b3754838 100644 --- a/target/arm/mte_helper.c +++ b/target/arm/mte_helper.c @@ -95,10 +95,6 @@ static uint8_t *allocation_tag_mem(CPUARMState *env, int= ptr_mmu_idx, } =20 tags =3D page_get_target_data(clean_ptr); - if (tags =3D=3D NULL) { - tags =3D page_alloc_target_data(clean_ptr); - assert(tags !=3D NULL); - } =20 index =3D extract32(ptr, LOG2_TAG_GRANULE + 1, TARGET_PAGE_BITS - LOG2_TAG_GRANULE - 1); --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751093; cv=none; d=zohomail.com; s=zohoarc; b=ms1obXxqoxqc2KTAidPU/+QvYr2dWIvIZM5cgZq2ThTKqhnlF474uJde9Sh1j1jyciDoaTWrIALcLF+WOkuAuLKM4Br9CDzqBEPAeNTIFaTOtokVeDmZo/DcS+N0/5ogJCUIXewQhrjhISvEyTb/g9wh60p7Xq6fUTK3/3LFglc= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751093; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=Ov3aeYf9Oo0htgsB4UrYWgNfrt2xvA4eqzI8BqeKPbs=; b=EhYxzKxOkS/MvF/G6WqnqVD/tb6YCrAEeKGNRpGO4KTKY13Rm8lbGbqLOiNZZRuBOC/dR8bi3UAVoGRQKthNN3CPVNSFL4c+51uJVZyy4G6e9mrzzjr2j0P9Fy4kqQ43BsnUyZg7/xm7ez1zRUKQ0XtQtsnz42mPNyQVl6f9C8M= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751093612457.0596308015222; Tue, 25 Oct 2022 19:24:53 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuH-0005H5-Mc; Tue, 25 Oct 2022 22:12:37 -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 1onVuG-0005Bp-1T for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:36 -0400 Received: from mail-pg1-x531.google.com ([2607:f8b0:4864:20::531]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuE-00019J-8i for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:35 -0400 Received: by mail-pg1-x531.google.com with SMTP id 20so13457922pgc.5 for ; Tue, 25 Oct 2022 19:12:33 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.31 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=Ov3aeYf9Oo0htgsB4UrYWgNfrt2xvA4eqzI8BqeKPbs=; b=pLnUxxiO+GAbNyYkn/vCTvFwd3giqz1rQ1ZKx0C9rb0hZE/pWu3cIgUSoSMFrTMyyj velu/smSxVo6Pb8P08nF1pJkRVk/Rmo7ArBweIJ732N0z4uL3frypgi9XE+jpWH9l6Rx GpaFOHn2ct3TediaFUb/iGtePhcaLwUHwoY919VUTfvXefpd1tYg7b3cT4j3Wq5yxEzH Od6w5AWkoArJwJwoKsjzE8rGdnSmP6Fke/j2jwlMt14duAJlyjRyFx5qOrlX0fjbwnXp BpZVzE/HoybdOxKABjAJlS3KDldWUAqyYhGzstMf9E8MsO6IKAaSoqA/5zjFS5n9nLOf V8Fg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=Ov3aeYf9Oo0htgsB4UrYWgNfrt2xvA4eqzI8BqeKPbs=; b=b6stdoiVFBLa6jNgNfiNyS4mp1ttfrKWk082S8IJGlzfezyNmWVslzM0LXs86aS/d/ 44M71Cm46x/MapyjC2Ce03Sl6Yiv5uBNlF7BGBFakbQQldMBFLJk9Hn0Zg6uQAILBtJ1 eNdRYbmzzC7ploenMJ4N0YSJQICGyaeAI3QhZb08k2IjqrCIV1YQrV1QZE3duNoSsrZ+ QhtBWAOWTqwx0SwlsZfZHAY6YrlMinpTD+xD2uajrX0ZVNMBEeGuZNO0TRpjrXlL93MR 8hq0jg4au5meOMh0qsoz386BauVfWTtsfHAjrTXax8gcjWVb2bdwcYWUJafV/9OU9yhX s46w== X-Gm-Message-State: ACrzQf2ZqilUb9ZIfmHl64D8XJOFax/I3mHmkpm4vvepaP+ZoC76e1wG LDyyq4VLraCcN44wXi3B37ncSaBF+JQfud/j X-Google-Smtp-Source: AMsMyM6Tp1n/MD9nWtMUIrFxb0dCCjYE3pXn3O4dKzfpr8xZrfl1Endy6SUSFpZ1qEE75XRBYURBvg== X-Received: by 2002:a05:6a00:27a1:b0:566:8937:27c2 with SMTP id bd33-20020a056a0027a100b00566893727c2mr40959692pfb.24.1666750353465; Tue, 25 Oct 2022 19:12:33 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Claudio Fontana Subject: [PULL 25/47] accel/tcg: Add restore_state_to_opc to TCGCPUOps Date: Wed, 26 Oct 2022 12:10:54 +1000 Message-Id: <20221026021116.1988449-26-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> 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=2607:f8b0:4864:20::531; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x531.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751095288100005 Content-Type: text/plain; charset="utf-8" Add a tcg_ops hook to replace the restore_state_to_opc function call. Because these generic hooks cannot depend on target-specific types, temporarily, copy the current target_ulong data[] into uint64_t d64[]. Reviewed-by: Claudio Fontana Signed-off-by: Richard Henderson --- include/exec/exec-all.h | 2 +- include/hw/core/tcg-cpu-ops.h | 11 +++++++++++ accel/tcg/translate-all.c | 24 ++++++++++++++++++++++-- 3 files changed, 34 insertions(+), 3 deletions(-) diff --git a/include/exec/exec-all.h b/include/exec/exec-all.h index 5ae484e34d..3b5e84240b 100644 --- a/include/exec/exec-all.h +++ b/include/exec/exec-all.h @@ -40,7 +40,7 @@ typedef ram_addr_t tb_page_addr_t; #endif =20 void restore_state_to_opc(CPUArchState *env, TranslationBlock *tb, - target_ulong *data); + target_ulong *data) __attribute__((weak)); =20 /** * cpu_restore_state: diff --git a/include/hw/core/tcg-cpu-ops.h b/include/hw/core/tcg-cpu-ops.h index 78c6c6635d..20e3c0ffbb 100644 --- a/include/hw/core/tcg-cpu-ops.h +++ b/include/hw/core/tcg-cpu-ops.h @@ -31,6 +31,17 @@ struct TCGCPUOps { * function to restore all the state, and register it here. */ void (*synchronize_from_tb)(CPUState *cpu, const TranslationBlock *tb); + /** + * @restore_state_to_opc: Synchronize state from INDEX_op_start_insn + * + * This is called when we unwind state in the middle of a TB, + * usually before raising an exception. Set all part of the CPU + * state which are tracked insn-by-insn in the target-specific + * arguments to start_insn, passed as @data. + */ + void (*restore_state_to_opc)(CPUState *cpu, const TranslationBlock *tb, + const uint64_t *data); + /** @cpu_exec_enter: Callback for cpu_exec preparation */ void (*cpu_exec_enter)(CPUState *cpu); /** @cpu_exec_exit: Callback for cpu_exec cleanup */ diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 433fa247f4..4d8783efc7 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -256,7 +256,6 @@ int cpu_restore_state_from_tb(CPUState *cpu, Translatio= nBlock *tb, { target_ulong data[TARGET_INSN_START_WORDS]; uintptr_t host_pc =3D (uintptr_t)tb->tc.ptr; - CPUArchState *env =3D cpu->env_ptr; const uint8_t *p =3D tb->tc.ptr + tb->tc.size; int i, j, num_insns =3D tb->icount; #ifdef CONFIG_PROFILER @@ -295,7 +294,20 @@ int cpu_restore_state_from_tb(CPUState *cpu, Translati= onBlock *tb, and shift if to the number of actually executed instructions */ cpu_neg(cpu)->icount_decr.u16.low +=3D num_insns - i; } - restore_state_to_opc(env, tb, data); + + { + const struct TCGCPUOps *ops =3D cpu->cc->tcg_ops; + __typeof(ops->restore_state_to_opc) restore =3D ops->restore_state= _to_opc; + if (restore) { + uint64_t d64[TARGET_INSN_START_WORDS]; + for (i =3D 0; i < TARGET_INSN_START_WORDS; ++i) { + d64[i] =3D data[i]; + } + restore(cpu, tb, d64); + } else { + restore_state_to_opc(cpu->env_ptr, tb, data); + } + } =20 #ifdef CONFIG_PROFILER qatomic_set(&prof->restore_time, @@ -307,6 +319,14 @@ int cpu_restore_state_from_tb(CPUState *cpu, Translati= onBlock *tb, =20 bool cpu_restore_state(CPUState *cpu, uintptr_t host_pc, bool will_exit) { + /* + * The pc update associated with restore without exit will + * break the relative pc adjustments performed by TARGET_TB_PCREL. + */ + if (TARGET_TB_PCREL) { + assert(will_exit); + } + /* * The host_pc has to be in the rx region of the code buffer. * If it is not we will not be able to resolve it here. --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751422; cv=none; d=zohomail.com; s=zohoarc; b=lCaBMk38WdHp7sZcXbOVQxgaza28wi7OQrot0/GCRQZfZeaoFn3F5mHBpN5COdjcQGYCm+7mFhJfoCs+9xVBhZnX120ARJjvnOqVCCaNPz4t93NjqYu43y7qjVHQDn+JJv5K6YaCzWSv/SePMOjxqJMvR9hW2bsg1m83y6cg+GY= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751422; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=9G9r4XqZ5tNsPMB9JL7bV/JWLZpybHX4NvIu3/hknWg=; b=G1OlR6zxNkDAP/TPBpm3pdsYnCpmKnAlzeCmOPAjmHxSD1FXG4cBC6IpRlkCkndl23dG0Aq8DA8TNlnCUy8sLHTL7zIE09aK2SACSMZoUu8sFOf5urFWn/M9xbPbEfYiUKoKZ+gI6xE3L7hLe5TMElJEX1BEmtfDh9OGB25Gi6Q= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751422555254.56842570920696; Tue, 25 Oct 2022 19:30:22 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuK-0005Hr-AX; Tue, 25 Oct 2022 22:12:40 -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 1onVuI-0005HU-Sp for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:38 -0400 Received: from mail-pf1-x430.google.com ([2607:f8b0:4864:20::430]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuH-0001GB-Bb for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:38 -0400 Received: by mail-pf1-x430.google.com with SMTP id 130so3550585pfu.8 for ; Tue, 25 Oct 2022 19:12:36 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=9G9r4XqZ5tNsPMB9JL7bV/JWLZpybHX4NvIu3/hknWg=; b=w+a96H81tBHhEiDAbMQTiJnk1lzxsYJ1KWfiMUKQvcaALxrineBCUjBItCqR9b/Xhh JbgDj3KFnZFUyiNF5RZEvMoeztDdIal9/RWsOgzUjERaBDWIARM7x3bsddnOx90UYqul 3TElrdZk/dfGHibZX64xJw8SP/87M3EGwhHVAuPwr5IRQTZeXVi/7ffjmlrvfzOUsWQ0 PfW+DqPiTzNtRpiwR5ueP5GGJXmHRSuAMegFEXVtLT/pu8SwxAfrQIFHZqDMifogXSvs JE9edR6/1a9Xlm+LT2bA4OG/jMDdIvqO3ut+GJtY6ympneIQCVbwm8cabQ6cyN0wTZeK /duw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=9G9r4XqZ5tNsPMB9JL7bV/JWLZpybHX4NvIu3/hknWg=; b=u8GzpuAYr3ddUIF5gR6Tx+euUtrwEAkzP8nhn/Tv4y2vhhNMw3rhJ7o3xTx+r6u3/e Sj7haQJKqIZFmOfNxnFx9RAuwXfqyjB8pljE320rAxPsAhyS+hb97UX80K26bh0QEUtv musFE1mUokpjdELSaWXnSSRIN0H9MRPzGBQ2Qaqr1F3b2eKtJ1gWJrvSW/mG8cZHYGpv 4LvkjwtkwjKl16Yvy1+QReaKny1IqpLGtK6JzzePF/9/IERVNEITdwaaSnjRLrOsh31t UymeJaIUIq3e8S7e1EvOO28m9dQVGgienpRsZeEnHdZp613FHAmterH807yaqnHAXAh2 WutA== X-Gm-Message-State: ACrzQf34vH8KofKI9HpS2Ow1E9mQWFPNvkQVmfBcPBakvFEzmiNZVW4A GolHQE9hiI3hw85yfbZ9/dzfSkYFnRqmpfqz X-Google-Smtp-Source: AMsMyM5yPEzILBAlCRYaGrdw+mEFmm2+7eXGtWhMIWuy3UNHZag2mbebz4u47+Wk3smyqqiTjZLUmA== X-Received: by 2002:a05:6a00:1349:b0:563:654d:ce3f with SMTP id k9-20020a056a00134900b00563654dce3fmr41965931pfu.32.1666750356101; Tue, 25 Oct 2022 19:12:36 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 26/47] target/alpha: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:10:55 +1000 Message-Id: <20221026021116.1988449-27-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::430; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x430.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751423811100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/alpha/cpu.c | 9 +++++++++ target/alpha/translate.c | 6 ------ 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/target/alpha/cpu.c b/target/alpha/cpu.c index 979a629d59..270ae787b1 100644 --- a/target/alpha/cpu.c +++ b/target/alpha/cpu.c @@ -40,6 +40,14 @@ static vaddr alpha_cpu_get_pc(CPUState *cs) return cpu->env.pc; } =20 +static void alpha_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + AlphaCPU *cpu =3D ALPHA_CPU(cs); + + cpu->env.pc =3D data[0]; +} =20 static bool alpha_cpu_has_work(CPUState *cs) { @@ -226,6 +234,7 @@ static const struct SysemuCPUOps alpha_sysemu_ops =3D { =20 static const struct TCGCPUOps alpha_tcg_ops =3D { .initialize =3D alpha_translate_init, + .restore_state_to_opc =3D alpha_restore_state_to_opc, =20 #ifdef CONFIG_USER_ONLY .record_sigsegv =3D alpha_cpu_record_sigsegv, diff --git a/target/alpha/translate.c b/target/alpha/translate.c index 6766350f56..f9bcdeb717 100644 --- a/target/alpha/translate.c +++ b/target/alpha/translate.c @@ -3049,9 +3049,3 @@ void gen_intermediate_code(CPUState *cpu, Translation= Block *tb, int max_insns, DisasContext dc; translator_loop(cpu, tb, max_insns, pc, host_pc, &alpha_tr_ops, &dc.ba= se); } - -void restore_state_to_opc(CPUAlphaState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750775; cv=none; d=zohomail.com; s=zohoarc; b=hwmkYVBOLFtA5t8VgsdNYs2vzEMbLo9ZhDw8hItOHy1VdJ38MuvrdcJY29iLT+2nv8Jgppt66zACAzYEungdgJjRNsi1+NjmagJH/PcW3g7ohdBsopzhc6cT8PbsDcRxHRKYZCOqPBrPhZ0XErBZnqzA6K5WSfKqZG3kApoZ+NE= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750775; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=MTYhZzWqH75b7i9XrWtJz4ZdUurs/QeXSrqfR/Rb3bI=; b=TVxERleRHeslnO5TqXylcEAdjCm7QnLwq82m7k4Q35WD6cINix5e1kNzHuexpUn9rCqiZ/ORxe5/dPwRMhvAMgSlI14YOhJh7GeFfUG8rBeU88fFGKcsazjsf7FiuSBxGfXZ59+ZgoZtkOBZprRd7rF5AuG6m2U5ubUkQCcuWp4= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 166675077579356.04005627647746; Tue, 25 Oct 2022 19:19:35 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuN-0005Ig-SD; Tue, 25 Oct 2022 22:12:43 -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 1onVuM-0005IC-5d for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:42 -0400 Received: from mail-pl1-x634.google.com ([2607:f8b0:4864:20::634]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuK-0001GX-5H for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:41 -0400 Received: by mail-pl1-x634.google.com with SMTP id j12so12691537plj.5 for ; Tue, 25 Oct 2022 19:12:39 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=MTYhZzWqH75b7i9XrWtJz4ZdUurs/QeXSrqfR/Rb3bI=; b=x57iF97JFvN3DSTb0St8pnhXCIkcaaYcobsabfcMAX+V6/JooA78tvAiEZPja8M9ws gPlZnXNpVXJZ3MMSZTf8oxH1p9mTE1e1Tp1581atlYu1kZw84i3XDsH7bUJRLRkHiMBj cbB/dFxuHq6u6S6X7S/yGVBMrbxneDMK+/hf7M3rk0vyb8HO5vFRX3FgIgaHlhYfQO0b 8To5uQiykNbXEnpbj7lqPPkUQ4ihqqxiGzP0jxLdvH+yOJsG/Cg9T9X4Fl0GjPda+GTa WqqXL7mM0VQohgh6A2XQcSuAXGKaEO9cc/xJwBA1dnbFccJct+DXOlqgtpEKUCtlpnGl oS0A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=MTYhZzWqH75b7i9XrWtJz4ZdUurs/QeXSrqfR/Rb3bI=; b=Xs65re/Xe2Ea92wdYz4LZgA23tMYA8gE2lgx6W2z4CrR3X3reshYwc+Ukjdh6FMnZk lAnrpqMR4+1FtdqWK+fGHS9xovP1tbMZ/JhvvULyWuCxsMRqHimfgHGERqVQTLYnLafZ ZSUJQNvJ6kRbvt/2xmljBG3fTq72RHs4Oo3xnC5o6v/jqIYZTeeDDBH8p3762t52Z7aE 4U0eBhh8QmcLIxqM9//3oL/P6IitUs9c4n6oYcflWUovbwAPxF6bOSs/KUREGzuQ7Ur+ 8lQcj11cO+BIH005Y8Zdte7GO/bw1cCpdQiAE+5EuqyM3E5ognD0IeKXPY8ZtFErEwRq VdhQ== X-Gm-Message-State: ACrzQf2/eW5zbx0noCPM6Awd4BoHtxnBPnNcfEATBir8LOj2h4xOI6uR mk5VUeoQDfcNZ6sD2h3yWpXLRlPwnmN3QQUM X-Google-Smtp-Source: AMsMyM7vRkpzQPrOtTnajfUXoD8Gxa20fqtitJHx02ftMtrAuyIpeNY5kTwew7RK13XWorJZ8kQQOw== X-Received: by 2002:a17:902:edcd:b0:17a:6fa:228d with SMTP id q13-20020a170902edcd00b0017a06fa228dmr41411096plk.29.1666750358751; Tue, 25 Oct 2022 19:12:38 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 27/47] target/arm: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:10:56 +1000 Message-Id: <20221026021116.1988449-28-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::634; envelope-from=richard.henderson@linaro.org; helo=mail-pl1-x634.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750777629100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/arm/cpu.c | 26 ++++++++++++++++++++++++++ target/arm/translate.c | 22 ---------------------- 2 files changed, 26 insertions(+), 22 deletions(-) diff --git a/target/arm/cpu.c b/target/arm/cpu.c index 0bc5e9b125..0a7bfbf999 100644 --- a/target/arm/cpu.c +++ b/target/arm/cpu.c @@ -90,6 +90,31 @@ void arm_cpu_synchronize_from_tb(CPUState *cs, } } } + +static void arm_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + CPUARMState *env =3D cs->env_ptr; + + if (is_a64(env)) { + if (TARGET_TB_PCREL) { + env->pc =3D (env->pc & TARGET_PAGE_MASK) | data[0]; + } else { + env->pc =3D data[0]; + } + env->condexec_bits =3D 0; + env->exception.syndrome =3D data[2] << ARM_INSN_START_WORD2_SHIFT; + } else { + if (TARGET_TB_PCREL) { + env->regs[15] =3D (env->regs[15] & TARGET_PAGE_MASK) | data[0]; + } else { + env->regs[15] =3D data[0]; + } + env->condexec_bits =3D data[1]; + env->exception.syndrome =3D data[2] << ARM_INSN_START_WORD2_SHIFT; + } +} #endif /* CONFIG_TCG */ =20 static bool arm_cpu_has_work(CPUState *cs) @@ -2152,6 +2177,7 @@ static const struct TCGCPUOps arm_tcg_ops =3D { .initialize =3D arm_translate_init, .synchronize_from_tb =3D arm_cpu_synchronize_from_tb, .debug_excp_handler =3D arm_debug_excp_handler, + .restore_state_to_opc =3D arm_restore_state_to_opc, =20 #ifdef CONFIG_USER_ONLY .record_sigsegv =3D arm_cpu_record_sigsegv, diff --git a/target/arm/translate.c b/target/arm/translate.c index d1b868430e..74a903072f 100644 --- a/target/arm/translate.c +++ b/target/arm/translate.c @@ -9939,25 +9939,3 @@ void gen_intermediate_code(CPUState *cpu, Translatio= nBlock *tb, int max_insns, =20 translator_loop(cpu, tb, max_insns, pc, host_pc, ops, &dc.base); } - -void restore_state_to_opc(CPUARMState *env, TranslationBlock *tb, - target_ulong *data) -{ - if (is_a64(env)) { - if (TARGET_TB_PCREL) { - env->pc =3D (env->pc & TARGET_PAGE_MASK) | data[0]; - } else { - env->pc =3D data[0]; - } - env->condexec_bits =3D 0; - env->exception.syndrome =3D data[2] << ARM_INSN_START_WORD2_SHIFT; - } else { - if (TARGET_TB_PCREL) { - env->regs[15] =3D (env->regs[15] & TARGET_PAGE_MASK) | data[0]; - } else { - env->regs[15] =3D data[0]; - } - env->condexec_bits =3D data[1]; - env->exception.syndrome =3D data[2] << ARM_INSN_START_WORD2_SHIFT; - } -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751322; cv=none; d=zohomail.com; s=zohoarc; b=TgVPInJFhXOPyVNlvLL/LV4klH58VN7vSFnwPkoSRyhjyyoQNLfpd27myHG2hKclkuGfIHUhTAcrslnvb7QReYZmQbrC5flR3IdwTNHL2QiRf8ilujeINU/1BTNkBg+jxKDaB9x2b4CmoVqKw89kOHfBU0kTZy2+3WpwqKFCuVQ= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751322; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=SFr4v+s6ucu43YIiJCOufRZNSesp06+hT97e7RgzJng=; b=SeSqxK/jYMBN6bSQe4F4he95vUixVs1G46AWkQPoxzuJpFhQ6AlibbKZMGNiTrpMXiNLvoBQo71ARCOQbdayeCRHK4P39rEsrdWeqHHWuZGsMZE5PCONR7SX81ZYxxYzLGBm67WMHR87DtlbD3r2RiLfsO1GpCi5sefrUSFNh5Y= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751322079919.047814545399; Tue, 25 Oct 2022 19:28:42 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuP-0005Ix-Fs; Tue, 25 Oct 2022 22:12:45 -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 1onVuO-0005Ii-0O for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:44 -0400 Received: from mail-pg1-x535.google.com ([2607:f8b0:4864:20::535]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuM-0001Fb-Ee for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:43 -0400 Received: by mail-pg1-x535.google.com with SMTP id f9so9052971pgj.2 for ; Tue, 25 Oct 2022 19:12:41 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=SFr4v+s6ucu43YIiJCOufRZNSesp06+hT97e7RgzJng=; b=yu3Fw/YS5x0hqSs3fdpcnRgvvb6zmyORqY+Y1EbOVP+etgQOsGD0HYdDMddk1PK8Qo qfIUNMLC4UmRIPLd9G0xh0qoKssTMwUaxxJLOqdYeUiiQfOGlv+T+6b7SJ1jqa1lFEng +A/mChY+XtqGOklg46Pp90JpLQAnhGiKecHYWze5gJ29+1OFJ+blbtHxSpx0900Fpmqz 0JzMe31Zvke/P6MdjkMokc4DeAvY+qof3ia8BasRnSFpoheleLcewtrayb+JR7M6MDBt h/BBWovguc6LwA2z6LUMosUY0c2vtDCMXKFCRorqJNJi3+MlXVbJhQ/MIfWSvHGNj1RE bsGA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=SFr4v+s6ucu43YIiJCOufRZNSesp06+hT97e7RgzJng=; b=HlpOg1OH+WMy8o5eFM+4XlNLapqBkk9XitK3lZUTP24mKNhBFSraU0Rs7l7DpWmmBA FdYcvctM2ePUOFTxqxL6SL2vlVpCUdd8JhgUoNURFDEAbngJhp+YeERf+RWdaIta6UUB YdoBvy14RR32Rp8afic8GvnL0/TDESX6akJVA5SisZUML7th6ayCrjIpbcOdwb6RRS/V mVqRUA3TfdW5/8VCT2T/JFOO+TNzta0d18jxrP+F66LwDPWC03tvvelP+CBlXbOah5fT wTjwcH48opbBRBV7ChVbfiHUJ4Ba3BaPvnPf/nF7o5cwhray5JRX7261fEqLl0kwOvCs chuQ== X-Gm-Message-State: ACrzQf2v6oaVr9c+W0+7zShYSCMdF131fawhjMrsSsrcMoNRCf7WnAwB SzsHTCrMGjJMJKjZ7s+vlYPoElJsCFVBofr0 X-Google-Smtp-Source: AMsMyM4dcGIC2tqeiwNXTbst9B21C5Iqv6jCOktVq7t/dlJUm3vZ6bX0AJZzeeBBdyXFdMUYnB2jnQ== X-Received: by 2002:a63:81c8:0:b0:462:953a:8534 with SMTP id t191-20020a6381c8000000b00462953a8534mr34637735pgd.69.1666750361592; Tue, 25 Oct 2022 19:12:41 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 28/47] target/avr: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:10:57 +1000 Message-Id: <20221026021116.1988449-29-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::535; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x535.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751323579100003 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/avr/cpu.c | 11 +++++++++++ target/avr/translate.c | 6 ------ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/target/avr/cpu.c b/target/avr/cpu.c index 0d2861179d..c7295b488d 100644 --- a/target/avr/cpu.c +++ b/target/avr/cpu.c @@ -57,6 +57,16 @@ static void avr_cpu_synchronize_from_tb(CPUState *cs, env->pc_w =3D tb_pc(tb) / 2; /* internally PC points to words */ } =20 +static void avr_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + AVRCPU *cpu =3D AVR_CPU(cs); + CPUAVRState *env =3D &cpu->env; + + env->pc_w =3D data[0]; +} + static void avr_cpu_reset(DeviceState *ds) { CPUState *cs =3D CPU(ds); @@ -202,6 +212,7 @@ static const struct SysemuCPUOps avr_sysemu_ops =3D { static const struct TCGCPUOps avr_tcg_ops =3D { .initialize =3D avr_cpu_tcg_init, .synchronize_from_tb =3D avr_cpu_synchronize_from_tb, + .restore_state_to_opc =3D avr_restore_state_to_opc, .cpu_exec_interrupt =3D avr_cpu_exec_interrupt, .tlb_fill =3D avr_cpu_tlb_fill, .do_interrupt =3D avr_cpu_do_interrupt, diff --git a/target/avr/translate.c b/target/avr/translate.c index e65b6008c0..2bed56f135 100644 --- a/target/avr/translate.c +++ b/target/avr/translate.c @@ -3055,9 +3055,3 @@ void gen_intermediate_code(CPUState *cs, TranslationB= lock *tb, int max_insns, DisasContext dc =3D { }; translator_loop(cs, tb, max_insns, pc, host_pc, &avr_tr_ops, &dc.base); } - -void restore_state_to_opc(CPUAVRState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc_w =3D data[0]; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750715; cv=none; d=zohomail.com; s=zohoarc; b=LeM6Erb6aEFctna31niP4RE1K2bofAgM3lbkydT+6MK2KATXzqZYTLmOjzLb8R89af/Lplt8SgkR7O1jyA1mBZFPnSZbgN0bRjeWHUS1gni6IgPPuPVgCcLLbKI1LFi4r5KKa40ZLi690cDTNdZUbRpbJnlk2XoiEv9jpj7Lm/c= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750715; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=4pnG9nOOACtBusrxYRYQuNOIosZyxdgNQde/unc31MM=; b=XIqECZ18vxioni0p/475qCNgmo+YE16BeQSWlsvSbZtvpHiN71nyj3XaOt6noOZOdtoLM30qz74GS8MrpmMFOOtgvFUV8P+61hOsTLaSkbMfBcOnY6TOFWG563z8YKuB0jKT0WJvfxRAJCV8uak+fZs5ureu2xK3Qay/x9+sorE= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750715263150.19897321880342; Tue, 25 Oct 2022 19:18:35 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuT-0005Jb-1E; Tue, 25 Oct 2022 22:12:49 -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 1onVuR-0005JJ-Ca for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:47 -0400 Received: from mail-pf1-x42f.google.com ([2607:f8b0:4864:20::42f]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuP-0001H5-OD for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:47 -0400 Received: by mail-pf1-x42f.google.com with SMTP id b29so9472464pfp.13 for ; Tue, 25 Oct 2022 19:12:45 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.41 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=4pnG9nOOACtBusrxYRYQuNOIosZyxdgNQde/unc31MM=; b=brrLRU6SxVkIXxiMhygDlEsebZ26z5l0UDjLL8oKrsqmJVQA61YjQ4v85bj+YoGOh2 NlFVp2XdvmFk9ZDivGQBx46ocNeFvGR92rjW2inUdOl0WpxoFRcBiKYcIXUmS/h68Nlx lNuGTuwHFDEJAJ8mFd4eejuPKE1WgHs9R90lXWeuWjjIx3cL04Zc7qzyBk1ltM7CIsbn kf/a1qcK5A3wlHroZVXapnRftjT7RBxF5VJXQk8MLKR7oiXLk8JZoSs/N6DFgnwaerrF r+wJP2pFf04E6hxZ5ZxF0Y3NjpdCdD4JYpys65JHXPZXr/NuDWyYPoR35uIuzqUp2wiV 8icg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=4pnG9nOOACtBusrxYRYQuNOIosZyxdgNQde/unc31MM=; b=gqYXPmjspUUGFGdrnK9ZzI5PkEiMduSlKYwJQUOzuQ2p18Qjou0akWMgujUwAMqOt6 wRgpWvfXfJWjwyn+dHOJljlUiqxRH6eJuu/pSYpZJA07KmEBqrMWEUQ95CBJRf3ksuaL Ll/qlLC9Alp99+8DZuNRy9qAHD4K5YtryJNw+9c0f4IFmAwXvUMuHP4tEFkhRNA/shpJ rEVV2V8paZT4LRq/TlrIpj4Q13KBvG8wH1m6cWP5SBSyq4lEXqb069yJDBTlErpt/R74 u1JXDpwCL2wf40IL//943Q5pm+/oJGnGpBR7m3mVz1F0vTAw5TbfBbzvt1TdJjdFDeTg Ie2Q== X-Gm-Message-State: ACrzQf1smYIFUgQdR6kXZAfxoezcyJNgmnrGkZV3oTnFmI7Orf0st4XI fwm4IIA0N2olf+CLZdaqxjiZuDFYXqSY6ssF X-Google-Smtp-Source: AMsMyM6Br16z3++YfR6wL12kQMxxI9SSH3dAOxbwuC6hxjrBdmICfkHcNVAAc+bgy9l62j/LJtfE+w== X-Received: by 2002:a65:6849:0:b0:461:8779:2452 with SMTP id q9-20020a656849000000b0046187792452mr34181323pgt.383.1666750364356; Tue, 25 Oct 2022 19:12:44 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 29/47] target/cris: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:10:58 +1000 Message-Id: <20221026021116.1988449-30-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42f; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42f.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750717179100005 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/cris/cpu.c | 11 +++++++++++ target/cris/translate.c | 6 ------ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/target/cris/cpu.c b/target/cris/cpu.c index 22f5c70f39..fb05dc6f9a 100644 --- a/target/cris/cpu.c +++ b/target/cris/cpu.c @@ -42,6 +42,15 @@ static vaddr cris_cpu_get_pc(CPUState *cs) return cpu->env.pc; } =20 +static void cris_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + CRISCPU *cpu =3D CRIS_CPU(cs); + + cpu->env.pc =3D data[0]; +} + static bool cris_cpu_has_work(CPUState *cs) { return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI= ); @@ -212,6 +221,7 @@ static const struct SysemuCPUOps cris_sysemu_ops =3D { =20 static const struct TCGCPUOps crisv10_tcg_ops =3D { .initialize =3D cris_initialize_crisv10_tcg, + .restore_state_to_opc =3D cris_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D cris_cpu_tlb_fill, @@ -222,6 +232,7 @@ static const struct TCGCPUOps crisv10_tcg_ops =3D { =20 static const struct TCGCPUOps crisv32_tcg_ops =3D { .initialize =3D cris_initialize_tcg, + .restore_state_to_opc =3D cris_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D cris_cpu_tlb_fill, diff --git a/target/cris/translate.c b/target/cris/translate.c index 73385b0b3c..fbc3fd5865 100644 --- a/target/cris/translate.c +++ b/target/cris/translate.c @@ -3392,9 +3392,3 @@ void cris_initialize_tcg(void) pregnames_v32[i]); } } - -void restore_state_to_opc(CPUCRISState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750610; cv=none; d=zohomail.com; s=zohoarc; b=PI2/096UHVw35znhSytxisFex222sJbfsg7W9b7G8vGjx4ity4szb69V7+mEPG/Aqi25gJHn6RYAiO9IrQD5HYdmJ795DzdLqzUmm4adbnkBDoSY96m4PCcOK86+aYyH6IVVad5IensJLwZ6OVys5IR3lSuG3x0RaYBV7yznH30= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750610; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=xCgUD/CDm7rh2G6Hg1YAveve5hrsKtyPudhnNjch8RI=; b=IMUnzlTc98jQnryPFFmXKw0oBZ1e0PdbrYykEM+CGs8Jm0X8V3h5p4MulpuWetFTKYTxDmCymIaVbIbEs07Dni2UREJLPB4rF3so69Ze/+ZzCaU+US5xiXu2TTmf2QfZzfjd8Ag8e1oEBjPZrR3Kx+adhNfUL2CwTA7OOOQL3eQ= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750610460624.1771100308629; Tue, 25 Oct 2022 19:16:50 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuV-0005KA-KL; Tue, 25 Oct 2022 22:12:51 -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 1onVuT-0005Jm-Kz for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:49 -0400 Received: from mail-pg1-x52a.google.com ([2607:f8b0:4864:20::52a]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuS-0001HO-6x for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:49 -0400 Received: by mail-pg1-x52a.google.com with SMTP id r18so13415702pgr.12 for ; Tue, 25 Oct 2022 19:12:47 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=xCgUD/CDm7rh2G6Hg1YAveve5hrsKtyPudhnNjch8RI=; b=dkklZ+0VYCYHJy6hkBFIXPoNR53foc4BMrGM7gSaBRPJlk0N+D7JKq04+EugRg85vh AfaQ8k1LCtFFKy7twrQefMAiNqpucjbQfrTNhlHIuw+4sVQsXAeK3ut0V5HSMxFFX0Xh 6304NAzxcxIqOgDhPETK3sNHg9s58+WKhIqIVN/EAaT+zfp5dbQq/I/Ikkglr9anFLqY uvVRRk5XEhxd2hfzDmjtbEkbRCEEx31NkfS/Q7VEkspo2hDZM7qkAxEnLs2yJnTLglth +hmCtZc/klwGw1/lQeuBuclgok8ztflbUWgSerCDN1VAYtXmoMrYeP9O9ObiJdoyKJ3M hlEA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=xCgUD/CDm7rh2G6Hg1YAveve5hrsKtyPudhnNjch8RI=; b=7HM3JBacVcL2HAAbzUo+sEKddRgnkjrgVQ1H9XFNDewWTVmgJpRWYQtA/tgdrPcIBU mj8L7Nsme1PmCS1hjDCwRJd7HDoHmAjrK4JmPLoer8prrZelPY0wHDNx5lhH1Jz1Pp7/ 955vrZxiPB63mNyHV6HcNLb8gVBvYQxKDKixaKsZjW76YqbBo8LuOce/s8AkqzoqGy61 SdcsMzuejEDlzru5aihFoFQYxQaZibe2OFqsHLtvH8u6PDiZXBEGQqv/jPHevVjJqV3I ZdPa/JQxwcwMScVKxkM6mKXgNscwO4SeBw3oqTjKOLEHUzwn2qRYSrzgrrxn+vNjpmSJ N3iA== X-Gm-Message-State: ACrzQf2Vxiqhgr+GRJuAEu3txLGsfMEjBsVe0y5l9FABNYXViytKvwNI kbRa23671ZHfnlE4YtHBVL8ojSrCwSnO9ceb X-Google-Smtp-Source: AMsMyM7m51GSPQvbHRSe2HdiCmqcBBu6YYPkPGkotSFM/xc+/y8abupbWRAdL91J5jHDaA9uITxhTQ== X-Received: by 2002:a63:5a08:0:b0:43c:9fcc:cc54 with SMTP id o8-20020a635a08000000b0043c9fcccc54mr35100239pgb.229.1666750366891; Tue, 25 Oct 2022 19:12:46 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 30/47] target/hexagon: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:10:59 +1000 Message-Id: <20221026021116.1988449-31-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::52a; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x52a.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750612566100003 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/hexagon/cpu.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/target/hexagon/cpu.c b/target/hexagon/cpu.c index fa6d722555..03221fbdc2 100644 --- a/target/hexagon/cpu.c +++ b/target/hexagon/cpu.c @@ -271,9 +271,13 @@ static bool hexagon_cpu_has_work(CPUState *cs) return true; } =20 -void restore_state_to_opc(CPUHexagonState *env, TranslationBlock *tb, - target_ulong *data) +static void hexagon_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) { + HexagonCPU *cpu =3D HEXAGON_CPU(cs); + CPUHexagonState *env =3D &cpu->env; + env->gpr[HEX_REG_PC] =3D data[0]; } =20 @@ -327,6 +331,7 @@ static void hexagon_cpu_init(Object *obj) static const struct TCGCPUOps hexagon_tcg_ops =3D { .initialize =3D hexagon_translate_init, .synchronize_from_tb =3D hexagon_cpu_synchronize_from_tb, + .restore_state_to_opc =3D hexagon_restore_state_to_opc, }; =20 static void hexagon_cpu_class_init(ObjectClass *c, void *data) --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750658; cv=none; d=zohomail.com; s=zohoarc; b=JpJh4raU6ULmabmclyy1j2gtA5G/ekclNGNCNW93PBSLoPE9Tw/3m+T3c7Z2T4VMAcE0DQnxcTcMBKyMUYne6ee4UurfUWqcauxd37bg5oQNvevZj3KdoY3FQqAXn5P/vpX2f4tFZc4Giy9C3PmtBVDVi+VmY2L5ibV+tPR1Wtk= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750658; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=ivVGdg8T3tgMGN4Yqz/msc0BdoDhOdnaWJxKNMe3heo=; b=HOlcZyPEoNJ4loO3GvzYunCM86dLI203anFxrYCLhmOK5ej3Y1Bz52/1j3ZuhrRpXjQBz5nMCHgUucoSNYq9aucrGzySLAYFtDoP4Lhgm08q+ij15ZLXE1oWHrfstQ1up3SRd6l/dD5yS+oApAtsAR/0OvO8h0yimnddyEJ5t9I= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750658129809.8716276280352; Tue, 25 Oct 2022 19:17:38 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuX-0005KM-5K; Tue, 25 Oct 2022 22:12:53 -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 1onVuW-0005KF-Fc for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:52 -0400 Received: from mail-pf1-x42d.google.com ([2607:f8b0:4864:20::42d]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuU-0001Hi-Qh for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:52 -0400 Received: by mail-pf1-x42d.google.com with SMTP id i3so13858017pfc.11 for ; Tue, 25 Oct 2022 19:12:50 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=ivVGdg8T3tgMGN4Yqz/msc0BdoDhOdnaWJxKNMe3heo=; b=DZ5aVSKb9vLS+xsX+MmgygCHujSeCsnvwC3HqQ4FVyqMoi2QyMAeyQoOgXsfysIbv8 0/sX8KYoIPOMCzztchPHK/l5CCtO3DAsI5rR9ayL2hE+maLm1QScOajgQGIZNTaf6IdQ JIh4JfEKz3AP3kmjaJA6V+/gtnfzJ+6wsj7nPoiIjvROIJoM1E1lAEBtTpUjkBafqXIw Hq5zSw8vqx8BQQ25KOk0/TguRu+/uR5kXTQQd/Z1Suv6eT57Qlbz4d2y803AyOeuk+n0 zgzjytSbbkhRSX4q1VwTrUnsLGmFrIUJbJve9rXFVxWYIzejYUMOyoMhAcapu2xZG4eq oLuQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=ivVGdg8T3tgMGN4Yqz/msc0BdoDhOdnaWJxKNMe3heo=; b=HISjnoma/dHgPZRn0buA44GnUVz4PIqyTic1KHSIGJI9k593N5sMZyjFhAWafv973+ MqaqDQKaz/XAnE1YHKsl5hggJvl1iHWIJ+GvJWlmM13RqdfS4k6PRL7eyXDWhpZzbCGQ a41DfX/b19llTNnQi4g++5RZV3gxp2mmYgWd11OYjo8DvxqV2SHaWPJGYZbAKApP+3zT 57qBoDEPqvQYBObH/7bdODHkxBWJOR+5TBhpDQvjnEvBmGAZmdJkjleX+OoMnxdA+IOO lYNEkn6CrJubBUM/XBCC+U/vVi+WxtJZwoyPT9JcoSC1TEIAbgjdTrLG5Ajdg3D31A0+ AcEg== X-Gm-Message-State: ACrzQf3Ux7HypBrwArolUkwenMPt78SkOWV0atkCslZZRJhTEevKcdii EcOQc56MdvglY0dKaps8KLpfqdIWspxDRgm9 X-Google-Smtp-Source: AMsMyM5NkIVC6JFCDFnF9vTNeBa2l7u8/Qqj8OVdoTWZZFtTXY6IR399Wf5f1g/3VVP4yqrBBXzLSg== X-Received: by 2002:a63:171b:0:b0:438:e47d:e79b with SMTP id x27-20020a63171b000000b00438e47de79bmr34716697pgl.542.1666750369504; Tue, 25 Oct 2022 19:12:49 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 31/47] target/hppa: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:00 +1000 Message-Id: <20221026021116.1988449-32-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42d; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42d.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750658899100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/hppa/cpu.c | 19 +++++++++++++++++++ target/hppa/translate.c | 13 ------------- 2 files changed, 19 insertions(+), 13 deletions(-) diff --git a/target/hppa/cpu.c b/target/hppa/cpu.c index e677ca09d4..55c190280e 100644 --- a/target/hppa/cpu.c +++ b/target/hppa/cpu.c @@ -68,6 +68,24 @@ static void hppa_cpu_synchronize_from_tb(CPUState *cs, cpu->env.psw_n =3D (tb->flags & PSW_N) !=3D 0; } =20 +static void hppa_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + HPPACPU *cpu =3D HPPA_CPU(cs); + + cpu->env.iaoq_f =3D data[0]; + if (data[1] !=3D (target_ureg)-1) { + cpu->env.iaoq_b =3D data[1]; + } + /* + * Since we were executing the instruction at IAOQ_F, and took some + * sort of action that provoked the cpu_restore_state, we can infer + * that the instruction was not nullified. + */ + cpu->env.psw_n =3D 0; +} + static bool hppa_cpu_has_work(CPUState *cs) { return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI= ); @@ -153,6 +171,7 @@ static const struct SysemuCPUOps hppa_sysemu_ops =3D { static const struct TCGCPUOps hppa_tcg_ops =3D { .initialize =3D hppa_translate_init, .synchronize_from_tb =3D hppa_cpu_synchronize_from_tb, + .restore_state_to_opc =3D hppa_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D hppa_cpu_tlb_fill, diff --git a/target/hppa/translate.c b/target/hppa/translate.c index 8b861957e0..1af77473da 100644 --- a/target/hppa/translate.c +++ b/target/hppa/translate.c @@ -4346,16 +4346,3 @@ void gen_intermediate_code(CPUState *cs, Translation= Block *tb, int max_insns, DisasContext ctx; translator_loop(cs, tb, max_insns, pc, host_pc, &hppa_tr_ops, &ctx.bas= e); } - -void restore_state_to_opc(CPUHPPAState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->iaoq_f =3D data[0]; - if (data[1] !=3D (target_ureg)-1) { - env->iaoq_b =3D data[1]; - } - /* Since we were executing the instruction at IAOQ_F, and took some - sort of action that provoked the cpu_restore_state, we can infer - that the instruction was not nullified. */ - env->psw_n =3D 0; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751064; cv=none; d=zohomail.com; s=zohoarc; b=mVgEGF3tPZkmMq/5noY9KLCsFIOrZdpt3prX0rCkhsB017g7PCN16lskbd46Z/jvUcX60tGg4Dk6Eayc0BYMVxzi27uEzu0FxF9nArsdeatTTZw1d+lqOIp7cavgUB4aweOx6FWxN9nVkhP0HQ8TzxghSwCsB3qMnDQwClwAHzQ= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751064; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=sCi48ZqO6AkPMJ+ZyF18T2s297T/4zk3YpQYq8qyJcQ=; b=EsuU5gfwCKoAtgpsWx/ckJI6tbm3S+KDzLUAjZj5YxtKq3Dbv+ddBBxcvUvqNu7FJsf4sS6Wcdr2LpzyrE4xAKtw0hdsStlpNhl0o45IpouRUVK2Tu6drlhv+pSxLVmx3CxBXKr9S3RKwzpeGNdZeYf5wOtXMsj/dO7kqSGbfx4= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751064265634.3242218464866; Tue, 25 Oct 2022 19:24:24 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuZ-0005Ki-NP; Tue, 25 Oct 2022 22:12:55 -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 1onVuZ-0005Ka-2i for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:55 -0400 Received: from mail-pf1-x42c.google.com ([2607:f8b0:4864:20::42c]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuX-0001I1-GB for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:54 -0400 Received: by mail-pf1-x42c.google.com with SMTP id k22so2219873pfd.3 for ; Tue, 25 Oct 2022 19:12:53 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:51 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=sCi48ZqO6AkPMJ+ZyF18T2s297T/4zk3YpQYq8qyJcQ=; b=MRRBpFJLTkB1PUXL4scR8hNxrtJjCJfIAmF5CzC95ImTIe2BoE818XksIAjNPMWRy9 clxQgb/nkMp7AcwdSq6ChaJAI1/Wg1GwmvBTx0g41Wv6FkRKaVCbdeP52QDo7vQrsPbo xXY4ivL3Kuc0ng9J2uLsyNLng7eZ41siFWWlAExe46X8LpOOF0e9Pst7uKscyedo6td6 NH1aC7jNAOfpCCC/T/6YuAeAk9hjAS2ifzaVNgukPg6hDntuIHrFNxWBcb+HYYj7WkOG 7yB6kzvOAR5zK0cdAA5UbynCI+Rnz/7ryWbInbLTLBIm83PhtI1ZvF+Qdfm/nlsFjtGT 7D1A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=sCi48ZqO6AkPMJ+ZyF18T2s297T/4zk3YpQYq8qyJcQ=; b=wQ1l5ZqC6rF8qQETLXvpCiy0OWy3tm9srf3/I9LsjfSG4tsnZqZWjNVW0BLcMxXQ6L 1tW6sm2/iqwzPS79/37lx8dWxqHLz3KIcksZux15eYxhvHf0NPG1uZRsgppsN7qNFC3Q PbXabisAYH/26YG5scKmW0eALzFFrz8YQEYsQkQu7UnXjcEKt3/n6JcoUP+dYcjh4J6u DJeOGAcGR//dSfb6hmZE4Dqn5A5zdmM2LzK+TQeq3RFHidZVMQi3fak4zdY9ck1yFdKm qElTeBt+tfJI3kNyuhAtQY3Qb2+pWkXCJUtVEHTjwBsPJsRZlqMQ0NPBP8nVSg1ju+Ee /ATQ== X-Gm-Message-State: ACrzQf1sByna46VURTxb4Eh1roN3rewxUvHMjuyT1vDmrjhVFtcP3MdS uT/vzuQDAdCNLKSyh6kc6BYjNpPfsxqY4bWp X-Google-Smtp-Source: AMsMyM4UbvjeSkVPAiYmf8DaEvWxhUmYKugvvhfwRdEluffxVY+seVy+Nb1MNDib90OaLG+e62BxkA== X-Received: by 2002:a63:e74d:0:b0:440:6c50:eab7 with SMTP id j13-20020a63e74d000000b004406c50eab7mr34930607pgk.308.1666750372199; Tue, 25 Oct 2022 19:12:52 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 32/47] target/i386: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:01 +1000 Message-Id: <20221026021116.1988449-33-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42c; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42c.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751065164100005 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/i386/tcg/tcg-cpu.c | 19 +++++++++++++++++++ target/i386/tcg/translate.c | 15 --------------- 2 files changed, 19 insertions(+), 15 deletions(-) diff --git a/target/i386/tcg/tcg-cpu.c b/target/i386/tcg/tcg-cpu.c index 828244abe2..79ac5908f7 100644 --- a/target/i386/tcg/tcg-cpu.c +++ b/target/i386/tcg/tcg-cpu.c @@ -56,6 +56,24 @@ static void x86_cpu_synchronize_from_tb(CPUState *cs, } } =20 +static void x86_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + X86CPU *cpu =3D X86_CPU(cs); + CPUX86State *env =3D &cpu->env; + int cc_op =3D data[1]; + + if (TARGET_TB_PCREL) { + env->eip =3D (env->eip & TARGET_PAGE_MASK) | data[0]; + } else { + env->eip =3D data[0] - tb->cs_base; + } + if (cc_op !=3D CC_OP_DYNAMIC) { + env->cc_op =3D cc_op; + } +} + #ifndef CONFIG_USER_ONLY static bool x86_debug_check_breakpoint(CPUState *cs) { @@ -72,6 +90,7 @@ static bool x86_debug_check_breakpoint(CPUState *cs) static const struct TCGCPUOps x86_tcg_ops =3D { .initialize =3D tcg_x86_init, .synchronize_from_tb =3D x86_cpu_synchronize_from_tb, + .restore_state_to_opc =3D x86_restore_state_to_opc, .cpu_exec_enter =3D x86_cpu_exec_enter, .cpu_exec_exit =3D x86_cpu_exec_exit, #ifdef CONFIG_USER_ONLY diff --git a/target/i386/tcg/translate.c b/target/i386/tcg/translate.c index 85be2e58c2..546c427c23 100644 --- a/target/i386/tcg/translate.c +++ b/target/i386/tcg/translate.c @@ -7023,18 +7023,3 @@ void gen_intermediate_code(CPUState *cpu, Translatio= nBlock *tb, int max_insns, =20 translator_loop(cpu, tb, max_insns, pc, host_pc, &i386_tr_ops, &dc.bas= e); } - -void restore_state_to_opc(CPUX86State *env, TranslationBlock *tb, - target_ulong *data) -{ - int cc_op =3D data[1]; - - if (TARGET_TB_PCREL) { - env->eip =3D (env->eip & TARGET_PAGE_MASK) | data[0]; - } else { - env->eip =3D data[0] - tb->cs_base; - } - if (cc_op !=3D CC_OP_DYNAMIC) { - env->cc_op =3D cc_op; - } -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751400; cv=none; d=zohomail.com; s=zohoarc; b=ZoLlh44HThxAFgciQbT7jd0qZER2jRB61lsVNJmzZDNMnqCXI3wRm9mAYqW2ULeVbQ7ugordFTNI2zr4sW6S73+u9wNTl4UcIYsXyohHfz1aJBW/vgiKTg8zGrWFY0KLSjyNDZdHKOf6pzfr/9pNlbYGKx3QMzIKtuaJ/FCLan0= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751400; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=eD/aEJdWjUBUHpnzJsPaChBd1LKmz8z122Vxs/vIfNE=; b=TlANRWCfumY+23rnlSL708apf34QUKd2b1Pn7Q7NsMrPvyg3ravPZzyJWZLSXL8D9SOsPwa5Lfe0wCgoJgjjbiSFXcZQtCaQ8Ovgd2GhOMC6zDj19iSprbdLg/cIxi23lYEMOhDhwsr+etFOoRrMqQziUVAuqBWdRzrGBDbLodk= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751400872416.61070108991885; Tue, 25 Oct 2022 19:30:00 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuc-0005L7-EY; Tue, 25 Oct 2022 22:12:58 -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 1onVub-0005Kz-89 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:57 -0400 Received: from mail-pg1-x52a.google.com ([2607:f8b0:4864:20::52a]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuZ-0001HO-Or for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:12:57 -0400 Received: by mail-pg1-x52a.google.com with SMTP id r18so13415962pgr.12 for ; Tue, 25 Oct 2022 19:12:55 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=eD/aEJdWjUBUHpnzJsPaChBd1LKmz8z122Vxs/vIfNE=; b=yYHDaJlDVmTHUUtrIVwsU9P+VDZ5LHAjToEtnFtOjcagJ8VM8F75qwDKcHX02r4fdg TaeMG1ienUMItqFbkkKTq+qx5lxsO09O5n+nuETLxEghNn3Y5pUi/HHvsFRneycAUzge +2lEpF1sBlosmv1xQkdLTTW1VSgcKPimnLe1sCQPZSdddQRc4KafDyMni4HwbSmXeTbM inG66G3kDCmD16moKX4xcPCIrfEdYO4HHboVJgXSlJh7jpRG19PByiUy6y8InXDLHE0g kXyWXwnGOL3YPvtPnBbb9c8f/5E6paH6oVY4Vzh3UpvjnEBNof2kdSyeqaONO/7Q+Zcm Kibw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=eD/aEJdWjUBUHpnzJsPaChBd1LKmz8z122Vxs/vIfNE=; b=zaQgoXrYKK6NeWR/ozOZybBROwOsXUcrOYEiURW7huSKaKS1XQgozAvxtAkqyS3gyN vFeNtfrbjvfc1V549+LRq5PpOzbqaykhjwEALSXvThvbb2Rr5WPH4IDzMEKjj5KY4zY6 Q6W2gC4MCjFDuhJhg/XJIxYQNZfBpm9GOC0B6rAg6QtKCYYGUnZbd9GOyVR0y1xPS1I2 efGwcCu/wmilsKjm4wmkVuJxYFAtBSc63EXz9PH+xB0SN8g9wS5IW1Gp/uHGKuAouu8p fK+xcRiRi0S/Byf/hOqvuUekOUvbS0IsgA8GgJ7marpkwHGepjZuIW+t1KXF5dENvmSc 8IpQ== X-Gm-Message-State: ACrzQf3+32XbUFizH7VwPZmkFjcESBAR4S32+Lojh57c/xoaniZAjsI3 IjldxNq+KF1+KFsywCjuTRRuw/n7alxXCJRV X-Google-Smtp-Source: AMsMyM7wS3ndua0arzBZ4OzdCPkrWHCYEcDvpBOq6UQba+3W5k6M42ZbVy6SsJw95ihCG9K71H7qcQ== X-Received: by 2002:a63:82c6:0:b0:460:a691:356 with SMTP id w189-20020a6382c6000000b00460a6910356mr34983460pgd.621.1666750374949; Tue, 25 Oct 2022 19:12:54 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 33/47] target/loongarch: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:02 +1000 Message-Id: <20221026021116.1988449-34-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::52a; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x52a.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751401750100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/loongarch/cpu.c | 11 +++++++++++ target/loongarch/translate.c | 6 ------ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/target/loongarch/cpu.c b/target/loongarch/cpu.c index 1722ed2a4d..49393d95d8 100644 --- a/target/loongarch/cpu.c +++ b/target/loongarch/cpu.c @@ -319,6 +319,16 @@ static void loongarch_cpu_synchronize_from_tb(CPUState= *cs, =20 env->pc =3D tb_pc(tb); } + +static void loongarch_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + LoongArchCPU *cpu =3D LOONGARCH_CPU(cs); + CPULoongArchState *env =3D &cpu->env; + + env->pc =3D data[0]; +} #endif /* CONFIG_TCG */ =20 static bool loongarch_cpu_has_work(CPUState *cs) @@ -651,6 +661,7 @@ void loongarch_cpu_dump_state(CPUState *cs, FILE *f, in= t flags) static struct TCGCPUOps loongarch_tcg_ops =3D { .initialize =3D loongarch_translate_init, .synchronize_from_tb =3D loongarch_cpu_synchronize_from_tb, + .restore_state_to_opc =3D loongarch_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D loongarch_cpu_tlb_fill, diff --git a/target/loongarch/translate.c b/target/loongarch/translate.c index 95b37ea180..6091772349 100644 --- a/target/loongarch/translate.c +++ b/target/loongarch/translate.c @@ -272,9 +272,3 @@ void loongarch_translate_init(void) cpu_llval =3D tcg_global_mem_new(cpu_env, offsetof(CPULoongArchState, llval), "llval"); } - -void restore_state_to_opc(CPULoongArchState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751274; cv=none; d=zohomail.com; s=zohoarc; b=D1woj6Q3iuR65E7HeTzOc4rUcOibQgHIRXykdC007GeehZhBOi9Ay1vn4E9WvXiLiqbYvkvQWDPLMhDS89PdN6Cgrd8aEEh52qxXXLfa2Mm0n55SPiLXVrkh3HEYCfRndNZUasW21Pk+NaSf0NyPqm8C8pYXRLVmdlzO+hqUwew= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751274; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=0+3o4CPyuPVVmOjPMArLfsmwt3aY6U6qlMjvebtFZz8=; b=gaiHnOmx3or7QD3hfsAdA0m6AFxAZf4jrD9K0ua0gKkBaNV+0cWrhHaJ7G9WNlFJcBNktml/q5Zbt+cA+eunLs2c1gAT8vt956I6bjBY/NL0ceAd8nfacIKZPY2mGHsky8ADHEuznGBaAAVZfV6cSJOvb0lw1vapz3XY4FCiHyc= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751274322359.7400679106403; Tue, 25 Oct 2022 19:27:54 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVug-0005Lb-1P; Tue, 25 Oct 2022 22:13:02 -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 1onVue-0005LP-Ly for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:00 -0400 Received: from mail-pf1-x42b.google.com ([2607:f8b0:4864:20::42b]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVud-0001Id-1Z for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:00 -0400 Received: by mail-pf1-x42b.google.com with SMTP id w189so12451577pfw.4 for ; Tue, 25 Oct 2022 19:12:58 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=0+3o4CPyuPVVmOjPMArLfsmwt3aY6U6qlMjvebtFZz8=; b=esPd9jbFujhkaxobtQp6bEVZVR6dAVCcyykvRMl9S/Gpj0rVWgoJ/D2Hjmby3GfmNV g9LiXVhmp/++yK+cpZrLKZaQBtkGTtvSipM2mpbbmiPo0DYQ43USe3U9ZOFlEKDbUQ4i 4Z+NhuSYlmK7Nj0Dz8aAqHXWWuOjToPpRkmCUQ0xkM0oBawYah83eXZuuT/zZmzhZapd RVfTCqkD4zlIbPklc8w/pxmLH1KxTqp7RyraVtgszSxs+YNjgvGiX7tQs2+43LuQRKuy EiRFvX4nXacr7YXVbmB6qgcY9aWjHSJ3yWfkCmfw1YT/FpxV3huO1ts/habd7a9yU2D2 fSsA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=0+3o4CPyuPVVmOjPMArLfsmwt3aY6U6qlMjvebtFZz8=; b=iwavg3tImtw7By3oluRwzdlXabU3is2xATukxi0hk6fiNB+XPvCsJ8GyiRwEw5ns3C IVzYoNroaRubrXxcihHlH8/03S4HzWq3TwPySeDALnV8IdUjPUMz/5q5BR6K94nWvVbV opjJdg86hfyT2JUeedzT9D4M4QTPF6iOzcEl5d9L8v1Y3qKIregrFupk1Q8dvrMkVWV5 9wcbMxPtTJsr0nnmuoHpwYbo1E0nUS8EVes7tcrIj4lH+4uIXRG03Z87O7E2hMFyzN2t riIitKmUnmR2PcWeLvC1W0GYgOcFbETcN4iey8u+CKuQLnOphR2dnVe93R4cAknSwsWt u+mQ== X-Gm-Message-State: ACrzQf3hcMRbXN9SkV6BlvjgpDM8FNwoWDNjfC1KDV+E+N6dFpqmE32/ lajh8K0bIMF6iFoOWjtg43bghm5RgJGrAPRN X-Google-Smtp-Source: AMsMyM4h34VWEF1jCmlat9CeR0zXZBCoPB3iLLCSHXZr/stm+06LgATltFbNbo8w0f4EjqB9FS10EQ== X-Received: by 2002:a63:2ac9:0:b0:457:24a2:6fa7 with SMTP id q192-20020a632ac9000000b0045724a26fa7mr34535424pgq.484.1666750377623; Tue, 25 Oct 2022 19:12:57 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 34/47] target/m68k: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:03 +1000 Message-Id: <20221026021116.1988449-35-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42b; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42b.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751275314100003 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/m68k/cpu.c | 14 ++++++++++++++ target/m68k/translate.c | 10 ---------- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/target/m68k/cpu.c b/target/m68k/cpu.c index 1e902e1ef0..b67ddea2ae 100644 --- a/target/m68k/cpu.c +++ b/target/m68k/cpu.c @@ -38,6 +38,19 @@ static vaddr m68k_cpu_get_pc(CPUState *cs) return cpu->env.pc; } =20 +static void m68k_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + M68kCPU *cpu =3D M68K_CPU(cs); + int cc_op =3D data[1]; + + cpu->env.pc =3D data[0]; + if (cc_op !=3D CC_OP_DYNAMIC) { + cpu->env.cc_op =3D cc_op; + } +} + static bool m68k_cpu_has_work(CPUState *cs) { return cs->interrupt_request & CPU_INTERRUPT_HARD; @@ -524,6 +537,7 @@ static const struct SysemuCPUOps m68k_sysemu_ops =3D { =20 static const struct TCGCPUOps m68k_tcg_ops =3D { .initialize =3D m68k_tcg_init, + .restore_state_to_opc =3D m68k_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D m68k_cpu_tlb_fill, diff --git a/target/m68k/translate.c b/target/m68k/translate.c index 9df17aa4b2..5cbde4be34 100644 --- a/target/m68k/translate.c +++ b/target/m68k/translate.c @@ -6479,13 +6479,3 @@ void m68k_cpu_dump_state(CPUState *cs, FILE *f, int = flags) env->mmu.mmusr, env->mmu.ar); #endif } - -void restore_state_to_opc(CPUM68KState *env, TranslationBlock *tb, - target_ulong *data) -{ - int cc_op =3D data[1]; - env->pc =3D data[0]; - if (cc_op !=3D CC_OP_DYNAMIC) { - env->cc_op =3D cc_op; - } -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751238; cv=none; d=zohomail.com; s=zohoarc; b=RuaL6RyCPcn6XMOXSOPPDMIDvFk+Lorbp/PeT7wE7I+jPvjQJpQsljreRxrRVyhxZIv8DWevlw9HV2QuA6Qh68YkyutO4aGJdDdoLjmlIXAyCnjjmx4owbudlBDUV20FBHeFnyetBOY2SLejChXxWjtCSK5NTD+MDmCOrHMbybU= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751238; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=DL2U3M4LkCRP8SMH/i6AX3/mkeQ3l2Tn5pl+fLhM1iQ=; b=H8uJkrmBuanKhc1ixZXs3tQ4RRx6ZcG/11JDTr+DUdbVqjfEk5cFaY1Zg92Gv4/pzDApbXlRrRaiv9a3ZuXK/m2cmFdzGnOJsYJybeP7YjmE64aGDoZkEpyyd/UmANIbjC0UaC7L1uMDrri4FJGp1jPafqCVv5jcafF5TKqvO/Q= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751238466375.10853334915794; Tue, 25 Oct 2022 19:27:18 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVui-0005MG-J4; Tue, 25 Oct 2022 22:13:04 -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 1onVuh-0005Lo-2a for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:03 -0400 Received: from mail-pf1-x433.google.com ([2607:f8b0:4864:20::433]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVuf-0001JA-J1 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:02 -0400 Received: by mail-pf1-x433.google.com with SMTP id 192so6738920pfx.5 for ; Tue, 25 Oct 2022 19:13:01 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.12.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:12:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=DL2U3M4LkCRP8SMH/i6AX3/mkeQ3l2Tn5pl+fLhM1iQ=; b=oAtMjCfu47eoM0AGi5pfU3/Y5jIMscbeZl2YBu7u7JYgxJ7M7+6BszusbL86WCeIdb qBuL3akL4daogIVzWGbit8YT4wMrtLTe8NJFD0QXm48AEc5qpgsxRRvSNQ5SCfbG/Kn3 b/nMr36rSwTS+IbHZKbcPb3UNsxIZngor5XXOZL85G6pVhKduyCtVKn8IvCd7TBoVUV1 sgpi2it6lnP3zQqGHLl16p98ROy4hhpQnvrGDpfVtwQGQ8HxhEOWWRBxCrlV1r0iW8Xd 8tSEAhzzYc8fj4JZ70nQvHrc5ob/+hFVmGY6QHRDQt0S7YNA96Z7Kcn4QK/1xohcQ7uP duqg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=DL2U3M4LkCRP8SMH/i6AX3/mkeQ3l2Tn5pl+fLhM1iQ=; b=0LIrhU3VyhwZI3wsmwpdI1LYA3UNfakKD0yOzaqZIPHrEIAVndOxpfm6gWFdS6tQeJ dxC6/Q/PQu2LMgNMuSiN1Qtgq2pOEV8som4q91+VDTs6Uz4lZkmNHFH5NGNWq0qpyTNB x6q9fG/oavw5jR4exhBNVG/UNceJMPVeww2Ro/WnZcaO53WwITKgzm+biBGurvPke+Xh t8Mx2N+GnYb6tvqESYRaLsbWP/uL5NfN0DJilBqFsB4Afx3ItOmQQ8Z+7lYNq6DVWRRe ycCjj4SSkLDZTH5WiGk0bQZcCtGmxu6iycRZ7YtjkMgwSHrqYb7zK2sbS11n/mJr6QJs 7s+g== X-Gm-Message-State: ACrzQf2u1heyY2m2Pg98z5aSFUdQ5c+c7/GgyBWDn2WzwOnJpLN7Hq3A 818z3bS7TlrnHYW3LMcZeWw4lnRTfTSsJ1AB X-Google-Smtp-Source: AMsMyM6l+SZUlxWebewHburW/LAbezkSwCXF3ETFG98KRz99DesbBF/HUW12HbU2JMgnmpINSqwjaQ== X-Received: by 2002:a65:5605:0:b0:46f:1e8d:ece9 with SMTP id l5-20020a655605000000b0046f1e8dece9mr8615476pgs.249.1666750380282; Tue, 25 Oct 2022 19:13:00 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 35/47] target/microblaze: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:04 +1000 Message-Id: <20221026021116.1988449-36-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::433; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x433.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751238942100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/microblaze/cpu.c | 11 +++++++++++ target/microblaze/translate.c | 7 ------- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/target/microblaze/cpu.c b/target/microblaze/cpu.c index c10b8ac029..89e493f3ff 100644 --- a/target/microblaze/cpu.c +++ b/target/microblaze/cpu.c @@ -100,6 +100,16 @@ static void mb_cpu_synchronize_from_tb(CPUState *cs, cpu->env.iflags =3D tb->flags & IFLAGS_TB_MASK; } =20 +static void mb_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + MicroBlazeCPU *cpu =3D MICROBLAZE_CPU(cs); + + cpu->env.pc =3D data[0]; + cpu->env.iflags =3D data[1]; +} + static bool mb_cpu_has_work(CPUState *cs) { return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI= ); @@ -373,6 +383,7 @@ static const struct SysemuCPUOps mb_sysemu_ops =3D { static const struct TCGCPUOps mb_tcg_ops =3D { .initialize =3D mb_tcg_init, .synchronize_from_tb =3D mb_cpu_synchronize_from_tb, + .restore_state_to_opc =3D mb_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D mb_cpu_tlb_fill, diff --git a/target/microblaze/translate.c b/target/microblaze/translate.c index c5546f93aa..974f21eb31 100644 --- a/target/microblaze/translate.c +++ b/target/microblaze/translate.c @@ -1946,10 +1946,3 @@ void mb_tcg_init(void) cpu_res_addr =3D tcg_global_mem_new(cpu_env, offsetof(CPUMBState, res_addr), "res_a= ddr"); } - -void restore_state_to_opc(CPUMBState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; - env->iflags =3D data[1]; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751418; cv=none; d=zohomail.com; s=zohoarc; b=cfgCIUFkNr26FvGS0IFZpiH697PRc8+KkTJXe4dr/yyURAgaT22VRPA21aPOo/mTOULu4YJ/yf18S3mgfekwLxoPebXEyzrlspaDu+8kqqFl7LcShjJUuCOxMBJ7ryCIq8o6W6LVfp0op3jdRmluLMSoeeZD1s2auNVRBRubCac= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751418; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=nWBF5zhKRiXyn9OVB8QHNYB94/Bgwx0Q3fh3y9juC7M=; b=X59FkpuP+CW7XDsdtPURJWob2Vtn1mx/LqfRJ0+AEulr4a9WBnZOS0rpWRn445Mf9zFSs1zF36SAHXdYKqzZ0n354ZKsXPsUssPQxSLsOqyNFPHNoZ/DTBWJzR2i0thJ0A3Kuh9bk3WbIwW6IMN/vBcLO7QCEYFCwUls2z9a9Zc= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751418479593.1324926459332; Tue, 25 Oct 2022 19:30:18 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVul-0005O5-5b; Tue, 25 Oct 2022 22:13:07 -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 1onVuj-0005NS-On for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:05 -0400 Received: from mail-pl1-x634.google.com ([2607:f8b0:4864:20::634]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVui-0001Ja-7v for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:05 -0400 Received: by mail-pl1-x634.google.com with SMTP id u6so12668124plq.12 for ; Tue, 25 Oct 2022 19:13:03 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.13.00 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:13:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=nWBF5zhKRiXyn9OVB8QHNYB94/Bgwx0Q3fh3y9juC7M=; b=UeBSWv3ObyL4/hrShsrQTQ6FM/f1u9NltLcVFD5ODfWmBS6pYl5hWKftiPGj0JR2t0 5uMlbmNptmD70zGeLN8BZR/nMS6KYVq5mc18yiPVHI+/+npgQVv4jOAOBuAwZNuKJ0cZ M6fJr1xqTtIiis0SQdrXQpkxLITgr6KGhLD00Nq2s9mEZJf83vWB0fhuTt/KePPuKS7E rhS8ElWGS9/49u3Ks8sCpEITUo3LtXEAfp21M+F2nkofUlx62yFvcjtrA8H/T+WdXo5g EF7zY+PVIUG3FKnN7nx7POiBymyIaAgtSlet47D57IqdicZu+dBxQh8y1Hp1eV4z+4hA Tr7g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=nWBF5zhKRiXyn9OVB8QHNYB94/Bgwx0Q3fh3y9juC7M=; b=odnapIZIn7+Hv3mxuWA/9GolRTPs0NMaNVVvSry2rPVFvQs87+6PXNpTVWUwIPrFXr 9L98xFUayfTCZvpq/Icy7+7Mg4r81uLhcde6v8/l+ofVdk+/USA3EFW9kNKGwltGuj4Q tNFN7gdbUEjGxJrqII7//cWpMmm1Up5JPFaeXZqa4/0I7pqKR9V+W1/eKDfWCMnPqbj8 Nx+zuCbENzxbu3uhch+AmPVm4femIqfA9OUsrUUPZvFcg8HMd1SKwYcuZIQNz+P4jxjn eaFZbYREVSafIqPvrqEb0B/dbG0oZoVr0UsEq8ryAFBTtn6qnsHBTrYaqnWjtWRGDwQ8 pC0w== X-Gm-Message-State: ACrzQf2NKEo6ceBNnssWYD3YP99RNeljznlP2LesaqvR0wXwF97G10L6 CaDgrXdDWTX9ka3rGsW8otqIarEIvVSOaoyo X-Google-Smtp-Source: AMsMyM5T2PB5u1m+qa8x9fsUpeMGQ1Dh5jrov3fdmXU04LyAbW8u6CIZYwN/PttE+SX1YfyHKMKP5Q== X-Received: by 2002:a17:90b:1643:b0:20c:c7c7:d598 with SMTP id il3-20020a17090b164300b0020cc7c7d598mr1505017pjb.97.1666750382948; Tue, 25 Oct 2022 19:13:02 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 36/47] target/mips: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:05 +1000 Message-Id: <20221026021116.1988449-37-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::634; envelope-from=richard.henderson@linaro.org; helo=mail-pl1-x634.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751419842100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/mips/tcg/tcg-internal.h | 3 +++ target/mips/cpu.c | 1 + target/mips/tcg/translate.c | 8 ++++++-- 3 files changed, 10 insertions(+), 2 deletions(-) diff --git a/target/mips/tcg/tcg-internal.h b/target/mips/tcg/tcg-internal.h index 1d27fa2ff9..aef032c48d 100644 --- a/target/mips/tcg/tcg-internal.h +++ b/target/mips/tcg/tcg-internal.h @@ -21,6 +21,9 @@ void mips_cpu_synchronize_from_tb(CPUState *cs, const Tra= nslationBlock *tb); G_NORETURN void mips_cpu_do_unaligned_access(CPUState *cpu, vaddr addr, MMUAccessType access_type, in= t mmu_idx, uintptr_t retaddr); +void mips_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data); =20 const char *mips_exception_name(int32_t exception); =20 diff --git a/target/mips/cpu.c b/target/mips/cpu.c index da58eb8892..e997c1b9cb 100644 --- a/target/mips/cpu.c +++ b/target/mips/cpu.c @@ -538,6 +538,7 @@ static const struct SysemuCPUOps mips_sysemu_ops =3D { static const struct TCGCPUOps mips_tcg_ops =3D { .initialize =3D mips_tcg_init, .synchronize_from_tb =3D mips_cpu_synchronize_from_tb, + .restore_state_to_opc =3D mips_restore_state_to_opc, =20 #if !defined(CONFIG_USER_ONLY) .tlb_fill =3D mips_cpu_tlb_fill, diff --git a/target/mips/tcg/translate.c b/target/mips/tcg/translate.c index c3f92ea652..2f2d707a12 100644 --- a/target/mips/tcg/translate.c +++ b/target/mips/tcg/translate.c @@ -16229,9 +16229,13 @@ void mips_tcg_init(void) } } =20 -void restore_state_to_opc(CPUMIPSState *env, TranslationBlock *tb, - target_ulong *data) +void mips_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) { + MIPSCPU *cpu =3D MIPS_CPU(cs); + CPUMIPSState *env =3D &cpu->env; + env->active_tc.PC =3D data[0]; env->hflags &=3D ~MIPS_HFLAG_BMASK; env->hflags |=3D data[1]; --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750734; cv=none; d=zohomail.com; s=zohoarc; b=H/cVkf6CvpZm645zLwpzDAMe0QxJ52k3zEXJLVzpjLznPW228etZS+0oXeYuprQLdBeVgEUBIR9Dlmv+JjR7AOC8KIz5KQubWHwVaEfWaa/tzb2GUBwJm/oteRnoqTlVirwHGkbkYpAxz0YWXA3M2USnq1kxI8t1G0Ky5Yo7MCg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750734; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=1Lt8PtTep8NzHGKaIk0wg/EMVOUzJ5wtCQJDLoHf3Hs=; b=SRdhhM1UfWc2YMTL17Hkpyk0VMg/H4YVGe5YunoY/MuFll8MGI6unIYwlVXVeulpzPRjQXQcPZYG0geFvmRbcAcrYR+9GMdbsEEDV9l2AXy87ov64ZZlgeWspJfFCdj4/imIiqGfil/I8VMg0cr9bevdfg6Cg0V1yvVPBhp96Qg= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750734189371.40783461185663; Tue, 25 Oct 2022 19:18:54 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVun-0005XO-Sc; Tue, 25 Oct 2022 22:13:09 -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 1onVum-0005V7-Qa for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:08 -0400 Received: from mail-pl1-x62d.google.com ([2607:f8b0:4864:20::62d]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVul-0001Jt-4z for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:08 -0400 Received: by mail-pl1-x62d.google.com with SMTP id g24so7690204plq.3 for ; Tue, 25 Oct 2022 19:13:06 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.13.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:13:05 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=1Lt8PtTep8NzHGKaIk0wg/EMVOUzJ5wtCQJDLoHf3Hs=; b=dMM2CsL2Yvud7UgYR7njM6XmBTfdGw/Qk/nq2iZAf4ra4IXLNSeDSbOKsogRRZ8C5T 8nTcKPfXYgrcVf02kz9P7Ew09JzqW3tjkFuax5ngN2xusMGF9mFnWKeNY46xQVaMOeMc 18rDIHO6oI//wclWyD55EeVQ6EbvVLwtW/Q2AgFpoLuRcPt+xkjMLVZTKkhTNOz4pgkf bEXZcp8y4AQTy4ODJGMQydu8w0tissCLw44YN2ZyE0BbOrEWQU6z3G2fFFMxyXTY1/56 0WpJcR4+8lyr+SJfWUdZLZphjsAiA86zIloVtaCBidXqEEtFOSIZbUyKlRHyV3lrOzm8 UjVQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=1Lt8PtTep8NzHGKaIk0wg/EMVOUzJ5wtCQJDLoHf3Hs=; b=erro36GJUJVWdJsTl9mh+yuUMNP/VRYbmeMm01QohjFkJGX0uiD9YHoWWVuP+ARiQr H8i0XAu2tLT5KAzKKEDlxBFkswjoAS1b6hWllxVRsW9a9Y5CEvqTP38TG5NS4+qQQXe6 h8clgpNxNE3nYAwVhtjjik9zH/t0Q9DDbfD3qgK0JOEa0F7sw4gT00e11vM1/91f/0qO clpozPUX2fJ79CAp9khETMrSSCB4ruHI1HmEO3MAAaBb3H0UyvwYDdw7YIUY6dtJaRjR 2aKih0MLiIdjsbq+zvHbrBDzpHmbyoqX9ZdFzZlVbEDhSVxLRS5mZF6FY8ENJKzzi9OZ 0n+Q== X-Gm-Message-State: ACrzQf2LLS2CMb7du4oeBB2SPIkf9Iej76X8C05DN4kfsjKMFT8IahQR yQpYaOa9Mx8GVLpWS6hkE0OVdTs5/04StbI8 X-Google-Smtp-Source: AMsMyM6+NJnlMskxdG3L+TvK3eClHocnaY7IHmrv4G8zJYENPcl+07z4/OfMeR3zRPvJhZOV9tsWAA== X-Received: by 2002:a17:902:ea06:b0:185:3d64:8d55 with SMTP id s6-20020a170902ea0600b001853d648d55mr40855886plg.7.1666750385766; Tue, 25 Oct 2022 19:13:05 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 37/47] target/nios2: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:06 +1000 Message-Id: <20221026021116.1988449-38-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::62d; envelope-from=richard.henderson@linaro.org; helo=mail-pl1-x62d.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750735390100005 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/nios2/cpu.c | 11 +++++++++++ target/nios2/translate.c | 6 ------ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/target/nios2/cpu.c b/target/nios2/cpu.c index 2b28429c08..9a5351bc81 100644 --- a/target/nios2/cpu.c +++ b/target/nios2/cpu.c @@ -42,6 +42,16 @@ static vaddr nios2_cpu_get_pc(CPUState *cs) return env->pc; } =20 +static void nios2_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + Nios2CPU *cpu =3D NIOS2_CPU(cs); + CPUNios2State *env =3D &cpu->env; + + env->pc =3D data[0]; +} + static bool nios2_cpu_has_work(CPUState *cs) { return cs->interrupt_request & CPU_INTERRUPT_HARD; @@ -346,6 +356,7 @@ static const struct SysemuCPUOps nios2_sysemu_ops =3D { =20 static const struct TCGCPUOps nios2_tcg_ops =3D { .initialize =3D nios2_tcg_init, + .restore_state_to_opc =3D nios2_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D nios2_cpu_tlb_fill, diff --git a/target/nios2/translate.c b/target/nios2/translate.c index 8dc0a32c6c..4db8b47744 100644 --- a/target/nios2/translate.c +++ b/target/nios2/translate.c @@ -1110,9 +1110,3 @@ void nios2_tcg_init(void) cpu_pc =3D tcg_global_mem_new(cpu_env, offsetof(CPUNios2State, pc), "pc"); } - -void restore_state_to_opc(CPUNios2State *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750788; cv=none; d=zohomail.com; s=zohoarc; b=Sje3pAgEeOSaVXTBs4rurAeUpsDgOlYG5RvlAabswLLlB8dBRe2Ce3/oyjKIVJi1hmAMG2ppbqLh0UXiedeJRwoAsjJ0L/rmhFiPJbjL6L3DrjtgYS41lfDYEUCoeHDBn+pwgDXfYs7mDNLTHI20j3ql7ltIXEXVNJ61I87Hbhg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750788; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=bNZP9ZbaRsIjl4oUm/zT0jhrd1DGs2Oik+dsf8zhpAU=; b=NilN61/c+7Ys9wLKYBfCN5snP3z/eZv6bIrfOsotEnQamzkC6uN/bMTkbbLiXLbmpYHFXDBV1it/z7RHOhhqtmpNhdf8tmBPg7ECq1iQcsGZXvrTI9DaX2hVZBlhEJKWtdEl9mS1uzDDdBx7MJknrMkazIkolgW8F0qdNa/V0PE= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750788641396.4862213981162; Tue, 25 Oct 2022 19:19:48 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVuq-0005Yb-FI; Tue, 25 Oct 2022 22:13:12 -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 1onVup-0005YC-26 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:11 -0400 Received: from mail-pf1-x42d.google.com ([2607:f8b0:4864:20::42d]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVun-0001LI-Io for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:10 -0400 Received: by mail-pf1-x42d.google.com with SMTP id e4so9970732pfl.2 for ; Tue, 25 Oct 2022 19:13:09 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.13.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:13:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=bNZP9ZbaRsIjl4oUm/zT0jhrd1DGs2Oik+dsf8zhpAU=; b=pvlP5gme3RKxIRmV8nak1dcYivFY90NgvVYqP8Hc+SrV1UBcSdC1SHgwRnwAeeC5sh yJdkmFPVbHETl+vt9mUGXJA8t8YubdogjkJK10eWdyBdmYuV0zpqmBpAUET1/LETKwzN XC/meCvlYSIACG1J8bsbK+llGtrT/dJA1wVUDHgTofLpvFamKkUrP9j2HFYLo3D6Oqnq NPu/MsC8FIdhPKVh5SqFeU2Sap1XhcsU6b27Otq1ytZTH4ypq6HpYaLwTb8x0HWqPWxU I82pKoZ2g1Ts5oSF5MadpsX4MaXJ5ZwXNQ3RvMoEGqqLXDZT8CFq4L3jYxu2C/e/IpVp 6mZw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=bNZP9ZbaRsIjl4oUm/zT0jhrd1DGs2Oik+dsf8zhpAU=; b=cYajfmOV1fNb+6kZMGXJCa72oum8+WFdwc3D/8tX/wItRj4lshtpsHR3nI8y7lxsyy kNFFrEBBWLJN3NKs5eDTfi93uxVpdVswAs+IdEvOu6bH6YxkPGdwgOGuIYZcq7SVOrR4 2xulrC4CsW/qf9gG9pRB8dRJd8KAonhGs0FKLZbjbtJR3oPPvsnvjs/gIvb8I+NzjTOq CX2Jz7/MYjCSiZoy5fbl3xxODIbHXKTijDw/E/0Fsxk2FE5f8eZjmiIX9/0Z5wLDKUzV ZWErRevKO12UBXYGo9Jf01Mpk7oQA/5c+9tdOC6c6H2+cnfGEJg7YeTj7+xwd0ZkMQ2i hkHw== X-Gm-Message-State: ACrzQf2qmy0u4VvyQzYWEArS2QFMHjxNyFanpU7gwWN92omUu0U0wu/R 8J/j8XCw/x8m8sWXS5gi6EJMnIrCTCF/s2/v X-Google-Smtp-Source: AMsMyM7QlJJSB3esRxbQWEFOhNc7LDKMRXqnMgO6+RFNIJkwTxnWNEoAtsEuvbvBh7ZucOsAfyjzMQ== X-Received: by 2002:a05:6a00:1707:b0:562:e790:dfc3 with SMTP id h7-20020a056a00170700b00562e790dfc3mr41941861pfc.59.1666750388395; Tue, 25 Oct 2022 19:13:08 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 38/47] target/openrisc: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:07 +1000 Message-Id: <20221026021116.1988449-39-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42d; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42d.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750789703100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/openrisc/cpu.c | 13 +++++++++++++ target/openrisc/translate.c | 10 ---------- 2 files changed, 13 insertions(+), 10 deletions(-) diff --git a/target/openrisc/cpu.c b/target/openrisc/cpu.c index f6fd437785..de0176cd20 100644 --- a/target/openrisc/cpu.c +++ b/target/openrisc/cpu.c @@ -46,6 +46,18 @@ static void openrisc_cpu_synchronize_from_tb(CPUState *c= s, cpu->env.pc =3D tb_pc(tb); } =20 +static void openrisc_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + OpenRISCCPU *cpu =3D OPENRISC_CPU(cs); + + cpu->env.pc =3D data[0]; + cpu->env.dflag =3D data[1] & 1; + if (data[1] & 2) { + cpu->env.ppc =3D cpu->env.pc - 4; + } +} =20 static bool openrisc_cpu_has_work(CPUState *cs) { @@ -203,6 +215,7 @@ static const struct SysemuCPUOps openrisc_sysemu_ops = =3D { static const struct TCGCPUOps openrisc_tcg_ops =3D { .initialize =3D openrisc_translate_init, .synchronize_from_tb =3D openrisc_cpu_synchronize_from_tb, + .restore_state_to_opc =3D openrisc_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D openrisc_cpu_tlb_fill, diff --git a/target/openrisc/translate.c b/target/openrisc/translate.c index 8154f9d744..2f3d7c5fd1 100644 --- a/target/openrisc/translate.c +++ b/target/openrisc/translate.c @@ -1726,13 +1726,3 @@ void openrisc_cpu_dump_state(CPUState *cs, FILE *f, = int flags) (i % 4) =3D=3D 3 ? '\n' : ' '); } } - -void restore_state_to_opc(CPUOpenRISCState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; - env->dflag =3D data[1] & 1; - if (data[1] & 2) { - env->ppc =3D env->pc - 4; - } -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750901; cv=none; d=zohomail.com; s=zohoarc; b=D3j8mzvV+2SzhPT6T9m4ZZdODjUMaBZ0WH54E5aPrA41bCxEB82A252h/u9XemWYK+SXbGSe9VtE1i9539Lk+Z4VgYHOIlxIWTA6WRh6Dj+xeGPr+kT07b6phtta5YjyQNVju84fcc9UqOnYYXf5gFaUQSxdWEOH8+tCYyKXwfk= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750901; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=htRWvpv+4dNFXsMhSbNK8JieGtJ3hejF/Z+2w9zO94g=; b=LK5jph8KMner3sZWPz4DYE4jHIyf8ELJ8QTc9QJhx98s5sCLO0WH0Mrvhcv2piH5M80drfmMXv+SYcATZa0ypFSQjEqkxRUrNqSAll5oSQx9QQPc+43Gsa3rrZevmXYMzvGeBUcVh1qYHttFLRXum7tYSFTeDA1TcuNjnbSSDDc= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750901251888.7506246731396; Tue, 25 Oct 2022 19:21:41 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVv4-0005ie-0z; Tue, 25 Oct 2022 22:13:26 -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 1onVv2-0005iR-IT for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:24 -0400 Received: from mail-qv1-xf35.google.com ([2607:f8b0:4864:20::f35]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVv1-0001NO-3c for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:13:24 -0400 Received: by mail-qv1-xf35.google.com with SMTP id c8so9670581qvn.10 for ; Tue, 25 Oct 2022 19:13:22 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id o29-20020a635d5d000000b0043c9da02729sm1897833pgm.6.2022.10.25.19.13.08 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:13:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=htRWvpv+4dNFXsMhSbNK8JieGtJ3hejF/Z+2w9zO94g=; b=F3kaZFccNWQ2sTBckSe+FVfa4k13L+539ljlF0Lr/KbPT8qYPC/gGWYm7SzgMzG0Af W3u0A1cDoxWFUKxnZTxApiWwHZRIVgDbn9uy72OcOZ+cl4Y+s08C/l1m84vfKgQwmieK p7pbToP+nNWt2yhM7h9LYpEnuthcibReEE1F3GWq9vrxgHdD0z/0dbcY41KmM9fduue/ fNmp89eL0GlRYRP1ZCT3nRS9tgD+j6b7+8ggvGAGhpupkvXlyzKrs8PMNkrtPbGmRNU1 2aTrxLJT3squrSgbR26yfFiDWoHCaMmf2voGLmLSrZ7/DgPTq731s069VPzCLGOirXJ4 I5Eg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=htRWvpv+4dNFXsMhSbNK8JieGtJ3hejF/Z+2w9zO94g=; b=vI00IP22I186M1e+H9NtytV5OkjBEIIXLuaWQAlu/vUZqsEhlVn7J4IX9eTAKWH0ZV 3l2g5n/wrk8r6Oq2u7oPffZzS36sY3OBs0bVYU22U0Xjmeup7PE016UfHFelTyU8U+FS FiQ+EFibDiRbJIWitXBzmyMxj/AmvQhdrn/+vIANsQgMmGboDHCKMW+NlG5qFUcMhIi9 2Ya8k0DLYCcBTKeNIWAB8AA9eCBcKKr2Yokjjf3Q+3AVOzSKntSC4rMLMRNIOcUY87C9 aNmWvJgR2xm2NzMOV6BQ0TVTtZ14nUqU5MYvScMxNP4ze9qBsG0eeJoWBvO1bitnumAU 68dA== X-Gm-Message-State: ACrzQf2/e3M/2N9PRkvJVFQi22C4NAPdy42DIpcmg5JVD6vrEyVH4lX9 EFUlmLZQPNaFM/ZU5Um0lx9+wTiGRoHQvKbh X-Google-Smtp-Source: AMsMyM5qSr6cxHx2mFfF0BfwQwdMlEt1NkJS99md0Iwn/NOYwjnZVlX4/zk6/Ne5UtdexAv0hqJ0ng== X-Received: by 2002:a05:6a00:ac6:b0:530:3197:48b6 with SMTP id c6-20020a056a000ac600b00530319748b6mr41227288pfl.80.1666750391089; Tue, 25 Oct 2022 19:13:11 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 39/47] target/ppc: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:08 +1000 Message-Id: <20221026021116.1988449-40-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::f35; envelope-from=richard.henderson@linaro.org; helo=mail-qv1-xf35.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750902355100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/ppc/cpu_init.c | 10 ++++++++++ target/ppc/translate.c | 6 ------ 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/target/ppc/cpu_init.c b/target/ppc/cpu_init.c index 763a8431be..335351c226 100644 --- a/target/ppc/cpu_init.c +++ b/target/ppc/cpu_init.c @@ -7221,6 +7221,15 @@ static vaddr ppc_cpu_get_pc(CPUState *cs) return cpu->env.nip; } =20 +static void ppc_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + PowerPCCPU *cpu =3D POWERPC_CPU(cs); + + cpu->env.nip =3D data[0]; +} + static bool ppc_cpu_has_work(CPUState *cs) { PowerPCCPU *cpu =3D POWERPC_CPU(cs); @@ -7446,6 +7455,7 @@ static const struct SysemuCPUOps ppc_sysemu_ops =3D { =20 static const struct TCGCPUOps ppc_tcg_ops =3D { .initialize =3D ppc_translate_init, + .restore_state_to_opc =3D ppc_restore_state_to_opc, =20 #ifdef CONFIG_USER_ONLY .record_sigsegv =3D ppc_cpu_record_sigsegv, diff --git a/target/ppc/translate.c b/target/ppc/translate.c index e810842925..7228857e23 100644 --- a/target/ppc/translate.c +++ b/target/ppc/translate.c @@ -7739,9 +7739,3 @@ void gen_intermediate_code(CPUState *cs, TranslationB= lock *tb, int max_insns, =20 translator_loop(cs, tb, max_insns, pc, host_pc, &ppc_tr_ops, &ctx.base= ); } - -void restore_state_to_opc(CPUPPCState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->nip =3D data[0]; -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750902; cv=none; d=zohomail.com; s=zohoarc; b=EEspwLeZVJkqiw/1ldvaUmjX0cP+snALb4Q7uuhfzvf+5kbGuFByzlDabDO1juWvzGU2q5wWOIxkoXbMRGeq8xJ5rNBS0IMHwePFwOMU4PloqcTF8+7JJ785mWCVXoBE72xaUD5K4f+tEakDQdHoxVIh4wJBSk05rgzmslqHTag= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750902; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=i7vVd4Q5V6HW/R+ICEMk6aJDNyn3ol3YXdsq0hzOo+k=; b=TFHuEXw59CWGF1lPu1xVFFGD0kAtrxAHk2X2qqV/n72o3aFvLSvF9K7JKDflqHu25Upa1K7jDzPvM5plD7Rvb0VMnjaVKfo4g1k6r29rM0df6Y4qWK+EFv2pwPJWa6dpgJqvlr4Uc82+Hy8yjNILDhX9AJ5W+KbO2dWnGfl9fxs= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750902820333.20899752566106; Tue, 25 Oct 2022 19:21:42 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVxu-0007Xi-At; Tue, 25 Oct 2022 22:16:22 -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 1onVxs-0007Th-3i for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:20 -0400 Received: from mail-pj1-x1036.google.com ([2607:f8b0:4864:20::1036]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVxq-0001rx-Iv for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:19 -0400 Received: by mail-pj1-x1036.google.com with SMTP id h14so12694010pjv.4 for ; Tue, 25 Oct 2022 19:16:18 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=i7vVd4Q5V6HW/R+ICEMk6aJDNyn3ol3YXdsq0hzOo+k=; b=aysdxu/6VQOIo/oAwqtR0/oWYhF4dAw4yoV83SA9pjALgrE65na+qK3HCYrjTwcL1o EX+jrg6B452xYmpF5Dg6SZvDjL9LFE8HElRavuZMUpb5eEgJjtZt7mcNM1e2L/TPD/Kq bli2Wa4EJcS2kjmU0ETIAz9n9nX8y9ToSrjiYwWzi3y/3hk2wrLpOuulK1fzthXpyZ+C JvDvCDjiUeLhdhUW4kW2hoSVCH8pPnaDl3cFYSFdsluaTfI4ZkzDcPtPAx+3o4MCGgb4 +DWW/hP2RoZTCiWijlWkyRshb5yv0NqQugnX7kbM77cAJCLnYsSUDowq0oU4AtRpbKRf mRdA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=i7vVd4Q5V6HW/R+ICEMk6aJDNyn3ol3YXdsq0hzOo+k=; b=muIis0cYwKJ+gXK0DzI3K1wgfeToZcIMPepfxql/PUEd4AxpVxqtqZCyZALSsXsDiD M/O45a3jlhReGJ7A3oqutK4WkZkBpk5md0RqhUGcpLutnSmFzioI3Krq0KoWDQ6smtWc yf0vb0DwWVKeCtdFIs+Ob5CajBnhfAlFDBaT2382QR1K3fztMW1WWrkUk2fPHmyAmcRo AOrs8ahBlb0wHg1DxIWeGqVXjAmeKxTX+iIuD9sne8G45/HVza6bYR9Uz6R4HRBRtdwx 3RKfcJXOKEUx8iZRTmRh4UpanrT2CdK9ReRU4NEfRdHX6r/Xz/NTwBAUcy5fE8kEewgM 3vIg== X-Gm-Message-State: ACrzQf20l6oNBfZc2TJacIBr+qhYODqCMsgNkItOA8eWOKOpBbRtD8JR KvAl4XKGd/izRaJLppgno3YrV/X7YGiqt9ho X-Google-Smtp-Source: AMsMyM5EReC05zmxCO+mkyU/TPRrcYn4TBfiyNHxy3yUp65sii2RLiHDQhH4Q9c1fwS8uFms5FVfQA== X-Received: by 2002:a17:90a:8b93:b0:20a:bd84:5182 with SMTP id z19-20020a17090a8b9300b0020abd845182mr1542923pjn.161.1666750577396; Tue, 25 Oct 2022 19:16:17 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 40/47] target/riscv: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:09 +1000 Message-Id: <20221026021116.1988449-41-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::1036; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x1036.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750904303100005 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/riscv/cpu.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/target/riscv/cpu.c b/target/riscv/cpu.c index e6d9c706bb..d14e95c9dc 100644 --- a/target/riscv/cpu.c +++ b/target/riscv/cpu.c @@ -503,10 +503,14 @@ static bool riscv_cpu_has_work(CPUState *cs) #endif } =20 -void restore_state_to_opc(CPURISCVState *env, TranslationBlock *tb, - target_ulong *data) +static void riscv_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) { + RISCVCPU *cpu =3D RISCV_CPU(cs); + CPURISCVState *env =3D &cpu->env; RISCVMXL xl =3D FIELD_EX32(tb->flags, TB_FLAGS, XL); + if (xl =3D=3D MXL_RV32) { env->pc =3D (int32_t)data[0]; } else { @@ -1138,6 +1142,7 @@ static const struct SysemuCPUOps riscv_sysemu_ops =3D= { static const struct TCGCPUOps riscv_tcg_ops =3D { .initialize =3D riscv_translate_init, .synchronize_from_tb =3D riscv_cpu_synchronize_from_tb, + .restore_state_to_opc =3D riscv_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D riscv_cpu_tlb_fill, --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751062; cv=none; d=zohomail.com; s=zohoarc; b=czCvDzbYGa1L9rMKCq/KVIAlXi7jHuh47Al9M83kGaZ8CFpVTbxs/tJ6uIenj+PLEtG2i3PhonOE3vWjhRursrfT3AEQK0iR5Ebhl6R52/blyq9ABqp6HV89cAYF6YaIMMGDR/jhYePjrhXgQQvpTG1PWuG6y+ZXN1xrj7L3sVA= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751062; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=WVndpCezY7JBunGT3GvHhnOUrjtLFW/jqQ+DpGvV3iA=; b=er6CsiQ0cGqBy/h6SiNLhmVvcP+czIOKAXjIZKTRRR9cnnFrekiEueGX+ZZiBHRLZZgbxFpfrIpMnEiBlABUKXqaHsaGvmcFGZCTNtf4lEYH73sP7PXlEujUDU88DOzwK4Y7f9WvS+dJOsGQ+1/RVC3u+xJx8i88GcnEDa8W9Ds= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751062542339.58920106256846; Tue, 25 Oct 2022 19:24:22 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVxw-0007ao-Ue; Tue, 25 Oct 2022 22:16:24 -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 1onVxv-0007Xw-5v for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:23 -0400 Received: from mail-pj1-x102b.google.com ([2607:f8b0:4864:20::102b]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVxt-0001sF-Jw for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:22 -0400 Received: by mail-pj1-x102b.google.com with SMTP id d59-20020a17090a6f4100b00213202d77e1so1037316pjk.2 for ; Tue, 25 Oct 2022 19:16:21 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=WVndpCezY7JBunGT3GvHhnOUrjtLFW/jqQ+DpGvV3iA=; b=TXZG/tyklNPuQEzdAPzZ5rZXkRXt5x5Q/k2yRlIvJN4TaPhja3v3k6fjz28o1SANzF 0P4mUzv+yTmGJW5hsiX54909lbz+VkZmC241acSwHirFKBG66gf0BzbM8VZnL3MdssCO QwK434ApoH/Zg6d9JyFy/jX2tkO3fvoipCF3Pp4qKxuKSxtpKheXyaohIhQQcnN9LhDd z2Xio6nWnUFF3GT6VCMNqoOmFGVodAJYPQVVwp+1g6qttXhwt1Q4d4r7EMd19Y6cgs6k 8jG4XidJl64A4HhN2Tl23Ak4ETYDGZndQjXnWjJPw1Cd0BMPLkI+Ehs3IbaEFf/Fmq0Z FIEQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=WVndpCezY7JBunGT3GvHhnOUrjtLFW/jqQ+DpGvV3iA=; b=RQF8W0LSTcZSF4GIIipl+yCgA6w7dt5EpqbXyrmPJy2mPR5qMO43QTNpQ6ZKSz0aKk jtGe4pneTAc9Emm+JSwjUsaCF5PgfvcAKEvy6coBveXX4GkoLMCN18I0F0ODYipYfV99 P8lLPflUbkX7wxvNaxtwydqgzuulotlJwIUhT11L7tuF1F1/mU8TGv5Nc8wcJnCO0MfT 6UMV/4GMocmVdEJx1T0LK6Ws5gyWF1ubMO9JzpAR7AJP6L5F+98GWHPeNK66d8iRxY6H 8v2cV8eQEsMdWlCoF4v2gA91BD9Iq7TjRzKrrHeNvlSRVvVaMVD8lesRbNDDrHH+1uBt js3g== X-Gm-Message-State: ACrzQf17Kk1wpOI40ifeF05tg96RyMZlinAPk/eVcuCWThtIegjSyG0U o/jXMqB63lXH7AJSFupSeqwnDwjE+7t9euDG X-Google-Smtp-Source: AMsMyM7cu0XMjj4R6cWBNOA+QqpHuRb9Id5nDwGkwcCTtgdL3y0W4IvXqYSdXMsRQbYFyhnm4TkLkg== X-Received: by 2002:a17:90a:e593:b0:212:f0e8:46ca with SMTP id g19-20020a17090ae59300b00212f0e846camr1526515pjz.144.1666750580082; Tue, 25 Oct 2022 19:16:20 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 41/47] target/rx: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:10 +1000 Message-Id: <20221026021116.1988449-42-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::102b; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x102b.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751063293100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/rx/cpu.c | 10 ++++++++++ target/rx/translate.c | 6 ------ 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/target/rx/cpu.c b/target/rx/cpu.c index 2f28099723..9003c6e9fe 100644 --- a/target/rx/cpu.c +++ b/target/rx/cpu.c @@ -47,6 +47,15 @@ static void rx_cpu_synchronize_from_tb(CPUState *cs, cpu->env.pc =3D tb_pc(tb); } =20 +static void rx_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + RXCPU *cpu =3D RX_CPU(cs); + + cpu->env.pc =3D data[0]; +} + static bool rx_cpu_has_work(CPUState *cs) { return cs->interrupt_request & @@ -192,6 +201,7 @@ static const struct SysemuCPUOps rx_sysemu_ops =3D { static const struct TCGCPUOps rx_tcg_ops =3D { .initialize =3D rx_translate_init, .synchronize_from_tb =3D rx_cpu_synchronize_from_tb, + .restore_state_to_opc =3D rx_restore_state_to_opc, .tlb_fill =3D rx_cpu_tlb_fill, =20 #ifndef CONFIG_USER_ONLY diff --git a/target/rx/translate.c b/target/rx/translate.c index ea5653bc95..87a3f54adb 100644 --- a/target/rx/translate.c +++ b/target/rx/translate.c @@ -2371,12 +2371,6 @@ void gen_intermediate_code(CPUState *cs, Translation= Block *tb, int max_insns, translator_loop(cs, tb, max_insns, pc, host_pc, &rx_tr_ops, &dc.base); } =20 -void restore_state_to_opc(CPURXState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; -} - #define ALLOC_REGISTER(sym, name) \ cpu_##sym =3D tcg_global_mem_new_i32(cpu_env, \ offsetof(CPURXState, sym), name) --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751094; cv=none; d=zohomail.com; s=zohoarc; b=glxiI0nDATCzEtLQVAtYQNzsPgYbRaeMnpVD55Di9Az596eodtHyRrD5hotf2L9tWozsQtQ/2RNawlM3GiAxuAU5aP+sJwPPymg6hoYIJhjxxu6WxAOaaVBH9XZA8HbeaHyALdNjMVvF6rWdAAIE/6gIcuz+vyVMu4kO/xTPfas= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751094; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=VKbB7K0HwBJ/XftUm9+xrFi2M3poh8MvJJd+df6GbYo=; b=Gyx6fXtvaIc3EM0kpE0MTWuEju3tkGPWrbyGe38D31XZMuPvH63STCRqWB6NL7R0+Av1ylZRtaWj76Hkje8VussRpkoryyMRBs4H98J57f0woi3tzcCyjH+txT028DGYxHg9uBS3vTwwfGGvtoqpPhX4gR4Y2jODUR9Py7LFvCo= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751094537451.7917791538191; Tue, 25 Oct 2022 19:24:54 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVy1-0007bu-Nu; Tue, 25 Oct 2022 22:16:31 -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 1onVxx-0007b2-N2 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:25 -0400 Received: from mail-pl1-x62b.google.com ([2607:f8b0:4864:20::62b]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVxw-0001sV-4w for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:25 -0400 Received: by mail-pl1-x62b.google.com with SMTP id 4so6797537pli.0 for ; Tue, 25 Oct 2022 19:16:23 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=VKbB7K0HwBJ/XftUm9+xrFi2M3poh8MvJJd+df6GbYo=; b=ghebxw3aMF/Vj2Mx5yKpFoADo/5jee7aQT9s68CWW2rWxjzbFGUc/1YnIfc083aGiV 7DUVnyR+q5lPoBW9VIYDVynNmEGnot9qQaHabcKz+fnQCeBGgSGv0oWwbdqK0eTLXYUq FlbdYBWEzL8mwZLEas232TFwvNbrBx/rbc5y27ZVZbQCH8eLg6N2BHgJ0J40A2yulE52 gdgMqrRKJJlNvtsc7xbjKfauV54bZLjupYcXHrtSCCDOTKaIq60yKgC5V1YmKizskyvY AwOB7pbkhLb6QDWAtJ3hFvwq1oMbD+IBsA39dSIKoTnrN26bDqjnqqQ0nGa71BjyX3ww Q84g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=VKbB7K0HwBJ/XftUm9+xrFi2M3poh8MvJJd+df6GbYo=; b=KZP0nCxRBSqq+1y/8DL5z3w8vBd/LeiOwSTgcp+O5UcW2M2aYPnYMIwMk1pheWs6tx sSTJQ4e6+sl2MFYh3cmRswzZK9jR39vZAGxwLXt+Wk5NomQoJqiVd7WMcf7uu2NN5e/2 lZ8DHydVqjPodZC1QMrJ5D7gFebiqBCmgeskR8YeWB4IkuAM48o4GFU2+1uj2CXu1Lgb FQF+YrK+Jjxu+nJs/Dg3suE+GgNVYCVnE8fm2I+O2BiDbROqLvQqt4G2j8QB9ZzPpqee pApqDF8J062U4o8KxdCpYFoIokk0w0As75bxGo6uf7zzVeAAPX7kSvzY/JDcO0ElzC8U 9/sA== X-Gm-Message-State: ACrzQf2KwNgJod2/wdnTKbBxsnQGU/9hlkzSPXmo7baMuaQwvyQF6ab7 72BBsNGgO+ak/JKGF9BDvM6vFnPIYF3QGZfK X-Google-Smtp-Source: AMsMyM7lOx3tKCRdT/p1PDVK0NHmEp2uV3F8PwMZyoOp1VpyZjhgZnohk0ws2tRp5bt/jvByauLBVg== X-Received: by 2002:a17:90a:e7c4:b0:20d:451f:a988 with SMTP id kb4-20020a17090ae7c400b0020d451fa988mr1477442pjb.57.1666750582718; Tue, 25 Oct 2022 19:16:22 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 42/47] target/s390x: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:11 +1000 Message-Id: <20221026021116.1988449-43-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::62b; envelope-from=richard.henderson@linaro.org; helo=mail-pl1-x62b.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751095313100006 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/s390x/s390x-internal.h | 4 +++- target/s390x/cpu.c | 1 + target/s390x/tcg/translate.c | 7 +++++-- 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/target/s390x/s390x-internal.h b/target/s390x/s390x-internal.h index b5ae0ae364..5d4361d35b 100644 --- a/target/s390x/s390x-internal.h +++ b/target/s390x/s390x-internal.h @@ -398,7 +398,9 @@ void handle_diag_308(CPUS390XState *env, uint64_t r1, u= int64_t r3, =20 /* translate.c */ void s390x_translate_init(void); - +void s390x_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data); =20 /* sigp.c */ int handle_sigp(CPUS390XState *env, uint8_t order, uint64_t r1, uint64_t r= 3); diff --git a/target/s390x/cpu.c b/target/s390x/cpu.c index df00040e95..96562c516d 100644 --- a/target/s390x/cpu.c +++ b/target/s390x/cpu.c @@ -272,6 +272,7 @@ static void s390_cpu_reset_full(DeviceState *dev) =20 static const struct TCGCPUOps s390_tcg_ops =3D { .initialize =3D s390x_translate_init, + .restore_state_to_opc =3D s390x_restore_state_to_opc, =20 #ifdef CONFIG_USER_ONLY .record_sigsegv =3D s390_cpu_record_sigsegv, diff --git a/target/s390x/tcg/translate.c b/target/s390x/tcg/translate.c index 1d2dddab1c..5798928473 100644 --- a/target/s390x/tcg/translate.c +++ b/target/s390x/tcg/translate.c @@ -6691,9 +6691,12 @@ void gen_intermediate_code(CPUState *cs, Translation= Block *tb, int max_insns, translator_loop(cs, tb, max_insns, pc, host_pc, &s390x_tr_ops, &dc.bas= e); } =20 -void restore_state_to_opc(CPUS390XState *env, TranslationBlock *tb, - target_ulong *data) +void s390x_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) { + S390CPU *cpu =3D S390_CPU(cs); + CPUS390XState *env =3D &cpu->env; int cc_op =3D data[1]; =20 env->psw.addr =3D data[0]; --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751212; cv=none; d=zohomail.com; s=zohoarc; b=GQZM7QLAnHu70c1Wuwe5VkRSKnahEZyWuWUQw/3mOR4UBHg7gvKqmqXccKdyf81NpnULMimihS/vmhlRURSr40AONmgQjnQLszi5ZWBg7uZ1yHDLO/2+vGS5hkdfsd/k5teJ9Pr4ZuHRy+x3ZPMQNV9dxiFVYYxmOaEmJcGBn3I= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751212; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=tF/RwGukDicY+8ye6QbG84ecHxoGGEYhOUNZE7mAzY8=; b=QgnMP3SqNDrGOHEItOxZOjNWRa7AbBfE9sdilxOjyb2cr24hY7Nb/wrcRDB89xJxg46VD6duOwfpXNlvxyoizEFju1xL5xgA5rCoq4A8OOf0qsHoVMjaW6Jd9I/IIkWiPNvSoMowr7FGwPQuDMKEukm+mQsXm8TNtA5dnOGfe6M= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751212456239.6903456159165; Tue, 25 Oct 2022 19:26:52 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVyL-0007r8-IE; Tue, 25 Oct 2022 22:16:51 -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 1onVy4-0007kc-9a for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:32 -0400 Received: from mail-pj1-x102e.google.com ([2607:f8b0:4864:20::102e]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVxy-0001sm-Ot for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:31 -0400 Received: by mail-pj1-x102e.google.com with SMTP id z5-20020a17090a8b8500b00210a3a2364fso2725284pjn.0 for ; Tue, 25 Oct 2022 19:16:26 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=tF/RwGukDicY+8ye6QbG84ecHxoGGEYhOUNZE7mAzY8=; b=uRCZQwE2USy78A7HnNR/actACjm7hjRzF2iRcKK/9ris7ElfDHz/5RF+sWdC5pN2k2 Tsr26snSxC9s+yu4WvqnFoJggfRwxZTGWyf6xmN9HKBu7zmC38IpV3JxD2vXrEzi5ZoC Rua0U7yXbuFfjT+vsyiMl+4kVVrOL/RfTPwH/zphfOEl1bxQEf1i5Fbpw+29T6+JxRJE GbnF9RCytnt4VXPn14mTylTus3hT187LsWEskAgU9XwhUWaUsbdowPRFq88sbBI3jPzU r/Es5J7eJcdSif5EzPvbmL3ClSgfKjYSN/IOyE/R5/jTKcPm61fa0MdFNwWAu3E0AMBP gcig== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=tF/RwGukDicY+8ye6QbG84ecHxoGGEYhOUNZE7mAzY8=; b=yvAI5AsuU0akw5Ro3mCzdyNSSICE6Jl9P1vvi71hrS0qR6dhUQuy2wko4jCMEFGMYP d1bt68YEIxIbLe8cQQNKFLpYALLkKFKc9kB2bn4VWq62zfXByqh2Tz2j4H+PL5wclkF8 YDdE2aFxZEzPWDN20ehqNgfT4w0AGf7yKA8zB1eDBihTsWoXlD9YX6+GNswqAdYpEP7G UsmT+3hAgm8GN0g5eo8lw7fitiWcCmm0w1Xa0IIuC7TO9eI7ds4ZKdsdXgAjCdCE+oPd f2qodeRDVhhl/7L62IgHCQ6j3rGeZagi2HjaAx2uCxJYAcv0h5OZ3VVJjb2dZtIYgVFC u9Tg== X-Gm-Message-State: ACrzQf1i6PTbmsEMTITSn+RZ5fGVgrmaAZ/uIo0g8lEt0QIdmYGCE33R K/4QoFwGRcerBUcJqFl9IVJRvcBKmOCBichQ X-Google-Smtp-Source: AMsMyM52QheWcx3mRT8QsUrSnl8twwbq/VswR3pqxH4MFKisj6REBRW2poUYSEFU0q3BNrKTEPdFjg== X-Received: by 2002:a17:903:2284:b0:185:3948:be7c with SMTP id b4-20020a170903228400b001853948be7cmr42440360plh.51.1666750585386; Tue, 25 Oct 2022 19:16:25 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 43/47] target/sh4: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:12 +1000 Message-Id: <20221026021116.1988449-44-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::102e; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x102e.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751213930100003 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/sh4/cpu.c | 16 ++++++++++++++++ target/sh4/translate.c | 10 ---------- 2 files changed, 16 insertions(+), 10 deletions(-) diff --git a/target/sh4/cpu.c b/target/sh4/cpu.c index 56c50530da..453268392b 100644 --- a/target/sh4/cpu.c +++ b/target/sh4/cpu.c @@ -50,6 +50,21 @@ static void superh_cpu_synchronize_from_tb(CPUState *cs, cpu->env.flags =3D tb->flags; } =20 +static void superh_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + SuperHCPU *cpu =3D SUPERH_CPU(cs); + + cpu->env.pc =3D data[0]; + cpu->env.flags =3D data[1]; + /* + * Theoretically delayed_pc should also be restored. In practice the + * branch instruction is re-executed after exception, so the delayed + * branch target will be recomputed. + */ +} + #ifndef CONFIG_USER_ONLY static bool superh_io_recompile_replay_branch(CPUState *cs, const TranslationBlock *tb) @@ -243,6 +258,7 @@ static const struct SysemuCPUOps sh4_sysemu_ops =3D { static const struct TCGCPUOps superh_tcg_ops =3D { .initialize =3D sh4_translate_init, .synchronize_from_tb =3D superh_cpu_synchronize_from_tb, + .restore_state_to_opc =3D superh_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D superh_cpu_tlb_fill, diff --git a/target/sh4/translate.c b/target/sh4/translate.c index 26231b2a5a..7db3468b01 100644 --- a/target/sh4/translate.c +++ b/target/sh4/translate.c @@ -2381,13 +2381,3 @@ void gen_intermediate_code(CPUState *cs, Translation= Block *tb, int max_insns, =20 translator_loop(cs, tb, max_insns, pc, host_pc, &sh4_tr_ops, &ctx.base= ); } - -void restore_state_to_opc(CPUSH4State *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; - env->flags =3D data[1]; - /* Theoretically delayed_pc should also be restored. In practice the - branch instruction is re-executed after exception, so the delayed - branch target will be recomputed. */ -} --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751158; cv=none; d=zohomail.com; s=zohoarc; b=MkTyw56hWoyHXFbpEKTT1maeQvF2Qc24AnGcX7DO6ZymXrCt3+sTNVvOQrTYzwewvJQ6z7SexaZIZOT2f1ULFWiaPmyhFR+/LWkTUfmqwUuWJuruPg0eYDBfpaBRxTF7Az1YfxtdGyqbhVbrqOxJMC+5AneinAg27yqLO5lYJmM= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751158; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=OoTrhOW+FgyqAL5tOpJBBH0wKZwhc1ALSUhVIqbqWFk=; b=P0WIFzLEmO0h/niJBz1RBnkwf/4wpuzYlP1wOS0AtbhdK4WaMAqaPD2qwkPN3N3hJACWDmj7Shb4dS2TB89Ez1bk5MB457CSForOfDzHna/ArnZ8psqd10EGzigLmObEKTV6zLoEX9vA1PpNzbV9xEma92LKgaOQvgYeuVvMrwk= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 16667511582897.644307086989102; Tue, 25 Oct 2022 19:25:58 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVyh-00085e-To; Tue, 25 Oct 2022 22:17:12 -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 1onVy6-0007pF-36 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:34 -0400 Received: from mail-pj1-x1035.google.com ([2607:f8b0:4864:20::1035]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVy2-0001sx-W0 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:32 -0400 Received: by mail-pj1-x1035.google.com with SMTP id l6so9114541pjj.0 for ; Tue, 25 Oct 2022 19:16:29 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=OoTrhOW+FgyqAL5tOpJBBH0wKZwhc1ALSUhVIqbqWFk=; b=ifM1s71OUGJ1BqD5n6gaPyBtJO/VbwERZTg9C5IN0m5JAkJC3se1gH3n2zKAbRxgzL 6FWuaXAWriDS5ttnOJZFgQBBulHyQEygEBVpDTWPNXyBpHkhv3fcUN9H+DKgML8Fu++I TiFtb7aspRY0V+oDi57BuvyB1bpjR1mfiMH846xtJ5p2+oVfiQWTjldN0sncZokV0vlh TngsB8csK6LPhirb/U3TAnU4tD0sdmDKGDd5XOSWqQZ0MAJaWnJYi/vnFoZ8DX+7W5jt AbdHnkCkd5ChOhzYMTqOEX3m2zWmr17stiDU4QX1KHffmhQrVJdhg1aSQZ7nISJjHnHX DlcA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=OoTrhOW+FgyqAL5tOpJBBH0wKZwhc1ALSUhVIqbqWFk=; b=lZ4XOEV2zWiiKHqffOk3Onc+8cQjeilM5ZIYFnX/T/piOdqvcLQ3ZdPTs4e4hSwIr3 pcIx3tiHZGhYGIRAcKTu9HTvWRFb1vgbgfbGR+L4Gma1okoWTEXgJyJxyNaL5Mm0s/gE TkcBpN1XkfkuU6ZQspcojJmlgS+1i9wx5JY2bzkVrHbBZuovVf8kL3sKwL5Cfi5PZlFX SqF43mjyW2t8o5wvF2khULgPqjyG+TRhZB0xSZHRyUyuNUg95d8OuejQxN4NsbPdQgzr QU7ZGoNS3sS9LRWMnb4BqqZ3uMSMid8ltyr+hJqZXr77L6GWOK+T4py1bpkLbXvxitak qQqQ== X-Gm-Message-State: ACrzQf0T5SGsnxdtakIMWifyAHnVMhPzdfLZiJl1lCINMzlzNEL1j9pb xAD5TlzG6jDRZHnAZsw1Wp4oFV5Tig7WWEJH X-Google-Smtp-Source: AMsMyM49ITgQUXcOddPYwSixRyMLyxrvq+lwqdWDIZL6RKhxnHqSATW/Hrk2Gdj7Q5NHQq+r+UoPag== X-Received: by 2002:a17:902:e9c2:b0:186:79dc:7d87 with SMTP id 2-20020a170902e9c200b0018679dc7d87mr25204153plk.59.1666750588174; Tue, 25 Oct 2022 19:16:28 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 44/47] target/sparc: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:13 +1000 Message-Id: <20221026021116.1988449-45-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::1035; envelope-from=richard.henderson@linaro.org; helo=mail-pj1-x1035.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751158543100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/sparc/cpu.h | 3 +++ target/sparc/cpu.c | 1 + target/sparc/translate.c | 7 +++++-- 3 files changed, 9 insertions(+), 2 deletions(-) diff --git a/target/sparc/cpu.h b/target/sparc/cpu.h index f80ea2e8cf..e478c5eb16 100644 --- a/target/sparc/cpu.h +++ b/target/sparc/cpu.h @@ -600,6 +600,9 @@ int sparc_cpu_memory_rw_debug(CPUState *cpu, vaddr addr, =20 /* translate.c */ void sparc_tcg_init(void); +void sparc_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data); =20 /* cpu-exec.c */ =20 diff --git a/target/sparc/cpu.c b/target/sparc/cpu.c index 1f9ef7afd8..4c3d08a875 100644 --- a/target/sparc/cpu.c +++ b/target/sparc/cpu.c @@ -872,6 +872,7 @@ static const struct SysemuCPUOps sparc_sysemu_ops =3D { static const struct TCGCPUOps sparc_tcg_ops =3D { .initialize =3D sparc_tcg_init, .synchronize_from_tb =3D sparc_cpu_synchronize_from_tb, + .restore_state_to_opc =3D sparc_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D sparc_cpu_tlb_fill, diff --git a/target/sparc/translate.c b/target/sparc/translate.c index 2cbbe2396a..34858eb95f 100644 --- a/target/sparc/translate.c +++ b/target/sparc/translate.c @@ -6011,9 +6011,12 @@ void sparc_tcg_init(void) } } =20 -void restore_state_to_opc(CPUSPARCState *env, TranslationBlock *tb, - target_ulong *data) +void sparc_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) { + SPARCCPU *cpu =3D SPARC_CPU(cs); + CPUSPARCState *env =3D &cpu->env; target_ulong pc =3D data[0]; target_ulong npc =3D data[1]; =20 --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751276; cv=none; d=zohomail.com; s=zohoarc; b=N18RFsdG2Iw6wlmg2jmqERgGf9nKCARjQEy9v4luvGeUFNA2ikl53p0cNRm348JThJZ+K2pnNXBaKXVNl5m1/nf7sg5o3AaNSdCpnqhWcvaShnsnlXnkJRBcJcJ9nZ1GdYF4ljzZV+FExVU37y4ZPEXSYNjJAoOhY9dAboDGLyM= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751276; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=zh4R/Fn+WhRA1To1jEk6vn5EnlhA+Z2cxPabIrA7c+g=; b=Ru+LsJ4Oc9mQOHTHLFZamlTGEn8e9kz9vN7Qr5vYhivTySUWg+lrqfHvWAgCuIadWfy4QTltsMXV3pAScLNqWijc3bIU8m1rHOzIL6DirKFJIlM60Aq3FEOfSzz76lJby4cntsjPtkObyWBZEaz8E+a7ZscRntscuypM007LZ7M= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751276109942.7241687948044; Tue, 25 Oct 2022 19:27:56 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVys-0008A0-19; Tue, 25 Oct 2022 22:17:22 -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 1onVy6-0007pn-Qj for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:39 -0400 Received: from mail-pf1-x42c.google.com ([2607:f8b0:4864:20::42c]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVy4-0001tF-4A for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:34 -0400 Received: by mail-pf1-x42c.google.com with SMTP id f140so13931769pfa.1 for ; Tue, 25 Oct 2022 19:16:31 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=zh4R/Fn+WhRA1To1jEk6vn5EnlhA+Z2cxPabIrA7c+g=; b=vIOkZ1Fu6dPAOuwgsAdLKSQBWTFJUlkaRwEEd5Wml3YXl44KOA0HWPaeaaa33ZUvLn bY7pZnOMDvo4hJvaCswpchgZGU6zrFc4Fc02N9nheASZmx2Q8Xjr2FMKpu5AuiMf+JZz XAVfAhC2FjZuxOC1sWWub8xW1UYydp9/6a6lGz43Q+lyHeM5lMcrrMCga0HhkNdwJqO0 +KRVwsP4uopKi+ZuzhUPMUXA7q/7BYeam+x1oZCUj0J+Cx63c/GHzCNuwqd07D+Zneca /zmpy2X36qm9uolLKn2plCdJacMFm2zRrmNTvAjXs7aJAzkjCh9lk8G3MhR/b7yiqtLE 0KQw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=zh4R/Fn+WhRA1To1jEk6vn5EnlhA+Z2cxPabIrA7c+g=; b=LetTOeJuPpd6Um3Q6LwhN/Ww4rfDCI5Kf3eCekGvX6CLdMqh1KEpMHAa0rK5ypQ//G wZSSBu2YPsPvMYZdYUMGLWph/8P+sHyurHiHMYUx7jk9v49z20hfI2CxXy64nApVQ82G mzW4iNxQZcRUWQKMq75gYpdFQKrasLFxbMt3jKGSIhXgRpV6Igq/VU+7pyRXp6UZ1IRp OFpOnQS8DId8q6jjFcpKPfmHKb4GC2m2khKmJXqvaopWa/NVwC5XHtk0IKR39hTfPVPy aM7AyPiTiviSn78+Q/qAS2rzPnog5nqzgZZD/nAJJ+4vq2u5f9RxUDM+XjIcO40wL/iU SZCQ== X-Gm-Message-State: ACrzQf0TPYyem7v/pzeX1yARNQ/XmS1XZuh+18nm61GYSu1QkWqOHVvv LmKgGRWDzx9A6YsfLJPfwIc2Ob0kfX4HA/gN X-Google-Smtp-Source: AMsMyM7b26Q7S98/bcvYIr6JDI3SAHrUGY52QEfQl//9PfbT0+lcQhTyTJr+1zy3Hq/y3Ekterwa5w== X-Received: by 2002:aa7:83cd:0:b0:563:5f54:d78c with SMTP id j13-20020aa783cd000000b005635f54d78cmr43006834pfn.66.1666750590772; Tue, 25 Oct 2022 19:16:30 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 45/47] target/tricore: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:14 +1000 Message-Id: <20221026021116.1988449-46-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::42c; envelope-from=richard.henderson@linaro.org; helo=mail-pf1-x42c.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751277210100005 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/tricore/cpu.c | 11 +++++++++++ target/tricore/translate.c | 6 ------ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/target/tricore/cpu.c b/target/tricore/cpu.c index ab7a1e3a6d..2c54a2825f 100644 --- a/target/tricore/cpu.c +++ b/target/tricore/cpu.c @@ -58,6 +58,16 @@ static void tricore_cpu_synchronize_from_tb(CPUState *cs, env->PC =3D tb_pc(tb); } =20 +static void tricore_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + TriCoreCPU *cpu =3D TRICORE_CPU(cs); + CPUTriCoreState *env =3D &cpu->env; + + env->PC =3D data[0]; +} + static void tricore_cpu_reset(DeviceState *dev) { CPUState *s =3D CPU(dev); @@ -161,6 +171,7 @@ static const struct SysemuCPUOps tricore_sysemu_ops =3D= { static const struct TCGCPUOps tricore_tcg_ops =3D { .initialize =3D tricore_tcg_init, .synchronize_from_tb =3D tricore_cpu_synchronize_from_tb, + .restore_state_to_opc =3D tricore_restore_state_to_opc, .tlb_fill =3D tricore_cpu_tlb_fill, }; =20 diff --git a/target/tricore/translate.c b/target/tricore/translate.c index a0558ead71..c5b7bfbf20 100644 --- a/target/tricore/translate.c +++ b/target/tricore/translate.c @@ -8886,12 +8886,6 @@ void gen_intermediate_code(CPUState *cs, Translation= Block *tb, int max_insns, &tricore_tr_ops, &ctx.base); } =20 -void -restore_state_to_opc(CPUTriCoreState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->PC =3D data[0]; -} /* * * Initialization --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666750880; cv=none; d=zohomail.com; s=zohoarc; b=fqBTFlrWsSrboTw2N3ZOcKcBrwL45jvX+pReQQVsVFycQmkhOCRN7J81UWDZyXVRH2xKSocElR1J3GymmMJp8Eov1LO9AHfQkVVX+LlXOaOKsOCyMvHfxRgc5B84L03H20QLeBE0gUGxDZbKaFgAP7lXz9Ax2HW1Me9ynJDedEc= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666750880; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=WY+A++lzDPuTw27rLB3LnIK22fG4kGVR5q1RFvEyx/k=; b=RKoerV6rxBKXKG6qAov0XfaNfli3T962+OD5J25sC7E8jX/zf+caOygRYhUh0mMbqG+JAUU/b7ld2bFS1FXhwuvOdS2pRJYHHi7pato0XYM8ov7Odmobg9FIvEFIzN25ciBbNChjxfz1lKNAJEjPMg4ZuiQZYWmosOYKysyrOT0= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666750880723221.07259177851654; Tue, 25 Oct 2022 19:21:20 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVyw-0008LJ-RY; Tue, 25 Oct 2022 22:17:26 -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 1onVy9-0007q7-V6 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:39 -0400 Received: from mail-pg1-x52b.google.com ([2607:f8b0:4864:20::52b]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVy7-0001ul-H8 for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:36 -0400 Received: by mail-pg1-x52b.google.com with SMTP id 20so13465586pgc.5 for ; Tue, 25 Oct 2022 19:16:34 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.31 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=WY+A++lzDPuTw27rLB3LnIK22fG4kGVR5q1RFvEyx/k=; b=zVuNQJWbBQyzVwn8jNobr3vINp3RzAIN/vCrPRxyqMqYSJw+wp3XHEUb8WDJNjvyCe gYVGwY0CuAwJh++yKLCHspj/EBeYTAAoeRbYxlKSnP8gw3tTlLMoxS4tgerDENWQJ3BI bT8XX4Y3rzpaFR2RHU2hFGHVornXjUG88UW4MCle0C8t+rnKe/rWj38HSXTB//XJ2ArQ q00nfpaj4NqIYkjQcVuziD5m1+1cq+7jOqFsnhCTNZLZP3jJWhZTvr3bfEzKRZxPuNu4 aw1CCkSxfY1sf+fvp2j+PaT1sjhfZZLld3I/xz6rU59jkxdjXDuti/Ui4rkSuYjawwEw gQpw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=WY+A++lzDPuTw27rLB3LnIK22fG4kGVR5q1RFvEyx/k=; b=ev0XCFpfXJSX4XtUMGKdluAwmOiFfQRKvQtFzuCrEqMHZWKqqFxsSN+FNCr9PR7dtI NIJS28o2SXyF8WG3ZOX/CP5OLbZp3vDHOap4ILS7z1ac4Nvai0Nqf4fb4CDD3a3LkjiT U64x7/vPURd14SotCWgC8j6hBI1M6CN8aBl7nMKEvwbGGSlU9kUMDESTPQWuJhY5QW+Q hEQYHFJzznFkEm7KG/kHzsmYxwJCJz+HD69OFBMqiMUisUiqhhwOm2RIth9jmhPtu1ed 0XMY/2f3iXC5oVb8lMnEaEHVXXHc+Q8OJgPJtTDokJinb1UL5VUMhSKHOncKuuEg2cM3 ByTw== X-Gm-Message-State: ACrzQf3tVbLqhws6dYEl7Vj/ac/CLfbyzeupQi92xCEbXHHsDnpDAmuJ CAtpJGcgOYl89TM9YrSk/fz1LLYhL5X13MgM X-Google-Smtp-Source: AMsMyM72HnIXeDGad6DAPvg9kDVt6PtaUSkj81g4Jo8nOwbBsgfeM80bZTOmBx9gY9mNwmOpnCL1iA== X-Received: by 2002:a63:6a48:0:b0:43a:18ce:4e08 with SMTP id f69-20020a636a48000000b0043a18ce4e08mr36180789pgc.432.1666750593595; Tue, 25 Oct 2022 19:16:33 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PULL 46/47] target/xtensa: Convert to tcg_ops restore_state_to_opc Date: Wed, 26 Oct 2022 12:11:15 +1000 Message-Id: <20221026021116.1988449-47-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" 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=2607:f8b0:4864:20::52b; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x52b.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666750882202100001 Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Richard Henderson --- target/xtensa/cpu.c | 10 ++++++++++ target/xtensa/translate.c | 6 ------ 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/target/xtensa/cpu.c b/target/xtensa/cpu.c index cbbe0e84a2..09923301c4 100644 --- a/target/xtensa/cpu.c +++ b/target/xtensa/cpu.c @@ -51,6 +51,15 @@ static vaddr xtensa_cpu_get_pc(CPUState *cs) return cpu->env.pc; } =20 +static void xtensa_restore_state_to_opc(CPUState *cs, + const TranslationBlock *tb, + const uint64_t *data) +{ + XtensaCPU *cpu =3D XTENSA_CPU(cs); + + cpu->env.pc =3D data[0]; +} + static bool xtensa_cpu_has_work(CPUState *cs) { #ifndef CONFIG_USER_ONLY @@ -215,6 +224,7 @@ static const struct SysemuCPUOps xtensa_sysemu_ops =3D { static const struct TCGCPUOps xtensa_tcg_ops =3D { .initialize =3D xtensa_translate_init, .debug_excp_handler =3D xtensa_breakpoint_handler, + .restore_state_to_opc =3D xtensa_restore_state_to_opc, =20 #ifndef CONFIG_USER_ONLY .tlb_fill =3D xtensa_cpu_tlb_fill, diff --git a/target/xtensa/translate.c b/target/xtensa/translate.c index bdd4690a5c..77bcd71030 100644 --- a/target/xtensa/translate.c +++ b/target/xtensa/translate.c @@ -1355,12 +1355,6 @@ void xtensa_cpu_dump_state(CPUState *cs, FILE *f, in= t flags) } } =20 -void restore_state_to_opc(CPUXtensaState *env, TranslationBlock *tb, - target_ulong *data) -{ - env->pc =3D data[0]; -} - static void translate_abs(DisasContext *dc, const OpcodeArg arg[], const uint32_t par[]) { --=20 2.34.1 From nobody Tue May 21 22:53:50 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; 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=linaro.org ARC-Seal: i=1; a=rsa-sha256; t=1666751418; cv=none; d=zohomail.com; s=zohoarc; b=KmKT5gQQOpjWQW+T8hZsT/EX6qkMRkj8fD2PN1/FFVGisbwWuO7oLhy+LEybDoIBrqUAYAOsH/l3bkH66e3FBs8FRy/MkVdWCzSGRA4gYoPM4mrpl7HCeF07ASSwIv+W5TMfUaLc/BRp03Y9429X+0Pm912SImZmkp5T4V4QNIc= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1666751418; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=+oSBBoEPz0C6PveutCusSV+WpNj8J88GSxwKesi4JlU=; b=G0Q9OkVeFnAAKsPK8ugn7Iy9lwRSODN7g9giOP46qDQoBIEhSB9XI7nipeOmIj6+yIBKuzxz9/LjrnaQ4hJFqN1dUs7p//cxJ8X46nt3yV6+Mc3igw67XFc6DsFaWvwT1aDi3MU5uhyLnrlTqa70UnOOgJF835S4kkGZv5RbN3A= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; 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 1666751418266472.30781278846575; Tue, 25 Oct 2022 19:30:18 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1onVyv-0008FW-ED; Tue, 25 Oct 2022 22:17:25 -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 1onVyB-0007qN-Qz for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:42 -0400 Received: from mail-pg1-x52e.google.com ([2607:f8b0:4864:20::52e]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1onVy9-0001x2-QC for qemu-devel@nongnu.org; Tue, 25 Oct 2022 22:16:39 -0400 Received: by mail-pg1-x52e.google.com with SMTP id s196so13469796pgs.3 for ; Tue, 25 Oct 2022 19:16:37 -0700 (PDT) Received: from stoup.hotspotlogin.services ([103.100.225.182]) by smtp.gmail.com with ESMTPSA id q18-20020a17090311d200b0018123556931sm1819732plh.204.2022.10.25.19.16.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 Oct 2022 19:16:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=+oSBBoEPz0C6PveutCusSV+WpNj8J88GSxwKesi4JlU=; b=AkNZPiDO8jFpAx8HjjbalHvLi4/flMxmim7ah3dmqkak80TJnaLCdYTpBtnCFygwFY BhP/PyRBZq3wJACmtOFp+KPcwwJqWaEp3R146RwcPXl12oG6D9DiTBw8Z2Deuj2G/fAl gZeoZe4xaPBKgCTeB0pFTDl7n9Fk2YNC2LSBG1FzjNRDU1FdGusJM2Y+hov3pw+n94Yq fYw7SXB0dmgpHrfKN16yyOc0bewLFgUhWGS7EGzvBVyrHCc9+8lCIAUPKS9jTTXXtlDZ FR7O3zdTOHAlTE3l7zRdrm8B35ptyIsK5xMZgWRHkPLrYO1R9yIMj9yVzxMhAPXlZU6n qy+A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=+oSBBoEPz0C6PveutCusSV+WpNj8J88GSxwKesi4JlU=; b=CDoEUolWqzwkqI+2hG6CWn6Bn0z2+WojNP+Nt8u62RKC3pl5Jei3VGGCL5S8ndyHAR T62hDXmHua0J/UYNIjktDq2sTDq487V/snd/n/FbMaYcB5WElnKSrauW7XuwUtSRxFEX 436d1K+jgjLKZ8Jrc2mY5v4PcNOqZzME6NGlHYyWGNSKojumU7/rufKy4cnRJ3ncIwfE hm83C7oJ00isiK0S/MdviR5A06C1yy8lvPRIkvasmFR803nOc8TjrR36osHOZSMdryiH PCvvfQp6yTioxlIcVGJp5J7BGqsix71Ym1WI5PQH9012WUcXybSAqi82MHgV9onCTbsz qF2A== X-Gm-Message-State: ACrzQf1y+x97YdAZHtdb5+S4orm1BMcw3WcYl25UdYNdL6HgxNHO+dtx KS+TLzRJfwLm656tmLpwsD0Sw+ToNJ04VhNZ X-Google-Smtp-Source: AMsMyM7CyDlq5xwBtfz80OCLEW6jWrT1uHC4X/jPWO86cNupzv6PbNf1btcm2hofQ1yExn44klittw== X-Received: by 2002:a63:4384:0:b0:43a:18ce:f98a with SMTP id q126-20020a634384000000b0043a18cef98amr34893921pga.273.1666750596292; Tue, 25 Oct 2022 19:16:36 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, Claudio Fontana Subject: [PULL 47/47] accel/tcg: Remove restore_state_to_opc function Date: Wed, 26 Oct 2022 12:11:16 +1000 Message-Id: <20221026021116.1988449-48-richard.henderson@linaro.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221026021116.1988449-1-richard.henderson@linaro.org> References: <20221026021116.1988449-1-richard.henderson@linaro.org> 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=2607:f8b0:4864:20::52e; envelope-from=richard.henderson@linaro.org; helo=mail-pg1-x52e.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: , Sender: "Qemu-devel" Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @linaro.org) X-ZM-MESSAGEID: 1666751419880100003 Content-Type: text/plain; charset="utf-8" All targets have been updated. Use the tcg_ops target hook exclusively, which allows the compat code to be removed. Reviewed-by: Claudio Fontana Signed-off-by: Richard Henderson --- include/exec/exec-all.h | 3 --- accel/tcg/translate-all.c | 16 ++-------------- 2 files changed, 2 insertions(+), 17 deletions(-) diff --git a/include/exec/exec-all.h b/include/exec/exec-all.h index 3b5e84240b..e948992a80 100644 --- a/include/exec/exec-all.h +++ b/include/exec/exec-all.h @@ -39,9 +39,6 @@ typedef ram_addr_t tb_page_addr_t; #define TB_PAGE_ADDR_FMT RAM_ADDR_FMT #endif =20 -void restore_state_to_opc(CPUArchState *env, TranslationBlock *tb, - target_ulong *data) __attribute__((weak)); - /** * cpu_restore_state: * @cpu: the vCPU state is to be restore to diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 4d8783efc7..f185356a36 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -254,7 +254,7 @@ static int encode_search(TranslationBlock *tb, uint8_t = *block) int cpu_restore_state_from_tb(CPUState *cpu, TranslationBlock *tb, uintptr_t searched_pc, bool reset_icount) { - target_ulong data[TARGET_INSN_START_WORDS]; + uint64_t data[TARGET_INSN_START_WORDS]; uintptr_t host_pc =3D (uintptr_t)tb->tc.ptr; const uint8_t *p =3D tb->tc.ptr + tb->tc.size; int i, j, num_insns =3D tb->icount; @@ -295,19 +295,7 @@ int cpu_restore_state_from_tb(CPUState *cpu, Translati= onBlock *tb, cpu_neg(cpu)->icount_decr.u16.low +=3D num_insns - i; } =20 - { - const struct TCGCPUOps *ops =3D cpu->cc->tcg_ops; - __typeof(ops->restore_state_to_opc) restore =3D ops->restore_state= _to_opc; - if (restore) { - uint64_t d64[TARGET_INSN_START_WORDS]; - for (i =3D 0; i < TARGET_INSN_START_WORDS; ++i) { - d64[i] =3D data[i]; - } - restore(cpu, tb, d64); - } else { - restore_state_to_opc(cpu->env_ptr, tb, data); - } - } + cpu->cc->tcg_ops->restore_state_to_opc(cpu, tb, data); =20 #ifdef CONFIG_PROFILER qatomic_set(&prof->restore_time, --=20 2.34.1