Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp759321pxk; Thu, 17 Sep 2020 15:49:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyOIsAn8xLau358dbpBT2Kpx8pVEQT9JCoS3XAuopQ1aYmftwXPTK6pBnvbNTwULjLWVnN7 X-Received: by 2002:a17:906:2b48:: with SMTP id b8mr34473608ejg.125.1600382943752; Thu, 17 Sep 2020 15:49:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600382943; cv=none; d=google.com; s=arc-20160816; b=rZf0K6vZ+gTKzbZKYiJ5A1NKhVre1cOGTRKktbGrYkrkvj50CBfGFZ2usTYdAViZEh o0xqp2huJvJ4qUzzePeEMzxHqloocmaAyfdnAHODbAcry+yBUCMYpWSns0RIk4LnG2fK VMDZR2DsR3WGhi9ZNuislTTu6rn1dubI3cyLh2CeZDk7f694gzhMyUKMv8X0+9cDmzUG M8FJ5bib27Wh06K5Ti/jCjPf2U59hBFUDl4lKHm6IMIG1GYEU7B5yTF221iVSTPzFe1F 9zjb2WVx2fSmyDURmU6DZitR5rs7bYxFzzDmhcoM5CJXhjcsJPtuWkT+R2Ahn+bqwJGl 1dHA== 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 :wdcironportexception:ironport-sdr:ironport-sdr:ironport-sdr :dkim-signature; bh=pUpQ0EN7TwikJUjuF+Xy+4Zi8PoU5qPsp7hOgwbZIP8=; b=aroonGjFwIac2h2fgpDKqzYybqw9s9IbQ+rqglOe4qjCyuR8nCG/WbAjS2KrKAP5XG +aE5aJCHPCVy8FLHnYORYRaWyhy0PceyptBkWgdxnFGlne609Dd7wbFxGuCYDTUaqqd7 fxiPKAk9mPE8hiBQ7nQHNHJ5nXBKQID7Vbs55Sq6h1gQJpNo6LfPwue3pCFwq6mvKEjs GeqJ+OgNHk41ZoByah+GdNgt60TwmojF0I+JTUglT0oBLzsoFjDGXktXVCkXzylayKU6 OxVo/1POZbHqHLVQiSODyWOOPyETC+qrIp+DKaVHgiWlGG+QU/UIgQEhKRT09sFa1le/ zy3w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@wdc.com header.s=dkim.wdc.com header.b=Burcm7ux; 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=fail (p=NONE sp=NONE dis=NONE) header.from=wdc.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n6si773244edy.596.2020.09.17.15.48.39; Thu, 17 Sep 2020 15:49:03 -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=fail header.i=@wdc.com header.s=dkim.wdc.com header.b=Burcm7ux; 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=fail (p=NONE sp=NONE dis=NONE) header.from=wdc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726178AbgIQWrl (ORCPT + 99 others); Thu, 17 Sep 2020 18:47:41 -0400 Received: from esa2.hgst.iphmx.com ([68.232.143.124]:54146 "EHLO esa2.hgst.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725858AbgIQWrk (ORCPT ); Thu, 17 Sep 2020 18:47:40 -0400 X-Greylist: delayed 601 seconds by postgrey-1.27 at vger.kernel.org; Thu, 17 Sep 2020 18:47:38 EDT DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=wdc.com; i=@wdc.com; q=dns/txt; s=dkim.wdc.com; t=1600382911; x=1631918911; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=lhOc3WWtQwFeHFYUWyapAldP7DuySUtkVYHUOa8roXg=; b=Burcm7ux7uGhf4OOwZcmeOUydMa1EeLezcKWHjBxSqFAHouY5ZHBGJmi EUrWO5jLnr9f5hUF0FPlWtWSebDg7oAMrAe/xn22ZENRd/nwKWoqotepH 9JhY1EssylgTrJ12VVD/b4s7oyJ6aZ3coKvUszVEY3M48pq+QcVSbDlRS F0axwOIjzbilkK/6fMBlxtRjR1hGmOPtQ6EkYgXQQKcaFUUjp4YQb12QZ E4VswemAHrQWJnJUwDm8lheRu13yu+HrJGpLcgmU3IuVR7+yYeMSG/FmQ nfVCCqUAGga8sm+8bGcIru+uP3xmGDSuxSqH/NHYm+Vhg7lR1On/rc7+C g==; IronPort-SDR: CdcBWL5rYUIq/fH2M96FKzb9I0VDUhY9k4ouo/DUJeL/MnGXIUrTTiUFiObxP6w3LxCJ6qRiQ6 QzKurPGZoRtq/ZLeN1Hl6BOpGmuUO02fwX96d9pKPuTB1CgOAEMW2lwxsx/rvWJh6JNA1+R8wv vCv7Q1dGWnye/k4uPhGIllQ2sQwswOK+YRvsG05DFgYa9a2aOgJKAAfiIu/NWmb+xb1MC0hbkl +7ow9OVhi07umG6gprYIHNqTuo0KezbTHKLu+sIEfly7NjycTMtnmmQwg2FbYsfZ5iKBJPhmqe 7rk= X-IronPort-AV: E=Sophos;i="5.77,272,1596470400"; d="scan'208";a="251021081" Received: from uls-op-cesaip02.wdc.com (HELO uls-op-cesaep02.wdc.com) ([199.255.45.15]) by ob1.hgst.iphmx.com with ESMTP; 18 Sep 2020 06:37:55 +0800 IronPort-SDR: OZaoUnx/SdGx1b04TNIBoSk2WBcRleqsmHGVpYA9co65uMDhY7qR2yOvmdeyUpJuUHGlQ5sa62 KWD+Hjw/uIrQ== Received: from uls-op-cesaip02.wdc.com ([10.248.3.37]) by uls-op-cesaep02.wdc.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Sep 2020 15:23:52 -0700 IronPort-SDR: 8ZlNwjQorpceowXk1nDGConbDnwxgJfD0D7sz7hFJvZnmS0oH93Z2IbDhj0zQV2akqtAhrAb3L q4MDctKH/tMQ== WDCIronportException: Internal Received: from use204338.ad.shared (HELO jedi-01.hgst.com) ([10.86.60.39]) by uls-op-cesaip02.wdc.com with ESMTP; 17 Sep 2020 15:37:38 -0700 From: Atish Patra To: linux-kernel@vger.kernel.org Cc: Atish Patra , Anup Patel , Palmer Dabbelt , Albert Ou , Alistair Francis , Andrew Morton , Anup Patel , Ard Biesheuvel , Arvind Sankar , Borislav Petkov , Greentime Hu , Heiko Carstens , Ingo Molnar , Kees Cook , linux-efi@vger.kernel.org, linux-riscv@lists.infradead.org, Masahiro Yamada , Maxim Uvarov , Michal Simek , Mike Rapoport , Nick Desaulniers , Palmer Dabbelt , Paul Walmsley , Thomas Gleixner , Zong Li Subject: [PATCH v8 2/7] RISC-V: Add early ioremap support Date: Thu, 17 Sep 2020 15:37:11 -0700 Message-Id: <20200917223716.2300238-3-atish.patra@wdc.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200917223716.2300238-1-atish.patra@wdc.com> References: <20200917223716.2300238-1-atish.patra@wdc.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org UEFI uses early IO or memory mappings for runtime services before normal ioremap() is usable. Add the necessary fixmap bindings and pmd mappings for generic ioremap support to work. Signed-off-by: Atish Patra Reviewed-by: Anup Patel Reviewed-by: Palmer Dabbelt Signed-off-by: Palmer Dabbelt --- arch/riscv/Kconfig | 1 + arch/riscv/include/asm/Kbuild | 1 + arch/riscv/include/asm/fixmap.h | 13 +++++++++++++ arch/riscv/include/asm/io.h | 1 + arch/riscv/kernel/setup.c | 2 ++ arch/riscv/mm/init.c | 33 +++++++++++++++++++++++++++++++++ 6 files changed, 51 insertions(+) diff --git a/arch/riscv/Kconfig b/arch/riscv/Kconfig index df18372861d8..5e4ace64acbc 100644 --- a/arch/riscv/Kconfig +++ b/arch/riscv/Kconfig @@ -37,6 +37,7 @@ config RISCV select GENERIC_ARCH_TOPOLOGY if SMP select GENERIC_ATOMIC64 if !64BIT select GENERIC_CLOCKEVENTS + select GENERIC_EARLY_IOREMAP select GENERIC_GETTIMEOFDAY if HAVE_GENERIC_VDSO select GENERIC_IOREMAP select GENERIC_IRQ_MULTI_HANDLER diff --git a/arch/riscv/include/asm/Kbuild b/arch/riscv/include/asm/Kbuild index 3d9410bb4de0..59dd7be55005 100644 --- a/arch/riscv/include/asm/Kbuild +++ b/arch/riscv/include/asm/Kbuild @@ -1,4 +1,5 @@ # SPDX-License-Identifier: GPL-2.0 +generic-y += early_ioremap.h generic-y += extable.h generic-y += flat.h generic-y += kvm_para.h diff --git a/arch/riscv/include/asm/fixmap.h b/arch/riscv/include/asm/fixmap.h index 11613f38228a..54cbf07fb4e9 100644 --- a/arch/riscv/include/asm/fixmap.h +++ b/arch/riscv/include/asm/fixmap.h @@ -27,6 +27,19 @@ enum fixed_addresses { FIX_TEXT_POKE1, FIX_TEXT_POKE0, FIX_EARLYCON_MEM_BASE, + + __end_of_permanent_fixed_addresses, + /* + * Temporary boot-time mappings, used by early_ioremap(), + * before ioremap() is functional. + */ +#define NR_FIX_BTMAPS (SZ_256K / PAGE_SIZE) +#define FIX_BTMAPS_SLOTS 7 +#define TOTAL_FIX_BTMAPS (NR_FIX_BTMAPS * FIX_BTMAPS_SLOTS) + + FIX_BTMAP_END = __end_of_permanent_fixed_addresses, + FIX_BTMAP_BEGIN = FIX_BTMAP_END + TOTAL_FIX_BTMAPS - 1, + __end_of_fixed_addresses }; diff --git a/arch/riscv/include/asm/io.h b/arch/riscv/include/asm/io.h index 3835c3295dc5..c025a746a148 100644 --- a/arch/riscv/include/asm/io.h +++ b/arch/riscv/include/asm/io.h @@ -14,6 +14,7 @@ #include #include #include +#include /* * MMIO access functions are separated out to break dependency cycles diff --git a/arch/riscv/kernel/setup.c b/arch/riscv/kernel/setup.c index edea7ef88402..41ef96d0d97a 100644 --- a/arch/riscv/kernel/setup.c +++ b/arch/riscv/kernel/setup.c @@ -19,6 +19,7 @@ #include #include +#include #include #include #include @@ -71,6 +72,7 @@ void __init setup_arch(char **cmdline_p) *cmdline_p = boot_command_line; + early_ioremap_setup(); parse_early_param(); setup_bootmem(); diff --git a/arch/riscv/mm/init.c b/arch/riscv/mm/init.c index 2b651f63f5c4..b75ebe8e7a92 100644 --- a/arch/riscv/mm/init.c +++ b/arch/riscv/mm/init.c @@ -403,6 +403,9 @@ asmlinkage void __init setup_vm(uintptr_t dtb_pa) uintptr_t load_pa = (uintptr_t)(&_start); uintptr_t load_sz = (uintptr_t)(&_end) - load_pa; uintptr_t map_size = best_map_size(load_pa, MAX_EARLY_MAPPING_SIZE); +#ifndef __PAGETABLE_PMD_FOLDED + pmd_t fix_bmap_spmd, fix_bmap_epmd; +#endif va_pa_offset = PAGE_OFFSET - load_pa; pfn_base = PFN_DOWN(load_pa); @@ -456,6 +459,36 @@ asmlinkage void __init setup_vm(uintptr_t dtb_pa) pa + PGDIR_SIZE, PGDIR_SIZE, PAGE_KERNEL); dtb_early_va = (void *)DTB_EARLY_BASE_VA + (dtb_pa & (PGDIR_SIZE - 1)); dtb_early_pa = dtb_pa; + + /* + * Bootime fixmap only can handle PMD_SIZE mapping. Thus, boot-ioremap + * range can not span multiple pmds. + */ + BUILD_BUG_ON((__fix_to_virt(FIX_BTMAP_BEGIN) >> PMD_SHIFT) + != (__fix_to_virt(FIX_BTMAP_END) >> PMD_SHIFT)); + +#ifndef __PAGETABLE_PMD_FOLDED + /* + * Early ioremap fixmap is already created as it lies within first 2MB + * of fixmap region. We always map PMD_SIZE. Thus, both FIX_BTMAP_END + * FIX_BTMAP_BEGIN should lie in the same pmd. Verify that and warn + * the user if not. + */ + fix_bmap_spmd = fixmap_pmd[pmd_index(__fix_to_virt(FIX_BTMAP_BEGIN))]; + fix_bmap_epmd = fixmap_pmd[pmd_index(__fix_to_virt(FIX_BTMAP_END))]; + if (pmd_val(fix_bmap_spmd) != pmd_val(fix_bmap_epmd)) { + WARN_ON(1); + pr_warn("fixmap btmap start [%08lx] != end [%08lx]\n", + pmd_val(fix_bmap_spmd), pmd_val(fix_bmap_epmd)); + pr_warn("fix_to_virt(FIX_BTMAP_BEGIN): %08lx\n", + fix_to_virt(FIX_BTMAP_BEGIN)); + pr_warn("fix_to_virt(FIX_BTMAP_END): %08lx\n", + fix_to_virt(FIX_BTMAP_END)); + + pr_warn("FIX_BTMAP_END: %d\n", FIX_BTMAP_END); + pr_warn("FIX_BTMAP_BEGIN: %d\n", FIX_BTMAP_BEGIN); + } +#endif } static void __init setup_vm_final(void) -- 2.25.1