12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513 |
- /*
- * i386 CPUID, CPU class, definitions, models
- *
- * Copyright (c) 2003 Fabrice Bellard
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, see <http://www.gnu.org/licenses/>.
- */
- #include "qemu/osdep.h"
- #include "qemu/units.h"
- #include "qemu/cutils.h"
- #include "qemu/qemu-print.h"
- #include "qemu/hw-version.h"
- #include "cpu.h"
- #include "tcg/helper-tcg.h"
- #include "sysemu/hvf.h"
- #include "hvf/hvf-i386.h"
- #include "kvm/kvm_i386.h"
- #include "sev.h"
- #include "qapi/error.h"
- #include "qemu/error-report.h"
- #include "qapi/qapi-visit-machine.h"
- #include "qapi/qmp/qerror.h"
- #include "standard-headers/asm-x86/kvm_para.h"
- #include "hw/qdev-properties.h"
- #include "hw/i386/topology.h"
- #ifndef CONFIG_USER_ONLY
- #include "sysemu/reset.h"
- #include "qapi/qapi-commands-machine-target.h"
- #include "exec/address-spaces.h"
- #include "hw/boards.h"
- #include "hw/i386/sgx-epc.h"
- #endif
- #include "disas/capstone.h"
- #include "cpu-internal.h"
- static void x86_cpu_realizefn(DeviceState *dev, Error **errp);
- /* Helpers for building CPUID[2] descriptors: */
- struct CPUID2CacheDescriptorInfo {
- enum CacheType type;
- int level;
- int size;
- int line_size;
- int associativity;
- };
- /*
- * Known CPUID 2 cache descriptors.
- * From Intel SDM Volume 2A, CPUID instruction
- */
- struct CPUID2CacheDescriptorInfo cpuid2_cache_descriptors[] = {
- [0x06] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 8 * KiB,
- .associativity = 4, .line_size = 32, },
- [0x08] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 16 * KiB,
- .associativity = 4, .line_size = 32, },
- [0x09] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 32 * KiB,
- .associativity = 4, .line_size = 64, },
- [0x0A] = { .level = 1, .type = DATA_CACHE, .size = 8 * KiB,
- .associativity = 2, .line_size = 32, },
- [0x0C] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
- .associativity = 4, .line_size = 32, },
- [0x0D] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
- .associativity = 4, .line_size = 64, },
- [0x0E] = { .level = 1, .type = DATA_CACHE, .size = 24 * KiB,
- .associativity = 6, .line_size = 64, },
- [0x1D] = { .level = 2, .type = UNIFIED_CACHE, .size = 128 * KiB,
- .associativity = 2, .line_size = 64, },
- [0x21] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
- .associativity = 8, .line_size = 64, },
- /* lines per sector is not supported cpuid2_cache_descriptor(),
- * so descriptors 0x22, 0x23 are not included
- */
- [0x24] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
- .associativity = 16, .line_size = 64, },
- /* lines per sector is not supported cpuid2_cache_descriptor(),
- * so descriptors 0x25, 0x20 are not included
- */
- [0x2C] = { .level = 1, .type = DATA_CACHE, .size = 32 * KiB,
- .associativity = 8, .line_size = 64, },
- [0x30] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 32 * KiB,
- .associativity = 8, .line_size = 64, },
- [0x41] = { .level = 2, .type = UNIFIED_CACHE, .size = 128 * KiB,
- .associativity = 4, .line_size = 32, },
- [0x42] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
- .associativity = 4, .line_size = 32, },
- [0x43] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
- .associativity = 4, .line_size = 32, },
- [0x44] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
- .associativity = 4, .line_size = 32, },
- [0x45] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
- .associativity = 4, .line_size = 32, },
- [0x46] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
- .associativity = 4, .line_size = 64, },
- [0x47] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
- .associativity = 8, .line_size = 64, },
- [0x48] = { .level = 2, .type = UNIFIED_CACHE, .size = 3 * MiB,
- .associativity = 12, .line_size = 64, },
- /* Descriptor 0x49 depends on CPU family/model, so it is not included */
- [0x4A] = { .level = 3, .type = UNIFIED_CACHE, .size = 6 * MiB,
- .associativity = 12, .line_size = 64, },
- [0x4B] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
- .associativity = 16, .line_size = 64, },
- [0x4C] = { .level = 3, .type = UNIFIED_CACHE, .size = 12 * MiB,
- .associativity = 12, .line_size = 64, },
- [0x4D] = { .level = 3, .type = UNIFIED_CACHE, .size = 16 * MiB,
- .associativity = 16, .line_size = 64, },
- [0x4E] = { .level = 2, .type = UNIFIED_CACHE, .size = 6 * MiB,
- .associativity = 24, .line_size = 64, },
- [0x60] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
- .associativity = 8, .line_size = 64, },
- [0x66] = { .level = 1, .type = DATA_CACHE, .size = 8 * KiB,
- .associativity = 4, .line_size = 64, },
- [0x67] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
- .associativity = 4, .line_size = 64, },
- [0x68] = { .level = 1, .type = DATA_CACHE, .size = 32 * KiB,
- .associativity = 4, .line_size = 64, },
- [0x78] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
- .associativity = 4, .line_size = 64, },
- /* lines per sector is not supported cpuid2_cache_descriptor(),
- * so descriptors 0x79, 0x7A, 0x7B, 0x7C are not included.
- */
- [0x7D] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
- .associativity = 8, .line_size = 64, },
- [0x7F] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
- .associativity = 2, .line_size = 64, },
- [0x80] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
- .associativity = 8, .line_size = 64, },
- [0x82] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
- .associativity = 8, .line_size = 32, },
- [0x83] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
- .associativity = 8, .line_size = 32, },
- [0x84] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
- .associativity = 8, .line_size = 32, },
- [0x85] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
- .associativity = 8, .line_size = 32, },
- [0x86] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
- .associativity = 4, .line_size = 64, },
- [0x87] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
- .associativity = 8, .line_size = 64, },
- [0xD0] = { .level = 3, .type = UNIFIED_CACHE, .size = 512 * KiB,
- .associativity = 4, .line_size = 64, },
- [0xD1] = { .level = 3, .type = UNIFIED_CACHE, .size = 1 * MiB,
- .associativity = 4, .line_size = 64, },
- [0xD2] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
- .associativity = 4, .line_size = 64, },
- [0xD6] = { .level = 3, .type = UNIFIED_CACHE, .size = 1 * MiB,
- .associativity = 8, .line_size = 64, },
- [0xD7] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
- .associativity = 8, .line_size = 64, },
- [0xD8] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
- .associativity = 8, .line_size = 64, },
- [0xDC] = { .level = 3, .type = UNIFIED_CACHE, .size = 1.5 * MiB,
- .associativity = 12, .line_size = 64, },
- [0xDD] = { .level = 3, .type = UNIFIED_CACHE, .size = 3 * MiB,
- .associativity = 12, .line_size = 64, },
- [0xDE] = { .level = 3, .type = UNIFIED_CACHE, .size = 6 * MiB,
- .associativity = 12, .line_size = 64, },
- [0xE2] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
- .associativity = 16, .line_size = 64, },
- [0xE3] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
- .associativity = 16, .line_size = 64, },
- [0xE4] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
- .associativity = 16, .line_size = 64, },
- [0xEA] = { .level = 3, .type = UNIFIED_CACHE, .size = 12 * MiB,
- .associativity = 24, .line_size = 64, },
- [0xEB] = { .level = 3, .type = UNIFIED_CACHE, .size = 18 * MiB,
- .associativity = 24, .line_size = 64, },
- [0xEC] = { .level = 3, .type = UNIFIED_CACHE, .size = 24 * MiB,
- .associativity = 24, .line_size = 64, },
- };
- /*
- * "CPUID leaf 2 does not report cache descriptor information,
- * use CPUID leaf 4 to query cache parameters"
- */
- #define CACHE_DESCRIPTOR_UNAVAILABLE 0xFF
- /*
- * Return a CPUID 2 cache descriptor for a given cache.
- * If no known descriptor is found, return CACHE_DESCRIPTOR_UNAVAILABLE
- */
- static uint8_t cpuid2_cache_descriptor(CPUCacheInfo *cache)
- {
- int i;
- assert(cache->size > 0);
- assert(cache->level > 0);
- assert(cache->line_size > 0);
- assert(cache->associativity > 0);
- for (i = 0; i < ARRAY_SIZE(cpuid2_cache_descriptors); i++) {
- struct CPUID2CacheDescriptorInfo *d = &cpuid2_cache_descriptors[i];
- if (d->level == cache->level && d->type == cache->type &&
- d->size == cache->size && d->line_size == cache->line_size &&
- d->associativity == cache->associativity) {
- return i;
- }
- }
- return CACHE_DESCRIPTOR_UNAVAILABLE;
- }
- /* CPUID Leaf 4 constants: */
- /* EAX: */
- #define CACHE_TYPE_D 1
- #define CACHE_TYPE_I 2
- #define CACHE_TYPE_UNIFIED 3
- #define CACHE_LEVEL(l) (l << 5)
- #define CACHE_SELF_INIT_LEVEL (1 << 8)
- /* EDX: */
- #define CACHE_NO_INVD_SHARING (1 << 0)
- #define CACHE_INCLUSIVE (1 << 1)
- #define CACHE_COMPLEX_IDX (1 << 2)
- /* Encode CacheType for CPUID[4].EAX */
- #define CACHE_TYPE(t) (((t) == DATA_CACHE) ? CACHE_TYPE_D : \
- ((t) == INSTRUCTION_CACHE) ? CACHE_TYPE_I : \
- ((t) == UNIFIED_CACHE) ? CACHE_TYPE_UNIFIED : \
- 0 /* Invalid value */)
- static uint32_t max_thread_ids_for_cache(X86CPUTopoInfo *topo_info,
- enum CPUTopoLevel share_level)
- {
- uint32_t num_ids = 0;
- switch (share_level) {
- case CPU_TOPO_LEVEL_CORE:
- num_ids = 1 << apicid_core_offset(topo_info);
- break;
- case CPU_TOPO_LEVEL_DIE:
- num_ids = 1 << apicid_die_offset(topo_info);
- break;
- case CPU_TOPO_LEVEL_PACKAGE:
- num_ids = 1 << apicid_pkg_offset(topo_info);
- break;
- default:
- /*
- * Currently there is no use case for SMT and MODULE, so use
- * assert directly to facilitate debugging.
- */
- g_assert_not_reached();
- }
- return num_ids - 1;
- }
- static uint32_t max_core_ids_in_package(X86CPUTopoInfo *topo_info)
- {
- uint32_t num_cores = 1 << (apicid_pkg_offset(topo_info) -
- apicid_core_offset(topo_info));
- return num_cores - 1;
- }
- /* Encode cache info for CPUID[4] */
- static void encode_cache_cpuid4(CPUCacheInfo *cache,
- X86CPUTopoInfo *topo_info,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
- {
- assert(cache->size == cache->line_size * cache->associativity *
- cache->partitions * cache->sets);
- *eax = CACHE_TYPE(cache->type) |
- CACHE_LEVEL(cache->level) |
- (cache->self_init ? CACHE_SELF_INIT_LEVEL : 0) |
- (max_core_ids_in_package(topo_info) << 26) |
- (max_thread_ids_for_cache(topo_info, cache->share_level) << 14);
- assert(cache->line_size > 0);
- assert(cache->partitions > 0);
- assert(cache->associativity > 0);
- /* We don't implement fully-associative caches */
- assert(cache->associativity < cache->sets);
- *ebx = (cache->line_size - 1) |
- ((cache->partitions - 1) << 12) |
- ((cache->associativity - 1) << 22);
- assert(cache->sets > 0);
- *ecx = cache->sets - 1;
- *edx = (cache->no_invd_sharing ? CACHE_NO_INVD_SHARING : 0) |
- (cache->inclusive ? CACHE_INCLUSIVE : 0) |
- (cache->complex_indexing ? CACHE_COMPLEX_IDX : 0);
- }
- static uint32_t num_threads_by_topo_level(X86CPUTopoInfo *topo_info,
- enum CPUTopoLevel topo_level)
- {
- switch (topo_level) {
- case CPU_TOPO_LEVEL_SMT:
- return 1;
- case CPU_TOPO_LEVEL_CORE:
- return topo_info->threads_per_core;
- case CPU_TOPO_LEVEL_MODULE:
- return topo_info->threads_per_core * topo_info->cores_per_module;
- case CPU_TOPO_LEVEL_DIE:
- return topo_info->threads_per_core * topo_info->cores_per_module *
- topo_info->modules_per_die;
- case CPU_TOPO_LEVEL_PACKAGE:
- return topo_info->threads_per_core * topo_info->cores_per_module *
- topo_info->modules_per_die * topo_info->dies_per_pkg;
- default:
- g_assert_not_reached();
- }
- return 0;
- }
- static uint32_t apicid_offset_by_topo_level(X86CPUTopoInfo *topo_info,
- enum CPUTopoLevel topo_level)
- {
- switch (topo_level) {
- case CPU_TOPO_LEVEL_SMT:
- return 0;
- case CPU_TOPO_LEVEL_CORE:
- return apicid_core_offset(topo_info);
- case CPU_TOPO_LEVEL_MODULE:
- return apicid_module_offset(topo_info);
- case CPU_TOPO_LEVEL_DIE:
- return apicid_die_offset(topo_info);
- case CPU_TOPO_LEVEL_PACKAGE:
- return apicid_pkg_offset(topo_info);
- default:
- g_assert_not_reached();
- }
- return 0;
- }
- static uint32_t cpuid1f_topo_type(enum CPUTopoLevel topo_level)
- {
- switch (topo_level) {
- case CPU_TOPO_LEVEL_INVALID:
- return CPUID_1F_ECX_TOPO_LEVEL_INVALID;
- case CPU_TOPO_LEVEL_SMT:
- return CPUID_1F_ECX_TOPO_LEVEL_SMT;
- case CPU_TOPO_LEVEL_CORE:
- return CPUID_1F_ECX_TOPO_LEVEL_CORE;
- case CPU_TOPO_LEVEL_MODULE:
- return CPUID_1F_ECX_TOPO_LEVEL_MODULE;
- case CPU_TOPO_LEVEL_DIE:
- return CPUID_1F_ECX_TOPO_LEVEL_DIE;
- default:
- /* Other types are not supported in QEMU. */
- g_assert_not_reached();
- }
- return 0;
- }
- static void encode_topo_cpuid1f(CPUX86State *env, uint32_t count,
- X86CPUTopoInfo *topo_info,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
- {
- X86CPU *cpu = env_archcpu(env);
- unsigned long level, next_level;
- uint32_t num_threads_next_level, offset_next_level;
- assert(count + 1 < CPU_TOPO_LEVEL_MAX);
- /*
- * Find the No.(count + 1) topology level in avail_cpu_topo bitmap.
- * The search starts from bit 1 (CPU_TOPO_LEVEL_INVALID + 1).
- */
- level = CPU_TOPO_LEVEL_INVALID;
- for (int i = 0; i <= count; i++) {
- level = find_next_bit(env->avail_cpu_topo,
- CPU_TOPO_LEVEL_PACKAGE,
- level + 1);
- /*
- * CPUID[0x1f] doesn't explicitly encode the package level,
- * and it just encodes the invalid level (all fields are 0)
- * into the last subleaf of 0x1f.
- */
- if (level == CPU_TOPO_LEVEL_PACKAGE) {
- level = CPU_TOPO_LEVEL_INVALID;
- break;
- }
- }
- if (level == CPU_TOPO_LEVEL_INVALID) {
- num_threads_next_level = 0;
- offset_next_level = 0;
- } else {
- next_level = find_next_bit(env->avail_cpu_topo,
- CPU_TOPO_LEVEL_PACKAGE,
- level + 1);
- num_threads_next_level = num_threads_by_topo_level(topo_info,
- next_level);
- offset_next_level = apicid_offset_by_topo_level(topo_info,
- next_level);
- }
- *eax = offset_next_level;
- /* The count (bits 15-00) doesn't need to be reliable. */
- *ebx = num_threads_next_level & 0xffff;
- *ecx = (count & 0xff) | (cpuid1f_topo_type(level) << 8);
- *edx = cpu->apic_id;
- assert(!(*eax & ~0x1f));
- }
- /* Encode cache info for CPUID[0x80000005].ECX or CPUID[0x80000005].EDX */
- static uint32_t encode_cache_cpuid80000005(CPUCacheInfo *cache)
- {
- assert(cache->size % 1024 == 0);
- assert(cache->lines_per_tag > 0);
- assert(cache->associativity > 0);
- assert(cache->line_size > 0);
- return ((cache->size / 1024) << 24) | (cache->associativity << 16) |
- (cache->lines_per_tag << 8) | (cache->line_size);
- }
- #define ASSOC_FULL 0xFF
- /* AMD associativity encoding used on CPUID Leaf 0x80000006: */
- #define AMD_ENC_ASSOC(a) (a <= 1 ? a : \
- a == 2 ? 0x2 : \
- a == 4 ? 0x4 : \
- a == 8 ? 0x6 : \
- a == 16 ? 0x8 : \
- a == 32 ? 0xA : \
- a == 48 ? 0xB : \
- a == 64 ? 0xC : \
- a == 96 ? 0xD : \
- a == 128 ? 0xE : \
- a == ASSOC_FULL ? 0xF : \
- 0 /* invalid value */)
- /*
- * Encode cache info for CPUID[0x80000006].ECX and CPUID[0x80000006].EDX
- * @l3 can be NULL.
- */
- static void encode_cache_cpuid80000006(CPUCacheInfo *l2,
- CPUCacheInfo *l3,
- uint32_t *ecx, uint32_t *edx)
- {
- assert(l2->size % 1024 == 0);
- assert(l2->associativity > 0);
- assert(l2->lines_per_tag > 0);
- assert(l2->line_size > 0);
- *ecx = ((l2->size / 1024) << 16) |
- (AMD_ENC_ASSOC(l2->associativity) << 12) |
- (l2->lines_per_tag << 8) | (l2->line_size);
- if (l3) {
- assert(l3->size % (512 * 1024) == 0);
- assert(l3->associativity > 0);
- assert(l3->lines_per_tag > 0);
- assert(l3->line_size > 0);
- *edx = ((l3->size / (512 * 1024)) << 18) |
- (AMD_ENC_ASSOC(l3->associativity) << 12) |
- (l3->lines_per_tag << 8) | (l3->line_size);
- } else {
- *edx = 0;
- }
- }
- /* Encode cache info for CPUID[8000001D] */
- static void encode_cache_cpuid8000001d(CPUCacheInfo *cache,
- X86CPUTopoInfo *topo_info,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
- {
- assert(cache->size == cache->line_size * cache->associativity *
- cache->partitions * cache->sets);
- *eax = CACHE_TYPE(cache->type) | CACHE_LEVEL(cache->level) |
- (cache->self_init ? CACHE_SELF_INIT_LEVEL : 0);
- *eax |= max_thread_ids_for_cache(topo_info, cache->share_level) << 14;
- assert(cache->line_size > 0);
- assert(cache->partitions > 0);
- assert(cache->associativity > 0);
- /* We don't implement fully-associative caches */
- assert(cache->associativity < cache->sets);
- *ebx = (cache->line_size - 1) |
- ((cache->partitions - 1) << 12) |
- ((cache->associativity - 1) << 22);
- assert(cache->sets > 0);
- *ecx = cache->sets - 1;
- *edx = (cache->no_invd_sharing ? CACHE_NO_INVD_SHARING : 0) |
- (cache->inclusive ? CACHE_INCLUSIVE : 0) |
- (cache->complex_indexing ? CACHE_COMPLEX_IDX : 0);
- }
- /* Encode cache info for CPUID[8000001E] */
- static void encode_topo_cpuid8000001e(X86CPU *cpu, X86CPUTopoInfo *topo_info,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
- {
- X86CPUTopoIDs topo_ids;
- x86_topo_ids_from_apicid(cpu->apic_id, topo_info, &topo_ids);
- *eax = cpu->apic_id;
- /*
- * CPUID_Fn8000001E_EBX [Core Identifiers] (CoreId)
- * Read-only. Reset: 0000_XXXXh.
- * See Core::X86::Cpuid::ExtApicId.
- * Core::X86::Cpuid::CoreId_lthree[1:0]_core[3:0]_thread[1:0];
- * Bits Description
- * 31:16 Reserved.
- * 15:8 ThreadsPerCore: threads per core. Read-only. Reset: XXh.
- * The number of threads per core is ThreadsPerCore+1.
- * 7:0 CoreId: core ID. Read-only. Reset: XXh.
- *
- * NOTE: CoreId is already part of apic_id. Just use it. We can
- * use all the 8 bits to represent the core_id here.
- */
- *ebx = ((topo_info->threads_per_core - 1) << 8) | (topo_ids.core_id & 0xFF);
- /*
- * CPUID_Fn8000001E_ECX [Node Identifiers] (NodeId)
- * Read-only. Reset: 0000_0XXXh.
- * Core::X86::Cpuid::NodeId_lthree[1:0]_core[3:0]_thread[1:0];
- * Bits Description
- * 31:11 Reserved.
- * 10:8 NodesPerProcessor: Node per processor. Read-only. Reset: XXXb.
- * ValidValues:
- * Value Description
- * 0h 1 node per processor.
- * 7h-1h Reserved.
- * 7:0 NodeId: Node ID. Read-only. Reset: XXh.
- *
- * NOTE: Hardware reserves 3 bits for number of nodes per processor.
- * But users can create more nodes than the actual hardware can
- * support. To genaralize we can use all the upper 8 bits for nodes.
- * NodeId is combination of node and socket_id which is already decoded
- * in apic_id. Just use it by shifting.
- */
- if (cpu->legacy_multi_node) {
- *ecx = ((topo_info->dies_per_pkg - 1) << 8) |
- ((cpu->apic_id >> apicid_die_offset(topo_info)) & 0xFF);
- } else {
- *ecx = (cpu->apic_id >> apicid_pkg_offset(topo_info)) & 0xFF;
- }
- *edx = 0;
- }
- /*
- * Definitions of the hardcoded cache entries we expose:
- * These are legacy cache values. If there is a need to change any
- * of these values please use builtin_x86_defs
- */
- /* L1 data cache: */
- static CPUCacheInfo legacy_l1d_cache = {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .self_init = 1,
- .line_size = 64,
- .associativity = 8,
- .sets = 64,
- .partitions = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- };
- /*FIXME: CPUID leaf 0x80000005 is inconsistent with leaves 2 & 4 */
- static CPUCacheInfo legacy_l1d_cache_amd = {
- .type = DATA_CACHE,
- .level = 1,
- .size = 64 * KiB,
- .self_init = 1,
- .line_size = 64,
- .associativity = 2,
- .sets = 512,
- .partitions = 1,
- .lines_per_tag = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- };
- /* L1 instruction cache: */
- static CPUCacheInfo legacy_l1i_cache = {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .self_init = 1,
- .line_size = 64,
- .associativity = 8,
- .sets = 64,
- .partitions = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- };
- /*FIXME: CPUID leaf 0x80000005 is inconsistent with leaves 2 & 4 */
- static CPUCacheInfo legacy_l1i_cache_amd = {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 64 * KiB,
- .self_init = 1,
- .line_size = 64,
- .associativity = 2,
- .sets = 512,
- .partitions = 1,
- .lines_per_tag = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- };
- /* Level 2 unified cache: */
- static CPUCacheInfo legacy_l2_cache = {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 4 * MiB,
- .self_init = 1,
- .line_size = 64,
- .associativity = 16,
- .sets = 4096,
- .partitions = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- };
- /*FIXME: CPUID leaf 2 descriptor is inconsistent with CPUID leaf 4 */
- static CPUCacheInfo legacy_l2_cache_cpuid2 = {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 2 * MiB,
- .line_size = 64,
- .associativity = 8,
- .share_level = CPU_TOPO_LEVEL_INVALID,
- };
- /*FIXME: CPUID leaf 0x80000006 is inconsistent with leaves 2 & 4 */
- static CPUCacheInfo legacy_l2_cache_amd = {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 512 * KiB,
- .line_size = 64,
- .lines_per_tag = 1,
- .associativity = 16,
- .sets = 512,
- .partitions = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- };
- /* Level 3 unified cache: */
- static CPUCacheInfo legacy_l3_cache = {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 16 * MiB,
- .line_size = 64,
- .associativity = 16,
- .sets = 16384,
- .partitions = 1,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = true,
- .share_level = CPU_TOPO_LEVEL_DIE,
- };
- /* TLB definitions: */
- #define L1_DTLB_2M_ASSOC 1
- #define L1_DTLB_2M_ENTRIES 255
- #define L1_DTLB_4K_ASSOC 1
- #define L1_DTLB_4K_ENTRIES 255
- #define L1_ITLB_2M_ASSOC 1
- #define L1_ITLB_2M_ENTRIES 255
- #define L1_ITLB_4K_ASSOC 1
- #define L1_ITLB_4K_ENTRIES 255
- #define L2_DTLB_2M_ASSOC 0 /* disabled */
- #define L2_DTLB_2M_ENTRIES 0 /* disabled */
- #define L2_DTLB_4K_ASSOC 4
- #define L2_DTLB_4K_ENTRIES 512
- #define L2_ITLB_2M_ASSOC 0 /* disabled */
- #define L2_ITLB_2M_ENTRIES 0 /* disabled */
- #define L2_ITLB_4K_ASSOC 4
- #define L2_ITLB_4K_ENTRIES 512
- /* CPUID Leaf 0x14 constants: */
- #define INTEL_PT_MAX_SUBLEAF 0x1
- /*
- * bit[00]: IA32_RTIT_CTL.CR3 filter can be set to 1 and IA32_RTIT_CR3_MATCH
- * MSR can be accessed;
- * bit[01]: Support Configurable PSB and Cycle-Accurate Mode;
- * bit[02]: Support IP Filtering, TraceStop filtering, and preservation
- * of Intel PT MSRs across warm reset;
- * bit[03]: Support MTC timing packet and suppression of COFI-based packets;
- */
- #define INTEL_PT_MINIMAL_EBX 0xf
- /*
- * bit[00]: Tracing can be enabled with IA32_RTIT_CTL.ToPA = 1 and
- * IA32_RTIT_OUTPUT_BASE and IA32_RTIT_OUTPUT_MASK_PTRS MSRs can be
- * accessed;
- * bit[01]: ToPA tables can hold any number of output entries, up to the
- * maximum allowed by the MaskOrTableOffset field of
- * IA32_RTIT_OUTPUT_MASK_PTRS;
- * bit[02]: Support Single-Range Output scheme;
- */
- #define INTEL_PT_MINIMAL_ECX 0x7
- /* generated packets which contain IP payloads have LIP values */
- #define INTEL_PT_IP_LIP (1 << 31)
- #define INTEL_PT_ADDR_RANGES_NUM 0x2 /* Number of configurable address ranges */
- #define INTEL_PT_ADDR_RANGES_NUM_MASK 0x3
- #define INTEL_PT_MTC_BITMAP (0x0249 << 16) /* Support ART(0,3,6,9) */
- #define INTEL_PT_CYCLE_BITMAP 0x1fff /* Support 0,2^(0~11) */
- #define INTEL_PT_PSB_BITMAP (0x003f << 16) /* Support 2K,4K,8K,16K,32K,64K */
- /* CPUID Leaf 0x1D constants: */
- #define INTEL_AMX_TILE_MAX_SUBLEAF 0x1
- #define INTEL_AMX_TOTAL_TILE_BYTES 0x2000
- #define INTEL_AMX_BYTES_PER_TILE 0x400
- #define INTEL_AMX_BYTES_PER_ROW 0x40
- #define INTEL_AMX_TILE_MAX_NAMES 0x8
- #define INTEL_AMX_TILE_MAX_ROWS 0x10
- /* CPUID Leaf 0x1E constants: */
- #define INTEL_AMX_TMUL_MAX_K 0x10
- #define INTEL_AMX_TMUL_MAX_N 0x40
- void x86_cpu_vendor_words2str(char *dst, uint32_t vendor1,
- uint32_t vendor2, uint32_t vendor3)
- {
- int i;
- for (i = 0; i < 4; i++) {
- dst[i] = vendor1 >> (8 * i);
- dst[i + 4] = vendor2 >> (8 * i);
- dst[i + 8] = vendor3 >> (8 * i);
- }
- dst[CPUID_VENDOR_SZ] = '\0';
- }
- #define I486_FEATURES (CPUID_FP87 | CPUID_VME | CPUID_PSE)
- #define PENTIUM_FEATURES (I486_FEATURES | CPUID_DE | CPUID_TSC | \
- CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_MMX | CPUID_APIC)
- #define PENTIUM2_FEATURES (PENTIUM_FEATURES | CPUID_PAE | CPUID_SEP | \
- CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV | CPUID_PAT | \
- CPUID_PSE36 | CPUID_FXSR)
- #define PENTIUM3_FEATURES (PENTIUM2_FEATURES | CPUID_SSE)
- #define PPRO_FEATURES (CPUID_FP87 | CPUID_DE | CPUID_PSE | CPUID_TSC | \
- CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_PGE | CPUID_CMOV | \
- CPUID_PAT | CPUID_FXSR | CPUID_MMX | CPUID_SSE | CPUID_SSE2 | \
- CPUID_PAE | CPUID_SEP | CPUID_APIC)
- #define TCG_FEATURES (CPUID_FP87 | CPUID_PSE | CPUID_TSC | CPUID_MSR | \
- CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC | CPUID_SEP | \
- CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV | CPUID_PAT | \
- CPUID_PSE36 | CPUID_CLFLUSH | CPUID_ACPI | CPUID_MMX | \
- CPUID_FXSR | CPUID_SSE | CPUID_SSE2 | CPUID_SS | CPUID_DE)
- /* partly implemented:
- CPUID_MTRR, CPUID_MCA, CPUID_CLFLUSH (needed for Win64) */
- /* missing:
- CPUID_VME, CPUID_DTS, CPUID_SS, CPUID_HT, CPUID_TM, CPUID_PBE */
- /*
- * Kernel-only features that can be shown to usermode programs even if
- * they aren't actually supported by TCG, because qemu-user only runs
- * in CPL=3; remove them if they are ever implemented for system emulation.
- */
- #if defined CONFIG_USER_ONLY
- #define CPUID_EXT_KERNEL_FEATURES \
- (CPUID_EXT_PCID | CPUID_EXT_TSC_DEADLINE_TIMER)
- #else
- #define CPUID_EXT_KERNEL_FEATURES 0
- #endif
- #define TCG_EXT_FEATURES (CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | \
- CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 | CPUID_EXT_CX16 | \
- CPUID_EXT_SSE41 | CPUID_EXT_SSE42 | CPUID_EXT_POPCNT | \
- CPUID_EXT_XSAVE | /* CPUID_EXT_OSXSAVE is dynamic */ \
- CPUID_EXT_MOVBE | CPUID_EXT_AES | CPUID_EXT_HYPERVISOR | \
- CPUID_EXT_RDRAND | CPUID_EXT_AVX | CPUID_EXT_F16C | \
- CPUID_EXT_FMA | CPUID_EXT_X2APIC | CPUID_EXT_KERNEL_FEATURES)
- /* missing:
- CPUID_EXT_DTES64, CPUID_EXT_DSCPL, CPUID_EXT_VMX, CPUID_EXT_SMX,
- CPUID_EXT_EST, CPUID_EXT_TM2, CPUID_EXT_CID,
- CPUID_EXT_XTPR, CPUID_EXT_PDCM, CPUID_EXT_PCID, CPUID_EXT_DCA,
- CPUID_EXT_TSC_DEADLINE_TIMER
- */
- #ifdef TARGET_X86_64
- #define TCG_EXT2_X86_64_FEATURES CPUID_EXT2_LM
- #else
- #define TCG_EXT2_X86_64_FEATURES 0
- #endif
- /*
- * CPUID_*_KERNEL_FEATURES denotes bits and features that are not usable
- * in usermode or by 32-bit programs. Those are added to supported
- * TCG features unconditionally in user-mode emulation mode. This may
- * indeed seem strange or incorrect, but it works because code running
- * under usermode emulation cannot access them.
- *
- * Even for long mode, qemu-i386 is not running "a userspace program on a
- * 32-bit CPU"; it's running "a userspace program with a 32-bit code segment"
- * and therefore using the 32-bit ABI; the CPU itself might be 64-bit
- * but again the difference is only visible in kernel mode.
- */
- #if defined CONFIG_LINUX_USER
- #define CPUID_EXT2_KERNEL_FEATURES (CPUID_EXT2_LM | CPUID_EXT2_FFXSR)
- #elif defined CONFIG_USER_ONLY
- /* FIXME: Long mode not yet supported for i386 bsd-user */
- #define CPUID_EXT2_KERNEL_FEATURES CPUID_EXT2_FFXSR
- #else
- #define CPUID_EXT2_KERNEL_FEATURES 0
- #endif
- #define TCG_EXT2_FEATURES ((TCG_FEATURES & CPUID_EXT2_AMD_ALIASES) | \
- CPUID_EXT2_NX | CPUID_EXT2_MMXEXT | CPUID_EXT2_RDTSCP | \
- CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT | CPUID_EXT2_PDPE1GB | \
- CPUID_EXT2_SYSCALL | TCG_EXT2_X86_64_FEATURES | \
- CPUID_EXT2_KERNEL_FEATURES)
- #if defined CONFIG_USER_ONLY
- #define CPUID_EXT3_KERNEL_FEATURES CPUID_EXT3_OSVW
- #else
- #define CPUID_EXT3_KERNEL_FEATURES 0
- #endif
- #define TCG_EXT3_FEATURES (CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM | \
- CPUID_EXT3_CR8LEG | CPUID_EXT3_ABM | CPUID_EXT3_SSE4A | \
- CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_KERNEL_FEATURES)
- #define TCG_EXT4_FEATURES 0
- #if defined CONFIG_USER_ONLY
- #define CPUID_SVM_KERNEL_FEATURES (CPUID_SVM_NRIPSAVE | CPUID_SVM_VNMI)
- #else
- #define CPUID_SVM_KERNEL_FEATURES 0
- #endif
- #define TCG_SVM_FEATURES (CPUID_SVM_NPT | CPUID_SVM_VGIF | \
- CPUID_SVM_SVME_ADDR_CHK | CPUID_SVM_KERNEL_FEATURES)
- #define TCG_KVM_FEATURES 0
- #if defined CONFIG_USER_ONLY
- #define CPUID_7_0_EBX_KERNEL_FEATURES CPUID_7_0_EBX_INVPCID
- #else
- #define CPUID_7_0_EBX_KERNEL_FEATURES 0
- #endif
- #define TCG_7_0_EBX_FEATURES (CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_SMAP | \
- CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ADX | \
- CPUID_7_0_EBX_CLFLUSHOPT | \
- CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_MPX | CPUID_7_0_EBX_FSGSBASE | \
- CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_RDSEED | \
- CPUID_7_0_EBX_SHA_NI | CPUID_7_0_EBX_KERNEL_FEATURES)
- /* missing:
- CPUID_7_0_EBX_HLE
- CPUID_7_0_EBX_INVPCID, CPUID_7_0_EBX_RTM */
- #if !defined CONFIG_USER_ONLY || defined CONFIG_LINUX
- #define TCG_7_0_ECX_RDPID CPUID_7_0_ECX_RDPID
- #else
- #define TCG_7_0_ECX_RDPID 0
- #endif
- #define TCG_7_0_ECX_FEATURES (CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU | \
- /* CPUID_7_0_ECX_OSPKE is dynamic */ \
- CPUID_7_0_ECX_LA57 | CPUID_7_0_ECX_PKS | CPUID_7_0_ECX_VAES | \
- TCG_7_0_ECX_RDPID)
- #if defined CONFIG_USER_ONLY
- #define CPUID_7_0_EDX_KERNEL_FEATURES (CPUID_7_0_EDX_SPEC_CTRL | \
- CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD)
- #else
- #define CPUID_7_0_EDX_KERNEL_FEATURES 0
- #endif
- #define TCG_7_0_EDX_FEATURES (CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_KERNEL_FEATURES)
- #define TCG_7_1_EAX_FEATURES (CPUID_7_1_EAX_FZRM | CPUID_7_1_EAX_FSRS | \
- CPUID_7_1_EAX_FSRC | CPUID_7_1_EAX_CMPCCXADD)
- #define TCG_7_1_EDX_FEATURES 0
- #define TCG_7_2_EDX_FEATURES 0
- #define TCG_APM_FEATURES 0
- #define TCG_6_EAX_FEATURES CPUID_6_EAX_ARAT
- #define TCG_XSAVE_FEATURES (CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XGETBV1)
- /* missing:
- CPUID_XSAVE_XSAVEC, CPUID_XSAVE_XSAVES */
- #define TCG_14_0_ECX_FEATURES 0
- #define TCG_SGX_12_0_EAX_FEATURES 0
- #define TCG_SGX_12_0_EBX_FEATURES 0
- #define TCG_SGX_12_1_EAX_FEATURES 0
- #if defined CONFIG_USER_ONLY
- #define CPUID_8000_0008_EBX_KERNEL_FEATURES (CPUID_8000_0008_EBX_IBPB | \
- CPUID_8000_0008_EBX_IBRS | CPUID_8000_0008_EBX_STIBP | \
- CPUID_8000_0008_EBX_STIBP_ALWAYS_ON | CPUID_8000_0008_EBX_AMD_SSBD | \
- CPUID_8000_0008_EBX_AMD_PSFD)
- #else
- #define CPUID_8000_0008_EBX_KERNEL_FEATURES 0
- #endif
- #define TCG_8000_0008_EBX (CPUID_8000_0008_EBX_XSAVEERPTR | \
- CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_KERNEL_FEATURES)
- FeatureWordInfo feature_word_info[FEATURE_WORDS] = {
- [FEAT_1_EDX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "fpu", "vme", "de", "pse",
- "tsc", "msr", "pae", "mce",
- "cx8", "apic", NULL, "sep",
- "mtrr", "pge", "mca", "cmov",
- "pat", "pse36", "pn" /* Intel psn */, "clflush" /* Intel clfsh */,
- NULL, "ds" /* Intel dts */, "acpi", "mmx",
- "fxsr", "sse", "sse2", "ss",
- "ht" /* Intel htt */, "tm", "ia64", "pbe",
- },
- .cpuid = {.eax = 1, .reg = R_EDX, },
- .tcg_features = TCG_FEATURES,
- .no_autoenable_flags = CPUID_HT,
- },
- [FEAT_1_ECX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "pni" /* Intel,AMD sse3 */, "pclmulqdq", "dtes64", "monitor",
- "ds-cpl", "vmx", "smx", "est",
- "tm2", "ssse3", "cid", NULL,
- "fma", "cx16", "xtpr", "pdcm",
- NULL, "pcid", "dca", "sse4.1",
- "sse4.2", "x2apic", "movbe", "popcnt",
- "tsc-deadline", "aes", "xsave", NULL /* osxsave */,
- "avx", "f16c", "rdrand", "hypervisor",
- },
- .cpuid = { .eax = 1, .reg = R_ECX, },
- .tcg_features = TCG_EXT_FEATURES,
- },
- /* Feature names that are already defined on feature_name[] but
- * are set on CPUID[8000_0001].EDX on AMD CPUs don't have their
- * names on feat_names below. They are copied automatically
- * to features[FEAT_8000_0001_EDX] if and only if CPU vendor is AMD.
- */
- [FEAT_8000_0001_EDX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL /* fpu */, NULL /* vme */, NULL /* de */, NULL /* pse */,
- NULL /* tsc */, NULL /* msr */, NULL /* pae */, NULL /* mce */,
- NULL /* cx8 */, NULL /* apic */, NULL, "syscall",
- NULL /* mtrr */, NULL /* pge */, NULL /* mca */, NULL /* cmov */,
- NULL /* pat */, NULL /* pse36 */, NULL, NULL /* Linux mp */,
- "nx", NULL, "mmxext", NULL /* mmx */,
- NULL /* fxsr */, "fxsr-opt", "pdpe1gb", "rdtscp",
- NULL, "lm", "3dnowext", "3dnow",
- },
- .cpuid = { .eax = 0x80000001, .reg = R_EDX, },
- .tcg_features = TCG_EXT2_FEATURES,
- },
- [FEAT_8000_0001_ECX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "lahf-lm", "cmp-legacy", "svm", "extapic",
- "cr8legacy", "abm", "sse4a", "misalignsse",
- "3dnowprefetch", "osvw", "ibs", "xop",
- "skinit", "wdt", NULL, "lwp",
- "fma4", "tce", NULL, "nodeid-msr",
- NULL, "tbm", "topoext", "perfctr-core",
- "perfctr-nb", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = { .eax = 0x80000001, .reg = R_ECX, },
- .tcg_features = TCG_EXT3_FEATURES,
- /*
- * TOPOEXT is always allowed but can't be enabled blindly by
- * "-cpu host", as it requires consistent cache topology info
- * to be provided so it doesn't confuse guests.
- */
- .no_autoenable_flags = CPUID_EXT3_TOPOEXT,
- },
- [FEAT_C000_0001_EDX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, "xstore", "xstore-en",
- NULL, NULL, "xcrypt", "xcrypt-en",
- "ace2", "ace2-en", "phe", "phe-en",
- "pmm", "pmm-en", NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = { .eax = 0xC0000001, .reg = R_EDX, },
- .tcg_features = TCG_EXT4_FEATURES,
- },
- [FEAT_KVM] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "kvmclock", "kvm-nopiodelay", "kvm-mmu", "kvmclock",
- "kvm-asyncpf", "kvm-steal-time", "kvm-pv-eoi", "kvm-pv-unhalt",
- NULL, "kvm-pv-tlb-flush", "kvm-asyncpf-vmexit", "kvm-pv-ipi",
- "kvm-poll-control", "kvm-pv-sched-yield", "kvm-asyncpf-int", "kvm-msi-ext-dest-id",
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- "kvmclock-stable-bit", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = { .eax = KVM_CPUID_FEATURES, .reg = R_EAX, },
- .tcg_features = TCG_KVM_FEATURES,
- },
- [FEAT_KVM_HINTS] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "kvm-hint-dedicated", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = { .eax = KVM_CPUID_FEATURES, .reg = R_EDX, },
- .tcg_features = TCG_KVM_FEATURES,
- /*
- * KVM hints aren't auto-enabled by -cpu host, they need to be
- * explicitly enabled in the command-line.
- */
- .no_autoenable_flags = ~0U,
- },
- [FEAT_SVM] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "npt", "lbrv", "svm-lock", "nrip-save",
- "tsc-scale", "vmcb-clean", "flushbyasid", "decodeassists",
- NULL, NULL, "pause-filter", NULL,
- "pfthreshold", "avic", NULL, "v-vmsave-vmload",
- "vgif", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, "vnmi", NULL, NULL,
- "svme-addr-chk", NULL, NULL, NULL,
- },
- .cpuid = { .eax = 0x8000000A, .reg = R_EDX, },
- .tcg_features = TCG_SVM_FEATURES,
- },
- [FEAT_7_0_EBX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "fsgsbase", "tsc-adjust", "sgx", "bmi1",
- "hle", "avx2", NULL, "smep",
- "bmi2", "erms", "invpcid", "rtm",
- NULL, NULL, "mpx", NULL,
- "avx512f", "avx512dq", "rdseed", "adx",
- "smap", "avx512ifma", "pcommit", "clflushopt",
- "clwb", "intel-pt", "avx512pf", "avx512er",
- "avx512cd", "sha-ni", "avx512bw", "avx512vl",
- },
- .cpuid = {
- .eax = 7,
- .needs_ecx = true, .ecx = 0,
- .reg = R_EBX,
- },
- .tcg_features = TCG_7_0_EBX_FEATURES,
- },
- [FEAT_7_0_ECX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, "avx512vbmi", "umip", "pku",
- NULL /* ospke */, "waitpkg", "avx512vbmi2", NULL,
- "gfni", "vaes", "vpclmulqdq", "avx512vnni",
- "avx512bitalg", NULL, "avx512-vpopcntdq", NULL,
- "la57", NULL, NULL, NULL,
- NULL, NULL, "rdpid", NULL,
- "bus-lock-detect", "cldemote", NULL, "movdiri",
- "movdir64b", NULL, "sgxlc", "pks",
- },
- .cpuid = {
- .eax = 7,
- .needs_ecx = true, .ecx = 0,
- .reg = R_ECX,
- },
- .tcg_features = TCG_7_0_ECX_FEATURES,
- },
- [FEAT_7_0_EDX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, "avx512-4vnniw", "avx512-4fmaps",
- "fsrm", NULL, NULL, NULL,
- "avx512-vp2intersect", NULL, "md-clear", NULL,
- NULL, NULL, "serialize", NULL,
- "tsx-ldtrk", NULL, NULL /* pconfig */, "arch-lbr",
- NULL, NULL, "amx-bf16", "avx512-fp16",
- "amx-tile", "amx-int8", "spec-ctrl", "stibp",
- "flush-l1d", "arch-capabilities", "core-capability", "ssbd",
- },
- .cpuid = {
- .eax = 7,
- .needs_ecx = true, .ecx = 0,
- .reg = R_EDX,
- },
- .tcg_features = TCG_7_0_EDX_FEATURES,
- },
- [FEAT_7_1_EAX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- "avx-vnni", "avx512-bf16", NULL, "cmpccxadd",
- NULL, NULL, "fzrm", "fsrs",
- "fsrc", NULL, NULL, NULL,
- NULL, "fred", "lkgs", "wrmsrns",
- NULL, "amx-fp16", NULL, "avx-ifma",
- NULL, NULL, "lam", NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 7,
- .needs_ecx = true, .ecx = 1,
- .reg = R_EAX,
- },
- .tcg_features = TCG_7_1_EAX_FEATURES,
- },
- [FEAT_7_1_EDX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- "avx-vnni-int8", "avx-ne-convert", NULL, NULL,
- "amx-complex", NULL, "avx-vnni-int16", NULL,
- NULL, NULL, "prefetchiti", NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 7,
- .needs_ecx = true, .ecx = 1,
- .reg = R_EDX,
- },
- .tcg_features = TCG_7_1_EDX_FEATURES,
- },
- [FEAT_7_2_EDX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- NULL, "mcdt-no", NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 7,
- .needs_ecx = true, .ecx = 2,
- .reg = R_EDX,
- },
- .tcg_features = TCG_7_2_EDX_FEATURES,
- },
- [FEAT_8000_0007_EDX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- "invtsc", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = { .eax = 0x80000007, .reg = R_EDX, },
- .tcg_features = TCG_APM_FEATURES,
- .unmigratable_flags = CPUID_APM_INVTSC,
- },
- [FEAT_8000_0007_EBX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "overflow-recov", "succor", NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = { .eax = 0x80000007, .reg = R_EBX, },
- .tcg_features = 0,
- .unmigratable_flags = 0,
- },
- [FEAT_8000_0008_EBX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "clzero", NULL, "xsaveerptr", NULL,
- NULL, NULL, NULL, NULL,
- NULL, "wbnoinvd", NULL, NULL,
- "ibpb", NULL, "ibrs", "amd-stibp",
- NULL, "stibp-always-on", NULL, NULL,
- NULL, NULL, NULL, NULL,
- "amd-ssbd", "virt-ssbd", "amd-no-ssb", NULL,
- "amd-psfd", NULL, NULL, NULL,
- },
- .cpuid = { .eax = 0x80000008, .reg = R_EBX, },
- .tcg_features = TCG_8000_0008_EBX,
- .unmigratable_flags = 0,
- },
- [FEAT_8000_0021_EAX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "no-nested-data-bp", NULL, "lfence-always-serializing", NULL,
- NULL, NULL, "null-sel-clr-base", NULL,
- "auto-ibrs", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, "sbpb",
- "ibpb-brtype", NULL, NULL, NULL,
- },
- .cpuid = { .eax = 0x80000021, .reg = R_EAX, },
- .tcg_features = 0,
- .unmigratable_flags = 0,
- },
- [FEAT_XSAVE] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "xsaveopt", "xsavec", "xgetbv1", "xsaves",
- "xfd", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 0xd,
- .needs_ecx = true, .ecx = 1,
- .reg = R_EAX,
- },
- .tcg_features = TCG_XSAVE_FEATURES,
- },
- [FEAT_XSAVE_XSS_LO] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 0xD,
- .needs_ecx = true,
- .ecx = 1,
- .reg = R_ECX,
- },
- },
- [FEAT_XSAVE_XSS_HI] = {
- .type = CPUID_FEATURE_WORD,
- .cpuid = {
- .eax = 0xD,
- .needs_ecx = true,
- .ecx = 1,
- .reg = R_EDX
- },
- },
- [FEAT_6_EAX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, "arat", NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = { .eax = 6, .reg = R_EAX, },
- .tcg_features = TCG_6_EAX_FEATURES,
- },
- [FEAT_XSAVE_XCR0_LO] = {
- .type = CPUID_FEATURE_WORD,
- .cpuid = {
- .eax = 0xD,
- .needs_ecx = true, .ecx = 0,
- .reg = R_EAX,
- },
- .tcg_features = ~0U,
- .migratable_flags = XSTATE_FP_MASK | XSTATE_SSE_MASK |
- XSTATE_YMM_MASK | XSTATE_BNDREGS_MASK | XSTATE_BNDCSR_MASK |
- XSTATE_OPMASK_MASK | XSTATE_ZMM_Hi256_MASK | XSTATE_Hi16_ZMM_MASK |
- XSTATE_PKRU_MASK,
- },
- [FEAT_XSAVE_XCR0_HI] = {
- .type = CPUID_FEATURE_WORD,
- .cpuid = {
- .eax = 0xD,
- .needs_ecx = true, .ecx = 0,
- .reg = R_EDX,
- },
- .tcg_features = ~0U,
- },
- /*Below are MSR exposed features*/
- [FEAT_ARCH_CAPABILITIES] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- "rdctl-no", "ibrs-all", "rsba", "skip-l1dfl-vmentry",
- "ssb-no", "mds-no", "pschange-mc-no", "tsx-ctrl",
- "taa-no", NULL, NULL, NULL,
- NULL, "sbdr-ssdp-no", "fbsdp-no", "psdp-no",
- NULL, "fb-clear", NULL, NULL,
- NULL, NULL, NULL, NULL,
- "pbrsb-no", NULL, "gds-no", "rfds-no",
- "rfds-clear", NULL, NULL, NULL,
- },
- .msr = {
- .index = MSR_IA32_ARCH_CAPABILITIES,
- },
- /*
- * FEAT_ARCH_CAPABILITIES only affects a read-only MSR, which
- * cannot be read from user mode. Therefore, it has no impact
- > on any user-mode operation, and warnings about unsupported
- * features do not matter.
- */
- .tcg_features = ~0U,
- },
- [FEAT_CORE_CAPABILITY] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- NULL, "split-lock-detect", NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .msr = {
- .index = MSR_IA32_CORE_CAPABILITY,
- },
- },
- [FEAT_PERF_CAPABILITIES] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, "full-width-write", NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .msr = {
- .index = MSR_IA32_PERF_CAPABILITIES,
- },
- },
- [FEAT_VMX_PROCBASED_CTLS] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, "vmx-vintr-pending", "vmx-tsc-offset",
- NULL, NULL, NULL, "vmx-hlt-exit",
- NULL, "vmx-invlpg-exit", "vmx-mwait-exit", "vmx-rdpmc-exit",
- "vmx-rdtsc-exit", NULL, NULL, "vmx-cr3-load-noexit",
- "vmx-cr3-store-noexit", NULL, NULL, "vmx-cr8-load-exit",
- "vmx-cr8-store-exit", "vmx-flexpriority", "vmx-vnmi-pending", "vmx-movdr-exit",
- "vmx-io-exit", "vmx-io-bitmap", NULL, "vmx-mtf",
- "vmx-msr-bitmap", "vmx-monitor-exit", "vmx-pause-exit", "vmx-secondary-ctls",
- },
- .msr = {
- .index = MSR_IA32_VMX_TRUE_PROCBASED_CTLS,
- }
- },
- [FEAT_VMX_SECONDARY_CTLS] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- "vmx-apicv-xapic", "vmx-ept", "vmx-desc-exit", "vmx-rdtscp-exit",
- "vmx-apicv-x2apic", "vmx-vpid", "vmx-wbinvd-exit", "vmx-unrestricted-guest",
- "vmx-apicv-register", "vmx-apicv-vid", "vmx-ple", "vmx-rdrand-exit",
- "vmx-invpcid-exit", "vmx-vmfunc", "vmx-shadow-vmcs", "vmx-encls-exit",
- "vmx-rdseed-exit", "vmx-pml", NULL, NULL,
- "vmx-xsaves", NULL, NULL, NULL,
- NULL, "vmx-tsc-scaling", "vmx-enable-user-wait-pause", NULL,
- NULL, NULL, NULL, NULL,
- },
- .msr = {
- .index = MSR_IA32_VMX_PROCBASED_CTLS2,
- }
- },
- [FEAT_VMX_PINBASED_CTLS] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- "vmx-intr-exit", NULL, NULL, "vmx-nmi-exit",
- NULL, "vmx-vnmi", "vmx-preemption-timer", "vmx-posted-intr",
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .msr = {
- .index = MSR_IA32_VMX_TRUE_PINBASED_CTLS,
- }
- },
- [FEAT_VMX_EXIT_CTLS] = {
- .type = MSR_FEATURE_WORD,
- /*
- * VMX_VM_EXIT_HOST_ADDR_SPACE_SIZE is copied from
- * the LM CPUID bit.
- */
- .feat_names = {
- NULL, NULL, "vmx-exit-nosave-debugctl", NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL /* vmx-exit-host-addr-space-size */, NULL, NULL,
- "vmx-exit-load-perf-global-ctrl", NULL, NULL, "vmx-exit-ack-intr",
- NULL, NULL, "vmx-exit-save-pat", "vmx-exit-load-pat",
- "vmx-exit-save-efer", "vmx-exit-load-efer",
- "vmx-exit-save-preemption-timer", "vmx-exit-clear-bndcfgs",
- NULL, "vmx-exit-clear-rtit-ctl", NULL, NULL,
- NULL, "vmx-exit-load-pkrs", NULL, "vmx-exit-secondary-ctls",
- },
- .msr = {
- .index = MSR_IA32_VMX_TRUE_EXIT_CTLS,
- }
- },
- [FEAT_VMX_ENTRY_CTLS] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, "vmx-entry-noload-debugctl", NULL,
- NULL, NULL, NULL, NULL,
- NULL, "vmx-entry-ia32e-mode", NULL, NULL,
- NULL, "vmx-entry-load-perf-global-ctrl", "vmx-entry-load-pat", "vmx-entry-load-efer",
- "vmx-entry-load-bndcfgs", NULL, "vmx-entry-load-rtit-ctl", NULL,
- NULL, NULL, "vmx-entry-load-pkrs", "vmx-entry-load-fred",
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .msr = {
- .index = MSR_IA32_VMX_TRUE_ENTRY_CTLS,
- }
- },
- [FEAT_VMX_MISC] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- NULL, "vmx-store-lma", "vmx-activity-hlt", "vmx-activity-shutdown",
- "vmx-activity-wait-sipi", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, "vmx-vmwrite-vmexit-fields", "vmx-zero-len-inject", NULL,
- },
- .msr = {
- .index = MSR_IA32_VMX_MISC,
- }
- },
- [FEAT_VMX_EPT_VPID_CAPS] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- "vmx-ept-execonly", NULL, NULL, NULL,
- NULL, NULL, "vmx-page-walk-4", "vmx-page-walk-5",
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- "vmx-ept-2mb", "vmx-ept-1gb", NULL, NULL,
- "vmx-invept", "vmx-eptad", "vmx-ept-advanced-exitinfo", NULL,
- NULL, "vmx-invept-single-context", "vmx-invept-all-context", NULL,
- NULL, NULL, NULL, NULL,
- "vmx-invvpid", NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- "vmx-invvpid-single-addr", "vmx-invept-single-context",
- "vmx-invvpid-all-context", "vmx-invept-single-context-noglobals",
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .msr = {
- .index = MSR_IA32_VMX_EPT_VPID_CAP,
- }
- },
- [FEAT_VMX_BASIC] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- [54] = "vmx-ins-outs",
- [55] = "vmx-true-ctls",
- [56] = "vmx-any-errcode",
- [58] = "vmx-nested-exception",
- },
- .msr = {
- .index = MSR_IA32_VMX_BASIC,
- },
- /* Just to be safe - we don't support setting the MSEG version field. */
- .no_autoenable_flags = MSR_VMX_BASIC_DUAL_MONITOR,
- },
- [FEAT_VMX_VMFUNC] = {
- .type = MSR_FEATURE_WORD,
- .feat_names = {
- [0] = "vmx-eptp-switching",
- },
- .msr = {
- .index = MSR_IA32_VMX_VMFUNC,
- }
- },
- [FEAT_14_0_ECX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, "intel-pt-lip",
- },
- .cpuid = {
- .eax = 0x14,
- .needs_ecx = true, .ecx = 0,
- .reg = R_ECX,
- },
- .tcg_features = TCG_14_0_ECX_FEATURES,
- },
- [FEAT_SGX_12_0_EAX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "sgx1", "sgx2", NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, "sgx-edeccssa",
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 0x12,
- .needs_ecx = true, .ecx = 0,
- .reg = R_EAX,
- },
- .tcg_features = TCG_SGX_12_0_EAX_FEATURES,
- },
- [FEAT_SGX_12_0_EBX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- "sgx-exinfo" , NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 0x12,
- .needs_ecx = true, .ecx = 0,
- .reg = R_EBX,
- },
- .tcg_features = TCG_SGX_12_0_EBX_FEATURES,
- },
- [FEAT_SGX_12_1_EAX] = {
- .type = CPUID_FEATURE_WORD,
- .feat_names = {
- NULL, "sgx-debug", "sgx-mode64", NULL,
- "sgx-provisionkey", "sgx-tokenkey", NULL, "sgx-kss",
- NULL, NULL, "sgx-aex-notify", NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL,
- },
- .cpuid = {
- .eax = 0x12,
- .needs_ecx = true, .ecx = 1,
- .reg = R_EAX,
- },
- .tcg_features = TCG_SGX_12_1_EAX_FEATURES,
- },
- };
- typedef struct FeatureMask {
- FeatureWord index;
- uint64_t mask;
- } FeatureMask;
- typedef struct FeatureDep {
- FeatureMask from, to;
- } FeatureDep;
- static FeatureDep feature_dependencies[] = {
- {
- .from = { FEAT_7_0_EDX, CPUID_7_0_EDX_ARCH_CAPABILITIES },
- .to = { FEAT_ARCH_CAPABILITIES, ~0ull },
- },
- {
- .from = { FEAT_7_0_EDX, CPUID_7_0_EDX_CORE_CAPABILITY },
- .to = { FEAT_CORE_CAPABILITY, ~0ull },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_PDCM },
- .to = { FEAT_PERF_CAPABILITIES, ~0ull },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_VMX },
- .to = { FEAT_VMX_PROCBASED_CTLS, ~0ull },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_VMX },
- .to = { FEAT_VMX_PINBASED_CTLS, ~0ull },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_VMX },
- .to = { FEAT_VMX_EXIT_CTLS, ~0ull },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_VMX },
- .to = { FEAT_VMX_ENTRY_CTLS, ~0ull },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_VMX },
- .to = { FEAT_VMX_MISC, ~0ull },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_VMX },
- .to = { FEAT_VMX_BASIC, ~0ull },
- },
- {
- .from = { FEAT_8000_0001_EDX, CPUID_EXT2_LM },
- .to = { FEAT_VMX_ENTRY_CTLS, VMX_VM_ENTRY_IA32E_MODE },
- },
- {
- .from = { FEAT_VMX_PROCBASED_CTLS, VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS },
- .to = { FEAT_VMX_SECONDARY_CTLS, ~0ull },
- },
- {
- .from = { FEAT_XSAVE, CPUID_XSAVE_XSAVES },
- .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_XSAVES },
- },
- {
- .from = { FEAT_1_ECX, CPUID_EXT_RDRAND },
- .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDRAND_EXITING },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_INVPCID },
- .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_INVPCID },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_MPX },
- .to = { FEAT_VMX_EXIT_CTLS, VMX_VM_EXIT_CLEAR_BNDCFGS },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_MPX },
- .to = { FEAT_VMX_ENTRY_CTLS, VMX_VM_ENTRY_LOAD_BNDCFGS },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_RDSEED },
- .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDSEED_EXITING },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_INTEL_PT },
- .to = { FEAT_14_0_ECX, ~0ull },
- },
- {
- .from = { FEAT_8000_0001_EDX, CPUID_EXT2_RDTSCP },
- .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDTSCP },
- },
- {
- .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_EPT },
- .to = { FEAT_VMX_EPT_VPID_CAPS, 0xffffffffull },
- },
- {
- .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_EPT },
- .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST },
- },
- {
- .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_VPID },
- .to = { FEAT_VMX_EPT_VPID_CAPS, 0xffffffffull << 32 },
- },
- {
- .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_VMFUNC },
- .to = { FEAT_VMX_VMFUNC, ~0ull },
- },
- {
- .from = { FEAT_8000_0001_ECX, CPUID_EXT3_SVM },
- .to = { FEAT_SVM, ~0ull },
- },
- {
- .from = { FEAT_7_0_ECX, CPUID_7_0_ECX_WAITPKG },
- .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_USER_WAIT_PAUSE },
- },
- {
- .from = { FEAT_8000_0001_EDX, CPUID_EXT2_LM },
- .to = { FEAT_7_1_EAX, CPUID_7_1_EAX_FRED },
- },
- {
- .from = { FEAT_7_1_EAX, CPUID_7_1_EAX_LKGS },
- .to = { FEAT_7_1_EAX, CPUID_7_1_EAX_FRED },
- },
- {
- .from = { FEAT_7_1_EAX, CPUID_7_1_EAX_WRMSRNS },
- .to = { FEAT_7_1_EAX, CPUID_7_1_EAX_FRED },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
- .to = { FEAT_7_0_ECX, CPUID_7_0_ECX_SGX_LC },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
- .to = { FEAT_SGX_12_0_EAX, ~0ull },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
- .to = { FEAT_SGX_12_0_EBX, ~0ull },
- },
- {
- .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
- .to = { FEAT_SGX_12_1_EAX, ~0ull },
- },
- };
- typedef struct X86RegisterInfo32 {
- /* Name of register */
- const char *name;
- /* QAPI enum value register */
- X86CPURegister32 qapi_enum;
- } X86RegisterInfo32;
- #define REGISTER(reg) \
- [R_##reg] = { .name = #reg, .qapi_enum = X86_CPU_REGISTER32_##reg }
- static const X86RegisterInfo32 x86_reg_info_32[CPU_NB_REGS32] = {
- REGISTER(EAX),
- REGISTER(ECX),
- REGISTER(EDX),
- REGISTER(EBX),
- REGISTER(ESP),
- REGISTER(EBP),
- REGISTER(ESI),
- REGISTER(EDI),
- };
- #undef REGISTER
- /* CPUID feature bits available in XSS */
- #define CPUID_XSTATE_XSS_MASK (XSTATE_ARCH_LBR_MASK)
- ExtSaveArea x86_ext_save_areas[XSAVE_STATE_AREA_COUNT] = {
- [XSTATE_FP_BIT] = {
- /* x87 FP state component is always enabled if XSAVE is supported */
- .feature = FEAT_1_ECX, .bits = CPUID_EXT_XSAVE,
- .size = sizeof(X86LegacyXSaveArea) + sizeof(X86XSaveHeader),
- },
- [XSTATE_SSE_BIT] = {
- /* SSE state component is always enabled if XSAVE is supported */
- .feature = FEAT_1_ECX, .bits = CPUID_EXT_XSAVE,
- .size = sizeof(X86LegacyXSaveArea) + sizeof(X86XSaveHeader),
- },
- [XSTATE_YMM_BIT] =
- { .feature = FEAT_1_ECX, .bits = CPUID_EXT_AVX,
- .size = sizeof(XSaveAVX) },
- [XSTATE_BNDREGS_BIT] =
- { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_MPX,
- .size = sizeof(XSaveBNDREG) },
- [XSTATE_BNDCSR_BIT] =
- { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_MPX,
- .size = sizeof(XSaveBNDCSR) },
- [XSTATE_OPMASK_BIT] =
- { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
- .size = sizeof(XSaveOpmask) },
- [XSTATE_ZMM_Hi256_BIT] =
- { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
- .size = sizeof(XSaveZMM_Hi256) },
- [XSTATE_Hi16_ZMM_BIT] =
- { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
- .size = sizeof(XSaveHi16_ZMM) },
- [XSTATE_PKRU_BIT] =
- { .feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_PKU,
- .size = sizeof(XSavePKRU) },
- [XSTATE_ARCH_LBR_BIT] = {
- .feature = FEAT_7_0_EDX, .bits = CPUID_7_0_EDX_ARCH_LBR,
- .offset = 0 /*supervisor mode component, offset = 0 */,
- .size = sizeof(XSavesArchLBR) },
- [XSTATE_XTILE_CFG_BIT] = {
- .feature = FEAT_7_0_EDX, .bits = CPUID_7_0_EDX_AMX_TILE,
- .size = sizeof(XSaveXTILECFG),
- },
- [XSTATE_XTILE_DATA_BIT] = {
- .feature = FEAT_7_0_EDX, .bits = CPUID_7_0_EDX_AMX_TILE,
- .size = sizeof(XSaveXTILEDATA)
- },
- };
- uint32_t xsave_area_size(uint64_t mask, bool compacted)
- {
- uint64_t ret = x86_ext_save_areas[0].size;
- const ExtSaveArea *esa;
- uint32_t offset = 0;
- int i;
- for (i = 2; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
- esa = &x86_ext_save_areas[i];
- if ((mask >> i) & 1) {
- offset = compacted ? ret : esa->offset;
- ret = MAX(ret, offset + esa->size);
- }
- }
- return ret;
- }
- static inline bool accel_uses_host_cpuid(void)
- {
- return kvm_enabled() || hvf_enabled();
- }
- static inline uint64_t x86_cpu_xsave_xcr0_components(X86CPU *cpu)
- {
- return ((uint64_t)cpu->env.features[FEAT_XSAVE_XCR0_HI]) << 32 |
- cpu->env.features[FEAT_XSAVE_XCR0_LO];
- }
- /* Return name of 32-bit register, from a R_* constant */
- static const char *get_register_name_32(unsigned int reg)
- {
- if (reg >= CPU_NB_REGS32) {
- return NULL;
- }
- return x86_reg_info_32[reg].name;
- }
- static inline uint64_t x86_cpu_xsave_xss_components(X86CPU *cpu)
- {
- return ((uint64_t)cpu->env.features[FEAT_XSAVE_XSS_HI]) << 32 |
- cpu->env.features[FEAT_XSAVE_XSS_LO];
- }
- /*
- * Returns the set of feature flags that are supported and migratable by
- * QEMU, for a given FeatureWord.
- */
- static uint64_t x86_cpu_get_migratable_flags(FeatureWord w)
- {
- FeatureWordInfo *wi = &feature_word_info[w];
- uint64_t r = 0;
- int i;
- for (i = 0; i < 64; i++) {
- uint64_t f = 1ULL << i;
- /* If the feature name is known, it is implicitly considered migratable,
- * unless it is explicitly set in unmigratable_flags */
- if ((wi->migratable_flags & f) ||
- (wi->feat_names[i] && !(wi->unmigratable_flags & f))) {
- r |= f;
- }
- }
- return r;
- }
- void host_cpuid(uint32_t function, uint32_t count,
- uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx)
- {
- uint32_t vec[4];
- #ifdef __x86_64__
- asm volatile("cpuid"
- : "=a"(vec[0]), "=b"(vec[1]),
- "=c"(vec[2]), "=d"(vec[3])
- : "0"(function), "c"(count) : "cc");
- #elif defined(__i386__)
- asm volatile("pusha \n\t"
- "cpuid \n\t"
- "mov %%eax, 0(%2) \n\t"
- "mov %%ebx, 4(%2) \n\t"
- "mov %%ecx, 8(%2) \n\t"
- "mov %%edx, 12(%2) \n\t"
- "popa"
- : : "a"(function), "c"(count), "S"(vec)
- : "memory", "cc");
- #else
- abort();
- #endif
- if (eax)
- *eax = vec[0];
- if (ebx)
- *ebx = vec[1];
- if (ecx)
- *ecx = vec[2];
- if (edx)
- *edx = vec[3];
- }
- /* CPU class name definitions: */
- /* Return type name for a given CPU model name
- * Caller is responsible for freeing the returned string.
- */
- static char *x86_cpu_type_name(const char *model_name)
- {
- return g_strdup_printf(X86_CPU_TYPE_NAME("%s"), model_name);
- }
- static ObjectClass *x86_cpu_class_by_name(const char *cpu_model)
- {
- g_autofree char *typename = x86_cpu_type_name(cpu_model);
- return object_class_by_name(typename);
- }
- static char *x86_cpu_class_get_model_name(X86CPUClass *cc)
- {
- const char *class_name = object_class_get_name(OBJECT_CLASS(cc));
- assert(g_str_has_suffix(class_name, X86_CPU_TYPE_SUFFIX));
- return cpu_model_from_type(class_name);
- }
- typedef struct X86CPUVersionDefinition {
- X86CPUVersion version;
- const char *alias;
- const char *note;
- PropValue *props;
- const CPUCaches *const cache_info;
- } X86CPUVersionDefinition;
- /* Base definition for a CPU model */
- typedef struct X86CPUDefinition {
- const char *name;
- uint32_t level;
- uint32_t xlevel;
- /* vendor is zero-terminated, 12 character ASCII string */
- char vendor[CPUID_VENDOR_SZ + 1];
- int family;
- int model;
- int stepping;
- FeatureWordArray features;
- const char *model_id;
- const CPUCaches *const cache_info;
- /*
- * Definitions for alternative versions of CPU model.
- * List is terminated by item with version == 0.
- * If NULL, version 1 will be registered automatically.
- */
- const X86CPUVersionDefinition *versions;
- const char *deprecation_note;
- } X86CPUDefinition;
- /* Reference to a specific CPU model version */
- struct X86CPUModel {
- /* Base CPU definition */
- const X86CPUDefinition *cpudef;
- /* CPU model version */
- X86CPUVersion version;
- const char *note;
- /*
- * If true, this is an alias CPU model.
- * This matters only for "-cpu help" and query-cpu-definitions
- */
- bool is_alias;
- };
- /* Get full model name for CPU version */
- static char *x86_cpu_versioned_model_name(const X86CPUDefinition *cpudef,
- X86CPUVersion version)
- {
- assert(version > 0);
- return g_strdup_printf("%s-v%d", cpudef->name, (int)version);
- }
- static const X86CPUVersionDefinition *
- x86_cpu_def_get_versions(const X86CPUDefinition *def)
- {
- /* When X86CPUDefinition::versions is NULL, we register only v1 */
- static const X86CPUVersionDefinition default_version_list[] = {
- { 1 },
- { /* end of list */ }
- };
- return def->versions ?: default_version_list;
- }
- static const CPUCaches epyc_cache_info = {
- .l1d_cache = &(CPUCacheInfo) {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l1i_cache = &(CPUCacheInfo) {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 64 * KiB,
- .line_size = 64,
- .associativity = 4,
- .partitions = 1,
- .sets = 256,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l2_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 512 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 1024,
- .lines_per_tag = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l3_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 8 * MiB,
- .line_size = 64,
- .associativity = 16,
- .partitions = 1,
- .sets = 8192,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = true,
- .share_level = CPU_TOPO_LEVEL_DIE,
- },
- };
- static CPUCaches epyc_v4_cache_info = {
- .l1d_cache = &(CPUCacheInfo) {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l1i_cache = &(CPUCacheInfo) {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 64 * KiB,
- .line_size = 64,
- .associativity = 4,
- .partitions = 1,
- .sets = 256,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l2_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 512 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 1024,
- .lines_per_tag = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l3_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 8 * MiB,
- .line_size = 64,
- .associativity = 16,
- .partitions = 1,
- .sets = 8192,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = false,
- .share_level = CPU_TOPO_LEVEL_DIE,
- },
- };
- static const CPUCaches epyc_rome_cache_info = {
- .l1d_cache = &(CPUCacheInfo) {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l1i_cache = &(CPUCacheInfo) {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l2_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 512 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 1024,
- .lines_per_tag = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l3_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 16 * MiB,
- .line_size = 64,
- .associativity = 16,
- .partitions = 1,
- .sets = 16384,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = true,
- .share_level = CPU_TOPO_LEVEL_DIE,
- },
- };
- static const CPUCaches epyc_rome_v3_cache_info = {
- .l1d_cache = &(CPUCacheInfo) {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l1i_cache = &(CPUCacheInfo) {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l2_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 512 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 1024,
- .lines_per_tag = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l3_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 16 * MiB,
- .line_size = 64,
- .associativity = 16,
- .partitions = 1,
- .sets = 16384,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = false,
- .share_level = CPU_TOPO_LEVEL_DIE,
- },
- };
- static const CPUCaches epyc_milan_cache_info = {
- .l1d_cache = &(CPUCacheInfo) {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l1i_cache = &(CPUCacheInfo) {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l2_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 512 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 1024,
- .lines_per_tag = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l3_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 32 * MiB,
- .line_size = 64,
- .associativity = 16,
- .partitions = 1,
- .sets = 32768,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = true,
- .share_level = CPU_TOPO_LEVEL_DIE,
- },
- };
- static const CPUCaches epyc_milan_v2_cache_info = {
- .l1d_cache = &(CPUCacheInfo) {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l1i_cache = &(CPUCacheInfo) {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l2_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 512 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 1024,
- .lines_per_tag = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l3_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 32 * MiB,
- .line_size = 64,
- .associativity = 16,
- .partitions = 1,
- .sets = 32768,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = false,
- .share_level = CPU_TOPO_LEVEL_DIE,
- },
- };
- static const CPUCaches epyc_genoa_cache_info = {
- .l1d_cache = &(CPUCacheInfo) {
- .type = DATA_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l1i_cache = &(CPUCacheInfo) {
- .type = INSTRUCTION_CACHE,
- .level = 1,
- .size = 32 * KiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 64,
- .lines_per_tag = 1,
- .self_init = 1,
- .no_invd_sharing = true,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l2_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 2,
- .size = 1 * MiB,
- .line_size = 64,
- .associativity = 8,
- .partitions = 1,
- .sets = 2048,
- .lines_per_tag = 1,
- .share_level = CPU_TOPO_LEVEL_CORE,
- },
- .l3_cache = &(CPUCacheInfo) {
- .type = UNIFIED_CACHE,
- .level = 3,
- .size = 32 * MiB,
- .line_size = 64,
- .associativity = 16,
- .partitions = 1,
- .sets = 32768,
- .lines_per_tag = 1,
- .self_init = true,
- .inclusive = true,
- .complex_indexing = false,
- .share_level = CPU_TOPO_LEVEL_DIE,
- },
- };
- /* The following VMX features are not supported by KVM and are left out in the
- * CPU definitions:
- *
- * Dual-monitor support (all processors)
- * Entry to SMM
- * Deactivate dual-monitor treatment
- * Number of CR3-target values
- * Shutdown activity state
- * Wait-for-SIPI activity state
- * PAUSE-loop exiting (Westmere and newer)
- * EPT-violation #VE (Broadwell and newer)
- * Inject event with insn length=0 (Skylake and newer)
- * Conceal non-root operation from PT
- * Conceal VM exits from PT
- * Conceal VM entries from PT
- * Enable ENCLS exiting
- * Mode-based execute control (XS/XU)
- * TSC scaling (Skylake Server and newer)
- * GPA translation for PT (IceLake and newer)
- * User wait and pause
- * ENCLV exiting
- * Load IA32_RTIT_CTL
- * Clear IA32_RTIT_CTL
- * Advanced VM-exit information for EPT violations
- * Sub-page write permissions
- * PT in VMX operation
- */
- static const X86CPUDefinition builtin_x86_defs[] = {
- {
- .name = "qemu64",
- .level = 0xd,
- .vendor = CPUID_VENDOR_AMD,
- .family = 15,
- .model = 107,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- PPRO_FEATURES |
- CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
- CPUID_PSE36,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_CX16,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM,
- .xlevel = 0x8000000A,
- .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
- },
- {
- .name = "phenom",
- .level = 5,
- .vendor = CPUID_VENDOR_AMD,
- .family = 16,
- .model = 2,
- .stepping = 3,
- /* Missing: CPUID_HT */
- .features[FEAT_1_EDX] =
- PPRO_FEATURES |
- CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
- CPUID_PSE36 | CPUID_VME,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_CX16 |
- CPUID_EXT_POPCNT,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX |
- CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT | CPUID_EXT2_MMXEXT |
- CPUID_EXT2_FFXSR | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP,
- /* Missing: CPUID_EXT3_CMP_LEG, CPUID_EXT3_EXTAPIC,
- CPUID_EXT3_CR8LEG,
- CPUID_EXT3_MISALIGNSSE, CPUID_EXT3_3DNOWPREFETCH,
- CPUID_EXT3_OSVW, CPUID_EXT3_IBS */
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM |
- CPUID_EXT3_ABM | CPUID_EXT3_SSE4A,
- /* Missing: CPUID_SVM_LBRV */
- .features[FEAT_SVM] =
- CPUID_SVM_NPT,
- .xlevel = 0x8000001A,
- .model_id = "AMD Phenom(tm) 9550 Quad-Core Processor"
- },
- {
- .name = "core2duo",
- .level = 10,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 15,
- .stepping = 11,
- /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
- .features[FEAT_1_EDX] =
- PPRO_FEATURES |
- CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
- CPUID_PSE36 | CPUID_VME | CPUID_ACPI | CPUID_SS,
- /* Missing: CPUID_EXT_DTES64, CPUID_EXT_DSCPL, CPUID_EXT_EST,
- * CPUID_EXT_TM2, CPUID_EXT_XTPR, CPUID_EXT_PDCM, CPUID_EXT_VMX */
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 |
- CPUID_EXT_CX16,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
- .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES,
- .xlevel = 0x80000008,
- .model_id = "Intel(R) Core(TM)2 Duo CPU T7700 @ 2.40GHz",
- },
- {
- .name = "kvm64",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 15,
- .model = 6,
- .stepping = 1,
- /* Missing: CPUID_HT */
- .features[FEAT_1_EDX] =
- PPRO_FEATURES | CPUID_VME |
- CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
- CPUID_PSE36,
- /* Missing: CPUID_EXT_POPCNT, CPUID_EXT_MONITOR */
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_CX16,
- /* Missing: CPUID_EXT2_PDPE1GB, CPUID_EXT2_RDTSCP */
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
- /* Missing: CPUID_EXT3_LAHF_LM, CPUID_EXT3_CMP_LEG, CPUID_EXT3_EXTAPIC,
- CPUID_EXT3_CR8LEG, CPUID_EXT3_ABM, CPUID_EXT3_SSE4A,
- CPUID_EXT3_MISALIGNSSE, CPUID_EXT3_3DNOWPREFETCH,
- CPUID_EXT3_OSVW, CPUID_EXT3_IBS, CPUID_EXT3_SVM */
- .features[FEAT_8000_0001_ECX] =
- 0,
- /* VMX features from Cedar Mill/Prescott */
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
- .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING,
- .xlevel = 0x80000008,
- .model_id = "Common KVM processor"
- },
- {
- .name = "qemu32",
- .level = 4,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 6,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- PPRO_FEATURES,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3,
- .xlevel = 0x80000004,
- .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
- },
- {
- .name = "kvm32",
- .level = 5,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 15,
- .model = 6,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- PPRO_FEATURES | CPUID_VME |
- CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_PSE36,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_ECX] =
- 0,
- /* VMX features from Yonah */
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
- .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
- VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
- VMX_CPU_BASED_PAUSE_EXITING | VMX_CPU_BASED_USE_MSR_BITMAPS,
- .xlevel = 0x80000008,
- .model_id = "Common 32-bit KVM processor"
- },
- {
- .name = "coreduo",
- .level = 10,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 14,
- .stepping = 8,
- /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
- .features[FEAT_1_EDX] =
- PPRO_FEATURES | CPUID_VME |
- CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_ACPI |
- CPUID_SS,
- /* Missing: CPUID_EXT_EST, CPUID_EXT_TM2 , CPUID_EXT_XTPR,
- * CPUID_EXT_PDCM, CPUID_EXT_VMX */
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_MONITOR,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_NX,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
- .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
- VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
- VMX_CPU_BASED_PAUSE_EXITING | VMX_CPU_BASED_USE_MSR_BITMAPS,
- .xlevel = 0x80000008,
- .model_id = "Genuine Intel(R) CPU T2600 @ 2.16GHz",
- },
- {
- .name = "486",
- .level = 1,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 4,
- .model = 8,
- .stepping = 0,
- .features[FEAT_1_EDX] =
- I486_FEATURES,
- .xlevel = 0,
- .model_id = "",
- },
- {
- .name = "pentium",
- .level = 1,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 5,
- .model = 4,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- PENTIUM_FEATURES,
- .xlevel = 0,
- .model_id = "",
- },
- {
- .name = "pentium2",
- .level = 2,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 5,
- .stepping = 2,
- .features[FEAT_1_EDX] =
- PENTIUM2_FEATURES,
- .xlevel = 0,
- .model_id = "",
- },
- {
- .name = "pentium3",
- .level = 3,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 7,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- PENTIUM3_FEATURES,
- .xlevel = 0,
- .model_id = "",
- },
- {
- .name = "athlon",
- .level = 2,
- .vendor = CPUID_VENDOR_AMD,
- .family = 6,
- .model = 2,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- PPRO_FEATURES | CPUID_PSE36 | CPUID_VME | CPUID_MTRR |
- CPUID_MCA,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_MMXEXT | CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT,
- .xlevel = 0x80000008,
- .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
- },
- {
- .name = "n270",
- .level = 10,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 28,
- .stepping = 2,
- /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
- .features[FEAT_1_EDX] =
- PPRO_FEATURES |
- CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_VME |
- CPUID_ACPI | CPUID_SS,
- /* Some CPUs got no CPUID_SEP */
- /* Missing: CPUID_EXT_DSCPL, CPUID_EXT_EST, CPUID_EXT_TM2,
- * CPUID_EXT_XTPR */
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 |
- CPUID_EXT_MOVBE,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_NX,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .xlevel = 0x80000008,
- .model_id = "Intel(R) Atom(TM) CPU N270 @ 1.60GHz",
- },
- {
- .name = "Conroe",
- .level = 10,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 15,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSSE3 | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
- .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES,
- .xlevel = 0x80000008,
- .model_id = "Intel Celeron_4x0 (Conroe/Merom Class Core 2)",
- },
- {
- .name = "Penryn",
- .level = 10,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 23,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL,
- .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING,
- .xlevel = 0x80000008,
- .model_id = "Intel Core 2 Duo P9xxx (Penryn Class Core 2)",
- },
- {
- .name = "Nehalem",
- .level = 11,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 26,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_POPCNT | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID,
- .xlevel = 0x80000008,
- .model_id = "Intel Core i7 9xx (Nehalem Class Core i7)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "Nehalem-IBRS",
- .props = (PropValue[]) {
- { "spec-ctrl", "on" },
- { "model-id",
- "Intel Core i7 9xx (Nehalem Core i7, IBRS update)" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Westmere",
- .level = 11,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 44,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AES | CPUID_EXT_POPCNT | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST,
- .xlevel = 0x80000008,
- .model_id = "Westmere E56xx/L56xx/X56xx (Nehalem-C)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "Westmere-IBRS",
- .props = (PropValue[]) {
- { "spec-ctrl", "on" },
- { "model-id",
- "Westmere E56xx/L56xx/X56xx (IBRS update)" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "SandyBridge",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 42,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_POPCNT |
- CPUID_EXT_X2APIC | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
- CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon E312xx (Sandy Bridge)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "SandyBridge-IBRS",
- .props = (PropValue[]) {
- { "spec-ctrl", "on" },
- { "model-id",
- "Intel Xeon E312xx (Sandy Bridge, IBRS update)" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "IvyBridge",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 58,
- .stepping = 9,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_POPCNT |
- CPUID_EXT_X2APIC | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
- CPUID_EXT_SSE3 | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_ERMS,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon E3-12xx v2 (Ivy Bridge)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "IvyBridge-IBRS",
- .props = (PropValue[]) {
- { "spec-ctrl", "on" },
- { "model-id",
- "Intel Xeon E3-12xx v2 (Ivy Bridge, IBRS)" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Haswell",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 60,
- .stepping = 4,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
- CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
- CPUID_7_0_EBX_RTM,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS,
- .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Core Processor (Haswell)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "Haswell-noTSX",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- { "stepping", "1" },
- { "model-id", "Intel Core Processor (Haswell, no TSX)", },
- { /* end of list */ }
- },
- },
- {
- .version = 3,
- .alias = "Haswell-IBRS",
- .props = (PropValue[]) {
- /* Restore TSX features removed by -v2 above */
- { "hle", "on" },
- { "rtm", "on" },
- /*
- * Haswell and Haswell-IBRS had stepping=4 in
- * QEMU 4.0 and older
- */
- { "stepping", "4" },
- { "spec-ctrl", "on" },
- { "model-id",
- "Intel Core Processor (Haswell, IBRS)" },
- { /* end of list */ }
- }
- },
- {
- .version = 4,
- .alias = "Haswell-noTSX-IBRS",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- /* spec-ctrl was already enabled by -v3 above */
- { "stepping", "1" },
- { "model-id",
- "Intel Core Processor (Haswell, no TSX, IBRS)" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Broadwell",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 61,
- .stepping = 2,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
- CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
- CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
- .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Core Processor (Broadwell)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "Broadwell-noTSX",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- { "model-id", "Intel Core Processor (Broadwell, no TSX)", },
- { /* end of list */ }
- },
- },
- {
- .version = 3,
- .alias = "Broadwell-IBRS",
- .props = (PropValue[]) {
- /* Restore TSX features removed by -v2 above */
- { "hle", "on" },
- { "rtm", "on" },
- { "spec-ctrl", "on" },
- { "model-id",
- "Intel Core Processor (Broadwell, IBRS)" },
- { /* end of list */ }
- }
- },
- {
- .version = 4,
- .alias = "Broadwell-noTSX-IBRS",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- /* spec-ctrl was already enabled by -v3 above */
- { "model-id",
- "Intel Core Processor (Broadwell, no TSX, IBRS)" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Skylake-Client",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 94,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
- CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
- CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP,
- /* XSAVES is added in version 4 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
- .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Core Processor (Skylake)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "Skylake-Client-IBRS",
- .props = (PropValue[]) {
- { "spec-ctrl", "on" },
- { "model-id",
- "Intel Core Processor (Skylake, IBRS)" },
- { /* end of list */ }
- }
- },
- {
- .version = 3,
- .alias = "Skylake-Client-noTSX-IBRS",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- { "model-id",
- "Intel Core Processor (Skylake, IBRS, no TSX)" },
- { /* end of list */ }
- }
- },
- {
- .version = 4,
- .note = "IBRS, XSAVES, no TSX",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { "vmx-xsaves", "on" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Skylake-Server",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 85,
- .stepping = 4,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
- CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
- CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
- CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
- CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
- CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
- CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_PKU,
- /* XSAVES is added in version 5 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Processor (Skylake)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "Skylake-Server-IBRS",
- .props = (PropValue[]) {
- /* clflushopt was not added to Skylake-Server-IBRS */
- /* TODO: add -v3 including clflushopt */
- { "clflushopt", "off" },
- { "spec-ctrl", "on" },
- { "model-id",
- "Intel Xeon Processor (Skylake, IBRS)" },
- { /* end of list */ }
- }
- },
- {
- .version = 3,
- .alias = "Skylake-Server-noTSX-IBRS",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- { "model-id",
- "Intel Xeon Processor (Skylake, IBRS, no TSX)" },
- { /* end of list */ }
- }
- },
- {
- .version = 4,
- .props = (PropValue[]) {
- { "vmx-eptp-switching", "on" },
- { /* end of list */ }
- }
- },
- {
- .version = 5,
- .note = "IBRS, XSAVES, EPT switching, no TSX",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { "vmx-xsaves", "on" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Cascadelake-Server",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 85,
- .stepping = 6,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
- CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
- CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
- CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
- CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
- CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
- CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_PKU |
- CPUID_7_0_ECX_AVX512VNNI,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
- /* XSAVES is added in version 5 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Processor (Cascadelake)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- { .version = 2,
- .note = "ARCH_CAPABILITIES",
- .props = (PropValue[]) {
- { "arch-capabilities", "on" },
- { "rdctl-no", "on" },
- { "ibrs-all", "on" },
- { "skip-l1dfl-vmentry", "on" },
- { "mds-no", "on" },
- { /* end of list */ }
- },
- },
- { .version = 3,
- .alias = "Cascadelake-Server-noTSX",
- .note = "ARCH_CAPABILITIES, no TSX",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- { /* end of list */ }
- },
- },
- { .version = 4,
- .note = "ARCH_CAPABILITIES, no TSX",
- .props = (PropValue[]) {
- { "vmx-eptp-switching", "on" },
- { /* end of list */ }
- },
- },
- { .version = 5,
- .note = "ARCH_CAPABILITIES, EPT switching, XSAVES, no TSX",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { "vmx-xsaves", "on" },
- { /* end of list */ }
- },
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Cooperlake",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 85,
- .stepping = 10,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
- CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
- CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
- CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
- CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
- CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
- CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_PKU |
- CPUID_7_0_ECX_AVX512VNNI,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_STIBP |
- CPUID_7_0_EDX_SPEC_CTRL_SSBD | CPUID_7_0_EDX_ARCH_CAPABILITIES,
- .features[FEAT_ARCH_CAPABILITIES] =
- MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
- MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
- MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_TAA_NO,
- .features[FEAT_7_1_EAX] =
- CPUID_7_1_EAX_AVX512_BF16,
- /* XSAVES is added in version 2 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
- .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Processor (Cooperlake)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- { .version = 2,
- .note = "XSAVES",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { "vmx-xsaves", "on" },
- { /* end of list */ }
- },
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Icelake-Server",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 134,
- .stepping = 0,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
- CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_WBNOINVD,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
- CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
- CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
- CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
- CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
- CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
- CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
- CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
- CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
- CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
- /* XSAVES is added in version 5 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Processor (Icelake)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .note = "no TSX",
- .alias = "Icelake-Server-noTSX",
- .props = (PropValue[]) {
- { "hle", "off" },
- { "rtm", "off" },
- { /* end of list */ }
- },
- },
- {
- .version = 3,
- .props = (PropValue[]) {
- { "arch-capabilities", "on" },
- { "rdctl-no", "on" },
- { "ibrs-all", "on" },
- { "skip-l1dfl-vmentry", "on" },
- { "mds-no", "on" },
- { "pschange-mc-no", "on" },
- { "taa-no", "on" },
- { /* end of list */ }
- },
- },
- {
- .version = 4,
- .props = (PropValue[]) {
- { "sha-ni", "on" },
- { "avx512ifma", "on" },
- { "rdpid", "on" },
- { "fsrm", "on" },
- { "vmx-rdseed-exit", "on" },
- { "vmx-pml", "on" },
- { "vmx-eptp-switching", "on" },
- { "model", "106" },
- { /* end of list */ }
- },
- },
- {
- .version = 5,
- .note = "XSAVES",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { "vmx-xsaves", "on" },
- { /* end of list */ }
- },
- },
- {
- .version = 6,
- .note = "5-level EPT",
- .props = (PropValue[]) {
- { "vmx-page-walk-5", "on" },
- { /* end of list */ }
- },
- },
- {
- .version = 7,
- .note = "TSX, taa-no",
- .props = (PropValue[]) {
- /* Restore TSX features removed by -v2 above */
- { "hle", "on" },
- { "rtm", "on" },
- { /* end of list */ }
- },
- },
- { /* end of list */ }
- }
- },
- {
- .name = "SapphireRapids",
- .level = 0x20,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 143,
- .stepping = 4,
- /*
- * please keep the ascending order so that we can have a clear view of
- * bit position of each feature.
- */
- .features[FEAT_1_EDX] =
- CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
- CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
- CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
- CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
- CPUID_SSE | CPUID_SSE2,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSSE3 |
- CPUID_EXT_FMA | CPUID_EXT_CX16 | CPUID_EXT_PCID | CPUID_EXT_SSE41 |
- CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
- CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES |
- CPUID_EXT_XSAVE | CPUID_EXT_AVX | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM | CPUID_EXT3_ABM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_WBNOINVD,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_HLE |
- CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 |
- CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_RTM |
- CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
- CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP |
- CPUID_7_0_EBX_AVX512IFMA | CPUID_7_0_EBX_CLFLUSHOPT |
- CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_SHA_NI |
- CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512VL,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
- CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
- CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
- CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
- CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57 |
- CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_BUS_LOCK_DETECT,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_SERIALIZE |
- CPUID_7_0_EDX_TSX_LDTRK | CPUID_7_0_EDX_AMX_BF16 |
- CPUID_7_0_EDX_AVX512_FP16 | CPUID_7_0_EDX_AMX_TILE |
- CPUID_7_0_EDX_AMX_INT8 | CPUID_7_0_EDX_SPEC_CTRL |
- CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
- .features[FEAT_ARCH_CAPABILITIES] =
- MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
- MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
- MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_TAA_NO,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES | CPUID_D_1_EAX_XFD,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_7_1_EAX] =
- CPUID_7_1_EAX_AVX_VNNI | CPUID_7_1_EAX_AVX512_BF16 |
- CPUID_7_1_EAX_FZRM | CPUID_7_1_EAX_FSRS | CPUID_7_1_EAX_FSRC,
- .features[FEAT_VMX_BASIC] =
- MSR_VMX_BASIC_INS_OUTS | MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] =
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_ENTRY_LOAD_IA32_PAT | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] =
- MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_PAGE_WALK_LENGTH_5 |
- MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB | MSR_VMX_EPT_1GB |
- MSR_VMX_EPT_INVEPT | MSR_VMX_EPT_AD_BITS |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT |
- MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_IA32_PAT |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_LOAD_IA32_EFER | VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] =
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] =
- VMX_PIN_BASED_EXT_INTR_MASK | VMX_PIN_BASED_NMI_EXITING |
- VMX_PIN_BASED_VIRTUAL_NMIS | VMX_PIN_BASED_VMX_PREEMPTION_TIMER |
- VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] =
- VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_VIRTUAL_NMI_PENDING |
- VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
- VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_USE_MSR_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
- VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_ENABLE_EPT | VMX_SECONDARY_EXEC_DESC |
- VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_WBINVD_EXITING |
- VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING |
- VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML |
- VMX_SECONDARY_EXEC_XSAVES,
- .features[FEAT_VMX_VMFUNC] =
- MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Processor (SapphireRapids)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .props = (PropValue[]) {
- { "sbdr-ssdp-no", "on" },
- { "fbsdp-no", "on" },
- { "psdp-no", "on" },
- { /* end of list */ }
- }
- },
- {
- .version = 3,
- .props = (PropValue[]) {
- { "ss", "on" },
- { "tsc-adjust", "on" },
- { "cldemote", "on" },
- { "movdiri", "on" },
- { "movdir64b", "on" },
- { /* end of list */ }
- }
- },
- { /* end of list */ }
- }
- },
- {
- .name = "GraniteRapids",
- .level = 0x20,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 173,
- .stepping = 0,
- /*
- * please keep the ascending order so that we can have a clear view of
- * bit position of each feature.
- */
- .features[FEAT_1_EDX] =
- CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
- CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
- CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
- CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
- CPUID_SSE | CPUID_SSE2,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSSE3 |
- CPUID_EXT_FMA | CPUID_EXT_CX16 | CPUID_EXT_PCID | CPUID_EXT_SSE41 |
- CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
- CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES |
- CPUID_EXT_XSAVE | CPUID_EXT_AVX | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM | CPUID_EXT3_ABM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_WBNOINVD,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_HLE |
- CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 |
- CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_RTM |
- CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
- CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP |
- CPUID_7_0_EBX_AVX512IFMA | CPUID_7_0_EBX_CLFLUSHOPT |
- CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_SHA_NI |
- CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512VL,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
- CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
- CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
- CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
- CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57 |
- CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_BUS_LOCK_DETECT,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_SERIALIZE |
- CPUID_7_0_EDX_TSX_LDTRK | CPUID_7_0_EDX_AMX_BF16 |
- CPUID_7_0_EDX_AVX512_FP16 | CPUID_7_0_EDX_AMX_TILE |
- CPUID_7_0_EDX_AMX_INT8 | CPUID_7_0_EDX_SPEC_CTRL |
- CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
- .features[FEAT_ARCH_CAPABILITIES] =
- MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
- MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
- MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_TAA_NO |
- MSR_ARCH_CAP_SBDR_SSDP_NO | MSR_ARCH_CAP_FBSDP_NO |
- MSR_ARCH_CAP_PSDP_NO | MSR_ARCH_CAP_PBRSB_NO,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES | CPUID_D_1_EAX_XFD,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_7_1_EAX] =
- CPUID_7_1_EAX_AVX_VNNI | CPUID_7_1_EAX_AVX512_BF16 |
- CPUID_7_1_EAX_FZRM | CPUID_7_1_EAX_FSRS | CPUID_7_1_EAX_FSRC |
- CPUID_7_1_EAX_AMX_FP16,
- .features[FEAT_7_1_EDX] =
- CPUID_7_1_EDX_PREFETCHITI,
- .features[FEAT_7_2_EDX] =
- CPUID_7_2_EDX_MCDT_NO,
- .features[FEAT_VMX_BASIC] =
- MSR_VMX_BASIC_INS_OUTS | MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] =
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_ENTRY_LOAD_IA32_PAT | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] =
- MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_PAGE_WALK_LENGTH_5 |
- MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB | MSR_VMX_EPT_1GB |
- MSR_VMX_EPT_INVEPT | MSR_VMX_EPT_AD_BITS |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT |
- MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_IA32_PAT |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_LOAD_IA32_EFER | VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] =
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] =
- VMX_PIN_BASED_EXT_INTR_MASK | VMX_PIN_BASED_NMI_EXITING |
- VMX_PIN_BASED_VIRTUAL_NMIS | VMX_PIN_BASED_VMX_PREEMPTION_TIMER |
- VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] =
- VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_VIRTUAL_NMI_PENDING |
- VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
- VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_USE_MSR_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
- VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_ENABLE_EPT | VMX_SECONDARY_EXEC_DESC |
- VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_WBINVD_EXITING |
- VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING |
- VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML |
- VMX_SECONDARY_EXEC_XSAVES,
- .features[FEAT_VMX_VMFUNC] =
- MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Processor (GraniteRapids)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- { /* end of list */ },
- },
- },
- {
- .name = "SierraForest",
- .level = 0x23,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 175,
- .stepping = 0,
- /*
- * please keep the ascending order so that we can have a clear view of
- * bit position of each feature.
- */
- .features[FEAT_1_EDX] =
- CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
- CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
- CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
- CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
- CPUID_SSE | CPUID_SSE2,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSSE3 |
- CPUID_EXT_FMA | CPUID_EXT_CX16 | CPUID_EXT_PCID | CPUID_EXT_SSE41 |
- CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
- CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES |
- CPUID_EXT_XSAVE | CPUID_EXT_AVX | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM | CPUID_EXT3_ABM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_WBNOINVD,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
- CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS |
- CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT | CPUID_7_0_EBX_CLWB |
- CPUID_7_0_EBX_SHA_NI,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU | CPUID_7_0_ECX_GFNI |
- CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
- CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_BUS_LOCK_DETECT,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_SERIALIZE |
- CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_ARCH_CAPABILITIES |
- CPUID_7_0_EDX_SPEC_CTRL_SSBD,
- .features[FEAT_ARCH_CAPABILITIES] =
- MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
- MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
- MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_SBDR_SSDP_NO |
- MSR_ARCH_CAP_FBSDP_NO | MSR_ARCH_CAP_PSDP_NO |
- MSR_ARCH_CAP_PBRSB_NO,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_7_1_EAX] =
- CPUID_7_1_EAX_AVX_VNNI | CPUID_7_1_EAX_CMPCCXADD |
- CPUID_7_1_EAX_FSRS | CPUID_7_1_EAX_AVX_IFMA,
- .features[FEAT_7_1_EDX] =
- CPUID_7_1_EDX_AVX_VNNI_INT8 | CPUID_7_1_EDX_AVX_NE_CONVERT,
- .features[FEAT_7_2_EDX] =
- CPUID_7_2_EDX_MCDT_NO,
- .features[FEAT_VMX_BASIC] =
- MSR_VMX_BASIC_INS_OUTS | MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] =
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_ENTRY_LOAD_IA32_PAT | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] =
- MSR_VMX_EPT_EXECONLY | MSR_VMX_EPT_PAGE_WALK_LENGTH_4 |
- MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB | MSR_VMX_EPT_1GB |
- MSR_VMX_EPT_INVEPT | MSR_VMX_EPT_AD_BITS |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT |
- MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_IA32_PAT |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_LOAD_IA32_EFER | VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] =
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] =
- VMX_PIN_BASED_EXT_INTR_MASK | VMX_PIN_BASED_NMI_EXITING |
- VMX_PIN_BASED_VIRTUAL_NMIS | VMX_PIN_BASED_VMX_PREEMPTION_TIMER |
- VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] =
- VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_VIRTUAL_NMI_PENDING |
- VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
- VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_USE_MSR_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
- VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_ENABLE_EPT | VMX_SECONDARY_EXEC_DESC |
- VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_WBINVD_EXITING |
- VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING |
- VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML |
- VMX_SECONDARY_EXEC_XSAVES,
- .features[FEAT_VMX_VMFUNC] =
- MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Processor (SierraForest)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- { /* end of list */ },
- },
- },
- {
- .name = "Denverton",
- .level = 21,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 95,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
- CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
- CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
- CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
- CPUID_SSE | CPUID_SSE2,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_MONITOR |
- CPUID_EXT_SSSE3 | CPUID_EXT_CX16 | CPUID_EXT_SSE41 |
- CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
- CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER |
- CPUID_EXT_AES | CPUID_EXT_XSAVE | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_ERMS |
- CPUID_7_0_EBX_MPX | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_SMAP |
- CPUID_7_0_EBX_CLFLUSHOPT | CPUID_7_0_EBX_SHA_NI,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_ARCH_CAPABILITIES |
- CPUID_7_0_EDX_SPEC_CTRL_SSBD,
- /* XSAVES is added in version 3 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC | CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_ARCH_CAPABILITIES] =
- MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
- .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Atom Processor (Denverton)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .note = "no MPX, no MONITOR",
- .props = (PropValue[]) {
- { "monitor", "off" },
- { "mpx", "off" },
- { /* end of list */ },
- },
- },
- {
- .version = 3,
- .note = "XSAVES, no MPX, no MONITOR",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { "vmx-xsaves", "on" },
- { /* end of list */ },
- },
- },
- { /* end of list */ },
- },
- },
- {
- .name = "Snowridge",
- .level = 27,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 134,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- /* missing: CPUID_PN CPUID_IA64 */
- /* missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
- CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE |
- CPUID_TSC | CPUID_MSR | CPUID_PAE | CPUID_MCE |
- CPUID_CX8 | CPUID_APIC | CPUID_SEP |
- CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
- CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH |
- CPUID_MMX |
- CPUID_FXSR | CPUID_SSE | CPUID_SSE2,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_MONITOR |
- CPUID_EXT_SSSE3 |
- CPUID_EXT_CX16 |
- CPUID_EXT_SSE41 |
- CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
- CPUID_EXT_POPCNT |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES | CPUID_EXT_XSAVE |
- CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_SYSCALL |
- CPUID_EXT2_NX |
- CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
- CPUID_EXT2_LM,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_LAHF_LM |
- CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE |
- CPUID_7_0_EBX_SMEP |
- CPUID_7_0_EBX_ERMS |
- CPUID_7_0_EBX_MPX | /* missing bits 13, 15 */
- CPUID_7_0_EBX_RDSEED |
- CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
- CPUID_7_0_EBX_CLWB |
- CPUID_7_0_EBX_SHA_NI,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_UMIP |
- /* missing bit 5 */
- CPUID_7_0_ECX_GFNI |
- CPUID_7_0_ECX_MOVDIRI | CPUID_7_0_ECX_CLDEMOTE |
- CPUID_7_0_ECX_MOVDIR64B,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_SPEC_CTRL |
- CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD |
- CPUID_7_0_EDX_CORE_CAPABILITY,
- .features[FEAT_CORE_CAPABILITY] =
- MSR_CORE_CAP_SPLIT_LOCK_DETECT,
- /* XSAVES is added in version 3 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
- MSR_VMX_BASIC_TRUE_CTLS,
- .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
- VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
- VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
- .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
- MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
- MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
- MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
- MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
- .features[FEAT_VMX_EXIT_CTLS] =
- VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
- VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
- VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
- VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
- VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
- .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
- MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
- .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
- VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
- VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
- .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
- VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
- VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
- VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
- VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
- VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
- VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
- VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
- VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
- VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
- VMX_CPU_BASED_MONITOR_TRAP_FLAG |
- VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
- .features[FEAT_VMX_SECONDARY_CTLS] =
- VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
- VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
- VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
- VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
- VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
- VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
- VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
- VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
- VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
- VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
- .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
- .xlevel = 0x80000008,
- .model_id = "Intel Atom Processor (SnowRidge)",
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .props = (PropValue[]) {
- { "mpx", "off" },
- { "model-id", "Intel Atom Processor (Snowridge, no MPX)" },
- { /* end of list */ },
- },
- },
- {
- .version = 3,
- .note = "XSAVES, no MPX",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { "vmx-xsaves", "on" },
- { /* end of list */ },
- },
- },
- {
- .version = 4,
- .note = "no split lock detect, no core-capability",
- .props = (PropValue[]) {
- { "split-lock-detect", "off" },
- { "core-capability", "off" },
- { /* end of list */ },
- },
- },
- { /* end of list */ },
- },
- },
- {
- .name = "KnightsMill",
- .level = 0xd,
- .vendor = CPUID_VENDOR_INTEL,
- .family = 6,
- .model = 133,
- .stepping = 0,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SS | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR |
- CPUID_MMX | CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV |
- CPUID_MCA | CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC |
- CPUID_CX8 | CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC |
- CPUID_PSE | CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
- CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
- CPUID_EXT_F16C | CPUID_EXT_RDRAND,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
- CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
- CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS |
- CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_AVX512F |
- CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_AVX512PF |
- CPUID_7_0_EBX_AVX512ER,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_AVX512_VPOPCNTDQ,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_AVX512_4VNNIW | CPUID_7_0_EDX_AVX512_4FMAPS,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .xlevel = 0x80000008,
- .model_id = "Intel Xeon Phi Processor (Knights Mill)",
- },
- {
- .name = "Opteron_G1",
- .level = 5,
- .vendor = CPUID_VENDOR_AMD,
- .family = 15,
- .model = 6,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .xlevel = 0x80000008,
- .model_id = "AMD Opteron 240 (Gen 1 Class Opteron)",
- },
- {
- .name = "Opteron_G2",
- .level = 5,
- .vendor = CPUID_VENDOR_AMD,
- .family = 15,
- .model = 6,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_CX16 | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM,
- .xlevel = 0x80000008,
- .model_id = "AMD Opteron 22xx (Gen 2 Class Opteron)",
- },
- {
- .name = "Opteron_G3",
- .level = 5,
- .vendor = CPUID_VENDOR_AMD,
- .family = 16,
- .model = 2,
- .stepping = 3,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_POPCNT | CPUID_EXT_CX16 | CPUID_EXT_MONITOR |
- CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL |
- CPUID_EXT2_RDTSCP,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A |
- CPUID_EXT3_ABM | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM,
- .xlevel = 0x80000008,
- .model_id = "AMD Opteron 23xx (Gen 3 Class Opteron)",
- },
- {
- .name = "Opteron_G4",
- .level = 0xd,
- .vendor = CPUID_VENDOR_AMD,
- .family = 21,
- .model = 1,
- .stepping = 2,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
- CPUID_EXT_POPCNT | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
- CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL | CPUID_EXT2_RDTSCP,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_FMA4 | CPUID_EXT3_XOP |
- CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_MISALIGNSSE |
- CPUID_EXT3_SSE4A | CPUID_EXT3_ABM | CPUID_EXT3_SVM |
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_SVM] =
- CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
- /* no xsaveopt! */
- .xlevel = 0x8000001A,
- .model_id = "AMD Opteron 62xx class CPU",
- },
- {
- .name = "Opteron_G5",
- .level = 0xd,
- .vendor = CPUID_VENDOR_AMD,
- .family = 21,
- .model = 2,
- .stepping = 0,
- .features[FEAT_1_EDX] =
- CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
- CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
- CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
- CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
- CPUID_DE | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_F16C | CPUID_EXT_AVX | CPUID_EXT_XSAVE |
- CPUID_EXT_AES | CPUID_EXT_POPCNT | CPUID_EXT_SSE42 |
- CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_FMA |
- CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL | CPUID_EXT2_RDTSCP,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_TBM | CPUID_EXT3_FMA4 | CPUID_EXT3_XOP |
- CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_MISALIGNSSE |
- CPUID_EXT3_SSE4A | CPUID_EXT3_ABM | CPUID_EXT3_SVM |
- CPUID_EXT3_LAHF_LM,
- .features[FEAT_SVM] =
- CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
- /* no xsaveopt! */
- .xlevel = 0x8000001A,
- .model_id = "AMD Opteron 63xx class CPU",
- },
- {
- .name = "EPYC",
- .level = 0xd,
- .vendor = CPUID_VENDOR_AMD,
- .family = 23,
- .model = 1,
- .stepping = 2,
- .features[FEAT_1_EDX] =
- CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
- CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
- CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
- CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
- CPUID_VME | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
- CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
- CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
- CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
- CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
- CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
- CPUID_EXT3_TOPOEXT,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
- CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
- CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
- CPUID_7_0_EBX_SHA_NI,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_SVM] =
- CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
- .xlevel = 0x8000001E,
- .model_id = "AMD EPYC Processor",
- .cache_info = &epyc_cache_info,
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .alias = "EPYC-IBPB",
- .props = (PropValue[]) {
- { "ibpb", "on" },
- { "model-id",
- "AMD EPYC Processor (with IBPB)" },
- { /* end of list */ }
- }
- },
- {
- .version = 3,
- .props = (PropValue[]) {
- { "ibpb", "on" },
- { "perfctr-core", "on" },
- { "clzero", "on" },
- { "xsaveerptr", "on" },
- { "xsaves", "on" },
- { "model-id",
- "AMD EPYC Processor" },
- { /* end of list */ }
- }
- },
- {
- .version = 4,
- .props = (PropValue[]) {
- { "model-id",
- "AMD EPYC-v4 Processor" },
- { /* end of list */ }
- },
- .cache_info = &epyc_v4_cache_info
- },
- { /* end of list */ }
- }
- },
- {
- .name = "Dhyana",
- .level = 0xd,
- .vendor = CPUID_VENDOR_HYGON,
- .family = 24,
- .model = 0,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
- CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
- CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
- CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
- CPUID_VME | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
- CPUID_EXT_XSAVE | CPUID_EXT_POPCNT |
- CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
- CPUID_EXT_MONITOR | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
- CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
- CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
- CPUID_EXT3_TOPOEXT,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_IBPB,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
- CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
- CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT,
- /* XSAVES is added in version 2 */
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_SVM] =
- CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
- .xlevel = 0x8000001E,
- .model_id = "Hygon Dhyana Processor",
- .cache_info = &epyc_cache_info,
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- { .version = 2,
- .note = "XSAVES",
- .props = (PropValue[]) {
- { "xsaves", "on" },
- { /* end of list */ }
- },
- },
- { /* end of list */ }
- }
- },
- {
- .name = "EPYC-Rome",
- .level = 0xd,
- .vendor = CPUID_VENDOR_AMD,
- .family = 23,
- .model = 49,
- .stepping = 0,
- .features[FEAT_1_EDX] =
- CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
- CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
- CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
- CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
- CPUID_VME | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
- CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
- CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
- CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
- CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
- CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
- CPUID_EXT3_TOPOEXT | CPUID_EXT3_PERFCORE,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_CLZERO | CPUID_8000_0008_EBX_XSAVEERPTR |
- CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_IBPB |
- CPUID_8000_0008_EBX_STIBP,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
- CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
- CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
- CPUID_7_0_EBX_SHA_NI | CPUID_7_0_EBX_CLWB,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_RDPID,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_SVM] =
- CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
- .xlevel = 0x8000001E,
- .model_id = "AMD EPYC-Rome Processor",
- .cache_info = &epyc_rome_cache_info,
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .props = (PropValue[]) {
- { "ibrs", "on" },
- { "amd-ssbd", "on" },
- { /* end of list */ }
- }
- },
- {
- .version = 3,
- .props = (PropValue[]) {
- { "model-id",
- "AMD EPYC-Rome-v3 Processor" },
- { /* end of list */ }
- },
- .cache_info = &epyc_rome_v3_cache_info
- },
- {
- .version = 4,
- .props = (PropValue[]) {
- /* Erratum 1386 */
- { "model-id",
- "AMD EPYC-Rome-v4 Processor (no XSAVES)" },
- { "xsaves", "off" },
- { /* end of list */ }
- },
- },
- { /* end of list */ }
- }
- },
- {
- .name = "EPYC-Milan",
- .level = 0xd,
- .vendor = CPUID_VENDOR_AMD,
- .family = 25,
- .model = 1,
- .stepping = 1,
- .features[FEAT_1_EDX] =
- CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
- CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
- CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
- CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
- CPUID_VME | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
- CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
- CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
- CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
- CPUID_EXT_PCID,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
- CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
- CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
- CPUID_EXT3_TOPOEXT | CPUID_EXT3_PERFCORE,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_CLZERO | CPUID_8000_0008_EBX_XSAVEERPTR |
- CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_IBPB |
- CPUID_8000_0008_EBX_IBRS | CPUID_8000_0008_EBX_STIBP |
- CPUID_8000_0008_EBX_AMD_SSBD,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
- CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
- CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
- CPUID_7_0_EBX_SHA_NI | CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_ERMS |
- CPUID_7_0_EBX_INVPCID,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_PKU,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_FSRM,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_SVM] =
- CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE | CPUID_SVM_SVME_ADDR_CHK,
- .xlevel = 0x8000001E,
- .model_id = "AMD EPYC-Milan Processor",
- .cache_info = &epyc_milan_cache_info,
- .versions = (X86CPUVersionDefinition[]) {
- { .version = 1 },
- {
- .version = 2,
- .props = (PropValue[]) {
- { "model-id",
- "AMD EPYC-Milan-v2 Processor" },
- { "vaes", "on" },
- { "vpclmulqdq", "on" },
- { "stibp-always-on", "on" },
- { "amd-psfd", "on" },
- { "no-nested-data-bp", "on" },
- { "lfence-always-serializing", "on" },
- { "null-sel-clr-base", "on" },
- { /* end of list */ }
- },
- .cache_info = &epyc_milan_v2_cache_info
- },
- { /* end of list */ }
- }
- },
- {
- .name = "EPYC-Genoa",
- .level = 0xd,
- .vendor = CPUID_VENDOR_AMD,
- .family = 25,
- .model = 17,
- .stepping = 0,
- .features[FEAT_1_EDX] =
- CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
- CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
- CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
- CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
- CPUID_VME | CPUID_FP87,
- .features[FEAT_1_ECX] =
- CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
- CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
- CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
- CPUID_EXT_PCID | CPUID_EXT_CX16 | CPUID_EXT_FMA |
- CPUID_EXT_SSSE3 | CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ |
- CPUID_EXT_SSE3,
- .features[FEAT_8000_0001_EDX] =
- CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
- CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
- CPUID_EXT2_SYSCALL,
- .features[FEAT_8000_0001_ECX] =
- CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
- CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
- CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
- CPUID_EXT3_TOPOEXT | CPUID_EXT3_PERFCORE,
- .features[FEAT_8000_0008_EBX] =
- CPUID_8000_0008_EBX_CLZERO | CPUID_8000_0008_EBX_XSAVEERPTR |
- CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_IBPB |
- CPUID_8000_0008_EBX_IBRS | CPUID_8000_0008_EBX_STIBP |
- CPUID_8000_0008_EBX_STIBP_ALWAYS_ON |
- CPUID_8000_0008_EBX_AMD_SSBD | CPUID_8000_0008_EBX_AMD_PSFD,
- .features[FEAT_8000_0021_EAX] =
- CPUID_8000_0021_EAX_No_NESTED_DATA_BP |
- CPUID_8000_0021_EAX_LFENCE_ALWAYS_SERIALIZING |
- CPUID_8000_0021_EAX_NULL_SEL_CLR_BASE |
- CPUID_8000_0021_EAX_AUTO_IBRS,
- .features[FEAT_7_0_EBX] =
- CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
- CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS |
- CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_AVX512F |
- CPUID_7_0_EBX_AVX512DQ | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
- CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_AVX512IFMA |
- CPUID_7_0_EBX_CLFLUSHOPT | CPUID_7_0_EBX_CLWB |
- CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_SHA_NI |
- CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512VL,
- .features[FEAT_7_0_ECX] =
- CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
- CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
- CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
- CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
- CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57 |
- CPUID_7_0_ECX_RDPID,
- .features[FEAT_7_0_EDX] =
- CPUID_7_0_EDX_FSRM,
- .features[FEAT_7_1_EAX] =
- CPUID_7_1_EAX_AVX512_BF16,
- .features[FEAT_XSAVE] =
- CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
- CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
- .features[FEAT_6_EAX] =
- CPUID_6_EAX_ARAT,
- .features[FEAT_SVM] =
- CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE | CPUID_SVM_VNMI |
- CPUID_SVM_SVME_ADDR_CHK,
- .xlevel = 0x80000022,
- .model_id = "AMD EPYC-Genoa Processor",
- .cache_info = &epyc_genoa_cache_info,
- },
- };
- /*
- * We resolve CPU model aliases using -v1 when using "-machine
- * none", but this is just for compatibility while libvirt isn't
- * adapted to resolve CPU model versions before creating VMs.
- * See "Runnability guarantee of CPU models" at
- * docs/about/deprecated.rst.
- */
- X86CPUVersion default_cpu_version = 1;
- void x86_cpu_set_default_version(X86CPUVersion version)
- {
- /* Translating CPU_VERSION_AUTO to CPU_VERSION_AUTO doesn't make sense */
- assert(version != CPU_VERSION_AUTO);
- default_cpu_version = version;
- }
- static X86CPUVersion x86_cpu_model_last_version(const X86CPUModel *model)
- {
- int v = 0;
- const X86CPUVersionDefinition *vdef =
- x86_cpu_def_get_versions(model->cpudef);
- while (vdef->version) {
- v = vdef->version;
- vdef++;
- }
- return v;
- }
- /* Return the actual version being used for a specific CPU model */
- static X86CPUVersion x86_cpu_model_resolve_version(const X86CPUModel *model)
- {
- X86CPUVersion v = model->version;
- if (v == CPU_VERSION_AUTO) {
- v = default_cpu_version;
- }
- if (v == CPU_VERSION_LATEST) {
- return x86_cpu_model_last_version(model);
- }
- return v;
- }
- static Property max_x86_cpu_properties[] = {
- DEFINE_PROP_BOOL("migratable", X86CPU, migratable, true),
- DEFINE_PROP_BOOL("host-cache-info", X86CPU, cache_info_passthrough, false),
- DEFINE_PROP_END_OF_LIST()
- };
- static void max_x86_cpu_realize(DeviceState *dev, Error **errp)
- {
- Object *obj = OBJECT(dev);
- if (!object_property_get_int(obj, "family", &error_abort)) {
- if (X86_CPU(obj)->env.features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
- object_property_set_int(obj, "family", 15, &error_abort);
- object_property_set_int(obj, "model", 107, &error_abort);
- object_property_set_int(obj, "stepping", 1, &error_abort);
- } else {
- object_property_set_int(obj, "family", 6, &error_abort);
- object_property_set_int(obj, "model", 6, &error_abort);
- object_property_set_int(obj, "stepping", 3, &error_abort);
- }
- }
- x86_cpu_realizefn(dev, errp);
- }
- static void max_x86_cpu_class_init(ObjectClass *oc, void *data)
- {
- DeviceClass *dc = DEVICE_CLASS(oc);
- X86CPUClass *xcc = X86_CPU_CLASS(oc);
- xcc->ordering = 9;
- xcc->model_description =
- "Enables all features supported by the accelerator in the current host";
- device_class_set_props(dc, max_x86_cpu_properties);
- dc->realize = max_x86_cpu_realize;
- }
- static void max_x86_cpu_initfn(Object *obj)
- {
- X86CPU *cpu = X86_CPU(obj);
- /* We can't fill the features array here because we don't know yet if
- * "migratable" is true or false.
- */
- cpu->max_features = true;
- object_property_set_bool(OBJECT(cpu), "pmu", true, &error_abort);
- /*
- * these defaults are used for TCG and all other accelerators
- * besides KVM and HVF, which overwrite these values
- */
- object_property_set_str(OBJECT(cpu), "vendor", CPUID_VENDOR_AMD,
- &error_abort);
- object_property_set_str(OBJECT(cpu), "model-id",
- "QEMU TCG CPU version " QEMU_HW_VERSION,
- &error_abort);
- }
- static const TypeInfo max_x86_cpu_type_info = {
- .name = X86_CPU_TYPE_NAME("max"),
- .parent = TYPE_X86_CPU,
- .instance_init = max_x86_cpu_initfn,
- .class_init = max_x86_cpu_class_init,
- };
- static char *feature_word_description(FeatureWordInfo *f, uint32_t bit)
- {
- assert(f->type == CPUID_FEATURE_WORD || f->type == MSR_FEATURE_WORD);
- switch (f->type) {
- case CPUID_FEATURE_WORD:
- {
- const char *reg = get_register_name_32(f->cpuid.reg);
- assert(reg);
- return g_strdup_printf("CPUID.%02XH:%s",
- f->cpuid.eax, reg);
- }
- case MSR_FEATURE_WORD:
- return g_strdup_printf("MSR(%02XH)",
- f->msr.index);
- }
- return NULL;
- }
- static bool x86_cpu_have_filtered_features(X86CPU *cpu)
- {
- FeatureWord w;
- for (w = 0; w < FEATURE_WORDS; w++) {
- if (cpu->filtered_features[w]) {
- return true;
- }
- }
- return false;
- }
- static void mark_unavailable_features(X86CPU *cpu, FeatureWord w, uint64_t mask,
- const char *verbose_prefix)
- {
- CPUX86State *env = &cpu->env;
- FeatureWordInfo *f = &feature_word_info[w];
- int i;
- if (!cpu->force_features) {
- env->features[w] &= ~mask;
- }
- cpu->filtered_features[w] |= mask;
- if (!verbose_prefix) {
- return;
- }
- for (i = 0; i < 64; ++i) {
- if ((1ULL << i) & mask) {
- g_autofree char *feat_word_str = feature_word_description(f, i);
- warn_report("%s: %s%s%s [bit %d]",
- verbose_prefix,
- feat_word_str,
- f->feat_names[i] ? "." : "",
- f->feat_names[i] ? f->feat_names[i] : "", i);
- }
- }
- }
- static void x86_cpuid_version_get_family(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- int64_t value;
- value = (env->cpuid_version >> 8) & 0xf;
- if (value == 0xf) {
- value += (env->cpuid_version >> 20) & 0xff;
- }
- visit_type_int(v, name, &value, errp);
- }
- static void x86_cpuid_version_set_family(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- const int64_t min = 0;
- const int64_t max = 0xff + 0xf;
- int64_t value;
- if (!visit_type_int(v, name, &value, errp)) {
- return;
- }
- if (value < min || value > max) {
- error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
- name ? name : "null", value, min, max);
- return;
- }
- env->cpuid_version &= ~0xff00f00;
- if (value > 0x0f) {
- env->cpuid_version |= 0xf00 | ((value - 0x0f) << 20);
- } else {
- env->cpuid_version |= value << 8;
- }
- }
- static void x86_cpuid_version_get_model(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- int64_t value;
- value = (env->cpuid_version >> 4) & 0xf;
- value |= ((env->cpuid_version >> 16) & 0xf) << 4;
- visit_type_int(v, name, &value, errp);
- }
- static void x86_cpuid_version_set_model(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- const int64_t min = 0;
- const int64_t max = 0xff;
- int64_t value;
- if (!visit_type_int(v, name, &value, errp)) {
- return;
- }
- if (value < min || value > max) {
- error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
- name ? name : "null", value, min, max);
- return;
- }
- env->cpuid_version &= ~0xf00f0;
- env->cpuid_version |= ((value & 0xf) << 4) | ((value >> 4) << 16);
- }
- static void x86_cpuid_version_get_stepping(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- int64_t value;
- value = env->cpuid_version & 0xf;
- visit_type_int(v, name, &value, errp);
- }
- static void x86_cpuid_version_set_stepping(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- const int64_t min = 0;
- const int64_t max = 0xf;
- int64_t value;
- if (!visit_type_int(v, name, &value, errp)) {
- return;
- }
- if (value < min || value > max) {
- error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
- name ? name : "null", value, min, max);
- return;
- }
- env->cpuid_version &= ~0xf;
- env->cpuid_version |= value & 0xf;
- }
- static char *x86_cpuid_get_vendor(Object *obj, Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- char *value;
- value = g_malloc(CPUID_VENDOR_SZ + 1);
- x86_cpu_vendor_words2str(value, env->cpuid_vendor1, env->cpuid_vendor2,
- env->cpuid_vendor3);
- return value;
- }
- static void x86_cpuid_set_vendor(Object *obj, const char *value,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- int i;
- if (strlen(value) != CPUID_VENDOR_SZ) {
- error_setg(errp, "value of property 'vendor' must consist of"
- " exactly " stringify(CPUID_VENDOR_SZ) " characters");
- return;
- }
- env->cpuid_vendor1 = 0;
- env->cpuid_vendor2 = 0;
- env->cpuid_vendor3 = 0;
- for (i = 0; i < 4; i++) {
- env->cpuid_vendor1 |= ((uint8_t)value[i ]) << (8 * i);
- env->cpuid_vendor2 |= ((uint8_t)value[i + 4]) << (8 * i);
- env->cpuid_vendor3 |= ((uint8_t)value[i + 8]) << (8 * i);
- }
- }
- static char *x86_cpuid_get_model_id(Object *obj, Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- char *value;
- int i;
- value = g_malloc(48 + 1);
- for (i = 0; i < 48; i++) {
- value[i] = env->cpuid_model[i >> 2] >> (8 * (i & 3));
- }
- value[48] = '\0';
- return value;
- }
- static void x86_cpuid_set_model_id(Object *obj, const char *model_id,
- Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- CPUX86State *env = &cpu->env;
- int c, len, i;
- if (model_id == NULL) {
- model_id = "";
- }
- len = strlen(model_id);
- memset(env->cpuid_model, 0, 48);
- for (i = 0; i < 48; i++) {
- if (i >= len) {
- c = '\0';
- } else {
- c = (uint8_t)model_id[i];
- }
- env->cpuid_model[i >> 2] |= c << (8 * (i & 3));
- }
- }
- static void x86_cpuid_get_tsc_freq(Object *obj, Visitor *v, const char *name,
- void *opaque, Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- int64_t value;
- value = cpu->env.tsc_khz * 1000;
- visit_type_int(v, name, &value, errp);
- }
- static void x86_cpuid_set_tsc_freq(Object *obj, Visitor *v, const char *name,
- void *opaque, Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- const int64_t min = 0;
- const int64_t max = INT64_MAX;
- int64_t value;
- if (!visit_type_int(v, name, &value, errp)) {
- return;
- }
- if (value < min || value > max) {
- error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
- name ? name : "null", value, min, max);
- return;
- }
- cpu->env.tsc_khz = cpu->env.user_tsc_khz = value / 1000;
- }
- /* Generic getter for "feature-words" and "filtered-features" properties */
- static void x86_cpu_get_feature_words(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- uint64_t *array = (uint64_t *)opaque;
- FeatureWord w;
- X86CPUFeatureWordInfo word_infos[FEATURE_WORDS] = { };
- X86CPUFeatureWordInfoList list_entries[FEATURE_WORDS] = { };
- X86CPUFeatureWordInfoList *list = NULL;
- for (w = 0; w < FEATURE_WORDS; w++) {
- FeatureWordInfo *wi = &feature_word_info[w];
- /*
- * We didn't have MSR features when "feature-words" was
- * introduced. Therefore skipped other type entries.
- */
- if (wi->type != CPUID_FEATURE_WORD) {
- continue;
- }
- X86CPUFeatureWordInfo *qwi = &word_infos[w];
- qwi->cpuid_input_eax = wi->cpuid.eax;
- qwi->has_cpuid_input_ecx = wi->cpuid.needs_ecx;
- qwi->cpuid_input_ecx = wi->cpuid.ecx;
- qwi->cpuid_register = x86_reg_info_32[wi->cpuid.reg].qapi_enum;
- qwi->features = array[w];
- /* List will be in reverse order, but order shouldn't matter */
- list_entries[w].next = list;
- list_entries[w].value = &word_infos[w];
- list = &list_entries[w];
- }
- visit_type_X86CPUFeatureWordInfoList(v, "feature-words", &list, errp);
- }
- /* Convert all '_' in a feature string option name to '-', to make feature
- * name conform to QOM property naming rule, which uses '-' instead of '_'.
- */
- static inline void feat2prop(char *s)
- {
- while ((s = strchr(s, '_'))) {
- *s = '-';
- }
- }
- /* Return the feature property name for a feature flag bit */
- static const char *x86_cpu_feature_name(FeatureWord w, int bitnr)
- {
- const char *name;
- /* XSAVE components are automatically enabled by other features,
- * so return the original feature name instead
- */
- if (w == FEAT_XSAVE_XCR0_LO || w == FEAT_XSAVE_XCR0_HI) {
- int comp = (w == FEAT_XSAVE_XCR0_HI) ? bitnr + 32 : bitnr;
- if (comp < ARRAY_SIZE(x86_ext_save_areas) &&
- x86_ext_save_areas[comp].bits) {
- w = x86_ext_save_areas[comp].feature;
- bitnr = ctz32(x86_ext_save_areas[comp].bits);
- }
- }
- assert(bitnr < 64);
- assert(w < FEATURE_WORDS);
- name = feature_word_info[w].feat_names[bitnr];
- assert(bitnr < 32 || !(name && feature_word_info[w].type == CPUID_FEATURE_WORD));
- return name;
- }
- /* Compatibility hack to maintain legacy +-feat semantic,
- * where +-feat overwrites any feature set by
- * feat=on|feat even if the later is parsed after +-feat
- * (i.e. "-x2apic,x2apic=on" will result in x2apic disabled)
- */
- static GList *plus_features, *minus_features;
- static gint compare_string(gconstpointer a, gconstpointer b)
- {
- return g_strcmp0(a, b);
- }
- /* Parse "+feature,-feature,feature=foo" CPU feature string
- */
- static void x86_cpu_parse_featurestr(const char *typename, char *features,
- Error **errp)
- {
- char *featurestr; /* Single 'key=value" string being parsed */
- static bool cpu_globals_initialized;
- bool ambiguous = false;
- if (cpu_globals_initialized) {
- return;
- }
- cpu_globals_initialized = true;
- if (!features) {
- return;
- }
- for (featurestr = strtok(features, ",");
- featurestr;
- featurestr = strtok(NULL, ",")) {
- const char *name;
- const char *val = NULL;
- char *eq = NULL;
- char num[32];
- GlobalProperty *prop;
- /* Compatibility syntax: */
- if (featurestr[0] == '+') {
- plus_features = g_list_append(plus_features,
- g_strdup(featurestr + 1));
- continue;
- } else if (featurestr[0] == '-') {
- minus_features = g_list_append(minus_features,
- g_strdup(featurestr + 1));
- continue;
- }
- eq = strchr(featurestr, '=');
- if (eq) {
- *eq++ = 0;
- val = eq;
- } else {
- val = "on";
- }
- feat2prop(featurestr);
- name = featurestr;
- if (g_list_find_custom(plus_features, name, compare_string)) {
- warn_report("Ambiguous CPU model string. "
- "Don't mix both \"+%s\" and \"%s=%s\"",
- name, name, val);
- ambiguous = true;
- }
- if (g_list_find_custom(minus_features, name, compare_string)) {
- warn_report("Ambiguous CPU model string. "
- "Don't mix both \"-%s\" and \"%s=%s\"",
- name, name, val);
- ambiguous = true;
- }
- /* Special case: */
- if (!strcmp(name, "tsc-freq")) {
- int ret;
- uint64_t tsc_freq;
- ret = qemu_strtosz_metric(val, NULL, &tsc_freq);
- if (ret < 0 || tsc_freq > INT64_MAX) {
- error_setg(errp, "bad numerical value %s", val);
- return;
- }
- snprintf(num, sizeof(num), "%" PRId64, tsc_freq);
- val = num;
- name = "tsc-frequency";
- }
- prop = g_new0(typeof(*prop), 1);
- prop->driver = typename;
- prop->property = g_strdup(name);
- prop->value = g_strdup(val);
- qdev_prop_register_global(prop);
- }
- if (ambiguous) {
- warn_report("Compatibility of ambiguous CPU model "
- "strings won't be kept on future QEMU versions");
- }
- }
- static void x86_cpu_filter_features(X86CPU *cpu, bool verbose);
- /* Build a list with the name of all features on a feature word array */
- static void x86_cpu_list_feature_names(FeatureWordArray features,
- strList **list)
- {
- strList **tail = list;
- FeatureWord w;
- for (w = 0; w < FEATURE_WORDS; w++) {
- uint64_t filtered = features[w];
- int i;
- for (i = 0; i < 64; i++) {
- if (filtered & (1ULL << i)) {
- QAPI_LIST_APPEND(tail, g_strdup(x86_cpu_feature_name(w, i)));
- }
- }
- }
- }
- static void x86_cpu_get_unavailable_features(Object *obj, Visitor *v,
- const char *name, void *opaque,
- Error **errp)
- {
- X86CPU *xc = X86_CPU(obj);
- strList *result = NULL;
- x86_cpu_list_feature_names(xc->filtered_features, &result);
- visit_type_strList(v, "unavailable-features", &result, errp);
- }
- /* Print all cpuid feature names in featureset
- */
- static void listflags(GList *features)
- {
- size_t len = 0;
- GList *tmp;
- for (tmp = features; tmp; tmp = tmp->next) {
- const char *name = tmp->data;
- if ((len + strlen(name) + 1) >= 75) {
- qemu_printf("\n");
- len = 0;
- }
- qemu_printf("%s%s", len == 0 ? " " : " ", name);
- len += strlen(name) + 1;
- }
- qemu_printf("\n");
- }
- /* Sort alphabetically by type name, respecting X86CPUClass::ordering. */
- static gint x86_cpu_list_compare(gconstpointer a, gconstpointer b)
- {
- ObjectClass *class_a = (ObjectClass *)a;
- ObjectClass *class_b = (ObjectClass *)b;
- X86CPUClass *cc_a = X86_CPU_CLASS(class_a);
- X86CPUClass *cc_b = X86_CPU_CLASS(class_b);
- int ret;
- if (cc_a->ordering != cc_b->ordering) {
- ret = cc_a->ordering - cc_b->ordering;
- } else {
- g_autofree char *name_a = x86_cpu_class_get_model_name(cc_a);
- g_autofree char *name_b = x86_cpu_class_get_model_name(cc_b);
- ret = strcmp(name_a, name_b);
- }
- return ret;
- }
- static GSList *get_sorted_cpu_model_list(void)
- {
- GSList *list = object_class_get_list(TYPE_X86_CPU, false);
- list = g_slist_sort(list, x86_cpu_list_compare);
- return list;
- }
- static char *x86_cpu_class_get_model_id(X86CPUClass *xc)
- {
- Object *obj = object_new_with_class(OBJECT_CLASS(xc));
- char *r = object_property_get_str(obj, "model-id", &error_abort);
- object_unref(obj);
- return r;
- }
- static char *x86_cpu_class_get_alias_of(X86CPUClass *cc)
- {
- X86CPUVersion version;
- if (!cc->model || !cc->model->is_alias) {
- return NULL;
- }
- version = x86_cpu_model_resolve_version(cc->model);
- if (version <= 0) {
- return NULL;
- }
- return x86_cpu_versioned_model_name(cc->model->cpudef, version);
- }
- static void x86_cpu_list_entry(gpointer data, gpointer user_data)
- {
- ObjectClass *oc = data;
- X86CPUClass *cc = X86_CPU_CLASS(oc);
- g_autofree char *name = x86_cpu_class_get_model_name(cc);
- g_autofree char *desc = g_strdup(cc->model_description);
- g_autofree char *alias_of = x86_cpu_class_get_alias_of(cc);
- g_autofree char *model_id = x86_cpu_class_get_model_id(cc);
- if (!desc && alias_of) {
- if (cc->model && cc->model->version == CPU_VERSION_AUTO) {
- desc = g_strdup("(alias configured by machine type)");
- } else {
- desc = g_strdup_printf("(alias of %s)", alias_of);
- }
- }
- if (!desc && cc->model && cc->model->note) {
- desc = g_strdup_printf("%s [%s]", model_id, cc->model->note);
- }
- if (!desc) {
- desc = g_strdup_printf("%s", model_id);
- }
- if (cc->model && cc->model->cpudef->deprecation_note) {
- g_autofree char *olddesc = desc;
- desc = g_strdup_printf("%s (deprecated)", olddesc);
- }
- qemu_printf(" %-20s %s\n", name, desc);
- }
- /* list available CPU models and flags */
- void x86_cpu_list(void)
- {
- int i, j;
- GSList *list;
- GList *names = NULL;
- qemu_printf("Available CPUs:\n");
- list = get_sorted_cpu_model_list();
- g_slist_foreach(list, x86_cpu_list_entry, NULL);
- g_slist_free(list);
- names = NULL;
- for (i = 0; i < ARRAY_SIZE(feature_word_info); i++) {
- FeatureWordInfo *fw = &feature_word_info[i];
- for (j = 0; j < 64; j++) {
- if (fw->feat_names[j]) {
- names = g_list_append(names, (gpointer)fw->feat_names[j]);
- }
- }
- }
- names = g_list_sort(names, (GCompareFunc)strcmp);
- qemu_printf("\nRecognized CPUID flags:\n");
- listflags(names);
- qemu_printf("\n");
- g_list_free(names);
- }
- #ifndef CONFIG_USER_ONLY
- /* Check for missing features that may prevent the CPU class from
- * running using the current machine and accelerator.
- */
- static void x86_cpu_class_check_missing_features(X86CPUClass *xcc,
- strList **list)
- {
- strList **tail = list;
- X86CPU *xc;
- Error *err = NULL;
- if (xcc->host_cpuid_required && !accel_uses_host_cpuid()) {
- QAPI_LIST_APPEND(tail, g_strdup("kvm"));
- return;
- }
- xc = X86_CPU(object_new_with_class(OBJECT_CLASS(xcc)));
- x86_cpu_expand_features(xc, &err);
- if (err) {
- /* Errors at x86_cpu_expand_features should never happen,
- * but in case it does, just report the model as not
- * runnable at all using the "type" property.
- */
- QAPI_LIST_APPEND(tail, g_strdup("type"));
- error_free(err);
- }
- x86_cpu_filter_features(xc, false);
- x86_cpu_list_feature_names(xc->filtered_features, tail);
- object_unref(OBJECT(xc));
- }
- static void x86_cpu_definition_entry(gpointer data, gpointer user_data)
- {
- ObjectClass *oc = data;
- X86CPUClass *cc = X86_CPU_CLASS(oc);
- CpuDefinitionInfoList **cpu_list = user_data;
- CpuDefinitionInfo *info;
- info = g_malloc0(sizeof(*info));
- info->name = x86_cpu_class_get_model_name(cc);
- x86_cpu_class_check_missing_features(cc, &info->unavailable_features);
- info->has_unavailable_features = true;
- info->q_typename = g_strdup(object_class_get_name(oc));
- info->migration_safe = cc->migration_safe;
- info->has_migration_safe = true;
- info->q_static = cc->static_model;
- if (cc->model && cc->model->cpudef->deprecation_note) {
- info->deprecated = true;
- } else {
- info->deprecated = false;
- }
- /*
- * Old machine types won't report aliases, so that alias translation
- * doesn't break compatibility with previous QEMU versions.
- */
- if (default_cpu_version != CPU_VERSION_LEGACY) {
- info->alias_of = x86_cpu_class_get_alias_of(cc);
- }
- QAPI_LIST_PREPEND(*cpu_list, info);
- }
- CpuDefinitionInfoList *qmp_query_cpu_definitions(Error **errp)
- {
- CpuDefinitionInfoList *cpu_list = NULL;
- GSList *list = get_sorted_cpu_model_list();
- g_slist_foreach(list, x86_cpu_definition_entry, &cpu_list);
- g_slist_free(list);
- return cpu_list;
- }
- #endif /* !CONFIG_USER_ONLY */
- uint64_t x86_cpu_get_supported_feature_word(X86CPU *cpu, FeatureWord w)
- {
- FeatureWordInfo *wi = &feature_word_info[w];
- uint64_t r = 0;
- uint64_t unavail = 0;
- if (kvm_enabled()) {
- switch (wi->type) {
- case CPUID_FEATURE_WORD:
- r = kvm_arch_get_supported_cpuid(kvm_state, wi->cpuid.eax,
- wi->cpuid.ecx,
- wi->cpuid.reg);
- break;
- case MSR_FEATURE_WORD:
- r = kvm_arch_get_supported_msr_feature(kvm_state,
- wi->msr.index);
- break;
- }
- } else if (hvf_enabled()) {
- if (wi->type != CPUID_FEATURE_WORD) {
- return 0;
- }
- r = hvf_get_supported_cpuid(wi->cpuid.eax,
- wi->cpuid.ecx,
- wi->cpuid.reg);
- } else if (tcg_enabled()) {
- r = wi->tcg_features;
- } else {
- return ~0;
- }
- switch (w) {
- #ifndef TARGET_X86_64
- case FEAT_8000_0001_EDX:
- /*
- * 32-bit TCG can emulate 64-bit compatibility mode. If there is no
- * way for userspace to get out of its 32-bit jail, we can leave
- * the LM bit set.
- */
- unavail = tcg_enabled()
- ? CPUID_EXT2_LM & ~CPUID_EXT2_KERNEL_FEATURES
- : CPUID_EXT2_LM;
- break;
- #endif
- case FEAT_8000_0007_EBX:
- if (cpu && !IS_AMD_CPU(&cpu->env)) {
- /* Disable AMD machine check architecture for Intel CPU. */
- unavail = ~0;
- }
- break;
- case FEAT_7_0_EBX:
- #ifndef CONFIG_USER_ONLY
- if (!check_sgx_support()) {
- unavail = CPUID_7_0_EBX_SGX;
- }
- #endif
- break;
- case FEAT_7_0_ECX:
- #ifndef CONFIG_USER_ONLY
- if (!check_sgx_support()) {
- unavail = CPUID_7_0_ECX_SGX_LC;
- }
- #endif
- break;
- default:
- break;
- }
- r &= ~unavail;
- if (cpu && cpu->migratable) {
- r &= x86_cpu_get_migratable_flags(w);
- }
- return r;
- }
- static void x86_cpu_get_supported_cpuid(uint32_t func, uint32_t index,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
- {
- if (kvm_enabled()) {
- *eax = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_EAX);
- *ebx = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_EBX);
- *ecx = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_ECX);
- *edx = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_EDX);
- } else if (hvf_enabled()) {
- *eax = hvf_get_supported_cpuid(func, index, R_EAX);
- *ebx = hvf_get_supported_cpuid(func, index, R_EBX);
- *ecx = hvf_get_supported_cpuid(func, index, R_ECX);
- *edx = hvf_get_supported_cpuid(func, index, R_EDX);
- } else {
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- }
- }
- static void x86_cpu_get_cache_cpuid(uint32_t func, uint32_t index,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
- {
- uint32_t level, unused;
- /* Only return valid host leaves. */
- switch (func) {
- case 2:
- case 4:
- host_cpuid(0, 0, &level, &unused, &unused, &unused);
- break;
- case 0x80000005:
- case 0x80000006:
- case 0x8000001d:
- host_cpuid(0x80000000, 0, &level, &unused, &unused, &unused);
- break;
- default:
- return;
- }
- if (func > level) {
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- } else {
- host_cpuid(func, index, eax, ebx, ecx, edx);
- }
- }
- /*
- * Only for builtin_x86_defs models initialized with x86_register_cpudef_types.
- */
- void x86_cpu_apply_props(X86CPU *cpu, PropValue *props)
- {
- PropValue *pv;
- for (pv = props; pv->prop; pv++) {
- if (!pv->value) {
- continue;
- }
- object_property_parse(OBJECT(cpu), pv->prop, pv->value,
- &error_abort);
- }
- }
- /*
- * Apply properties for the CPU model version specified in model.
- * Only for builtin_x86_defs models initialized with x86_register_cpudef_types.
- */
- static void x86_cpu_apply_version_props(X86CPU *cpu, X86CPUModel *model)
- {
- const X86CPUVersionDefinition *vdef;
- X86CPUVersion version = x86_cpu_model_resolve_version(model);
- if (version == CPU_VERSION_LEGACY) {
- return;
- }
- for (vdef = x86_cpu_def_get_versions(model->cpudef); vdef->version; vdef++) {
- PropValue *p;
- for (p = vdef->props; p && p->prop; p++) {
- object_property_parse(OBJECT(cpu), p->prop, p->value,
- &error_abort);
- }
- if (vdef->version == version) {
- break;
- }
- }
- /*
- * If we reached the end of the list, version number was invalid
- */
- assert(vdef->version == version);
- }
- static const CPUCaches *x86_cpu_get_versioned_cache_info(X86CPU *cpu,
- X86CPUModel *model)
- {
- const X86CPUVersionDefinition *vdef;
- X86CPUVersion version = x86_cpu_model_resolve_version(model);
- const CPUCaches *cache_info = model->cpudef->cache_info;
- if (version == CPU_VERSION_LEGACY) {
- return cache_info;
- }
- for (vdef = x86_cpu_def_get_versions(model->cpudef); vdef->version; vdef++) {
- if (vdef->cache_info) {
- cache_info = vdef->cache_info;
- }
- if (vdef->version == version) {
- break;
- }
- }
- assert(vdef->version == version);
- return cache_info;
- }
- /*
- * Load data from X86CPUDefinition into a X86CPU object.
- * Only for builtin_x86_defs models initialized with x86_register_cpudef_types.
- */
- static void x86_cpu_load_model(X86CPU *cpu, X86CPUModel *model)
- {
- const X86CPUDefinition *def = model->cpudef;
- CPUX86State *env = &cpu->env;
- FeatureWord w;
- /*NOTE: any property set by this function should be returned by
- * x86_cpu_static_props(), so static expansion of
- * query-cpu-model-expansion is always complete.
- */
- /* CPU models only set _minimum_ values for level/xlevel: */
- object_property_set_uint(OBJECT(cpu), "min-level", def->level,
- &error_abort);
- object_property_set_uint(OBJECT(cpu), "min-xlevel", def->xlevel,
- &error_abort);
- object_property_set_int(OBJECT(cpu), "family", def->family, &error_abort);
- object_property_set_int(OBJECT(cpu), "model", def->model, &error_abort);
- object_property_set_int(OBJECT(cpu), "stepping", def->stepping,
- &error_abort);
- object_property_set_str(OBJECT(cpu), "model-id", def->model_id,
- &error_abort);
- for (w = 0; w < FEATURE_WORDS; w++) {
- env->features[w] = def->features[w];
- }
- /* legacy-cache defaults to 'off' if CPU model provides cache info */
- cpu->legacy_cache = !x86_cpu_get_versioned_cache_info(cpu, model);
- env->features[FEAT_1_ECX] |= CPUID_EXT_HYPERVISOR;
- /* sysenter isn't supported in compatibility mode on AMD,
- * syscall isn't supported in compatibility mode on Intel.
- * Normally we advertise the actual CPU vendor, but you can
- * override this using the 'vendor' property if you want to use
- * KVM's sysenter/syscall emulation in compatibility mode and
- * when doing cross vendor migration
- */
- /*
- * vendor property is set here but then overloaded with the
- * host cpu vendor for KVM and HVF.
- */
- object_property_set_str(OBJECT(cpu), "vendor", def->vendor, &error_abort);
- x86_cpu_apply_version_props(cpu, model);
- /*
- * Properties in versioned CPU model are not user specified features.
- * We can simply clear env->user_features here since it will be filled later
- * in x86_cpu_expand_features() based on plus_features and minus_features.
- */
- memset(&env->user_features, 0, sizeof(env->user_features));
- }
- static const gchar *x86_gdb_arch_name(CPUState *cs)
- {
- #ifdef TARGET_X86_64
- return "i386:x86-64";
- #else
- return "i386";
- #endif
- }
- static void x86_cpu_cpudef_class_init(ObjectClass *oc, void *data)
- {
- X86CPUModel *model = data;
- X86CPUClass *xcc = X86_CPU_CLASS(oc);
- CPUClass *cc = CPU_CLASS(oc);
- xcc->model = model;
- xcc->migration_safe = true;
- cc->deprecation_note = model->cpudef->deprecation_note;
- }
- static void x86_register_cpu_model_type(const char *name, X86CPUModel *model)
- {
- g_autofree char *typename = x86_cpu_type_name(name);
- TypeInfo ti = {
- .name = typename,
- .parent = TYPE_X86_CPU,
- .class_init = x86_cpu_cpudef_class_init,
- .class_data = model,
- };
- type_register(&ti);
- }
- /*
- * register builtin_x86_defs;
- * "max", "base" and subclasses ("host") are not registered here.
- * See x86_cpu_register_types for all model registrations.
- */
- static void x86_register_cpudef_types(const X86CPUDefinition *def)
- {
- X86CPUModel *m;
- const X86CPUVersionDefinition *vdef;
- /* AMD aliases are handled at runtime based on CPUID vendor, so
- * they shouldn't be set on the CPU model table.
- */
- assert(!(def->features[FEAT_8000_0001_EDX] & CPUID_EXT2_AMD_ALIASES));
- /* catch mistakes instead of silently truncating model_id when too long */
- assert(def->model_id && strlen(def->model_id) <= 48);
- /* Unversioned model: */
- m = g_new0(X86CPUModel, 1);
- m->cpudef = def;
- m->version = CPU_VERSION_AUTO;
- m->is_alias = true;
- x86_register_cpu_model_type(def->name, m);
- /* Versioned models: */
- for (vdef = x86_cpu_def_get_versions(def); vdef->version; vdef++) {
- g_autofree char *name =
- x86_cpu_versioned_model_name(def, vdef->version);
- m = g_new0(X86CPUModel, 1);
- m->cpudef = def;
- m->version = vdef->version;
- m->note = vdef->note;
- x86_register_cpu_model_type(name, m);
- if (vdef->alias) {
- X86CPUModel *am = g_new0(X86CPUModel, 1);
- am->cpudef = def;
- am->version = vdef->version;
- am->is_alias = true;
- x86_register_cpu_model_type(vdef->alias, am);
- }
- }
- }
- uint32_t cpu_x86_virtual_addr_width(CPUX86State *env)
- {
- if (env->features[FEAT_7_0_ECX] & CPUID_7_0_ECX_LA57) {
- return 57; /* 57 bits virtual */
- } else {
- return 48; /* 48 bits virtual */
- }
- }
- void cpu_x86_cpuid(CPUX86State *env, uint32_t index, uint32_t count,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
- {
- X86CPU *cpu = env_archcpu(env);
- CPUState *cs = env_cpu(env);
- uint32_t limit;
- uint32_t signature[3];
- X86CPUTopoInfo topo_info;
- uint32_t cores_per_pkg;
- uint32_t threads_per_pkg;
- topo_info.dies_per_pkg = env->nr_dies;
- topo_info.modules_per_die = env->nr_modules;
- topo_info.cores_per_module = cs->nr_cores / env->nr_dies / env->nr_modules;
- topo_info.threads_per_core = cs->nr_threads;
- cores_per_pkg = topo_info.cores_per_module * topo_info.modules_per_die *
- topo_info.dies_per_pkg;
- threads_per_pkg = cores_per_pkg * topo_info.threads_per_core;
- /* Calculate & apply limits for different index ranges */
- if (index >= 0xC0000000) {
- limit = env->cpuid_xlevel2;
- } else if (index >= 0x80000000) {
- limit = env->cpuid_xlevel;
- } else if (index >= 0x40000000) {
- limit = 0x40000001;
- } else {
- limit = env->cpuid_level;
- }
- if (index > limit) {
- /* Intel documentation states that invalid EAX input will
- * return the same information as EAX=cpuid_level
- * (Intel SDM Vol. 2A - Instruction Set Reference - CPUID)
- */
- index = env->cpuid_level;
- }
- switch(index) {
- case 0:
- *eax = env->cpuid_level;
- *ebx = env->cpuid_vendor1;
- *edx = env->cpuid_vendor2;
- *ecx = env->cpuid_vendor3;
- break;
- case 1:
- *eax = env->cpuid_version;
- *ebx = (cpu->apic_id << 24) |
- 8 << 8; /* CLFLUSH size in quad words, Linux wants it. */
- *ecx = env->features[FEAT_1_ECX];
- if ((*ecx & CPUID_EXT_XSAVE) && (env->cr[4] & CR4_OSXSAVE_MASK)) {
- *ecx |= CPUID_EXT_OSXSAVE;
- }
- *edx = env->features[FEAT_1_EDX];
- if (threads_per_pkg > 1) {
- *ebx |= threads_per_pkg << 16;
- *edx |= CPUID_HT;
- }
- if (!cpu->enable_pmu) {
- *ecx &= ~CPUID_EXT_PDCM;
- }
- break;
- case 2:
- /* cache info: needed for Pentium Pro compatibility */
- if (cpu->cache_info_passthrough) {
- x86_cpu_get_cache_cpuid(index, 0, eax, ebx, ecx, edx);
- break;
- } else if (cpu->vendor_cpuid_only && IS_AMD_CPU(env)) {
- *eax = *ebx = *ecx = *edx = 0;
- break;
- }
- *eax = 1; /* Number of CPUID[EAX=2] calls required */
- *ebx = 0;
- if (!cpu->enable_l3_cache) {
- *ecx = 0;
- } else {
- *ecx = cpuid2_cache_descriptor(env->cache_info_cpuid2.l3_cache);
- }
- *edx = (cpuid2_cache_descriptor(env->cache_info_cpuid2.l1d_cache) << 16) |
- (cpuid2_cache_descriptor(env->cache_info_cpuid2.l1i_cache) << 8) |
- (cpuid2_cache_descriptor(env->cache_info_cpuid2.l2_cache));
- break;
- case 4:
- /* cache info: needed for Core compatibility */
- if (cpu->cache_info_passthrough) {
- x86_cpu_get_cache_cpuid(index, count, eax, ebx, ecx, edx);
- /*
- * QEMU has its own number of cores/logical cpus,
- * set 24..14, 31..26 bit to configured values
- */
- if (*eax & 31) {
- int host_vcpus_per_cache = 1 + ((*eax & 0x3FFC000) >> 14);
- *eax &= ~0xFC000000;
- *eax |= max_core_ids_in_package(&topo_info) << 26;
- if (host_vcpus_per_cache > threads_per_pkg) {
- *eax &= ~0x3FFC000;
- /* Share the cache at package level. */
- *eax |= max_thread_ids_for_cache(&topo_info,
- CPU_TOPO_LEVEL_PACKAGE) << 14;
- }
- }
- } else if (cpu->vendor_cpuid_only && IS_AMD_CPU(env)) {
- *eax = *ebx = *ecx = *edx = 0;
- } else {
- *eax = 0;
- switch (count) {
- case 0: /* L1 dcache info */
- encode_cache_cpuid4(env->cache_info_cpuid4.l1d_cache,
- &topo_info,
- eax, ebx, ecx, edx);
- if (!cpu->l1_cache_per_core) {
- *eax &= ~MAKE_64BIT_MASK(14, 12);
- }
- break;
- case 1: /* L1 icache info */
- encode_cache_cpuid4(env->cache_info_cpuid4.l1i_cache,
- &topo_info,
- eax, ebx, ecx, edx);
- if (!cpu->l1_cache_per_core) {
- *eax &= ~MAKE_64BIT_MASK(14, 12);
- }
- break;
- case 2: /* L2 cache info */
- encode_cache_cpuid4(env->cache_info_cpuid4.l2_cache,
- &topo_info,
- eax, ebx, ecx, edx);
- break;
- case 3: /* L3 cache info */
- if (cpu->enable_l3_cache) {
- encode_cache_cpuid4(env->cache_info_cpuid4.l3_cache,
- &topo_info,
- eax, ebx, ecx, edx);
- break;
- }
- /* fall through */
- default: /* end of info */
- *eax = *ebx = *ecx = *edx = 0;
- break;
- }
- }
- break;
- case 5:
- /* MONITOR/MWAIT Leaf */
- *eax = cpu->mwait.eax; /* Smallest monitor-line size in bytes */
- *ebx = cpu->mwait.ebx; /* Largest monitor-line size in bytes */
- *ecx = cpu->mwait.ecx; /* flags */
- *edx = cpu->mwait.edx; /* mwait substates */
- break;
- case 6:
- /* Thermal and Power Leaf */
- *eax = env->features[FEAT_6_EAX];
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- break;
- case 7:
- /* Structured Extended Feature Flags Enumeration Leaf */
- if (count == 0) {
- /* Maximum ECX value for sub-leaves */
- *eax = env->cpuid_level_func7;
- *ebx = env->features[FEAT_7_0_EBX]; /* Feature flags */
- *ecx = env->features[FEAT_7_0_ECX]; /* Feature flags */
- if ((*ecx & CPUID_7_0_ECX_PKU) && env->cr[4] & CR4_PKE_MASK) {
- *ecx |= CPUID_7_0_ECX_OSPKE;
- }
- *edx = env->features[FEAT_7_0_EDX]; /* Feature flags */
- } else if (count == 1) {
- *eax = env->features[FEAT_7_1_EAX];
- *edx = env->features[FEAT_7_1_EDX];
- *ebx = 0;
- *ecx = 0;
- } else if (count == 2) {
- *edx = env->features[FEAT_7_2_EDX];
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- } else {
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- }
- break;
- case 9:
- /* Direct Cache Access Information Leaf */
- *eax = 0; /* Bits 0-31 in DCA_CAP MSR */
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- break;
- case 0xA:
- /* Architectural Performance Monitoring Leaf */
- if (cpu->enable_pmu) {
- x86_cpu_get_supported_cpuid(0xA, count, eax, ebx, ecx, edx);
- } else {
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- }
- break;
- case 0xB:
- /* Extended Topology Enumeration Leaf */
- if (!cpu->enable_cpuid_0xb) {
- *eax = *ebx = *ecx = *edx = 0;
- break;
- }
- *ecx = count & 0xff;
- *edx = cpu->apic_id;
- switch (count) {
- case 0:
- *eax = apicid_core_offset(&topo_info);
- *ebx = topo_info.threads_per_core;
- *ecx |= CPUID_B_ECX_TOPO_LEVEL_SMT << 8;
- break;
- case 1:
- *eax = apicid_pkg_offset(&topo_info);
- *ebx = threads_per_pkg;
- *ecx |= CPUID_B_ECX_TOPO_LEVEL_CORE << 8;
- break;
- default:
- *eax = 0;
- *ebx = 0;
- *ecx |= CPUID_B_ECX_TOPO_LEVEL_INVALID << 8;
- }
- assert(!(*eax & ~0x1f));
- *ebx &= 0xffff; /* The count doesn't need to be reliable. */
- break;
- case 0x1C:
- if (cpu->enable_pmu && (env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_ARCH_LBR)) {
- x86_cpu_get_supported_cpuid(0x1C, 0, eax, ebx, ecx, edx);
- *edx = 0;
- }
- break;
- case 0x1F:
- /* V2 Extended Topology Enumeration Leaf */
- if (!x86_has_extended_topo(env->avail_cpu_topo)) {
- *eax = *ebx = *ecx = *edx = 0;
- break;
- }
- encode_topo_cpuid1f(env, count, &topo_info, eax, ebx, ecx, edx);
- break;
- case 0xD: {
- /* Processor Extended State */
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- if (!(env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE)) {
- break;
- }
- if (count == 0) {
- *ecx = xsave_area_size(x86_cpu_xsave_xcr0_components(cpu), false);
- *eax = env->features[FEAT_XSAVE_XCR0_LO];
- *edx = env->features[FEAT_XSAVE_XCR0_HI];
- /*
- * The initial value of xcr0 and ebx == 0, On host without kvm
- * commit 412a3c41(e.g., CentOS 6), the ebx's value always == 0
- * even through guest update xcr0, this will crash some legacy guest
- * (e.g., CentOS 6), So set ebx == ecx to workaround it.
- */
- *ebx = kvm_enabled() ? *ecx : xsave_area_size(env->xcr0, false);
- } else if (count == 1) {
- uint64_t xstate = x86_cpu_xsave_xcr0_components(cpu) |
- x86_cpu_xsave_xss_components(cpu);
- *eax = env->features[FEAT_XSAVE];
- *ebx = xsave_area_size(xstate, true);
- *ecx = env->features[FEAT_XSAVE_XSS_LO];
- *edx = env->features[FEAT_XSAVE_XSS_HI];
- if (kvm_enabled() && cpu->enable_pmu &&
- (env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_ARCH_LBR) &&
- (*eax & CPUID_XSAVE_XSAVES)) {
- *ecx |= XSTATE_ARCH_LBR_MASK;
- } else {
- *ecx &= ~XSTATE_ARCH_LBR_MASK;
- }
- } else if (count == 0xf && cpu->enable_pmu
- && (env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_ARCH_LBR)) {
- x86_cpu_get_supported_cpuid(0xD, count, eax, ebx, ecx, edx);
- } else if (count < ARRAY_SIZE(x86_ext_save_areas)) {
- const ExtSaveArea *esa = &x86_ext_save_areas[count];
- if (x86_cpu_xsave_xcr0_components(cpu) & (1ULL << count)) {
- *eax = esa->size;
- *ebx = esa->offset;
- *ecx = esa->ecx &
- (ESA_FEATURE_ALIGN64_MASK | ESA_FEATURE_XFD_MASK);
- } else if (x86_cpu_xsave_xss_components(cpu) & (1ULL << count)) {
- *eax = esa->size;
- *ebx = 0;
- *ecx = 1;
- }
- }
- break;
- }
- case 0x12:
- #ifndef CONFIG_USER_ONLY
- if (!kvm_enabled() ||
- !(env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_SGX)) {
- *eax = *ebx = *ecx = *edx = 0;
- break;
- }
- /*
- * SGX sub-leafs CPUID.0x12.{0x2..N} enumerate EPC sections. Retrieve
- * the EPC properties, e.g. confidentiality and integrity, from the
- * host's first EPC section, i.e. assume there is one EPC section or
- * that all EPC sections have the same security properties.
- */
- if (count > 1) {
- uint64_t epc_addr, epc_size;
- if (sgx_epc_get_section(count - 2, &epc_addr, &epc_size)) {
- *eax = *ebx = *ecx = *edx = 0;
- break;
- }
- host_cpuid(index, 2, eax, ebx, ecx, edx);
- *eax = (uint32_t)(epc_addr & 0xfffff000) | 0x1;
- *ebx = (uint32_t)(epc_addr >> 32);
- *ecx = (uint32_t)(epc_size & 0xfffff000) | (*ecx & 0xf);
- *edx = (uint32_t)(epc_size >> 32);
- break;
- }
- /*
- * SGX sub-leafs CPUID.0x12.{0x0,0x1} are heavily dependent on hardware
- * and KVM, i.e. QEMU cannot emulate features to override what KVM
- * supports. Features can be further restricted by userspace, but not
- * made more permissive.
- */
- x86_cpu_get_supported_cpuid(0x12, count, eax, ebx, ecx, edx);
- if (count == 0) {
- *eax &= env->features[FEAT_SGX_12_0_EAX];
- *ebx &= env->features[FEAT_SGX_12_0_EBX];
- } else {
- *eax &= env->features[FEAT_SGX_12_1_EAX];
- *ebx &= 0; /* ebx reserve */
- *ecx &= env->features[FEAT_XSAVE_XCR0_LO];
- *edx &= env->features[FEAT_XSAVE_XCR0_HI];
- /* FP and SSE are always allowed regardless of XSAVE/XCR0. */
- *ecx |= XSTATE_FP_MASK | XSTATE_SSE_MASK;
- /* Access to PROVISIONKEY requires additional credentials. */
- if ((*eax & (1U << 4)) &&
- !kvm_enable_sgx_provisioning(cs->kvm_state)) {
- *eax &= ~(1U << 4);
- }
- }
- #endif
- break;
- case 0x14: {
- /* Intel Processor Trace Enumeration */
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- if (!(env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT) ||
- !kvm_enabled()) {
- break;
- }
- /*
- * If these are changed, they should stay in sync with
- * x86_cpu_filter_features().
- */
- if (count == 0) {
- *eax = INTEL_PT_MAX_SUBLEAF;
- *ebx = INTEL_PT_MINIMAL_EBX;
- *ecx = INTEL_PT_MINIMAL_ECX;
- if (env->features[FEAT_14_0_ECX] & CPUID_14_0_ECX_LIP) {
- *ecx |= CPUID_14_0_ECX_LIP;
- }
- } else if (count == 1) {
- *eax = INTEL_PT_MTC_BITMAP | INTEL_PT_ADDR_RANGES_NUM;
- *ebx = INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP;
- }
- break;
- }
- case 0x1D: {
- /* AMX TILE, for now hardcoded for Sapphire Rapids*/
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- if (!(env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_AMX_TILE)) {
- break;
- }
- if (count == 0) {
- /* Highest numbered palette subleaf */
- *eax = INTEL_AMX_TILE_MAX_SUBLEAF;
- } else if (count == 1) {
- *eax = INTEL_AMX_TOTAL_TILE_BYTES |
- (INTEL_AMX_BYTES_PER_TILE << 16);
- *ebx = INTEL_AMX_BYTES_PER_ROW | (INTEL_AMX_TILE_MAX_NAMES << 16);
- *ecx = INTEL_AMX_TILE_MAX_ROWS;
- }
- break;
- }
- case 0x1E: {
- /* AMX TMUL, for now hardcoded for Sapphire Rapids */
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- if (!(env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_AMX_TILE)) {
- break;
- }
- if (count == 0) {
- /* Highest numbered palette subleaf */
- *ebx = INTEL_AMX_TMUL_MAX_K | (INTEL_AMX_TMUL_MAX_N << 8);
- }
- break;
- }
- case 0x40000000:
- /*
- * CPUID code in kvm_arch_init_vcpu() ignores stuff
- * set here, but we restrict to TCG none the less.
- */
- if (tcg_enabled() && cpu->expose_tcg) {
- memcpy(signature, "TCGTCGTCGTCG", 12);
- *eax = 0x40000001;
- *ebx = signature[0];
- *ecx = signature[1];
- *edx = signature[2];
- } else {
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- }
- break;
- case 0x40000001:
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- break;
- case 0x80000000:
- *eax = env->cpuid_xlevel;
- *ebx = env->cpuid_vendor1;
- *edx = env->cpuid_vendor2;
- *ecx = env->cpuid_vendor3;
- break;
- case 0x80000001:
- *eax = env->cpuid_version;
- *ebx = 0;
- *ecx = env->features[FEAT_8000_0001_ECX];
- *edx = env->features[FEAT_8000_0001_EDX];
- /* The Linux kernel checks for the CMPLegacy bit and
- * discards multiple thread information if it is set.
- * So don't set it here for Intel to make Linux guests happy.
- */
- if (threads_per_pkg > 1) {
- if (env->cpuid_vendor1 != CPUID_VENDOR_INTEL_1 ||
- env->cpuid_vendor2 != CPUID_VENDOR_INTEL_2 ||
- env->cpuid_vendor3 != CPUID_VENDOR_INTEL_3) {
- *ecx |= 1 << 1; /* CmpLegacy bit */
- }
- }
- if (tcg_enabled() && env->cpuid_vendor1 == CPUID_VENDOR_INTEL_1 &&
- !(env->hflags & HF_LMA_MASK)) {
- *edx &= ~CPUID_EXT2_SYSCALL;
- }
- break;
- case 0x80000002:
- case 0x80000003:
- case 0x80000004:
- *eax = env->cpuid_model[(index - 0x80000002) * 4 + 0];
- *ebx = env->cpuid_model[(index - 0x80000002) * 4 + 1];
- *ecx = env->cpuid_model[(index - 0x80000002) * 4 + 2];
- *edx = env->cpuid_model[(index - 0x80000002) * 4 + 3];
- break;
- case 0x80000005:
- /* cache info (L1 cache) */
- if (cpu->cache_info_passthrough) {
- x86_cpu_get_cache_cpuid(index, 0, eax, ebx, ecx, edx);
- break;
- }
- *eax = (L1_DTLB_2M_ASSOC << 24) | (L1_DTLB_2M_ENTRIES << 16) |
- (L1_ITLB_2M_ASSOC << 8) | (L1_ITLB_2M_ENTRIES);
- *ebx = (L1_DTLB_4K_ASSOC << 24) | (L1_DTLB_4K_ENTRIES << 16) |
- (L1_ITLB_4K_ASSOC << 8) | (L1_ITLB_4K_ENTRIES);
- *ecx = encode_cache_cpuid80000005(env->cache_info_amd.l1d_cache);
- *edx = encode_cache_cpuid80000005(env->cache_info_amd.l1i_cache);
- break;
- case 0x80000006:
- /* cache info (L2 cache) */
- if (cpu->cache_info_passthrough) {
- x86_cpu_get_cache_cpuid(index, 0, eax, ebx, ecx, edx);
- break;
- }
- *eax = (AMD_ENC_ASSOC(L2_DTLB_2M_ASSOC) << 28) |
- (L2_DTLB_2M_ENTRIES << 16) |
- (AMD_ENC_ASSOC(L2_ITLB_2M_ASSOC) << 12) |
- (L2_ITLB_2M_ENTRIES);
- *ebx = (AMD_ENC_ASSOC(L2_DTLB_4K_ASSOC) << 28) |
- (L2_DTLB_4K_ENTRIES << 16) |
- (AMD_ENC_ASSOC(L2_ITLB_4K_ASSOC) << 12) |
- (L2_ITLB_4K_ENTRIES);
- encode_cache_cpuid80000006(env->cache_info_amd.l2_cache,
- cpu->enable_l3_cache ?
- env->cache_info_amd.l3_cache : NULL,
- ecx, edx);
- break;
- case 0x80000007:
- *eax = 0;
- *ebx = env->features[FEAT_8000_0007_EBX];
- *ecx = 0;
- *edx = env->features[FEAT_8000_0007_EDX];
- break;
- case 0x80000008:
- /* virtual & phys address size in low 2 bytes. */
- *eax = cpu->phys_bits;
- if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
- /* 64 bit processor */
- *eax |= (cpu_x86_virtual_addr_width(env) << 8);
- *eax |= (cpu->guest_phys_bits << 16);
- }
- *ebx = env->features[FEAT_8000_0008_EBX];
- if (threads_per_pkg > 1) {
- /*
- * Bits 15:12 is "The number of bits in the initial
- * Core::X86::Apic::ApicId[ApicId] value that indicate
- * thread ID within a package".
- * Bits 7:0 is "The number of threads in the package is NC+1"
- */
- *ecx = (apicid_pkg_offset(&topo_info) << 12) |
- (threads_per_pkg - 1);
- } else {
- *ecx = 0;
- }
- *edx = 0;
- break;
- case 0x8000000A:
- if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
- *eax = 0x00000001; /* SVM Revision */
- *ebx = 0x00000010; /* nr of ASIDs */
- *ecx = 0;
- *edx = env->features[FEAT_SVM]; /* optional features */
- } else {
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- }
- break;
- case 0x8000001D:
- *eax = 0;
- if (cpu->cache_info_passthrough) {
- x86_cpu_get_cache_cpuid(index, count, eax, ebx, ecx, edx);
- break;
- }
- switch (count) {
- case 0: /* L1 dcache info */
- encode_cache_cpuid8000001d(env->cache_info_amd.l1d_cache,
- &topo_info, eax, ebx, ecx, edx);
- break;
- case 1: /* L1 icache info */
- encode_cache_cpuid8000001d(env->cache_info_amd.l1i_cache,
- &topo_info, eax, ebx, ecx, edx);
- break;
- case 2: /* L2 cache info */
- encode_cache_cpuid8000001d(env->cache_info_amd.l2_cache,
- &topo_info, eax, ebx, ecx, edx);
- break;
- case 3: /* L3 cache info */
- encode_cache_cpuid8000001d(env->cache_info_amd.l3_cache,
- &topo_info, eax, ebx, ecx, edx);
- break;
- default: /* end of info */
- *eax = *ebx = *ecx = *edx = 0;
- break;
- }
- if (cpu->amd_topoext_features_only) {
- *edx &= CACHE_NO_INVD_SHARING | CACHE_INCLUSIVE;
- }
- break;
- case 0x8000001E:
- if (cpu->core_id <= 255) {
- encode_topo_cpuid8000001e(cpu, &topo_info, eax, ebx, ecx, edx);
- } else {
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- }
- break;
- case 0xC0000000:
- *eax = env->cpuid_xlevel2;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- break;
- case 0xC0000001:
- /* Support for VIA CPU's CPUID instruction */
- *eax = env->cpuid_version;
- *ebx = 0;
- *ecx = 0;
- *edx = env->features[FEAT_C000_0001_EDX];
- break;
- case 0xC0000002:
- case 0xC0000003:
- case 0xC0000004:
- /* Reserved for the future, and now filled with zero */
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- break;
- case 0x8000001F:
- *eax = *ebx = *ecx = *edx = 0;
- if (sev_enabled()) {
- *eax = 0x2;
- *eax |= sev_es_enabled() ? 0x8 : 0;
- *eax |= sev_snp_enabled() ? 0x10 : 0;
- *ebx = sev_get_cbit_position() & 0x3f; /* EBX[5:0] */
- *ebx |= (sev_get_reduced_phys_bits() & 0x3f) << 6; /* EBX[11:6] */
- }
- break;
- case 0x80000021:
- *eax = env->features[FEAT_8000_0021_EAX];
- *ebx = *ecx = *edx = 0;
- break;
- default:
- /* reserved values: zero */
- *eax = 0;
- *ebx = 0;
- *ecx = 0;
- *edx = 0;
- break;
- }
- }
- static void x86_cpu_set_sgxlepubkeyhash(CPUX86State *env)
- {
- #ifndef CONFIG_USER_ONLY
- /* Those default values are defined in Skylake HW */
- env->msr_ia32_sgxlepubkeyhash[0] = 0xa6053e051270b7acULL;
- env->msr_ia32_sgxlepubkeyhash[1] = 0x6cfbe8ba8b3b413dULL;
- env->msr_ia32_sgxlepubkeyhash[2] = 0xc4916d99f2b3735dULL;
- env->msr_ia32_sgxlepubkeyhash[3] = 0xd4f8c05909f9bb3bULL;
- #endif
- }
- static void x86_cpu_reset_hold(Object *obj, ResetType type)
- {
- CPUState *cs = CPU(obj);
- X86CPU *cpu = X86_CPU(cs);
- X86CPUClass *xcc = X86_CPU_GET_CLASS(obj);
- CPUX86State *env = &cpu->env;
- target_ulong cr4;
- uint64_t xcr0;
- int i;
- if (xcc->parent_phases.hold) {
- xcc->parent_phases.hold(obj, type);
- }
- memset(env, 0, offsetof(CPUX86State, end_reset_fields));
- env->old_exception = -1;
- /* init to reset state */
- env->int_ctl = 0;
- env->hflags2 |= HF2_GIF_MASK;
- env->hflags2 |= HF2_VGIF_MASK;
- env->hflags &= ~HF_GUEST_MASK;
- cpu_x86_update_cr0(env, 0x60000010);
- env->a20_mask = ~0x0;
- env->smbase = 0x30000;
- env->msr_smi_count = 0;
- env->idt.limit = 0xffff;
- env->gdt.limit = 0xffff;
- env->ldt.limit = 0xffff;
- env->ldt.flags = DESC_P_MASK | (2 << DESC_TYPE_SHIFT);
- env->tr.limit = 0xffff;
- env->tr.flags = DESC_P_MASK | (11 << DESC_TYPE_SHIFT);
- cpu_x86_load_seg_cache(env, R_CS, 0xf000, 0xffff0000, 0xffff,
- DESC_P_MASK | DESC_S_MASK | DESC_CS_MASK |
- DESC_R_MASK | DESC_A_MASK);
- cpu_x86_load_seg_cache(env, R_DS, 0, 0, 0xffff,
- DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
- DESC_A_MASK);
- cpu_x86_load_seg_cache(env, R_ES, 0, 0, 0xffff,
- DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
- DESC_A_MASK);
- cpu_x86_load_seg_cache(env, R_SS, 0, 0, 0xffff,
- DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
- DESC_A_MASK);
- cpu_x86_load_seg_cache(env, R_FS, 0, 0, 0xffff,
- DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
- DESC_A_MASK);
- cpu_x86_load_seg_cache(env, R_GS, 0, 0, 0xffff,
- DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
- DESC_A_MASK);
- env->eip = 0xfff0;
- env->regs[R_EDX] = env->cpuid_version;
- env->eflags = 0x2;
- /* FPU init */
- for (i = 0; i < 8; i++) {
- env->fptags[i] = 1;
- }
- cpu_set_fpuc(env, 0x37f);
- env->mxcsr = 0x1f80;
- /* All units are in INIT state. */
- env->xstate_bv = 0;
- env->pat = 0x0007040600070406ULL;
- if (kvm_enabled()) {
- /*
- * KVM handles TSC = 0 specially and thinks we are hot-plugging
- * a new CPU, use 1 instead to force a reset.
- */
- if (env->tsc != 0) {
- env->tsc = 1;
- }
- } else {
- env->tsc = 0;
- }
- env->msr_ia32_misc_enable = MSR_IA32_MISC_ENABLE_DEFAULT;
- if (env->features[FEAT_1_ECX] & CPUID_EXT_MONITOR) {
- env->msr_ia32_misc_enable |= MSR_IA32_MISC_ENABLE_MWAIT;
- }
- memset(env->dr, 0, sizeof(env->dr));
- env->dr[6] = DR6_FIXED_1;
- env->dr[7] = DR7_FIXED_1;
- cpu_breakpoint_remove_all(cs, BP_CPU);
- cpu_watchpoint_remove_all(cs, BP_CPU);
- cr4 = 0;
- xcr0 = XSTATE_FP_MASK;
- #ifdef CONFIG_USER_ONLY
- /* Enable all the features for user-mode. */
- if (env->features[FEAT_1_EDX] & CPUID_SSE) {
- xcr0 |= XSTATE_SSE_MASK;
- }
- for (i = 2; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
- const ExtSaveArea *esa = &x86_ext_save_areas[i];
- if (!((1 << i) & CPUID_XSTATE_XCR0_MASK)) {
- continue;
- }
- if (env->features[esa->feature] & esa->bits) {
- xcr0 |= 1ull << i;
- }
- }
- if (env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE) {
- cr4 |= CR4_OSFXSR_MASK | CR4_OSXSAVE_MASK;
- }
- if (env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_FSGSBASE) {
- cr4 |= CR4_FSGSBASE_MASK;
- }
- #endif
- env->xcr0 = xcr0;
- cpu_x86_update_cr4(env, cr4);
- /*
- * SDM 11.11.5 requires:
- * - IA32_MTRR_DEF_TYPE MSR.E = 0
- * - IA32_MTRR_PHYSMASKn.V = 0
- * All other bits are undefined. For simplification, zero it all.
- */
- env->mtrr_deftype = 0;
- memset(env->mtrr_var, 0, sizeof(env->mtrr_var));
- memset(env->mtrr_fixed, 0, sizeof(env->mtrr_fixed));
- env->interrupt_injected = -1;
- env->exception_nr = -1;
- env->exception_pending = 0;
- env->exception_injected = 0;
- env->exception_has_payload = false;
- env->exception_payload = 0;
- env->nmi_injected = false;
- env->triple_fault_pending = false;
- #if !defined(CONFIG_USER_ONLY)
- /* We hard-wire the BSP to the first CPU. */
- apic_designate_bsp(cpu->apic_state, cs->cpu_index == 0);
- cs->halted = !cpu_is_bsp(cpu);
- if (kvm_enabled()) {
- kvm_arch_reset_vcpu(cpu);
- }
- x86_cpu_set_sgxlepubkeyhash(env);
- env->amd_tsc_scale_msr = MSR_AMD64_TSC_RATIO_DEFAULT;
- #endif
- }
- void x86_cpu_after_reset(X86CPU *cpu)
- {
- #ifndef CONFIG_USER_ONLY
- if (kvm_enabled()) {
- kvm_arch_after_reset_vcpu(cpu);
- }
- if (cpu->apic_state) {
- device_cold_reset(cpu->apic_state);
- }
- #endif
- }
- static void mce_init(X86CPU *cpu)
- {
- CPUX86State *cenv = &cpu->env;
- unsigned int bank;
- if (((cenv->cpuid_version >> 8) & 0xf) >= 6
- && (cenv->features[FEAT_1_EDX] & (CPUID_MCE | CPUID_MCA)) ==
- (CPUID_MCE | CPUID_MCA)) {
- cenv->mcg_cap = MCE_CAP_DEF | MCE_BANKS_DEF |
- (cpu->enable_lmce ? MCG_LMCE_P : 0);
- cenv->mcg_ctl = ~(uint64_t)0;
- for (bank = 0; bank < MCE_BANKS_DEF; bank++) {
- cenv->mce_banks[bank * 4] = ~(uint64_t)0;
- }
- }
- }
- static void x86_cpu_adjust_level(X86CPU *cpu, uint32_t *min, uint32_t value)
- {
- if (*min < value) {
- *min = value;
- }
- }
- /* Increase cpuid_min_{level,xlevel,xlevel2} automatically, if appropriate */
- static void x86_cpu_adjust_feat_level(X86CPU *cpu, FeatureWord w)
- {
- CPUX86State *env = &cpu->env;
- FeatureWordInfo *fi = &feature_word_info[w];
- uint32_t eax = fi->cpuid.eax;
- uint32_t region = eax & 0xF0000000;
- assert(feature_word_info[w].type == CPUID_FEATURE_WORD);
- if (!env->features[w]) {
- return;
- }
- switch (region) {
- case 0x00000000:
- x86_cpu_adjust_level(cpu, &env->cpuid_min_level, eax);
- break;
- case 0x80000000:
- x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, eax);
- break;
- case 0xC0000000:
- x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel2, eax);
- break;
- }
- if (eax == 7) {
- x86_cpu_adjust_level(cpu, &env->cpuid_min_level_func7,
- fi->cpuid.ecx);
- }
- }
- /* Calculate XSAVE components based on the configured CPU feature flags */
- static void x86_cpu_enable_xsave_components(X86CPU *cpu)
- {
- CPUX86State *env = &cpu->env;
- int i;
- uint64_t mask;
- static bool request_perm;
- if (!(env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE)) {
- env->features[FEAT_XSAVE_XCR0_LO] = 0;
- env->features[FEAT_XSAVE_XCR0_HI] = 0;
- env->features[FEAT_XSAVE_XSS_LO] = 0;
- env->features[FEAT_XSAVE_XSS_HI] = 0;
- return;
- }
- mask = 0;
- for (i = 0; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
- const ExtSaveArea *esa = &x86_ext_save_areas[i];
- if (env->features[esa->feature] & esa->bits) {
- mask |= (1ULL << i);
- }
- }
- /* Only request permission for first vcpu */
- if (kvm_enabled() && !request_perm) {
- kvm_request_xsave_components(cpu, mask);
- request_perm = true;
- }
- env->features[FEAT_XSAVE_XCR0_LO] = mask & CPUID_XSTATE_XCR0_MASK;
- env->features[FEAT_XSAVE_XCR0_HI] = (mask & CPUID_XSTATE_XCR0_MASK) >> 32;
- env->features[FEAT_XSAVE_XSS_LO] = mask & CPUID_XSTATE_XSS_MASK;
- env->features[FEAT_XSAVE_XSS_HI] = (mask & CPUID_XSTATE_XSS_MASK) >> 32;
- }
- /***** Steps involved on loading and filtering CPUID data
- *
- * When initializing and realizing a CPU object, the steps
- * involved in setting up CPUID data are:
- *
- * 1) Loading CPU model definition (X86CPUDefinition). This is
- * implemented by x86_cpu_load_model() and should be completely
- * transparent, as it is done automatically by instance_init.
- * No code should need to look at X86CPUDefinition structs
- * outside instance_init.
- *
- * 2) CPU expansion. This is done by realize before CPUID
- * filtering, and will make sure host/accelerator data is
- * loaded for CPU models that depend on host capabilities
- * (e.g. "host"). Done by x86_cpu_expand_features().
- *
- * 3) CPUID filtering. This initializes extra data related to
- * CPUID, and checks if the host supports all capabilities
- * required by the CPU. Runnability of a CPU model is
- * determined at this step. Done by x86_cpu_filter_features().
- *
- * Some operations don't require all steps to be performed.
- * More precisely:
- *
- * - CPU instance creation (instance_init) will run only CPU
- * model loading. CPU expansion can't run at instance_init-time
- * because host/accelerator data may be not available yet.
- * - CPU realization will perform both CPU model expansion and CPUID
- * filtering, and return an error in case one of them fails.
- * - query-cpu-definitions needs to run all 3 steps. It needs
- * to run CPUID filtering, as the 'unavailable-features'
- * field is set based on the filtering results.
- * - The query-cpu-model-expansion QMP command only needs to run
- * CPU model loading and CPU expansion. It should not filter
- * any CPUID data based on host capabilities.
- */
- /* Expand CPU configuration data, based on configured features
- * and host/accelerator capabilities when appropriate.
- */
- void x86_cpu_expand_features(X86CPU *cpu, Error **errp)
- {
- CPUX86State *env = &cpu->env;
- FeatureWord w;
- int i;
- GList *l;
- for (l = plus_features; l; l = l->next) {
- const char *prop = l->data;
- if (!object_property_set_bool(OBJECT(cpu), prop, true, errp)) {
- return;
- }
- }
- for (l = minus_features; l; l = l->next) {
- const char *prop = l->data;
- if (!object_property_set_bool(OBJECT(cpu), prop, false, errp)) {
- return;
- }
- }
- /*TODO: Now cpu->max_features doesn't overwrite features
- * set using QOM properties, and we can convert
- * plus_features & minus_features to global properties
- * inside x86_cpu_parse_featurestr() too.
- */
- if (cpu->max_features) {
- for (w = 0; w < FEATURE_WORDS; w++) {
- /* Override only features that weren't set explicitly
- * by the user.
- */
- env->features[w] |=
- x86_cpu_get_supported_feature_word(cpu, w) &
- ~env->user_features[w] &
- ~feature_word_info[w].no_autoenable_flags;
- }
- }
- for (i = 0; i < ARRAY_SIZE(feature_dependencies); i++) {
- FeatureDep *d = &feature_dependencies[i];
- if (!(env->features[d->from.index] & d->from.mask)) {
- uint64_t unavailable_features = env->features[d->to.index] & d->to.mask;
- /* Not an error unless the dependent feature was added explicitly. */
- mark_unavailable_features(cpu, d->to.index,
- unavailable_features & env->user_features[d->to.index],
- "This feature depends on other features that were not requested");
- env->features[d->to.index] &= ~unavailable_features;
- }
- }
- if (!kvm_enabled() || !cpu->expose_kvm) {
- env->features[FEAT_KVM] = 0;
- }
- x86_cpu_enable_xsave_components(cpu);
- /* CPUID[EAX=7,ECX=0].EBX always increased level automatically: */
- x86_cpu_adjust_feat_level(cpu, FEAT_7_0_EBX);
- if (cpu->full_cpuid_auto_level) {
- x86_cpu_adjust_feat_level(cpu, FEAT_1_EDX);
- x86_cpu_adjust_feat_level(cpu, FEAT_1_ECX);
- x86_cpu_adjust_feat_level(cpu, FEAT_6_EAX);
- x86_cpu_adjust_feat_level(cpu, FEAT_7_0_ECX);
- x86_cpu_adjust_feat_level(cpu, FEAT_7_1_EAX);
- x86_cpu_adjust_feat_level(cpu, FEAT_7_1_EDX);
- x86_cpu_adjust_feat_level(cpu, FEAT_7_2_EDX);
- x86_cpu_adjust_feat_level(cpu, FEAT_8000_0001_EDX);
- x86_cpu_adjust_feat_level(cpu, FEAT_8000_0001_ECX);
- x86_cpu_adjust_feat_level(cpu, FEAT_8000_0007_EDX);
- x86_cpu_adjust_feat_level(cpu, FEAT_8000_0008_EBX);
- x86_cpu_adjust_feat_level(cpu, FEAT_C000_0001_EDX);
- x86_cpu_adjust_feat_level(cpu, FEAT_SVM);
- x86_cpu_adjust_feat_level(cpu, FEAT_XSAVE);
- /* Intel Processor Trace requires CPUID[0x14] */
- if ((env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT)) {
- if (cpu->intel_pt_auto_level) {
- x86_cpu_adjust_level(cpu, &cpu->env.cpuid_min_level, 0x14);
- } else if (cpu->env.cpuid_min_level < 0x14) {
- mark_unavailable_features(cpu, FEAT_7_0_EBX,
- CPUID_7_0_EBX_INTEL_PT,
- "Intel PT need CPUID leaf 0x14, please set by \"-cpu ...,intel-pt=on,min-level=0x14\"");
- }
- }
- /*
- * Intel CPU topology with multi-dies support requires CPUID[0x1F].
- * For AMD Rome/Milan, cpuid level is 0x10, and guest OS should detect
- * extended toplogy by leaf 0xB. Only adjust it for Intel CPU, unless
- * cpu->vendor_cpuid_only has been unset for compatibility with older
- * machine types.
- */
- if (x86_has_extended_topo(env->avail_cpu_topo) &&
- (IS_INTEL_CPU(env) || !cpu->vendor_cpuid_only)) {
- x86_cpu_adjust_level(cpu, &env->cpuid_min_level, 0x1F);
- }
- /* SVM requires CPUID[0x8000000A] */
- if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
- x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x8000000A);
- }
- /* SEV requires CPUID[0x8000001F] */
- if (sev_enabled()) {
- x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x8000001F);
- }
- if (env->features[FEAT_8000_0021_EAX]) {
- x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x80000021);
- }
- /* SGX requires CPUID[0x12] for EPC enumeration */
- if (env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_SGX) {
- x86_cpu_adjust_level(cpu, &env->cpuid_min_level, 0x12);
- }
- }
- /* Set cpuid_*level* based on cpuid_min_*level, if not explicitly set */
- if (env->cpuid_level_func7 == UINT32_MAX) {
- env->cpuid_level_func7 = env->cpuid_min_level_func7;
- }
- if (env->cpuid_level == UINT32_MAX) {
- env->cpuid_level = env->cpuid_min_level;
- }
- if (env->cpuid_xlevel == UINT32_MAX) {
- env->cpuid_xlevel = env->cpuid_min_xlevel;
- }
- if (env->cpuid_xlevel2 == UINT32_MAX) {
- env->cpuid_xlevel2 = env->cpuid_min_xlevel2;
- }
- if (kvm_enabled() && !kvm_hyperv_expand_features(cpu, errp)) {
- return;
- }
- }
- /*
- * Finishes initialization of CPUID data, filters CPU feature
- * words based on host availability of each feature.
- *
- * Returns: 0 if all flags are supported by the host, non-zero otherwise.
- */
- static void x86_cpu_filter_features(X86CPU *cpu, bool verbose)
- {
- CPUX86State *env = &cpu->env;
- FeatureWord w;
- const char *prefix = NULL;
- if (verbose) {
- prefix = accel_uses_host_cpuid()
- ? "host doesn't support requested feature"
- : "TCG doesn't support requested feature";
- }
- for (w = 0; w < FEATURE_WORDS; w++) {
- uint64_t host_feat =
- x86_cpu_get_supported_feature_word(NULL, w);
- uint64_t requested_features = env->features[w];
- uint64_t unavailable_features = requested_features & ~host_feat;
- mark_unavailable_features(cpu, w, unavailable_features, prefix);
- }
- /*
- * Check that KVM actually allows the processor tracing features that
- * are advertised by cpu_x86_cpuid(). Keep these two in sync.
- */
- if ((env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT) &&
- kvm_enabled()) {
- uint32_t eax_0, ebx_0, ecx_0, edx_0_unused;
- uint32_t eax_1, ebx_1, ecx_1_unused, edx_1_unused;
- x86_cpu_get_supported_cpuid(0x14, 0,
- &eax_0, &ebx_0, &ecx_0, &edx_0_unused);
- x86_cpu_get_supported_cpuid(0x14, 1,
- &eax_1, &ebx_1, &ecx_1_unused, &edx_1_unused);
- if (!eax_0 ||
- ((ebx_0 & INTEL_PT_MINIMAL_EBX) != INTEL_PT_MINIMAL_EBX) ||
- ((ecx_0 & INTEL_PT_MINIMAL_ECX) != INTEL_PT_MINIMAL_ECX) ||
- ((eax_1 & INTEL_PT_MTC_BITMAP) != INTEL_PT_MTC_BITMAP) ||
- ((eax_1 & INTEL_PT_ADDR_RANGES_NUM_MASK) <
- INTEL_PT_ADDR_RANGES_NUM) ||
- ((ebx_1 & (INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP)) !=
- (INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP)) ||
- ((ecx_0 & CPUID_14_0_ECX_LIP) !=
- (env->features[FEAT_14_0_ECX] & CPUID_14_0_ECX_LIP))) {
- /*
- * Processor Trace capabilities aren't configurable, so if the
- * host can't emulate the capabilities we report on
- * cpu_x86_cpuid(), intel-pt can't be enabled on the current host.
- */
- mark_unavailable_features(cpu, FEAT_7_0_EBX, CPUID_7_0_EBX_INTEL_PT, prefix);
- }
- }
- }
- static void x86_cpu_hyperv_realize(X86CPU *cpu)
- {
- size_t len;
- /* Hyper-V vendor id */
- if (!cpu->hyperv_vendor) {
- object_property_set_str(OBJECT(cpu), "hv-vendor-id", "Microsoft Hv",
- &error_abort);
- }
- len = strlen(cpu->hyperv_vendor);
- if (len > 12) {
- warn_report("hv-vendor-id truncated to 12 characters");
- len = 12;
- }
- memset(cpu->hyperv_vendor_id, 0, 12);
- memcpy(cpu->hyperv_vendor_id, cpu->hyperv_vendor, len);
- /* 'Hv#1' interface identification*/
- cpu->hyperv_interface_id[0] = 0x31237648;
- cpu->hyperv_interface_id[1] = 0;
- cpu->hyperv_interface_id[2] = 0;
- cpu->hyperv_interface_id[3] = 0;
- /* Hypervisor implementation limits */
- cpu->hyperv_limits[0] = 64;
- cpu->hyperv_limits[1] = 0;
- cpu->hyperv_limits[2] = 0;
- }
- static void x86_cpu_realizefn(DeviceState *dev, Error **errp)
- {
- CPUState *cs = CPU(dev);
- X86CPU *cpu = X86_CPU(dev);
- X86CPUClass *xcc = X86_CPU_GET_CLASS(dev);
- CPUX86State *env = &cpu->env;
- Error *local_err = NULL;
- unsigned requested_lbr_fmt;
- #if defined(CONFIG_TCG) && !defined(CONFIG_USER_ONLY)
- /* Use pc-relative instructions in system-mode */
- tcg_cflags_set(cs, CF_PCREL);
- #endif
- if (cpu->apic_id == UNASSIGNED_APIC_ID) {
- error_setg(errp, "apic-id property was not initialized properly");
- return;
- }
- /*
- * Process Hyper-V enlightenments.
- * Note: this currently has to happen before the expansion of CPU features.
- */
- x86_cpu_hyperv_realize(cpu);
- x86_cpu_expand_features(cpu, &local_err);
- if (local_err) {
- goto out;
- }
- /*
- * Override env->features[FEAT_PERF_CAPABILITIES].LBR_FMT
- * with user-provided setting.
- */
- if (cpu->lbr_fmt != ~PERF_CAP_LBR_FMT) {
- if ((cpu->lbr_fmt & PERF_CAP_LBR_FMT) != cpu->lbr_fmt) {
- error_setg(errp, "invalid lbr-fmt");
- return;
- }
- env->features[FEAT_PERF_CAPABILITIES] &= ~PERF_CAP_LBR_FMT;
- env->features[FEAT_PERF_CAPABILITIES] |= cpu->lbr_fmt;
- }
- /*
- * vPMU LBR is supported when 1) KVM is enabled 2) Option pmu=on and
- * 3)vPMU LBR format matches that of host setting.
- */
- requested_lbr_fmt =
- env->features[FEAT_PERF_CAPABILITIES] & PERF_CAP_LBR_FMT;
- if (requested_lbr_fmt && kvm_enabled()) {
- uint64_t host_perf_cap =
- x86_cpu_get_supported_feature_word(NULL, FEAT_PERF_CAPABILITIES);
- unsigned host_lbr_fmt = host_perf_cap & PERF_CAP_LBR_FMT;
- if (!cpu->enable_pmu) {
- error_setg(errp, "vPMU: LBR is unsupported without pmu=on");
- return;
- }
- if (requested_lbr_fmt != host_lbr_fmt) {
- error_setg(errp, "vPMU: the lbr-fmt value (0x%x) does not match "
- "the host value (0x%x).",
- requested_lbr_fmt, host_lbr_fmt);
- return;
- }
- }
- x86_cpu_filter_features(cpu, cpu->check_cpuid || cpu->enforce_cpuid);
- if (cpu->enforce_cpuid && x86_cpu_have_filtered_features(cpu)) {
- error_setg(&local_err,
- accel_uses_host_cpuid() ?
- "Host doesn't support requested features" :
- "TCG doesn't support requested features");
- goto out;
- }
- /* On AMD CPUs, some CPUID[8000_0001].EDX bits must match the bits on
- * CPUID[1].EDX.
- */
- if (IS_AMD_CPU(env)) {
- env->features[FEAT_8000_0001_EDX] &= ~CPUID_EXT2_AMD_ALIASES;
- env->features[FEAT_8000_0001_EDX] |= (env->features[FEAT_1_EDX]
- & CPUID_EXT2_AMD_ALIASES);
- }
- x86_cpu_set_sgxlepubkeyhash(env);
- /*
- * note: the call to the framework needs to happen after feature expansion,
- * but before the checks/modifications to ucode_rev, mwait, phys_bits.
- * These may be set by the accel-specific code,
- * and the results are subsequently checked / assumed in this function.
- */
- cpu_exec_realizefn(cs, &local_err);
- if (local_err != NULL) {
- error_propagate(errp, local_err);
- return;
- }
- if (xcc->host_cpuid_required && !accel_uses_host_cpuid()) {
- g_autofree char *name = x86_cpu_class_get_model_name(xcc);
- error_setg(&local_err, "CPU model '%s' requires KVM or HVF", name);
- goto out;
- }
- if (cpu->guest_phys_bits == -1) {
- /*
- * If it was not set by the user, or by the accelerator via
- * cpu_exec_realizefn, clear.
- */
- cpu->guest_phys_bits = 0;
- }
- if (cpu->ucode_rev == 0) {
- /*
- * The default is the same as KVM's. Note that this check
- * needs to happen after the evenual setting of ucode_rev in
- * accel-specific code in cpu_exec_realizefn.
- */
- if (IS_AMD_CPU(env)) {
- cpu->ucode_rev = 0x01000065;
- } else {
- cpu->ucode_rev = 0x100000000ULL;
- }
- }
- /*
- * mwait extended info: needed for Core compatibility
- * We always wake on interrupt even if host does not have the capability.
- *
- * requires the accel-specific code in cpu_exec_realizefn to
- * have already acquired the CPUID data into cpu->mwait.
- */
- cpu->mwait.ecx |= CPUID_MWAIT_EMX | CPUID_MWAIT_IBE;
- /* For 64bit systems think about the number of physical bits to present.
- * ideally this should be the same as the host; anything other than matching
- * the host can cause incorrect guest behaviour.
- * QEMU used to pick the magic value of 40 bits that corresponds to
- * consumer AMD devices but nothing else.
- *
- * Note that this code assumes features expansion has already been done
- * (as it checks for CPUID_EXT2_LM), and also assumes that potential
- * phys_bits adjustments to match the host have been already done in
- * accel-specific code in cpu_exec_realizefn.
- */
- if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
- if (cpu->phys_bits &&
- (cpu->phys_bits > TARGET_PHYS_ADDR_SPACE_BITS ||
- cpu->phys_bits < 32)) {
- error_setg(errp, "phys-bits should be between 32 and %u "
- " (but is %u)",
- TARGET_PHYS_ADDR_SPACE_BITS, cpu->phys_bits);
- return;
- }
- /*
- * 0 means it was not explicitly set by the user (or by machine
- * compat_props or by the host code in host-cpu.c).
- * In this case, the default is the value used by TCG (40).
- */
- if (cpu->phys_bits == 0) {
- cpu->phys_bits = TCG_PHYS_ADDR_BITS;
- }
- if (cpu->guest_phys_bits &&
- (cpu->guest_phys_bits > cpu->phys_bits ||
- cpu->guest_phys_bits < 32)) {
- error_setg(errp, "guest-phys-bits should be between 32 and %u "
- " (but is %u)",
- cpu->phys_bits, cpu->guest_phys_bits);
- return;
- }
- } else {
- /* For 32 bit systems don't use the user set value, but keep
- * phys_bits consistent with what we tell the guest.
- */
- if (cpu->phys_bits != 0) {
- error_setg(errp, "phys-bits is not user-configurable in 32 bit");
- return;
- }
- if (cpu->guest_phys_bits != 0) {
- error_setg(errp, "guest-phys-bits is not user-configurable in 32 bit");
- return;
- }
- if (env->features[FEAT_1_EDX] & (CPUID_PSE36 | CPUID_PAE)) {
- cpu->phys_bits = 36;
- } else {
- cpu->phys_bits = 32;
- }
- }
- /* Cache information initialization */
- if (!cpu->legacy_cache) {
- const CPUCaches *cache_info =
- x86_cpu_get_versioned_cache_info(cpu, xcc->model);
- if (!xcc->model || !cache_info) {
- g_autofree char *name = x86_cpu_class_get_model_name(xcc);
- error_setg(errp,
- "CPU model '%s' doesn't support legacy-cache=off", name);
- return;
- }
- env->cache_info_cpuid2 = env->cache_info_cpuid4 = env->cache_info_amd =
- *cache_info;
- } else {
- /* Build legacy cache information */
- env->cache_info_cpuid2.l1d_cache = &legacy_l1d_cache;
- env->cache_info_cpuid2.l1i_cache = &legacy_l1i_cache;
- env->cache_info_cpuid2.l2_cache = &legacy_l2_cache_cpuid2;
- env->cache_info_cpuid2.l3_cache = &legacy_l3_cache;
- env->cache_info_cpuid4.l1d_cache = &legacy_l1d_cache;
- env->cache_info_cpuid4.l1i_cache = &legacy_l1i_cache;
- env->cache_info_cpuid4.l2_cache = &legacy_l2_cache;
- env->cache_info_cpuid4.l3_cache = &legacy_l3_cache;
- env->cache_info_amd.l1d_cache = &legacy_l1d_cache_amd;
- env->cache_info_amd.l1i_cache = &legacy_l1i_cache_amd;
- env->cache_info_amd.l2_cache = &legacy_l2_cache_amd;
- env->cache_info_amd.l3_cache = &legacy_l3_cache;
- }
- #ifndef CONFIG_USER_ONLY
- MachineState *ms = MACHINE(qdev_get_machine());
- qemu_register_reset(x86_cpu_machine_reset_cb, cpu);
- if (cpu->env.features[FEAT_1_EDX] & CPUID_APIC || ms->smp.cpus > 1) {
- x86_cpu_apic_create(cpu, &local_err);
- if (local_err != NULL) {
- goto out;
- }
- }
- #endif
- mce_init(cpu);
- qemu_init_vcpu(cs);
- /*
- * Most Intel and certain AMD CPUs support hyperthreading. Even though QEMU
- * fixes this issue by adjusting CPUID_0000_0001_EBX and CPUID_8000_0008_ECX
- * based on inputs (sockets,cores,threads), it is still better to give
- * users a warning.
- *
- * NOTE: the following code has to follow qemu_init_vcpu(). Otherwise
- * cs->nr_threads hasn't be populated yet and the checking is incorrect.
- */
- if (IS_AMD_CPU(env) &&
- !(env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_TOPOEXT) &&
- cs->nr_threads > 1) {
- warn_report_once("This family of AMD CPU doesn't support "
- "hyperthreading(%d). Please configure -smp "
- "options properly or try enabling topoext "
- "feature.", cs->nr_threads);
- }
- #ifndef CONFIG_USER_ONLY
- x86_cpu_apic_realize(cpu, &local_err);
- if (local_err != NULL) {
- goto out;
- }
- #endif /* !CONFIG_USER_ONLY */
- cpu_reset(cs);
- xcc->parent_realize(dev, &local_err);
- out:
- if (local_err != NULL) {
- error_propagate(errp, local_err);
- return;
- }
- }
- static void x86_cpu_unrealizefn(DeviceState *dev)
- {
- X86CPU *cpu = X86_CPU(dev);
- X86CPUClass *xcc = X86_CPU_GET_CLASS(dev);
- #ifndef CONFIG_USER_ONLY
- cpu_remove_sync(CPU(dev));
- qemu_unregister_reset(x86_cpu_machine_reset_cb, dev);
- #endif
- if (cpu->apic_state) {
- object_unparent(OBJECT(cpu->apic_state));
- cpu->apic_state = NULL;
- }
- xcc->parent_unrealize(dev);
- }
- typedef struct BitProperty {
- FeatureWord w;
- uint64_t mask;
- } BitProperty;
- static void x86_cpu_get_bit_prop(Object *obj, Visitor *v, const char *name,
- void *opaque, Error **errp)
- {
- X86CPU *cpu = X86_CPU(obj);
- BitProperty *fp = opaque;
- uint64_t f = cpu->env.features[fp->w];
- bool value = (f & fp->mask) == fp->mask;
- visit_type_bool(v, name, &value, errp);
- }
- static void x86_cpu_set_bit_prop(Object *obj, Visitor *v, const char *name,
- void *opaque, Error **errp)
- {
- DeviceState *dev = DEVICE(obj);
- X86CPU *cpu = X86_CPU(obj);
- BitProperty *fp = opaque;
- bool value;
- if (dev->realized) {
- qdev_prop_set_after_realize(dev, name, errp);
- return;
- }
- if (!visit_type_bool(v, name, &value, errp)) {
- return;
- }
- if (value) {
- cpu->env.features[fp->w] |= fp->mask;
- } else {
- cpu->env.features[fp->w] &= ~fp->mask;
- }
- cpu->env.user_features[fp->w] |= fp->mask;
- }
- /* Register a boolean property to get/set a single bit in a uint32_t field.
- *
- * The same property name can be registered multiple times to make it affect
- * multiple bits in the same FeatureWord. In that case, the getter will return
- * true only if all bits are set.
- */
- static void x86_cpu_register_bit_prop(X86CPUClass *xcc,
- const char *prop_name,
- FeatureWord w,
- int bitnr)
- {
- ObjectClass *oc = OBJECT_CLASS(xcc);
- BitProperty *fp;
- ObjectProperty *op;
- uint64_t mask = (1ULL << bitnr);
- op = object_class_property_find(oc, prop_name);
- if (op) {
- fp = op->opaque;
- assert(fp->w == w);
- fp->mask |= mask;
- } else {
- fp = g_new0(BitProperty, 1);
- fp->w = w;
- fp->mask = mask;
- object_class_property_add(oc, prop_name, "bool",
- x86_cpu_get_bit_prop,
- x86_cpu_set_bit_prop,
- NULL, fp);
- }
- }
- static void x86_cpu_register_feature_bit_props(X86CPUClass *xcc,
- FeatureWord w,
- int bitnr)
- {
- FeatureWordInfo *fi = &feature_word_info[w];
- const char *name = fi->feat_names[bitnr];
- if (!name) {
- return;
- }
- /* Property names should use "-" instead of "_".
- * Old names containing underscores are registered as aliases
- * using object_property_add_alias()
- */
- assert(!strchr(name, '_'));
- /* aliases don't use "|" delimiters anymore, they are registered
- * manually using object_property_add_alias() */
- assert(!strchr(name, '|'));
- x86_cpu_register_bit_prop(xcc, name, w, bitnr);
- }
- static void x86_cpu_post_initfn(Object *obj)
- {
- accel_cpu_instance_init(CPU(obj));
- }
- static void x86_cpu_init_default_topo(X86CPU *cpu)
- {
- CPUX86State *env = &cpu->env;
- env->nr_modules = 1;
- env->nr_dies = 1;
- /* SMT, core and package levels are set by default. */
- set_bit(CPU_TOPO_LEVEL_SMT, env->avail_cpu_topo);
- set_bit(CPU_TOPO_LEVEL_CORE, env->avail_cpu_topo);
- set_bit(CPU_TOPO_LEVEL_PACKAGE, env->avail_cpu_topo);
- }
- static void x86_cpu_initfn(Object *obj)
- {
- X86CPU *cpu = X86_CPU(obj);
- X86CPUClass *xcc = X86_CPU_GET_CLASS(obj);
- CPUX86State *env = &cpu->env;
- x86_cpu_init_default_topo(cpu);
- object_property_add(obj, "feature-words", "X86CPUFeatureWordInfo",
- x86_cpu_get_feature_words,
- NULL, NULL, (void *)env->features);
- object_property_add(obj, "filtered-features", "X86CPUFeatureWordInfo",
- x86_cpu_get_feature_words,
- NULL, NULL, (void *)cpu->filtered_features);
- object_property_add_alias(obj, "sse3", obj, "pni");
- object_property_add_alias(obj, "pclmuldq", obj, "pclmulqdq");
- object_property_add_alias(obj, "sse4-1", obj, "sse4.1");
- object_property_add_alias(obj, "sse4-2", obj, "sse4.2");
- object_property_add_alias(obj, "xd", obj, "nx");
- object_property_add_alias(obj, "ffxsr", obj, "fxsr-opt");
- object_property_add_alias(obj, "i64", obj, "lm");
- object_property_add_alias(obj, "ds_cpl", obj, "ds-cpl");
- object_property_add_alias(obj, "tsc_adjust", obj, "tsc-adjust");
- object_property_add_alias(obj, "fxsr_opt", obj, "fxsr-opt");
- object_property_add_alias(obj, "lahf_lm", obj, "lahf-lm");
- object_property_add_alias(obj, "cmp_legacy", obj, "cmp-legacy");
- object_property_add_alias(obj, "nodeid_msr", obj, "nodeid-msr");
- object_property_add_alias(obj, "perfctr_core", obj, "perfctr-core");
- object_property_add_alias(obj, "perfctr_nb", obj, "perfctr-nb");
- object_property_add_alias(obj, "kvm_nopiodelay", obj, "kvm-nopiodelay");
- object_property_add_alias(obj, "kvm_mmu", obj, "kvm-mmu");
- object_property_add_alias(obj, "kvm_asyncpf", obj, "kvm-asyncpf");
- object_property_add_alias(obj, "kvm_asyncpf_int", obj, "kvm-asyncpf-int");
- object_property_add_alias(obj, "kvm_steal_time", obj, "kvm-steal-time");
- object_property_add_alias(obj, "kvm_pv_eoi", obj, "kvm-pv-eoi");
- object_property_add_alias(obj, "kvm_pv_unhalt", obj, "kvm-pv-unhalt");
- object_property_add_alias(obj, "kvm_poll_control", obj, "kvm-poll-control");
- object_property_add_alias(obj, "svm_lock", obj, "svm-lock");
- object_property_add_alias(obj, "nrip_save", obj, "nrip-save");
- object_property_add_alias(obj, "tsc_scale", obj, "tsc-scale");
- object_property_add_alias(obj, "vmcb_clean", obj, "vmcb-clean");
- object_property_add_alias(obj, "pause_filter", obj, "pause-filter");
- object_property_add_alias(obj, "sse4_1", obj, "sse4.1");
- object_property_add_alias(obj, "sse4_2", obj, "sse4.2");
- object_property_add_alias(obj, "hv-apicv", obj, "hv-avic");
- cpu->lbr_fmt = ~PERF_CAP_LBR_FMT;
- object_property_add_alias(obj, "lbr_fmt", obj, "lbr-fmt");
- if (xcc->model) {
- x86_cpu_load_model(cpu, xcc->model);
- }
- }
- static int64_t x86_cpu_get_arch_id(CPUState *cs)
- {
- X86CPU *cpu = X86_CPU(cs);
- return cpu->apic_id;
- }
- #if !defined(CONFIG_USER_ONLY)
- static bool x86_cpu_get_paging_enabled(const CPUState *cs)
- {
- X86CPU *cpu = X86_CPU(cs);
- return cpu->env.cr[0] & CR0_PG_MASK;
- }
- #endif /* !CONFIG_USER_ONLY */
- static void x86_cpu_set_pc(CPUState *cs, vaddr value)
- {
- X86CPU *cpu = X86_CPU(cs);
- cpu->env.eip = value;
- }
- static vaddr x86_cpu_get_pc(CPUState *cs)
- {
- X86CPU *cpu = X86_CPU(cs);
- /* Match cpu_get_tb_cpu_state. */
- return cpu->env.eip + cpu->env.segs[R_CS].base;
- }
- int x86_cpu_pending_interrupt(CPUState *cs, int interrupt_request)
- {
- X86CPU *cpu = X86_CPU(cs);
- CPUX86State *env = &cpu->env;
- #if !defined(CONFIG_USER_ONLY)
- if (interrupt_request & CPU_INTERRUPT_POLL) {
- return CPU_INTERRUPT_POLL;
- }
- #endif
- if (interrupt_request & CPU_INTERRUPT_SIPI) {
- return CPU_INTERRUPT_SIPI;
- }
- if (env->hflags2 & HF2_GIF_MASK) {
- if ((interrupt_request & CPU_INTERRUPT_SMI) &&
- !(env->hflags & HF_SMM_MASK)) {
- return CPU_INTERRUPT_SMI;
- } else if ((interrupt_request & CPU_INTERRUPT_NMI) &&
- !(env->hflags2 & HF2_NMI_MASK)) {
- return CPU_INTERRUPT_NMI;
- } else if (interrupt_request & CPU_INTERRUPT_MCE) {
- return CPU_INTERRUPT_MCE;
- } else if ((interrupt_request & CPU_INTERRUPT_HARD) &&
- (((env->hflags2 & HF2_VINTR_MASK) &&
- (env->hflags2 & HF2_HIF_MASK)) ||
- (!(env->hflags2 & HF2_VINTR_MASK) &&
- (env->eflags & IF_MASK &&
- !(env->hflags & HF_INHIBIT_IRQ_MASK))))) {
- return CPU_INTERRUPT_HARD;
- #if !defined(CONFIG_USER_ONLY)
- } else if (env->hflags2 & HF2_VGIF_MASK) {
- if((interrupt_request & CPU_INTERRUPT_VIRQ) &&
- (env->eflags & IF_MASK) &&
- !(env->hflags & HF_INHIBIT_IRQ_MASK)) {
- return CPU_INTERRUPT_VIRQ;
- }
- #endif
- }
- }
- return 0;
- }
- static bool x86_cpu_has_work(CPUState *cs)
- {
- return x86_cpu_pending_interrupt(cs, cs->interrupt_request) != 0;
- }
- int x86_mmu_index_pl(CPUX86State *env, unsigned pl)
- {
- int mmu_index_32 = (env->hflags & HF_CS64_MASK) ? 0 : 1;
- int mmu_index_base =
- pl == 3 ? MMU_USER64_IDX :
- !(env->hflags & HF_SMAP_MASK) ? MMU_KNOSMAP64_IDX :
- (env->eflags & AC_MASK) ? MMU_KNOSMAP64_IDX : MMU_KSMAP64_IDX;
- return mmu_index_base + mmu_index_32;
- }
- static int x86_cpu_mmu_index(CPUState *cs, bool ifetch)
- {
- CPUX86State *env = cpu_env(cs);
- return x86_mmu_index_pl(env, env->hflags & HF_CPL_MASK);
- }
- static int x86_mmu_index_kernel_pl(CPUX86State *env, unsigned pl)
- {
- int mmu_index_32 = (env->hflags & HF_LMA_MASK) ? 0 : 1;
- int mmu_index_base =
- !(env->hflags & HF_SMAP_MASK) ? MMU_KNOSMAP64_IDX :
- (pl < 3 && (env->eflags & AC_MASK)
- ? MMU_KNOSMAP64_IDX : MMU_KSMAP64_IDX);
- return mmu_index_base + mmu_index_32;
- }
- int cpu_mmu_index_kernel(CPUX86State *env)
- {
- return x86_mmu_index_kernel_pl(env, env->hflags & HF_CPL_MASK);
- }
- static void x86_disas_set_info(CPUState *cs, disassemble_info *info)
- {
- X86CPU *cpu = X86_CPU(cs);
- CPUX86State *env = &cpu->env;
- info->mach = (env->hflags & HF_CS64_MASK ? bfd_mach_x86_64
- : env->hflags & HF_CS32_MASK ? bfd_mach_i386_i386
- : bfd_mach_i386_i8086);
- info->cap_arch = CS_ARCH_X86;
- info->cap_mode = (env->hflags & HF_CS64_MASK ? CS_MODE_64
- : env->hflags & HF_CS32_MASK ? CS_MODE_32
- : CS_MODE_16);
- info->cap_insn_unit = 1;
- info->cap_insn_split = 8;
- }
- void x86_update_hflags(CPUX86State *env)
- {
- uint32_t hflags;
- #define HFLAG_COPY_MASK \
- ~( HF_CPL_MASK | HF_PE_MASK | HF_MP_MASK | HF_EM_MASK | \
- HF_TS_MASK | HF_TF_MASK | HF_VM_MASK | HF_IOPL_MASK | \
- HF_OSFXSR_MASK | HF_LMA_MASK | HF_CS32_MASK | \
- HF_SS32_MASK | HF_CS64_MASK | HF_ADDSEG_MASK)
- hflags = env->hflags & HFLAG_COPY_MASK;
- hflags |= (env->segs[R_SS].flags >> DESC_DPL_SHIFT) & HF_CPL_MASK;
- hflags |= (env->cr[0] & CR0_PE_MASK) << (HF_PE_SHIFT - CR0_PE_SHIFT);
- hflags |= (env->cr[0] << (HF_MP_SHIFT - CR0_MP_SHIFT)) &
- (HF_MP_MASK | HF_EM_MASK | HF_TS_MASK);
- hflags |= (env->eflags & (HF_TF_MASK | HF_VM_MASK | HF_IOPL_MASK));
- if (env->cr[4] & CR4_OSFXSR_MASK) {
- hflags |= HF_OSFXSR_MASK;
- }
- if (env->efer & MSR_EFER_LMA) {
- hflags |= HF_LMA_MASK;
- }
- if ((hflags & HF_LMA_MASK) && (env->segs[R_CS].flags & DESC_L_MASK)) {
- hflags |= HF_CS32_MASK | HF_SS32_MASK | HF_CS64_MASK;
- } else {
- hflags |= (env->segs[R_CS].flags & DESC_B_MASK) >>
- (DESC_B_SHIFT - HF_CS32_SHIFT);
- hflags |= (env->segs[R_SS].flags & DESC_B_MASK) >>
- (DESC_B_SHIFT - HF_SS32_SHIFT);
- if (!(env->cr[0] & CR0_PE_MASK) || (env->eflags & VM_MASK) ||
- !(hflags & HF_CS32_MASK)) {
- hflags |= HF_ADDSEG_MASK;
- } else {
- hflags |= ((env->segs[R_DS].base | env->segs[R_ES].base |
- env->segs[R_SS].base) != 0) << HF_ADDSEG_SHIFT;
- }
- }
- env->hflags = hflags;
- }
- static Property x86_cpu_properties[] = {
- #ifdef CONFIG_USER_ONLY
- /* apic_id = 0 by default for *-user, see commit 9886e834 */
- DEFINE_PROP_UINT32("apic-id", X86CPU, apic_id, 0),
- DEFINE_PROP_INT32("thread-id", X86CPU, thread_id, 0),
- DEFINE_PROP_INT32("core-id", X86CPU, core_id, 0),
- DEFINE_PROP_INT32("module-id", X86CPU, module_id, 0),
- DEFINE_PROP_INT32("die-id", X86CPU, die_id, 0),
- DEFINE_PROP_INT32("socket-id", X86CPU, socket_id, 0),
- #else
- DEFINE_PROP_UINT32("apic-id", X86CPU, apic_id, UNASSIGNED_APIC_ID),
- DEFINE_PROP_INT32("thread-id", X86CPU, thread_id, -1),
- DEFINE_PROP_INT32("core-id", X86CPU, core_id, -1),
- DEFINE_PROP_INT32("module-id", X86CPU, module_id, -1),
- DEFINE_PROP_INT32("die-id", X86CPU, die_id, -1),
- DEFINE_PROP_INT32("socket-id", X86CPU, socket_id, -1),
- #endif
- DEFINE_PROP_INT32("node-id", X86CPU, node_id, CPU_UNSET_NUMA_NODE_ID),
- DEFINE_PROP_BOOL("pmu", X86CPU, enable_pmu, false),
- DEFINE_PROP_UINT64_CHECKMASK("lbr-fmt", X86CPU, lbr_fmt, PERF_CAP_LBR_FMT),
- DEFINE_PROP_UINT32("hv-spinlocks", X86CPU, hyperv_spinlock_attempts,
- HYPERV_SPINLOCK_NEVER_NOTIFY),
- DEFINE_PROP_BIT64("hv-relaxed", X86CPU, hyperv_features,
- HYPERV_FEAT_RELAXED, 0),
- DEFINE_PROP_BIT64("hv-vapic", X86CPU, hyperv_features,
- HYPERV_FEAT_VAPIC, 0),
- DEFINE_PROP_BIT64("hv-time", X86CPU, hyperv_features,
- HYPERV_FEAT_TIME, 0),
- DEFINE_PROP_BIT64("hv-crash", X86CPU, hyperv_features,
- HYPERV_FEAT_CRASH, 0),
- DEFINE_PROP_BIT64("hv-reset", X86CPU, hyperv_features,
- HYPERV_FEAT_RESET, 0),
- DEFINE_PROP_BIT64("hv-vpindex", X86CPU, hyperv_features,
- HYPERV_FEAT_VPINDEX, 0),
- DEFINE_PROP_BIT64("hv-runtime", X86CPU, hyperv_features,
- HYPERV_FEAT_RUNTIME, 0),
- DEFINE_PROP_BIT64("hv-synic", X86CPU, hyperv_features,
- HYPERV_FEAT_SYNIC, 0),
- DEFINE_PROP_BIT64("hv-stimer", X86CPU, hyperv_features,
- HYPERV_FEAT_STIMER, 0),
- DEFINE_PROP_BIT64("hv-frequencies", X86CPU, hyperv_features,
- HYPERV_FEAT_FREQUENCIES, 0),
- DEFINE_PROP_BIT64("hv-reenlightenment", X86CPU, hyperv_features,
- HYPERV_FEAT_REENLIGHTENMENT, 0),
- DEFINE_PROP_BIT64("hv-tlbflush", X86CPU, hyperv_features,
- HYPERV_FEAT_TLBFLUSH, 0),
- DEFINE_PROP_BIT64("hv-evmcs", X86CPU, hyperv_features,
- HYPERV_FEAT_EVMCS, 0),
- DEFINE_PROP_BIT64("hv-ipi", X86CPU, hyperv_features,
- HYPERV_FEAT_IPI, 0),
- DEFINE_PROP_BIT64("hv-stimer-direct", X86CPU, hyperv_features,
- HYPERV_FEAT_STIMER_DIRECT, 0),
- DEFINE_PROP_BIT64("hv-avic", X86CPU, hyperv_features,
- HYPERV_FEAT_AVIC, 0),
- DEFINE_PROP_BIT64("hv-emsr-bitmap", X86CPU, hyperv_features,
- HYPERV_FEAT_MSR_BITMAP, 0),
- DEFINE_PROP_BIT64("hv-xmm-input", X86CPU, hyperv_features,
- HYPERV_FEAT_XMM_INPUT, 0),
- DEFINE_PROP_BIT64("hv-tlbflush-ext", X86CPU, hyperv_features,
- HYPERV_FEAT_TLBFLUSH_EXT, 0),
- DEFINE_PROP_BIT64("hv-tlbflush-direct", X86CPU, hyperv_features,
- HYPERV_FEAT_TLBFLUSH_DIRECT, 0),
- DEFINE_PROP_ON_OFF_AUTO("hv-no-nonarch-coresharing", X86CPU,
- hyperv_no_nonarch_cs, ON_OFF_AUTO_OFF),
- DEFINE_PROP_BIT64("hv-syndbg", X86CPU, hyperv_features,
- HYPERV_FEAT_SYNDBG, 0),
- DEFINE_PROP_BOOL("hv-passthrough", X86CPU, hyperv_passthrough, false),
- DEFINE_PROP_BOOL("hv-enforce-cpuid", X86CPU, hyperv_enforce_cpuid, false),
- /* WS2008R2 identify by default */
- DEFINE_PROP_UINT32("hv-version-id-build", X86CPU, hyperv_ver_id_build,
- 0x3839),
- DEFINE_PROP_UINT16("hv-version-id-major", X86CPU, hyperv_ver_id_major,
- 0x000A),
- DEFINE_PROP_UINT16("hv-version-id-minor", X86CPU, hyperv_ver_id_minor,
- 0x0000),
- DEFINE_PROP_UINT32("hv-version-id-spack", X86CPU, hyperv_ver_id_sp, 0),
- DEFINE_PROP_UINT8("hv-version-id-sbranch", X86CPU, hyperv_ver_id_sb, 0),
- DEFINE_PROP_UINT32("hv-version-id-snumber", X86CPU, hyperv_ver_id_sn, 0),
- DEFINE_PROP_BOOL("check", X86CPU, check_cpuid, true),
- DEFINE_PROP_BOOL("enforce", X86CPU, enforce_cpuid, false),
- DEFINE_PROP_BOOL("x-force-features", X86CPU, force_features, false),
- DEFINE_PROP_BOOL("kvm", X86CPU, expose_kvm, true),
- DEFINE_PROP_UINT32("phys-bits", X86CPU, phys_bits, 0),
- DEFINE_PROP_UINT32("guest-phys-bits", X86CPU, guest_phys_bits, -1),
- DEFINE_PROP_BOOL("host-phys-bits", X86CPU, host_phys_bits, false),
- DEFINE_PROP_UINT8("host-phys-bits-limit", X86CPU, host_phys_bits_limit, 0),
- DEFINE_PROP_BOOL("fill-mtrr-mask", X86CPU, fill_mtrr_mask, true),
- DEFINE_PROP_UINT32("level-func7", X86CPU, env.cpuid_level_func7,
- UINT32_MAX),
- DEFINE_PROP_UINT32("level", X86CPU, env.cpuid_level, UINT32_MAX),
- DEFINE_PROP_UINT32("xlevel", X86CPU, env.cpuid_xlevel, UINT32_MAX),
- DEFINE_PROP_UINT32("xlevel2", X86CPU, env.cpuid_xlevel2, UINT32_MAX),
- DEFINE_PROP_UINT32("min-level", X86CPU, env.cpuid_min_level, 0),
- DEFINE_PROP_UINT32("min-xlevel", X86CPU, env.cpuid_min_xlevel, 0),
- DEFINE_PROP_UINT32("min-xlevel2", X86CPU, env.cpuid_min_xlevel2, 0),
- DEFINE_PROP_UINT64("ucode-rev", X86CPU, ucode_rev, 0),
- DEFINE_PROP_BOOL("full-cpuid-auto-level", X86CPU, full_cpuid_auto_level, true),
- DEFINE_PROP_STRING("hv-vendor-id", X86CPU, hyperv_vendor),
- DEFINE_PROP_BOOL("cpuid-0xb", X86CPU, enable_cpuid_0xb, true),
- DEFINE_PROP_BOOL("x-vendor-cpuid-only", X86CPU, vendor_cpuid_only, true),
- DEFINE_PROP_BOOL("x-amd-topoext-features-only", X86CPU, amd_topoext_features_only, true),
- DEFINE_PROP_BOOL("lmce", X86CPU, enable_lmce, false),
- DEFINE_PROP_BOOL("l3-cache", X86CPU, enable_l3_cache, true),
- DEFINE_PROP_BOOL("kvm-pv-enforce-cpuid", X86CPU, kvm_pv_enforce_cpuid,
- false),
- DEFINE_PROP_BOOL("vmware-cpuid-freq", X86CPU, vmware_cpuid_freq, true),
- DEFINE_PROP_BOOL("tcg-cpuid", X86CPU, expose_tcg, true),
- DEFINE_PROP_BOOL("x-migrate-smi-count", X86CPU, migrate_smi_count,
- true),
- /*
- * lecacy_cache defaults to true unless the CPU model provides its
- * own cache information (see x86_cpu_load_def()).
- */
- DEFINE_PROP_BOOL("legacy-cache", X86CPU, legacy_cache, true),
- DEFINE_PROP_BOOL("legacy-multi-node", X86CPU, legacy_multi_node, false),
- DEFINE_PROP_BOOL("xen-vapic", X86CPU, xen_vapic, false),
- /*
- * From "Requirements for Implementing the Microsoft
- * Hypervisor Interface":
- * https://docs.microsoft.com/en-us/virtualization/hyper-v-on-windows/reference/tlfs
- *
- * "Starting with Windows Server 2012 and Windows 8, if
- * CPUID.40000005.EAX contains a value of -1, Windows assumes that
- * the hypervisor imposes no specific limit to the number of VPs.
- * In this case, Windows Server 2012 guest VMs may use more than
- * 64 VPs, up to the maximum supported number of processors applicable
- * to the specific Windows version being used."
- */
- DEFINE_PROP_INT32("x-hv-max-vps", X86CPU, hv_max_vps, -1),
- DEFINE_PROP_BOOL("x-hv-synic-kvm-only", X86CPU, hyperv_synic_kvm_only,
- false),
- DEFINE_PROP_BOOL("x-intel-pt-auto-level", X86CPU, intel_pt_auto_level,
- true),
- DEFINE_PROP_BOOL("x-l1-cache-per-thread", X86CPU, l1_cache_per_core, true),
- DEFINE_PROP_END_OF_LIST()
- };
- #ifndef CONFIG_USER_ONLY
- #include "hw/core/sysemu-cpu-ops.h"
- static const struct SysemuCPUOps i386_sysemu_ops = {
- .get_memory_mapping = x86_cpu_get_memory_mapping,
- .get_paging_enabled = x86_cpu_get_paging_enabled,
- .get_phys_page_attrs_debug = x86_cpu_get_phys_page_attrs_debug,
- .asidx_from_attrs = x86_asidx_from_attrs,
- .get_crash_info = x86_cpu_get_crash_info,
- .write_elf32_note = x86_cpu_write_elf32_note,
- .write_elf64_note = x86_cpu_write_elf64_note,
- .write_elf32_qemunote = x86_cpu_write_elf32_qemunote,
- .write_elf64_qemunote = x86_cpu_write_elf64_qemunote,
- .legacy_vmsd = &vmstate_x86_cpu,
- };
- #endif
- static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
- {
- X86CPUClass *xcc = X86_CPU_CLASS(oc);
- CPUClass *cc = CPU_CLASS(oc);
- DeviceClass *dc = DEVICE_CLASS(oc);
- ResettableClass *rc = RESETTABLE_CLASS(oc);
- FeatureWord w;
- device_class_set_parent_realize(dc, x86_cpu_realizefn,
- &xcc->parent_realize);
- device_class_set_parent_unrealize(dc, x86_cpu_unrealizefn,
- &xcc->parent_unrealize);
- device_class_set_props(dc, x86_cpu_properties);
- resettable_class_set_parent_phases(rc, NULL, x86_cpu_reset_hold, NULL,
- &xcc->parent_phases);
- cc->reset_dump_flags = CPU_DUMP_FPU | CPU_DUMP_CCOP;
- cc->class_by_name = x86_cpu_class_by_name;
- cc->parse_features = x86_cpu_parse_featurestr;
- cc->has_work = x86_cpu_has_work;
- cc->mmu_index = x86_cpu_mmu_index;
- cc->dump_state = x86_cpu_dump_state;
- cc->set_pc = x86_cpu_set_pc;
- cc->get_pc = x86_cpu_get_pc;
- cc->gdb_read_register = x86_cpu_gdb_read_register;
- cc->gdb_write_register = x86_cpu_gdb_write_register;
- cc->get_arch_id = x86_cpu_get_arch_id;
- #ifndef CONFIG_USER_ONLY
- cc->sysemu_ops = &i386_sysemu_ops;
- #endif /* !CONFIG_USER_ONLY */
- cc->gdb_arch_name = x86_gdb_arch_name;
- #ifdef TARGET_X86_64
- cc->gdb_core_xml_file = "i386-64bit.xml";
- #else
- cc->gdb_core_xml_file = "i386-32bit.xml";
- #endif
- cc->disas_set_info = x86_disas_set_info;
- dc->user_creatable = true;
- object_class_property_add(oc, "family", "int",
- x86_cpuid_version_get_family,
- x86_cpuid_version_set_family, NULL, NULL);
- object_class_property_add(oc, "model", "int",
- x86_cpuid_version_get_model,
- x86_cpuid_version_set_model, NULL, NULL);
- object_class_property_add(oc, "stepping", "int",
- x86_cpuid_version_get_stepping,
- x86_cpuid_version_set_stepping, NULL, NULL);
- object_class_property_add_str(oc, "vendor",
- x86_cpuid_get_vendor,
- x86_cpuid_set_vendor);
- object_class_property_add_str(oc, "model-id",
- x86_cpuid_get_model_id,
- x86_cpuid_set_model_id);
- object_class_property_add(oc, "tsc-frequency", "int",
- x86_cpuid_get_tsc_freq,
- x86_cpuid_set_tsc_freq, NULL, NULL);
- /*
- * The "unavailable-features" property has the same semantics as
- * CpuDefinitionInfo.unavailable-features on the "query-cpu-definitions"
- * QMP command: they list the features that would have prevented the
- * CPU from running if the "enforce" flag was set.
- */
- object_class_property_add(oc, "unavailable-features", "strList",
- x86_cpu_get_unavailable_features,
- NULL, NULL, NULL);
- #if !defined(CONFIG_USER_ONLY)
- object_class_property_add(oc, "crash-information", "GuestPanicInformation",
- x86_cpu_get_crash_info_qom, NULL, NULL, NULL);
- #endif
- for (w = 0; w < FEATURE_WORDS; w++) {
- int bitnr;
- for (bitnr = 0; bitnr < 64; bitnr++) {
- x86_cpu_register_feature_bit_props(xcc, w, bitnr);
- }
- }
- }
- static const TypeInfo x86_cpu_type_info = {
- .name = TYPE_X86_CPU,
- .parent = TYPE_CPU,
- .instance_size = sizeof(X86CPU),
- .instance_align = __alignof(X86CPU),
- .instance_init = x86_cpu_initfn,
- .instance_post_init = x86_cpu_post_initfn,
- .abstract = true,
- .class_size = sizeof(X86CPUClass),
- .class_init = x86_cpu_common_class_init,
- };
- /* "base" CPU model, used by query-cpu-model-expansion */
- static void x86_cpu_base_class_init(ObjectClass *oc, void *data)
- {
- X86CPUClass *xcc = X86_CPU_CLASS(oc);
- xcc->static_model = true;
- xcc->migration_safe = true;
- xcc->model_description = "base CPU model type with no features enabled";
- xcc->ordering = 8;
- }
- static const TypeInfo x86_base_cpu_type_info = {
- .name = X86_CPU_TYPE_NAME("base"),
- .parent = TYPE_X86_CPU,
- .class_init = x86_cpu_base_class_init,
- };
- static void x86_cpu_register_types(void)
- {
- int i;
- type_register_static(&x86_cpu_type_info);
- for (i = 0; i < ARRAY_SIZE(builtin_x86_defs); i++) {
- x86_register_cpudef_types(&builtin_x86_defs[i]);
- }
- type_register_static(&max_x86_cpu_type_info);
- type_register_static(&x86_base_cpu_type_info);
- }
- type_init(x86_cpu_register_types)
|