diff options
author | dzwdz | 2021-07-18 14:16:24 +0200 |
---|---|---|
committer | dzwdz | 2021-07-18 14:16:24 +0200 |
commit | ed12953042ec38244f3ab93d67f4c2dea6f1fee3 (patch) | |
tree | 7984f01c156535fb57104db9cbcf0f8a9112b7ed /src/kernel/arch/log.h | |
parent | e333a43fb7c1e39418cfcc1be660d5006903c42a (diff) |
move all kernel sources to src/kernel/
Diffstat (limited to 'src/kernel/arch/log.h')
-rw-r--r-- | src/kernel/arch/log.h | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/src/kernel/arch/log.h b/src/kernel/arch/log.h new file mode 100644 index 0000000..0a5d5a0 --- /dev/null +++ b/src/kernel/arch/log.h @@ -0,0 +1,28 @@ +#pragma once +#include <stddef.h> + +void log_write(const char *buf, size_t len); + +inline void log_hex(const char *buf, size_t len) { + char hex[2]; + for (size_t i = 0; i < len; i++) { + hex[0] = (buf[i] & 0xF0) >> 4; + hex[0] += '0'; + if (hex[0] > '9') + hex[0] += 'a' - '9' - 1; + + hex[1] = buf[i] & 0xF; + hex[1] += '0'; + if (hex[1] > '9') + hex[1] += 'a' - '9' - 1; + + log_write(hex, 2); + } +} + +// used for static strings +#define log_const(str) log_write(str, sizeof(str) - 1) + +// very hacky, shouldn't be actually used - only for debugging +// prints backwards +#define log_var_dont_use(var) log_hex((void*)&var, sizeof(var)) |