X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/f1036cb8c8899f38e97e45d345a0c28585d9a000..80890b99fec2630ef0a1a0805d894c3d86c16506:/lunaix-os/kernel/k_main.c diff --git a/lunaix-os/kernel/k_main.c b/lunaix-os/kernel/k_main.c index 3f56166..b3b1103 100644 --- a/lunaix-os/kernel/k_main.c +++ b/lunaix-os/kernel/k_main.c @@ -1,44 +1,71 @@ -#include -#include -#include #include -#include +#include +#include +#include +#include +#include +#include +#include extern uint8_t __kernel_start; +LOG_MODULE("LX") + +void +test_timer(void* payload); + void _kernel_main() { char buf[64]; - - printf("Hello higher half kernel world!\nWe are now running in virtual " + + kprintf(KINFO "Hello higher half kernel world!\nWe are now running in virtual " "address space!\n\n"); - + cpu_get_brand(buf); - printf("CPU: %s\n\n", buf); + kprintf("CPU: %s\n\n", buf); void* k_start = vmm_v2p(&__kernel_start); - printf("The kernel's base address mapping: %p->%p\n", &__kernel_start, k_start); - - dmm_init(); + kprintf(KINFO "The kernel's base address mapping: %p->%p\n", &__kernel_start, k_start); // test malloc & free - - uint32_t** arr = (uint32_t**) lx_malloc(10 * sizeof(uint32_t*)); - - for (size_t i = 0; i < 10; i++) - { - arr[i] = (uint32_t*) lx_malloc((i + 1) * 2); - } - void* big_ = lx_malloc(8192); + uint8_t** arr = (uint8_t**)lxmalloc(10 * sizeof(uint8_t*)); - for (size_t i = 0; i < 10; i++) - { - lx_free(arr[i]); + for (size_t i = 0; i < 10; i++) { + arr[i] = (uint8_t*)lxmalloc((i + 1) * 2); } - - lx_free(arr); - lx_free(big_); - // assert(0); + + for (size_t i = 0; i < 10; i++) { + lxfree(arr[i]); + } + + uint8_t* big_ = lxmalloc(8192); + big_[0] = 123; + big_[1] = 23; + big_[2] = 3; + + kprintf(KINFO "%u, %u, %u\n", big_[0], big_[1], big_[2]); + + // good free + lxfree(arr); + lxfree(big_); + + timer_run_second(1, test_timer, NULL, TIMER_MODE_PERIODIC); + + spin(); +} + +static datetime_t datetime; + +void test_timer(void* payload) { + clock_walltime(&datetime); + + kprintf(KWARN "%u/%02u/%02u %02u:%02u:%02u\r", + datetime.year, + datetime.month, + datetime.day, + datetime.hour, + datetime.minute, + datetime.second); } \ No newline at end of file