2.自旋锁

1、不同版本的内核文件

单核:
2-9-9-12分页 ntkrnlpa.exe
10-10-12分页 ntoskrnl.exe

多核:
2-9-9-12分页 ntkrnlpa.exe
10-10-12分页 ntoskrnl.exe

文件虽然相同但单核与多核的代码是不一样的,自旋锁只有在多核下才是有价值的。

Windows自旋锁
参考: KeAcquireSpinLockAtDpcLevel

多核下有很多包含SpinLock的函数,只要包含这个的函数都是和自旋锁相关的

关键代码:lock bts dword ptr [ecx], 0

LOCK是锁前缀,保证这条指令在同一时刻只能有一个CPU访问 BTS指令:设置并检测将ECX指向数据的第0位置1如果[ECX]原来的值==0那么CF=1 否则CF=0

多核
2.自旋锁

单核直接retn 4
2.自旋锁

pause指令让CPU在这旋转一会,所以它叫自旋锁。

总结:

  1. 自旋锁只对多核有意义。 (查看不同版本的KeAcquireSpinLockAtDpcLevel函数)
  2. 自旋锁与临界区、事件、互斥体一样,都是一种同步机制,都可以让当前线程处于等待状态,区别在于自旋锁不用切换线程。