Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/1.1/patches/2231030/?format=api
{ "id": 2231030, "url": "http://patchwork.ozlabs.org/api/1.1/patches/2231030/?format=api", "web_url": "http://patchwork.ozlabs.org/project/qemu-devel/patch/20260430093810.2762539-19-peter.maydell@linaro.org/", "project": { "id": 14, "url": "http://patchwork.ozlabs.org/api/1.1/projects/14/?format=api", "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-19-peter.maydell@linaro.org>", "date": "2026-04-30T09:38:03", "name": "[v2,18/25] system/physmem: Use translate_for_debug() in cpu_memory_rw_debug()", "commit_ref": null, "pull_url": null, "state": "new", "archived": false, "hash": "3c6bf65137873667c3334dab31f94aa10cc82dd0", "submitter": { "id": 5111, "url": "http://patchwork.ozlabs.org/api/1.1/people/5111/?format=api", "name": "Peter Maydell", "email": "peter.maydell@linaro.org" }, "delegate": null, "mbox": "http://patchwork.ozlabs.org/project/qemu-devel/patch/20260430093810.2762539-19-peter.maydell@linaro.org/mbox/", "series": [ { "id": 502257, "url": "http://patchwork.ozlabs.org/api/1.1/series/502257/?format=api", "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/2231030/comments/", "check": "pending", "checks": "http://patchwork.ozlabs.org/api/patches/2231030/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=dwHdPbSm;\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 4g5q4m5jzKz1yGq\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 30 Apr 2026 19:44:08 +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 1wINrH-0005Pr-Vx; Thu, 30 Apr 2026 05:39:00 -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 1wINrB-0005Ac-KW\n for qemu-devel@nongnu.org; Thu, 30 Apr 2026 05:38:53 -0400", "from mail-wm1-x332.google.com ([2a00:1450:4864:20::332])\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 1wINqy-0002kL-7m\n for qemu-devel@nongnu.org; Thu, 30 Apr 2026 05:38:53 -0400", "by mail-wm1-x332.google.com with SMTP id\n 5b1f17b1804b1-488e1a8ac40so6808405e9.2\n for <qemu-devel@nongnu.org>; Thu, 30 Apr 2026 02:38:36 -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.34\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Thu, 30 Apr 2026 02:38:34 -0700 (PDT)" ], "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=linaro.org; s=google; t=1777541916; x=1778146716; 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=ZNtoNR8zwSaxp92UruVR20bb34aPvKjX5U1Njv0t9eU=;\n b=dwHdPbSmuiYdOi55FdKawJhr7wyiK4UdY2WY2ukR6+CYKlEHqzbx3oxi6lqwuDU6bB\n t7f7Ho0zNHAHBH5u2JP5p11EZMlg+L28lW1ZyYDPYEogmiXuGs9bc+XOMryBYsgNiv0T\n 1CTErAMovwkLuySD1B7vgf8MCKtkrBERt2F82xOX1UGWNp+FWs+5CwUHgTf5rIiujp41\n vY1a0AKs7YJwk6Wbz1wQxV7i4znDUCuWtSZFyvTCmGEDxQDEM3A6Lr41SdXQqiLw98tD\n dYsVGMQYabqRPEAtGn0XDRXaHQGswmXOOrH2i4xAQR6HDt0R2ZKLF9E/QVEBZ0Y/cHy/\n 6dmQ==", "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20251104; t=1777541916; x=1778146716;\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=ZNtoNR8zwSaxp92UruVR20bb34aPvKjX5U1Njv0t9eU=;\n b=p6S/vNgsz5F3gIHBPj6TDmvwzOlQUooKKYEKg/PHpuO+4Dw/IjSj578p96lQDVvOh8\n PDvC3qwdB75VppWqnNjYWY4ZogAA/EN0cP60Rw1huPLaXT6Lz6/g6HeZpS2edH4cNyM4\n e6ETIp1vBFRw0rmD5H6owlhsQgilAZiTby1HSwPHK2TF+2nF4uxqsD2ggs7G0q1ek98L\n hRikmE7ZkF+waQHewiwJNsLsJhITWckNTTBL7qw846TEFEDpYUyl1OEU49Abnq4/cEkr\n oQ2P0RyfYwmLZzkWGMN2A3ioAXB/wPSSO0eGCZj0lPi/T4aPf9m6e3yO4QOC5+1fr+R1\n T76A==", "X-Gm-Message-State": "AOJu0Yzh5QI3ErSQclq4oKISgLbP0gAuvQ0omQB87C+0Bg+0Xmg/anxi\n LnLC7X5WiUwovjrDcBEaNjJ8wnuCuk+56lFXid7pI5LtrAgjqi9TVjIfCYsCYygZ9iXR3Pkpbbi\n 2H/QK", "X-Gm-Gg": "AeBDieuajgj3QwvECA72OZWZBPgMqknQqa5NrAB7DgcU241zGDmIbT+dh8SioiiwqpT\n hI2U3zYxiZd9lHRgzyV8p/S0aKWuJ8B/waJLMlEvbuxTfjI5By0BCnrfRkytIdmT801PjLjkCbK\n k59JdStqX0vm5U2sVTpRY/8miH0UYrEyPZDSMmy9FpVbm21hCu2g/32Oi5mWqQjb+zU2vXBZrqw\n vUS9N4HLozlZAtkrOowS2BfnNKjE67sP3yMUZ86+dmL0cxisn60tlyQWirDHQ3UWnydgbJDAKUP\n Bws9G825j72wTtzhfOQSpVK4sorca4V/Q2ceEOlwHbMdyouaj8DyCRQbpQmG0gx+LUSyZ9CSVun\n xymJnO/UhbdAMWoPp3Pcb6LuQc2HvMmWp12zdrX0potJBcM8mAwQKhLRQT4GR80cldRCJTBmybg\n ddcr5nN8TiJ0ZizZXM5fteopo5HF/VrlBdpIM2EnaOna8ME37m/LSHWfdKiPba35ll7InVUg6S2\n 0BcCGhVX/FLPWyK+NqBK80N2PQOpBm883w1BnkJEQ==", "X-Received": "by 2002:a05:600c:4fc8:b0:488:ffad:6728 with SMTP id\n 5b1f17b1804b1-48a84451ac5mr37835485e9.19.1777541915355;\n Thu, 30 Apr 2026 02:38:35 -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 18/25] system/physmem: Use translate_for_debug() in\n cpu_memory_rw_debug()", "Date": "Thu, 30 Apr 2026 10:38:03 +0100", "Message-ID": "<20260430093810.2762539-19-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-Transfer-Encoding": "8bit", "Received-SPF": "pass client-ip=2a00:1450:4864:20::332;\n envelope-from=peter.maydell@linaro.org; helo=mail-wm1-x332.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=unavailable 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": "Currently cpu_memory_rw_debug() assumes page-granularity for translations,\nand it works in a loop where each iteration translates for the vaddr\nrounded down to a page boundary and then copies up to the end of the\npage boundary.\n\nRewrite it to use the new cpu_translate_for_debug(): we no longer want\nto round down the input address, and the boundary we copy up to is now\ndetermined by the lg_page_size it returns rather than being assumed\nto be page-sized.\n\nThis, together with the implementation of translate_for_debug for\nArm targets, fixes the bug where semihosting would incorrectly\nfail to access parameter blocks that were in memory where the\nstart of the 4K region they were in was inaccessible due to MPU\nregion settings, even if the parameter block itself was readable.\n\nResolves: https://gitlab.com/qemu-project/qemu/-/work_items/3292\nSigned-off-by: Peter Maydell <peter.maydell@linaro.org>\nMessage-id: 20260417173105.1648172-18-peter.maydell@linaro.org\n---\n system/physmem.c | 38 ++++++++++++++++++++++++--------------\n 1 file changed, 24 insertions(+), 14 deletions(-)", "diff": "diff --git a/system/physmem.c b/system/physmem.c\nindex 652b03ad5f..7bcbf87573 100644\n--- a/system/physmem.c\n+++ b/system/physmem.c\n@@ -4030,28 +4030,38 @@ address_space_write_cached_slow(MemoryRegionCache *cache, hwaddr addr,\n int cpu_memory_rw_debug(CPUState *cpu, vaddr addr,\n void *ptr, size_t len, bool is_write)\n {\n- hwaddr phys_addr;\n- vaddr l, page;\n uint8_t *buf = ptr;\n \n cpu_synchronize_state(cpu);\n while (len > 0) {\n int asidx;\n- MemTxAttrs attrs;\n+ TranslateForDebugResult tres;\n MemTxResult res;\n+ hwaddr blk_base, blk_size, l;\n \n- page = addr & TARGET_PAGE_MASK;\n- phys_addr = cpu_get_phys_addr_attrs_debug(cpu, page, &attrs);\n- asidx = cpu_asidx_from_attrs(cpu, attrs);\n- /* if no physical page mapped, return an error */\n- if (phys_addr == -1)\n+ if (!cpu_translate_for_debug(cpu, addr, &tres)) {\n+ /* Return error if no physical page mapped */\n return -1;\n- l = (page + TARGET_PAGE_SIZE) - addr;\n- if (l > len)\n- l = len;\n- phys_addr += (addr & ~TARGET_PAGE_MASK);\n- res = address_space_rw(cpu->cpu_ases[asidx].as, phys_addr, attrs, buf,\n- l, is_write);\n+ }\n+ asidx = cpu_asidx_from_attrs(cpu, tres.attrs);\n+ /*\n+ * Clamp the amount we read to not go beyond a page even if\n+ * the CPU returned a larger lg_page_size, in case this access\n+ * is to a memory-mapped IO region.\n+ */\n+ tres.lg_page_size = MIN(tres.lg_page_size, TARGET_PAGE_BITS);\n+ /*\n+ * Find the length in bytes from tres.physaddr to the end of the\n+ * block whose size is 1 << tres.lg_page_size; we will access\n+ * that much in one go.\n+ */\n+ blk_size = 1ULL << tres.lg_page_size;\n+ blk_base = ROUND_DOWN(tres.physaddr, blk_size);\n+ l = blk_base + blk_size - tres.physaddr;\n+ l = MIN(l, len);\n+\n+ res = address_space_rw(cpu->cpu_ases[asidx].as, tres.physaddr,\n+ tres.attrs, buf, l, is_write);\n if (res != MEMTX_OK) {\n return -1;\n }\n", "prefixes": [ "v2", "18/25" ] }