Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp241886ybh; Wed, 15 Jul 2020 00:20:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy2xXhExOQ3+ZeNhtiwbmLBWN/B0bIe5RG6ckasoXCCoFvwEIknzhjaLVsA0KZgh9h80zFL X-Received: by 2002:a17:906:c056:: with SMTP id bm22mr8263690ejb.444.1594797639305; Wed, 15 Jul 2020 00:20:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594797639; cv=none; d=google.com; s=arc-20160816; b=ZP+bouCTW2KARx+JJDcs5csn4pHfojF5KtugxQJ2618JxGlJJyk0O+4PBhWW4tGTh/ bznBa7umpFX3zr+ljFKmahaF7M6W9mwi75CyR1XEu0TtWVvueK3b57Avz+zj91BbSxw/ JsVICxplE7GYgkklN8MHJ62nG4BPypJNAKBsEUosuQ/NIBSwAt4KnTGAs0rW6AGC5D7w 6HPoZNAche6JqWlYQ+nazU3asTmmvY6j13YAp3vkxeTQvk2tkKlnDVgos78CFMgceeuP yakctIoovM9TZg0PcRtcMZIrRpUtbVkiUNBYGRphT/ZNeGOkW1n9MGKRmn1lmErqNQVt pQnA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=Fr5SJhfglVOM+TnlPebRm42+dT9QiiGLKWl4vSqVf00=; b=S9nWcH6kdd3lZJ7CjZOtPQYvMfc7JC1q+06G98bGP8cFOJbHdjpZtr/2mhEgOLaX9D V6USThHMqR/a76kvJltzQFao6Rf2YXSsyX1FEbGMNv41/1bhwDnDl6ZY3tobtas2e5A7 hCmJau/Y1rdOBjLcFFc2n/y8ckoiDE5uydqpvEu0+Bvdk3trHAj1ecB+Sy1UhbzJ0QK3 xhMmkjy4spPaAzHkoiPJ9H7ZzAFEnNOX5dYsgsryKG+J4Rf7mk9nH2cg4gzdw0scWgdH /4PYA7rYDW55BGB2uQlMOMQdcKePuN+Z30GwMJaAx81GTV3DVmw5Fx165JUxtO8sAkGc Zusg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cz26si706328edb.378.2020.07.15.00.20.16; Wed, 15 Jul 2020 00:20:39 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729162AbgGOHUD (ORCPT + 99 others); Wed, 15 Jul 2020 03:20:03 -0400 Received: from szxga05-in.huawei.com ([45.249.212.191]:7317 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728876AbgGOHUD (ORCPT ); Wed, 15 Jul 2020 03:20:03 -0400 Received: from DGGEMS413-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 367C086A3F7B3A2F6EFD; Wed, 15 Jul 2020 15:20:01 +0800 (CST) Received: from DESKTOP-KKJBAGG.china.huawei.com (10.174.186.75) by DGGEMS413-HUB.china.huawei.com (10.3.19.213) with Microsoft SMTP Server id 14.3.487.0; Wed, 15 Jul 2020 15:19:51 +0800 From: Zhenyu Ye To: , , , , , , CC: , , , , , , , , , Subject: [PATCH v3 0/3] arm64: tlb: add support for TLBI RANGE instructions Date: Wed, 15 Jul 2020 15:19:42 +0800 Message-ID: <20200715071945.897-1-yezhenyu2@huawei.com> X-Mailer: git-send-email 2.22.0.windows.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.174.186.75] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org NOTICE: this series are based on the arm64 for-next/tlbi branch: git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux.git for-next/tlbi ARMv8.4-TLBI provides TLBI invalidation instruction that apply to a range of input addresses. This series add support for this feature. -- ChangeList: v3: - add check on whether binutils supports ARMv8.4-a instructions. - pass -march=armv8.4-a to KBUILD_CFLAGS. - make __TLBI_RANGE_PAGES to be 'unsigned long' explicitly. v2: - remove the __tlbi_last_level() macro. - add check for parameters in __TLBI_VADDR_RANGE macro. RFC patches: - Link: https://lore.kernel.org/linux-arm-kernel/20200708124031.1414-1-yezhenyu2@huawei.com/ Zhenyu Ye (3): arm64: tlb: Detect the ARMv8.4 TLBI RANGE feature arm64: enable tlbi range instructions arm64: tlb: Use the TLBI RANGE feature in arm64 arch/arm64/Kconfig | 14 +++ arch/arm64/Makefile | 7 ++ arch/arm64/include/asm/cpucaps.h | 3 +- arch/arm64/include/asm/sysreg.h | 3 + arch/arm64/include/asm/tlbflush.h | 156 ++++++++++++++++++++++++------ arch/arm64/kernel/cpufeature.c | 10 ++ 6 files changed, 163 insertions(+), 30 deletions(-) -- 2.19.1