diff options
author | Christian Cunningham <cc@localhost> | 2022-02-01 20:36:30 -0700 |
---|---|---|
committer | Christian Cunningham <cc@localhost> | 2022-02-01 20:36:30 -0700 |
commit | 7d3884b5cfc282dbdfe5d9a22d8b2b343280b8af (patch) | |
tree | a3e5e5376c35cce48d1e2d907720646448c5e2ba /src | |
parent | 98793badc1c1d3e4bfd735fdecd3d2d731701ab3 (diff) |
Thread yield control to any other threads
Diffstat (limited to 'src')
-rw-r--r-- | src/cpu/irq.c | 12 | ||||
-rw-r--r-- | src/exceptions/svc.S | 13 | ||||
-rw-r--r-- | src/sys/schedule.c | 13 |
3 files changed, 30 insertions, 8 deletions
diff --git a/src/cpu/irq.c b/src/cpu/irq.c index 612b6d8..2197067 100644 --- a/src/cpu/irq.c +++ b/src/cpu/irq.c @@ -140,14 +140,15 @@ void testfxn2(void) void testfxn(void) { - unsigned int i = 0x69420; + unsigned long long ti = get_sys_time(); + unsigned int i = 0xDEADBEEF; void* a = malloc(5); void* b = malloc(3); void* c = malloc(4); void* d = malloc(4); uart_string("Start\n"); add_thread(testfxn2, 0, 0); - delay(0x20000000); + sys0(SYS_YIELD); uart_string("Freeing B\n"); free(b); uart_string("Freeing A\n"); @@ -160,4 +161,11 @@ void testfxn(void) delay(0x20000000); uart_hexn(i); uart_string("End\n"); + unsigned long long tf = get_sys_time(); + unsigned long long dt = tf-ti; + unsigned long thi, tlo; + thi = dt >> 32; + tlo = dt; + uart_hex(thi); + uart_hexn(tlo); } diff --git a/src/exceptions/svc.S b/src/exceptions/svc.S index 51c6479..7e6a327 100644 --- a/src/exceptions/svc.S +++ b/src/exceptions/svc.S @@ -12,12 +12,13 @@ svc: beq svc_000002 cmp r0, #1 beq svc_000001 - cmp r0, #1 + cmp r0, #0 beq svc_000000 svc_000000: - cps #0x13 - b svc_exit -svc_000001: + bl yield + ldmfd sp!, {r0-r12,lr} + b schedule +svc_000001: // Get time mov r2, #0x3004 movt r2, #0x3F00 ldr r0, [r2, #4] // <- SYS_TIMER_CLO @@ -25,10 +26,10 @@ svc_000001: str r0, [sp] // Return value str r1, [sp, #4] // Return value hi b svc_exit -svc_000002: +svc_000002: // Run Schedule ldmfd sp!, {r0-r12,lr} b schedule -svc_000003: +svc_000003: // Clean task stack ldr r3, =scheduler ldr r2, [r3, #0] // struct Thread* rthread ldr r1, [r2, #8] // sp_base diff --git a/src/sys/schedule.c b/src/sys/schedule.c index 6f2a72d..70aebb9 100644 --- a/src/sys/schedule.c +++ b/src/sys/schedule.c @@ -156,3 +156,16 @@ void* get_rthread_roffset(void) { return &scheduler.thread_queues[scheduler.rthread->priority].ready.roffset; } + +void yield(void) +{ + struct Thread* rthread = scheduler.rthread; + if (rthread == &usrloopthread) + return; + unsigned char priority = rthread->priority; + struct ThreadRotBuffer* trb = &scheduler.thread_queues[priority].ready; + trb->roffset += 1; + trb->roffset %= TQUEUE_MAX; + trb->queue[trb->woffset++] = rthread; + trb->roffset %= TQUEUE_MAX; +} |