aboutsummaryrefslogtreecommitdiff
path: root/src/kernel/lib/stdio/debug.c
blob: d66ee5948eb2105c19592af4945b8a4f36cdd8ec (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#include <stdarg.h>
#include <stdint.h>
#include <kernel/lib/string.h>
#include <kernel/lib/stdlib.h>
#include <kernel/io/io.h>

void _write_serial(const char *data)
{
    for (size_t i = 0; i < strlen(data); i++) serial_put(data[i]);
}

void serial_printf(const char *fmt, ...)
{
    va_list args;
    va_start(args, fmt);

    uint8_t readyToFormat = 0;

    char buff = 0;

    for (; *fmt; fmt++) {
        if (readyToFormat) {
            if (*fmt == '%') {
                serial_put('%');
                readyToFormat = 0;
                continue;
            }

            buff = *fmt;
            if (buff == 's') {
                const char *str = va_arg(args, const char*);
                _write_serial(str);
                readyToFormat = 0;
            } else if (buff == 'x') {
                char *p = htoa((uint32_t) va_arg(args, int));
                _write_serial(p);
                kfree(p);
                readyToFormat = 0;
            } else if (buff == 'd') {
                char *p = itoa(va_arg(args, int));
                _write_serial(p);
                kfree(p);
                readyToFormat = 0;
            } else if (buff == 'c') {
                serial_put((char) va_arg(args, int));
                readyToFormat = 0;
            }
        } else {
            if (*fmt == '%')
                readyToFormat = 1;
            else
                serial_put(*fmt);
        }
    }

    serial_put('\n');

    va_end(args);
}