我知道自旋锁是由Windows中的hal.dll导出的,所以我对自旋锁的代码进行了逆向工程。结果如下。
Windows XP的反编译自旋锁。
unsigned __int32 __thiscall KfAcquireSpinLock(signed __int32 *this)
{
unsigned __int32 result; // eax@1
result = __readfsdword(36);
__writefsdword(36, 2u);
while ( _interlockedbittestandset(this, 0) )
{
while ( *this & 1 )
_mm_pause();
}
return result;
}
Windows7的反编译自旋锁。
unsigned __int32 __fastcall KeAcquireSpinLockRaiseToSynch(signed __int32 *a1)
{
unsigned __int32 result; // eax@1
int v2; // edx@4
unsigned __int32 v3; // ST0C_4@7
signed __int32 *v4; // ST08_4@7
int v5; // ST04_4@7
result = __readfsdword(36);
__writefsbyte(36, 0x1Bu);
while ( _interlockedbittestandset(a1, 0) )
{
v2 = 0;
do
{
++v2;
if ( !(v2 & dword_8002D1B0) )
{
if ( dword_8002D19C & 0x40 )
{
v3 = result;
v4 = a1;
v5 = v2;
dword_8002D1B4(v2);
v2 = v5;
a1 = v4;
result = v3;
}
}
_mm_pause();
}
while ( *a1 & 1 );
}
return result;
}
为什么不同版本的代码会有所不同?特别是,我看不到Windows7版本中添加的代码如何提高spinlock在虚拟化方面的性能。
发布于 2012-01-28 08:23:59
KeAcquireSpinLockRaiseToSynch
与KeAcquireSpinLock
不同。
KeAcquireSpinLockRaiseToSynch
是reserved for system use,不能由接口驱动程序使用。
这就是区别所在。
https://stackoverflow.com/questions/8924069
复制相似问题