diff options
| author | kaashoek <kaashoek> | 2006-06-28 16:44:41 +0000 | 
|---|---|---|
| committer | kaashoek <kaashoek> | 2006-06-28 16:44:41 +0000 | 
| commit | f7cea12b38a86e9b37fa5bc635310d3f85e5f8db (patch) | |
| tree | 3e4992596ecd73a1068b1a1284d1128692e903f1 | |
| parent | bd303ed06096395778c80558e013b64bb47b9e9c (diff) | |
| download | xv6-labs-f7cea12b38a86e9b37fa5bc635310d3f85e5f8db.tar.gz xv6-labs-f7cea12b38a86e9b37fa5bc635310d3f85e5f8db.tar.bz2 xv6-labs-f7cea12b38a86e9b37fa5bc635310d3f85e5f8db.zip  | |
disable interrupts when holding kernel lock
| -rw-r--r-- | defs.h | 1 | ||||
| -rw-r--r-- | mp.c | 6 | ||||
| -rw-r--r-- | spinlock.c | 3 | 
3 files changed, 10 insertions, 0 deletions
@@ -41,6 +41,7 @@ void lapic_init(int);  void lapic_timerinit(void);  void lapic_timerintr(void);  void lapic_enableintr(void); +void lapic_disableintr(void);  // spinlock.c  extern uint32_t kernel_lock; @@ -183,6 +183,12 @@ lapic_enableintr(void)    lapic_write(LAPIC_TPR, 0);  } +void +lapic_disableintr(void)  +{ +  lapic_write(LAPIC_TPR, 0xFF); +} +  int  cpu(void)  { @@ -14,6 +14,8 @@ acquire_spinlock(uint32_t* lock)    if (*lock == cpu_id)      return; +   +  lapic_disableintr();    while ( cmpxchg(LOCK_FREE, cpu_id, lock) != cpu_id ) { ; }    // cprintf ("acquired: %d\n", cpu_id);  } @@ -26,6 +28,7 @@ release_spinlock(uint32_t* lock)    if (*lock != cpu_id)      panic("release_spinlock: releasing a lock that i don't own\n");    *lock = LOCK_FREE; +  lapic_enableintr();  }  void  | 
