在多CPU系統,即MP系統中,存在總線仲裁。
1. 原子操作
從CPU或者I/O設備到主存儲器的單次讀或者寫操作為原子操作。
這樣的操作一旦開始,就不能被系統上來自CPU或者I/O設備的任何其他存儲操作所中斷,或者受到他們的干擾。
原子變量
2. 自旋鎖 (自旋鎖用于短期互斥)
自旋鎖得名于這樣一個事實,一個進程在等候另一個進程正在使用的鎖時會處于忙等待(busy-wait,在一個循環中自旋)狀態。
typedef int lock_t;
void initlock( volatile lock_t * lock_status)
{
*lock_status = 0;
}
int
test_and_set(volatile int *addr)
{
int old_value;
old_value = swap_atomic(addr, 1);
if (old_value == 0)
return 0;
return 1;
}
void lock(volatile lock_t *lock_status)
{
while (test_and_set( lock_status) == 1) //被鎖定時,進程在此自旋。
;
}
// test_and_set 如果前面的狀態不為0就返回1,否則返回0.
//如果鎖的狀態已經是1(鎖已經被占用),那么test_and_set函數返回1,并且處理器在循環中自旋,直到該鎖被釋放為止。只要把鎖的狀態設置為0,就可以釋放鎖了。
void
unlock(volatile lock_t * lock_status)
{
*lock_status =0;
}
減少對鎖的爭用可以采用兩種辦法:
第一、內核針對不同的臨界資源使用不同的自旋鎖,防止處理器在沒有競爭條件威脅的時候被另一個處理器掛起。
第二、增強lock和unlock函數,在上鎖的時候屏蔽中斷。