aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/sbi/riscv_asm.c7
-rw-r--r--lib/sbi/sbi_console.c14
2 files changed, 18 insertions, 3 deletions
diff --git a/lib/sbi/riscv_asm.c b/lib/sbi/riscv_asm.c
index 1642ac6..2e2e148 100644
--- a/lib/sbi/riscv_asm.c
+++ b/lib/sbi/riscv_asm.c
@@ -76,7 +76,8 @@ void misa_string(int xlen, char *out, unsigned int out_sz)
out[pos++] = '8';
break;
default:
- BUG();
+ sbi_panic("%s: Unknown misa.MXL encoding %d",
+ __func__, xlen);
return;
}
}
@@ -145,7 +146,7 @@ unsigned long csr_read_num(int csr_num)
#endif
default:
- BUG();
+ sbi_panic("%s: Unknown CSR %#x", __func__, csr_num);
break;
};
@@ -213,7 +214,7 @@ void csr_write_num(int csr_num, unsigned long val)
switchcase_csr_write_16(CSR_MHPMEVENT16, val)
default:
- BUG();
+ sbi_panic("%s: Unknown CSR %#x", __func__, csr_num);
break;
};
diff --git a/lib/sbi/sbi_console.c b/lib/sbi/sbi_console.c
index 29eede3..34c843d 100644
--- a/lib/sbi/sbi_console.c
+++ b/lib/sbi/sbi_console.c
@@ -9,6 +9,7 @@
#include <sbi/riscv_locks.h>
#include <sbi/sbi_console.h>
+#include <sbi/sbi_hart.h>
#include <sbi/sbi_platform.h>
#include <sbi/sbi_scratch.h>
@@ -397,6 +398,19 @@ int sbi_dprintf(const char *format, ...)
return retval;
}
+void sbi_panic(const char *format, ...)
+{
+ va_list args;
+
+ spin_lock(&console_out_lock);
+ va_start(args, format);
+ print(NULL, NULL, format, args);
+ va_end(args);
+ spin_unlock(&console_out_lock);
+
+ sbi_hart_hang();
+}
+
const struct sbi_console_device *sbi_console_get_device(void)
{
return console_dev;