From patchwork Mon Nov 21 21:24:04 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Peter Maydell X-Patchwork-Id: 627260 Delivered-To: patch@linaro.org Received: by 2002:a17:522:c983:b0:460:3032:e3c4 with SMTP id kr3csp2039649pvb; Mon, 21 Nov 2022 13:24:58 -0800 (PST) X-Google-Smtp-Source: AA0mqf66SrdQO40wesLNbNOLVW4+11kL8wyKcxRXsaa9si8Ww9SQEfQ3Dw//EKImadC8Yt51Lfyy X-Received: by 2002:a05:620a:2150:b0:6fa:12ed:931c with SMTP id m16-20020a05620a215000b006fa12ed931cmr18051556qkm.83.1669065898224; Mon, 21 Nov 2022 13:24:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669065898; cv=none; d=google.com; s=arc-20160816; b=CSXXHuWpsQ3ShTIRlZ+zKYGiYDRj5sg7QLgdIwgy0jmurwKbL+1QGqQY4fsPbU0swK KdaVOcVFQHJpzp9fDVPywTjVoahtrTOb/cO2ALb0y1JWPeqv3fJRkMSugmBmBTA+aiiL Dfmobj01Tx/0iUu3Z0fMwALjZhFnZSvmMrqYBXxVmjzEeMt0XUAPkUDDxIq3+TzG9HOK pc53jnOCd4YMu/nzKkOVMSM5aZiuTZZK/5sy1StEppja+G1fFb/a7irlNalAWwxXFL8I RUKne2Gn1hfoX5OCHoJajqHxO4/YppKHcOiOHvMZzhCUeKIdw7PfDgw+pY1T2iPw6JQ/ 6SGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:message-id:date:subject:cc:to:from:dkim-signature; bh=8gkv8kvW5LJw8L5Xe3JzRzRvQ07cJtVsiJm2+QBkpmY=; b=oDPGHuGHk1ZzlwTU7fAj/eMjCid8xgA6RagHvE8MuU9EoPOMEx7cDmCiKPYIZFEtA3 fkWqUi8mpAYgyadFh9RU8tYP/pTc5u1/04UPeUbyLWwfzsODuFgdGHCps1RXk4nwkVf4 APhqVHZ4ArssAJpvwgbUsiru/fSOKzbgvBfKWq2z1ihvnvyUcTSh39nC1lW9Ha2LMm7G IDHSaIox/KLRXF9BPDUhy/C4DigiSIBCH61Em3uLCfTZHS6rPn3vtdUiyovRd+AjGVXP UjOBEQL7fnToHriqbbeopDSecryUHvs2LW++7p9qjkapm6vYP4OczblKv4Y9PdcqBWBY d6pA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=qkEMBhw8; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id fw13-20020a056214238d00b004bb76da669bsi6281023qvb.388.2022.11.21.13.24.58 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Mon, 21 Nov 2022 13:24:58 -0800 (PST) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=qkEMBhw8; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1oxEHO-0004XQ-OB; Mon, 21 Nov 2022 16:24:38 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oxEGz-0004Jy-Mr for qemu-devel@nongnu.org; Mon, 21 Nov 2022 16:24:15 -0500 Received: from mail-wm1-x331.google.com ([2a00:1450:4864:20::331]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1oxEGu-00083N-BL for qemu-devel@nongnu.org; Mon, 21 Nov 2022 16:24:10 -0500 Received: by mail-wm1-x331.google.com with SMTP id c65-20020a1c3544000000b003cfffd00fc0so9766940wma.1 for ; Mon, 21 Nov 2022 13:24:07 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=8gkv8kvW5LJw8L5Xe3JzRzRvQ07cJtVsiJm2+QBkpmY=; b=qkEMBhw8WpRLi0SK/AIrmEo6m8CHUL997iWpOhHRXeuz84PurIkzwW5U2e9vYqdIXD iMx2gqbIsF+LEQxJ3cDPLMqUoMhjOiiZM7rzp8nt6y3Wl2Rmj6QLZuR30VRjFvQcNGhr wHNrgIKhg+spRWly4YUOPKpmKa2iYP611lACP6Wv3uu/KiJTaEwIwL1d5dMONxy+BqyU /+xnIjDTH41kMlvfxluR5lyo6IGgAMSok+yOY/LmkO00OEaC42ohUSNjktWHELyqPqpc SEuOOiH/62Eh2kcKfl+OZBnGew411C5kBlBRiw0dbuEWjCNt/7xU0irqwq6FIwBHhgc9 3B4Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=8gkv8kvW5LJw8L5Xe3JzRzRvQ07cJtVsiJm2+QBkpmY=; b=r0nWxBDL2Syl8TyV7PGJrh7FhSdRSljUaXdhu4KNvzOq9gBGAkDRt6ZrAVMgBqgGmd 4eP3MhWP7RK8/wq6DnfK1oNdvwKdQfeVSzfbkX3Sv2BCi2ErsaUlqO3QOHIRxlnd8vpU xKojwx1gRLTTWmW2PDTbdwwOd2ZqZe4cOl1oqN5/t1zajg00TCmnv+sPx6q7zLxkf5yw XTWeANBAkcuBPi4r0V48aT8s3J3zGCt/z46+9rjacDif2ZDv4Uzlvloi+Uwg5p8tf2AL qQDItSjNnLRg9ohq25/faKnEpzW+Id6mMnE5/rnBwRe/Phpiw84RjMkNcwkvRp3QmFWW 8fEA== X-Gm-Message-State: ANoB5pk7oInqAOMFJSZEeyI03RuqO7O+6pfvWT4rLB/5fz3iZl6HR5H+ heQlcxG+xAjlZo4VSXhXznWPSA== X-Received: by 2002:a05:600c:a0d:b0:3cf:6c0d:a27 with SMTP id z13-20020a05600c0a0d00b003cf6c0d0a27mr13954630wmp.196.1669065846540; Mon, 21 Nov 2022 13:24:06 -0800 (PST) Received: from orth.archaic.org.uk (orth.archaic.org.uk. [2001:8b0:1d0::2]) by smtp.gmail.com with ESMTPSA id r24-20020adfa158000000b00236b2804d79sm12675461wrr.2.2022.11.21.13.24.05 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 21 Nov 2022 13:24:05 -0800 (PST) From: Peter Maydell To: qemu-arm@nongnu.org, qemu-devel@nongnu.org Cc: Richard Henderson , Jens Wiklander Subject: [PATCH for-7.2] target/arm: Don't do two-stage lookup if stage 2 is disabled Date: Mon, 21 Nov 2022 21:24:04 +0000 Message-Id: <20221121212404.1450382-1-peter.maydell@linaro.org> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Received-SPF: pass client-ip=2a00:1450:4864:20::331; envelope-from=peter.maydell@linaro.org; helo=mail-wm1-x331.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=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: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: qemu-devel-bounces+patch=linaro.org@nongnu.org In get_phys_addr_with_struct(), we call get_phys_addr_twostage() if the CPU supports EL2. However, we don't check here that stage 2 is actually enabled. Instead we only check that inside get_phys_addr_twostage() to skip stage 2 translation. This means that even if stage 2 is disabled we still tell the stage 1 lookup to do its page table walks via stage 2. This works by luck for normal CPU accesses, but it breaks for debug accesses, which are used by the disassembler and also by semihosting file reads and writes, because the debug case takes a different code path inside S1_ptw_translate(). This means that setups that use semihosting for file loads are broken (a regression since 7.1, introduced in recent ptw refactoring), and that sometimes disassembly in debug logs reports "unable to read memory" rather than showing the guest insns. Fix the bug by hoisting the "is stage 2 enabled?" check up to get_phys_addr_with_struct(), so that we handle S2 disabled the same way we do the "no EL2" case, with a simple single stage lookup. Reported-by: Jens Wiklander Reviewed-by: Richard Henderson Signed-off-by: Peter Maydell --- This patch has RTH's r-by because I ran a couple of options for fixing this by him over private email. --- target/arm/ptw.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/target/arm/ptw.c b/target/arm/ptw.c index 3745ac97234..4264002021a 100644 --- a/target/arm/ptw.c +++ b/target/arm/ptw.c @@ -2604,8 +2604,8 @@ static bool get_phys_addr_twostage(CPUARMState *env, S1Translate *ptw, ret = get_phys_addr_with_struct(env, ptw, address, access_type, result, fi); - /* If S1 fails or S2 is disabled, return early. */ - if (ret || regime_translation_disabled(env, ARMMMUIdx_Stage2, is_secure)) { + /* If S1 fails, return early. */ + if (ret) { return ret; } @@ -2731,7 +2731,8 @@ static bool get_phys_addr_with_struct(CPUARMState *env, S1Translate *ptw, * Otherwise, a stage1+stage2 translation is just stage 1. */ ptw->in_mmu_idx = mmu_idx = s1_mmu_idx; - if (arm_feature(env, ARM_FEATURE_EL2)) { + if (arm_feature(env, ARM_FEATURE_EL2) && + !regime_translation_disabled(env, ARMMMUIdx_Stage2, is_secure)) { return get_phys_addr_twostage(env, ptw, address, access_type, result, fi); }