Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • kernel/arch/ia32/src/proc/scheduler.c

    r1d3d2cf r99d6fd0  
    3838#include <proc/thread.h>
    3939#include <arch.h>
    40 #include <arch/interrupt.h>
     40#include <arch/context.h>       /* SP_DELTA */
    4141#include <arch/pm.h>
    4242#include <arch/asm.h>
     
    5858void before_thread_runs_arch(void)
    5959{
    60         uintptr_t kstk = (uintptr_t) &THREAD->kstack[THREAD_STACK_SIZE];
     60        uintptr_t kstk = (uintptr_t) &THREAD->kstack[THREAD_STACK_SIZE -
     61            SP_DELTA];
    6162       
    62         if (CPU->arch.fi.bits.sep) {
    63                 /* Set kernel stack for CP3 -> CPL0 switch via SYSENTER */
    64                 write_msr(IA32_MSR_SYSENTER_ESP, kstk - sizeof(istate_t));
    65         }
     63        /* Set kernel stack for CP3 -> CPL0 switch via SYSENTER */
     64        write_msr(IA32_MSR_SYSENTER_ESP, kstk);
    6665       
    6766        /* Set kernel stack for CPL3 -> CPL0 switch via interrupt */
    6867        CPU->arch.tss->esp0 = kstk;
    69         CPU->arch.tss->ss0 = GDT_SELECTOR(KDATA_DES);
     68        CPU->arch.tss->ss0 = gdtselector(KDATA_DES);
    7069       
    7170        /* Set up TLS in GS register */
Note: See TracChangeset for help on using the changeset viewer.