diff --git a/include/sbi/sbi_console.h b/include/sbi/sbi_console.h index 16021d0..45af22f 100644 --- a/include/sbi/sbi_console.h +++ b/include/sbi/sbi_console.h @@ -31,6 +31,10 @@ int __printf(3, 4) sbi_snprintf(char *out, u32 out_sz, const char *format, ...); int __printf(1, 2) sbi_printf(const char *format, ...); struct sbi_scratch; + +int __printf(2, 3) sbi_dprintf(struct sbi_scratch *scratch, + const char *format, ...); + int sbi_console_init(struct sbi_scratch *scratch); #endif diff --git a/include/sbi/sbi_scratch.h b/include/sbi/sbi_scratch.h index 46ea38f..fd18bb2 100644 --- a/include/sbi/sbi_scratch.h +++ b/include/sbi/sbi_scratch.h @@ -74,6 +74,8 @@ struct sbi_scratch { enum sbi_scratch_options { /** Disable prints during boot */ SBI_SCRATCH_NO_BOOT_PRINTS = (1 << 0), + /** Enable runtime debug prints */ + SBI_SCRATCH_DEBUG_PRINTS = (1 << 1), }; /** Get pointer to sbi_scratch for current HART */ diff --git a/lib/sbi/sbi_console.c b/lib/sbi/sbi_console.c index 30fb2c8..03dcdb2 100644 --- a/lib/sbi/sbi_console.c +++ b/lib/sbi/sbi_console.c @@ -375,6 +375,19 @@ int sbi_printf(const char *format, ...) return retval; } +int sbi_dprintf(struct sbi_scratch *scratch, const char *format, ...) +{ + va_list args; + int retval = 0; + + va_start(args, format); + if (scratch->options & SBI_SCRATCH_DEBUG_PRINTS) + retval = print(NULL, NULL, format, args); + va_end(args); + + return retval; +} + int sbi_console_init(struct sbi_scratch *scratch) { console_plat = sbi_platform_ptr(scratch);