Merge branch 'master' of g.csail.mit.edu:xv6-dev
This commit is contained in:
commit
b8fd4cba13
7
proc.c
7
proc.c
|
@ -302,7 +302,12 @@ scheduler(void)
|
|||
}
|
||||
|
||||
// Enter scheduler. Must hold only ptable.lock
|
||||
// and have changed proc->state.
|
||||
// and have changed proc->state. Saves and restores
|
||||
// intena because intena is a property of this
|
||||
// kernel thread, not this CPU. It should
|
||||
// be proc->intena and proc->ncli, but that would
|
||||
// break in the few places where a lock is held but
|
||||
// there's no process.
|
||||
void
|
||||
sched(void)
|
||||
{
|
||||
|
|
|
@ -102,8 +102,9 @@ pushcli(void)
|
|||
|
||||
eflags = readeflags();
|
||||
cli();
|
||||
if(cpu->ncli++ == 0)
|
||||
if(cpu->ncli == 0)
|
||||
cpu->intena = eflags & FL_IF;
|
||||
cpu->ncli += 1;
|
||||
}
|
||||
|
||||
void
|
||||
|
|
2
vm.c
2
vm.c
|
@ -27,7 +27,7 @@ seginit(void)
|
|||
c->gdt[SEG_UCODE] = SEG(STA_X|STA_R, 0, 0xffffffff, DPL_USER);
|
||||
c->gdt[SEG_UDATA] = SEG(STA_W, 0, 0xffffffff, DPL_USER);
|
||||
|
||||
// Map cpu and curproc -- these are private per cpu.
|
||||
// Map cpu and proc -- these are private per cpu.
|
||||
c->gdt[SEG_KCPU] = SEG(STA_W, &c->cpu, 8, 0);
|
||||
|
||||
lgdt(c->gdt, sizeof(c->gdt));
|
||||
|
|
Loading…
Reference in a new issue