aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/user/init.h6
-rw-r--r--src/kern/main.c14
-rw-r--r--src/kern/priv.c14
-rw-r--r--src/user/init.c11
4 files changed, 30 insertions, 15 deletions
diff --git a/include/user/init.h b/include/user/init.h
new file mode 100644
index 0000000..a55d5d1
--- /dev/null
+++ b/include/user/init.h
@@ -0,0 +1,6 @@
+#ifndef USER_INIT_H_
+#define USER_INIT_H_
+
+void usermode_start();
+
+#endif
diff --git a/src/kern/main.c b/src/kern/main.c
index 3af8beb..4fddb0a 100644
--- a/src/kern/main.c
+++ b/src/kern/main.c
@@ -35,19 +35,7 @@ void configure_mpu()
int main()
{
configure_mpu();
-
- klogf("Outside of usermode, I can still log stuff using klogf()\n");
-
- enter_user_mode();
-
- logs("Now that I'm in user mode, I have to log stuff using a system call\n");
- logs(
- "because I no longer have direct accss to USART2 and cannot use\n"
- "klogf()\n");
-
-
- for (;;)
- ;
+ jump_to_user_mode();
}
#endif
diff --git a/src/kern/priv.c b/src/kern/priv.c
index 3162639..2c45eca 100644
--- a/src/kern/priv.c
+++ b/src/kern/priv.c
@@ -2,6 +2,7 @@
#include "arch.h"
#include "kern/log.h"
+#include "kern/mem.h"
void set_control_register(uint32_t reg)
{
@@ -24,7 +25,16 @@ void enter_user_mode()
void jump_to_user_mode()
{
+ void* new_stack = kalloc(4096);
+ new_stack += 4096;
+
asm volatile(
- "mov r0, #1\n\t"
- "msr control, r0\n\t");
+ "mov r0, %0\n\t"
+ "msr psp, r0\n\t"
+ "mrs r0, control\n\t"
+ "orrs r0, r0, #3\n\t"
+ "msr control, r0\n\t"
+ "isb\n\t"
+ "dsb\n\t"
+ "b usermode_start\n\t" : : "r"(new_stack));
}
diff --git a/src/user/init.c b/src/user/init.c
new file mode 100644
index 0000000..00f1b28
--- /dev/null
+++ b/src/user/init.c
@@ -0,0 +1,11 @@
+#include "user/syscall.h"
+#include "kern/log.h"
+#include "kern/common.h"
+
+void usermode_start()
+{
+ logs("I'm in usermode!\n");
+ logs("I'm still in usermode!\n");
+ logs("I'm super still in usermode!\n");
+ for(;;);
+}