VirtualBox และ CPUID พื้นฐาน
คุณต้องตั้งค่าVBoxInternal/CPUM/HostCPUID
extradata ของเครื่องเสมือน สิ่งนี้จะทำให้ 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)
การตั้งค่าสตริงผู้ขาย CPU
หาก EAX เป็น 0 (หรือ 80000000 ชั่วโมงบน 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" |
(นำมาจากข้อกำหนด CPUID ของ AMDส่วนย่อย "CPUID Fn0000_0000_E")
หากคุณ concatenate 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
การตั้งค่าสตริงแบรนด์ CPU
หาก 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
1HostCPUID
ค่าถูกนำมาจาก VirtualBox รายงานข้อผิดพลาด# 7865