2024-05-14 13:36:27

by Alexandre Ghiti

[permalink] [raw]
Subject: [PATCH] riscv: Extend sv39 linear mapping max size to 128G

This harmonizes all virtual addressing modes which can now all map
(PGDIR_SIZE * PTRS_PER_PGD) / 4 of physical memory.

Signed-off-by: Alexandre Ghiti <[email protected]>
---
Documentation/arch/riscv/vm-layout.rst | 10 +++++-----
arch/riscv/include/asm/page.h | 2 +-
2 files changed, 6 insertions(+), 6 deletions(-)

diff --git a/Documentation/arch/riscv/vm-layout.rst b/Documentation/arch/riscv/vm-layout.rst
index e476b4386bd9..f37812863991 100644
--- a/Documentation/arch/riscv/vm-layout.rst
+++ b/Documentation/arch/riscv/vm-layout.rst
@@ -47,11 +47,11 @@ RISC-V Linux Kernel SV39
| Kernel-space virtual memory, shared between all processes:
____________________________________________________________|___________________________________________________________
| | | |
- ffffffc6fea00000 | -228 GB | ffffffc6feffffff | 6 MB | fixmap
- ffffffc6ff000000 | -228 GB | ffffffc6ffffffff | 16 MB | PCI io
- ffffffc700000000 | -228 GB | ffffffc7ffffffff | 4 GB | vmemmap
- ffffffc800000000 | -224 GB | ffffffd7ffffffff | 64 GB | vmalloc/ioremap space
- ffffffd800000000 | -160 GB | fffffff6ffffffff | 124 GB | direct mapping of all physical memory
+ ffffffc5fea00000 | -232 GB | ffffffc5feffffff | 6 MB | fixmap
+ ffffffc5ff000000 | -232 GB | ffffffc5ffffffff | 16 MB | PCI io
+ ffffffc600000000 | -232 GB | ffffffc6ffffffff | 4 GB | vmemmap
+ ffffffc700000000 | -228 GB | ffffffd6ffffffff | 64 GB | vmalloc/ioremap space
+ ffffffd700000000 | -164 GB | fffffff6ffffffff | 128 GB | direct mapping of all physical memory
fffffff700000000 | -36 GB | fffffffeffffffff | 32 GB | kasan
__________________|____________|__________________|_________|____________________________________________________________
|
diff --git a/arch/riscv/include/asm/page.h b/arch/riscv/include/asm/page.h
index 115ac98b8d72..727ed7887cab 100644
--- a/arch/riscv/include/asm/page.h
+++ b/arch/riscv/include/asm/page.h
@@ -37,7 +37,7 @@
* define the PAGE_OFFSET value for SV48 and SV39.
*/
#define PAGE_OFFSET_L4 _AC(0xffffaf8000000000, UL)
-#define PAGE_OFFSET_L3 _AC(0xffffffd800000000, UL)
+#define PAGE_OFFSET_L3 _AC(0xffffffd700000000, UL)
#else
#define PAGE_OFFSET _AC(CONFIG_PAGE_OFFSET, UL)
#endif /* CONFIG_64BIT */
--
2.39.2



2024-05-14 16:35:40

by Björn Töpel

[permalink] [raw]
Subject: Re: [PATCH] riscv: Extend sv39 linear mapping max size to 128G

Alexandre Ghiti <[email protected]> writes:

> This harmonizes all virtual addressing modes which can now all map
> (PGDIR_SIZE * PTRS_PER_PGD) / 4 of physical memory.
>
> Signed-off-by: Alexandre Ghiti <[email protected]>

Nice!

Reviewed-by: Björn Töpel <[email protected]>