kernel/0092-fix-eswin-load-kvm-module-failed.patch

81 lines
3.8 KiB
Diff
Raw Normal View History

2024-12-15 18:29:23 +00:00
From 58d07ca01dc6452536d593a4e7f8d8a16094ee8f Mon Sep 17 00:00:00 2001
From: Han Gao <gaohan@iscas.ac.cn>
Date: Mon, 15 Jul 2024 23:51:22 +0800
Subject: [PATCH 092/219] fix: eswin: load kvm module failed
riscv_noncoherent_supported should not be called multiple times
in the sifive_errata_probe function
[ 72.659708] Unable to handle kernel paging request at virtual address ffffffff81389380
[ 72.667661] Oops [#1]
[ 72.669934] Modules linked in: es_iommu_rsv es_dev_dma_buf es_vdec es_rsvmem_heap es_buddy_driver nfnetlink ip_tables x_tables sha1_generic hmac ipv6 pvrsrvkm
[ 72.684133] CPU: 0 PID: 696 Comm: modprobe Not tainted 6.6.36-win2030 #10
[ 72.690922] Hardware name: ESWIN EIC7700 (DT)
[ 72.695277] epc : riscv_noncoherent_supported+0x10/0x3e
[ 72.700507] ra : sifive_errata_patch_func+0x44/0x1e2
[ 72.705560] epc : ffffffff8000bff6 ra : ffffffff8000c4da sp : ffff8f8008273ac0
[ 72.712781] gp : ffffffff81948e40 tp : ffffaf80b1115400 t0 : 0000000000000000
[ 72.720001] t1 : 0000000000000000 t2 : 0000000000000002 s0 : ffff8f8008273b30
[ 72.727221] s1 : ffffffff01d5e388 a0 : ffffffff01d5e388 a1 : ffffffff01d5e3c8
[ 72.734441] a2 : 8000000000000008 a3 : 0000000006220425 a4 : ffffffff81388ff2
[ 72.741661] a5 : 0000000000000001 a6 : 0000000000000006 a7 : 0000000000000010
[ 72.748881] s2 : ffffffff01d5e3c8 s3 : 8000000000000008 s4 : 0000000000000001
[ 72.756101] s5 : 0000000006220425 s6 : ffffffff8180f660 s7 : 0000000000000001
[ 72.763321] s8 : ffff8f8008273d58 s9 : ffffffff01dcb8c0 s10: ffffffff01dcb758
[ 72.770542] s11: 0000000000000000 t3 : ffffffffffffffff t4 : ffffffffffffffff
[ 72.777761] t5 : ffffffffffffffff t6 : ffffaf82a5ecc1c8
[ 72.783071] status: 0000000200000120 badaddr: ffffffff81389380 cause: 000000000000000f
[ 72.790986] [<ffffffff8000bff6>] riscv_noncoherent_supported+0x10/0x3e
[ 72.797514] [<ffffffff800027f6>] _apply_alternatives+0x84/0x86
[ 72.803348] [<ffffffff800029cc>] apply_module_alternatives+0x10/0x18
[ 72.809701] [<ffffffff80007c8c>] module_finalize+0x5e/0x74
[ 72.815193] [<ffffffff80083b54>] load_module+0x1110/0x18b4
[ 72.820682] [<ffffffff80084496>] init_module_from_file+0x76/0xaa
[ 72.826688] [<ffffffff800846e4>] __riscv_sys_finit_module+0x1e2/0x2a8
[ 72.833129] [<ffffffff80a9ccbc>] do_trap_ecall_u+0xbe/0x130
[ 72.838703] [<ffffffff80aa51f8>] ret_from_exception+0x0/0x64
[ 72.844376] Code: 0009 b7ed e797 0193 a783 12e7 c799 4785 d717 0137 (0723) 38f7
[ 72.851970] ---[ end trace 0000000000000000 ]---
Signed-off-by: Han Gao <gaohan@iscas.ac.cn>
Signed-off-by: Han Gao <rabenda.cn@gmail.com>
---
arch/riscv/errata/sifive/errata.c | 14 ++++++++------
1 file changed, 8 insertions(+), 6 deletions(-)
diff --git a/arch/riscv/errata/sifive/errata.c b/arch/riscv/errata/sifive/errata.c
index 20dcbd9e76f4..57fac9c2ccba 100644
--- a/arch/riscv/errata/sifive/errata.c
+++ b/arch/riscv/errata/sifive/errata.c
@@ -63,12 +63,6 @@ static u32 __init_or_module sifive_errata_probe(unsigned long archid,
int idx;
u32 cpu_req_errata = 0;
-#if IS_ENABLED(CONFIG_ARCH_ESWIN_EIC770X_SOC_FAMILY)
- /* Set this just to make core cbo code happy */
- riscv_cbom_block_size = 1;
- riscv_noncoherent_supported();
-#endif
-
for (idx = 0; idx < ERRATA_SIFIVE_NUMBER; idx++)
if (errata_list[idx].check_func(archid, impid))
cpu_req_errata |= (1U << idx);
@@ -101,6 +95,14 @@ void sifive_errata_patch_func(struct alt_entry *begin, struct alt_entry *end,
if (stage == RISCV_ALTERNATIVES_EARLY_BOOT)
return;
+#if IS_ENABLED(CONFIG_ARCH_ESWIN_EIC770X_SOC_FAMILY)
+ /* Set this just to make core cbo code happy */
+ if (stage == RISCV_ALTERNATIVES_BOOT) {
+ riscv_cbom_block_size = 1;
+ riscv_noncoherent_supported();
+ }
+#endif
+
cpu_req_errata = sifive_errata_probe(archid, impid);
for (alt = begin; alt < end; alt++) {
--
2.47.0