Основы VirtualBox и CPUID
Вам необходимо установить дополнительные данные VBoxInternal/CPUM/HostCPUID
HostCPUID виртуальной машины. В результате VirtualBox сообщит гостю о пользовательских результатах для инструкции CPUID . В зависимости от значения регистра EAX, эта инструкция возвращает информацию о процессоре - такие как поставщик, тип, семейство, степпинг, бренд, размер кэша, функции (MMX, SSE, SSE2, PAE, HTT) и т.д. Чем больше результатов чем вы травляете, тем выше шансы обмануть гостя.
Вы можете использовать команду vboxmanage setextradata
для настройки виртуальной машины. Например,
vboxmanage setextradata WinXP VBoxInternal/CPUM/HostCPUID/80000003/ebx 0x50202952
заставит CPUID возвращать 50202952₍₁₆₎ в регистр EBX при вызове с EAX, установленным в 80000003₍₁₆₎. (С этого момента шестнадцатеричные числа будут записываться как 0xNN или NNh.)
Установка строки поставщика ЦП
Если EAX равен 0 (или 80000000h для AMD), CPUID возвращает поставщика в виде строки ASCII в регистрах EBX, EDX, ECX (обратите внимание на порядок). Для процессора AMD они выглядят так:
| Register | Value | Description |
|----------|------------|--------------------------------|
| EBX | 6874_7541h | The ASCII characters "h t u A" |
| ECX | 444D_4163h | The ASCII characters "D M A c" |
| EDX | 6974_6E65h | The ASCII characters "i t n e" |
(Взято из спецификации AMD CPUID, подраздел "CPUID Fn0000_0000_E")
Если вы объедините EBX, EDX и ECX, вы получите AuthenticAMD
.
Если у вас есть Bash и традиционные утилиты Unix, вы можете легко установить поставщика с помощью следующих команд:
vm='WinXP' # UUID works as well
# The vendor string needs to have 12 characters!
vendor='AuthenticAMD'
if [ ${#vendor} -ne 12 ]; then
exit 1
fi
ascii2hex() { echo -n 0x; od -A n --endian little -t x4 | sed 's/ //g'; }
registers=(ebx edx ecx)
for (( i=0; i<${#vendor}; i+=4 )); do
register=${registers[$(($i/4))]}
value=`echo -n "${vendor:$i:4}" | ascii2hex`
# set value to an empty string to reset the CPUID, i.e.
# value=""
for eax in 00000000 80000000; do
key=VBoxInternal/CPUM/HostCPUID/${eax}/${register}
vboxmanage setextradata "$vm" $key $value
done
done
Установка строки марки процессора
Если EAX равен 80000002h, 80000003h, 80000004h, CPUID возвращает 16 символов ASCII строки бренда в регистрах EAX, EBX, ECX, EDX, всего 3 * 16 = 48 символов; строка заканчивается нулевым символом. Обратите внимание, что эта функция была введена с процессорами Pentium 4. Вот как может выглядеть строка бренда на процессоре Pentium 4:
| EAX Input Value | Return Values | ASCII Equivalent |
|-----------------|-----------------|------------------|
| 80000002h | EAX = 20202020h | " " |
| | EBX = 20202020h | " " |
| | ECX = 20202020h | " " |
| | EDX = 6E492020h | "nI " |
|-----------------|-----------------|------------------|
| 80000003h | EAX = 286C6574h | "(let" |
| | EBX = 50202952h | "P )R" |
| | ECX = 69746E65h | "itne" |
| | EDX = 52286D75h | "R(mu" |
|-----------------|-----------------|------------------|
| 80000004h | EAX = 20342029h | " 4 )" |
| | EBX = 20555043h | " UPC" |
| | ECX = 30303531h | "0051" |
| | EDX = 007A484Dh | "☠zHM" |
|-----------------|-----------------|------------------|
(Взято из Справочника по программированию расширений набора команд архитектуры Intel, подраздел 2.9, "Инструкция CPUID", таблица 2-30. ☠ - нулевой символ (числовое значение 0).)
Если вы соберете результаты, вы получите Intel(R) Pentium(R) 4 CPU 1500MHz☠
.
Если у вас есть Bash и традиционные утилиты Unix, вы можете легко установить марку с помощью следующих команд:
vm='WinXP' # UUID works as well
# The brand string needs to have 47 characters!
# The null terminator is added automatically
brand=' Intel(R) Pentium(R) 4 CPU 1500MHz'
if [ ${#brand} -ne 47 ]; then
exit 1
fi
ascii2hex() { echo -n 0x; od -A n --endian little -t x4 | sed 's/ //g'; }
eax_values=(80000002 80000003 80000004)
registers=(edx ecx ebx eax)
for (( i=0; i<${#brand}; i+=4 )); do
eax=${eax_values[$((${i} / 4 / 4))]}
register=${registers[$((${i} / 4 % 4 ))]}
key=VBoxInternal/CPUM/HostCPUID/${eax}/${register}
value=`echo -n "${brand:$i:4}" | ascii2hex`
# set value to an empty string to reset the CPUID, i.e.
# value=""
vboxmanage setextradata "$vm" $key $value
done
Если у вас есть командная строка Windows, вы можете установить марку Intel(R) Core(TM)2 CPU 6600 @ 2.40 GHz
1 , запустив:
set vm=your-vm-name-or-uuid
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000002/eax 0x65746e49
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000002/ebx 0x2952286c
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000002/ecx 0x726f4320
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000002/edx 0x4d542865
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000003/eax 0x43203229
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000003/ebx 0x20205550
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000003/ecx 0x20202020
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000003/edx 0x20202020
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000004/eax 0x30303636
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000004/ebx 0x20402020
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000004/ecx 0x30342e32
vboxmanage setextradata %vm% VBoxInternal/CPUM/HostCPUID/80000004/edx 0x007a4847
1 Значения HostCPUID
были взяты из сообщения об ошибке VirtualBox # 7865.