Message ID | 20221020075846.305576-3-apatel@ventanamicro.com (mailing list archive) |
---|---|
State | Superseded |
Delegated to: | Palmer Dabbelt |
Headers | show |
Series | Add PMEM support for RISC-V | expand |
On Thu, Oct 20, 2022 at 01:28:44PM +0530, Anup Patel wrote: > Currently, the memremap() called with MEMREMAP_WB maps memory using > the generic ioremap() function which breaks on system with Svpbmt > because memory mapped using _PAGE_IOREMAP page attributes is treated > as strongly-ordered non-cacheable IO memory. > > To address this, we implement RISC-V specific arch_memremap_wb() > which maps memory using _PAGE_KERNEL page attributes resulting in > write-back cacheable mapping on systems with Svpbmt. > > Fixes: ff689fd21cb1 ("riscv: add RISC-V Svpbmt extension support") > Co-developed-by: Mayuresh Chitale <mchitale@ventanamicro.com> > Signed-off-by: Mayuresh Chitale <mchitale@ventanamicro.com> > Signed-off-by: Anup Patel <apatel@ventanamicro.com> Hey Arnd, Does this look okay to you now? Thanks, Conor. > --- > arch/riscv/include/asm/io.h | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/arch/riscv/include/asm/io.h b/arch/riscv/include/asm/io.h > index 92080a227937..42497d487a17 100644 > --- a/arch/riscv/include/asm/io.h > +++ b/arch/riscv/include/asm/io.h > @@ -135,4 +135,9 @@ __io_writes_outs(outs, u64, q, __io_pbr(), __io_paw()) > > #include <asm-generic/io.h> > > +#ifdef CONFIG_MMU > +#define arch_memremap_wb(addr, size) \ > + ((__force void *)ioremap_prot((addr), (size), _PAGE_KERNEL)) > +#endif > + > #endif /* _ASM_RISCV_IO_H */ > -- > 2.34.1 >
diff --git a/arch/riscv/include/asm/io.h b/arch/riscv/include/asm/io.h index 92080a227937..42497d487a17 100644 --- a/arch/riscv/include/asm/io.h +++ b/arch/riscv/include/asm/io.h @@ -135,4 +135,9 @@ __io_writes_outs(outs, u64, q, __io_pbr(), __io_paw()) #include <asm-generic/io.h> +#ifdef CONFIG_MMU +#define arch_memremap_wb(addr, size) \ + ((__force void *)ioremap_prot((addr), (size), _PAGE_KERNEL)) +#endif + #endif /* _ASM_RISCV_IO_H */