summaryrefslogtreecommitdiff
path: root/kernel/src/print.c
diff options
context:
space:
mode:
authorTyler Murphy <=>2023-07-17 19:34:52 -0400
committerTyler Murphy <=>2023-07-17 19:34:52 -0400
commit7a912d1b668ab86ffe088eca3ac7e6f78a04a0c5 (patch)
tree4e86ff20e73171285156631db043e12aaf63bf04 /kernel/src/print.c
parentpaging (diff)
downloadfinix-7a912d1b668ab86ffe088eca3ac7e6f78a04a0c5.tar.gz
finix-7a912d1b668ab86ffe088eca3ac7e6f78a04a0c5.tar.bz2
finix-7a912d1b668ab86ffe088eca3ac7e6f78a04a0c5.zip
refactoring
Diffstat (limited to 'kernel/src/print.c')
-rw-r--r--kernel/src/print.c83
1 files changed, 83 insertions, 0 deletions
diff --git a/kernel/src/print.c b/kernel/src/print.c
new file mode 100644
index 0000000..12f45de
--- /dev/null
+++ b/kernel/src/print.c
@@ -0,0 +1,83 @@
+#include <stdbool.h>
+#include <stdint.h>
+#include <stdlib.h>
+#include <string.h>
+#include <print.h>
+#include <term.h>
+
+void printk(const char *restrict format, ...) {
+ va_list args;
+ va_start(args, format);
+ vprintk(format, args);
+ va_end(args);
+}
+
+void vprintk(const char *restrict format, va_list args) {
+ char buf[80];
+ for (; *format; format++) {
+ if (*format == '%') {
+ bool l = false;
+ char c = *++format;
+ if (c == 'l') {
+ l = true;
+ c = *++format;
+ }
+ switch(c) {
+ case '%':
+ putchar('%');
+ break;
+ case 's':
+ puts(va_arg(args, char*));
+ break;
+ case 'c':
+ putchar(va_arg(args, int));
+ break;
+ case 'd':
+ if (l) ltoa(va_arg(args, long long), buf, 10);
+ else itoa(va_arg(args, int), buf, 10);
+ puts(buf);
+ break;
+ case 'u':
+ if (l) ultoa(va_arg(args, unsigned long long), buf, 10);
+ else utoa(va_arg(args, unsigned int), buf, 10);
+ puts(buf);
+ break;
+ case 'f':
+ case 'F':
+ ftoa(va_arg(args, double), buf);
+ puts(buf);
+ break;
+ case 'x':
+ case 'X':
+ utoa(va_arg(args, unsigned int), buf, 16);
+ puts(buf);
+ break;
+ case 'b':
+ va_arg(args, int) ? puts("true") : puts("false");
+ break;
+ case 'k': {
+ static char disp[] = {'B', 'K', 'M', 'G'};
+ uint32_t size = va_arg(args, unsigned int);
+ size_t i = 0;
+ while (size / 1024 > 0) {
+ size /= 1024;
+ i++;
+ }
+ utoa(size, buf, 10);
+ puts(buf);
+ putchar(disp[i]);
+ if (i > 0) putchar('B');
+ break;
+ }
+ default:
+ break;
+ }
+ } else {
+ putchar(*format);
+ }
+ }
+}
+
+void puts(const char *s) {
+ for(; *s; s++) putchar(*s);
+}