From d0b87b7cc01270b3ed8a1e20a64482e1446f416b Mon Sep 17 00:00:00 2001 From: Rob Austein Date: Sat, 15 Apr 2017 16:35:41 -0400 Subject: Logging implementation for Alpha hardware. --- projects/hsm/hsm.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) (limited to 'projects/hsm/hsm.c') diff --git a/projects/hsm/hsm.c b/projects/hsm/hsm.c index 60e35fc..5e9d06e 100644 --- a/projects/hsm/hsm.c +++ b/projects/hsm/hsm.c @@ -257,6 +257,31 @@ void hal_critical_section_end(void) } #endif +/* Logging */ + +static hal_log_level_t current_log_level; + +void hal_log_set_level(const hal_log_level_t level) +{ + current_log_level = level; +} + +void hal_log(const hal_log_level_t level, const char *format, ...) +{ + if (level < current_log_level) + return; + + char buffer[2048]; + va_list ap; + + va_start(ap, format); + vsnprintf(buffer, sizeof(buffer), format, ap); + va_end(ap); + + uart_send_string2(STM_UART_MGMT, buffer); + uart_send_string2(STM_UART_MGMT, "\r\n"); +} + /* The main thread. This does all the setup, and the worker threads handle * the rest. */ -- cgit v1.2.3