diff options
author | Christian Cunningham <cc@localhost> | 2022-02-01 19:39:36 -0700 |
---|---|---|
committer | Christian Cunningham <cc@localhost> | 2022-02-01 19:39:36 -0700 |
commit | 98793badc1c1d3e4bfd735fdecd3d2d731701ab3 (patch) | |
tree | 3406220e55b0e7cce3895817796f75bf754da6d9 /src | |
parent | 33e35caf1104cdf5b8e1470112677f78b5e8dc59 (diff) |
Syscall to get timer value
Diffstat (limited to 'src')
-rw-r--r-- | src/cpu/irq.c | 13 | ||||
-rw-r--r-- | src/exceptions/svc.S | 6 |
2 files changed, 19 insertions, 0 deletions
diff --git a/src/cpu/irq.c b/src/cpu/irq.c index 24a809c..612b6d8 100644 --- a/src/cpu/irq.c +++ b/src/cpu/irq.c @@ -11,6 +11,7 @@ #include <util/status.h> #include <util/time.h> +void utime(void); void testfxn(void); void handle_data(unsigned char); @@ -109,6 +110,8 @@ void handle_data(unsigned char data) add_thread(uart_scheduler, 0, 2); } else if (data == 0x63) { add_thread(heap_info, 0, 2); + } else if (data == 0x64) { + add_thread(utime, 0, 2); } else { } g_Drawer.x = 0; @@ -120,6 +123,16 @@ void handle_data(unsigned char data) write_string(&g_Drawer, "> "); } +void utime(void) +{ + unsigned long thi, tlo; + unsigned long long t = get_sys_time(); + thi = t >> 32; + tlo = t; + uart_hex(thi); + uart_hexn(tlo); +} + void testfxn2(void) { uart_string("Ran testfxn2\n"); diff --git a/src/exceptions/svc.S b/src/exceptions/svc.S index d1fcbc0..51c6479 100644 --- a/src/exceptions/svc.S +++ b/src/exceptions/svc.S @@ -18,6 +18,12 @@ svc_000000: cps #0x13 b svc_exit svc_000001: + mov r2, #0x3004 + movt r2, #0x3F00 + ldr r0, [r2, #4] // <- SYS_TIMER_CLO + ldr r1, [r2, #0] // <- SYS_TIMER_CHI + str r0, [sp] // Return value + str r1, [sp, #4] // Return value hi b svc_exit svc_000002: ldmfd sp!, {r0-r12,lr} |