{"id":2231001,"url":"http://patchwork.ozlabs.org/api/1.1/patches/2231001/?format=json","web_url":"http://patchwork.ozlabs.org/project/qemu-devel/patch/20260430093810.2762539-18-peter.maydell@linaro.org/","project":{"id":14,"url":"http://patchwork.ozlabs.org/api/1.1/projects/14/?format=json","name":"QEMU Development","link_name":"qemu-devel","list_id":"qemu-devel.nongnu.org","list_email":"qemu-devel@nongnu.org","web_url":"","scm_url":"","webscm_url":""},"msgid":"<20260430093810.2762539-18-peter.maydell@linaro.org>","date":"2026-04-30T09:38:02","name":"[v2,17/25] target/arm: Implement translate_for_debug","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"07df5acc561e144ce3d7b2027e1fe45aa6ed8dfa","submitter":{"id":5111,"url":"http://patchwork.ozlabs.org/api/1.1/people/5111/?format=json","name":"Peter Maydell","email":"peter.maydell@linaro.org"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/qemu-devel/patch/20260430093810.2762539-18-peter.maydell@linaro.org/mbox/","series":[{"id":502257,"url":"http://patchwork.ozlabs.org/api/1.1/series/502257/?format=json","web_url":"http://patchwork.ozlabs.org/project/qemu-devel/list/?series=502257","date":"2026-04-30T09:37:47","name":"Handle sub-page granularity in cpu_memory_rw_debug()","version":2,"mbox":"http://patchwork.ozlabs.org/series/502257/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2231001/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2231001/checks/","tags":{},"headers":{"Return-Path":"<qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org>","X-Original-To":"incoming@patchwork.ozlabs.org","Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=linaro.org header.i=@linaro.org header.a=rsa-sha256\n header.s=google header.b=WYywqCBb;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=nongnu.org\n (client-ip=209.51.188.17; helo=lists1p.gnu.org;\n envelope-from=qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org;\n receiver=patchwork.ozlabs.org)"],"Received":["from lists1p.gnu.org (lists1p.gnu.org [209.51.188.17])\n\t(using TLSv1.2 with cipher ECDHE-ECDSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4g5pzS1ll5z1yGq\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 30 Apr 2026 19:39:32 +1000 (AEST)","from localhost ([::1] helo=lists1p.gnu.org)\n\tby lists1p.gnu.org with esmtp (Exim 4.90_1)\n\t(envelope-from <qemu-devel-bounces@nongnu.org>)\n\tid 1wINrF-0005Lo-V9; Thu, 30 Apr 2026 05:38:58 -0400","from eggs.gnu.org ([2001:470:142:3::10])\n by lists1p.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <peter.maydell@linaro.org>)\n id 1wINr7-0004zy-Pc\n for qemu-devel@nongnu.org; Thu, 30 Apr 2026 05:38:49 -0400","from mail-wr1-x429.google.com ([2a00:1450:4864:20::429])\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128)\n (Exim 4.90_1) (envelope-from <peter.maydell@linaro.org>)\n id 1wINqt-0002gs-R6\n for qemu-devel@nongnu.org; Thu, 30 Apr 2026 05:38:49 -0400","by mail-wr1-x429.google.com with SMTP id\n ffacd0b85a97d-43fde5b81a1so578191f8f.0\n for <qemu-devel@nongnu.org>; Thu, 30 Apr 2026 02:38:35 -0700 (PDT)","from lanath.. (wildly.archaic.org.uk. [81.2.115.145])\n by smtp.gmail.com with ESMTPSA id\n ffacd0b85a97d-447b421721fsm10816795f8f.15.2026.04.30.02.38.32\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Thu, 30 Apr 2026 02:38:33 -0700 (PDT)"],"DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=linaro.org; s=google; t=1777541914; x=1778146714; darn=nongnu.org;\n h=content-transfer-encoding:mime-version:references:in-reply-to\n :message-id:date:subject:cc:to:from:from:to:cc:subject:date\n :message-id:reply-to;\n bh=c9snYL6N/5LnNtzLZ3Lr1l12O+pLGtTzbqLqghTUwtI=;\n b=WYywqCBbQzH1VQkJNb/NHvj6KDKtDM6jVMT11PWLdrXfC1aICvpaU/RC0SnzRU5qE7\n T/3ug6f6fCDN6lqoOTOrJDW6l9FbKUntWwvexYgoWl/VlUgpA6XmMTa1UZuktqNXJJEY\n aG/K4rUHoIv+Q5MbJ5M6ZglCqh1cG7U9ujbgR915g43Df7BYu/KbxIfaAhkamPdFBZYa\n ep6fDa1FRXhsvBM6vUBcKVzX2w5Wf/crA+HM9t1JiRB30I2wtdUEOnx0inhO/4wFcgyr\n NDUA/NIEiUH4QCKsNcqDcpJUcHTFOtbOcO64jfk4bPg51nT3BWK9ti2eacPVJAmzpR1s\n QxEQ==","X-Google-DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20251104; t=1777541914; x=1778146714;\n h=content-transfer-encoding:mime-version:references:in-reply-to\n :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from\n :to:cc:subject:date:message-id:reply-to;\n bh=c9snYL6N/5LnNtzLZ3Lr1l12O+pLGtTzbqLqghTUwtI=;\n b=qcjFFMDA6bWue5GlALVcqKukRWsW+doO+W1hmKbi4DNxRy4p0DUEcyoIbrRUewHbVZ\n QAeIfBLyF43PAMU302EgUVWEVA27sdVYxDSVWMz+pTL6FbIFAFfSqTQB4iNUFQYIDdZ6\n Memmcto/v1ZmhJRY5djdeaxjpf2IiD4V0WtcOy7nzN+HHxm9lv6MhTaaHgiqJIngWIMm\n T11B1LCldJJmczMfCogv7KGtw/OqgxaY8Jz2be56fxW9q/QK0sDkVhGK4ktysiiDqnuj\n YR2vM7xTTW2udDUWL78nU39ieNBtfeYgIkg1MCfigk4Ybrt198XHIf6y1VL48yILobdS\n 0TGQ==","X-Gm-Message-State":"AOJu0YyKgQlFwOZz6m7MZ4Aq/Ob5LKQ6xcBcp9+66xZXUnyvEKp6e+Ox\n 2+4dobZMG6W40VSiN80LOTp3XO9sVOyBHWAsvIx9YMgJVMfL6iJufOEk/9XbgofajAc5Z3n2xop\n +3xcS","X-Gm-Gg":"AeBDiev+lrM7kC3zCNFjzh3HqF0y7g0jz+bLt5lWiQayARPQ0DypriCLG2CGT8pdbmP\n wmgthrtE4bCC2SHxLJO+Uzjvh0P7RP0e5fCSozXTRdIF1fyA2Xkx2AuE9g5k1PwCw5SeMjlEorT\n TOo4Cp+hUTw6B7R0a9zzRFVD2rYy8vi0rjfvf5BMPliifYZFJIP4p11HN2uSPkwTYSMQ0cDc6VL\n c/SclVR/aFJTL0H3hqfGgStkynKjGNOPDDhZ8q8gCRCM9ZEEljqmmalS/zikR6vNZV/W/myDQO+\n kWwSBy2unJhE57ssJsbjJibZW3JMWN0tRKZVVXM8Asdal4D5uPzl1tI9xdbgtjdC7Yie0SzDqUu\n hBXe7cwrk8QUOrb3uoIM1cQwFSW/dcs585a36fSQAQ1UidxaqlEFgQIf55CNek9TDRsdbTcd3Xd\n cPhNtx4wiB0DqAnqTRKoYN9dCFoF8iMhrwwKte9nn96i92ITxGHPX/M2EklgP3WLWyAH1e+Bo/b\n tBjH2OO4FpWHcbh1BnXFm8DjxJiOV8qiRFeyU+2Pw==","X-Received":"by 2002:a05:6000:2486:b0:43d:7d24:b4ff with SMTP id\n ffacd0b85a97d-4493f42e211mr3104854f8f.40.1777541914093;\n Thu, 30 Apr 2026 02:38:34 -0700 (PDT)","From":"Peter Maydell <peter.maydell@linaro.org>","To":"qemu-devel@nongnu.org","Cc":"qemu-arm@nongnu.org, qemu-ppc@nongnu.org, qemu-riscv@nongnu.org,\n qemu-s390x@nongnu.org,\n =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= <philmd@linaro.org>,\n Marcel Apfelbaum <marcel.apfelbaum@gmail.com>,\n Yanan Wang <wangyanan55@huawei.com>, Zhao Liu <zhao1.liu@intel.com>,\n Paolo Bonzini <pbonzini@redhat.com>,\n Richard Henderson <richard.henderson@linaro.org>,\n \"Dr. David Alan Gilbert\" <dave@treblig.org>,\n =?utf-8?q?Alex_Benn=C3=A9e?= <alex.bennee@linaro.org>,\n Alexandre Iooss <erdnaxe@crans.org>, Mahmoud Mandour <ma.mandourr@gmail.com>,\n Peter Xu <peterx@redhat.com>, \"Edgar E. Iglesias\" <edgar.iglesias@gmail.com>,\n Jiaxun Yang <jiaxun.yang@flygoat.com>, Nicholas Piggin <npiggin@gmail.com>,\n Chinmay Rath <rathc@linux.ibm.com>, Glenn Miles <milesg@linux.ibm.com>,\n Palmer Dabbelt <palmer@dabbelt.com>,\n Alistair Francis <alistair.francis@wdc.com>, Weiwei Li <liwei1518@gmail.com>,\n Daniel Henrique Barboza <daniel.barboza@oss.qualcomm.com>,\n Liu Zhiwei <zhiwei_liu@linux.alibaba.com>,\n Chao Liu <chao.liu.zevorn@gmail.com>, Ilya Leoshkevich <iii@linux.ibm.com>,\n David Hildenbrand <david@kernel.org>,\n Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>,\n Artyom Tarasenko <atar4qemu@gmail.com>, Max Filippov <jcmvbkbc@gmail.com>","Subject":"[PATCH v2 17/25] target/arm: Implement translate_for_debug","Date":"Thu, 30 Apr 2026 10:38:02 +0100","Message-ID":"<20260430093810.2762539-18-peter.maydell@linaro.org>","X-Mailer":"git-send-email 2.43.0","In-Reply-To":"<20260430093810.2762539-1-peter.maydell@linaro.org>","References":"<20260430093810.2762539-1-peter.maydell@linaro.org>","MIME-Version":"1.0","Content-Type":"text/plain; charset=UTF-8","Content-Transfer-Encoding":"8bit","Received-SPF":"pass client-ip=2a00:1450:4864:20::429;\n envelope-from=peter.maydell@linaro.org; helo=mail-wr1-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,\n DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1,\n RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001,\n 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":"qemu development <qemu-devel.nongnu.org>","List-Unsubscribe":"<https://lists.nongnu.org/mailman/options/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=unsubscribe>","List-Archive":"<https://lists.nongnu.org/archive/html/qemu-devel>","List-Post":"<mailto:qemu-devel@nongnu.org>","List-Help":"<mailto:qemu-devel-request@nongnu.org?subject=help>","List-Subscribe":"<https://lists.nongnu.org/mailman/listinfo/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=subscribe>","Errors-To":"qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org","Sender":"qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org"},"content":"Implement the translate_for_debug method instead of the\nget_phys_addr_attrs_debug one.  This allows us to pass the caller the\nlg_page_size from our internal GetPhysAddrResult struct.\n\nAwkwardly, translate_for_debug's \"true on success\" convention\nis the opposite of the one we use internally in ptw.c, so\nwe have to be careful about the sense of the return values.\nThis corresponds to the way that arm_cpu_tlb_fill_align()\nalso has to return true when get_phys_addr() returns false.\n\nSigned-off-by: Peter Maydell <peter.maydell@linaro.org>\nReviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>\nMessage-id: 20260417173105.1648172-17-peter.maydell@linaro.org\n---\nv1->v2: use 'fault' for the bool variable, not 'ret'\n---\n target/arm/cpu.c       |  2 +-\n target/arm/cpu.h       |  3 ---\n target/arm/internals.h |  4 ++++\n target/arm/ptw.c       | 39 +++++++++++++++++++++++----------------\n 4 files changed, 28 insertions(+), 20 deletions(-)","diff":"diff --git a/target/arm/cpu.c b/target/arm/cpu.c\nindex 9e6b4b1559..eaa1805160 100644\n--- a/target/arm/cpu.c\n+++ b/target/arm/cpu.c\n@@ -2436,7 +2436,7 @@ static vaddr aarch64_untagged_addr(CPUState *cs, vaddr x)\n \n static const struct SysemuCPUOps arm_sysemu_ops = {\n     .has_work = arm_cpu_has_work,\n-    .get_phys_addr_attrs_debug = arm_cpu_get_phys_addr_attrs_debug,\n+    .translate_for_debug = arm_cpu_translate_for_debug,\n     .asidx_from_attrs = arm_asidx_from_attrs,\n     .write_elf32_note = arm_cpu_write_elf32_note,\n     .write_elf64_note = arm_cpu_write_elf64_note,\ndiff --git a/target/arm/cpu.h b/target/arm/cpu.h\nindex b1563a4d43..6fd7c4bd30 100644\n--- a/target/arm/cpu.h\n+++ b/target/arm/cpu.h\n@@ -1233,9 +1233,6 @@ extern const VMStateDescription vmstate_arm_cpu;\n void arm_cpu_do_interrupt(CPUState *cpu);\n void arm_v7m_cpu_do_interrupt(CPUState *cpu);\n \n-hwaddr arm_cpu_get_phys_addr_attrs_debug(CPUState *cpu, vaddr addr,\n-                                         MemTxAttrs *attrs);\n-\n typedef struct ARMGranuleProtectionConfig {\n     /* GPCCR_EL3 */\n     uint64_t gpccr;\ndiff --git a/target/arm/internals.h b/target/arm/internals.h\nindex a632584a4e..81b2973b20 100644\n--- a/target/arm/internals.h\n+++ b/target/arm/internals.h\n@@ -1540,6 +1540,10 @@ bool pmsav8_mpu_lookup(CPUARMState *env, uint32_t address,\n \n void arm_log_exception(CPUState *cs);\n \n+/* Implementation of SysemuCPUOps::translate_for_debug */\n+bool arm_cpu_translate_for_debug(CPUState *cs, vaddr addr,\n+                                 TranslateForDebugResult *result);\n+\n #endif /* !CONFIG_USER_ONLY */\n \n /*\ndiff --git a/target/arm/ptw.c b/target/arm/ptw.c\nindex 8be6f243e6..cc7f78c329 100644\n--- a/target/arm/ptw.c\n+++ b/target/arm/ptw.c\n@@ -3922,8 +3922,9 @@ bool get_phys_addr(CPUARMState *env, vaddr address,\n                              memop, result, fi);\n }\n \n-static hwaddr arm_cpu_get_phys_addr(CPUARMState *env, vaddr addr,\n-                                    MemTxAttrs *attrs, ARMMMUIdx mmu_idx)\n+static bool arm_cpu_get_phys_addr(CPUARMState *env, vaddr addr,\n+                                  TranslateForDebugResult *result,\n+                                  ARMMMUIdx mmu_idx)\n {\n     S1Translate ptw = {\n         .in_mmu_idx = mmu_idx,\n@@ -3934,26 +3935,31 @@ static hwaddr arm_cpu_get_phys_addr(CPUARMState *env, vaddr addr,\n     };\n     GetPhysAddrResult res = {};\n     ARMMMUFaultInfo fi = {};\n-    bool ret = get_phys_addr_gpc(env, &ptw, addr, MMU_DATA_LOAD, 0, &res, &fi);\n-    *attrs = res.f.attrs;\n+    bool fault = get_phys_addr_gpc(env, &ptw, addr, MMU_DATA_LOAD, 0, &res, &fi);\n \n-    if (ret) {\n-        return -1;\n+    if (!fault) {\n+        /* translation succeeded */\n+        result->physaddr = res.f.phys_addr;\n+        result->attrs = res.f.attrs;\n+        result->lg_page_size = res.f.lg_page_size;\n     }\n-    return res.f.phys_addr;\n+    return fault;\n }\n \n-hwaddr arm_cpu_get_phys_addr_attrs_debug(CPUState *cs, vaddr addr,\n-                                         MemTxAttrs *attrs)\n+bool arm_cpu_translate_for_debug(CPUState *cs, vaddr addr,\n+                                 TranslateForDebugResult *result)\n {\n     ARMCPU *cpu = ARM_CPU(cs);\n     CPUARMState *env = &cpu->env;\n     ARMMMUIdx mmu_idx = arm_mmu_idx(env);\n \n-    hwaddr res = arm_cpu_get_phys_addr(env, addr, attrs, mmu_idx);\n-\n-    if (res != -1) {\n-        return res;\n+    /*\n+     * Note that this function returns true on translation success,\n+     * but arm_cpu_get_phys_addr() and all the other get_phys_addr\n+     * style functions in this file return true on failure.\n+     */\n+    if (!arm_cpu_get_phys_addr(env, addr, result, mmu_idx)) {\n+        return true;\n     }\n \n     /*\n@@ -3964,11 +3970,12 @@ hwaddr arm_cpu_get_phys_addr_attrs_debug(CPUState *cs, vaddr addr,\n     switch (mmu_idx) {\n     case ARMMMUIdx_E10_1:\n     case ARMMMUIdx_E10_1_PAN:\n-        return arm_cpu_get_phys_addr(env, addr, attrs, ARMMMUIdx_E10_0);\n+        return !arm_cpu_get_phys_addr(env, addr, result, ARMMMUIdx_E10_0);\n     case ARMMMUIdx_E20_2:\n     case ARMMMUIdx_E20_2_PAN:\n-        return arm_cpu_get_phys_addr(env, addr, attrs, ARMMMUIdx_E20_0);\n+        return !arm_cpu_get_phys_addr(env, addr, result, ARMMMUIdx_E20_0);\n     default:\n-        return -1;\n+        /* translation failed */\n+        return false;\n     }\n }\n","prefixes":["v2","17/25"]}