diff options
author | Xiang W <wxjstz@126.com> | 2021-04-01 15:59:40 +0800 |
---|---|---|
committer | Anup Patel <anup@brainfault.org> | 2021-04-05 13:43:08 +0530 |
commit | 3d8a952737935dd98200b05b68dacb5e94071877 (patch) | |
tree | 0e641519f65664f3f05deada0cf547c64037e08c /lib/sbi | |
parent | 4ef2f5d3e6b25356a8fab19574bed76ce60edeee (diff) |
lib: fix csr detect support
csr_read_allowed/csr_read_allowed requires trap.case to detect the results,
but if no exception occurs, the value of trap.case will remain unchanged,
which makes the detection results unreliable. Add code to initialize
trap.case to 0.
Signed-off-by: Xiang W <wxjstz@126.com>
Reviewed-by: Anup Patel <anup.patel@wdc.com>
Diffstat (limited to 'lib/sbi')
-rw-r--r-- | lib/sbi/sbi_hart.c | 3 |
1 files changed, 0 insertions, 3 deletions
diff --git a/lib/sbi/sbi_hart.c b/lib/sbi/sbi_hart.c index d91b08c..de59b14 100644 --- a/lib/sbi/sbi_hart.c +++ b/lib/sbi/sbi_hart.c @@ -406,7 +406,6 @@ __mhpm_skip: #undef __check_csr /* Detect if hart supports SCOUNTEREN feature */ - trap.cause = 0; val = csr_read_allowed(CSR_SCOUNTEREN, (unsigned long)&trap); if (!trap.cause) { csr_write_allowed(CSR_SCOUNTEREN, (unsigned long)&trap, val); @@ -415,7 +414,6 @@ __mhpm_skip: } /* Detect if hart supports MCOUNTEREN feature */ - trap.cause = 0; val = csr_read_allowed(CSR_MCOUNTEREN, (unsigned long)&trap); if (!trap.cause) { csr_write_allowed(CSR_MCOUNTEREN, (unsigned long)&trap, val); @@ -424,7 +422,6 @@ __mhpm_skip: } /* Detect if hart supports time CSR */ - trap.cause = 0; csr_read_allowed(CSR_TIME, (unsigned long)&trap); if (!trap.cause) hfeatures->features |= SBI_HART_HAS_TIME; |