Changes in kernel/arch/mips32/src/mips32.c [5a5269d:dabaa83] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/mips32/src/mips32.c
r5a5269d rdabaa83 71 71 arch_ops_t *arch_ops = &mips32_ops; 72 72 73 /* 74 * Why the linker moves the variable 64K away in assembler 75 * when not in .text section? 76 */ 77 73 78 /* Stack pointer saved when entering user mode */ 74 // FIXME: This won't work with SMP unless thread creation is globally serialized. 75 uintptr_t supervisor_sp; 79 uintptr_t supervisor_sp __attribute__((section(".text"))); 76 80 77 81 size_t cpu_count = 0; … … 167 171 cp0_status_write(cp0_status_read() | (cp0_status_exl_exception_bit | 168 172 cp0_status_um_bit | cp0_status_ie_enabled_bit)); 169 cp0_epc_write( kernel_uarg->uspace_entry);170 userspace_asm( kernel_uarg->uspace_stack +171 kernel_uarg->uspace_stack_size ,172 kernel_uarg->uspace_uarg,173 kernel_uarg->uspace_entry);173 cp0_epc_write((uintptr_t) kernel_uarg->uspace_entry); 174 userspace_asm(((uintptr_t) kernel_uarg->uspace_stack + 175 kernel_uarg->uspace_stack_size), 176 (uintptr_t) kernel_uarg->uspace_uarg, 177 (uintptr_t) kernel_uarg->uspace_entry); 174 178 175 179 while (true)
Note:
See TracChangeset
for help on using the changeset viewer.