Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp14074583pxu; Mon, 4 Jan 2021 12:11:38 -0800 (PST) X-Google-Smtp-Source: ABdhPJytgg2Rb5JUzpJJf0W0qXe5U/NU9jkTEve4Vc71VaIlepgnWR7heOMUOTyDUMQqCLYmNJpz X-Received: by 2002:a05:6402:22ea:: with SMTP id dn10mr71525893edb.67.1609791097872; Mon, 04 Jan 2021 12:11:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609791097; cv=none; d=google.com; s=arc-20160816; b=ikSfMcwn2SU4vlPsM8JGdI7szZYGJnxepLi6zdn6PQaWbKry0hKFiUaCV69+Yhig+Z HaH4aZWeWX00ourochIlnFx7tGCy7fs+7/QufeUeUP+LkqxBf2pM7Iqf9RHnPfToOs0v SkDqLcCFHtLqIs8heGEyhxKMwSgu9vJ6/8fRlLVV/vikiqN3uFD2BbNpC1CDDOFpEPwj XfuzNQV5FBJLW5exnQCD3yq4KtuNGrevORud7hMca5MqtU+qe/09z4aTgfMCWAA+s42+ XK3YDHJStHNQZdznJq/KtPoNXd591GWtPOU3arbbCfVHpeJ1Jkei5ETiFLhnzOFv8KaB 87lg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=jxgyL70RGo3g4+YS9yQsrv/+nd8MZt2IIj1upNCf9oM=; b=N/6j0jRjXTpaF/KFp+PHEt+c0TyiRjppJX8rTEd827WZLJ6biSxqjCBhTs4bz6LSmH 3SjN3ebMyzL8r0sQBG50sjJZ/rELua+5nDRU0RBKrxT/kTozQ3RSitwrpwCeioIYSQvI iMfMj07IAWVfAaxQ/3+HlNEYVL8sqfWn8p2QgCVW0REtWzvBAo//iY37wBi81ps1Mw0C KNrsj6/S4+5YYRiIpFtsNH6rMLc6d38JOzT9aj7wk3PBxF75nbuh5cyaobNudTBBdYNz CfhqIZ+ArWckvXehfvOpH55slTO4+cY0nEPe+RJlH87JY6oIFLaPTj2JNF8REuMrRq18 PFCQ== 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 q11si32084074edb.312.2021.01.04.12.11.14; Mon, 04 Jan 2021 12:11:37 -0800 (PST) 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 S1727698AbhADUKH (ORCPT + 99 others); Mon, 4 Jan 2021 15:10:07 -0500 Received: from relay8-d.mail.gandi.net ([217.70.183.201]:38227 "EHLO relay8-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726610AbhADUKH (ORCPT ); Mon, 4 Jan 2021 15:10:07 -0500 X-Originating-IP: 90.112.190.212 Received: from debian.home (lfbn-gre-1-231-212.w90-112.abo.wanadoo.fr [90.112.190.212]) (Authenticated sender: alex@ghiti.fr) by relay8-d.mail.gandi.net (Postfix) with ESMTPSA id 8C6BB1BF204; Mon, 4 Jan 2021 20:09:22 +0000 (UTC) From: Alexandre Ghiti To: Paul Walmsley , Palmer Dabbelt , Zong Li , Anup Patel , Christoph Hellwig , Ard Biesheuvel , Arnd Bergmann , linux-efi@vger.kernel.org, linux-arch@vger.kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Cc: Alexandre Ghiti , Palmer Dabbelt Subject: [RFC PATCH 10/12] riscv: Use pgtable_l4_enabled to output mmu type in cpuinfo Date: Mon, 4 Jan 2021 14:58:38 -0500 Message-Id: <20210104195840.1593-11-alex@ghiti.fr> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210104195840.1593-1-alex@ghiti.fr> References: <20210104195840.1593-1-alex@ghiti.fr> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Now that the mmu type is determined at runtime using SATP characteristic, use the global variable pgtable_l4_enabled to output mmu type of the processor through /proc/cpuinfo instead of relying on device tree infos. Signed-off-by: Alexandre Ghiti Reviewed-by: Anup Patel Reviewed-by: Palmer Dabbelt --- arch/riscv/include/asm/pgtable.h | 1 + arch/riscv/kernel/cpu.c | 23 ++++++++++++----------- 2 files changed, 13 insertions(+), 11 deletions(-) diff --git a/arch/riscv/include/asm/pgtable.h b/arch/riscv/include/asm/pgtable.h index dd27d28f1d9e..95721016049d 100644 --- a/arch/riscv/include/asm/pgtable.h +++ b/arch/riscv/include/asm/pgtable.h @@ -495,6 +495,7 @@ extern char _start[]; extern void *dtb_early_va; extern uintptr_t dtb_early_pa; extern u64 satp_mode; +extern bool pgtable_l4_enabled; void setup_bootmem(void); void paging_init(void); diff --git a/arch/riscv/kernel/cpu.c b/arch/riscv/kernel/cpu.c index 6d59e6906fdd..dea9b1c31889 100644 --- a/arch/riscv/kernel/cpu.c +++ b/arch/riscv/kernel/cpu.c @@ -7,6 +7,7 @@ #include #include #include +#include /* * Returns the hart ID of the given device tree node, or -ENODEV if the node @@ -70,18 +71,19 @@ static void print_isa(struct seq_file *f, const char *isa) seq_puts(f, "\n"); } -static void print_mmu(struct seq_file *f, const char *mmu_type) +static void print_mmu(struct seq_file *f) { + char sv_type[16]; + #if defined(CONFIG_32BIT) - if (strcmp(mmu_type, "riscv,sv32") != 0) - return; + strncpy(sv_type, "sv32", 5); #elif defined(CONFIG_64BIT) - if (strcmp(mmu_type, "riscv,sv39") != 0 && - strcmp(mmu_type, "riscv,sv48") != 0) - return; + if (pgtable_l4_enabled) + strncpy(sv_type, "sv48", 5); + else + strncpy(sv_type, "sv39", 5); #endif - - seq_printf(f, "mmu\t\t: %s\n", mmu_type+6); + seq_printf(f, "mmu\t\t: %s\n", sv_type); } static void *c_start(struct seq_file *m, loff_t *pos) @@ -106,14 +108,13 @@ static int c_show(struct seq_file *m, void *v) { unsigned long cpu_id = (unsigned long)v - 1; struct device_node *node = of_get_cpu_node(cpu_id, NULL); - const char *compat, *isa, *mmu; + const char *compat, *isa; seq_printf(m, "processor\t: %lu\n", cpu_id); seq_printf(m, "hart\t\t: %lu\n", cpuid_to_hartid_map(cpu_id)); if (!of_property_read_string(node, "riscv,isa", &isa)) print_isa(m, isa); - if (!of_property_read_string(node, "mmu-type", &mmu)) - print_mmu(m, mmu); + print_mmu(m); if (!of_property_read_string(node, "compatible", &compat) && strcmp(compat, "riscv")) seq_printf(m, "uarch\t\t: %s\n", compat); -- 2.20.1