RISC-V: mm: Fix set_satp_mode() for platform not having Sv57
authorAnup Patel <apatel@ventanamicro.com>
Tue, 12 Apr 2022 03:33:35 +0000 (09:03 +0530)
committerPalmer Dabbelt <palmer@rivosinc.com>
Thu, 21 Apr 2022 22:10:39 +0000 (15:10 -0700)
commitd5fdade9331f57335af97dbef61cf15b4930abc1
tree6f679f8322ff9804b0ee55e2cc466407c2090a0a
parentf81f7861ee2aaa6f652f18e8f622547bdd379724
RISC-V: mm: Fix set_satp_mode() for platform not having Sv57

When Sv57 is not available the satp.MODE test in set_satp_mode() will
fail and lead to pgdir re-programming for Sv48. The pgdir re-programming
will fail as well due to pre-existing pgdir entry used for Sv57 and as
a result kernel fails to boot on RISC-V platform not having Sv57.

To fix above issue, we should clear the pgdir memory in set_satp_mode()
before re-programming.

Fixes: 011f09d12052 ("riscv: mm: Set sv57 on defaultly")
Reported-by: Mayuresh Chitale <mchitale@ventanamicro.com>
Signed-off-by: Anup Patel <apatel@ventanamicro.com>
Reviewed-by: Atish Patra <atishp@rivosinc.com>
Cc: stable@vger.kernel.org
Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
arch/riscv/mm/init.c