Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp395776pxj; Thu, 20 May 2021 11:49:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw7LWE3rmvWO5pqPpncuZDb5dGrkvIr/dgFwdXQDIjAew62EeIyyxRfIHfpSPVWQpkZhemS X-Received: by 2002:a6b:8e04:: with SMTP id q4mr7137987iod.54.1621536588252; Thu, 20 May 2021 11:49:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621536588; cv=none; d=google.com; s=arc-20160816; b=eeYCXkuTtFebOExzPx3imKCbUIeQeRDBcGOB0hMPNUp5g4zaW5RtzDL1CE5ebROy89 ajfxHGVw9Q1N7i9nDp0c1bZZQXS7+7izcBHPH/e+Fzz5RJWs9UJmbKvgk5cy698rxDcL mRXzXvhNABEy6FjwQVy0x/3Zv/w7Jm/CduqBgn46baMVt7VCBDlLPVyGmLQWI4Fvgcyj S5VhWtMQ2VfsFR8st95rDAfPE2E3oAAl/mVdtYyintW/DTW1dlfNSXChe5RoxuA+Cvdn XJJBal9CxWBzGzRKupQ1ccrDI8VKU9KrNVxTEGkcWINOalK885eYCbLikuwnavu03pMX 1KGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=aK3ju3g+XfY/WhUscFtuqzE/oMDXFXHoXpoGeDe4qr4=; b=XspOrE2oMQnlDaVReR0zF8Bmi9GC3iRJrs3W7Dt6bXxCjGlmp9BxBsMFVtzIJlQAb1 EHOMKrLN93vr3ELVbpZvzKMrCFm1oQd6or+biqexEBwMwKHAmtbOWb9RnF1md+oS1SgS wtx7gZNYD8g9SjPLjPugM8TuEbgqaA8c//6fiUKYqvLZ2APmrYYji/MLopibygQ8jKvV NQazXwcamwZtadCQvF8ubLTQbpFQITvcZuJ+q51PURAaNvGMcuyhqmX0xTryjhqG8nVN 2ucAidNg1OD7JQN4H1De2GQP1e78K2s+LChQFF2LpPIjPH1enaCLDEYp+i0sgLAG0h74 GVAA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=HZ1ma24H; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d1si3709411ilg.93.2021.05.20.11.49.35; Thu, 20 May 2021 11:49:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=HZ1ma24H; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236647AbhETKYX (ORCPT + 99 others); Thu, 20 May 2021 06:24:23 -0400 Received: from mail.kernel.org ([198.145.29.99]:48106 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235904AbhETKNN (ORCPT ); Thu, 20 May 2021 06:13:13 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 524F7613EC; Thu, 20 May 2021 09:44:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621503851; bh=+zah6LQvn/y5djmh3np2bUfyQy65S0RZExEtnjTcECA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HZ1ma24HCYvjIBN8YcVddFPA308xoPbC0WkSyuYQOjF1x9KBMlRPlhbkAjAn5zEI0 aw/MNeklFc9ClFr5AfLW2x23a+7IZSrgojKmA15FBcHBAdt0iExrth/n1eMexNjFn8 zev9bWbfYCI47Z71apCBJOWDq0/At2jmc8FaycMY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Nicolas Pitre , Ard Biesheuvel , Russell King , Sasha Levin Subject: [PATCH 4.19 401/425] ARM: 9058/1: cache-v7: refactor v7_invalidate_l1 to avoid clobbering r5/r6 Date: Thu, 20 May 2021 11:22:50 +0200 Message-Id: <20210520092144.573609158@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210520092131.308959589@linuxfoundation.org> References: <20210520092131.308959589@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ard Biesheuvel [ Upstream commit f9e7a99fb6b86aa6a00e53b34ee6973840e005aa ] The cache invalidation code in v7_invalidate_l1 can be tweaked to re-read the associativity from CCSIDR, and keep the way identifier component in a single register that is assigned in the outer loop. This way, we need 2 registers less. Given that the number of sets is typically much larger than the associativity, rearrange the code so that the outer loop has the fewer number of iterations, ensuring that the re-read of CCSIDR only occurs a handful of times in practice. Fix the whitespace while at it, and update the comment to indicate that this code is no longer a clone of anything else. Acked-by: Nicolas Pitre Signed-off-by: Ard Biesheuvel Signed-off-by: Russell King Signed-off-by: Sasha Levin --- arch/arm/mm/cache-v7.S | 51 +++++++++++++++++++++--------------------- 1 file changed, 25 insertions(+), 26 deletions(-) diff --git a/arch/arm/mm/cache-v7.S b/arch/arm/mm/cache-v7.S index 2149b47a0c5a..463965dc7922 100644 --- a/arch/arm/mm/cache-v7.S +++ b/arch/arm/mm/cache-v7.S @@ -28,41 +28,40 @@ * processor. We fix this by performing an invalidate, rather than a * clean + invalidate, before jumping into the kernel. * - * This function is cloned from arch/arm/mach-tegra/headsmp.S, and needs - * to be called for both secondary cores startup and primary core resume - * procedures. + * This function needs to be called for both secondary cores startup and + * primary core resume procedures. */ ENTRY(v7_invalidate_l1) mov r0, #0 mcr p15, 2, r0, c0, c0, 0 mrc p15, 1, r0, c0, c0, 0 - movw r1, #0x7fff - and r2, r1, r0, lsr #13 + movw r3, #0x3ff + and r3, r3, r0, lsr #3 @ 'Associativity' in CCSIDR[12:3] + clz r1, r3 @ WayShift + mov r2, #1 + mov r3, r3, lsl r1 @ NumWays-1 shifted into bits [31:...] + movs r1, r2, lsl r1 @ #1 shifted left by same amount + moveq r1, #1 @ r1 needs value > 0 even if only 1 way - movw r1, #0x3ff + and r2, r0, #0x7 + add r2, r2, #4 @ SetShift - and r3, r1, r0, lsr #3 @ NumWays - 1 - add r2, r2, #1 @ NumSets +1: movw r4, #0x7fff + and r0, r4, r0, lsr #13 @ 'NumSets' in CCSIDR[27:13] - and r0, r0, #0x7 - add r0, r0, #4 @ SetShift - - clz r1, r3 @ WayShift - add r4, r3, #1 @ NumWays -1: sub r2, r2, #1 @ NumSets-- - mov r3, r4 @ Temp = NumWays -2: subs r3, r3, #1 @ Temp-- - mov r5, r3, lsl r1 - mov r6, r2, lsl r0 - orr r5, r5, r6 @ Reg = (Temp<