CPUID - CPUID

In x86 arxitektura, CPUID ko'rsatma (a tomonidan aniqlangan CPUID opkod ) a protsessorga qo'shimcha ko'rsatma (uning nomi olingan Markaziy protsessor Identifikatsiya) dasturiy ta'minotga protsessor tafsilotlarini topishga imkon beradi. Tomonidan kiritilgan Intel 1993 yilda ishga tushirilishi bilan Pentium va SL-takomillashtirilgan 486 protsessorlar.[1]

Dastur .dan foydalanishi mumkin CPUID protsessor turini va shunga o'xshash xususiyatlarni aniqlash MMX /SSE amalga oshirilmoqda.

Tarix

Umumiy mavjudligidan oldin CPUID ko'rsatma, dasturchilar ezoterik yozadilar mashina kodi protsessorning modeli va modelini aniqlash uchun protsessor xatti-harakatlaridagi kichik farqlardan foydalangan.[2][3] 80386 protsessorining kiritilishi bilan, qayta tiklashda EDX qayta ko'rib chiqilganligini ko'rsatdi, ammo bu faqat qayta o'rnatilgandan so'ng o'qilishi mumkin edi va dasturlarda qiymatni o'qishning standart usuli yo'q edi.

X86 oilasi tashqarisida, ishlab chiquvchilardan, asosan, mavjud bo'lgan CPU dizaynidagi o'zgarishlarni aniqlash uchun, asosan, ezoterik jarayonlardan foydalanish (buyruq vaqti yoki protsessorning ishdan chiqishiga sabab bo'lishi kerak) talab qilinadi.

Motorola 680x0 oilasida - hech qachon hech qanday CPUID ko'rsatmasi bo'lmagan - ba'zi bir aniq ko'rsatmalar yuqori imtiyozlarni talab qiladi. Bular turli CPU oilalari a'zolarini ajratish uchun ishlatilishi mumkin. In Motorola 68010 ko'rsatma SRdan ko'chirish imtiyozga ega bo'ldi. Ushbu muhim ko'rsatma (va davlat mashinasi) o'zgarishi 68010 ga javob berishga imkon berdi Popek va Goldberg virtualizatsiyasi talablari. Chunki 68000 imtiyozsiz taklif qildi SRdan ko'chirish 2 xil protsessorni CPU xato holati tetiklashi bilan ajratib ko'rsatish mumkin.

Da CPUID ko'rsatma x86 arxitekturasiga xosdir, boshqa arxitektura (ARM kabi) ko'pincha x86 protsessor ko'rsatmasi tomonidan taqdim etilgan bir xil ma'lumotlarni olish uchun belgilangan usullarda o'qilishi mumkin bo'lgan chip registrlarini taqdim etadi.

CPUID-ga qo'ng'iroq qilish

The CPUID opcode bu 0Fh, A2h (ikki bayt sifatida yoki A20Fh bitta singari so'z).

Yilda assambleya tili, CPUID ko'rsatmasi hech qanday parametrlarni talab qilmaydi CPUID qaytarilgan ma'lumotlarning asosiy toifasini aniqlash uchun EAX registridan bevosita foydalanadi. Intelning so'nggi terminologiyasida bu CPUID varag'i deb nomlanadi. CPUID bilan chaqirish kerak EAX = 0 birinchi navbatda, bu EAX-da ro'yxatdan o'tkaziladi, chunki protsessor amalga oshiradigan eng yuqori EAX chaqirish parametrini (bargini).

Kengaytirilgan funktsiyalar haqida ma'lumot olish uchun CPUID EAX to'plamining eng muhim biti bilan qo'ng'iroq qilish kerak. Kengaytirilgan funktsiyani chaqirish parametrini aniqlash uchun qo'ng'iroq qiling CPUID bilan EAX = 80000000 soat.

CPUID barglari 3 dan katta, ammo 80000000 dan kam bo'lgan vaqtga faqat kirish imkoni mavjud bo'lganda modelga oid registrlar bor IA32_MISC_ENABLE.BOOT_NT4 [bit 22] = 0 (bu sukut bo'yicha shunday). Nomidan ko'rinib turibdiki, Windows NT 4.0 agar ushbu bit o'rnatilmagan bo'lsa, SP6 to'g'ri yuklanmaguncha,[4][o'lik havola ] ammo Windows-ning keyingi versiyalari bunga muhtoj emas, shuning uchun 4 dan katta asosiy varaqlar hozirgi Windows tizimlarida ko'rinadi deb taxmin qilish mumkin. 2014 yil iyul holatiga ko'ra, asosiy yaroqli barglar 14 soatgacha ko'tariladi, ammo ba'zi barglar tomonidan qaytarilgan ma'lumotlar ommaviy hujjatlarda oshkor qilinmaydi, ya'ni ular "zaxiralangan".

Yaqinda qo'shilgan ba'zi barglarning pastki barglari ham bor, ular ECX registri orqali CPUID-ga qo'ng'iroq qilishdan oldin tanlanadi.

EAX = 0: Eng yuqori parametr va ishlab chiqaruvchining identifikatori

Bu protsessorning ishlab chiqaruvchi identifikatori qatorini qaytaradi - o'n ikki belgidan iborat ASCII EBX, EDX, ECX-da saqlanadigan satr (shu tartibda). Qo'ng'iroq qilishning eng yuqori parametrlari (qo'ng'iroq qilishdan oldin EAX-ni o'rnatadigan eng katta qiymat CPUID) EAX-da qaytariladi.

Bu erda protsessorlarning ro'yxati va amalga oshirilgan eng yuqori funktsiya mavjud.

Funktsiyaning eng yuqori parametrlari
ProtsessorlarAsosiyKengaytirilgan
Avvalroq Intel 486CPUID amalga oshirilmadi
Keyinchalik Intel 486 va Pentium0x01Amalga oshirilmagan
Pentium Pro, Pentium II va Celeron0x02Amalga oshirilmagan
Pentium III0x03Amalga oshirilmagan
Pentium 40x020x8000 0004
Xeon0x020x8000 0004
Pentium M0x020x8000 0004
Hyper-Threading bilan Pentium 40x050x8000 0008
Pentium D (8xx)0x050x8000 0008
Pentium D (9xx)0x060x8000 0008
Core Duo0x0A0x8000 0008
Core 2 Duo0x0A0x8000 0008
Xeon 3000, 5100, 5200, 5300, 5400 seriyalari0x0A0x8000 0008
Core 2 Duo 8000 seriyali0x0D0x8000 0008
Xeon 5200, 5400 seriyali0x0A0x8000 0008
Atom0x0A0x8000 0008
Nehalemga asoslangan protsessorlar0x0B0x8000 0008
IvyBridge asosidagi protsessorlar0x0D0x8000 0008
Skylake-ga asoslangan protsessorlar (proc base & max freq; Bus ref. Freq)0x160x8000 0008
Chipdagi tizim sotuvchisi sifatini ro'yxatga olish asosiy varaq0x170x8000 0008

Quyidagi ma'lum protsessor ishlab chiqaruvchisi identifikatori satrlari:

Quyida ochiq manba tomonidan ishlatiladigan identifikator satrlari keltirilgan yumshoq protsessor yadrolari:

  • "GenuineAO486" - ao486 protsessor[5]
  • "GenuineIntel" - v586 yadrosi[6] (bu Intel ID qatori bilan bir xil)

Virtual mashinalardan ma'lum bo'lgan ID satrlari quyidagilar:

Masalan, GenuineIntel protsessorida EBX-ga qaytarilgan qiymatlar 0x756e6547, EDX 0x49656e69 va ECX 0x6c65746e. Quyidagi kod yozilgan GNU Assembler uchun x86-64 arxitekturasi va sotuvchi identifikatori satrini, shuningdek CPU amalga oshiradigan eng yuqori qo'ng'iroq parametrini ko'rsatadi.

	.datas0:	.asiz	"CPUID:% x"s1:	.asiz	"Amalga oshirilgan eng katta asosiy raqam:% i"s2:	.asiz	"Sotuvchi identifikatori:% .12s"	.matn	.tizim	32	.globl	asosiyasosiy:	pushq	% rbp	movq	% rsp,% rbp	subq	$16,% rsp	ko'chirish	$1,% eax	CPU	movq	$ s0,% rdi	ko'chirish	% eax,% esi	xorl	% eax,% eax	qo'ng'iroq qiling	printf	pushq	% rbx  // -fPIC	xorl	% eax,% eax	CPU	ko'chirish	% ebx,0(% rsp)	ko'chirish	% edx,4(% rsp)	ko'chirish	% ecx,8(% rsp)	popq	% rbx  // -fPIC	movq	$ s1,% rdi	ko'chirish	% eax,% esi	xorl	% eax,% eax	qo'ng'iroq qiling	printf	movq	$ s2,% rdi	movq	% rsp,% rsi	xorl	% eax,% eax	qo'ng'iroq qiling	printf	movq	% rbp,% rsp	popq	% rbp//	ret	ko'chirish	$1,% eax	int	0x80 dollar

EAX = 1: protsessor haqida ma'lumot va xususiyatlar

Bu protsessorni qaytaradi qadam bosish, EAX registridagi model, va oilaviy ma'lumotlar (shuningdek imzo protsessor), EDX va ECX registrlaridagi bayroqchalar va EBX registrdagi qo'shimcha xususiyatlar haqida ma'lumot.[7]

Protsessor versiyasi haqida ma'lumot
EAX
313029282726252423222120191817161514131211109876543210
HimoyalanganKengaytirilgan oilaviy guvohnomaKengaytirilgan model identifikatoriHimoyalanganProtsessor turiOilaviy guvohnomaModelBosqich identifikatori
  • Step ID - bu aniqlanganligi sababli berilgan mahsulotni qayta ko'rib chiqish raqami xatolar yoki boshqa o'zgarishlar.
  • Haqiqiy protsessor modeli Model, kengaytirilgan model identifikatori va oilaviy identifikator maydonlaridan olingan. Agar Family ID maydoni 6 yoki 15 bo'lsa, model 4 bit chapga siljigan Kengaytirilgan Model identifikatori maydonining yig'indisiga va Model maydoniga teng. Aks holda, model Model maydonining qiymatiga teng.
  • Haqiqiy protsessor oilasi Family ID va Extended Family ID maydonlaridan olingan. Oilaviy guvohnoma maydoni 15 ga teng bo'lsa, oila Kengaytirilgan oila guvohnomasi va Oilaviy guvohnoma maydonlarining yig'indisiga teng. Aks holda, oila Family ID maydonining qiymatiga teng.
  • "Processor Type" maydonining ma'nosi quyidagi jadvalda keltirilgan.
Protsessor turi
TuriKodlash Ikkilik
Asl OEM Protsessor00
Intel Overdrive protsessori01
Ikkala protsessor (Intel486 protsessorlariga taalluqli emas)10
Himoyalangan qiymat11
Qo'shimcha ma'lumot
BitlarEBXYaroqli
7:0Tovar indeksi
15:8CLFLUSH qator kattaligi (qiymat. 8 = baytdagi kesh satrining kattaligi)agar CLFLUSH xususiyati bayrog'i o'rnatilgan bo'lsa.

CPUID.01.EDX.CLFSH [19-bit] = 1

23:16Ushbu jismoniy paketdagi mantiqiy protsessorlar uchun manzil identifikatorlarining maksimal soni;

Ushbu qiymatdan kam bo'lmagan 2 ga teng bo'lgan eng yaqin butun son fizik paketdagi turli mantiqiy protsessorlarga murojaat qilish uchun ajratilgan noyob APIC identifikatorlari soni.

Ilgari ishlatilishi: Jismoniy protsessorga to'g'ri keladigan mantiqiy protsessorlar soni; ikkitasi Hyper-Threading Technology bilan Pentium 4 protsessori uchun.[8]

agar Giper iplar xususiyati bayrog'i o'rnatilgan.

CPUID.01.EDX.HTT [bit 28] = 1

31:24Mahalliy APIC identifikatori: dastlabki APIC-identifikatori bajarilayotgan mantiqiy protsessorni aniqlash uchun ishlatiladi.

Uni cpuid 0BH yaprog'i orqali ham aniqlash mumkin (CPUID.0Bh.EDX [x2APIC-ID]).

Pentium 4 va undan keyingi protsessorlar.

Protsessor haqida ma'lumot va xususiyat bayroqlari ishlab chiqaruvchiga xosdir, lekin odatda Intel qiymatlari boshqa ishlab chiqaruvchilar tomonidan moslik uchun ishlatiladi.

Xususiyat haqida ma'lumot
BitEDXECX
QisqaXususiyatQisqaXususiyat
0fpuTransport vosita ichida x87 FPUsse3Preskott yangi ko'rsatmalar -SSE3 (PNI)
1vmeVirtual 8086 rejimining kengaytmalari (VIF, VIP, PIV kabi)pclmulqdqPCLMULQDQ
2deKengaytmalarda disk raskadrovka (CR4 bit 3)dtes6464-bitli disk raskadrovka do'koni (edx bit 21)
3pseSahifa o'lchamini kengaytirishmonitorMONITOR va MWAIT ko'rsatmalari (SSE3 )
4tscVaqt shtampi hisoblagichids-cplCPL malakali disk raskadrovka do'koni
5msrModelga xos registrlarvmxVirtual mashina kuchlanishlari
6paeJismoniy manzilni kengaytirishsmxXavfsiz rejim kengaytmalari (LaGrande )
7mceMashinani tekshirishda istisnoestRivojlangan SpeedStep
8cx8CMPXCHG8 (taqqoslash va almashtirish ) ko'rsatmatm2Termal monitor 2
9apicTransport vosita ichida Kengaytirilgan dasturlashtiriladigan uzilishlar tekshiruvissse3Qo'shimcha SSE3 ko'rsatmalar
10(ajratilgan)cnxt-idL1 kontekst identifikatori
11sepSYSENTER va SYSEXIT ko'rsatmalarisdbgSilicon Debug interfeysi
12mtrrXotira turi oralig'idagi registrlarfmaKo'paytirilgan qo'shish eritmasi (FMA3)
13pgeSahifa Global yoqish bit CR4cx16CMPXCHG16B ko'rsatmasi
14mcaMashinani tekshirish arxitekturasixtprVazifalarga ustuvor xabarlarni yuborishni o'chirib qo'yishi mumkin
15smovShartli harakat va FCMOV ko'rsatmalarpdcmPerfmon va disk raskadrovka qobiliyati
16patSahifalar jadvali(ajratilgan)
17pse-3636-bitli sahifa hajmini kengaytirishkompyuterKontekst identifikatorlarini qayta ishlash (CR4 bit 17)
18psnProtsessorning seriya raqamidcaDMA yozish uchun to'g'ridan-to'g'ri keshga kirish[9][10]
19clfshCLFLUSH ko'rsatmasi (SSE2 )sse4.1SSE4.1 ko'rsatmalar
20(ajratilgan)sse4.2SSE4.2 ko'rsatmalar
21dsDisklarni tuzatish do'koni: bajarilgan sakrashlar izini saqlashx2apicx2APIC
22acpiUchun termik boshqaruv MSRlari ACPImovbeMOVBE ko'rsatmasi (katta endian )
23mmxMMX ko'rsatmalarpopcntPOPCNT ko'rsatma
24fxsrFXSAVE, FXRESTOR ko'rsatmalari, CR4 9-bittsc-muddatiAPIC bir martalik operatsiyani TSC muddati qiymatidan foydalangan holda amalga oshiradi
25sseSSE ko'rsatmalar (a.k.a. Katmai yangi ko'rsatmalari)aesAES ko'rsatmalar to'plami
26sse2SSE2 ko'rsatmalarxsaveXSAVE, XRESTOR, XSETBV, XGETBV
27ssCPU keshi o'zini o'zi amalga oshiradiyashirinchaosxsaveXSAVE OS tomonidan yoqilgan
28httGiper iplaravxMurakkab vektor kengaytmalari
29tmTermal monitor haroratni avtomatik ravishda cheklaydif16cF16C (yarim aniqlik FP xususiyati
30ia64IA64 x86-ni taqlid qiluvchi protsessorrdrndRDRAND (chipdagi tasodifiy raqamlarni ishlab chiqaruvchi) xususiyati
31pbeKutilayotgan tanaffusni yoqish (PBE # pin) uyg'onish qobiliyatigipervizatorGipervizor mavjud (jismoniy protsessorlarda har doim nol)[11][12]

Himoyalangan maydonlarni protsessorni aniqlash maqsadida ishlatishdan oldin ularni maskalash kerak.

EAX = 2: kesh va TLB tavsiflovchi ma'lumotlari

Bu keshni va aniqlovchi tavsiflovchilar ro'yxatini qaytaradi TLB EAX, EBX, ECX va EDX registrlaridagi imkoniyatlar.

EAX = 3: protsessorning seriya raqami

Bu protsessorning seriya raqamini qaytaradi. Protsessorning seriya raqami Intelda taqdim etildi Pentium III, lekin maxfiylikka oid muammolar tufayli ushbu xususiyat endi keyingi modellarda qo'llanilmaydi (PSN xususiyati biti har doim o'chiriladi). Transmeta Efficeon va Crusoe protsessorlari ham ushbu xususiyatni taqdim etadi. Biroq, AMD protsessorlari ushbu xususiyatni hech qanday CPU modellarida qo'llamaydilar.

Intel Pentium III protsessorlari uchun seriya raqami EDX: ECX registrlarida qaytariladi. Transmeta Efficeon protsessorlari uchun u EBX: EAX registrlariga qaytariladi. Va Transmeta Crusoe protsessorlari uchun faqat EBX registrida qaytariladi.

Da protsessorning seriya raqami xususiyati yoqilgan bo'lishi kerakligini unutmang BIOS ishlash uchun sozlash.

EAX = 4 va EAX = Bh: Intel thread / core va kesh topologiyasi

Ushbu ikkita barg protsessor topologiyasi (ip, yadro, paket) va Intel ko'p yadroli (va gipertrikli) protsessorlarda kesh iyerarxiyasini sanash uchun ishlatiladi.[13] 2013 yildan boshlab AMD bu barglardan foydalanmaydi, ammo yadro sanashning muqobil usullariga ega.[14]

Ko'pgina boshqa CPUID barglaridan farqli o'laroq, Bh varag'i CPUID buyrug'i qaysi mantiqiy protsessor ishlashiga qarab EDXda har xil qiymatlarni qaytaradi; EDX-da qaytarilgan qiymat aslida x2APIC mantiqiy protsessorning id. X2APIC id maydoni doimiy ravishda mantiqiy protsessorlar bilan taqqoslanmaydi; xaritalashda bo'shliqlar bo'lishi mumkin, ya'ni ba'zi bir oraliq x2APIC identifikatorlari har qanday mantiqiy protsessorga mos kelmaydi. X2APIC identifikatorlarini yadrolarga solishtirish uchun qo'shimcha ma'lumotlar boshqa registrlarda keltirilgan. Bh bargida pastki barglar mavjud bo'lsa ham (ECX tomonidan quyida keltirilganidek tanlangan), EDX-da qaytarilgan qiymatga faqat ko'rsatma ishlayotgan mantiqiy protsessor ta'sir qiladi, lekin pastki barg ta'sir qilmaydi.

Bh yaprog'i ta'sir qiladigan protsessor (lar) topologiyasi ierarxikdir, ammo g'alati ogohlantirish bilan ushbu ierarxiyadagi (mantiqiy) darajalar tartibi jismoniy iyerarxiyadagi tartibga mos kelmasligi kerak (SMT / yadro / paket). Biroq, har qanday mantiqiy darajani SMT, yadro yoki "yaroqsiz" bo'lishi mumkin bo'lgan "daraja turiga" muvofiqligi uchun ECX subleaf (Bh bargidan) sifatida so'rash mumkin. Darajali id ​​maydoni 0 dan boshlanadi va uzluksiz, ya'ni daraja identifikatori yaroqsiz bo'lsa, barcha yuqori darajadagi idlar ham yaroqsiz bo'ladi. Darajaning turi ECX ning 15:08 bitlarida, so'ralgan darajadagi mantiqiy protsessorlarning soni esa EBX-da qaytariladi. Va nihoyat, ushbu darajalar va x2APIC identifikatorlari orasidagi bog'liqlik EAX [4: 0] da qaytariladi, chunki keyingi satrda noyob id olish uchun x2APIC identifikatorini almashtirish kerak bo'lgan bitlar soni.

Masalan, ikki yadroli G'arbiy qodir protsessor gipertriklash (shuning uchun jami ikkita yadro va to'rtta ipga ega) to'rtta mantiqiy protsessor uchun x2APIC identifikatorlari 0, 1, 4 va 5 bo'lishi mumkin. Yaproq Bh (= EAX), CPUID ning pastki barglari 0 (= ECX), masalan, ECXda 100 soat qaytishi mumkin, ya'ni 0 daraja SMT (giperturish) qatlamini tavsiflaydi va EBX da 2 qaytaradi, chunki ikkita mantiqiy protsessor (SMT birligi) mavjud. jismoniy yadro uchun. Ushbu 0 subleaf uchun EAX-da qaytarilgan qiymat bu holda 1 bo'lishi kerak, chunki yuqorida aytib o'tilgan x2APIC identifikatorlarini bir bitga o'ngga siljitish noyob yadro raqamini beradi (daraja id iyerarxiyasining keyingi darajasida) va SMT identifikatorini o'chirib tashlaydi. har bir yadro ichida bit. Ushbu ma'lumotni izohlashning sodda usuli shundaki, x2APIC identifikatorining oxirgi biti (bit raqami 0) bizning misolimizda har bir yadro ichidagi SMT / giperturish birligini aniqlaydi. Masalan, subleaf 1-ga o'tish (EAX = Bh va ECX = 1 bilan CPUID-ga yana bir qo'ng'iroq qilish orqali), masalan, ECX-da 201 soatni qaytarishi mumkin, ya'ni bu yadro tipidagi darajadir va EBX-da 4, chunki 4 mantiqiy protsessor mavjud. paket; Qaytgan EAX qiymati 3 dan katta bo'lgan har qanday qiymat bo'lishi mumkin, chunki x2APIC ididagi yadroni aniqlash uchun bit 2 raqami ishlatiladi. Ushbu misolda x2APIC identifikatorining bit raqami 1 ishlatilmaganligini unutmang. Biroq, EAX bu darajada qaytarilgan bo'lishi mumkin 4 (va u Clarkdale Core i3 5x0 da shunday bo'ladi), chunki bu x2APIC idni 4 bitga o'zgartirganda paket darajasida (= 0 aniq) noyob identifikatorni beradi. Va nihoyat, EAX = 4 bargi bizga nima bilishi mumkin, biz hali bilmaganligimizni bilishingizni so'rashingiz mumkin. EAX-da [31:26] u APIC niqobining bitlarini qaytaradi himoyalangan paket uchun; bu bizning misolimizda 111b bo'ladi, chunki 0 dan 2 gacha bitlar ushbu paket ichidagi mantiqiy protsessorlarni aniqlash uchun ishlatiladi, ammo bit 1 mantiqiy protsessorni identifikatsiya qilish sxemasining bir qismi sifatida ishlatilmasa ham saqlanadi. Boshqacha qilib aytganda, APIC identifikatorlari 0 dan 7 gacha bo'lgan paketlar uchun saqlanadi, garchi ushbu qiymatlarning yarmi mantiqiy protsessor bilan taqqoslanmasa ham.

Protsessorning kesh iyerarxiyasi 4-bargning pastki barglariga qarab o'rganiladi. APIC identifikatorlari ushbu ierarxiyada SMT birliklari va yadrolari tomonidan keshning turli darajalari qanday bo'lishishi haqidagi ma'lumotlarni etkazish uchun ishlatiladi. Bizning misolimizni davom ettirish uchun bir xil yadroli SMT birliklari tomonidan taqsimlanadigan, lekin Westmere-dagi jismoniy yadrolar o'rtasida bo'lmaydigan L2 keshi EAX tomonidan ko'rsatiladi [26:14] 1 ga o'rnatiladi, L3 kesh bilan bo'lishilganligi haqida ma'lumot. butun to'plam tomonidan ushbu bitlarni (kamida) 111b ga o'rnatish orqali ko'rsatiladi. Keshning tafsilotlari, shu jumladan kesh turi, hajmi va assotsiativligi 4-bargdagi boshqa registrlar orqali xabar qilinadi.

Intel dasturining 485-sonli eskirgan versiyalarida ba'zi bir chalg'ituvchi ma'lumotlar, ayniqsa ko'p yadroli protsessordagi yadrolarni aniqlash va hisoblash borasida ehtiyot bo'lish;[15] ushbu ma'lumotni noto'g'ri talqin qilishda xatolar, hatto Visual Studio-ning 2013-yilgi nashri uchun ham cpuid-dan foydalanish uchun Microsoft namunaviy kodiga kiritilgan,[16] va shuningdek CPUID uchun sandpile.org sahifasida,[17] lekin protsessor topologiyasini aniqlash uchun Intel kod namunasi[13] to'g'ri talqinga ega va hozirgi Intel dasturiy ta'minotni ishlab chiquvchi qo'llanmasida aniqroq til mavjud. (Ochiq manbali) platformalararo ishlab chiqarish kodi[18] dan Wildfire Games shuningdek, Intel hujjatlarining to'g'ri talqinini amalga oshiradi.

Eski (2010 yilgacha) x2APIC-ga ega bo'lmagan Intel protsessorlari (shu sababli EAX = Bh bargini qo'llamaydi) bilan bog'liq topologiyani aniqlash misollari 2010 yilgi Intel taqdimotida keltirilgan.[19] 2010 yilda va undan yangi Intel protsessorlarida ushbu eski aniqlash usulidan foydalanish yadrolar va mantiqiy protsessorlarning sonini oshirib yuborishi mumkinligidan ehtiyot bo'ling, chunki eski aniqlash usuli APIC id maydonida bo'shliqlar mavjud emas va bu taxmin ba'zi yangi protsessorlar tomonidan buzilgan ( Core i3 5x0 seriyali), ammo bu yangi protsessorlar x2APIC bilan birga keladi, shuning uchun ularning topologiyasini EAX = Bh barg usuli yordamida to'g'ri aniqlash mumkin.

EAX = 6: Issiqlik va quvvatni boshqarish

EAX = 7, ECX = 0: kengaytirilgan xususiyatlar

Bu EBX, ECX va EDX-da kengaytirilgan xususiyat bayroqlarini qaytaradi.

EAX = 7 CPUID xususiyati biti
BitEBXECXEDX
QisqaXususiyatQisqaXususiyatQisqaXususiyat
0fsgsbase% Fs va% gs bazalariga kirishprefetchwt1PREFETCHWT1 ko'rsatmasi(ajratilgan)
1IA32_TSC_ADJUSTavx512_vbmiAVX-512 Vektorli bitlarni boshqarish bo'yicha ko'rsatmalar(ajratilgan)
2sgxSoftware Guard kengaytmalariumipFoydalanuvchi rejimida ko'rsatmalarning oldini olishavx512_4vnniwAVX-512 4-registrli asab tizimining ko'rsatmalari
3bmi1Bitli manipulyatsiya bo'yicha ko'rsatma 1pkuFoydalanuvchi rejimidagi sahifalar uchun xotirani himoya qilish tugmalariavx512_4fmapsAVX-512 4-registrda ko'paytirishni ko'paytiring bitta aniqlik
4hleTSX Uskunani qulflash ElisionospkeOS tomonidan yoqilgan PKUfsrmTez qisqa REP MOVSB
5avx2Murakkab vektor kengaytmalari 2waitpkgVaqtinchalik pauza va foydalanuvchi darajasidagi monitor / kutish(ajratilgan)
6FDP_EXCPTN_ONLYavx512_vbmi2AVX-512 Vektorli bitlarni boshqarish bo'yicha ko'rsatmalar 2
7smepSupervisor rejimining bajarilishining oldini olishcet_ssOqimlarni boshqarish (CET) soya to'plami
8bmi2Bitli manipulyatsiya bo'yicha ko'rsatma 2gfniGalois Field ko'rsatmalariavx512_vp2intersectAVX-512 VP2INTERSECT Ikki so'zli va to'rt so'zli ko'rsatmalar
9xatolarKengaytirilgan REP MOVSB ​​/ STOSBvaesVektor AES ko'rsatmalar to'plami (VEX-256 / EVEX)SRBDS_CTRLMaxsus ro'yxatga olish buferi ma'lumotlarini tanlashni kamaytirish
10invpcidINVPCID ko'rsatmasivpclmulqdqCLMUL ko'rsatmalar to'plami (VEX-256 / EVEX)md_clearVERW buyrug'i protsessor buferlarini tozalaydi
11rtmTSX Cheklangan tranzaksiya xotirasiavx512_vnniAVX-512 Vektorli asab tizimining ko'rsatmalari(ajratilgan)
12kvXizmatlarni monitoring qilish platformasiavx512_bitalgAVX-512 BITALG ko'rsatmalari
13FPU CS va FPU DS eskirgan(ajratilgan)tsx_force_abort
14MPXIntel MPX (Xotira himoyasi kengaytmalari)avx512_vpopcntdqAVX-512 Vektorli aholi soni ikki va to'rt so'zdan iboratSERIALLASHKo'rsatmalarning bajarilishini ketma-ketlashtirish
15pqeXizmatni bajarish platformasi sifati(ajratilgan)Gibrid
16avx512_fAVX-512 Jamg'arma5 darajali pagingTSXLDTRKTSX yuk manzilini kuzatishni to'xtatadi
17avx512_dqAVX-512 Ikki so'zli va to'rt so'zli ko'rsatmalarmawauBNDLDX va BNDSTX tomonidan ishlatiladigan MPX manzil-kenglik sozlamalari foydalanuvchilar maydonining qiymati Intel MPX ko'rsatmalar 64-bit rejimida(ajratilgan)
18urug 'RDSEED ko'rsatmapconfigPlatformaning konfiguratsiyasi (Xotirani shifrlash texnologiyalari bo'yicha ko'rsatmalar)
19qo'shimchalarIntel ADX (Ko'p aniqlikdagi qo'shimcha yuk tashish bo'yicha ko'rsatmalar kengaytmalari)lbrArxitektura bo'yicha so'nggi filial yozuvlari
20urishSupervisor rejimidan foydalanishni oldini olishcet_ibtNazorat oqimining bajarilishini (CET) bilvosita filialni kuzatish
21avx512_ifmaAVX-512 Integer Fused Multiply-Add ko'rsatmalari(ajratilgan)
22pcommitPCOMMIT ko'rsatmasirdpidProcessor ID va IA32_TSC_AUX-ni o'qingamx-bf16Bfloat16 raqamlari bo'yicha plitkalarni hisoblash
23klyushkaCLFLUSHOPT ko'rsatmasi(ajratilgan)(ajratilgan)
24clwbCLWB ko'rsatmasi(ajratilgan)amx-kafelPlitka me'morchiligi
25intel_ptIntel protsessor izicldemoteKesh satrini pasaytirishamx-int88-bitli butun sonlar bo'yicha plitkalarni hisoblash
26avx512_pfAVX-512 Oldindan olish bo'yicha ko'rsatmalar(ajratilgan)IBRS_IBPB / spec_ctrlBilvosita filiallarni boshqarish (IBC) ning bir qismi bo'lgan spekulyatsiya nazorati:
Bilvosita filial tomonidan cheklangan spekulyatsiya (IBRS) va
Bilvosita filialni bashorat qilish to'sig'i (IBPB)[20][21]
27avx512_erAVX-512 Eksponent va o'zaro ko'rsatmalarMOVDIRItiqishBitta yo'nalishli bilvosita filialni bashorat qilish, IBC tarkibiga kiradi[20]
28avx512_cdAVX-512 Mojaroni aniqlash bo'yicha ko'rsatmalarMOVDIR64BL1D_FLUSHIA32_FLUSH_CMD MSR
29shaIntel SHA kengaytmalariENQCMDEnqueue do'konlariIA32_ARCH_CAPABILITIESSpekulyativ yon kanalni yumshatish[20]
30avx512_bwAVX-512 Bayt va so'zga oid ko'rsatmalarsgx_lcSGX ishga tushirish konfiguratsiyasiIA32_CORE_CAPABILITIESMSR ro'yxatiga modelga xos asosiy qobiliyatlarni qo'llab-quvvatlash
31avx512_vlAVX-512 Vektor uzunligini kengaytirishpksNazoratchi rejimidagi sahifalar uchun himoya kalitlariSSBDSpekulyativ do'konni aylanib o'tishni o'chirib qo'yish,[20] uchun yumshatish sifatida Spekulyativ do'kon atrofi (IA32_SPEC_CTRL)

EAX = 7, ECX = 1: kengaytirilgan xususiyatlar

Bu EAX-da kengaytirilgan xususiyat bayroqlarini qaytaradi.


EAX = 7 CPUID xususiyati biti
BitEAX
QisqaXususiyat
0(ajratilgan)
1(ajratilgan)
2(ajratilgan)
3(ajratilgan)
4(ajratilgan)
5avx512_bf16AVX-512 BFLOAT16 ko'rsatmalar
6(ajratilgan)
7(ajratilgan)
8(ajratilgan)
9(ajratilgan)
10(ajratilgan)
11(ajratilgan)
12(ajratilgan)
13(ajratilgan)
14(ajratilgan)
15(ajratilgan)
16(ajratilgan)
17(ajratilgan)
18(ajratilgan)
19(ajratilgan)
20(ajratilgan)
21(ajratilgan)
22(ajratilgan)
23(ajratilgan)
24(ajratilgan)
25(ajratilgan)
26(ajratilgan)
27(ajratilgan)
28(ajratilgan)
29(ajratilgan)
30(ajratilgan)
31(ajratilgan)

EAX = 80000000 soat: eng yuqori kengaytirilgan funktsiyani bajaring

Eng yuqori qo'ng'iroq parametri EAX-da qaytariladi.

EAX = 80000001 soat: kengaytirilgan protsessor ma'lumotlari va xususiyatlari

Bu EDX va ECX-da kengaytirilgan xususiyat bayroqlarini qaytaradi.

AMD xususiyati bayroqlari quyidagilar:[22][23]

EAX = 80000001 soat CPUID xususiyati bitlari
BitEDXECX
QisqaXususiyatQisqaXususiyat
0fpuTransport vosita ichida x87 FPUlahf_lmLAHF / SAHF uzoq rejimda
1vmeVirtual rejim kengaytmalari (VIF)cmp_legacyHyperthreading yaroqli emas
2deKengaytmalarda disk raskadrovka (CR4 bit 3)svmXavfsiz virtual mashina
3pseSahifa o'lchamini kengaytirishekstapikKengaytirilgan APIC bo'sh joy
4tscVaqt shtampi hisoblagichinilufar_abdullaevCR8 32-bit rejimida
5msrModelga xos registrlarabmMurakkab bit manipulyatsiyasi (lzcnt va popcnt )
6paeJismoniy manzilni kengaytirishsse4aSSE4a
7mceMashinani tekshirishda istisnonoto'g'riligiNoto'g'ri tuzilgan SSE rejimi
8cx8CMPXCHG8 (taqqoslash va almashtirish ) ko'rsatma3dnowprefetchPREFETCH va PREFETCHW ko'rsatmalari
9apicTransport vosita ichida Kengaytirilgan dasturlashtiriladigan uzilishlar tekshiruviosvwOS ko'rinadigan vaqtinchalik echim
10(ajratilgan)ibsKo'rsatmalar asosida namuna olish
11syscallSYSCALL va SYSRET ko'rsatmalarixopXOP ko'rsatmalar to'plami
12mtrrXotira turi oralig'idagi registrlarskinitSKINIT / STGI ko'rsatmalari
13pgePage Global bitni yoqish CR4wdtQo'riqchi taymeri
14mcaMashinani tekshirish arxitekturasi(ajratilgan)
15smovShartli harakat va FCMOV ko'rsatmalarlwpEngil vaznli profil berish[24]
16patSahifalar jadvalifma44 ta operand birlashtirilgan va ko'paytiriladi
17pse3636-bitli sahifa hajmini kengaytirishtseTarjima keshini kengaytirish
18(ajratilgan)
19MPMultiprotsessor Qobiliyatlinodeid_msrMSR tugunlari
20nxNX bit(ajratilgan)
21(ajratilgan)tbmBitta manipulyatsiya
22mmxextKengaytirilgan MMXtopoeksTopologiya kengaytmalari
23mmxMMX ko'rsatmalarmuborakAsosiy ishlash hisoblagich kengaytmalari
24fxsrFXSAVE, FXRSTOR ko'rsatmalari, CR4 9-bitabdullaevaNB ko'rsatkichlarining hisoblagich kengaytmalari
25fxsr_optFXSAVE / FXRSTOR optimallashtirishlari(ajratilgan)
26pdpe1gbGibibayt sahifalardbxMa'lumotlarni uzib qo'yish kengaytmalari
27rdtscpRDTSCP ko'rsatmasimuborakTSC ishlashi
28(ajratilgan)pcx_l2iL2I perf hisoblagich kengaytmalari
29lmUzoq rejim(ajratilgan)
303dnextextKengaytirilgan 3DNow!(ajratilgan)
31Endi3DNow!(ajratilgan)

EAX = 80000002 soat, 80000003 soat, 80000004 soat: Protsessor markasi qatori

Ular EAX, EBX, ECX va EDX-dagi protsessor markasining qatorini qaytaradi. CPUID barcha 48 baytlik bekor qilingan ASCII protsessor brendini olish uchun ketma-ket har bir parametr bilan berilishi kerak.[25] Xususiyat protsessorda mavjudligini emissiya orqali tekshirish kerak CPUID bilan EAX = 80000000 soat birinchi va qaytarilgan qiymat 80000004h ga teng yoki katta emasligini tekshirish.

# shu jumladan  // GCC tomonidan taqdim etilgan# shu jumladan <stdio.h># shu jumladan <stdint.h>int asosiy(bekor) {    uint32_t tovar belgisi[12];    agar (!__get_cpuid_max(0x80000004, NULL)) {        fprintf(stderr, "Xususiyat amalga oshirilmadi.");        qaytish 2;    }    __get_cpuid(0x80000002, tovar belgisi+0x0, tovar belgisi+0x1, tovar belgisi+0x2, tovar belgisi+0x3);    __get_cpuid(0x80000003, tovar belgisi+0x4, tovar belgisi+0x5, tovar belgisi+0x6, tovar belgisi+0x7);    __get_cpuid(0x80000004, tovar belgisi+0x8, tovar belgisi+0x9, tovar belgisi+0xa, tovar belgisi+0xb);    printf("Tovar belgisi:% s", tovar belgisi);}

EAX = 80000005 soat: L1 kesh va TLB identifikatorlari

Ushbu funktsiya protsessorning L1 keshini va TLB xususiyatlarini o'z ichiga oladi.

EAX = 80000006 soat: kengaytirilgan L2 kesh xususiyatlari

ECX-dagi L2 keshining tafsilotlarini, shu jumladan baytdagi satr hajmini (07 - 00 bit), assotsiativlik turini (4 bitli maydon bilan kodlangan; 15 - 12 bit) va KiB (31 - 16 bit) hajmidagi keshni qaytaradi. .

# shu jumladan  // GCC tomonidan taqdim etilgan# shu jumladan <stdio.h># shu jumladan <stdint.h>int asosiy(bekor) {    uint32_t eax, ebx, ekx, edx;    agar (__get_cpuid(0x80000006, &eax, &ebx, &ekx, &edx)) {        printf("Chiziq hajmi:% d B, Assoc. Turi:% d; Kesh hajmi:% d KB.", ekx & 0xff, (ekx >> 12) & 0x07, (ekx >> 16) & 0xffff);        qaytish 0;    } boshqa {        fputs(stderr, "CPU 0x80000006 ni qo'llab-quvvatlamaydi");        qaytish 2;    }}

EAX = 80000007 soat: Quvvatni boshqarish bo'yicha rivojlangan ma'lumot

Ushbu funktsiya rivojlangan quvvatni boshqarish xususiyati identifikatorlarini taqdim etadi. EDX bit 8 o'zgarmas TSC-ni qo'llab-quvvatlaydi.

EAX = 80000008 soat: Virtual va jismoniy manzil o'lchamlari

EAX-dagi eng katta virtual va jismoniy manzil o'lchamlarini qaytaradi.

  • 07-00-bitlar: # Jismoniy manzil bitlari.
  • 15-8-bitlar: # Chiziqli manzil bitlari.
  • 31-16-bitlar: Zaxiralangan = 0.

Virtual protsessor bilan mumkin bo'lgan jismoniy / virtual manzil o'lchamlari haqida xabar berish uchun uni virtual mashina tizimidagi gipervizator ishlatishi mumkin.

EBX quyidagi funktsiyalar uchun ishlatiladi:

  • Bit 0: CLZERO, RAX-dagi manzil bilan kesh satrini tozalash.
  • 4-bit: RDPRU, 3-ringdan MPERF yoki APERF-ni o'qing.
  • Bit 8: MCOMMIT, do'konlarni xotiraga topshiring. Xotirada fextavonie qilish va ECC xatolarini tiklash uchun.
  • 9-bit: WBNOINVD, Orqaga yozing va keshni bekor qilmang.

ECX yadro sonini ta'minlaydi.

  • 07-00-bitlar: #Jismoniy yadrolar minus bitta.
  • 11-8-bitlar: Zaxiralangan = 0.
  • 15-12-bitlar: #APIC ID bitlari. Ushbu kuchga ko'tarilgan 2 nolga teng bo'lmagan taqdirda, jismoniy yadro soni bo'ladi.
  • 17-16-bitlar: Ishlash vaqtini belgilaydigan taymer o'lchami.
  • 31-18-bitlar: Zaxiralangan = 0.

EDX 31-16 da RDPRU (ruxsat berilgan maksimal registr identifikatori) ga xos ma'lumotlarni taqdim etadi. Hozirgi raqam Zen 2 da MPERF va APERF uchun 1 tani tashkil etadi.

EAX = 8FFFFFFFh: AMD Easter Egg

AMD K7 va K8 protsessorlariga xos bo'lgan bu "IT HAMMER TIME" qatorini EAX, EBX, ECX va EDX-da qaytaradi.[26]

Yuqori darajadagi tillardan CPUID foydalanish

Ichki yig'ish

Ushbu ma'lumotlarga boshqa tillardan ham kirish oson. Masalan, quyidagi gcc uchun C kodi cpuid tomonidan qaytarilgan dastlabki beshta qiymatni bosib chiqaradi:

# shu jumladan <stdio.h>/ * Bu 32 va 64 bitli tizimlarda ishlaydi. Ushbu kodni o'qish bo'yicha maslahatlar uchun [[Inline assembler # In actual compilers]] ga qarang. * /int asosiy(){  / * To'rt registrni boshlash kerak emas, chunki protsessor uning ustiga yozadi. * /  int ma'lumot turi, a, b, v, d;  uchun (ma'lumot turi = 0; ma'lumot turi < 5; ma'lumot turi ++)  {    nigora("CPU"            : "= a" (a), "= b" (b), "= c" (v), "= d" (d)   // Chiqish o'zgaruvchilari. EAX -> a va aksincha.            : "0" (ma'lumot turi));                         // Infotype-ni EAX-ga joylashtiring.    printf ("InfoType% xEAX:% xEBX:% xECX:% xEDX:% x", ma'lumot turi, a, b, v, d);  }  qaytish 0;}

MSVC va Borland / Embarcadero C kompilyatorlarida (bcc32) xushbo'yli inline yig'ishda, bukuvchi ma'lumot ko'rsatmalarda aniq emas:

# shu jumladan <stdio.h>int asosiy(){  imzosiz int InfoType = 0;  imzosiz int a, b, v, d;  __asm {    / * Qo'ng'iroq qiling. * /    mov EAX, InfoType;    CPU;    / * Natijalarni saqlash. * /    mov a, EAX;    mov b, EBX;    mov v, ECX;    mov d, EDX;  }  printf ("InfoType% xEAX:% xEBX:% xECX:% xEDX:% x", InfoType, a, b, v, d);  qaytish 0;}

Agar har qanday versiya oddiy yig'ilish tilida yozilgan bo'lsa, dasturchi EAX, EBX, ECX va EDX natijalarini qo'lda saqlab qo'yishi kerak, agar ular qiymatlardan foydalanishni davom ettirmoqchi bo'lsa.

Qopqoqning vazifalari

GCC shuningdek nomlangan sarlavhani taqdim etadi <cpuid.h> CPUID-ga ega tizimlarda. The __cpuid ichki qatorga kengayadigan so'ldir. Odatda foydalanish quyidagicha bo'ladi:

# shu jumladan <cpuid.h># shu jumladan <stdio.h>intasosiy (bekor){  int a, b, v, d;  __cpuid (0 / * sotuvchi qatori * /, a, b, v, d);  printf ("EAX:% xEBX:% xECX:% xEDX:% x", a, b, v, d);  qaytish 0;}

Ammo bittasi ushbu protsessorda mavjud bo'lmagan kengaytirilgan xususiyatni talab qilsa, ular buni sezmaydilar va tasodifiy, kutilmagan natijalarni olishlari mumkin. Xavfsiz versiya ham taqdim etilgan <cpuid.h>. U kengaytirilgan xususiyatlarni tekshiradi va yana bir necha xavfsizlik tekshiruvlarini o'tkazadi. Chiqish qiymatlari mos yozuvlar makrosi parametrlari yordamida o'tkazilmaydi, lekin ko'proq an'anaviy ko'rsatgichlar.

# shu jumladan <cpuid.h># shu jumladan <stdio.h>intasosiy (bekor){  int a, b, v, d;  agar (!__get_cpuid (0x81234567 / * mavjud emas, lekin u mavjud deb taxmin qiling * /, &a, &b, &v, &d))    {      fprintf (stderr, "Ogohlantirish: CPUID so'rovi 0x81234567 haqiqiy emas!");    }  printf("EAX:% xEBX:% xECX:% xEDX:% x", a, b, v, d);  qaytish 0;}

Amperandlarga e'tibor bering &a B C D va shartli gap. Agar __get_cpuid qo'ng'iroq to'g'ri so'rovni oladi, u nolga teng bo'lmagan qiymatni qaytaradi, agar u bajarilmasa, nolga teng.[27]

Microsoft Visual C kompilyatori o'rnatilgan funktsiyaga ega __cpuid () shuning uchun cpuid buyrug'i ichki yig'ilishni ishlatmasdan joylashtirilishi mumkin, chunki bu juda qulay, chunki MSVC ning x86-64 versiyasi ichki yig'ilishga umuman ruxsat bermaydi. Xuddi shu dastur MSVC bo'lardi:

# shu jumladan <iostream># shu jumladan <intrin.h>int asosiy(){  int cpuInfo[4];  uchun (int a = 0; a < 5; a++)  {    __cpuid(cpuInfo, a);    std::cout << "Kod" << a << "beradi" << cpuInfo[0] << ", " << cpuInfo[1] << ", " << cpuInfo[2] << ", " << cpuInfo[3] << '';  }  qaytish 0;}

Ko'pgina tarjima qilingan yoki kompilyatsiya qilingan tillar CPU orqali an FFI kutubxona. Shunday dasturlardan biri CPUID opkodini o'z ichiga olgan montaj tilini bajarish uchun Ruby FFI modulidan foydalanishni ko'rsatadi.

X86 tashqarisidagi protsessorga xos ma'lumotlar

X86 bo'lmagan CPU arxitekturalarining ba'zilari, odatda, maxsus registrlar to'plami sifatida protsessorning qobiliyatlari to'g'risida tuzilgan ma'lumotlarning ma'lum shakllarini taqdim etadi:

  • ARM me'morchiligi bor CPUID kirish uchun EL1 yoki undan yuqori talab qiladigan koprotsessor registri.[28]
  • The IBM System z mainframe protsessorlari a CPU identifikatorini saqlash (STIDP) 1983 yildan beri ko'rsatma IBM 4381[29] protsessor identifikatorini so'rash uchun.[30]
  • The IBM System z asosiy protsessorlarda ham Do‘konlarning ro‘yxati kengaytirilgan (STFLE) o'rnatilgan apparat xususiyatlari ro'yxati ko'rsatmasi.[30]
  • The MIPS32 / 64 me'morchilik majburiyligini belgilaydi Protsessor identifikatsiyasi (PrId) va bir qator romashka bilan zanjirlangan Konfiguratsiya registrlari.[31]
  • The PowerPC protsessor faqat 32 bitli o'qish imkoniyatiga ega Protsessor versiyasining registri (PVR) ishlatilayotgan protsessor modelini aniqlash. Ko'rsatma rahbarning kirish darajasini talab qiladi.[32]

DSP va transputer -chiplar singari oilalar, dizayndagi shuncha xilma-xillikka ega bo'lishiga qaramay, ko'rsatmalarni sezilarli darajada qabul qilmaganlar. Kremniyni identifikatsiyalashning muqobil usullari mavjud bo'lishi mumkin; masalan, dan DSP-lar Texas Instruments har bir funktsional birlik uchun birlik turini va modelini aniqlaydigan identifikatorlardan boshlanadigan xotiraga asoslangan registrni o'z ichiga oladi ASIC dizaynni qayta ko'rib chiqish va loyihalash bosqichida tanlangan xususiyatlar va birlik uchun maxsus boshqarish va ma'lumotlar registrlari bilan davom etadi. Ushbu joylarga kirish oddiy yuklash va saqlash ko'rsatmalaridan foydalanish orqali amalga oshiriladi; Shunday qilib, bunday qurilmalar uchun qurilmani identifikatsiyalash maqsadida o'rnatilgan registrni kengaytirishga hojat yo'q.[iqtibos kerak ]

Shuningdek qarang

Adabiyotlar

  1. ^ "Intel 64 va IA-32 Architectures Software Developer qo'llanmasi" (PDF). Intel.com. Olingan 2013-04-11.
  2. ^ "Intel protsessorlarini aniqlash - tizim protsessorining avlodini bilish". Rcollins.org. Olingan 2013-04-11.
  3. ^ "LXR linux-old / arch / i386 / kernel / head.S". Lxr.linux.no. Arxivlandi asl nusxasi 2012-07-13. Olingan 2013-04-11.
  4. ^ "CPUID, EAX = 4 - g'alati natijalar (echildi)". Software.intel.com. Olingan 2014-07-10.
  5. ^ "ao486 CPUID ko'rsatmasi".
  6. ^ "v586: 586 FPGA uchun mos yumshoq yadro".
  7. ^ "3-bob ko'rsatmalar to'plami uchun ma'lumotnoma, A-L" (PDF). Intel® 64 va IA-32 Architectures Software Developer qo'llanmasi. Intel korporatsiyasi. 2018-12-20. Olingan 2018-12-20.
  8. ^ http://bochs.sourceforge.net/techspec/24161821.pdf
  9. ^ Xugaxalli, Ram; Iyer, Ravi; Tetrik, Skott (2005). "Yuqori tarmoqli o'tkazuvchanlik tarmog'iga to'g'ridan-to'g'ri keshga kirish". ACM SIGARCH Kompyuter arxitekturasi yangiliklari. 33 (2): 50–59. doi:10.1145/1080695.1069976. CiteSeerX:10.1.1.91.957.
  10. ^ Drepper, Ulrich (2007), Har bir dasturchi xotira haqida nimalarni bilishi kerak, CiteSeerX:10.1.1.91.957
  11. ^ "VMware virtual mashinasida dasturiy ta'minot ishlayotganligini aniqlash mexanizmlari". VMware bilim bazasi. VMWare. 2015-05-01. Intel va AMD protsessorlari gipervizektorning hozirgi biti sifatida CPUx bargining 0x1 ECX ning 31-bitini ajratib qo'ygan. Ushbu bit gipervizatorlarga mehmon operatsion tizimida mavjudligini ko'rsatishga imkon beradi. Gipervizatorlar ushbu bitni o'rnatadilar va jismoniy protsessorlar (barcha mavjud va kelajakdagi protsessorlar) bu bitni nolga tenglashtiradilar. Mehmon operatsion tizimlari virtual mashinada ishlayotganligini aniqlash uchun bit 31 ni sinab ko'rishlari mumkin.
  12. ^ Katariya, Aloq; Xech, Dan (2008-10-01). "Hypervisor CPUID interfeysi taklifi". LKML Lore.kernel.org saytidagi arxiv. Arxivlandi asl nusxasidan 2019-03-15. CPUID varag'i 0x1 ning ECX biti 31. Ushbu bit Intel & AMD tomonidan gipervizatorlar tomonidan foydalanish uchun ajratilgan va gipervizektor mavjudligini bildiradi. Virtual protsessorlar (gipervizatorlar) ushbu bitni 1 ga, jismoniy protsessorlar (mavjud va kelajakdagi barcha CPUlar) bu bitni nolga qo'ygan. Ushbu bitni virtual dastur ichida ishlayotganligini aniqlash uchun mehmon dasturlari tekshirishi mumkin.
  13. ^ a b Shih Kuo (2012 yil 27-yanvar). "Intel® 64 Arxitektura protsessori topologiyasini ro'yxatga olish".
  14. ^ "CPUID | AMD yordamida protsessor va yadrolarni hisoblash". Developer.amd.com. Arxivlandi asl nusxasi 2014-07-14. Olingan 2014-07-10.
  15. ^ "Sandybridge protsessorlari noto'g'ri raqam haqida xabar berishadimi?". Software.intel.com. 2012-12-29. Olingan 2014-07-10.
  16. ^ "cpuid, __cpuidex". Msdn.microsoft.com. 2014-06-20. Olingan 2014-07-10.
  17. ^ "x86 arxitekturasi - CPUID". sandpile.org. Olingan 2014-07-10.
  18. ^ "ps / trunk / source / lib / sysdep / arch / x86_x64 da topology.cpp - Wildfire Games". Trac.wildfiregames.com. 2011-12-27. Olingan 2014-07-10.
  19. ^ Hyper-Threading texnologiyasi va ko'p yadroli protsessorni aniqlash
  20. ^ a b v d "Spekulyativ ijro etuvchi yon kanalni yumshatish" (PDF). Qayta ko'rib chiqish 2.0. Intel. 2018 yil may (2018 yil yanvar). Hujjat raqami: 336996-002. Olingan 2018-05-26.
  21. ^ "IBRS patch seriyasi [LWN.net]".
  22. ^ CPUID spetsifikatsiyasi (PDF), AMD, 2010 yil sentyabr, olingan 2013-04-02
  23. ^ Linux yadrosining manba kodi
  24. ^ Engil profilli spetsifikatsiya (PDF), AMD, 2010 yil avgust, olingan 2013-04-03
  25. ^ "Intel® protsessorni identifikatsiyalash va CPUID ko'rsatmasi" (PDF). Download.intel.com. 2012-03-06. Olingan 2013-04-11.
  26. ^ Ferri, Piter. "Virtual mashina emulyatorlariga hujumlar" (PDF). symantec.com. Symantec Advanced Threat Research. Arxivlandi asl nusxasi (PDF) 2007-02-07 da. Olingan 15 mart 2017.
  27. ^ https://github.com/gcc-mirror/gcc/blob/master/gcc/config/i386/cpuid.h
  28. ^ "ARM Axborot Markazi". Infocenter.arm.com. Olingan 2013-04-11.
  29. ^ "Protsessor versiyasi kodlari va SRM konstantalari". Arxivlandi asl nusxasi 2014-09-08 da. Olingan 2014-09-08.
  30. ^ a b "IBM System z10 Enterprise Class texnik qo'llanmasi" (PDF).
  31. ^ "Dasturchilar uchun MIPS32 arxitekturasi, III jild: MIPS32 imtiyozli manbalar arxitekturasi" (PDF). MIPS Technologies, Inc. 2001-03-12.
  32. ^ "PowerPC operatsion muhiti arxitekturasi, III kitob" (PDF).

Qo'shimcha o'qish

Tashqi havolalar