46bbd72f3e
wakeup1() assumes you hold proc_table_lock sleep(chan, lock) provides atomic sleep-and-release to wait for condition ugly code in swtch/scheduler to implement new sleep fix lots of bugs in pipes, wait, and exit fix bugs if timer interrupt goes off in schedule() console locks per line, not per byte
59 lines
982 B
C
59 lines
982 B
C
#include "types.h"
|
|
#include "defs.h"
|
|
#include "x86.h"
|
|
#include "mmu.h"
|
|
#include "param.h"
|
|
#include "proc.h"
|
|
#include "spinlock.h"
|
|
|
|
#define DEBUG 0
|
|
|
|
extern int use_console_lock;
|
|
|
|
int getcallerpc(void *v) {
|
|
return ((int*)v)[-1];
|
|
}
|
|
|
|
void
|
|
acquire1(struct spinlock * lock, struct proc *cp)
|
|
{
|
|
if(DEBUG) cprintf("cpu%d: acquiring at %x\n", cpu(), getcallerpc(&lock));
|
|
|
|
cli();
|
|
while ( cmpxchg(0, 1, &lock->locked) == 1 ) { ; }
|
|
lock->locker_pc = getcallerpc(&lock);
|
|
|
|
if(cp)
|
|
cp->locks += 1;
|
|
|
|
if(DEBUG) cprintf("cpu%d: acquired at %x\n", cpu(), getcallerpc(&lock));
|
|
}
|
|
|
|
void
|
|
release1(struct spinlock * lock, struct proc *cp)
|
|
{
|
|
|
|
if(DEBUG) cprintf ("cpu%d: releasing at %x\n", cpu(), getcallerpc(&lock));
|
|
|
|
if(lock->locked != 1)
|
|
panic("release");
|
|
|
|
if(cp)
|
|
cp->locks -= 1;
|
|
|
|
cmpxchg(1, 0, &lock->locked);
|
|
sti();
|
|
}
|
|
|
|
void
|
|
acquire(struct spinlock *lock)
|
|
{
|
|
acquire1(lock, curproc[cpu()]);
|
|
}
|
|
|
|
void
|
|
release(struct spinlock *lock)
|
|
{
|
|
release1(lock, curproc[cpu()]);
|
|
}
|