Refactor KE::KernelInit::SwitchBootStack() inline assembly
All checks were successful
All checks were successful
This commit is contained in:
@@ -144,14 +144,14 @@ KE::KernelInit::SwitchBootStack(VOID)
|
||||
StartKernel = (PVOID)KE::KernelInit::StartKernel;
|
||||
|
||||
/* Discard old stack frame, switch stack and jump to KernelInit::StartKernel() */
|
||||
__asm__ volatile("mov %0, %%rdx\n"
|
||||
"xor %%rbp, %%rbp\n"
|
||||
"mov %%rdx, %%rsp\n"
|
||||
"sub %1, %%rsp\n"
|
||||
"jmp *%2\n"
|
||||
__asm__ volatile("movq %[Stack], %%rsp\n"
|
||||
"subq %[TotalSize], %%rsp\n"
|
||||
"xorq %%rbp, %%rbp\n"
|
||||
"jmp *%[TargetRoutine]\n"
|
||||
:
|
||||
: "m" (Stack),
|
||||
"i" (FLOATING_SAVE_AREA_SIZE | KEXCEPTION_FRAME_SIZE | KSWITCH_FRAME_SIZE | KRETURN_ADDRESS_SIZE),
|
||||
"r" (StartKernel)
|
||||
: "rdx", "rbp", "rsp", "memory");
|
||||
: [Stack] "r" (Stack),
|
||||
[TargetRoutine] "r" (StartKernel),
|
||||
[TotalSize] "i" (FLOATING_SAVE_AREA_SIZE + KEXCEPTION_FRAME_SIZE +
|
||||
KSWITCH_FRAME_SIZE + KRETURN_ADDRESS_SIZE)
|
||||
: "memory", "rbp", "rsp");
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user