refactor: rename QUICK to FAST

master
Sean McBride 5 years ago
parent 8614a838f8
commit 31c3a9329a

@ -20,7 +20,7 @@ arch_context_init(struct arch_context *actx, reg_t ip, reg_t sp)
actx->regs[UREG_RSP] = sp; actx->regs[UREG_RSP] = sp;
actx->regs[UREG_RIP] = ip; actx->regs[UREG_RIP] = ip;
actx->variant = ARCH_CONTEXT_QUICK; actx->variant = ARCH_CONTEXT_FAST;
} }
/** /**

@ -26,7 +26,7 @@ enum UREGS
enum ARCH_CONTEXT enum ARCH_CONTEXT
{ {
ARCH_CONTEXT_UNUSED = 0, ARCH_CONTEXT_UNUSED = 0,
ARCH_CONTEXT_QUICK = 1, ARCH_CONTEXT_FAST = 1,
ARCH_CONTEXT_SLOW = 2, ARCH_CONTEXT_SLOW = 2,
ARCH_CONTEXT_RUNNING = 3 ARCH_CONTEXT_RUNNING = 3
}; };

@ -58,7 +58,7 @@ arch_context_restore(mcontext_t *active_context, struct arch_context *sandbox_co
{ {
assert(active_context != NULL); assert(active_context != NULL);
assert(sandbox_context != NULL); assert(sandbox_context != NULL);
assert(sandbox_context->variant == ARCH_CONTEXT_QUICK); assert(sandbox_context->variant == ARCH_CONTEXT_FAST);
assert(sandbox_context != &worker_thread_base_context); assert(sandbox_context != &worker_thread_base_context);
/* TODO: Phani explained that we need to be able to restore a sandbox with an IP of 0. Why is this? */ /* TODO: Phani explained that we need to be able to restore a sandbox with an IP of 0. Why is this? */

@ -38,7 +38,7 @@ static void __attribute__((noinline)) arch_context_init(struct arch_context *act
actx->regs[UREG_RSP] = sp; actx->regs[UREG_RSP] = sp;
actx->regs[UREG_RIP] = ip; actx->regs[UREG_RIP] = ip;
actx->variant = ARCH_CONTEXT_QUICK; actx->variant = ARCH_CONTEXT_FAST;
} }
@ -56,8 +56,8 @@ arch_context_switch(struct arch_context *current, struct arch_context *next)
/* Assumption: Software Interrupts are disabled by caller */ /* Assumption: Software Interrupts are disabled by caller */
assert(software_interrupt_is_disabled); assert(software_interrupt_is_disabled);
if (next->variant == ARCH_CONTEXT_QUICK && (next->regs[UREG_RIP] == 0 || next->regs[UREG_RSP] == 0)) { if (next->variant == ARCH_CONTEXT_FAST && (next->regs[UREG_RIP] == 0 || next->regs[UREG_RSP] == 0)) {
debuglog("Next Context was Quick Variant, but data was invalid."); debuglog("Next Context was Fast Variant, but data was invalid.");
assert(0); assert(0);
} }
@ -72,7 +72,7 @@ arch_context_switch(struct arch_context *current, struct arch_context *next)
if (next == NULL) next = &worker_thread_base_context; if (next == NULL) next = &worker_thread_base_context;
/* Assumption: The context we are switching to should have saved a context in some form */ /* Assumption: The context we are switching to should have saved a context in some form */
assert(next->variant == ARCH_CONTEXT_QUICK || next->variant != ARCH_CONTEXT_UNUSED); assert(next->variant == ARCH_CONTEXT_FAST || next->variant != ARCH_CONTEXT_UNUSED);
reg_t *current_registers = current->regs, *next_registers = next->regs; reg_t *current_registers = current->regs, *next_registers = next->regs;
assert(current_registers && next_registers); assert(current_registers && next_registers);
@ -87,7 +87,7 @@ arch_context_switch(struct arch_context *current, struct arch_context *next)
*/ */
"movq $2f, 8(%%rax)\n\t" /* Write the address of label 2 to current_registers[1] (instruction_pointer). */ "movq $2f, 8(%%rax)\n\t" /* Write the address of label 2 to current_registers[1] (instruction_pointer). */
"movq %%rsp, (%%rax)\n\t" /* current_registers[0] (stack_pointer) = stack_pointer */ "movq %%rsp, (%%rax)\n\t" /* current_registers[0] (stack_pointer) = stack_pointer */
"movq $1, (%%rcx)\n\t" /* current->variant = ARCH_CONTEXT_QUICK; */ "movq $1, (%%rcx)\n\t" /* current->variant = ARCH_CONTEXT_FAST; */
/* /*
* Check if the variant of the context we're trying to switch to is SLOW (mcontext-based) * Check if the variant of the context we're trying to switch to is SLOW (mcontext-based)
@ -119,7 +119,7 @@ arch_context_switch(struct arch_context *current, struct arch_context *next)
* The sandbox either resumes at label 2 or 3 depending on if an offset of 8 is used. * The sandbox either resumes at label 2 or 3 depending on if an offset of 8 is used.
*/ */
"2:\n\t" "2:\n\t"
"movq $3, (%%rdx)\n\t" /* next->variant = ARCH_CONTEXT_QUICK; */ "movq $3, (%%rdx)\n\t" /* next->variant = ARCH_CONTEXT_FAST; */
".align 8\n\t" ".align 8\n\t"
/* This label is used in conjunction with a static offset */ /* This label is used in conjunction with a static offset */

Loading…
Cancel
Save