[rtems commit] riscv: Do not clear thread context
Sebastian Huber
sebh at rtems.org
Fri Jun 29 09:59:07 UTC 2018
Module: rtems
Branch: master
Commit: a49a3c8eed0663bfc4de8b854dcede1573daf246
Changeset: http://git.rtems.org/rtems/commit/?id=a49a3c8eed0663bfc4de8b854dcede1573daf246
Author: Sebastian Huber <sebastian.huber at embedded-brains.de>
Date: Wed Jun 27 08:37:34 2018 +0200
riscv: Do not clear thread context
Do not clear the complete thread context. Initialize only the necessary
members. The Context_Control::is_executing member must be preserved
across _CPU_Context_Initialize() calls.
Update #3433.
---
cpukit/score/cpu/riscv/riscv-context-initialize.c | 7 ++-----
1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/cpukit/score/cpu/riscv/riscv-context-initialize.c b/cpukit/score/cpu/riscv/riscv-context-initialize.c
index 619c691..f558fbd 100644
--- a/cpukit/score/cpu/riscv/riscv-context-initialize.c
+++ b/cpukit/score/cpu/riscv/riscv-context-initialize.c
@@ -32,11 +32,8 @@
#include "config.h"
#endif
-#include <string.h>
-
#include <rtems/score/cpu.h>
#include <rtems/score/riscv-utility.h>
-#include <rtems/score/interr.h>
void _CPU_Context_Initialize(
Context_Control *context,
@@ -52,8 +49,6 @@ void _CPU_Context_Initialize(
uintptr_t stack_high = stack + stack_area_size;
- memset(context, 0, sizeof(*context));
-
/* Stack Pointer - sp/x2 */
context->x[2] = stack_high;
/* Frame Pointer - fp/x8 */
@@ -61,6 +56,8 @@ void _CPU_Context_Initialize(
/* Return Address - ra/x1 */
context->x[1] = (uintptr_t) entry_point;
+ context->isr_dispatch_disable = 0;
+
/* Enable interrupts and FP */
context->mstatus = MSTATUS_FS | MSTATUS_MIE;
}
More information about the vc
mailing list