3

我知道自旋锁是由 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;
}

Windows 7 的反编译自旋锁。

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;
}

为什么版本之间的代码不同?特别是,我看不到 Windows 7 版本中添加的代码如何提高自旋锁在虚拟化中的性能。

4

1 回答 1

3

KeAcquireSpinLockRaiseToSynch不一样KeAcquireSpinLock

KeAcquireSpinLockRaiseToSynch保留供系统使用,不打算由接口驱动程序使用。

因此差异。

于 2012-01-28T00:23:58.650 回答