cpu.c 325 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513
  1. /*
  2. * i386 CPUID, CPU class, definitions, models
  3. *
  4. * Copyright (c) 2003 Fabrice Bellard
  5. *
  6. * This library is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * This library is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with this library; if not, see <http://www.gnu.org/licenses/>.
  18. */
  19. #include "qemu/osdep.h"
  20. #include "qemu/units.h"
  21. #include "qemu/cutils.h"
  22. #include "qemu/qemu-print.h"
  23. #include "qemu/hw-version.h"
  24. #include "cpu.h"
  25. #include "tcg/helper-tcg.h"
  26. #include "sysemu/hvf.h"
  27. #include "hvf/hvf-i386.h"
  28. #include "kvm/kvm_i386.h"
  29. #include "sev.h"
  30. #include "qapi/error.h"
  31. #include "qemu/error-report.h"
  32. #include "qapi/qapi-visit-machine.h"
  33. #include "qapi/qmp/qerror.h"
  34. #include "standard-headers/asm-x86/kvm_para.h"
  35. #include "hw/qdev-properties.h"
  36. #include "hw/i386/topology.h"
  37. #ifndef CONFIG_USER_ONLY
  38. #include "sysemu/reset.h"
  39. #include "qapi/qapi-commands-machine-target.h"
  40. #include "exec/address-spaces.h"
  41. #include "hw/boards.h"
  42. #include "hw/i386/sgx-epc.h"
  43. #endif
  44. #include "disas/capstone.h"
  45. #include "cpu-internal.h"
  46. static void x86_cpu_realizefn(DeviceState *dev, Error **errp);
  47. /* Helpers for building CPUID[2] descriptors: */
  48. struct CPUID2CacheDescriptorInfo {
  49. enum CacheType type;
  50. int level;
  51. int size;
  52. int line_size;
  53. int associativity;
  54. };
  55. /*
  56. * Known CPUID 2 cache descriptors.
  57. * From Intel SDM Volume 2A, CPUID instruction
  58. */
  59. struct CPUID2CacheDescriptorInfo cpuid2_cache_descriptors[] = {
  60. [0x06] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 8 * KiB,
  61. .associativity = 4, .line_size = 32, },
  62. [0x08] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 16 * KiB,
  63. .associativity = 4, .line_size = 32, },
  64. [0x09] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 32 * KiB,
  65. .associativity = 4, .line_size = 64, },
  66. [0x0A] = { .level = 1, .type = DATA_CACHE, .size = 8 * KiB,
  67. .associativity = 2, .line_size = 32, },
  68. [0x0C] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
  69. .associativity = 4, .line_size = 32, },
  70. [0x0D] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
  71. .associativity = 4, .line_size = 64, },
  72. [0x0E] = { .level = 1, .type = DATA_CACHE, .size = 24 * KiB,
  73. .associativity = 6, .line_size = 64, },
  74. [0x1D] = { .level = 2, .type = UNIFIED_CACHE, .size = 128 * KiB,
  75. .associativity = 2, .line_size = 64, },
  76. [0x21] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
  77. .associativity = 8, .line_size = 64, },
  78. /* lines per sector is not supported cpuid2_cache_descriptor(),
  79. * so descriptors 0x22, 0x23 are not included
  80. */
  81. [0x24] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
  82. .associativity = 16, .line_size = 64, },
  83. /* lines per sector is not supported cpuid2_cache_descriptor(),
  84. * so descriptors 0x25, 0x20 are not included
  85. */
  86. [0x2C] = { .level = 1, .type = DATA_CACHE, .size = 32 * KiB,
  87. .associativity = 8, .line_size = 64, },
  88. [0x30] = { .level = 1, .type = INSTRUCTION_CACHE, .size = 32 * KiB,
  89. .associativity = 8, .line_size = 64, },
  90. [0x41] = { .level = 2, .type = UNIFIED_CACHE, .size = 128 * KiB,
  91. .associativity = 4, .line_size = 32, },
  92. [0x42] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
  93. .associativity = 4, .line_size = 32, },
  94. [0x43] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
  95. .associativity = 4, .line_size = 32, },
  96. [0x44] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
  97. .associativity = 4, .line_size = 32, },
  98. [0x45] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
  99. .associativity = 4, .line_size = 32, },
  100. [0x46] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
  101. .associativity = 4, .line_size = 64, },
  102. [0x47] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
  103. .associativity = 8, .line_size = 64, },
  104. [0x48] = { .level = 2, .type = UNIFIED_CACHE, .size = 3 * MiB,
  105. .associativity = 12, .line_size = 64, },
  106. /* Descriptor 0x49 depends on CPU family/model, so it is not included */
  107. [0x4A] = { .level = 3, .type = UNIFIED_CACHE, .size = 6 * MiB,
  108. .associativity = 12, .line_size = 64, },
  109. [0x4B] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
  110. .associativity = 16, .line_size = 64, },
  111. [0x4C] = { .level = 3, .type = UNIFIED_CACHE, .size = 12 * MiB,
  112. .associativity = 12, .line_size = 64, },
  113. [0x4D] = { .level = 3, .type = UNIFIED_CACHE, .size = 16 * MiB,
  114. .associativity = 16, .line_size = 64, },
  115. [0x4E] = { .level = 2, .type = UNIFIED_CACHE, .size = 6 * MiB,
  116. .associativity = 24, .line_size = 64, },
  117. [0x60] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
  118. .associativity = 8, .line_size = 64, },
  119. [0x66] = { .level = 1, .type = DATA_CACHE, .size = 8 * KiB,
  120. .associativity = 4, .line_size = 64, },
  121. [0x67] = { .level = 1, .type = DATA_CACHE, .size = 16 * KiB,
  122. .associativity = 4, .line_size = 64, },
  123. [0x68] = { .level = 1, .type = DATA_CACHE, .size = 32 * KiB,
  124. .associativity = 4, .line_size = 64, },
  125. [0x78] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
  126. .associativity = 4, .line_size = 64, },
  127. /* lines per sector is not supported cpuid2_cache_descriptor(),
  128. * so descriptors 0x79, 0x7A, 0x7B, 0x7C are not included.
  129. */
  130. [0x7D] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
  131. .associativity = 8, .line_size = 64, },
  132. [0x7F] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
  133. .associativity = 2, .line_size = 64, },
  134. [0x80] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
  135. .associativity = 8, .line_size = 64, },
  136. [0x82] = { .level = 2, .type = UNIFIED_CACHE, .size = 256 * KiB,
  137. .associativity = 8, .line_size = 32, },
  138. [0x83] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
  139. .associativity = 8, .line_size = 32, },
  140. [0x84] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
  141. .associativity = 8, .line_size = 32, },
  142. [0x85] = { .level = 2, .type = UNIFIED_CACHE, .size = 2 * MiB,
  143. .associativity = 8, .line_size = 32, },
  144. [0x86] = { .level = 2, .type = UNIFIED_CACHE, .size = 512 * KiB,
  145. .associativity = 4, .line_size = 64, },
  146. [0x87] = { .level = 2, .type = UNIFIED_CACHE, .size = 1 * MiB,
  147. .associativity = 8, .line_size = 64, },
  148. [0xD0] = { .level = 3, .type = UNIFIED_CACHE, .size = 512 * KiB,
  149. .associativity = 4, .line_size = 64, },
  150. [0xD1] = { .level = 3, .type = UNIFIED_CACHE, .size = 1 * MiB,
  151. .associativity = 4, .line_size = 64, },
  152. [0xD2] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
  153. .associativity = 4, .line_size = 64, },
  154. [0xD6] = { .level = 3, .type = UNIFIED_CACHE, .size = 1 * MiB,
  155. .associativity = 8, .line_size = 64, },
  156. [0xD7] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
  157. .associativity = 8, .line_size = 64, },
  158. [0xD8] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
  159. .associativity = 8, .line_size = 64, },
  160. [0xDC] = { .level = 3, .type = UNIFIED_CACHE, .size = 1.5 * MiB,
  161. .associativity = 12, .line_size = 64, },
  162. [0xDD] = { .level = 3, .type = UNIFIED_CACHE, .size = 3 * MiB,
  163. .associativity = 12, .line_size = 64, },
  164. [0xDE] = { .level = 3, .type = UNIFIED_CACHE, .size = 6 * MiB,
  165. .associativity = 12, .line_size = 64, },
  166. [0xE2] = { .level = 3, .type = UNIFIED_CACHE, .size = 2 * MiB,
  167. .associativity = 16, .line_size = 64, },
  168. [0xE3] = { .level = 3, .type = UNIFIED_CACHE, .size = 4 * MiB,
  169. .associativity = 16, .line_size = 64, },
  170. [0xE4] = { .level = 3, .type = UNIFIED_CACHE, .size = 8 * MiB,
  171. .associativity = 16, .line_size = 64, },
  172. [0xEA] = { .level = 3, .type = UNIFIED_CACHE, .size = 12 * MiB,
  173. .associativity = 24, .line_size = 64, },
  174. [0xEB] = { .level = 3, .type = UNIFIED_CACHE, .size = 18 * MiB,
  175. .associativity = 24, .line_size = 64, },
  176. [0xEC] = { .level = 3, .type = UNIFIED_CACHE, .size = 24 * MiB,
  177. .associativity = 24, .line_size = 64, },
  178. };
  179. /*
  180. * "CPUID leaf 2 does not report cache descriptor information,
  181. * use CPUID leaf 4 to query cache parameters"
  182. */
  183. #define CACHE_DESCRIPTOR_UNAVAILABLE 0xFF
  184. /*
  185. * Return a CPUID 2 cache descriptor for a given cache.
  186. * If no known descriptor is found, return CACHE_DESCRIPTOR_UNAVAILABLE
  187. */
  188. static uint8_t cpuid2_cache_descriptor(CPUCacheInfo *cache)
  189. {
  190. int i;
  191. assert(cache->size > 0);
  192. assert(cache->level > 0);
  193. assert(cache->line_size > 0);
  194. assert(cache->associativity > 0);
  195. for (i = 0; i < ARRAY_SIZE(cpuid2_cache_descriptors); i++) {
  196. struct CPUID2CacheDescriptorInfo *d = &cpuid2_cache_descriptors[i];
  197. if (d->level == cache->level && d->type == cache->type &&
  198. d->size == cache->size && d->line_size == cache->line_size &&
  199. d->associativity == cache->associativity) {
  200. return i;
  201. }
  202. }
  203. return CACHE_DESCRIPTOR_UNAVAILABLE;
  204. }
  205. /* CPUID Leaf 4 constants: */
  206. /* EAX: */
  207. #define CACHE_TYPE_D 1
  208. #define CACHE_TYPE_I 2
  209. #define CACHE_TYPE_UNIFIED 3
  210. #define CACHE_LEVEL(l) (l << 5)
  211. #define CACHE_SELF_INIT_LEVEL (1 << 8)
  212. /* EDX: */
  213. #define CACHE_NO_INVD_SHARING (1 << 0)
  214. #define CACHE_INCLUSIVE (1 << 1)
  215. #define CACHE_COMPLEX_IDX (1 << 2)
  216. /* Encode CacheType for CPUID[4].EAX */
  217. #define CACHE_TYPE(t) (((t) == DATA_CACHE) ? CACHE_TYPE_D : \
  218. ((t) == INSTRUCTION_CACHE) ? CACHE_TYPE_I : \
  219. ((t) == UNIFIED_CACHE) ? CACHE_TYPE_UNIFIED : \
  220. 0 /* Invalid value */)
  221. static uint32_t max_thread_ids_for_cache(X86CPUTopoInfo *topo_info,
  222. enum CPUTopoLevel share_level)
  223. {
  224. uint32_t num_ids = 0;
  225. switch (share_level) {
  226. case CPU_TOPO_LEVEL_CORE:
  227. num_ids = 1 << apicid_core_offset(topo_info);
  228. break;
  229. case CPU_TOPO_LEVEL_DIE:
  230. num_ids = 1 << apicid_die_offset(topo_info);
  231. break;
  232. case CPU_TOPO_LEVEL_PACKAGE:
  233. num_ids = 1 << apicid_pkg_offset(topo_info);
  234. break;
  235. default:
  236. /*
  237. * Currently there is no use case for SMT and MODULE, so use
  238. * assert directly to facilitate debugging.
  239. */
  240. g_assert_not_reached();
  241. }
  242. return num_ids - 1;
  243. }
  244. static uint32_t max_core_ids_in_package(X86CPUTopoInfo *topo_info)
  245. {
  246. uint32_t num_cores = 1 << (apicid_pkg_offset(topo_info) -
  247. apicid_core_offset(topo_info));
  248. return num_cores - 1;
  249. }
  250. /* Encode cache info for CPUID[4] */
  251. static void encode_cache_cpuid4(CPUCacheInfo *cache,
  252. X86CPUTopoInfo *topo_info,
  253. uint32_t *eax, uint32_t *ebx,
  254. uint32_t *ecx, uint32_t *edx)
  255. {
  256. assert(cache->size == cache->line_size * cache->associativity *
  257. cache->partitions * cache->sets);
  258. *eax = CACHE_TYPE(cache->type) |
  259. CACHE_LEVEL(cache->level) |
  260. (cache->self_init ? CACHE_SELF_INIT_LEVEL : 0) |
  261. (max_core_ids_in_package(topo_info) << 26) |
  262. (max_thread_ids_for_cache(topo_info, cache->share_level) << 14);
  263. assert(cache->line_size > 0);
  264. assert(cache->partitions > 0);
  265. assert(cache->associativity > 0);
  266. /* We don't implement fully-associative caches */
  267. assert(cache->associativity < cache->sets);
  268. *ebx = (cache->line_size - 1) |
  269. ((cache->partitions - 1) << 12) |
  270. ((cache->associativity - 1) << 22);
  271. assert(cache->sets > 0);
  272. *ecx = cache->sets - 1;
  273. *edx = (cache->no_invd_sharing ? CACHE_NO_INVD_SHARING : 0) |
  274. (cache->inclusive ? CACHE_INCLUSIVE : 0) |
  275. (cache->complex_indexing ? CACHE_COMPLEX_IDX : 0);
  276. }
  277. static uint32_t num_threads_by_topo_level(X86CPUTopoInfo *topo_info,
  278. enum CPUTopoLevel topo_level)
  279. {
  280. switch (topo_level) {
  281. case CPU_TOPO_LEVEL_SMT:
  282. return 1;
  283. case CPU_TOPO_LEVEL_CORE:
  284. return topo_info->threads_per_core;
  285. case CPU_TOPO_LEVEL_MODULE:
  286. return topo_info->threads_per_core * topo_info->cores_per_module;
  287. case CPU_TOPO_LEVEL_DIE:
  288. return topo_info->threads_per_core * topo_info->cores_per_module *
  289. topo_info->modules_per_die;
  290. case CPU_TOPO_LEVEL_PACKAGE:
  291. return topo_info->threads_per_core * topo_info->cores_per_module *
  292. topo_info->modules_per_die * topo_info->dies_per_pkg;
  293. default:
  294. g_assert_not_reached();
  295. }
  296. return 0;
  297. }
  298. static uint32_t apicid_offset_by_topo_level(X86CPUTopoInfo *topo_info,
  299. enum CPUTopoLevel topo_level)
  300. {
  301. switch (topo_level) {
  302. case CPU_TOPO_LEVEL_SMT:
  303. return 0;
  304. case CPU_TOPO_LEVEL_CORE:
  305. return apicid_core_offset(topo_info);
  306. case CPU_TOPO_LEVEL_MODULE:
  307. return apicid_module_offset(topo_info);
  308. case CPU_TOPO_LEVEL_DIE:
  309. return apicid_die_offset(topo_info);
  310. case CPU_TOPO_LEVEL_PACKAGE:
  311. return apicid_pkg_offset(topo_info);
  312. default:
  313. g_assert_not_reached();
  314. }
  315. return 0;
  316. }
  317. static uint32_t cpuid1f_topo_type(enum CPUTopoLevel topo_level)
  318. {
  319. switch (topo_level) {
  320. case CPU_TOPO_LEVEL_INVALID:
  321. return CPUID_1F_ECX_TOPO_LEVEL_INVALID;
  322. case CPU_TOPO_LEVEL_SMT:
  323. return CPUID_1F_ECX_TOPO_LEVEL_SMT;
  324. case CPU_TOPO_LEVEL_CORE:
  325. return CPUID_1F_ECX_TOPO_LEVEL_CORE;
  326. case CPU_TOPO_LEVEL_MODULE:
  327. return CPUID_1F_ECX_TOPO_LEVEL_MODULE;
  328. case CPU_TOPO_LEVEL_DIE:
  329. return CPUID_1F_ECX_TOPO_LEVEL_DIE;
  330. default:
  331. /* Other types are not supported in QEMU. */
  332. g_assert_not_reached();
  333. }
  334. return 0;
  335. }
  336. static void encode_topo_cpuid1f(CPUX86State *env, uint32_t count,
  337. X86CPUTopoInfo *topo_info,
  338. uint32_t *eax, uint32_t *ebx,
  339. uint32_t *ecx, uint32_t *edx)
  340. {
  341. X86CPU *cpu = env_archcpu(env);
  342. unsigned long level, next_level;
  343. uint32_t num_threads_next_level, offset_next_level;
  344. assert(count + 1 < CPU_TOPO_LEVEL_MAX);
  345. /*
  346. * Find the No.(count + 1) topology level in avail_cpu_topo bitmap.
  347. * The search starts from bit 1 (CPU_TOPO_LEVEL_INVALID + 1).
  348. */
  349. level = CPU_TOPO_LEVEL_INVALID;
  350. for (int i = 0; i <= count; i++) {
  351. level = find_next_bit(env->avail_cpu_topo,
  352. CPU_TOPO_LEVEL_PACKAGE,
  353. level + 1);
  354. /*
  355. * CPUID[0x1f] doesn't explicitly encode the package level,
  356. * and it just encodes the invalid level (all fields are 0)
  357. * into the last subleaf of 0x1f.
  358. */
  359. if (level == CPU_TOPO_LEVEL_PACKAGE) {
  360. level = CPU_TOPO_LEVEL_INVALID;
  361. break;
  362. }
  363. }
  364. if (level == CPU_TOPO_LEVEL_INVALID) {
  365. num_threads_next_level = 0;
  366. offset_next_level = 0;
  367. } else {
  368. next_level = find_next_bit(env->avail_cpu_topo,
  369. CPU_TOPO_LEVEL_PACKAGE,
  370. level + 1);
  371. num_threads_next_level = num_threads_by_topo_level(topo_info,
  372. next_level);
  373. offset_next_level = apicid_offset_by_topo_level(topo_info,
  374. next_level);
  375. }
  376. *eax = offset_next_level;
  377. /* The count (bits 15-00) doesn't need to be reliable. */
  378. *ebx = num_threads_next_level & 0xffff;
  379. *ecx = (count & 0xff) | (cpuid1f_topo_type(level) << 8);
  380. *edx = cpu->apic_id;
  381. assert(!(*eax & ~0x1f));
  382. }
  383. /* Encode cache info for CPUID[0x80000005].ECX or CPUID[0x80000005].EDX */
  384. static uint32_t encode_cache_cpuid80000005(CPUCacheInfo *cache)
  385. {
  386. assert(cache->size % 1024 == 0);
  387. assert(cache->lines_per_tag > 0);
  388. assert(cache->associativity > 0);
  389. assert(cache->line_size > 0);
  390. return ((cache->size / 1024) << 24) | (cache->associativity << 16) |
  391. (cache->lines_per_tag << 8) | (cache->line_size);
  392. }
  393. #define ASSOC_FULL 0xFF
  394. /* AMD associativity encoding used on CPUID Leaf 0x80000006: */
  395. #define AMD_ENC_ASSOC(a) (a <= 1 ? a : \
  396. a == 2 ? 0x2 : \
  397. a == 4 ? 0x4 : \
  398. a == 8 ? 0x6 : \
  399. a == 16 ? 0x8 : \
  400. a == 32 ? 0xA : \
  401. a == 48 ? 0xB : \
  402. a == 64 ? 0xC : \
  403. a == 96 ? 0xD : \
  404. a == 128 ? 0xE : \
  405. a == ASSOC_FULL ? 0xF : \
  406. 0 /* invalid value */)
  407. /*
  408. * Encode cache info for CPUID[0x80000006].ECX and CPUID[0x80000006].EDX
  409. * @l3 can be NULL.
  410. */
  411. static void encode_cache_cpuid80000006(CPUCacheInfo *l2,
  412. CPUCacheInfo *l3,
  413. uint32_t *ecx, uint32_t *edx)
  414. {
  415. assert(l2->size % 1024 == 0);
  416. assert(l2->associativity > 0);
  417. assert(l2->lines_per_tag > 0);
  418. assert(l2->line_size > 0);
  419. *ecx = ((l2->size / 1024) << 16) |
  420. (AMD_ENC_ASSOC(l2->associativity) << 12) |
  421. (l2->lines_per_tag << 8) | (l2->line_size);
  422. if (l3) {
  423. assert(l3->size % (512 * 1024) == 0);
  424. assert(l3->associativity > 0);
  425. assert(l3->lines_per_tag > 0);
  426. assert(l3->line_size > 0);
  427. *edx = ((l3->size / (512 * 1024)) << 18) |
  428. (AMD_ENC_ASSOC(l3->associativity) << 12) |
  429. (l3->lines_per_tag << 8) | (l3->line_size);
  430. } else {
  431. *edx = 0;
  432. }
  433. }
  434. /* Encode cache info for CPUID[8000001D] */
  435. static void encode_cache_cpuid8000001d(CPUCacheInfo *cache,
  436. X86CPUTopoInfo *topo_info,
  437. uint32_t *eax, uint32_t *ebx,
  438. uint32_t *ecx, uint32_t *edx)
  439. {
  440. assert(cache->size == cache->line_size * cache->associativity *
  441. cache->partitions * cache->sets);
  442. *eax = CACHE_TYPE(cache->type) | CACHE_LEVEL(cache->level) |
  443. (cache->self_init ? CACHE_SELF_INIT_LEVEL : 0);
  444. *eax |= max_thread_ids_for_cache(topo_info, cache->share_level) << 14;
  445. assert(cache->line_size > 0);
  446. assert(cache->partitions > 0);
  447. assert(cache->associativity > 0);
  448. /* We don't implement fully-associative caches */
  449. assert(cache->associativity < cache->sets);
  450. *ebx = (cache->line_size - 1) |
  451. ((cache->partitions - 1) << 12) |
  452. ((cache->associativity - 1) << 22);
  453. assert(cache->sets > 0);
  454. *ecx = cache->sets - 1;
  455. *edx = (cache->no_invd_sharing ? CACHE_NO_INVD_SHARING : 0) |
  456. (cache->inclusive ? CACHE_INCLUSIVE : 0) |
  457. (cache->complex_indexing ? CACHE_COMPLEX_IDX : 0);
  458. }
  459. /* Encode cache info for CPUID[8000001E] */
  460. static void encode_topo_cpuid8000001e(X86CPU *cpu, X86CPUTopoInfo *topo_info,
  461. uint32_t *eax, uint32_t *ebx,
  462. uint32_t *ecx, uint32_t *edx)
  463. {
  464. X86CPUTopoIDs topo_ids;
  465. x86_topo_ids_from_apicid(cpu->apic_id, topo_info, &topo_ids);
  466. *eax = cpu->apic_id;
  467. /*
  468. * CPUID_Fn8000001E_EBX [Core Identifiers] (CoreId)
  469. * Read-only. Reset: 0000_XXXXh.
  470. * See Core::X86::Cpuid::ExtApicId.
  471. * Core::X86::Cpuid::CoreId_lthree[1:0]_core[3:0]_thread[1:0];
  472. * Bits Description
  473. * 31:16 Reserved.
  474. * 15:8 ThreadsPerCore: threads per core. Read-only. Reset: XXh.
  475. * The number of threads per core is ThreadsPerCore+1.
  476. * 7:0 CoreId: core ID. Read-only. Reset: XXh.
  477. *
  478. * NOTE: CoreId is already part of apic_id. Just use it. We can
  479. * use all the 8 bits to represent the core_id here.
  480. */
  481. *ebx = ((topo_info->threads_per_core - 1) << 8) | (topo_ids.core_id & 0xFF);
  482. /*
  483. * CPUID_Fn8000001E_ECX [Node Identifiers] (NodeId)
  484. * Read-only. Reset: 0000_0XXXh.
  485. * Core::X86::Cpuid::NodeId_lthree[1:0]_core[3:0]_thread[1:0];
  486. * Bits Description
  487. * 31:11 Reserved.
  488. * 10:8 NodesPerProcessor: Node per processor. Read-only. Reset: XXXb.
  489. * ValidValues:
  490. * Value Description
  491. * 0h 1 node per processor.
  492. * 7h-1h Reserved.
  493. * 7:0 NodeId: Node ID. Read-only. Reset: XXh.
  494. *
  495. * NOTE: Hardware reserves 3 bits for number of nodes per processor.
  496. * But users can create more nodes than the actual hardware can
  497. * support. To genaralize we can use all the upper 8 bits for nodes.
  498. * NodeId is combination of node and socket_id which is already decoded
  499. * in apic_id. Just use it by shifting.
  500. */
  501. if (cpu->legacy_multi_node) {
  502. *ecx = ((topo_info->dies_per_pkg - 1) << 8) |
  503. ((cpu->apic_id >> apicid_die_offset(topo_info)) & 0xFF);
  504. } else {
  505. *ecx = (cpu->apic_id >> apicid_pkg_offset(topo_info)) & 0xFF;
  506. }
  507. *edx = 0;
  508. }
  509. /*
  510. * Definitions of the hardcoded cache entries we expose:
  511. * These are legacy cache values. If there is a need to change any
  512. * of these values please use builtin_x86_defs
  513. */
  514. /* L1 data cache: */
  515. static CPUCacheInfo legacy_l1d_cache = {
  516. .type = DATA_CACHE,
  517. .level = 1,
  518. .size = 32 * KiB,
  519. .self_init = 1,
  520. .line_size = 64,
  521. .associativity = 8,
  522. .sets = 64,
  523. .partitions = 1,
  524. .no_invd_sharing = true,
  525. .share_level = CPU_TOPO_LEVEL_CORE,
  526. };
  527. /*FIXME: CPUID leaf 0x80000005 is inconsistent with leaves 2 & 4 */
  528. static CPUCacheInfo legacy_l1d_cache_amd = {
  529. .type = DATA_CACHE,
  530. .level = 1,
  531. .size = 64 * KiB,
  532. .self_init = 1,
  533. .line_size = 64,
  534. .associativity = 2,
  535. .sets = 512,
  536. .partitions = 1,
  537. .lines_per_tag = 1,
  538. .no_invd_sharing = true,
  539. .share_level = CPU_TOPO_LEVEL_CORE,
  540. };
  541. /* L1 instruction cache: */
  542. static CPUCacheInfo legacy_l1i_cache = {
  543. .type = INSTRUCTION_CACHE,
  544. .level = 1,
  545. .size = 32 * KiB,
  546. .self_init = 1,
  547. .line_size = 64,
  548. .associativity = 8,
  549. .sets = 64,
  550. .partitions = 1,
  551. .no_invd_sharing = true,
  552. .share_level = CPU_TOPO_LEVEL_CORE,
  553. };
  554. /*FIXME: CPUID leaf 0x80000005 is inconsistent with leaves 2 & 4 */
  555. static CPUCacheInfo legacy_l1i_cache_amd = {
  556. .type = INSTRUCTION_CACHE,
  557. .level = 1,
  558. .size = 64 * KiB,
  559. .self_init = 1,
  560. .line_size = 64,
  561. .associativity = 2,
  562. .sets = 512,
  563. .partitions = 1,
  564. .lines_per_tag = 1,
  565. .no_invd_sharing = true,
  566. .share_level = CPU_TOPO_LEVEL_CORE,
  567. };
  568. /* Level 2 unified cache: */
  569. static CPUCacheInfo legacy_l2_cache = {
  570. .type = UNIFIED_CACHE,
  571. .level = 2,
  572. .size = 4 * MiB,
  573. .self_init = 1,
  574. .line_size = 64,
  575. .associativity = 16,
  576. .sets = 4096,
  577. .partitions = 1,
  578. .no_invd_sharing = true,
  579. .share_level = CPU_TOPO_LEVEL_CORE,
  580. };
  581. /*FIXME: CPUID leaf 2 descriptor is inconsistent with CPUID leaf 4 */
  582. static CPUCacheInfo legacy_l2_cache_cpuid2 = {
  583. .type = UNIFIED_CACHE,
  584. .level = 2,
  585. .size = 2 * MiB,
  586. .line_size = 64,
  587. .associativity = 8,
  588. .share_level = CPU_TOPO_LEVEL_INVALID,
  589. };
  590. /*FIXME: CPUID leaf 0x80000006 is inconsistent with leaves 2 & 4 */
  591. static CPUCacheInfo legacy_l2_cache_amd = {
  592. .type = UNIFIED_CACHE,
  593. .level = 2,
  594. .size = 512 * KiB,
  595. .line_size = 64,
  596. .lines_per_tag = 1,
  597. .associativity = 16,
  598. .sets = 512,
  599. .partitions = 1,
  600. .share_level = CPU_TOPO_LEVEL_CORE,
  601. };
  602. /* Level 3 unified cache: */
  603. static CPUCacheInfo legacy_l3_cache = {
  604. .type = UNIFIED_CACHE,
  605. .level = 3,
  606. .size = 16 * MiB,
  607. .line_size = 64,
  608. .associativity = 16,
  609. .sets = 16384,
  610. .partitions = 1,
  611. .lines_per_tag = 1,
  612. .self_init = true,
  613. .inclusive = true,
  614. .complex_indexing = true,
  615. .share_level = CPU_TOPO_LEVEL_DIE,
  616. };
  617. /* TLB definitions: */
  618. #define L1_DTLB_2M_ASSOC 1
  619. #define L1_DTLB_2M_ENTRIES 255
  620. #define L1_DTLB_4K_ASSOC 1
  621. #define L1_DTLB_4K_ENTRIES 255
  622. #define L1_ITLB_2M_ASSOC 1
  623. #define L1_ITLB_2M_ENTRIES 255
  624. #define L1_ITLB_4K_ASSOC 1
  625. #define L1_ITLB_4K_ENTRIES 255
  626. #define L2_DTLB_2M_ASSOC 0 /* disabled */
  627. #define L2_DTLB_2M_ENTRIES 0 /* disabled */
  628. #define L2_DTLB_4K_ASSOC 4
  629. #define L2_DTLB_4K_ENTRIES 512
  630. #define L2_ITLB_2M_ASSOC 0 /* disabled */
  631. #define L2_ITLB_2M_ENTRIES 0 /* disabled */
  632. #define L2_ITLB_4K_ASSOC 4
  633. #define L2_ITLB_4K_ENTRIES 512
  634. /* CPUID Leaf 0x14 constants: */
  635. #define INTEL_PT_MAX_SUBLEAF 0x1
  636. /*
  637. * bit[00]: IA32_RTIT_CTL.CR3 filter can be set to 1 and IA32_RTIT_CR3_MATCH
  638. * MSR can be accessed;
  639. * bit[01]: Support Configurable PSB and Cycle-Accurate Mode;
  640. * bit[02]: Support IP Filtering, TraceStop filtering, and preservation
  641. * of Intel PT MSRs across warm reset;
  642. * bit[03]: Support MTC timing packet and suppression of COFI-based packets;
  643. */
  644. #define INTEL_PT_MINIMAL_EBX 0xf
  645. /*
  646. * bit[00]: Tracing can be enabled with IA32_RTIT_CTL.ToPA = 1 and
  647. * IA32_RTIT_OUTPUT_BASE and IA32_RTIT_OUTPUT_MASK_PTRS MSRs can be
  648. * accessed;
  649. * bit[01]: ToPA tables can hold any number of output entries, up to the
  650. * maximum allowed by the MaskOrTableOffset field of
  651. * IA32_RTIT_OUTPUT_MASK_PTRS;
  652. * bit[02]: Support Single-Range Output scheme;
  653. */
  654. #define INTEL_PT_MINIMAL_ECX 0x7
  655. /* generated packets which contain IP payloads have LIP values */
  656. #define INTEL_PT_IP_LIP (1 << 31)
  657. #define INTEL_PT_ADDR_RANGES_NUM 0x2 /* Number of configurable address ranges */
  658. #define INTEL_PT_ADDR_RANGES_NUM_MASK 0x3
  659. #define INTEL_PT_MTC_BITMAP (0x0249 << 16) /* Support ART(0,3,6,9) */
  660. #define INTEL_PT_CYCLE_BITMAP 0x1fff /* Support 0,2^(0~11) */
  661. #define INTEL_PT_PSB_BITMAP (0x003f << 16) /* Support 2K,4K,8K,16K,32K,64K */
  662. /* CPUID Leaf 0x1D constants: */
  663. #define INTEL_AMX_TILE_MAX_SUBLEAF 0x1
  664. #define INTEL_AMX_TOTAL_TILE_BYTES 0x2000
  665. #define INTEL_AMX_BYTES_PER_TILE 0x400
  666. #define INTEL_AMX_BYTES_PER_ROW 0x40
  667. #define INTEL_AMX_TILE_MAX_NAMES 0x8
  668. #define INTEL_AMX_TILE_MAX_ROWS 0x10
  669. /* CPUID Leaf 0x1E constants: */
  670. #define INTEL_AMX_TMUL_MAX_K 0x10
  671. #define INTEL_AMX_TMUL_MAX_N 0x40
  672. void x86_cpu_vendor_words2str(char *dst, uint32_t vendor1,
  673. uint32_t vendor2, uint32_t vendor3)
  674. {
  675. int i;
  676. for (i = 0; i < 4; i++) {
  677. dst[i] = vendor1 >> (8 * i);
  678. dst[i + 4] = vendor2 >> (8 * i);
  679. dst[i + 8] = vendor3 >> (8 * i);
  680. }
  681. dst[CPUID_VENDOR_SZ] = '\0';
  682. }
  683. #define I486_FEATURES (CPUID_FP87 | CPUID_VME | CPUID_PSE)
  684. #define PENTIUM_FEATURES (I486_FEATURES | CPUID_DE | CPUID_TSC | \
  685. CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_MMX | CPUID_APIC)
  686. #define PENTIUM2_FEATURES (PENTIUM_FEATURES | CPUID_PAE | CPUID_SEP | \
  687. CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV | CPUID_PAT | \
  688. CPUID_PSE36 | CPUID_FXSR)
  689. #define PENTIUM3_FEATURES (PENTIUM2_FEATURES | CPUID_SSE)
  690. #define PPRO_FEATURES (CPUID_FP87 | CPUID_DE | CPUID_PSE | CPUID_TSC | \
  691. CPUID_MSR | CPUID_MCE | CPUID_CX8 | CPUID_PGE | CPUID_CMOV | \
  692. CPUID_PAT | CPUID_FXSR | CPUID_MMX | CPUID_SSE | CPUID_SSE2 | \
  693. CPUID_PAE | CPUID_SEP | CPUID_APIC)
  694. #define TCG_FEATURES (CPUID_FP87 | CPUID_PSE | CPUID_TSC | CPUID_MSR | \
  695. CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC | CPUID_SEP | \
  696. CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV | CPUID_PAT | \
  697. CPUID_PSE36 | CPUID_CLFLUSH | CPUID_ACPI | CPUID_MMX | \
  698. CPUID_FXSR | CPUID_SSE | CPUID_SSE2 | CPUID_SS | CPUID_DE)
  699. /* partly implemented:
  700. CPUID_MTRR, CPUID_MCA, CPUID_CLFLUSH (needed for Win64) */
  701. /* missing:
  702. CPUID_VME, CPUID_DTS, CPUID_SS, CPUID_HT, CPUID_TM, CPUID_PBE */
  703. /*
  704. * Kernel-only features that can be shown to usermode programs even if
  705. * they aren't actually supported by TCG, because qemu-user only runs
  706. * in CPL=3; remove them if they are ever implemented for system emulation.
  707. */
  708. #if defined CONFIG_USER_ONLY
  709. #define CPUID_EXT_KERNEL_FEATURES \
  710. (CPUID_EXT_PCID | CPUID_EXT_TSC_DEADLINE_TIMER)
  711. #else
  712. #define CPUID_EXT_KERNEL_FEATURES 0
  713. #endif
  714. #define TCG_EXT_FEATURES (CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | \
  715. CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 | CPUID_EXT_CX16 | \
  716. CPUID_EXT_SSE41 | CPUID_EXT_SSE42 | CPUID_EXT_POPCNT | \
  717. CPUID_EXT_XSAVE | /* CPUID_EXT_OSXSAVE is dynamic */ \
  718. CPUID_EXT_MOVBE | CPUID_EXT_AES | CPUID_EXT_HYPERVISOR | \
  719. CPUID_EXT_RDRAND | CPUID_EXT_AVX | CPUID_EXT_F16C | \
  720. CPUID_EXT_FMA | CPUID_EXT_X2APIC | CPUID_EXT_KERNEL_FEATURES)
  721. /* missing:
  722. CPUID_EXT_DTES64, CPUID_EXT_DSCPL, CPUID_EXT_VMX, CPUID_EXT_SMX,
  723. CPUID_EXT_EST, CPUID_EXT_TM2, CPUID_EXT_CID,
  724. CPUID_EXT_XTPR, CPUID_EXT_PDCM, CPUID_EXT_PCID, CPUID_EXT_DCA,
  725. CPUID_EXT_TSC_DEADLINE_TIMER
  726. */
  727. #ifdef TARGET_X86_64
  728. #define TCG_EXT2_X86_64_FEATURES CPUID_EXT2_LM
  729. #else
  730. #define TCG_EXT2_X86_64_FEATURES 0
  731. #endif
  732. /*
  733. * CPUID_*_KERNEL_FEATURES denotes bits and features that are not usable
  734. * in usermode or by 32-bit programs. Those are added to supported
  735. * TCG features unconditionally in user-mode emulation mode. This may
  736. * indeed seem strange or incorrect, but it works because code running
  737. * under usermode emulation cannot access them.
  738. *
  739. * Even for long mode, qemu-i386 is not running "a userspace program on a
  740. * 32-bit CPU"; it's running "a userspace program with a 32-bit code segment"
  741. * and therefore using the 32-bit ABI; the CPU itself might be 64-bit
  742. * but again the difference is only visible in kernel mode.
  743. */
  744. #if defined CONFIG_LINUX_USER
  745. #define CPUID_EXT2_KERNEL_FEATURES (CPUID_EXT2_LM | CPUID_EXT2_FFXSR)
  746. #elif defined CONFIG_USER_ONLY
  747. /* FIXME: Long mode not yet supported for i386 bsd-user */
  748. #define CPUID_EXT2_KERNEL_FEATURES CPUID_EXT2_FFXSR
  749. #else
  750. #define CPUID_EXT2_KERNEL_FEATURES 0
  751. #endif
  752. #define TCG_EXT2_FEATURES ((TCG_FEATURES & CPUID_EXT2_AMD_ALIASES) | \
  753. CPUID_EXT2_NX | CPUID_EXT2_MMXEXT | CPUID_EXT2_RDTSCP | \
  754. CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT | CPUID_EXT2_PDPE1GB | \
  755. CPUID_EXT2_SYSCALL | TCG_EXT2_X86_64_FEATURES | \
  756. CPUID_EXT2_KERNEL_FEATURES)
  757. #if defined CONFIG_USER_ONLY
  758. #define CPUID_EXT3_KERNEL_FEATURES CPUID_EXT3_OSVW
  759. #else
  760. #define CPUID_EXT3_KERNEL_FEATURES 0
  761. #endif
  762. #define TCG_EXT3_FEATURES (CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM | \
  763. CPUID_EXT3_CR8LEG | CPUID_EXT3_ABM | CPUID_EXT3_SSE4A | \
  764. CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_KERNEL_FEATURES)
  765. #define TCG_EXT4_FEATURES 0
  766. #if defined CONFIG_USER_ONLY
  767. #define CPUID_SVM_KERNEL_FEATURES (CPUID_SVM_NRIPSAVE | CPUID_SVM_VNMI)
  768. #else
  769. #define CPUID_SVM_KERNEL_FEATURES 0
  770. #endif
  771. #define TCG_SVM_FEATURES (CPUID_SVM_NPT | CPUID_SVM_VGIF | \
  772. CPUID_SVM_SVME_ADDR_CHK | CPUID_SVM_KERNEL_FEATURES)
  773. #define TCG_KVM_FEATURES 0
  774. #if defined CONFIG_USER_ONLY
  775. #define CPUID_7_0_EBX_KERNEL_FEATURES CPUID_7_0_EBX_INVPCID
  776. #else
  777. #define CPUID_7_0_EBX_KERNEL_FEATURES 0
  778. #endif
  779. #define TCG_7_0_EBX_FEATURES (CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_SMAP | \
  780. CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ADX | \
  781. CPUID_7_0_EBX_CLFLUSHOPT | \
  782. CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_MPX | CPUID_7_0_EBX_FSGSBASE | \
  783. CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_RDSEED | \
  784. CPUID_7_0_EBX_SHA_NI | CPUID_7_0_EBX_KERNEL_FEATURES)
  785. /* missing:
  786. CPUID_7_0_EBX_HLE
  787. CPUID_7_0_EBX_INVPCID, CPUID_7_0_EBX_RTM */
  788. #if !defined CONFIG_USER_ONLY || defined CONFIG_LINUX
  789. #define TCG_7_0_ECX_RDPID CPUID_7_0_ECX_RDPID
  790. #else
  791. #define TCG_7_0_ECX_RDPID 0
  792. #endif
  793. #define TCG_7_0_ECX_FEATURES (CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU | \
  794. /* CPUID_7_0_ECX_OSPKE is dynamic */ \
  795. CPUID_7_0_ECX_LA57 | CPUID_7_0_ECX_PKS | CPUID_7_0_ECX_VAES | \
  796. TCG_7_0_ECX_RDPID)
  797. #if defined CONFIG_USER_ONLY
  798. #define CPUID_7_0_EDX_KERNEL_FEATURES (CPUID_7_0_EDX_SPEC_CTRL | \
  799. CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD)
  800. #else
  801. #define CPUID_7_0_EDX_KERNEL_FEATURES 0
  802. #endif
  803. #define TCG_7_0_EDX_FEATURES (CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_KERNEL_FEATURES)
  804. #define TCG_7_1_EAX_FEATURES (CPUID_7_1_EAX_FZRM | CPUID_7_1_EAX_FSRS | \
  805. CPUID_7_1_EAX_FSRC | CPUID_7_1_EAX_CMPCCXADD)
  806. #define TCG_7_1_EDX_FEATURES 0
  807. #define TCG_7_2_EDX_FEATURES 0
  808. #define TCG_APM_FEATURES 0
  809. #define TCG_6_EAX_FEATURES CPUID_6_EAX_ARAT
  810. #define TCG_XSAVE_FEATURES (CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XGETBV1)
  811. /* missing:
  812. CPUID_XSAVE_XSAVEC, CPUID_XSAVE_XSAVES */
  813. #define TCG_14_0_ECX_FEATURES 0
  814. #define TCG_SGX_12_0_EAX_FEATURES 0
  815. #define TCG_SGX_12_0_EBX_FEATURES 0
  816. #define TCG_SGX_12_1_EAX_FEATURES 0
  817. #if defined CONFIG_USER_ONLY
  818. #define CPUID_8000_0008_EBX_KERNEL_FEATURES (CPUID_8000_0008_EBX_IBPB | \
  819. CPUID_8000_0008_EBX_IBRS | CPUID_8000_0008_EBX_STIBP | \
  820. CPUID_8000_0008_EBX_STIBP_ALWAYS_ON | CPUID_8000_0008_EBX_AMD_SSBD | \
  821. CPUID_8000_0008_EBX_AMD_PSFD)
  822. #else
  823. #define CPUID_8000_0008_EBX_KERNEL_FEATURES 0
  824. #endif
  825. #define TCG_8000_0008_EBX (CPUID_8000_0008_EBX_XSAVEERPTR | \
  826. CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_KERNEL_FEATURES)
  827. FeatureWordInfo feature_word_info[FEATURE_WORDS] = {
  828. [FEAT_1_EDX] = {
  829. .type = CPUID_FEATURE_WORD,
  830. .feat_names = {
  831. "fpu", "vme", "de", "pse",
  832. "tsc", "msr", "pae", "mce",
  833. "cx8", "apic", NULL, "sep",
  834. "mtrr", "pge", "mca", "cmov",
  835. "pat", "pse36", "pn" /* Intel psn */, "clflush" /* Intel clfsh */,
  836. NULL, "ds" /* Intel dts */, "acpi", "mmx",
  837. "fxsr", "sse", "sse2", "ss",
  838. "ht" /* Intel htt */, "tm", "ia64", "pbe",
  839. },
  840. .cpuid = {.eax = 1, .reg = R_EDX, },
  841. .tcg_features = TCG_FEATURES,
  842. .no_autoenable_flags = CPUID_HT,
  843. },
  844. [FEAT_1_ECX] = {
  845. .type = CPUID_FEATURE_WORD,
  846. .feat_names = {
  847. "pni" /* Intel,AMD sse3 */, "pclmulqdq", "dtes64", "monitor",
  848. "ds-cpl", "vmx", "smx", "est",
  849. "tm2", "ssse3", "cid", NULL,
  850. "fma", "cx16", "xtpr", "pdcm",
  851. NULL, "pcid", "dca", "sse4.1",
  852. "sse4.2", "x2apic", "movbe", "popcnt",
  853. "tsc-deadline", "aes", "xsave", NULL /* osxsave */,
  854. "avx", "f16c", "rdrand", "hypervisor",
  855. },
  856. .cpuid = { .eax = 1, .reg = R_ECX, },
  857. .tcg_features = TCG_EXT_FEATURES,
  858. },
  859. /* Feature names that are already defined on feature_name[] but
  860. * are set on CPUID[8000_0001].EDX on AMD CPUs don't have their
  861. * names on feat_names below. They are copied automatically
  862. * to features[FEAT_8000_0001_EDX] if and only if CPU vendor is AMD.
  863. */
  864. [FEAT_8000_0001_EDX] = {
  865. .type = CPUID_FEATURE_WORD,
  866. .feat_names = {
  867. NULL /* fpu */, NULL /* vme */, NULL /* de */, NULL /* pse */,
  868. NULL /* tsc */, NULL /* msr */, NULL /* pae */, NULL /* mce */,
  869. NULL /* cx8 */, NULL /* apic */, NULL, "syscall",
  870. NULL /* mtrr */, NULL /* pge */, NULL /* mca */, NULL /* cmov */,
  871. NULL /* pat */, NULL /* pse36 */, NULL, NULL /* Linux mp */,
  872. "nx", NULL, "mmxext", NULL /* mmx */,
  873. NULL /* fxsr */, "fxsr-opt", "pdpe1gb", "rdtscp",
  874. NULL, "lm", "3dnowext", "3dnow",
  875. },
  876. .cpuid = { .eax = 0x80000001, .reg = R_EDX, },
  877. .tcg_features = TCG_EXT2_FEATURES,
  878. },
  879. [FEAT_8000_0001_ECX] = {
  880. .type = CPUID_FEATURE_WORD,
  881. .feat_names = {
  882. "lahf-lm", "cmp-legacy", "svm", "extapic",
  883. "cr8legacy", "abm", "sse4a", "misalignsse",
  884. "3dnowprefetch", "osvw", "ibs", "xop",
  885. "skinit", "wdt", NULL, "lwp",
  886. "fma4", "tce", NULL, "nodeid-msr",
  887. NULL, "tbm", "topoext", "perfctr-core",
  888. "perfctr-nb", NULL, NULL, NULL,
  889. NULL, NULL, NULL, NULL,
  890. },
  891. .cpuid = { .eax = 0x80000001, .reg = R_ECX, },
  892. .tcg_features = TCG_EXT3_FEATURES,
  893. /*
  894. * TOPOEXT is always allowed but can't be enabled blindly by
  895. * "-cpu host", as it requires consistent cache topology info
  896. * to be provided so it doesn't confuse guests.
  897. */
  898. .no_autoenable_flags = CPUID_EXT3_TOPOEXT,
  899. },
  900. [FEAT_C000_0001_EDX] = {
  901. .type = CPUID_FEATURE_WORD,
  902. .feat_names = {
  903. NULL, NULL, "xstore", "xstore-en",
  904. NULL, NULL, "xcrypt", "xcrypt-en",
  905. "ace2", "ace2-en", "phe", "phe-en",
  906. "pmm", "pmm-en", NULL, NULL,
  907. NULL, NULL, NULL, NULL,
  908. NULL, NULL, NULL, NULL,
  909. NULL, NULL, NULL, NULL,
  910. NULL, NULL, NULL, NULL,
  911. },
  912. .cpuid = { .eax = 0xC0000001, .reg = R_EDX, },
  913. .tcg_features = TCG_EXT4_FEATURES,
  914. },
  915. [FEAT_KVM] = {
  916. .type = CPUID_FEATURE_WORD,
  917. .feat_names = {
  918. "kvmclock", "kvm-nopiodelay", "kvm-mmu", "kvmclock",
  919. "kvm-asyncpf", "kvm-steal-time", "kvm-pv-eoi", "kvm-pv-unhalt",
  920. NULL, "kvm-pv-tlb-flush", "kvm-asyncpf-vmexit", "kvm-pv-ipi",
  921. "kvm-poll-control", "kvm-pv-sched-yield", "kvm-asyncpf-int", "kvm-msi-ext-dest-id",
  922. NULL, NULL, NULL, NULL,
  923. NULL, NULL, NULL, NULL,
  924. "kvmclock-stable-bit", NULL, NULL, NULL,
  925. NULL, NULL, NULL, NULL,
  926. },
  927. .cpuid = { .eax = KVM_CPUID_FEATURES, .reg = R_EAX, },
  928. .tcg_features = TCG_KVM_FEATURES,
  929. },
  930. [FEAT_KVM_HINTS] = {
  931. .type = CPUID_FEATURE_WORD,
  932. .feat_names = {
  933. "kvm-hint-dedicated", NULL, NULL, NULL,
  934. NULL, NULL, NULL, NULL,
  935. NULL, NULL, NULL, NULL,
  936. NULL, NULL, NULL, NULL,
  937. NULL, NULL, NULL, NULL,
  938. NULL, NULL, NULL, NULL,
  939. NULL, NULL, NULL, NULL,
  940. NULL, NULL, NULL, NULL,
  941. },
  942. .cpuid = { .eax = KVM_CPUID_FEATURES, .reg = R_EDX, },
  943. .tcg_features = TCG_KVM_FEATURES,
  944. /*
  945. * KVM hints aren't auto-enabled by -cpu host, they need to be
  946. * explicitly enabled in the command-line.
  947. */
  948. .no_autoenable_flags = ~0U,
  949. },
  950. [FEAT_SVM] = {
  951. .type = CPUID_FEATURE_WORD,
  952. .feat_names = {
  953. "npt", "lbrv", "svm-lock", "nrip-save",
  954. "tsc-scale", "vmcb-clean", "flushbyasid", "decodeassists",
  955. NULL, NULL, "pause-filter", NULL,
  956. "pfthreshold", "avic", NULL, "v-vmsave-vmload",
  957. "vgif", NULL, NULL, NULL,
  958. NULL, NULL, NULL, NULL,
  959. NULL, "vnmi", NULL, NULL,
  960. "svme-addr-chk", NULL, NULL, NULL,
  961. },
  962. .cpuid = { .eax = 0x8000000A, .reg = R_EDX, },
  963. .tcg_features = TCG_SVM_FEATURES,
  964. },
  965. [FEAT_7_0_EBX] = {
  966. .type = CPUID_FEATURE_WORD,
  967. .feat_names = {
  968. "fsgsbase", "tsc-adjust", "sgx", "bmi1",
  969. "hle", "avx2", NULL, "smep",
  970. "bmi2", "erms", "invpcid", "rtm",
  971. NULL, NULL, "mpx", NULL,
  972. "avx512f", "avx512dq", "rdseed", "adx",
  973. "smap", "avx512ifma", "pcommit", "clflushopt",
  974. "clwb", "intel-pt", "avx512pf", "avx512er",
  975. "avx512cd", "sha-ni", "avx512bw", "avx512vl",
  976. },
  977. .cpuid = {
  978. .eax = 7,
  979. .needs_ecx = true, .ecx = 0,
  980. .reg = R_EBX,
  981. },
  982. .tcg_features = TCG_7_0_EBX_FEATURES,
  983. },
  984. [FEAT_7_0_ECX] = {
  985. .type = CPUID_FEATURE_WORD,
  986. .feat_names = {
  987. NULL, "avx512vbmi", "umip", "pku",
  988. NULL /* ospke */, "waitpkg", "avx512vbmi2", NULL,
  989. "gfni", "vaes", "vpclmulqdq", "avx512vnni",
  990. "avx512bitalg", NULL, "avx512-vpopcntdq", NULL,
  991. "la57", NULL, NULL, NULL,
  992. NULL, NULL, "rdpid", NULL,
  993. "bus-lock-detect", "cldemote", NULL, "movdiri",
  994. "movdir64b", NULL, "sgxlc", "pks",
  995. },
  996. .cpuid = {
  997. .eax = 7,
  998. .needs_ecx = true, .ecx = 0,
  999. .reg = R_ECX,
  1000. },
  1001. .tcg_features = TCG_7_0_ECX_FEATURES,
  1002. },
  1003. [FEAT_7_0_EDX] = {
  1004. .type = CPUID_FEATURE_WORD,
  1005. .feat_names = {
  1006. NULL, NULL, "avx512-4vnniw", "avx512-4fmaps",
  1007. "fsrm", NULL, NULL, NULL,
  1008. "avx512-vp2intersect", NULL, "md-clear", NULL,
  1009. NULL, NULL, "serialize", NULL,
  1010. "tsx-ldtrk", NULL, NULL /* pconfig */, "arch-lbr",
  1011. NULL, NULL, "amx-bf16", "avx512-fp16",
  1012. "amx-tile", "amx-int8", "spec-ctrl", "stibp",
  1013. "flush-l1d", "arch-capabilities", "core-capability", "ssbd",
  1014. },
  1015. .cpuid = {
  1016. .eax = 7,
  1017. .needs_ecx = true, .ecx = 0,
  1018. .reg = R_EDX,
  1019. },
  1020. .tcg_features = TCG_7_0_EDX_FEATURES,
  1021. },
  1022. [FEAT_7_1_EAX] = {
  1023. .type = CPUID_FEATURE_WORD,
  1024. .feat_names = {
  1025. NULL, NULL, NULL, NULL,
  1026. "avx-vnni", "avx512-bf16", NULL, "cmpccxadd",
  1027. NULL, NULL, "fzrm", "fsrs",
  1028. "fsrc", NULL, NULL, NULL,
  1029. NULL, "fred", "lkgs", "wrmsrns",
  1030. NULL, "amx-fp16", NULL, "avx-ifma",
  1031. NULL, NULL, "lam", NULL,
  1032. NULL, NULL, NULL, NULL,
  1033. },
  1034. .cpuid = {
  1035. .eax = 7,
  1036. .needs_ecx = true, .ecx = 1,
  1037. .reg = R_EAX,
  1038. },
  1039. .tcg_features = TCG_7_1_EAX_FEATURES,
  1040. },
  1041. [FEAT_7_1_EDX] = {
  1042. .type = CPUID_FEATURE_WORD,
  1043. .feat_names = {
  1044. NULL, NULL, NULL, NULL,
  1045. "avx-vnni-int8", "avx-ne-convert", NULL, NULL,
  1046. "amx-complex", NULL, "avx-vnni-int16", NULL,
  1047. NULL, NULL, "prefetchiti", NULL,
  1048. NULL, NULL, NULL, NULL,
  1049. NULL, NULL, NULL, NULL,
  1050. NULL, NULL, NULL, NULL,
  1051. NULL, NULL, NULL, NULL,
  1052. },
  1053. .cpuid = {
  1054. .eax = 7,
  1055. .needs_ecx = true, .ecx = 1,
  1056. .reg = R_EDX,
  1057. },
  1058. .tcg_features = TCG_7_1_EDX_FEATURES,
  1059. },
  1060. [FEAT_7_2_EDX] = {
  1061. .type = CPUID_FEATURE_WORD,
  1062. .feat_names = {
  1063. NULL, NULL, NULL, NULL,
  1064. NULL, "mcdt-no", NULL, NULL,
  1065. NULL, NULL, NULL, NULL,
  1066. NULL, NULL, NULL, NULL,
  1067. NULL, NULL, NULL, NULL,
  1068. NULL, NULL, NULL, NULL,
  1069. NULL, NULL, NULL, NULL,
  1070. NULL, NULL, NULL, NULL,
  1071. },
  1072. .cpuid = {
  1073. .eax = 7,
  1074. .needs_ecx = true, .ecx = 2,
  1075. .reg = R_EDX,
  1076. },
  1077. .tcg_features = TCG_7_2_EDX_FEATURES,
  1078. },
  1079. [FEAT_8000_0007_EDX] = {
  1080. .type = CPUID_FEATURE_WORD,
  1081. .feat_names = {
  1082. NULL, NULL, NULL, NULL,
  1083. NULL, NULL, NULL, NULL,
  1084. "invtsc", NULL, NULL, NULL,
  1085. NULL, NULL, NULL, NULL,
  1086. NULL, NULL, NULL, NULL,
  1087. NULL, NULL, NULL, NULL,
  1088. NULL, NULL, NULL, NULL,
  1089. NULL, NULL, NULL, NULL,
  1090. },
  1091. .cpuid = { .eax = 0x80000007, .reg = R_EDX, },
  1092. .tcg_features = TCG_APM_FEATURES,
  1093. .unmigratable_flags = CPUID_APM_INVTSC,
  1094. },
  1095. [FEAT_8000_0007_EBX] = {
  1096. .type = CPUID_FEATURE_WORD,
  1097. .feat_names = {
  1098. "overflow-recov", "succor", NULL, NULL,
  1099. NULL, NULL, NULL, NULL,
  1100. NULL, NULL, NULL, NULL,
  1101. NULL, NULL, NULL, NULL,
  1102. NULL, NULL, NULL, NULL,
  1103. NULL, NULL, NULL, NULL,
  1104. NULL, NULL, NULL, NULL,
  1105. NULL, NULL, NULL, NULL,
  1106. },
  1107. .cpuid = { .eax = 0x80000007, .reg = R_EBX, },
  1108. .tcg_features = 0,
  1109. .unmigratable_flags = 0,
  1110. },
  1111. [FEAT_8000_0008_EBX] = {
  1112. .type = CPUID_FEATURE_WORD,
  1113. .feat_names = {
  1114. "clzero", NULL, "xsaveerptr", NULL,
  1115. NULL, NULL, NULL, NULL,
  1116. NULL, "wbnoinvd", NULL, NULL,
  1117. "ibpb", NULL, "ibrs", "amd-stibp",
  1118. NULL, "stibp-always-on", NULL, NULL,
  1119. NULL, NULL, NULL, NULL,
  1120. "amd-ssbd", "virt-ssbd", "amd-no-ssb", NULL,
  1121. "amd-psfd", NULL, NULL, NULL,
  1122. },
  1123. .cpuid = { .eax = 0x80000008, .reg = R_EBX, },
  1124. .tcg_features = TCG_8000_0008_EBX,
  1125. .unmigratable_flags = 0,
  1126. },
  1127. [FEAT_8000_0021_EAX] = {
  1128. .type = CPUID_FEATURE_WORD,
  1129. .feat_names = {
  1130. "no-nested-data-bp", NULL, "lfence-always-serializing", NULL,
  1131. NULL, NULL, "null-sel-clr-base", NULL,
  1132. "auto-ibrs", NULL, NULL, NULL,
  1133. NULL, NULL, NULL, NULL,
  1134. NULL, NULL, NULL, NULL,
  1135. NULL, NULL, NULL, NULL,
  1136. NULL, NULL, NULL, "sbpb",
  1137. "ibpb-brtype", NULL, NULL, NULL,
  1138. },
  1139. .cpuid = { .eax = 0x80000021, .reg = R_EAX, },
  1140. .tcg_features = 0,
  1141. .unmigratable_flags = 0,
  1142. },
  1143. [FEAT_XSAVE] = {
  1144. .type = CPUID_FEATURE_WORD,
  1145. .feat_names = {
  1146. "xsaveopt", "xsavec", "xgetbv1", "xsaves",
  1147. "xfd", NULL, NULL, NULL,
  1148. NULL, NULL, NULL, NULL,
  1149. NULL, NULL, NULL, NULL,
  1150. NULL, NULL, NULL, NULL,
  1151. NULL, NULL, NULL, NULL,
  1152. NULL, NULL, NULL, NULL,
  1153. NULL, NULL, NULL, NULL,
  1154. },
  1155. .cpuid = {
  1156. .eax = 0xd,
  1157. .needs_ecx = true, .ecx = 1,
  1158. .reg = R_EAX,
  1159. },
  1160. .tcg_features = TCG_XSAVE_FEATURES,
  1161. },
  1162. [FEAT_XSAVE_XSS_LO] = {
  1163. .type = CPUID_FEATURE_WORD,
  1164. .feat_names = {
  1165. NULL, NULL, NULL, NULL,
  1166. NULL, NULL, NULL, NULL,
  1167. NULL, NULL, NULL, NULL,
  1168. NULL, NULL, NULL, NULL,
  1169. NULL, NULL, NULL, NULL,
  1170. NULL, NULL, NULL, NULL,
  1171. NULL, NULL, NULL, NULL,
  1172. NULL, NULL, NULL, NULL,
  1173. },
  1174. .cpuid = {
  1175. .eax = 0xD,
  1176. .needs_ecx = true,
  1177. .ecx = 1,
  1178. .reg = R_ECX,
  1179. },
  1180. },
  1181. [FEAT_XSAVE_XSS_HI] = {
  1182. .type = CPUID_FEATURE_WORD,
  1183. .cpuid = {
  1184. .eax = 0xD,
  1185. .needs_ecx = true,
  1186. .ecx = 1,
  1187. .reg = R_EDX
  1188. },
  1189. },
  1190. [FEAT_6_EAX] = {
  1191. .type = CPUID_FEATURE_WORD,
  1192. .feat_names = {
  1193. NULL, NULL, "arat", NULL,
  1194. NULL, NULL, NULL, NULL,
  1195. NULL, NULL, NULL, NULL,
  1196. NULL, NULL, NULL, NULL,
  1197. NULL, NULL, NULL, NULL,
  1198. NULL, NULL, NULL, NULL,
  1199. NULL, NULL, NULL, NULL,
  1200. NULL, NULL, NULL, NULL,
  1201. },
  1202. .cpuid = { .eax = 6, .reg = R_EAX, },
  1203. .tcg_features = TCG_6_EAX_FEATURES,
  1204. },
  1205. [FEAT_XSAVE_XCR0_LO] = {
  1206. .type = CPUID_FEATURE_WORD,
  1207. .cpuid = {
  1208. .eax = 0xD,
  1209. .needs_ecx = true, .ecx = 0,
  1210. .reg = R_EAX,
  1211. },
  1212. .tcg_features = ~0U,
  1213. .migratable_flags = XSTATE_FP_MASK | XSTATE_SSE_MASK |
  1214. XSTATE_YMM_MASK | XSTATE_BNDREGS_MASK | XSTATE_BNDCSR_MASK |
  1215. XSTATE_OPMASK_MASK | XSTATE_ZMM_Hi256_MASK | XSTATE_Hi16_ZMM_MASK |
  1216. XSTATE_PKRU_MASK,
  1217. },
  1218. [FEAT_XSAVE_XCR0_HI] = {
  1219. .type = CPUID_FEATURE_WORD,
  1220. .cpuid = {
  1221. .eax = 0xD,
  1222. .needs_ecx = true, .ecx = 0,
  1223. .reg = R_EDX,
  1224. },
  1225. .tcg_features = ~0U,
  1226. },
  1227. /*Below are MSR exposed features*/
  1228. [FEAT_ARCH_CAPABILITIES] = {
  1229. .type = MSR_FEATURE_WORD,
  1230. .feat_names = {
  1231. "rdctl-no", "ibrs-all", "rsba", "skip-l1dfl-vmentry",
  1232. "ssb-no", "mds-no", "pschange-mc-no", "tsx-ctrl",
  1233. "taa-no", NULL, NULL, NULL,
  1234. NULL, "sbdr-ssdp-no", "fbsdp-no", "psdp-no",
  1235. NULL, "fb-clear", NULL, NULL,
  1236. NULL, NULL, NULL, NULL,
  1237. "pbrsb-no", NULL, "gds-no", "rfds-no",
  1238. "rfds-clear", NULL, NULL, NULL,
  1239. },
  1240. .msr = {
  1241. .index = MSR_IA32_ARCH_CAPABILITIES,
  1242. },
  1243. /*
  1244. * FEAT_ARCH_CAPABILITIES only affects a read-only MSR, which
  1245. * cannot be read from user mode. Therefore, it has no impact
  1246. > on any user-mode operation, and warnings about unsupported
  1247. * features do not matter.
  1248. */
  1249. .tcg_features = ~0U,
  1250. },
  1251. [FEAT_CORE_CAPABILITY] = {
  1252. .type = MSR_FEATURE_WORD,
  1253. .feat_names = {
  1254. NULL, NULL, NULL, NULL,
  1255. NULL, "split-lock-detect", NULL, NULL,
  1256. NULL, NULL, NULL, NULL,
  1257. NULL, NULL, NULL, NULL,
  1258. NULL, NULL, NULL, NULL,
  1259. NULL, NULL, NULL, NULL,
  1260. NULL, NULL, NULL, NULL,
  1261. NULL, NULL, NULL, NULL,
  1262. },
  1263. .msr = {
  1264. .index = MSR_IA32_CORE_CAPABILITY,
  1265. },
  1266. },
  1267. [FEAT_PERF_CAPABILITIES] = {
  1268. .type = MSR_FEATURE_WORD,
  1269. .feat_names = {
  1270. NULL, NULL, NULL, NULL,
  1271. NULL, NULL, NULL, NULL,
  1272. NULL, NULL, NULL, NULL,
  1273. NULL, "full-width-write", NULL, NULL,
  1274. NULL, NULL, NULL, NULL,
  1275. NULL, NULL, NULL, NULL,
  1276. NULL, NULL, NULL, NULL,
  1277. NULL, NULL, NULL, NULL,
  1278. },
  1279. .msr = {
  1280. .index = MSR_IA32_PERF_CAPABILITIES,
  1281. },
  1282. },
  1283. [FEAT_VMX_PROCBASED_CTLS] = {
  1284. .type = MSR_FEATURE_WORD,
  1285. .feat_names = {
  1286. NULL, NULL, "vmx-vintr-pending", "vmx-tsc-offset",
  1287. NULL, NULL, NULL, "vmx-hlt-exit",
  1288. NULL, "vmx-invlpg-exit", "vmx-mwait-exit", "vmx-rdpmc-exit",
  1289. "vmx-rdtsc-exit", NULL, NULL, "vmx-cr3-load-noexit",
  1290. "vmx-cr3-store-noexit", NULL, NULL, "vmx-cr8-load-exit",
  1291. "vmx-cr8-store-exit", "vmx-flexpriority", "vmx-vnmi-pending", "vmx-movdr-exit",
  1292. "vmx-io-exit", "vmx-io-bitmap", NULL, "vmx-mtf",
  1293. "vmx-msr-bitmap", "vmx-monitor-exit", "vmx-pause-exit", "vmx-secondary-ctls",
  1294. },
  1295. .msr = {
  1296. .index = MSR_IA32_VMX_TRUE_PROCBASED_CTLS,
  1297. }
  1298. },
  1299. [FEAT_VMX_SECONDARY_CTLS] = {
  1300. .type = MSR_FEATURE_WORD,
  1301. .feat_names = {
  1302. "vmx-apicv-xapic", "vmx-ept", "vmx-desc-exit", "vmx-rdtscp-exit",
  1303. "vmx-apicv-x2apic", "vmx-vpid", "vmx-wbinvd-exit", "vmx-unrestricted-guest",
  1304. "vmx-apicv-register", "vmx-apicv-vid", "vmx-ple", "vmx-rdrand-exit",
  1305. "vmx-invpcid-exit", "vmx-vmfunc", "vmx-shadow-vmcs", "vmx-encls-exit",
  1306. "vmx-rdseed-exit", "vmx-pml", NULL, NULL,
  1307. "vmx-xsaves", NULL, NULL, NULL,
  1308. NULL, "vmx-tsc-scaling", "vmx-enable-user-wait-pause", NULL,
  1309. NULL, NULL, NULL, NULL,
  1310. },
  1311. .msr = {
  1312. .index = MSR_IA32_VMX_PROCBASED_CTLS2,
  1313. }
  1314. },
  1315. [FEAT_VMX_PINBASED_CTLS] = {
  1316. .type = MSR_FEATURE_WORD,
  1317. .feat_names = {
  1318. "vmx-intr-exit", NULL, NULL, "vmx-nmi-exit",
  1319. NULL, "vmx-vnmi", "vmx-preemption-timer", "vmx-posted-intr",
  1320. NULL, NULL, NULL, NULL,
  1321. NULL, NULL, NULL, NULL,
  1322. NULL, NULL, NULL, NULL,
  1323. NULL, NULL, NULL, NULL,
  1324. NULL, NULL, NULL, NULL,
  1325. NULL, NULL, NULL, NULL,
  1326. },
  1327. .msr = {
  1328. .index = MSR_IA32_VMX_TRUE_PINBASED_CTLS,
  1329. }
  1330. },
  1331. [FEAT_VMX_EXIT_CTLS] = {
  1332. .type = MSR_FEATURE_WORD,
  1333. /*
  1334. * VMX_VM_EXIT_HOST_ADDR_SPACE_SIZE is copied from
  1335. * the LM CPUID bit.
  1336. */
  1337. .feat_names = {
  1338. NULL, NULL, "vmx-exit-nosave-debugctl", NULL,
  1339. NULL, NULL, NULL, NULL,
  1340. NULL, NULL /* vmx-exit-host-addr-space-size */, NULL, NULL,
  1341. "vmx-exit-load-perf-global-ctrl", NULL, NULL, "vmx-exit-ack-intr",
  1342. NULL, NULL, "vmx-exit-save-pat", "vmx-exit-load-pat",
  1343. "vmx-exit-save-efer", "vmx-exit-load-efer",
  1344. "vmx-exit-save-preemption-timer", "vmx-exit-clear-bndcfgs",
  1345. NULL, "vmx-exit-clear-rtit-ctl", NULL, NULL,
  1346. NULL, "vmx-exit-load-pkrs", NULL, "vmx-exit-secondary-ctls",
  1347. },
  1348. .msr = {
  1349. .index = MSR_IA32_VMX_TRUE_EXIT_CTLS,
  1350. }
  1351. },
  1352. [FEAT_VMX_ENTRY_CTLS] = {
  1353. .type = MSR_FEATURE_WORD,
  1354. .feat_names = {
  1355. NULL, NULL, "vmx-entry-noload-debugctl", NULL,
  1356. NULL, NULL, NULL, NULL,
  1357. NULL, "vmx-entry-ia32e-mode", NULL, NULL,
  1358. NULL, "vmx-entry-load-perf-global-ctrl", "vmx-entry-load-pat", "vmx-entry-load-efer",
  1359. "vmx-entry-load-bndcfgs", NULL, "vmx-entry-load-rtit-ctl", NULL,
  1360. NULL, NULL, "vmx-entry-load-pkrs", "vmx-entry-load-fred",
  1361. NULL, NULL, NULL, NULL,
  1362. NULL, NULL, NULL, NULL,
  1363. },
  1364. .msr = {
  1365. .index = MSR_IA32_VMX_TRUE_ENTRY_CTLS,
  1366. }
  1367. },
  1368. [FEAT_VMX_MISC] = {
  1369. .type = MSR_FEATURE_WORD,
  1370. .feat_names = {
  1371. NULL, NULL, NULL, NULL,
  1372. NULL, "vmx-store-lma", "vmx-activity-hlt", "vmx-activity-shutdown",
  1373. "vmx-activity-wait-sipi", NULL, NULL, NULL,
  1374. NULL, NULL, NULL, NULL,
  1375. NULL, NULL, NULL, NULL,
  1376. NULL, NULL, NULL, NULL,
  1377. NULL, NULL, NULL, NULL,
  1378. NULL, "vmx-vmwrite-vmexit-fields", "vmx-zero-len-inject", NULL,
  1379. },
  1380. .msr = {
  1381. .index = MSR_IA32_VMX_MISC,
  1382. }
  1383. },
  1384. [FEAT_VMX_EPT_VPID_CAPS] = {
  1385. .type = MSR_FEATURE_WORD,
  1386. .feat_names = {
  1387. "vmx-ept-execonly", NULL, NULL, NULL,
  1388. NULL, NULL, "vmx-page-walk-4", "vmx-page-walk-5",
  1389. NULL, NULL, NULL, NULL,
  1390. NULL, NULL, NULL, NULL,
  1391. "vmx-ept-2mb", "vmx-ept-1gb", NULL, NULL,
  1392. "vmx-invept", "vmx-eptad", "vmx-ept-advanced-exitinfo", NULL,
  1393. NULL, "vmx-invept-single-context", "vmx-invept-all-context", NULL,
  1394. NULL, NULL, NULL, NULL,
  1395. "vmx-invvpid", NULL, NULL, NULL,
  1396. NULL, NULL, NULL, NULL,
  1397. "vmx-invvpid-single-addr", "vmx-invept-single-context",
  1398. "vmx-invvpid-all-context", "vmx-invept-single-context-noglobals",
  1399. NULL, NULL, NULL, NULL,
  1400. NULL, NULL, NULL, NULL,
  1401. NULL, NULL, NULL, NULL,
  1402. NULL, NULL, NULL, NULL,
  1403. NULL, NULL, NULL, NULL,
  1404. },
  1405. .msr = {
  1406. .index = MSR_IA32_VMX_EPT_VPID_CAP,
  1407. }
  1408. },
  1409. [FEAT_VMX_BASIC] = {
  1410. .type = MSR_FEATURE_WORD,
  1411. .feat_names = {
  1412. [54] = "vmx-ins-outs",
  1413. [55] = "vmx-true-ctls",
  1414. [56] = "vmx-any-errcode",
  1415. [58] = "vmx-nested-exception",
  1416. },
  1417. .msr = {
  1418. .index = MSR_IA32_VMX_BASIC,
  1419. },
  1420. /* Just to be safe - we don't support setting the MSEG version field. */
  1421. .no_autoenable_flags = MSR_VMX_BASIC_DUAL_MONITOR,
  1422. },
  1423. [FEAT_VMX_VMFUNC] = {
  1424. .type = MSR_FEATURE_WORD,
  1425. .feat_names = {
  1426. [0] = "vmx-eptp-switching",
  1427. },
  1428. .msr = {
  1429. .index = MSR_IA32_VMX_VMFUNC,
  1430. }
  1431. },
  1432. [FEAT_14_0_ECX] = {
  1433. .type = CPUID_FEATURE_WORD,
  1434. .feat_names = {
  1435. NULL, NULL, NULL, NULL,
  1436. NULL, NULL, NULL, NULL,
  1437. NULL, NULL, NULL, NULL,
  1438. NULL, NULL, NULL, NULL,
  1439. NULL, NULL, NULL, NULL,
  1440. NULL, NULL, NULL, NULL,
  1441. NULL, NULL, NULL, NULL,
  1442. NULL, NULL, NULL, "intel-pt-lip",
  1443. },
  1444. .cpuid = {
  1445. .eax = 0x14,
  1446. .needs_ecx = true, .ecx = 0,
  1447. .reg = R_ECX,
  1448. },
  1449. .tcg_features = TCG_14_0_ECX_FEATURES,
  1450. },
  1451. [FEAT_SGX_12_0_EAX] = {
  1452. .type = CPUID_FEATURE_WORD,
  1453. .feat_names = {
  1454. "sgx1", "sgx2", NULL, NULL,
  1455. NULL, NULL, NULL, NULL,
  1456. NULL, NULL, NULL, "sgx-edeccssa",
  1457. NULL, NULL, NULL, NULL,
  1458. NULL, NULL, NULL, NULL,
  1459. NULL, NULL, NULL, NULL,
  1460. NULL, NULL, NULL, NULL,
  1461. NULL, NULL, NULL, NULL,
  1462. },
  1463. .cpuid = {
  1464. .eax = 0x12,
  1465. .needs_ecx = true, .ecx = 0,
  1466. .reg = R_EAX,
  1467. },
  1468. .tcg_features = TCG_SGX_12_0_EAX_FEATURES,
  1469. },
  1470. [FEAT_SGX_12_0_EBX] = {
  1471. .type = CPUID_FEATURE_WORD,
  1472. .feat_names = {
  1473. "sgx-exinfo" , NULL, NULL, NULL,
  1474. NULL, NULL, NULL, NULL,
  1475. NULL, NULL, NULL, NULL,
  1476. NULL, NULL, NULL, NULL,
  1477. NULL, NULL, NULL, NULL,
  1478. NULL, NULL, NULL, NULL,
  1479. NULL, NULL, NULL, NULL,
  1480. NULL, NULL, NULL, NULL,
  1481. },
  1482. .cpuid = {
  1483. .eax = 0x12,
  1484. .needs_ecx = true, .ecx = 0,
  1485. .reg = R_EBX,
  1486. },
  1487. .tcg_features = TCG_SGX_12_0_EBX_FEATURES,
  1488. },
  1489. [FEAT_SGX_12_1_EAX] = {
  1490. .type = CPUID_FEATURE_WORD,
  1491. .feat_names = {
  1492. NULL, "sgx-debug", "sgx-mode64", NULL,
  1493. "sgx-provisionkey", "sgx-tokenkey", NULL, "sgx-kss",
  1494. NULL, NULL, "sgx-aex-notify", NULL,
  1495. NULL, NULL, NULL, NULL,
  1496. NULL, NULL, NULL, NULL,
  1497. NULL, NULL, NULL, NULL,
  1498. NULL, NULL, NULL, NULL,
  1499. NULL, NULL, NULL, NULL,
  1500. },
  1501. .cpuid = {
  1502. .eax = 0x12,
  1503. .needs_ecx = true, .ecx = 1,
  1504. .reg = R_EAX,
  1505. },
  1506. .tcg_features = TCG_SGX_12_1_EAX_FEATURES,
  1507. },
  1508. };
  1509. typedef struct FeatureMask {
  1510. FeatureWord index;
  1511. uint64_t mask;
  1512. } FeatureMask;
  1513. typedef struct FeatureDep {
  1514. FeatureMask from, to;
  1515. } FeatureDep;
  1516. static FeatureDep feature_dependencies[] = {
  1517. {
  1518. .from = { FEAT_7_0_EDX, CPUID_7_0_EDX_ARCH_CAPABILITIES },
  1519. .to = { FEAT_ARCH_CAPABILITIES, ~0ull },
  1520. },
  1521. {
  1522. .from = { FEAT_7_0_EDX, CPUID_7_0_EDX_CORE_CAPABILITY },
  1523. .to = { FEAT_CORE_CAPABILITY, ~0ull },
  1524. },
  1525. {
  1526. .from = { FEAT_1_ECX, CPUID_EXT_PDCM },
  1527. .to = { FEAT_PERF_CAPABILITIES, ~0ull },
  1528. },
  1529. {
  1530. .from = { FEAT_1_ECX, CPUID_EXT_VMX },
  1531. .to = { FEAT_VMX_PROCBASED_CTLS, ~0ull },
  1532. },
  1533. {
  1534. .from = { FEAT_1_ECX, CPUID_EXT_VMX },
  1535. .to = { FEAT_VMX_PINBASED_CTLS, ~0ull },
  1536. },
  1537. {
  1538. .from = { FEAT_1_ECX, CPUID_EXT_VMX },
  1539. .to = { FEAT_VMX_EXIT_CTLS, ~0ull },
  1540. },
  1541. {
  1542. .from = { FEAT_1_ECX, CPUID_EXT_VMX },
  1543. .to = { FEAT_VMX_ENTRY_CTLS, ~0ull },
  1544. },
  1545. {
  1546. .from = { FEAT_1_ECX, CPUID_EXT_VMX },
  1547. .to = { FEAT_VMX_MISC, ~0ull },
  1548. },
  1549. {
  1550. .from = { FEAT_1_ECX, CPUID_EXT_VMX },
  1551. .to = { FEAT_VMX_BASIC, ~0ull },
  1552. },
  1553. {
  1554. .from = { FEAT_8000_0001_EDX, CPUID_EXT2_LM },
  1555. .to = { FEAT_VMX_ENTRY_CTLS, VMX_VM_ENTRY_IA32E_MODE },
  1556. },
  1557. {
  1558. .from = { FEAT_VMX_PROCBASED_CTLS, VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS },
  1559. .to = { FEAT_VMX_SECONDARY_CTLS, ~0ull },
  1560. },
  1561. {
  1562. .from = { FEAT_XSAVE, CPUID_XSAVE_XSAVES },
  1563. .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_XSAVES },
  1564. },
  1565. {
  1566. .from = { FEAT_1_ECX, CPUID_EXT_RDRAND },
  1567. .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDRAND_EXITING },
  1568. },
  1569. {
  1570. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_INVPCID },
  1571. .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_INVPCID },
  1572. },
  1573. {
  1574. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_MPX },
  1575. .to = { FEAT_VMX_EXIT_CTLS, VMX_VM_EXIT_CLEAR_BNDCFGS },
  1576. },
  1577. {
  1578. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_MPX },
  1579. .to = { FEAT_VMX_ENTRY_CTLS, VMX_VM_ENTRY_LOAD_BNDCFGS },
  1580. },
  1581. {
  1582. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_RDSEED },
  1583. .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDSEED_EXITING },
  1584. },
  1585. {
  1586. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_INTEL_PT },
  1587. .to = { FEAT_14_0_ECX, ~0ull },
  1588. },
  1589. {
  1590. .from = { FEAT_8000_0001_EDX, CPUID_EXT2_RDTSCP },
  1591. .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_RDTSCP },
  1592. },
  1593. {
  1594. .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_EPT },
  1595. .to = { FEAT_VMX_EPT_VPID_CAPS, 0xffffffffull },
  1596. },
  1597. {
  1598. .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_EPT },
  1599. .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST },
  1600. },
  1601. {
  1602. .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_VPID },
  1603. .to = { FEAT_VMX_EPT_VPID_CAPS, 0xffffffffull << 32 },
  1604. },
  1605. {
  1606. .from = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_VMFUNC },
  1607. .to = { FEAT_VMX_VMFUNC, ~0ull },
  1608. },
  1609. {
  1610. .from = { FEAT_8000_0001_ECX, CPUID_EXT3_SVM },
  1611. .to = { FEAT_SVM, ~0ull },
  1612. },
  1613. {
  1614. .from = { FEAT_7_0_ECX, CPUID_7_0_ECX_WAITPKG },
  1615. .to = { FEAT_VMX_SECONDARY_CTLS, VMX_SECONDARY_EXEC_ENABLE_USER_WAIT_PAUSE },
  1616. },
  1617. {
  1618. .from = { FEAT_8000_0001_EDX, CPUID_EXT2_LM },
  1619. .to = { FEAT_7_1_EAX, CPUID_7_1_EAX_FRED },
  1620. },
  1621. {
  1622. .from = { FEAT_7_1_EAX, CPUID_7_1_EAX_LKGS },
  1623. .to = { FEAT_7_1_EAX, CPUID_7_1_EAX_FRED },
  1624. },
  1625. {
  1626. .from = { FEAT_7_1_EAX, CPUID_7_1_EAX_WRMSRNS },
  1627. .to = { FEAT_7_1_EAX, CPUID_7_1_EAX_FRED },
  1628. },
  1629. {
  1630. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
  1631. .to = { FEAT_7_0_ECX, CPUID_7_0_ECX_SGX_LC },
  1632. },
  1633. {
  1634. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
  1635. .to = { FEAT_SGX_12_0_EAX, ~0ull },
  1636. },
  1637. {
  1638. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
  1639. .to = { FEAT_SGX_12_0_EBX, ~0ull },
  1640. },
  1641. {
  1642. .from = { FEAT_7_0_EBX, CPUID_7_0_EBX_SGX },
  1643. .to = { FEAT_SGX_12_1_EAX, ~0ull },
  1644. },
  1645. };
  1646. typedef struct X86RegisterInfo32 {
  1647. /* Name of register */
  1648. const char *name;
  1649. /* QAPI enum value register */
  1650. X86CPURegister32 qapi_enum;
  1651. } X86RegisterInfo32;
  1652. #define REGISTER(reg) \
  1653. [R_##reg] = { .name = #reg, .qapi_enum = X86_CPU_REGISTER32_##reg }
  1654. static const X86RegisterInfo32 x86_reg_info_32[CPU_NB_REGS32] = {
  1655. REGISTER(EAX),
  1656. REGISTER(ECX),
  1657. REGISTER(EDX),
  1658. REGISTER(EBX),
  1659. REGISTER(ESP),
  1660. REGISTER(EBP),
  1661. REGISTER(ESI),
  1662. REGISTER(EDI),
  1663. };
  1664. #undef REGISTER
  1665. /* CPUID feature bits available in XSS */
  1666. #define CPUID_XSTATE_XSS_MASK (XSTATE_ARCH_LBR_MASK)
  1667. ExtSaveArea x86_ext_save_areas[XSAVE_STATE_AREA_COUNT] = {
  1668. [XSTATE_FP_BIT] = {
  1669. /* x87 FP state component is always enabled if XSAVE is supported */
  1670. .feature = FEAT_1_ECX, .bits = CPUID_EXT_XSAVE,
  1671. .size = sizeof(X86LegacyXSaveArea) + sizeof(X86XSaveHeader),
  1672. },
  1673. [XSTATE_SSE_BIT] = {
  1674. /* SSE state component is always enabled if XSAVE is supported */
  1675. .feature = FEAT_1_ECX, .bits = CPUID_EXT_XSAVE,
  1676. .size = sizeof(X86LegacyXSaveArea) + sizeof(X86XSaveHeader),
  1677. },
  1678. [XSTATE_YMM_BIT] =
  1679. { .feature = FEAT_1_ECX, .bits = CPUID_EXT_AVX,
  1680. .size = sizeof(XSaveAVX) },
  1681. [XSTATE_BNDREGS_BIT] =
  1682. { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_MPX,
  1683. .size = sizeof(XSaveBNDREG) },
  1684. [XSTATE_BNDCSR_BIT] =
  1685. { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_MPX,
  1686. .size = sizeof(XSaveBNDCSR) },
  1687. [XSTATE_OPMASK_BIT] =
  1688. { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
  1689. .size = sizeof(XSaveOpmask) },
  1690. [XSTATE_ZMM_Hi256_BIT] =
  1691. { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
  1692. .size = sizeof(XSaveZMM_Hi256) },
  1693. [XSTATE_Hi16_ZMM_BIT] =
  1694. { .feature = FEAT_7_0_EBX, .bits = CPUID_7_0_EBX_AVX512F,
  1695. .size = sizeof(XSaveHi16_ZMM) },
  1696. [XSTATE_PKRU_BIT] =
  1697. { .feature = FEAT_7_0_ECX, .bits = CPUID_7_0_ECX_PKU,
  1698. .size = sizeof(XSavePKRU) },
  1699. [XSTATE_ARCH_LBR_BIT] = {
  1700. .feature = FEAT_7_0_EDX, .bits = CPUID_7_0_EDX_ARCH_LBR,
  1701. .offset = 0 /*supervisor mode component, offset = 0 */,
  1702. .size = sizeof(XSavesArchLBR) },
  1703. [XSTATE_XTILE_CFG_BIT] = {
  1704. .feature = FEAT_7_0_EDX, .bits = CPUID_7_0_EDX_AMX_TILE,
  1705. .size = sizeof(XSaveXTILECFG),
  1706. },
  1707. [XSTATE_XTILE_DATA_BIT] = {
  1708. .feature = FEAT_7_0_EDX, .bits = CPUID_7_0_EDX_AMX_TILE,
  1709. .size = sizeof(XSaveXTILEDATA)
  1710. },
  1711. };
  1712. uint32_t xsave_area_size(uint64_t mask, bool compacted)
  1713. {
  1714. uint64_t ret = x86_ext_save_areas[0].size;
  1715. const ExtSaveArea *esa;
  1716. uint32_t offset = 0;
  1717. int i;
  1718. for (i = 2; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
  1719. esa = &x86_ext_save_areas[i];
  1720. if ((mask >> i) & 1) {
  1721. offset = compacted ? ret : esa->offset;
  1722. ret = MAX(ret, offset + esa->size);
  1723. }
  1724. }
  1725. return ret;
  1726. }
  1727. static inline bool accel_uses_host_cpuid(void)
  1728. {
  1729. return kvm_enabled() || hvf_enabled();
  1730. }
  1731. static inline uint64_t x86_cpu_xsave_xcr0_components(X86CPU *cpu)
  1732. {
  1733. return ((uint64_t)cpu->env.features[FEAT_XSAVE_XCR0_HI]) << 32 |
  1734. cpu->env.features[FEAT_XSAVE_XCR0_LO];
  1735. }
  1736. /* Return name of 32-bit register, from a R_* constant */
  1737. static const char *get_register_name_32(unsigned int reg)
  1738. {
  1739. if (reg >= CPU_NB_REGS32) {
  1740. return NULL;
  1741. }
  1742. return x86_reg_info_32[reg].name;
  1743. }
  1744. static inline uint64_t x86_cpu_xsave_xss_components(X86CPU *cpu)
  1745. {
  1746. return ((uint64_t)cpu->env.features[FEAT_XSAVE_XSS_HI]) << 32 |
  1747. cpu->env.features[FEAT_XSAVE_XSS_LO];
  1748. }
  1749. /*
  1750. * Returns the set of feature flags that are supported and migratable by
  1751. * QEMU, for a given FeatureWord.
  1752. */
  1753. static uint64_t x86_cpu_get_migratable_flags(FeatureWord w)
  1754. {
  1755. FeatureWordInfo *wi = &feature_word_info[w];
  1756. uint64_t r = 0;
  1757. int i;
  1758. for (i = 0; i < 64; i++) {
  1759. uint64_t f = 1ULL << i;
  1760. /* If the feature name is known, it is implicitly considered migratable,
  1761. * unless it is explicitly set in unmigratable_flags */
  1762. if ((wi->migratable_flags & f) ||
  1763. (wi->feat_names[i] && !(wi->unmigratable_flags & f))) {
  1764. r |= f;
  1765. }
  1766. }
  1767. return r;
  1768. }
  1769. void host_cpuid(uint32_t function, uint32_t count,
  1770. uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx)
  1771. {
  1772. uint32_t vec[4];
  1773. #ifdef __x86_64__
  1774. asm volatile("cpuid"
  1775. : "=a"(vec[0]), "=b"(vec[1]),
  1776. "=c"(vec[2]), "=d"(vec[3])
  1777. : "0"(function), "c"(count) : "cc");
  1778. #elif defined(__i386__)
  1779. asm volatile("pusha \n\t"
  1780. "cpuid \n\t"
  1781. "mov %%eax, 0(%2) \n\t"
  1782. "mov %%ebx, 4(%2) \n\t"
  1783. "mov %%ecx, 8(%2) \n\t"
  1784. "mov %%edx, 12(%2) \n\t"
  1785. "popa"
  1786. : : "a"(function), "c"(count), "S"(vec)
  1787. : "memory", "cc");
  1788. #else
  1789. abort();
  1790. #endif
  1791. if (eax)
  1792. *eax = vec[0];
  1793. if (ebx)
  1794. *ebx = vec[1];
  1795. if (ecx)
  1796. *ecx = vec[2];
  1797. if (edx)
  1798. *edx = vec[3];
  1799. }
  1800. /* CPU class name definitions: */
  1801. /* Return type name for a given CPU model name
  1802. * Caller is responsible for freeing the returned string.
  1803. */
  1804. static char *x86_cpu_type_name(const char *model_name)
  1805. {
  1806. return g_strdup_printf(X86_CPU_TYPE_NAME("%s"), model_name);
  1807. }
  1808. static ObjectClass *x86_cpu_class_by_name(const char *cpu_model)
  1809. {
  1810. g_autofree char *typename = x86_cpu_type_name(cpu_model);
  1811. return object_class_by_name(typename);
  1812. }
  1813. static char *x86_cpu_class_get_model_name(X86CPUClass *cc)
  1814. {
  1815. const char *class_name = object_class_get_name(OBJECT_CLASS(cc));
  1816. assert(g_str_has_suffix(class_name, X86_CPU_TYPE_SUFFIX));
  1817. return cpu_model_from_type(class_name);
  1818. }
  1819. typedef struct X86CPUVersionDefinition {
  1820. X86CPUVersion version;
  1821. const char *alias;
  1822. const char *note;
  1823. PropValue *props;
  1824. const CPUCaches *const cache_info;
  1825. } X86CPUVersionDefinition;
  1826. /* Base definition for a CPU model */
  1827. typedef struct X86CPUDefinition {
  1828. const char *name;
  1829. uint32_t level;
  1830. uint32_t xlevel;
  1831. /* vendor is zero-terminated, 12 character ASCII string */
  1832. char vendor[CPUID_VENDOR_SZ + 1];
  1833. int family;
  1834. int model;
  1835. int stepping;
  1836. FeatureWordArray features;
  1837. const char *model_id;
  1838. const CPUCaches *const cache_info;
  1839. /*
  1840. * Definitions for alternative versions of CPU model.
  1841. * List is terminated by item with version == 0.
  1842. * If NULL, version 1 will be registered automatically.
  1843. */
  1844. const X86CPUVersionDefinition *versions;
  1845. const char *deprecation_note;
  1846. } X86CPUDefinition;
  1847. /* Reference to a specific CPU model version */
  1848. struct X86CPUModel {
  1849. /* Base CPU definition */
  1850. const X86CPUDefinition *cpudef;
  1851. /* CPU model version */
  1852. X86CPUVersion version;
  1853. const char *note;
  1854. /*
  1855. * If true, this is an alias CPU model.
  1856. * This matters only for "-cpu help" and query-cpu-definitions
  1857. */
  1858. bool is_alias;
  1859. };
  1860. /* Get full model name for CPU version */
  1861. static char *x86_cpu_versioned_model_name(const X86CPUDefinition *cpudef,
  1862. X86CPUVersion version)
  1863. {
  1864. assert(version > 0);
  1865. return g_strdup_printf("%s-v%d", cpudef->name, (int)version);
  1866. }
  1867. static const X86CPUVersionDefinition *
  1868. x86_cpu_def_get_versions(const X86CPUDefinition *def)
  1869. {
  1870. /* When X86CPUDefinition::versions is NULL, we register only v1 */
  1871. static const X86CPUVersionDefinition default_version_list[] = {
  1872. { 1 },
  1873. { /* end of list */ }
  1874. };
  1875. return def->versions ?: default_version_list;
  1876. }
  1877. static const CPUCaches epyc_cache_info = {
  1878. .l1d_cache = &(CPUCacheInfo) {
  1879. .type = DATA_CACHE,
  1880. .level = 1,
  1881. .size = 32 * KiB,
  1882. .line_size = 64,
  1883. .associativity = 8,
  1884. .partitions = 1,
  1885. .sets = 64,
  1886. .lines_per_tag = 1,
  1887. .self_init = 1,
  1888. .no_invd_sharing = true,
  1889. .share_level = CPU_TOPO_LEVEL_CORE,
  1890. },
  1891. .l1i_cache = &(CPUCacheInfo) {
  1892. .type = INSTRUCTION_CACHE,
  1893. .level = 1,
  1894. .size = 64 * KiB,
  1895. .line_size = 64,
  1896. .associativity = 4,
  1897. .partitions = 1,
  1898. .sets = 256,
  1899. .lines_per_tag = 1,
  1900. .self_init = 1,
  1901. .no_invd_sharing = true,
  1902. .share_level = CPU_TOPO_LEVEL_CORE,
  1903. },
  1904. .l2_cache = &(CPUCacheInfo) {
  1905. .type = UNIFIED_CACHE,
  1906. .level = 2,
  1907. .size = 512 * KiB,
  1908. .line_size = 64,
  1909. .associativity = 8,
  1910. .partitions = 1,
  1911. .sets = 1024,
  1912. .lines_per_tag = 1,
  1913. .share_level = CPU_TOPO_LEVEL_CORE,
  1914. },
  1915. .l3_cache = &(CPUCacheInfo) {
  1916. .type = UNIFIED_CACHE,
  1917. .level = 3,
  1918. .size = 8 * MiB,
  1919. .line_size = 64,
  1920. .associativity = 16,
  1921. .partitions = 1,
  1922. .sets = 8192,
  1923. .lines_per_tag = 1,
  1924. .self_init = true,
  1925. .inclusive = true,
  1926. .complex_indexing = true,
  1927. .share_level = CPU_TOPO_LEVEL_DIE,
  1928. },
  1929. };
  1930. static CPUCaches epyc_v4_cache_info = {
  1931. .l1d_cache = &(CPUCacheInfo) {
  1932. .type = DATA_CACHE,
  1933. .level = 1,
  1934. .size = 32 * KiB,
  1935. .line_size = 64,
  1936. .associativity = 8,
  1937. .partitions = 1,
  1938. .sets = 64,
  1939. .lines_per_tag = 1,
  1940. .self_init = 1,
  1941. .no_invd_sharing = true,
  1942. .share_level = CPU_TOPO_LEVEL_CORE,
  1943. },
  1944. .l1i_cache = &(CPUCacheInfo) {
  1945. .type = INSTRUCTION_CACHE,
  1946. .level = 1,
  1947. .size = 64 * KiB,
  1948. .line_size = 64,
  1949. .associativity = 4,
  1950. .partitions = 1,
  1951. .sets = 256,
  1952. .lines_per_tag = 1,
  1953. .self_init = 1,
  1954. .no_invd_sharing = true,
  1955. .share_level = CPU_TOPO_LEVEL_CORE,
  1956. },
  1957. .l2_cache = &(CPUCacheInfo) {
  1958. .type = UNIFIED_CACHE,
  1959. .level = 2,
  1960. .size = 512 * KiB,
  1961. .line_size = 64,
  1962. .associativity = 8,
  1963. .partitions = 1,
  1964. .sets = 1024,
  1965. .lines_per_tag = 1,
  1966. .share_level = CPU_TOPO_LEVEL_CORE,
  1967. },
  1968. .l3_cache = &(CPUCacheInfo) {
  1969. .type = UNIFIED_CACHE,
  1970. .level = 3,
  1971. .size = 8 * MiB,
  1972. .line_size = 64,
  1973. .associativity = 16,
  1974. .partitions = 1,
  1975. .sets = 8192,
  1976. .lines_per_tag = 1,
  1977. .self_init = true,
  1978. .inclusive = true,
  1979. .complex_indexing = false,
  1980. .share_level = CPU_TOPO_LEVEL_DIE,
  1981. },
  1982. };
  1983. static const CPUCaches epyc_rome_cache_info = {
  1984. .l1d_cache = &(CPUCacheInfo) {
  1985. .type = DATA_CACHE,
  1986. .level = 1,
  1987. .size = 32 * KiB,
  1988. .line_size = 64,
  1989. .associativity = 8,
  1990. .partitions = 1,
  1991. .sets = 64,
  1992. .lines_per_tag = 1,
  1993. .self_init = 1,
  1994. .no_invd_sharing = true,
  1995. .share_level = CPU_TOPO_LEVEL_CORE,
  1996. },
  1997. .l1i_cache = &(CPUCacheInfo) {
  1998. .type = INSTRUCTION_CACHE,
  1999. .level = 1,
  2000. .size = 32 * KiB,
  2001. .line_size = 64,
  2002. .associativity = 8,
  2003. .partitions = 1,
  2004. .sets = 64,
  2005. .lines_per_tag = 1,
  2006. .self_init = 1,
  2007. .no_invd_sharing = true,
  2008. .share_level = CPU_TOPO_LEVEL_CORE,
  2009. },
  2010. .l2_cache = &(CPUCacheInfo) {
  2011. .type = UNIFIED_CACHE,
  2012. .level = 2,
  2013. .size = 512 * KiB,
  2014. .line_size = 64,
  2015. .associativity = 8,
  2016. .partitions = 1,
  2017. .sets = 1024,
  2018. .lines_per_tag = 1,
  2019. .share_level = CPU_TOPO_LEVEL_CORE,
  2020. },
  2021. .l3_cache = &(CPUCacheInfo) {
  2022. .type = UNIFIED_CACHE,
  2023. .level = 3,
  2024. .size = 16 * MiB,
  2025. .line_size = 64,
  2026. .associativity = 16,
  2027. .partitions = 1,
  2028. .sets = 16384,
  2029. .lines_per_tag = 1,
  2030. .self_init = true,
  2031. .inclusive = true,
  2032. .complex_indexing = true,
  2033. .share_level = CPU_TOPO_LEVEL_DIE,
  2034. },
  2035. };
  2036. static const CPUCaches epyc_rome_v3_cache_info = {
  2037. .l1d_cache = &(CPUCacheInfo) {
  2038. .type = DATA_CACHE,
  2039. .level = 1,
  2040. .size = 32 * KiB,
  2041. .line_size = 64,
  2042. .associativity = 8,
  2043. .partitions = 1,
  2044. .sets = 64,
  2045. .lines_per_tag = 1,
  2046. .self_init = 1,
  2047. .no_invd_sharing = true,
  2048. .share_level = CPU_TOPO_LEVEL_CORE,
  2049. },
  2050. .l1i_cache = &(CPUCacheInfo) {
  2051. .type = INSTRUCTION_CACHE,
  2052. .level = 1,
  2053. .size = 32 * KiB,
  2054. .line_size = 64,
  2055. .associativity = 8,
  2056. .partitions = 1,
  2057. .sets = 64,
  2058. .lines_per_tag = 1,
  2059. .self_init = 1,
  2060. .no_invd_sharing = true,
  2061. .share_level = CPU_TOPO_LEVEL_CORE,
  2062. },
  2063. .l2_cache = &(CPUCacheInfo) {
  2064. .type = UNIFIED_CACHE,
  2065. .level = 2,
  2066. .size = 512 * KiB,
  2067. .line_size = 64,
  2068. .associativity = 8,
  2069. .partitions = 1,
  2070. .sets = 1024,
  2071. .lines_per_tag = 1,
  2072. .share_level = CPU_TOPO_LEVEL_CORE,
  2073. },
  2074. .l3_cache = &(CPUCacheInfo) {
  2075. .type = UNIFIED_CACHE,
  2076. .level = 3,
  2077. .size = 16 * MiB,
  2078. .line_size = 64,
  2079. .associativity = 16,
  2080. .partitions = 1,
  2081. .sets = 16384,
  2082. .lines_per_tag = 1,
  2083. .self_init = true,
  2084. .inclusive = true,
  2085. .complex_indexing = false,
  2086. .share_level = CPU_TOPO_LEVEL_DIE,
  2087. },
  2088. };
  2089. static const CPUCaches epyc_milan_cache_info = {
  2090. .l1d_cache = &(CPUCacheInfo) {
  2091. .type = DATA_CACHE,
  2092. .level = 1,
  2093. .size = 32 * KiB,
  2094. .line_size = 64,
  2095. .associativity = 8,
  2096. .partitions = 1,
  2097. .sets = 64,
  2098. .lines_per_tag = 1,
  2099. .self_init = 1,
  2100. .no_invd_sharing = true,
  2101. .share_level = CPU_TOPO_LEVEL_CORE,
  2102. },
  2103. .l1i_cache = &(CPUCacheInfo) {
  2104. .type = INSTRUCTION_CACHE,
  2105. .level = 1,
  2106. .size = 32 * KiB,
  2107. .line_size = 64,
  2108. .associativity = 8,
  2109. .partitions = 1,
  2110. .sets = 64,
  2111. .lines_per_tag = 1,
  2112. .self_init = 1,
  2113. .no_invd_sharing = true,
  2114. .share_level = CPU_TOPO_LEVEL_CORE,
  2115. },
  2116. .l2_cache = &(CPUCacheInfo) {
  2117. .type = UNIFIED_CACHE,
  2118. .level = 2,
  2119. .size = 512 * KiB,
  2120. .line_size = 64,
  2121. .associativity = 8,
  2122. .partitions = 1,
  2123. .sets = 1024,
  2124. .lines_per_tag = 1,
  2125. .share_level = CPU_TOPO_LEVEL_CORE,
  2126. },
  2127. .l3_cache = &(CPUCacheInfo) {
  2128. .type = UNIFIED_CACHE,
  2129. .level = 3,
  2130. .size = 32 * MiB,
  2131. .line_size = 64,
  2132. .associativity = 16,
  2133. .partitions = 1,
  2134. .sets = 32768,
  2135. .lines_per_tag = 1,
  2136. .self_init = true,
  2137. .inclusive = true,
  2138. .complex_indexing = true,
  2139. .share_level = CPU_TOPO_LEVEL_DIE,
  2140. },
  2141. };
  2142. static const CPUCaches epyc_milan_v2_cache_info = {
  2143. .l1d_cache = &(CPUCacheInfo) {
  2144. .type = DATA_CACHE,
  2145. .level = 1,
  2146. .size = 32 * KiB,
  2147. .line_size = 64,
  2148. .associativity = 8,
  2149. .partitions = 1,
  2150. .sets = 64,
  2151. .lines_per_tag = 1,
  2152. .self_init = 1,
  2153. .no_invd_sharing = true,
  2154. .share_level = CPU_TOPO_LEVEL_CORE,
  2155. },
  2156. .l1i_cache = &(CPUCacheInfo) {
  2157. .type = INSTRUCTION_CACHE,
  2158. .level = 1,
  2159. .size = 32 * KiB,
  2160. .line_size = 64,
  2161. .associativity = 8,
  2162. .partitions = 1,
  2163. .sets = 64,
  2164. .lines_per_tag = 1,
  2165. .self_init = 1,
  2166. .no_invd_sharing = true,
  2167. .share_level = CPU_TOPO_LEVEL_CORE,
  2168. },
  2169. .l2_cache = &(CPUCacheInfo) {
  2170. .type = UNIFIED_CACHE,
  2171. .level = 2,
  2172. .size = 512 * KiB,
  2173. .line_size = 64,
  2174. .associativity = 8,
  2175. .partitions = 1,
  2176. .sets = 1024,
  2177. .lines_per_tag = 1,
  2178. .share_level = CPU_TOPO_LEVEL_CORE,
  2179. },
  2180. .l3_cache = &(CPUCacheInfo) {
  2181. .type = UNIFIED_CACHE,
  2182. .level = 3,
  2183. .size = 32 * MiB,
  2184. .line_size = 64,
  2185. .associativity = 16,
  2186. .partitions = 1,
  2187. .sets = 32768,
  2188. .lines_per_tag = 1,
  2189. .self_init = true,
  2190. .inclusive = true,
  2191. .complex_indexing = false,
  2192. .share_level = CPU_TOPO_LEVEL_DIE,
  2193. },
  2194. };
  2195. static const CPUCaches epyc_genoa_cache_info = {
  2196. .l1d_cache = &(CPUCacheInfo) {
  2197. .type = DATA_CACHE,
  2198. .level = 1,
  2199. .size = 32 * KiB,
  2200. .line_size = 64,
  2201. .associativity = 8,
  2202. .partitions = 1,
  2203. .sets = 64,
  2204. .lines_per_tag = 1,
  2205. .self_init = 1,
  2206. .no_invd_sharing = true,
  2207. .share_level = CPU_TOPO_LEVEL_CORE,
  2208. },
  2209. .l1i_cache = &(CPUCacheInfo) {
  2210. .type = INSTRUCTION_CACHE,
  2211. .level = 1,
  2212. .size = 32 * KiB,
  2213. .line_size = 64,
  2214. .associativity = 8,
  2215. .partitions = 1,
  2216. .sets = 64,
  2217. .lines_per_tag = 1,
  2218. .self_init = 1,
  2219. .no_invd_sharing = true,
  2220. .share_level = CPU_TOPO_LEVEL_CORE,
  2221. },
  2222. .l2_cache = &(CPUCacheInfo) {
  2223. .type = UNIFIED_CACHE,
  2224. .level = 2,
  2225. .size = 1 * MiB,
  2226. .line_size = 64,
  2227. .associativity = 8,
  2228. .partitions = 1,
  2229. .sets = 2048,
  2230. .lines_per_tag = 1,
  2231. .share_level = CPU_TOPO_LEVEL_CORE,
  2232. },
  2233. .l3_cache = &(CPUCacheInfo) {
  2234. .type = UNIFIED_CACHE,
  2235. .level = 3,
  2236. .size = 32 * MiB,
  2237. .line_size = 64,
  2238. .associativity = 16,
  2239. .partitions = 1,
  2240. .sets = 32768,
  2241. .lines_per_tag = 1,
  2242. .self_init = true,
  2243. .inclusive = true,
  2244. .complex_indexing = false,
  2245. .share_level = CPU_TOPO_LEVEL_DIE,
  2246. },
  2247. };
  2248. /* The following VMX features are not supported by KVM and are left out in the
  2249. * CPU definitions:
  2250. *
  2251. * Dual-monitor support (all processors)
  2252. * Entry to SMM
  2253. * Deactivate dual-monitor treatment
  2254. * Number of CR3-target values
  2255. * Shutdown activity state
  2256. * Wait-for-SIPI activity state
  2257. * PAUSE-loop exiting (Westmere and newer)
  2258. * EPT-violation #VE (Broadwell and newer)
  2259. * Inject event with insn length=0 (Skylake and newer)
  2260. * Conceal non-root operation from PT
  2261. * Conceal VM exits from PT
  2262. * Conceal VM entries from PT
  2263. * Enable ENCLS exiting
  2264. * Mode-based execute control (XS/XU)
  2265. * TSC scaling (Skylake Server and newer)
  2266. * GPA translation for PT (IceLake and newer)
  2267. * User wait and pause
  2268. * ENCLV exiting
  2269. * Load IA32_RTIT_CTL
  2270. * Clear IA32_RTIT_CTL
  2271. * Advanced VM-exit information for EPT violations
  2272. * Sub-page write permissions
  2273. * PT in VMX operation
  2274. */
  2275. static const X86CPUDefinition builtin_x86_defs[] = {
  2276. {
  2277. .name = "qemu64",
  2278. .level = 0xd,
  2279. .vendor = CPUID_VENDOR_AMD,
  2280. .family = 15,
  2281. .model = 107,
  2282. .stepping = 1,
  2283. .features[FEAT_1_EDX] =
  2284. PPRO_FEATURES |
  2285. CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
  2286. CPUID_PSE36,
  2287. .features[FEAT_1_ECX] =
  2288. CPUID_EXT_SSE3 | CPUID_EXT_CX16,
  2289. .features[FEAT_8000_0001_EDX] =
  2290. CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
  2291. .features[FEAT_8000_0001_ECX] =
  2292. CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM,
  2293. .xlevel = 0x8000000A,
  2294. .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
  2295. },
  2296. {
  2297. .name = "phenom",
  2298. .level = 5,
  2299. .vendor = CPUID_VENDOR_AMD,
  2300. .family = 16,
  2301. .model = 2,
  2302. .stepping = 3,
  2303. /* Missing: CPUID_HT */
  2304. .features[FEAT_1_EDX] =
  2305. PPRO_FEATURES |
  2306. CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
  2307. CPUID_PSE36 | CPUID_VME,
  2308. .features[FEAT_1_ECX] =
  2309. CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_CX16 |
  2310. CPUID_EXT_POPCNT,
  2311. .features[FEAT_8000_0001_EDX] =
  2312. CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX |
  2313. CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT | CPUID_EXT2_MMXEXT |
  2314. CPUID_EXT2_FFXSR | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP,
  2315. /* Missing: CPUID_EXT3_CMP_LEG, CPUID_EXT3_EXTAPIC,
  2316. CPUID_EXT3_CR8LEG,
  2317. CPUID_EXT3_MISALIGNSSE, CPUID_EXT3_3DNOWPREFETCH,
  2318. CPUID_EXT3_OSVW, CPUID_EXT3_IBS */
  2319. .features[FEAT_8000_0001_ECX] =
  2320. CPUID_EXT3_LAHF_LM | CPUID_EXT3_SVM |
  2321. CPUID_EXT3_ABM | CPUID_EXT3_SSE4A,
  2322. /* Missing: CPUID_SVM_LBRV */
  2323. .features[FEAT_SVM] =
  2324. CPUID_SVM_NPT,
  2325. .xlevel = 0x8000001A,
  2326. .model_id = "AMD Phenom(tm) 9550 Quad-Core Processor"
  2327. },
  2328. {
  2329. .name = "core2duo",
  2330. .level = 10,
  2331. .vendor = CPUID_VENDOR_INTEL,
  2332. .family = 6,
  2333. .model = 15,
  2334. .stepping = 11,
  2335. /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
  2336. .features[FEAT_1_EDX] =
  2337. PPRO_FEATURES |
  2338. CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
  2339. CPUID_PSE36 | CPUID_VME | CPUID_ACPI | CPUID_SS,
  2340. /* Missing: CPUID_EXT_DTES64, CPUID_EXT_DSCPL, CPUID_EXT_EST,
  2341. * CPUID_EXT_TM2, CPUID_EXT_XTPR, CPUID_EXT_PDCM, CPUID_EXT_VMX */
  2342. .features[FEAT_1_ECX] =
  2343. CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 |
  2344. CPUID_EXT_CX16,
  2345. .features[FEAT_8000_0001_EDX] =
  2346. CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
  2347. .features[FEAT_8000_0001_ECX] =
  2348. CPUID_EXT3_LAHF_LM,
  2349. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
  2350. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
  2351. .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
  2352. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
  2353. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2354. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
  2355. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2356. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2357. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2358. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2359. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2360. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2361. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2362. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  2363. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  2364. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  2365. .features[FEAT_VMX_SECONDARY_CTLS] =
  2366. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES,
  2367. .xlevel = 0x80000008,
  2368. .model_id = "Intel(R) Core(TM)2 Duo CPU T7700 @ 2.40GHz",
  2369. },
  2370. {
  2371. .name = "kvm64",
  2372. .level = 0xd,
  2373. .vendor = CPUID_VENDOR_INTEL,
  2374. .family = 15,
  2375. .model = 6,
  2376. .stepping = 1,
  2377. /* Missing: CPUID_HT */
  2378. .features[FEAT_1_EDX] =
  2379. PPRO_FEATURES | CPUID_VME |
  2380. CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA |
  2381. CPUID_PSE36,
  2382. /* Missing: CPUID_EXT_POPCNT, CPUID_EXT_MONITOR */
  2383. .features[FEAT_1_ECX] =
  2384. CPUID_EXT_SSE3 | CPUID_EXT_CX16,
  2385. /* Missing: CPUID_EXT2_PDPE1GB, CPUID_EXT2_RDTSCP */
  2386. .features[FEAT_8000_0001_EDX] =
  2387. CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
  2388. /* Missing: CPUID_EXT3_LAHF_LM, CPUID_EXT3_CMP_LEG, CPUID_EXT3_EXTAPIC,
  2389. CPUID_EXT3_CR8LEG, CPUID_EXT3_ABM, CPUID_EXT3_SSE4A,
  2390. CPUID_EXT3_MISALIGNSSE, CPUID_EXT3_3DNOWPREFETCH,
  2391. CPUID_EXT3_OSVW, CPUID_EXT3_IBS, CPUID_EXT3_SVM */
  2392. .features[FEAT_8000_0001_ECX] =
  2393. 0,
  2394. /* VMX features from Cedar Mill/Prescott */
  2395. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
  2396. .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
  2397. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
  2398. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2399. VMX_PIN_BASED_NMI_EXITING,
  2400. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2401. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2402. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2403. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2404. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2405. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2406. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2407. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING,
  2408. .xlevel = 0x80000008,
  2409. .model_id = "Common KVM processor"
  2410. },
  2411. {
  2412. .name = "qemu32",
  2413. .level = 4,
  2414. .vendor = CPUID_VENDOR_INTEL,
  2415. .family = 6,
  2416. .model = 6,
  2417. .stepping = 3,
  2418. .features[FEAT_1_EDX] =
  2419. PPRO_FEATURES,
  2420. .features[FEAT_1_ECX] =
  2421. CPUID_EXT_SSE3,
  2422. .xlevel = 0x80000004,
  2423. .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
  2424. },
  2425. {
  2426. .name = "kvm32",
  2427. .level = 5,
  2428. .vendor = CPUID_VENDOR_INTEL,
  2429. .family = 15,
  2430. .model = 6,
  2431. .stepping = 1,
  2432. .features[FEAT_1_EDX] =
  2433. PPRO_FEATURES | CPUID_VME |
  2434. CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_PSE36,
  2435. .features[FEAT_1_ECX] =
  2436. CPUID_EXT_SSE3,
  2437. .features[FEAT_8000_0001_ECX] =
  2438. 0,
  2439. /* VMX features from Yonah */
  2440. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
  2441. .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
  2442. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
  2443. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2444. VMX_PIN_BASED_NMI_EXITING,
  2445. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2446. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2447. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2448. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2449. VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
  2450. VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
  2451. VMX_CPU_BASED_PAUSE_EXITING | VMX_CPU_BASED_USE_MSR_BITMAPS,
  2452. .xlevel = 0x80000008,
  2453. .model_id = "Common 32-bit KVM processor"
  2454. },
  2455. {
  2456. .name = "coreduo",
  2457. .level = 10,
  2458. .vendor = CPUID_VENDOR_INTEL,
  2459. .family = 6,
  2460. .model = 14,
  2461. .stepping = 8,
  2462. /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
  2463. .features[FEAT_1_EDX] =
  2464. PPRO_FEATURES | CPUID_VME |
  2465. CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_ACPI |
  2466. CPUID_SS,
  2467. /* Missing: CPUID_EXT_EST, CPUID_EXT_TM2 , CPUID_EXT_XTPR,
  2468. * CPUID_EXT_PDCM, CPUID_EXT_VMX */
  2469. .features[FEAT_1_ECX] =
  2470. CPUID_EXT_SSE3 | CPUID_EXT_MONITOR,
  2471. .features[FEAT_8000_0001_EDX] =
  2472. CPUID_EXT2_NX,
  2473. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
  2474. .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
  2475. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
  2476. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2477. VMX_PIN_BASED_NMI_EXITING,
  2478. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2479. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2480. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2481. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2482. VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
  2483. VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
  2484. VMX_CPU_BASED_PAUSE_EXITING | VMX_CPU_BASED_USE_MSR_BITMAPS,
  2485. .xlevel = 0x80000008,
  2486. .model_id = "Genuine Intel(R) CPU T2600 @ 2.16GHz",
  2487. },
  2488. {
  2489. .name = "486",
  2490. .level = 1,
  2491. .vendor = CPUID_VENDOR_INTEL,
  2492. .family = 4,
  2493. .model = 8,
  2494. .stepping = 0,
  2495. .features[FEAT_1_EDX] =
  2496. I486_FEATURES,
  2497. .xlevel = 0,
  2498. .model_id = "",
  2499. },
  2500. {
  2501. .name = "pentium",
  2502. .level = 1,
  2503. .vendor = CPUID_VENDOR_INTEL,
  2504. .family = 5,
  2505. .model = 4,
  2506. .stepping = 3,
  2507. .features[FEAT_1_EDX] =
  2508. PENTIUM_FEATURES,
  2509. .xlevel = 0,
  2510. .model_id = "",
  2511. },
  2512. {
  2513. .name = "pentium2",
  2514. .level = 2,
  2515. .vendor = CPUID_VENDOR_INTEL,
  2516. .family = 6,
  2517. .model = 5,
  2518. .stepping = 2,
  2519. .features[FEAT_1_EDX] =
  2520. PENTIUM2_FEATURES,
  2521. .xlevel = 0,
  2522. .model_id = "",
  2523. },
  2524. {
  2525. .name = "pentium3",
  2526. .level = 3,
  2527. .vendor = CPUID_VENDOR_INTEL,
  2528. .family = 6,
  2529. .model = 7,
  2530. .stepping = 3,
  2531. .features[FEAT_1_EDX] =
  2532. PENTIUM3_FEATURES,
  2533. .xlevel = 0,
  2534. .model_id = "",
  2535. },
  2536. {
  2537. .name = "athlon",
  2538. .level = 2,
  2539. .vendor = CPUID_VENDOR_AMD,
  2540. .family = 6,
  2541. .model = 2,
  2542. .stepping = 3,
  2543. .features[FEAT_1_EDX] =
  2544. PPRO_FEATURES | CPUID_PSE36 | CPUID_VME | CPUID_MTRR |
  2545. CPUID_MCA,
  2546. .features[FEAT_8000_0001_EDX] =
  2547. CPUID_EXT2_MMXEXT | CPUID_EXT2_3DNOW | CPUID_EXT2_3DNOWEXT,
  2548. .xlevel = 0x80000008,
  2549. .model_id = "QEMU Virtual CPU version " QEMU_HW_VERSION,
  2550. },
  2551. {
  2552. .name = "n270",
  2553. .level = 10,
  2554. .vendor = CPUID_VENDOR_INTEL,
  2555. .family = 6,
  2556. .model = 28,
  2557. .stepping = 2,
  2558. /* Missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
  2559. .features[FEAT_1_EDX] =
  2560. PPRO_FEATURES |
  2561. CPUID_MTRR | CPUID_CLFLUSH | CPUID_MCA | CPUID_VME |
  2562. CPUID_ACPI | CPUID_SS,
  2563. /* Some CPUs got no CPUID_SEP */
  2564. /* Missing: CPUID_EXT_DSCPL, CPUID_EXT_EST, CPUID_EXT_TM2,
  2565. * CPUID_EXT_XTPR */
  2566. .features[FEAT_1_ECX] =
  2567. CPUID_EXT_SSE3 | CPUID_EXT_MONITOR | CPUID_EXT_SSSE3 |
  2568. CPUID_EXT_MOVBE,
  2569. .features[FEAT_8000_0001_EDX] =
  2570. CPUID_EXT2_NX,
  2571. .features[FEAT_8000_0001_ECX] =
  2572. CPUID_EXT3_LAHF_LM,
  2573. .xlevel = 0x80000008,
  2574. .model_id = "Intel(R) Atom(TM) CPU N270 @ 1.60GHz",
  2575. },
  2576. {
  2577. .name = "Conroe",
  2578. .level = 10,
  2579. .vendor = CPUID_VENDOR_INTEL,
  2580. .family = 6,
  2581. .model = 15,
  2582. .stepping = 3,
  2583. .features[FEAT_1_EDX] =
  2584. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  2585. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  2586. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  2587. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  2588. CPUID_DE | CPUID_FP87,
  2589. .features[FEAT_1_ECX] =
  2590. CPUID_EXT_SSSE3 | CPUID_EXT_SSE3,
  2591. .features[FEAT_8000_0001_EDX] =
  2592. CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  2593. .features[FEAT_8000_0001_ECX] =
  2594. CPUID_EXT3_LAHF_LM,
  2595. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
  2596. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE,
  2597. .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT,
  2598. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
  2599. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2600. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
  2601. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2602. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2603. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2604. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2605. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2606. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2607. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2608. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  2609. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  2610. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  2611. .features[FEAT_VMX_SECONDARY_CTLS] =
  2612. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES,
  2613. .xlevel = 0x80000008,
  2614. .model_id = "Intel Celeron_4x0 (Conroe/Merom Class Core 2)",
  2615. },
  2616. {
  2617. .name = "Penryn",
  2618. .level = 10,
  2619. .vendor = CPUID_VENDOR_INTEL,
  2620. .family = 6,
  2621. .model = 23,
  2622. .stepping = 3,
  2623. .features[FEAT_1_EDX] =
  2624. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  2625. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  2626. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  2627. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  2628. CPUID_DE | CPUID_FP87,
  2629. .features[FEAT_1_ECX] =
  2630. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  2631. CPUID_EXT_SSE3,
  2632. .features[FEAT_8000_0001_EDX] =
  2633. CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  2634. .features[FEAT_8000_0001_ECX] =
  2635. CPUID_EXT3_LAHF_LM,
  2636. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS,
  2637. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  2638. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL,
  2639. .features[FEAT_VMX_EXIT_CTLS] = VMX_VM_EXIT_ACK_INTR_ON_EXIT |
  2640. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL,
  2641. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
  2642. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2643. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS,
  2644. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2645. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2646. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2647. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2648. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2649. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2650. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2651. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  2652. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  2653. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  2654. .features[FEAT_VMX_SECONDARY_CTLS] =
  2655. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  2656. VMX_SECONDARY_EXEC_WBINVD_EXITING,
  2657. .xlevel = 0x80000008,
  2658. .model_id = "Intel Core 2 Duo P9xxx (Penryn Class Core 2)",
  2659. },
  2660. {
  2661. .name = "Nehalem",
  2662. .level = 11,
  2663. .vendor = CPUID_VENDOR_INTEL,
  2664. .family = 6,
  2665. .model = 26,
  2666. .stepping = 3,
  2667. .features[FEAT_1_EDX] =
  2668. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  2669. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  2670. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  2671. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  2672. CPUID_DE | CPUID_FP87,
  2673. .features[FEAT_1_ECX] =
  2674. CPUID_EXT_POPCNT | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  2675. CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_SSE3,
  2676. .features[FEAT_8000_0001_EDX] =
  2677. CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
  2678. .features[FEAT_8000_0001_ECX] =
  2679. CPUID_EXT3_LAHF_LM,
  2680. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  2681. MSR_VMX_BASIC_TRUE_CTLS,
  2682. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  2683. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  2684. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  2685. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  2686. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  2687. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  2688. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  2689. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  2690. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  2691. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
  2692. .features[FEAT_VMX_EXIT_CTLS] =
  2693. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  2694. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  2695. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  2696. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  2697. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  2698. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT,
  2699. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2700. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  2701. VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
  2702. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2703. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2704. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2705. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2706. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2707. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2708. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2709. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  2710. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  2711. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  2712. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  2713. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  2714. .features[FEAT_VMX_SECONDARY_CTLS] =
  2715. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  2716. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  2717. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  2718. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  2719. VMX_SECONDARY_EXEC_ENABLE_VPID,
  2720. .xlevel = 0x80000008,
  2721. .model_id = "Intel Core i7 9xx (Nehalem Class Core i7)",
  2722. .versions = (X86CPUVersionDefinition[]) {
  2723. { .version = 1 },
  2724. {
  2725. .version = 2,
  2726. .alias = "Nehalem-IBRS",
  2727. .props = (PropValue[]) {
  2728. { "spec-ctrl", "on" },
  2729. { "model-id",
  2730. "Intel Core i7 9xx (Nehalem Core i7, IBRS update)" },
  2731. { /* end of list */ }
  2732. }
  2733. },
  2734. { /* end of list */ }
  2735. }
  2736. },
  2737. {
  2738. .name = "Westmere",
  2739. .level = 11,
  2740. .vendor = CPUID_VENDOR_INTEL,
  2741. .family = 6,
  2742. .model = 44,
  2743. .stepping = 1,
  2744. .features[FEAT_1_EDX] =
  2745. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  2746. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  2747. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  2748. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  2749. CPUID_DE | CPUID_FP87,
  2750. .features[FEAT_1_ECX] =
  2751. CPUID_EXT_AES | CPUID_EXT_POPCNT | CPUID_EXT_SSE42 |
  2752. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  2753. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
  2754. .features[FEAT_8000_0001_EDX] =
  2755. CPUID_EXT2_LM | CPUID_EXT2_SYSCALL | CPUID_EXT2_NX,
  2756. .features[FEAT_8000_0001_ECX] =
  2757. CPUID_EXT3_LAHF_LM,
  2758. .features[FEAT_6_EAX] =
  2759. CPUID_6_EAX_ARAT,
  2760. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  2761. MSR_VMX_BASIC_TRUE_CTLS,
  2762. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  2763. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  2764. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  2765. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  2766. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  2767. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  2768. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  2769. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  2770. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  2771. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
  2772. .features[FEAT_VMX_EXIT_CTLS] =
  2773. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  2774. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  2775. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  2776. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  2777. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  2778. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  2779. MSR_VMX_MISC_STORE_LMA,
  2780. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2781. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  2782. VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
  2783. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2784. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2785. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2786. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2787. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2788. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2789. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2790. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  2791. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  2792. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  2793. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  2794. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  2795. .features[FEAT_VMX_SECONDARY_CTLS] =
  2796. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  2797. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  2798. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  2799. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  2800. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST,
  2801. .xlevel = 0x80000008,
  2802. .model_id = "Westmere E56xx/L56xx/X56xx (Nehalem-C)",
  2803. .versions = (X86CPUVersionDefinition[]) {
  2804. { .version = 1 },
  2805. {
  2806. .version = 2,
  2807. .alias = "Westmere-IBRS",
  2808. .props = (PropValue[]) {
  2809. { "spec-ctrl", "on" },
  2810. { "model-id",
  2811. "Westmere E56xx/L56xx/X56xx (IBRS update)" },
  2812. { /* end of list */ }
  2813. }
  2814. },
  2815. { /* end of list */ }
  2816. }
  2817. },
  2818. {
  2819. .name = "SandyBridge",
  2820. .level = 0xd,
  2821. .vendor = CPUID_VENDOR_INTEL,
  2822. .family = 6,
  2823. .model = 42,
  2824. .stepping = 1,
  2825. .features[FEAT_1_EDX] =
  2826. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  2827. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  2828. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  2829. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  2830. CPUID_DE | CPUID_FP87,
  2831. .features[FEAT_1_ECX] =
  2832. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  2833. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_POPCNT |
  2834. CPUID_EXT_X2APIC | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  2835. CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
  2836. CPUID_EXT_SSE3,
  2837. .features[FEAT_8000_0001_EDX] =
  2838. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
  2839. CPUID_EXT2_SYSCALL,
  2840. .features[FEAT_8000_0001_ECX] =
  2841. CPUID_EXT3_LAHF_LM,
  2842. .features[FEAT_XSAVE] =
  2843. CPUID_XSAVE_XSAVEOPT,
  2844. .features[FEAT_6_EAX] =
  2845. CPUID_6_EAX_ARAT,
  2846. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  2847. MSR_VMX_BASIC_TRUE_CTLS,
  2848. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  2849. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  2850. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  2851. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  2852. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  2853. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  2854. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  2855. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  2856. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  2857. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
  2858. .features[FEAT_VMX_EXIT_CTLS] =
  2859. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  2860. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  2861. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  2862. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  2863. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  2864. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  2865. MSR_VMX_MISC_STORE_LMA,
  2866. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2867. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  2868. VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
  2869. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2870. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2871. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2872. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2873. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2874. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2875. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2876. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  2877. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  2878. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  2879. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  2880. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  2881. .features[FEAT_VMX_SECONDARY_CTLS] =
  2882. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  2883. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  2884. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  2885. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  2886. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST,
  2887. .xlevel = 0x80000008,
  2888. .model_id = "Intel Xeon E312xx (Sandy Bridge)",
  2889. .versions = (X86CPUVersionDefinition[]) {
  2890. { .version = 1 },
  2891. {
  2892. .version = 2,
  2893. .alias = "SandyBridge-IBRS",
  2894. .props = (PropValue[]) {
  2895. { "spec-ctrl", "on" },
  2896. { "model-id",
  2897. "Intel Xeon E312xx (Sandy Bridge, IBRS update)" },
  2898. { /* end of list */ }
  2899. }
  2900. },
  2901. { /* end of list */ }
  2902. }
  2903. },
  2904. {
  2905. .name = "IvyBridge",
  2906. .level = 0xd,
  2907. .vendor = CPUID_VENDOR_INTEL,
  2908. .family = 6,
  2909. .model = 58,
  2910. .stepping = 9,
  2911. .features[FEAT_1_EDX] =
  2912. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  2913. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  2914. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  2915. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  2916. CPUID_DE | CPUID_FP87,
  2917. .features[FEAT_1_ECX] =
  2918. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  2919. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_POPCNT |
  2920. CPUID_EXT_X2APIC | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  2921. CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
  2922. CPUID_EXT_SSE3 | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  2923. .features[FEAT_7_0_EBX] =
  2924. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_SMEP |
  2925. CPUID_7_0_EBX_ERMS,
  2926. .features[FEAT_8000_0001_EDX] =
  2927. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
  2928. CPUID_EXT2_SYSCALL,
  2929. .features[FEAT_8000_0001_ECX] =
  2930. CPUID_EXT3_LAHF_LM,
  2931. .features[FEAT_XSAVE] =
  2932. CPUID_XSAVE_XSAVEOPT,
  2933. .features[FEAT_6_EAX] =
  2934. CPUID_6_EAX_ARAT,
  2935. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  2936. MSR_VMX_BASIC_TRUE_CTLS,
  2937. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  2938. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  2939. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  2940. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  2941. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  2942. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  2943. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  2944. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  2945. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  2946. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
  2947. .features[FEAT_VMX_EXIT_CTLS] =
  2948. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  2949. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  2950. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  2951. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  2952. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  2953. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  2954. MSR_VMX_MISC_STORE_LMA,
  2955. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  2956. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  2957. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  2958. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  2959. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  2960. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  2961. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  2962. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  2963. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  2964. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  2965. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  2966. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  2967. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  2968. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  2969. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  2970. .features[FEAT_VMX_SECONDARY_CTLS] =
  2971. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  2972. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  2973. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  2974. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  2975. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  2976. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  2977. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  2978. VMX_SECONDARY_EXEC_RDRAND_EXITING,
  2979. .xlevel = 0x80000008,
  2980. .model_id = "Intel Xeon E3-12xx v2 (Ivy Bridge)",
  2981. .versions = (X86CPUVersionDefinition[]) {
  2982. { .version = 1 },
  2983. {
  2984. .version = 2,
  2985. .alias = "IvyBridge-IBRS",
  2986. .props = (PropValue[]) {
  2987. { "spec-ctrl", "on" },
  2988. { "model-id",
  2989. "Intel Xeon E3-12xx v2 (Ivy Bridge, IBRS)" },
  2990. { /* end of list */ }
  2991. }
  2992. },
  2993. { /* end of list */ }
  2994. }
  2995. },
  2996. {
  2997. .name = "Haswell",
  2998. .level = 0xd,
  2999. .vendor = CPUID_VENDOR_INTEL,
  3000. .family = 6,
  3001. .model = 60,
  3002. .stepping = 4,
  3003. .features[FEAT_1_EDX] =
  3004. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  3005. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  3006. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  3007. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  3008. CPUID_DE | CPUID_FP87,
  3009. .features[FEAT_1_ECX] =
  3010. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  3011. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  3012. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  3013. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  3014. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  3015. CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3016. .features[FEAT_8000_0001_EDX] =
  3017. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
  3018. CPUID_EXT2_SYSCALL,
  3019. .features[FEAT_8000_0001_ECX] =
  3020. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM,
  3021. .features[FEAT_7_0_EBX] =
  3022. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
  3023. CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
  3024. CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
  3025. CPUID_7_0_EBX_RTM,
  3026. .features[FEAT_XSAVE] =
  3027. CPUID_XSAVE_XSAVEOPT,
  3028. .features[FEAT_6_EAX] =
  3029. CPUID_6_EAX_ARAT,
  3030. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  3031. MSR_VMX_BASIC_TRUE_CTLS,
  3032. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  3033. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  3034. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3035. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  3036. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  3037. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  3038. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3039. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3040. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3041. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  3042. .features[FEAT_VMX_EXIT_CTLS] =
  3043. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  3044. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  3045. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  3046. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  3047. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  3048. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  3049. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  3050. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  3051. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  3052. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  3053. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  3054. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  3055. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  3056. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  3057. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  3058. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  3059. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  3060. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  3061. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  3062. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  3063. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  3064. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  3065. .features[FEAT_VMX_SECONDARY_CTLS] =
  3066. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  3067. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  3068. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  3069. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  3070. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  3071. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  3072. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  3073. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  3074. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS,
  3075. .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
  3076. .xlevel = 0x80000008,
  3077. .model_id = "Intel Core Processor (Haswell)",
  3078. .versions = (X86CPUVersionDefinition[]) {
  3079. { .version = 1 },
  3080. {
  3081. .version = 2,
  3082. .alias = "Haswell-noTSX",
  3083. .props = (PropValue[]) {
  3084. { "hle", "off" },
  3085. { "rtm", "off" },
  3086. { "stepping", "1" },
  3087. { "model-id", "Intel Core Processor (Haswell, no TSX)", },
  3088. { /* end of list */ }
  3089. },
  3090. },
  3091. {
  3092. .version = 3,
  3093. .alias = "Haswell-IBRS",
  3094. .props = (PropValue[]) {
  3095. /* Restore TSX features removed by -v2 above */
  3096. { "hle", "on" },
  3097. { "rtm", "on" },
  3098. /*
  3099. * Haswell and Haswell-IBRS had stepping=4 in
  3100. * QEMU 4.0 and older
  3101. */
  3102. { "stepping", "4" },
  3103. { "spec-ctrl", "on" },
  3104. { "model-id",
  3105. "Intel Core Processor (Haswell, IBRS)" },
  3106. { /* end of list */ }
  3107. }
  3108. },
  3109. {
  3110. .version = 4,
  3111. .alias = "Haswell-noTSX-IBRS",
  3112. .props = (PropValue[]) {
  3113. { "hle", "off" },
  3114. { "rtm", "off" },
  3115. /* spec-ctrl was already enabled by -v3 above */
  3116. { "stepping", "1" },
  3117. { "model-id",
  3118. "Intel Core Processor (Haswell, no TSX, IBRS)" },
  3119. { /* end of list */ }
  3120. }
  3121. },
  3122. { /* end of list */ }
  3123. }
  3124. },
  3125. {
  3126. .name = "Broadwell",
  3127. .level = 0xd,
  3128. .vendor = CPUID_VENDOR_INTEL,
  3129. .family = 6,
  3130. .model = 61,
  3131. .stepping = 2,
  3132. .features[FEAT_1_EDX] =
  3133. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  3134. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  3135. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  3136. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  3137. CPUID_DE | CPUID_FP87,
  3138. .features[FEAT_1_ECX] =
  3139. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  3140. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  3141. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  3142. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  3143. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  3144. CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3145. .features[FEAT_8000_0001_EDX] =
  3146. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
  3147. CPUID_EXT2_SYSCALL,
  3148. .features[FEAT_8000_0001_ECX] =
  3149. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  3150. .features[FEAT_7_0_EBX] =
  3151. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
  3152. CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
  3153. CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
  3154. CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  3155. CPUID_7_0_EBX_SMAP,
  3156. .features[FEAT_XSAVE] =
  3157. CPUID_XSAVE_XSAVEOPT,
  3158. .features[FEAT_6_EAX] =
  3159. CPUID_6_EAX_ARAT,
  3160. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  3161. MSR_VMX_BASIC_TRUE_CTLS,
  3162. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  3163. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  3164. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3165. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  3166. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  3167. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  3168. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3169. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3170. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3171. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  3172. .features[FEAT_VMX_EXIT_CTLS] =
  3173. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  3174. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  3175. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  3176. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  3177. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  3178. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  3179. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  3180. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  3181. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  3182. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  3183. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  3184. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  3185. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  3186. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  3187. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  3188. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  3189. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  3190. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  3191. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  3192. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  3193. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  3194. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  3195. .features[FEAT_VMX_SECONDARY_CTLS] =
  3196. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  3197. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  3198. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  3199. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  3200. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  3201. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  3202. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  3203. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  3204. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  3205. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
  3206. .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
  3207. .xlevel = 0x80000008,
  3208. .model_id = "Intel Core Processor (Broadwell)",
  3209. .versions = (X86CPUVersionDefinition[]) {
  3210. { .version = 1 },
  3211. {
  3212. .version = 2,
  3213. .alias = "Broadwell-noTSX",
  3214. .props = (PropValue[]) {
  3215. { "hle", "off" },
  3216. { "rtm", "off" },
  3217. { "model-id", "Intel Core Processor (Broadwell, no TSX)", },
  3218. { /* end of list */ }
  3219. },
  3220. },
  3221. {
  3222. .version = 3,
  3223. .alias = "Broadwell-IBRS",
  3224. .props = (PropValue[]) {
  3225. /* Restore TSX features removed by -v2 above */
  3226. { "hle", "on" },
  3227. { "rtm", "on" },
  3228. { "spec-ctrl", "on" },
  3229. { "model-id",
  3230. "Intel Core Processor (Broadwell, IBRS)" },
  3231. { /* end of list */ }
  3232. }
  3233. },
  3234. {
  3235. .version = 4,
  3236. .alias = "Broadwell-noTSX-IBRS",
  3237. .props = (PropValue[]) {
  3238. { "hle", "off" },
  3239. { "rtm", "off" },
  3240. /* spec-ctrl was already enabled by -v3 above */
  3241. { "model-id",
  3242. "Intel Core Processor (Broadwell, no TSX, IBRS)" },
  3243. { /* end of list */ }
  3244. }
  3245. },
  3246. { /* end of list */ }
  3247. }
  3248. },
  3249. {
  3250. .name = "Skylake-Client",
  3251. .level = 0xd,
  3252. .vendor = CPUID_VENDOR_INTEL,
  3253. .family = 6,
  3254. .model = 94,
  3255. .stepping = 3,
  3256. .features[FEAT_1_EDX] =
  3257. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  3258. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  3259. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  3260. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  3261. CPUID_DE | CPUID_FP87,
  3262. .features[FEAT_1_ECX] =
  3263. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  3264. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  3265. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  3266. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  3267. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  3268. CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3269. .features[FEAT_8000_0001_EDX] =
  3270. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_NX |
  3271. CPUID_EXT2_SYSCALL,
  3272. .features[FEAT_8000_0001_ECX] =
  3273. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  3274. .features[FEAT_7_0_EBX] =
  3275. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
  3276. CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
  3277. CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
  3278. CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  3279. CPUID_7_0_EBX_SMAP,
  3280. /* XSAVES is added in version 4 */
  3281. .features[FEAT_XSAVE] =
  3282. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  3283. CPUID_XSAVE_XGETBV1,
  3284. .features[FEAT_6_EAX] =
  3285. CPUID_6_EAX_ARAT,
  3286. /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
  3287. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  3288. MSR_VMX_BASIC_TRUE_CTLS,
  3289. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  3290. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  3291. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3292. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  3293. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  3294. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  3295. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3296. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3297. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3298. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  3299. .features[FEAT_VMX_EXIT_CTLS] =
  3300. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  3301. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  3302. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  3303. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  3304. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  3305. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  3306. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  3307. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  3308. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  3309. VMX_PIN_BASED_VMX_PREEMPTION_TIMER,
  3310. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  3311. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  3312. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  3313. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  3314. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  3315. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  3316. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  3317. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  3318. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  3319. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  3320. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  3321. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  3322. .features[FEAT_VMX_SECONDARY_CTLS] =
  3323. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  3324. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  3325. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  3326. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  3327. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  3328. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  3329. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
  3330. .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
  3331. .xlevel = 0x80000008,
  3332. .model_id = "Intel Core Processor (Skylake)",
  3333. .versions = (X86CPUVersionDefinition[]) {
  3334. { .version = 1 },
  3335. {
  3336. .version = 2,
  3337. .alias = "Skylake-Client-IBRS",
  3338. .props = (PropValue[]) {
  3339. { "spec-ctrl", "on" },
  3340. { "model-id",
  3341. "Intel Core Processor (Skylake, IBRS)" },
  3342. { /* end of list */ }
  3343. }
  3344. },
  3345. {
  3346. .version = 3,
  3347. .alias = "Skylake-Client-noTSX-IBRS",
  3348. .props = (PropValue[]) {
  3349. { "hle", "off" },
  3350. { "rtm", "off" },
  3351. { "model-id",
  3352. "Intel Core Processor (Skylake, IBRS, no TSX)" },
  3353. { /* end of list */ }
  3354. }
  3355. },
  3356. {
  3357. .version = 4,
  3358. .note = "IBRS, XSAVES, no TSX",
  3359. .props = (PropValue[]) {
  3360. { "xsaves", "on" },
  3361. { "vmx-xsaves", "on" },
  3362. { /* end of list */ }
  3363. }
  3364. },
  3365. { /* end of list */ }
  3366. }
  3367. },
  3368. {
  3369. .name = "Skylake-Server",
  3370. .level = 0xd,
  3371. .vendor = CPUID_VENDOR_INTEL,
  3372. .family = 6,
  3373. .model = 85,
  3374. .stepping = 4,
  3375. .features[FEAT_1_EDX] =
  3376. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  3377. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  3378. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  3379. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  3380. CPUID_DE | CPUID_FP87,
  3381. .features[FEAT_1_ECX] =
  3382. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  3383. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  3384. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  3385. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  3386. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  3387. CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3388. .features[FEAT_8000_0001_EDX] =
  3389. CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
  3390. CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  3391. .features[FEAT_8000_0001_ECX] =
  3392. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  3393. .features[FEAT_7_0_EBX] =
  3394. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
  3395. CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
  3396. CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
  3397. CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  3398. CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
  3399. CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
  3400. CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
  3401. CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
  3402. .features[FEAT_7_0_ECX] =
  3403. CPUID_7_0_ECX_PKU,
  3404. /* XSAVES is added in version 5 */
  3405. .features[FEAT_XSAVE] =
  3406. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  3407. CPUID_XSAVE_XGETBV1,
  3408. .features[FEAT_6_EAX] =
  3409. CPUID_6_EAX_ARAT,
  3410. /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
  3411. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  3412. MSR_VMX_BASIC_TRUE_CTLS,
  3413. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  3414. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  3415. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3416. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  3417. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  3418. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  3419. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3420. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3421. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3422. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  3423. .features[FEAT_VMX_EXIT_CTLS] =
  3424. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  3425. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  3426. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  3427. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  3428. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  3429. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  3430. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  3431. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  3432. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  3433. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  3434. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  3435. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  3436. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  3437. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  3438. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  3439. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  3440. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  3441. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  3442. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  3443. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  3444. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  3445. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  3446. .features[FEAT_VMX_SECONDARY_CTLS] =
  3447. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  3448. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  3449. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  3450. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  3451. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  3452. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  3453. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  3454. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  3455. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  3456. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
  3457. .xlevel = 0x80000008,
  3458. .model_id = "Intel Xeon Processor (Skylake)",
  3459. .versions = (X86CPUVersionDefinition[]) {
  3460. { .version = 1 },
  3461. {
  3462. .version = 2,
  3463. .alias = "Skylake-Server-IBRS",
  3464. .props = (PropValue[]) {
  3465. /* clflushopt was not added to Skylake-Server-IBRS */
  3466. /* TODO: add -v3 including clflushopt */
  3467. { "clflushopt", "off" },
  3468. { "spec-ctrl", "on" },
  3469. { "model-id",
  3470. "Intel Xeon Processor (Skylake, IBRS)" },
  3471. { /* end of list */ }
  3472. }
  3473. },
  3474. {
  3475. .version = 3,
  3476. .alias = "Skylake-Server-noTSX-IBRS",
  3477. .props = (PropValue[]) {
  3478. { "hle", "off" },
  3479. { "rtm", "off" },
  3480. { "model-id",
  3481. "Intel Xeon Processor (Skylake, IBRS, no TSX)" },
  3482. { /* end of list */ }
  3483. }
  3484. },
  3485. {
  3486. .version = 4,
  3487. .props = (PropValue[]) {
  3488. { "vmx-eptp-switching", "on" },
  3489. { /* end of list */ }
  3490. }
  3491. },
  3492. {
  3493. .version = 5,
  3494. .note = "IBRS, XSAVES, EPT switching, no TSX",
  3495. .props = (PropValue[]) {
  3496. { "xsaves", "on" },
  3497. { "vmx-xsaves", "on" },
  3498. { /* end of list */ }
  3499. }
  3500. },
  3501. { /* end of list */ }
  3502. }
  3503. },
  3504. {
  3505. .name = "Cascadelake-Server",
  3506. .level = 0xd,
  3507. .vendor = CPUID_VENDOR_INTEL,
  3508. .family = 6,
  3509. .model = 85,
  3510. .stepping = 6,
  3511. .features[FEAT_1_EDX] =
  3512. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  3513. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  3514. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  3515. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  3516. CPUID_DE | CPUID_FP87,
  3517. .features[FEAT_1_ECX] =
  3518. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  3519. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  3520. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  3521. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  3522. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  3523. CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3524. .features[FEAT_8000_0001_EDX] =
  3525. CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
  3526. CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  3527. .features[FEAT_8000_0001_ECX] =
  3528. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  3529. .features[FEAT_7_0_EBX] =
  3530. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
  3531. CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
  3532. CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
  3533. CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  3534. CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
  3535. CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
  3536. CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
  3537. CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
  3538. .features[FEAT_7_0_ECX] =
  3539. CPUID_7_0_ECX_PKU |
  3540. CPUID_7_0_ECX_AVX512VNNI,
  3541. .features[FEAT_7_0_EDX] =
  3542. CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
  3543. /* XSAVES is added in version 5 */
  3544. .features[FEAT_XSAVE] =
  3545. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  3546. CPUID_XSAVE_XGETBV1,
  3547. .features[FEAT_6_EAX] =
  3548. CPUID_6_EAX_ARAT,
  3549. /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
  3550. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  3551. MSR_VMX_BASIC_TRUE_CTLS,
  3552. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  3553. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  3554. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3555. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  3556. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  3557. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  3558. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3559. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3560. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3561. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  3562. .features[FEAT_VMX_EXIT_CTLS] =
  3563. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  3564. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  3565. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  3566. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  3567. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  3568. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  3569. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  3570. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  3571. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  3572. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  3573. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  3574. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  3575. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  3576. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  3577. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  3578. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  3579. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  3580. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  3581. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  3582. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  3583. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  3584. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  3585. .features[FEAT_VMX_SECONDARY_CTLS] =
  3586. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  3587. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  3588. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  3589. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  3590. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  3591. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  3592. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  3593. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  3594. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  3595. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
  3596. .xlevel = 0x80000008,
  3597. .model_id = "Intel Xeon Processor (Cascadelake)",
  3598. .versions = (X86CPUVersionDefinition[]) {
  3599. { .version = 1 },
  3600. { .version = 2,
  3601. .note = "ARCH_CAPABILITIES",
  3602. .props = (PropValue[]) {
  3603. { "arch-capabilities", "on" },
  3604. { "rdctl-no", "on" },
  3605. { "ibrs-all", "on" },
  3606. { "skip-l1dfl-vmentry", "on" },
  3607. { "mds-no", "on" },
  3608. { /* end of list */ }
  3609. },
  3610. },
  3611. { .version = 3,
  3612. .alias = "Cascadelake-Server-noTSX",
  3613. .note = "ARCH_CAPABILITIES, no TSX",
  3614. .props = (PropValue[]) {
  3615. { "hle", "off" },
  3616. { "rtm", "off" },
  3617. { /* end of list */ }
  3618. },
  3619. },
  3620. { .version = 4,
  3621. .note = "ARCH_CAPABILITIES, no TSX",
  3622. .props = (PropValue[]) {
  3623. { "vmx-eptp-switching", "on" },
  3624. { /* end of list */ }
  3625. },
  3626. },
  3627. { .version = 5,
  3628. .note = "ARCH_CAPABILITIES, EPT switching, XSAVES, no TSX",
  3629. .props = (PropValue[]) {
  3630. { "xsaves", "on" },
  3631. { "vmx-xsaves", "on" },
  3632. { /* end of list */ }
  3633. },
  3634. },
  3635. { /* end of list */ }
  3636. }
  3637. },
  3638. {
  3639. .name = "Cooperlake",
  3640. .level = 0xd,
  3641. .vendor = CPUID_VENDOR_INTEL,
  3642. .family = 6,
  3643. .model = 85,
  3644. .stepping = 10,
  3645. .features[FEAT_1_EDX] =
  3646. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  3647. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  3648. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  3649. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  3650. CPUID_DE | CPUID_FP87,
  3651. .features[FEAT_1_ECX] =
  3652. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  3653. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  3654. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  3655. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  3656. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  3657. CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3658. .features[FEAT_8000_0001_EDX] =
  3659. CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
  3660. CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  3661. .features[FEAT_8000_0001_ECX] =
  3662. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  3663. .features[FEAT_7_0_EBX] =
  3664. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
  3665. CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
  3666. CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
  3667. CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  3668. CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
  3669. CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
  3670. CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
  3671. CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
  3672. .features[FEAT_7_0_ECX] =
  3673. CPUID_7_0_ECX_PKU |
  3674. CPUID_7_0_ECX_AVX512VNNI,
  3675. .features[FEAT_7_0_EDX] =
  3676. CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_STIBP |
  3677. CPUID_7_0_EDX_SPEC_CTRL_SSBD | CPUID_7_0_EDX_ARCH_CAPABILITIES,
  3678. .features[FEAT_ARCH_CAPABILITIES] =
  3679. MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
  3680. MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
  3681. MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_TAA_NO,
  3682. .features[FEAT_7_1_EAX] =
  3683. CPUID_7_1_EAX_AVX512_BF16,
  3684. /* XSAVES is added in version 2 */
  3685. .features[FEAT_XSAVE] =
  3686. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  3687. CPUID_XSAVE_XGETBV1,
  3688. .features[FEAT_6_EAX] =
  3689. CPUID_6_EAX_ARAT,
  3690. /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
  3691. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  3692. MSR_VMX_BASIC_TRUE_CTLS,
  3693. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  3694. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  3695. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3696. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  3697. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  3698. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  3699. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3700. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3701. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3702. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  3703. .features[FEAT_VMX_EXIT_CTLS] =
  3704. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  3705. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  3706. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  3707. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  3708. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  3709. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  3710. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  3711. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  3712. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  3713. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  3714. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  3715. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  3716. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  3717. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  3718. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  3719. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  3720. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  3721. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  3722. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  3723. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  3724. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  3725. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  3726. .features[FEAT_VMX_SECONDARY_CTLS] =
  3727. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  3728. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  3729. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  3730. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  3731. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  3732. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  3733. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  3734. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  3735. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  3736. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
  3737. .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
  3738. .xlevel = 0x80000008,
  3739. .model_id = "Intel Xeon Processor (Cooperlake)",
  3740. .versions = (X86CPUVersionDefinition[]) {
  3741. { .version = 1 },
  3742. { .version = 2,
  3743. .note = "XSAVES",
  3744. .props = (PropValue[]) {
  3745. { "xsaves", "on" },
  3746. { "vmx-xsaves", "on" },
  3747. { /* end of list */ }
  3748. },
  3749. },
  3750. { /* end of list */ }
  3751. }
  3752. },
  3753. {
  3754. .name = "Icelake-Server",
  3755. .level = 0xd,
  3756. .vendor = CPUID_VENDOR_INTEL,
  3757. .family = 6,
  3758. .model = 134,
  3759. .stepping = 0,
  3760. .features[FEAT_1_EDX] =
  3761. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  3762. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  3763. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  3764. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  3765. CPUID_DE | CPUID_FP87,
  3766. .features[FEAT_1_ECX] =
  3767. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  3768. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  3769. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  3770. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  3771. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  3772. CPUID_EXT_PCID | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3773. .features[FEAT_8000_0001_EDX] =
  3774. CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
  3775. CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  3776. .features[FEAT_8000_0001_ECX] =
  3777. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  3778. .features[FEAT_8000_0008_EBX] =
  3779. CPUID_8000_0008_EBX_WBNOINVD,
  3780. .features[FEAT_7_0_EBX] =
  3781. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 |
  3782. CPUID_7_0_EBX_HLE | CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP |
  3783. CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID |
  3784. CPUID_7_0_EBX_RTM | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  3785. CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLWB |
  3786. CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
  3787. CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512CD |
  3788. CPUID_7_0_EBX_AVX512VL | CPUID_7_0_EBX_CLFLUSHOPT,
  3789. .features[FEAT_7_0_ECX] =
  3790. CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
  3791. CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
  3792. CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
  3793. CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
  3794. CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57,
  3795. .features[FEAT_7_0_EDX] =
  3796. CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
  3797. /* XSAVES is added in version 5 */
  3798. .features[FEAT_XSAVE] =
  3799. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  3800. CPUID_XSAVE_XGETBV1,
  3801. .features[FEAT_6_EAX] =
  3802. CPUID_6_EAX_ARAT,
  3803. /* Missing: Mode-based execute control (XS/XU), processor tracing, TSC scaling */
  3804. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  3805. MSR_VMX_BASIC_TRUE_CTLS,
  3806. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  3807. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  3808. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3809. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  3810. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  3811. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  3812. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3813. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3814. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3815. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  3816. .features[FEAT_VMX_EXIT_CTLS] =
  3817. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  3818. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  3819. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  3820. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  3821. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  3822. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  3823. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  3824. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  3825. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  3826. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  3827. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  3828. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  3829. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  3830. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  3831. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  3832. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  3833. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  3834. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  3835. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  3836. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  3837. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  3838. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  3839. .features[FEAT_VMX_SECONDARY_CTLS] =
  3840. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  3841. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  3842. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  3843. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  3844. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  3845. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  3846. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  3847. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  3848. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS,
  3849. .xlevel = 0x80000008,
  3850. .model_id = "Intel Xeon Processor (Icelake)",
  3851. .versions = (X86CPUVersionDefinition[]) {
  3852. { .version = 1 },
  3853. {
  3854. .version = 2,
  3855. .note = "no TSX",
  3856. .alias = "Icelake-Server-noTSX",
  3857. .props = (PropValue[]) {
  3858. { "hle", "off" },
  3859. { "rtm", "off" },
  3860. { /* end of list */ }
  3861. },
  3862. },
  3863. {
  3864. .version = 3,
  3865. .props = (PropValue[]) {
  3866. { "arch-capabilities", "on" },
  3867. { "rdctl-no", "on" },
  3868. { "ibrs-all", "on" },
  3869. { "skip-l1dfl-vmentry", "on" },
  3870. { "mds-no", "on" },
  3871. { "pschange-mc-no", "on" },
  3872. { "taa-no", "on" },
  3873. { /* end of list */ }
  3874. },
  3875. },
  3876. {
  3877. .version = 4,
  3878. .props = (PropValue[]) {
  3879. { "sha-ni", "on" },
  3880. { "avx512ifma", "on" },
  3881. { "rdpid", "on" },
  3882. { "fsrm", "on" },
  3883. { "vmx-rdseed-exit", "on" },
  3884. { "vmx-pml", "on" },
  3885. { "vmx-eptp-switching", "on" },
  3886. { "model", "106" },
  3887. { /* end of list */ }
  3888. },
  3889. },
  3890. {
  3891. .version = 5,
  3892. .note = "XSAVES",
  3893. .props = (PropValue[]) {
  3894. { "xsaves", "on" },
  3895. { "vmx-xsaves", "on" },
  3896. { /* end of list */ }
  3897. },
  3898. },
  3899. {
  3900. .version = 6,
  3901. .note = "5-level EPT",
  3902. .props = (PropValue[]) {
  3903. { "vmx-page-walk-5", "on" },
  3904. { /* end of list */ }
  3905. },
  3906. },
  3907. {
  3908. .version = 7,
  3909. .note = "TSX, taa-no",
  3910. .props = (PropValue[]) {
  3911. /* Restore TSX features removed by -v2 above */
  3912. { "hle", "on" },
  3913. { "rtm", "on" },
  3914. { /* end of list */ }
  3915. },
  3916. },
  3917. { /* end of list */ }
  3918. }
  3919. },
  3920. {
  3921. .name = "SapphireRapids",
  3922. .level = 0x20,
  3923. .vendor = CPUID_VENDOR_INTEL,
  3924. .family = 6,
  3925. .model = 143,
  3926. .stepping = 4,
  3927. /*
  3928. * please keep the ascending order so that we can have a clear view of
  3929. * bit position of each feature.
  3930. */
  3931. .features[FEAT_1_EDX] =
  3932. CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
  3933. CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
  3934. CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
  3935. CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
  3936. CPUID_SSE | CPUID_SSE2,
  3937. .features[FEAT_1_ECX] =
  3938. CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSSE3 |
  3939. CPUID_EXT_FMA | CPUID_EXT_CX16 | CPUID_EXT_PCID | CPUID_EXT_SSE41 |
  3940. CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
  3941. CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES |
  3942. CPUID_EXT_XSAVE | CPUID_EXT_AVX | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  3943. .features[FEAT_8000_0001_EDX] =
  3944. CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
  3945. CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
  3946. .features[FEAT_8000_0001_ECX] =
  3947. CPUID_EXT3_LAHF_LM | CPUID_EXT3_ABM | CPUID_EXT3_3DNOWPREFETCH,
  3948. .features[FEAT_8000_0008_EBX] =
  3949. CPUID_8000_0008_EBX_WBNOINVD,
  3950. .features[FEAT_7_0_EBX] =
  3951. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_HLE |
  3952. CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 |
  3953. CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_RTM |
  3954. CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
  3955. CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP |
  3956. CPUID_7_0_EBX_AVX512IFMA | CPUID_7_0_EBX_CLFLUSHOPT |
  3957. CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_SHA_NI |
  3958. CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512VL,
  3959. .features[FEAT_7_0_ECX] =
  3960. CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
  3961. CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
  3962. CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
  3963. CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
  3964. CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57 |
  3965. CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_BUS_LOCK_DETECT,
  3966. .features[FEAT_7_0_EDX] =
  3967. CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_SERIALIZE |
  3968. CPUID_7_0_EDX_TSX_LDTRK | CPUID_7_0_EDX_AMX_BF16 |
  3969. CPUID_7_0_EDX_AVX512_FP16 | CPUID_7_0_EDX_AMX_TILE |
  3970. CPUID_7_0_EDX_AMX_INT8 | CPUID_7_0_EDX_SPEC_CTRL |
  3971. CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
  3972. .features[FEAT_ARCH_CAPABILITIES] =
  3973. MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
  3974. MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
  3975. MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_TAA_NO,
  3976. .features[FEAT_XSAVE] =
  3977. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  3978. CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES | CPUID_D_1_EAX_XFD,
  3979. .features[FEAT_6_EAX] =
  3980. CPUID_6_EAX_ARAT,
  3981. .features[FEAT_7_1_EAX] =
  3982. CPUID_7_1_EAX_AVX_VNNI | CPUID_7_1_EAX_AVX512_BF16 |
  3983. CPUID_7_1_EAX_FZRM | CPUID_7_1_EAX_FSRS | CPUID_7_1_EAX_FSRC,
  3984. .features[FEAT_VMX_BASIC] =
  3985. MSR_VMX_BASIC_INS_OUTS | MSR_VMX_BASIC_TRUE_CTLS,
  3986. .features[FEAT_VMX_ENTRY_CTLS] =
  3987. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_IA32E_MODE |
  3988. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL |
  3989. VMX_VM_ENTRY_LOAD_IA32_PAT | VMX_VM_ENTRY_LOAD_IA32_EFER,
  3990. .features[FEAT_VMX_EPT_VPID_CAPS] =
  3991. MSR_VMX_EPT_EXECONLY |
  3992. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_PAGE_WALK_LENGTH_5 |
  3993. MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB | MSR_VMX_EPT_1GB |
  3994. MSR_VMX_EPT_INVEPT | MSR_VMX_EPT_AD_BITS |
  3995. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  3996. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  3997. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT |
  3998. MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  3999. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
  4000. .features[FEAT_VMX_EXIT_CTLS] =
  4001. VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  4002. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  4003. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_IA32_PAT |
  4004. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  4005. VMX_VM_EXIT_LOAD_IA32_EFER | VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  4006. .features[FEAT_VMX_MISC] =
  4007. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_ACTIVITY_HLT |
  4008. MSR_VMX_MISC_VMWRITE_VMEXIT,
  4009. .features[FEAT_VMX_PINBASED_CTLS] =
  4010. VMX_PIN_BASED_EXT_INTR_MASK | VMX_PIN_BASED_NMI_EXITING |
  4011. VMX_PIN_BASED_VIRTUAL_NMIS | VMX_PIN_BASED_VMX_PREEMPTION_TIMER |
  4012. VMX_PIN_BASED_POSTED_INTR,
  4013. .features[FEAT_VMX_PROCBASED_CTLS] =
  4014. VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  4015. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  4016. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  4017. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  4018. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  4019. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  4020. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_VIRTUAL_NMI_PENDING |
  4021. VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
  4022. VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  4023. VMX_CPU_BASED_USE_MSR_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
  4024. VMX_CPU_BASED_PAUSE_EXITING |
  4025. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  4026. .features[FEAT_VMX_SECONDARY_CTLS] =
  4027. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  4028. VMX_SECONDARY_EXEC_ENABLE_EPT | VMX_SECONDARY_EXEC_DESC |
  4029. VMX_SECONDARY_EXEC_RDTSCP |
  4030. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  4031. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_WBINVD_EXITING |
  4032. VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  4033. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  4034. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  4035. VMX_SECONDARY_EXEC_RDRAND_EXITING |
  4036. VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  4037. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  4038. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML |
  4039. VMX_SECONDARY_EXEC_XSAVES,
  4040. .features[FEAT_VMX_VMFUNC] =
  4041. MSR_VMX_VMFUNC_EPT_SWITCHING,
  4042. .xlevel = 0x80000008,
  4043. .model_id = "Intel Xeon Processor (SapphireRapids)",
  4044. .versions = (X86CPUVersionDefinition[]) {
  4045. { .version = 1 },
  4046. {
  4047. .version = 2,
  4048. .props = (PropValue[]) {
  4049. { "sbdr-ssdp-no", "on" },
  4050. { "fbsdp-no", "on" },
  4051. { "psdp-no", "on" },
  4052. { /* end of list */ }
  4053. }
  4054. },
  4055. {
  4056. .version = 3,
  4057. .props = (PropValue[]) {
  4058. { "ss", "on" },
  4059. { "tsc-adjust", "on" },
  4060. { "cldemote", "on" },
  4061. { "movdiri", "on" },
  4062. { "movdir64b", "on" },
  4063. { /* end of list */ }
  4064. }
  4065. },
  4066. { /* end of list */ }
  4067. }
  4068. },
  4069. {
  4070. .name = "GraniteRapids",
  4071. .level = 0x20,
  4072. .vendor = CPUID_VENDOR_INTEL,
  4073. .family = 6,
  4074. .model = 173,
  4075. .stepping = 0,
  4076. /*
  4077. * please keep the ascending order so that we can have a clear view of
  4078. * bit position of each feature.
  4079. */
  4080. .features[FEAT_1_EDX] =
  4081. CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
  4082. CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
  4083. CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
  4084. CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
  4085. CPUID_SSE | CPUID_SSE2,
  4086. .features[FEAT_1_ECX] =
  4087. CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSSE3 |
  4088. CPUID_EXT_FMA | CPUID_EXT_CX16 | CPUID_EXT_PCID | CPUID_EXT_SSE41 |
  4089. CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
  4090. CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES |
  4091. CPUID_EXT_XSAVE | CPUID_EXT_AVX | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  4092. .features[FEAT_8000_0001_EDX] =
  4093. CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
  4094. CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
  4095. .features[FEAT_8000_0001_ECX] =
  4096. CPUID_EXT3_LAHF_LM | CPUID_EXT3_ABM | CPUID_EXT3_3DNOWPREFETCH,
  4097. .features[FEAT_8000_0008_EBX] =
  4098. CPUID_8000_0008_EBX_WBNOINVD,
  4099. .features[FEAT_7_0_EBX] =
  4100. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_HLE |
  4101. CPUID_7_0_EBX_AVX2 | CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 |
  4102. CPUID_7_0_EBX_ERMS | CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_RTM |
  4103. CPUID_7_0_EBX_AVX512F | CPUID_7_0_EBX_AVX512DQ |
  4104. CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP |
  4105. CPUID_7_0_EBX_AVX512IFMA | CPUID_7_0_EBX_CLFLUSHOPT |
  4106. CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_SHA_NI |
  4107. CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512VL,
  4108. .features[FEAT_7_0_ECX] =
  4109. CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
  4110. CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
  4111. CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
  4112. CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
  4113. CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57 |
  4114. CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_BUS_LOCK_DETECT,
  4115. .features[FEAT_7_0_EDX] =
  4116. CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_SERIALIZE |
  4117. CPUID_7_0_EDX_TSX_LDTRK | CPUID_7_0_EDX_AMX_BF16 |
  4118. CPUID_7_0_EDX_AVX512_FP16 | CPUID_7_0_EDX_AMX_TILE |
  4119. CPUID_7_0_EDX_AMX_INT8 | CPUID_7_0_EDX_SPEC_CTRL |
  4120. CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD,
  4121. .features[FEAT_ARCH_CAPABILITIES] =
  4122. MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
  4123. MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
  4124. MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_TAA_NO |
  4125. MSR_ARCH_CAP_SBDR_SSDP_NO | MSR_ARCH_CAP_FBSDP_NO |
  4126. MSR_ARCH_CAP_PSDP_NO | MSR_ARCH_CAP_PBRSB_NO,
  4127. .features[FEAT_XSAVE] =
  4128. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  4129. CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES | CPUID_D_1_EAX_XFD,
  4130. .features[FEAT_6_EAX] =
  4131. CPUID_6_EAX_ARAT,
  4132. .features[FEAT_7_1_EAX] =
  4133. CPUID_7_1_EAX_AVX_VNNI | CPUID_7_1_EAX_AVX512_BF16 |
  4134. CPUID_7_1_EAX_FZRM | CPUID_7_1_EAX_FSRS | CPUID_7_1_EAX_FSRC |
  4135. CPUID_7_1_EAX_AMX_FP16,
  4136. .features[FEAT_7_1_EDX] =
  4137. CPUID_7_1_EDX_PREFETCHITI,
  4138. .features[FEAT_7_2_EDX] =
  4139. CPUID_7_2_EDX_MCDT_NO,
  4140. .features[FEAT_VMX_BASIC] =
  4141. MSR_VMX_BASIC_INS_OUTS | MSR_VMX_BASIC_TRUE_CTLS,
  4142. .features[FEAT_VMX_ENTRY_CTLS] =
  4143. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_IA32E_MODE |
  4144. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL |
  4145. VMX_VM_ENTRY_LOAD_IA32_PAT | VMX_VM_ENTRY_LOAD_IA32_EFER,
  4146. .features[FEAT_VMX_EPT_VPID_CAPS] =
  4147. MSR_VMX_EPT_EXECONLY |
  4148. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_PAGE_WALK_LENGTH_5 |
  4149. MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB | MSR_VMX_EPT_1GB |
  4150. MSR_VMX_EPT_INVEPT | MSR_VMX_EPT_AD_BITS |
  4151. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  4152. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  4153. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT |
  4154. MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  4155. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
  4156. .features[FEAT_VMX_EXIT_CTLS] =
  4157. VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  4158. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  4159. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_IA32_PAT |
  4160. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  4161. VMX_VM_EXIT_LOAD_IA32_EFER | VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  4162. .features[FEAT_VMX_MISC] =
  4163. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_ACTIVITY_HLT |
  4164. MSR_VMX_MISC_VMWRITE_VMEXIT,
  4165. .features[FEAT_VMX_PINBASED_CTLS] =
  4166. VMX_PIN_BASED_EXT_INTR_MASK | VMX_PIN_BASED_NMI_EXITING |
  4167. VMX_PIN_BASED_VIRTUAL_NMIS | VMX_PIN_BASED_VMX_PREEMPTION_TIMER |
  4168. VMX_PIN_BASED_POSTED_INTR,
  4169. .features[FEAT_VMX_PROCBASED_CTLS] =
  4170. VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  4171. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  4172. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  4173. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  4174. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  4175. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  4176. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_VIRTUAL_NMI_PENDING |
  4177. VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
  4178. VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  4179. VMX_CPU_BASED_USE_MSR_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
  4180. VMX_CPU_BASED_PAUSE_EXITING |
  4181. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  4182. .features[FEAT_VMX_SECONDARY_CTLS] =
  4183. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  4184. VMX_SECONDARY_EXEC_ENABLE_EPT | VMX_SECONDARY_EXEC_DESC |
  4185. VMX_SECONDARY_EXEC_RDTSCP |
  4186. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  4187. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_WBINVD_EXITING |
  4188. VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  4189. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  4190. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  4191. VMX_SECONDARY_EXEC_RDRAND_EXITING |
  4192. VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  4193. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  4194. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML |
  4195. VMX_SECONDARY_EXEC_XSAVES,
  4196. .features[FEAT_VMX_VMFUNC] =
  4197. MSR_VMX_VMFUNC_EPT_SWITCHING,
  4198. .xlevel = 0x80000008,
  4199. .model_id = "Intel Xeon Processor (GraniteRapids)",
  4200. .versions = (X86CPUVersionDefinition[]) {
  4201. { .version = 1 },
  4202. { /* end of list */ },
  4203. },
  4204. },
  4205. {
  4206. .name = "SierraForest",
  4207. .level = 0x23,
  4208. .vendor = CPUID_VENDOR_INTEL,
  4209. .family = 6,
  4210. .model = 175,
  4211. .stepping = 0,
  4212. /*
  4213. * please keep the ascending order so that we can have a clear view of
  4214. * bit position of each feature.
  4215. */
  4216. .features[FEAT_1_EDX] =
  4217. CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
  4218. CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
  4219. CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
  4220. CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
  4221. CPUID_SSE | CPUID_SSE2,
  4222. .features[FEAT_1_ECX] =
  4223. CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSSE3 |
  4224. CPUID_EXT_FMA | CPUID_EXT_CX16 | CPUID_EXT_PCID | CPUID_EXT_SSE41 |
  4225. CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
  4226. CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES |
  4227. CPUID_EXT_XSAVE | CPUID_EXT_AVX | CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  4228. .features[FEAT_8000_0001_EDX] =
  4229. CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
  4230. CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
  4231. .features[FEAT_8000_0001_ECX] =
  4232. CPUID_EXT3_LAHF_LM | CPUID_EXT3_ABM | CPUID_EXT3_3DNOWPREFETCH,
  4233. .features[FEAT_8000_0008_EBX] =
  4234. CPUID_8000_0008_EBX_WBNOINVD,
  4235. .features[FEAT_7_0_EBX] =
  4236. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
  4237. CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS |
  4238. CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  4239. CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT | CPUID_7_0_EBX_CLWB |
  4240. CPUID_7_0_EBX_SHA_NI,
  4241. .features[FEAT_7_0_ECX] =
  4242. CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU | CPUID_7_0_ECX_GFNI |
  4243. CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
  4244. CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_BUS_LOCK_DETECT,
  4245. .features[FEAT_7_0_EDX] =
  4246. CPUID_7_0_EDX_FSRM | CPUID_7_0_EDX_SERIALIZE |
  4247. CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_ARCH_CAPABILITIES |
  4248. CPUID_7_0_EDX_SPEC_CTRL_SSBD,
  4249. .features[FEAT_ARCH_CAPABILITIES] =
  4250. MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_IBRS_ALL |
  4251. MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY | MSR_ARCH_CAP_MDS_NO |
  4252. MSR_ARCH_CAP_PSCHANGE_MC_NO | MSR_ARCH_CAP_SBDR_SSDP_NO |
  4253. MSR_ARCH_CAP_FBSDP_NO | MSR_ARCH_CAP_PSDP_NO |
  4254. MSR_ARCH_CAP_PBRSB_NO,
  4255. .features[FEAT_XSAVE] =
  4256. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  4257. CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
  4258. .features[FEAT_6_EAX] =
  4259. CPUID_6_EAX_ARAT,
  4260. .features[FEAT_7_1_EAX] =
  4261. CPUID_7_1_EAX_AVX_VNNI | CPUID_7_1_EAX_CMPCCXADD |
  4262. CPUID_7_1_EAX_FSRS | CPUID_7_1_EAX_AVX_IFMA,
  4263. .features[FEAT_7_1_EDX] =
  4264. CPUID_7_1_EDX_AVX_VNNI_INT8 | CPUID_7_1_EDX_AVX_NE_CONVERT,
  4265. .features[FEAT_7_2_EDX] =
  4266. CPUID_7_2_EDX_MCDT_NO,
  4267. .features[FEAT_VMX_BASIC] =
  4268. MSR_VMX_BASIC_INS_OUTS | MSR_VMX_BASIC_TRUE_CTLS,
  4269. .features[FEAT_VMX_ENTRY_CTLS] =
  4270. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_IA32E_MODE |
  4271. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL |
  4272. VMX_VM_ENTRY_LOAD_IA32_PAT | VMX_VM_ENTRY_LOAD_IA32_EFER,
  4273. .features[FEAT_VMX_EPT_VPID_CAPS] =
  4274. MSR_VMX_EPT_EXECONLY | MSR_VMX_EPT_PAGE_WALK_LENGTH_4 |
  4275. MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB | MSR_VMX_EPT_1GB |
  4276. MSR_VMX_EPT_INVEPT | MSR_VMX_EPT_AD_BITS |
  4277. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  4278. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  4279. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT |
  4280. MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  4281. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS,
  4282. .features[FEAT_VMX_EXIT_CTLS] =
  4283. VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  4284. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  4285. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_IA32_PAT |
  4286. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  4287. VMX_VM_EXIT_LOAD_IA32_EFER | VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  4288. .features[FEAT_VMX_MISC] =
  4289. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_ACTIVITY_HLT |
  4290. MSR_VMX_MISC_VMWRITE_VMEXIT,
  4291. .features[FEAT_VMX_PINBASED_CTLS] =
  4292. VMX_PIN_BASED_EXT_INTR_MASK | VMX_PIN_BASED_NMI_EXITING |
  4293. VMX_PIN_BASED_VIRTUAL_NMIS | VMX_PIN_BASED_VMX_PREEMPTION_TIMER |
  4294. VMX_PIN_BASED_POSTED_INTR,
  4295. .features[FEAT_VMX_PROCBASED_CTLS] =
  4296. VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  4297. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  4298. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  4299. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  4300. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  4301. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  4302. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_VIRTUAL_NMI_PENDING |
  4303. VMX_CPU_BASED_MOV_DR_EXITING | VMX_CPU_BASED_UNCOND_IO_EXITING |
  4304. VMX_CPU_BASED_USE_IO_BITMAPS | VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  4305. VMX_CPU_BASED_USE_MSR_BITMAPS | VMX_CPU_BASED_MONITOR_EXITING |
  4306. VMX_CPU_BASED_PAUSE_EXITING |
  4307. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  4308. .features[FEAT_VMX_SECONDARY_CTLS] =
  4309. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  4310. VMX_SECONDARY_EXEC_ENABLE_EPT | VMX_SECONDARY_EXEC_DESC |
  4311. VMX_SECONDARY_EXEC_RDTSCP |
  4312. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  4313. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_WBINVD_EXITING |
  4314. VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  4315. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  4316. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  4317. VMX_SECONDARY_EXEC_RDRAND_EXITING |
  4318. VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  4319. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  4320. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML |
  4321. VMX_SECONDARY_EXEC_XSAVES,
  4322. .features[FEAT_VMX_VMFUNC] =
  4323. MSR_VMX_VMFUNC_EPT_SWITCHING,
  4324. .xlevel = 0x80000008,
  4325. .model_id = "Intel Xeon Processor (SierraForest)",
  4326. .versions = (X86CPUVersionDefinition[]) {
  4327. { .version = 1 },
  4328. { /* end of list */ },
  4329. },
  4330. },
  4331. {
  4332. .name = "Denverton",
  4333. .level = 21,
  4334. .vendor = CPUID_VENDOR_INTEL,
  4335. .family = 6,
  4336. .model = 95,
  4337. .stepping = 1,
  4338. .features[FEAT_1_EDX] =
  4339. CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE | CPUID_TSC |
  4340. CPUID_MSR | CPUID_PAE | CPUID_MCE | CPUID_CX8 | CPUID_APIC |
  4341. CPUID_SEP | CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
  4342. CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH | CPUID_MMX | CPUID_FXSR |
  4343. CPUID_SSE | CPUID_SSE2,
  4344. .features[FEAT_1_ECX] =
  4345. CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_MONITOR |
  4346. CPUID_EXT_SSSE3 | CPUID_EXT_CX16 | CPUID_EXT_SSE41 |
  4347. CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
  4348. CPUID_EXT_POPCNT | CPUID_EXT_TSC_DEADLINE_TIMER |
  4349. CPUID_EXT_AES | CPUID_EXT_XSAVE | CPUID_EXT_RDRAND,
  4350. .features[FEAT_8000_0001_EDX] =
  4351. CPUID_EXT2_SYSCALL | CPUID_EXT2_NX | CPUID_EXT2_PDPE1GB |
  4352. CPUID_EXT2_RDTSCP | CPUID_EXT2_LM,
  4353. .features[FEAT_8000_0001_ECX] =
  4354. CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  4355. .features[FEAT_7_0_EBX] =
  4356. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_ERMS |
  4357. CPUID_7_0_EBX_MPX | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_SMAP |
  4358. CPUID_7_0_EBX_CLFLUSHOPT | CPUID_7_0_EBX_SHA_NI,
  4359. .features[FEAT_7_0_EDX] =
  4360. CPUID_7_0_EDX_SPEC_CTRL | CPUID_7_0_EDX_ARCH_CAPABILITIES |
  4361. CPUID_7_0_EDX_SPEC_CTRL_SSBD,
  4362. /* XSAVES is added in version 3 */
  4363. .features[FEAT_XSAVE] =
  4364. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC | CPUID_XSAVE_XGETBV1,
  4365. .features[FEAT_6_EAX] =
  4366. CPUID_6_EAX_ARAT,
  4367. .features[FEAT_ARCH_CAPABILITIES] =
  4368. MSR_ARCH_CAP_RDCL_NO | MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY,
  4369. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  4370. MSR_VMX_BASIC_TRUE_CTLS,
  4371. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  4372. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  4373. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  4374. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  4375. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  4376. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  4377. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  4378. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  4379. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  4380. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  4381. .features[FEAT_VMX_EXIT_CTLS] =
  4382. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  4383. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  4384. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  4385. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  4386. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  4387. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  4388. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  4389. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  4390. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  4391. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  4392. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  4393. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  4394. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  4395. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  4396. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  4397. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  4398. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  4399. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  4400. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  4401. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  4402. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  4403. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  4404. .features[FEAT_VMX_SECONDARY_CTLS] =
  4405. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  4406. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  4407. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  4408. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  4409. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  4410. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  4411. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  4412. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  4413. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  4414. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
  4415. .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
  4416. .xlevel = 0x80000008,
  4417. .model_id = "Intel Atom Processor (Denverton)",
  4418. .versions = (X86CPUVersionDefinition[]) {
  4419. { .version = 1 },
  4420. {
  4421. .version = 2,
  4422. .note = "no MPX, no MONITOR",
  4423. .props = (PropValue[]) {
  4424. { "monitor", "off" },
  4425. { "mpx", "off" },
  4426. { /* end of list */ },
  4427. },
  4428. },
  4429. {
  4430. .version = 3,
  4431. .note = "XSAVES, no MPX, no MONITOR",
  4432. .props = (PropValue[]) {
  4433. { "xsaves", "on" },
  4434. { "vmx-xsaves", "on" },
  4435. { /* end of list */ },
  4436. },
  4437. },
  4438. { /* end of list */ },
  4439. },
  4440. },
  4441. {
  4442. .name = "Snowridge",
  4443. .level = 27,
  4444. .vendor = CPUID_VENDOR_INTEL,
  4445. .family = 6,
  4446. .model = 134,
  4447. .stepping = 1,
  4448. .features[FEAT_1_EDX] =
  4449. /* missing: CPUID_PN CPUID_IA64 */
  4450. /* missing: CPUID_DTS, CPUID_HT, CPUID_TM, CPUID_PBE */
  4451. CPUID_FP87 | CPUID_VME | CPUID_DE | CPUID_PSE |
  4452. CPUID_TSC | CPUID_MSR | CPUID_PAE | CPUID_MCE |
  4453. CPUID_CX8 | CPUID_APIC | CPUID_SEP |
  4454. CPUID_MTRR | CPUID_PGE | CPUID_MCA | CPUID_CMOV |
  4455. CPUID_PAT | CPUID_PSE36 | CPUID_CLFLUSH |
  4456. CPUID_MMX |
  4457. CPUID_FXSR | CPUID_SSE | CPUID_SSE2,
  4458. .features[FEAT_1_ECX] =
  4459. CPUID_EXT_SSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_MONITOR |
  4460. CPUID_EXT_SSSE3 |
  4461. CPUID_EXT_CX16 |
  4462. CPUID_EXT_SSE41 |
  4463. CPUID_EXT_SSE42 | CPUID_EXT_X2APIC | CPUID_EXT_MOVBE |
  4464. CPUID_EXT_POPCNT |
  4465. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_AES | CPUID_EXT_XSAVE |
  4466. CPUID_EXT_RDRAND,
  4467. .features[FEAT_8000_0001_EDX] =
  4468. CPUID_EXT2_SYSCALL |
  4469. CPUID_EXT2_NX |
  4470. CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
  4471. CPUID_EXT2_LM,
  4472. .features[FEAT_8000_0001_ECX] =
  4473. CPUID_EXT3_LAHF_LM |
  4474. CPUID_EXT3_3DNOWPREFETCH,
  4475. .features[FEAT_7_0_EBX] =
  4476. CPUID_7_0_EBX_FSGSBASE |
  4477. CPUID_7_0_EBX_SMEP |
  4478. CPUID_7_0_EBX_ERMS |
  4479. CPUID_7_0_EBX_MPX | /* missing bits 13, 15 */
  4480. CPUID_7_0_EBX_RDSEED |
  4481. CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
  4482. CPUID_7_0_EBX_CLWB |
  4483. CPUID_7_0_EBX_SHA_NI,
  4484. .features[FEAT_7_0_ECX] =
  4485. CPUID_7_0_ECX_UMIP |
  4486. /* missing bit 5 */
  4487. CPUID_7_0_ECX_GFNI |
  4488. CPUID_7_0_ECX_MOVDIRI | CPUID_7_0_ECX_CLDEMOTE |
  4489. CPUID_7_0_ECX_MOVDIR64B,
  4490. .features[FEAT_7_0_EDX] =
  4491. CPUID_7_0_EDX_SPEC_CTRL |
  4492. CPUID_7_0_EDX_ARCH_CAPABILITIES | CPUID_7_0_EDX_SPEC_CTRL_SSBD |
  4493. CPUID_7_0_EDX_CORE_CAPABILITY,
  4494. .features[FEAT_CORE_CAPABILITY] =
  4495. MSR_CORE_CAP_SPLIT_LOCK_DETECT,
  4496. /* XSAVES is added in version 3 */
  4497. .features[FEAT_XSAVE] =
  4498. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  4499. CPUID_XSAVE_XGETBV1,
  4500. .features[FEAT_6_EAX] =
  4501. CPUID_6_EAX_ARAT,
  4502. .features[FEAT_VMX_BASIC] = MSR_VMX_BASIC_INS_OUTS |
  4503. MSR_VMX_BASIC_TRUE_CTLS,
  4504. .features[FEAT_VMX_ENTRY_CTLS] = VMX_VM_ENTRY_IA32E_MODE |
  4505. VMX_VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL | VMX_VM_ENTRY_LOAD_IA32_PAT |
  4506. VMX_VM_ENTRY_LOAD_DEBUG_CONTROLS | VMX_VM_ENTRY_LOAD_IA32_EFER,
  4507. .features[FEAT_VMX_EPT_VPID_CAPS] = MSR_VMX_EPT_EXECONLY |
  4508. MSR_VMX_EPT_PAGE_WALK_LENGTH_4 | MSR_VMX_EPT_WB | MSR_VMX_EPT_2MB |
  4509. MSR_VMX_EPT_1GB | MSR_VMX_EPT_INVEPT |
  4510. MSR_VMX_EPT_INVEPT_SINGLE_CONTEXT | MSR_VMX_EPT_INVEPT_ALL_CONTEXT |
  4511. MSR_VMX_EPT_INVVPID | MSR_VMX_EPT_INVVPID_SINGLE_ADDR |
  4512. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT | MSR_VMX_EPT_INVVPID_ALL_CONTEXT |
  4513. MSR_VMX_EPT_INVVPID_SINGLE_CONTEXT_NOGLOBALS | MSR_VMX_EPT_AD_BITS,
  4514. .features[FEAT_VMX_EXIT_CTLS] =
  4515. VMX_VM_EXIT_ACK_INTR_ON_EXIT | VMX_VM_EXIT_SAVE_DEBUG_CONTROLS |
  4516. VMX_VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL |
  4517. VMX_VM_EXIT_LOAD_IA32_PAT | VMX_VM_EXIT_LOAD_IA32_EFER |
  4518. VMX_VM_EXIT_SAVE_IA32_PAT | VMX_VM_EXIT_SAVE_IA32_EFER |
  4519. VMX_VM_EXIT_SAVE_VMX_PREEMPTION_TIMER,
  4520. .features[FEAT_VMX_MISC] = MSR_VMX_MISC_ACTIVITY_HLT |
  4521. MSR_VMX_MISC_STORE_LMA | MSR_VMX_MISC_VMWRITE_VMEXIT,
  4522. .features[FEAT_VMX_PINBASED_CTLS] = VMX_PIN_BASED_EXT_INTR_MASK |
  4523. VMX_PIN_BASED_NMI_EXITING | VMX_PIN_BASED_VIRTUAL_NMIS |
  4524. VMX_PIN_BASED_VMX_PREEMPTION_TIMER | VMX_PIN_BASED_POSTED_INTR,
  4525. .features[FEAT_VMX_PROCBASED_CTLS] = VMX_CPU_BASED_VIRTUAL_INTR_PENDING |
  4526. VMX_CPU_BASED_USE_TSC_OFFSETING | VMX_CPU_BASED_HLT_EXITING |
  4527. VMX_CPU_BASED_INVLPG_EXITING | VMX_CPU_BASED_MWAIT_EXITING |
  4528. VMX_CPU_BASED_RDPMC_EXITING | VMX_CPU_BASED_RDTSC_EXITING |
  4529. VMX_CPU_BASED_CR8_LOAD_EXITING | VMX_CPU_BASED_CR8_STORE_EXITING |
  4530. VMX_CPU_BASED_TPR_SHADOW | VMX_CPU_BASED_MOV_DR_EXITING |
  4531. VMX_CPU_BASED_UNCOND_IO_EXITING | VMX_CPU_BASED_USE_IO_BITMAPS |
  4532. VMX_CPU_BASED_MONITOR_EXITING | VMX_CPU_BASED_PAUSE_EXITING |
  4533. VMX_CPU_BASED_VIRTUAL_NMI_PENDING | VMX_CPU_BASED_USE_MSR_BITMAPS |
  4534. VMX_CPU_BASED_CR3_LOAD_EXITING | VMX_CPU_BASED_CR3_STORE_EXITING |
  4535. VMX_CPU_BASED_MONITOR_TRAP_FLAG |
  4536. VMX_CPU_BASED_ACTIVATE_SECONDARY_CONTROLS,
  4537. .features[FEAT_VMX_SECONDARY_CTLS] =
  4538. VMX_SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES |
  4539. VMX_SECONDARY_EXEC_WBINVD_EXITING | VMX_SECONDARY_EXEC_ENABLE_EPT |
  4540. VMX_SECONDARY_EXEC_DESC | VMX_SECONDARY_EXEC_RDTSCP |
  4541. VMX_SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE |
  4542. VMX_SECONDARY_EXEC_ENABLE_VPID | VMX_SECONDARY_EXEC_UNRESTRICTED_GUEST |
  4543. VMX_SECONDARY_EXEC_APIC_REGISTER_VIRT |
  4544. VMX_SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY |
  4545. VMX_SECONDARY_EXEC_RDRAND_EXITING | VMX_SECONDARY_EXEC_ENABLE_INVPCID |
  4546. VMX_SECONDARY_EXEC_ENABLE_VMFUNC | VMX_SECONDARY_EXEC_SHADOW_VMCS |
  4547. VMX_SECONDARY_EXEC_RDSEED_EXITING | VMX_SECONDARY_EXEC_ENABLE_PML,
  4548. .features[FEAT_VMX_VMFUNC] = MSR_VMX_VMFUNC_EPT_SWITCHING,
  4549. .xlevel = 0x80000008,
  4550. .model_id = "Intel Atom Processor (SnowRidge)",
  4551. .versions = (X86CPUVersionDefinition[]) {
  4552. { .version = 1 },
  4553. {
  4554. .version = 2,
  4555. .props = (PropValue[]) {
  4556. { "mpx", "off" },
  4557. { "model-id", "Intel Atom Processor (Snowridge, no MPX)" },
  4558. { /* end of list */ },
  4559. },
  4560. },
  4561. {
  4562. .version = 3,
  4563. .note = "XSAVES, no MPX",
  4564. .props = (PropValue[]) {
  4565. { "xsaves", "on" },
  4566. { "vmx-xsaves", "on" },
  4567. { /* end of list */ },
  4568. },
  4569. },
  4570. {
  4571. .version = 4,
  4572. .note = "no split lock detect, no core-capability",
  4573. .props = (PropValue[]) {
  4574. { "split-lock-detect", "off" },
  4575. { "core-capability", "off" },
  4576. { /* end of list */ },
  4577. },
  4578. },
  4579. { /* end of list */ },
  4580. },
  4581. },
  4582. {
  4583. .name = "KnightsMill",
  4584. .level = 0xd,
  4585. .vendor = CPUID_VENDOR_INTEL,
  4586. .family = 6,
  4587. .model = 133,
  4588. .stepping = 0,
  4589. .features[FEAT_1_EDX] =
  4590. CPUID_VME | CPUID_SS | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR |
  4591. CPUID_MMX | CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV |
  4592. CPUID_MCA | CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC |
  4593. CPUID_CX8 | CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC |
  4594. CPUID_PSE | CPUID_DE | CPUID_FP87,
  4595. .features[FEAT_1_ECX] =
  4596. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  4597. CPUID_EXT_POPCNT | CPUID_EXT_X2APIC | CPUID_EXT_SSE42 |
  4598. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_SSSE3 |
  4599. CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  4600. CPUID_EXT_TSC_DEADLINE_TIMER | CPUID_EXT_FMA | CPUID_EXT_MOVBE |
  4601. CPUID_EXT_F16C | CPUID_EXT_RDRAND,
  4602. .features[FEAT_8000_0001_EDX] =
  4603. CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_RDTSCP |
  4604. CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  4605. .features[FEAT_8000_0001_ECX] =
  4606. CPUID_EXT3_ABM | CPUID_EXT3_LAHF_LM | CPUID_EXT3_3DNOWPREFETCH,
  4607. .features[FEAT_7_0_EBX] =
  4608. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
  4609. CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS |
  4610. CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_AVX512F |
  4611. CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_AVX512PF |
  4612. CPUID_7_0_EBX_AVX512ER,
  4613. .features[FEAT_7_0_ECX] =
  4614. CPUID_7_0_ECX_AVX512_VPOPCNTDQ,
  4615. .features[FEAT_7_0_EDX] =
  4616. CPUID_7_0_EDX_AVX512_4VNNIW | CPUID_7_0_EDX_AVX512_4FMAPS,
  4617. .features[FEAT_XSAVE] =
  4618. CPUID_XSAVE_XSAVEOPT,
  4619. .features[FEAT_6_EAX] =
  4620. CPUID_6_EAX_ARAT,
  4621. .xlevel = 0x80000008,
  4622. .model_id = "Intel Xeon Phi Processor (Knights Mill)",
  4623. },
  4624. {
  4625. .name = "Opteron_G1",
  4626. .level = 5,
  4627. .vendor = CPUID_VENDOR_AMD,
  4628. .family = 15,
  4629. .model = 6,
  4630. .stepping = 1,
  4631. .features[FEAT_1_EDX] =
  4632. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  4633. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  4634. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  4635. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  4636. CPUID_DE | CPUID_FP87,
  4637. .features[FEAT_1_ECX] =
  4638. CPUID_EXT_SSE3,
  4639. .features[FEAT_8000_0001_EDX] =
  4640. CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  4641. .xlevel = 0x80000008,
  4642. .model_id = "AMD Opteron 240 (Gen 1 Class Opteron)",
  4643. },
  4644. {
  4645. .name = "Opteron_G2",
  4646. .level = 5,
  4647. .vendor = CPUID_VENDOR_AMD,
  4648. .family = 15,
  4649. .model = 6,
  4650. .stepping = 1,
  4651. .features[FEAT_1_EDX] =
  4652. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  4653. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  4654. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  4655. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  4656. CPUID_DE | CPUID_FP87,
  4657. .features[FEAT_1_ECX] =
  4658. CPUID_EXT_CX16 | CPUID_EXT_SSE3,
  4659. .features[FEAT_8000_0001_EDX] =
  4660. CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL,
  4661. .features[FEAT_8000_0001_ECX] =
  4662. CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM,
  4663. .xlevel = 0x80000008,
  4664. .model_id = "AMD Opteron 22xx (Gen 2 Class Opteron)",
  4665. },
  4666. {
  4667. .name = "Opteron_G3",
  4668. .level = 5,
  4669. .vendor = CPUID_VENDOR_AMD,
  4670. .family = 16,
  4671. .model = 2,
  4672. .stepping = 3,
  4673. .features[FEAT_1_EDX] =
  4674. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  4675. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  4676. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  4677. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  4678. CPUID_DE | CPUID_FP87,
  4679. .features[FEAT_1_ECX] =
  4680. CPUID_EXT_POPCNT | CPUID_EXT_CX16 | CPUID_EXT_MONITOR |
  4681. CPUID_EXT_SSE3,
  4682. .features[FEAT_8000_0001_EDX] =
  4683. CPUID_EXT2_LM | CPUID_EXT2_NX | CPUID_EXT2_SYSCALL |
  4684. CPUID_EXT2_RDTSCP,
  4685. .features[FEAT_8000_0001_ECX] =
  4686. CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A |
  4687. CPUID_EXT3_ABM | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM,
  4688. .xlevel = 0x80000008,
  4689. .model_id = "AMD Opteron 23xx (Gen 3 Class Opteron)",
  4690. },
  4691. {
  4692. .name = "Opteron_G4",
  4693. .level = 0xd,
  4694. .vendor = CPUID_VENDOR_AMD,
  4695. .family = 21,
  4696. .model = 1,
  4697. .stepping = 2,
  4698. .features[FEAT_1_EDX] =
  4699. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  4700. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  4701. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  4702. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  4703. CPUID_DE | CPUID_FP87,
  4704. .features[FEAT_1_ECX] =
  4705. CPUID_EXT_AVX | CPUID_EXT_XSAVE | CPUID_EXT_AES |
  4706. CPUID_EXT_POPCNT | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  4707. CPUID_EXT_CX16 | CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ |
  4708. CPUID_EXT_SSE3,
  4709. .features[FEAT_8000_0001_EDX] =
  4710. CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_NX |
  4711. CPUID_EXT2_SYSCALL | CPUID_EXT2_RDTSCP,
  4712. .features[FEAT_8000_0001_ECX] =
  4713. CPUID_EXT3_FMA4 | CPUID_EXT3_XOP |
  4714. CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_MISALIGNSSE |
  4715. CPUID_EXT3_SSE4A | CPUID_EXT3_ABM | CPUID_EXT3_SVM |
  4716. CPUID_EXT3_LAHF_LM,
  4717. .features[FEAT_SVM] =
  4718. CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
  4719. /* no xsaveopt! */
  4720. .xlevel = 0x8000001A,
  4721. .model_id = "AMD Opteron 62xx class CPU",
  4722. },
  4723. {
  4724. .name = "Opteron_G5",
  4725. .level = 0xd,
  4726. .vendor = CPUID_VENDOR_AMD,
  4727. .family = 21,
  4728. .model = 2,
  4729. .stepping = 0,
  4730. .features[FEAT_1_EDX] =
  4731. CPUID_VME | CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX |
  4732. CPUID_CLFLUSH | CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA |
  4733. CPUID_PGE | CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 |
  4734. CPUID_MCE | CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE |
  4735. CPUID_DE | CPUID_FP87,
  4736. .features[FEAT_1_ECX] =
  4737. CPUID_EXT_F16C | CPUID_EXT_AVX | CPUID_EXT_XSAVE |
  4738. CPUID_EXT_AES | CPUID_EXT_POPCNT | CPUID_EXT_SSE42 |
  4739. CPUID_EXT_SSE41 | CPUID_EXT_CX16 | CPUID_EXT_FMA |
  4740. CPUID_EXT_SSSE3 | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
  4741. .features[FEAT_8000_0001_EDX] =
  4742. CPUID_EXT2_LM | CPUID_EXT2_PDPE1GB | CPUID_EXT2_NX |
  4743. CPUID_EXT2_SYSCALL | CPUID_EXT2_RDTSCP,
  4744. .features[FEAT_8000_0001_ECX] =
  4745. CPUID_EXT3_TBM | CPUID_EXT3_FMA4 | CPUID_EXT3_XOP |
  4746. CPUID_EXT3_3DNOWPREFETCH | CPUID_EXT3_MISALIGNSSE |
  4747. CPUID_EXT3_SSE4A | CPUID_EXT3_ABM | CPUID_EXT3_SVM |
  4748. CPUID_EXT3_LAHF_LM,
  4749. .features[FEAT_SVM] =
  4750. CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
  4751. /* no xsaveopt! */
  4752. .xlevel = 0x8000001A,
  4753. .model_id = "AMD Opteron 63xx class CPU",
  4754. },
  4755. {
  4756. .name = "EPYC",
  4757. .level = 0xd,
  4758. .vendor = CPUID_VENDOR_AMD,
  4759. .family = 23,
  4760. .model = 1,
  4761. .stepping = 2,
  4762. .features[FEAT_1_EDX] =
  4763. CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
  4764. CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
  4765. CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
  4766. CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
  4767. CPUID_VME | CPUID_FP87,
  4768. .features[FEAT_1_ECX] =
  4769. CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
  4770. CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
  4771. CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  4772. CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
  4773. CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
  4774. .features[FEAT_8000_0001_EDX] =
  4775. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
  4776. CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
  4777. CPUID_EXT2_SYSCALL,
  4778. .features[FEAT_8000_0001_ECX] =
  4779. CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
  4780. CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
  4781. CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
  4782. CPUID_EXT3_TOPOEXT,
  4783. .features[FEAT_7_0_EBX] =
  4784. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
  4785. CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
  4786. CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
  4787. CPUID_7_0_EBX_SHA_NI,
  4788. .features[FEAT_XSAVE] =
  4789. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  4790. CPUID_XSAVE_XGETBV1,
  4791. .features[FEAT_6_EAX] =
  4792. CPUID_6_EAX_ARAT,
  4793. .features[FEAT_SVM] =
  4794. CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
  4795. .xlevel = 0x8000001E,
  4796. .model_id = "AMD EPYC Processor",
  4797. .cache_info = &epyc_cache_info,
  4798. .versions = (X86CPUVersionDefinition[]) {
  4799. { .version = 1 },
  4800. {
  4801. .version = 2,
  4802. .alias = "EPYC-IBPB",
  4803. .props = (PropValue[]) {
  4804. { "ibpb", "on" },
  4805. { "model-id",
  4806. "AMD EPYC Processor (with IBPB)" },
  4807. { /* end of list */ }
  4808. }
  4809. },
  4810. {
  4811. .version = 3,
  4812. .props = (PropValue[]) {
  4813. { "ibpb", "on" },
  4814. { "perfctr-core", "on" },
  4815. { "clzero", "on" },
  4816. { "xsaveerptr", "on" },
  4817. { "xsaves", "on" },
  4818. { "model-id",
  4819. "AMD EPYC Processor" },
  4820. { /* end of list */ }
  4821. }
  4822. },
  4823. {
  4824. .version = 4,
  4825. .props = (PropValue[]) {
  4826. { "model-id",
  4827. "AMD EPYC-v4 Processor" },
  4828. { /* end of list */ }
  4829. },
  4830. .cache_info = &epyc_v4_cache_info
  4831. },
  4832. { /* end of list */ }
  4833. }
  4834. },
  4835. {
  4836. .name = "Dhyana",
  4837. .level = 0xd,
  4838. .vendor = CPUID_VENDOR_HYGON,
  4839. .family = 24,
  4840. .model = 0,
  4841. .stepping = 1,
  4842. .features[FEAT_1_EDX] =
  4843. CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
  4844. CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
  4845. CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
  4846. CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
  4847. CPUID_VME | CPUID_FP87,
  4848. .features[FEAT_1_ECX] =
  4849. CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
  4850. CPUID_EXT_XSAVE | CPUID_EXT_POPCNT |
  4851. CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  4852. CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
  4853. CPUID_EXT_MONITOR | CPUID_EXT_SSE3,
  4854. .features[FEAT_8000_0001_EDX] =
  4855. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
  4856. CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
  4857. CPUID_EXT2_SYSCALL,
  4858. .features[FEAT_8000_0001_ECX] =
  4859. CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
  4860. CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
  4861. CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
  4862. CPUID_EXT3_TOPOEXT,
  4863. .features[FEAT_8000_0008_EBX] =
  4864. CPUID_8000_0008_EBX_IBPB,
  4865. .features[FEAT_7_0_EBX] =
  4866. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
  4867. CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
  4868. CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT,
  4869. /* XSAVES is added in version 2 */
  4870. .features[FEAT_XSAVE] =
  4871. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  4872. CPUID_XSAVE_XGETBV1,
  4873. .features[FEAT_6_EAX] =
  4874. CPUID_6_EAX_ARAT,
  4875. .features[FEAT_SVM] =
  4876. CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
  4877. .xlevel = 0x8000001E,
  4878. .model_id = "Hygon Dhyana Processor",
  4879. .cache_info = &epyc_cache_info,
  4880. .versions = (X86CPUVersionDefinition[]) {
  4881. { .version = 1 },
  4882. { .version = 2,
  4883. .note = "XSAVES",
  4884. .props = (PropValue[]) {
  4885. { "xsaves", "on" },
  4886. { /* end of list */ }
  4887. },
  4888. },
  4889. { /* end of list */ }
  4890. }
  4891. },
  4892. {
  4893. .name = "EPYC-Rome",
  4894. .level = 0xd,
  4895. .vendor = CPUID_VENDOR_AMD,
  4896. .family = 23,
  4897. .model = 49,
  4898. .stepping = 0,
  4899. .features[FEAT_1_EDX] =
  4900. CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
  4901. CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
  4902. CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
  4903. CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
  4904. CPUID_VME | CPUID_FP87,
  4905. .features[FEAT_1_ECX] =
  4906. CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
  4907. CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
  4908. CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  4909. CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
  4910. CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3,
  4911. .features[FEAT_8000_0001_EDX] =
  4912. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
  4913. CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
  4914. CPUID_EXT2_SYSCALL,
  4915. .features[FEAT_8000_0001_ECX] =
  4916. CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
  4917. CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
  4918. CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
  4919. CPUID_EXT3_TOPOEXT | CPUID_EXT3_PERFCORE,
  4920. .features[FEAT_8000_0008_EBX] =
  4921. CPUID_8000_0008_EBX_CLZERO | CPUID_8000_0008_EBX_XSAVEERPTR |
  4922. CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_IBPB |
  4923. CPUID_8000_0008_EBX_STIBP,
  4924. .features[FEAT_7_0_EBX] =
  4925. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
  4926. CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
  4927. CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
  4928. CPUID_7_0_EBX_SHA_NI | CPUID_7_0_EBX_CLWB,
  4929. .features[FEAT_7_0_ECX] =
  4930. CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_RDPID,
  4931. .features[FEAT_XSAVE] =
  4932. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  4933. CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
  4934. .features[FEAT_6_EAX] =
  4935. CPUID_6_EAX_ARAT,
  4936. .features[FEAT_SVM] =
  4937. CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE,
  4938. .xlevel = 0x8000001E,
  4939. .model_id = "AMD EPYC-Rome Processor",
  4940. .cache_info = &epyc_rome_cache_info,
  4941. .versions = (X86CPUVersionDefinition[]) {
  4942. { .version = 1 },
  4943. {
  4944. .version = 2,
  4945. .props = (PropValue[]) {
  4946. { "ibrs", "on" },
  4947. { "amd-ssbd", "on" },
  4948. { /* end of list */ }
  4949. }
  4950. },
  4951. {
  4952. .version = 3,
  4953. .props = (PropValue[]) {
  4954. { "model-id",
  4955. "AMD EPYC-Rome-v3 Processor" },
  4956. { /* end of list */ }
  4957. },
  4958. .cache_info = &epyc_rome_v3_cache_info
  4959. },
  4960. {
  4961. .version = 4,
  4962. .props = (PropValue[]) {
  4963. /* Erratum 1386 */
  4964. { "model-id",
  4965. "AMD EPYC-Rome-v4 Processor (no XSAVES)" },
  4966. { "xsaves", "off" },
  4967. { /* end of list */ }
  4968. },
  4969. },
  4970. { /* end of list */ }
  4971. }
  4972. },
  4973. {
  4974. .name = "EPYC-Milan",
  4975. .level = 0xd,
  4976. .vendor = CPUID_VENDOR_AMD,
  4977. .family = 25,
  4978. .model = 1,
  4979. .stepping = 1,
  4980. .features[FEAT_1_EDX] =
  4981. CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
  4982. CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
  4983. CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
  4984. CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
  4985. CPUID_VME | CPUID_FP87,
  4986. .features[FEAT_1_ECX] =
  4987. CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
  4988. CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
  4989. CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  4990. CPUID_EXT_CX16 | CPUID_EXT_FMA | CPUID_EXT_SSSE3 |
  4991. CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ | CPUID_EXT_SSE3 |
  4992. CPUID_EXT_PCID,
  4993. .features[FEAT_8000_0001_EDX] =
  4994. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
  4995. CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
  4996. CPUID_EXT2_SYSCALL,
  4997. .features[FEAT_8000_0001_ECX] =
  4998. CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
  4999. CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
  5000. CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
  5001. CPUID_EXT3_TOPOEXT | CPUID_EXT3_PERFCORE,
  5002. .features[FEAT_8000_0008_EBX] =
  5003. CPUID_8000_0008_EBX_CLZERO | CPUID_8000_0008_EBX_XSAVEERPTR |
  5004. CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_IBPB |
  5005. CPUID_8000_0008_EBX_IBRS | CPUID_8000_0008_EBX_STIBP |
  5006. CPUID_8000_0008_EBX_AMD_SSBD,
  5007. .features[FEAT_7_0_EBX] =
  5008. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
  5009. CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_RDSEED |
  5010. CPUID_7_0_EBX_ADX | CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_CLFLUSHOPT |
  5011. CPUID_7_0_EBX_SHA_NI | CPUID_7_0_EBX_CLWB | CPUID_7_0_EBX_ERMS |
  5012. CPUID_7_0_EBX_INVPCID,
  5013. .features[FEAT_7_0_ECX] =
  5014. CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_RDPID | CPUID_7_0_ECX_PKU,
  5015. .features[FEAT_7_0_EDX] =
  5016. CPUID_7_0_EDX_FSRM,
  5017. .features[FEAT_XSAVE] =
  5018. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  5019. CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
  5020. .features[FEAT_6_EAX] =
  5021. CPUID_6_EAX_ARAT,
  5022. .features[FEAT_SVM] =
  5023. CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE | CPUID_SVM_SVME_ADDR_CHK,
  5024. .xlevel = 0x8000001E,
  5025. .model_id = "AMD EPYC-Milan Processor",
  5026. .cache_info = &epyc_milan_cache_info,
  5027. .versions = (X86CPUVersionDefinition[]) {
  5028. { .version = 1 },
  5029. {
  5030. .version = 2,
  5031. .props = (PropValue[]) {
  5032. { "model-id",
  5033. "AMD EPYC-Milan-v2 Processor" },
  5034. { "vaes", "on" },
  5035. { "vpclmulqdq", "on" },
  5036. { "stibp-always-on", "on" },
  5037. { "amd-psfd", "on" },
  5038. { "no-nested-data-bp", "on" },
  5039. { "lfence-always-serializing", "on" },
  5040. { "null-sel-clr-base", "on" },
  5041. { /* end of list */ }
  5042. },
  5043. .cache_info = &epyc_milan_v2_cache_info
  5044. },
  5045. { /* end of list */ }
  5046. }
  5047. },
  5048. {
  5049. .name = "EPYC-Genoa",
  5050. .level = 0xd,
  5051. .vendor = CPUID_VENDOR_AMD,
  5052. .family = 25,
  5053. .model = 17,
  5054. .stepping = 0,
  5055. .features[FEAT_1_EDX] =
  5056. CPUID_SSE2 | CPUID_SSE | CPUID_FXSR | CPUID_MMX | CPUID_CLFLUSH |
  5057. CPUID_PSE36 | CPUID_PAT | CPUID_CMOV | CPUID_MCA | CPUID_PGE |
  5058. CPUID_MTRR | CPUID_SEP | CPUID_APIC | CPUID_CX8 | CPUID_MCE |
  5059. CPUID_PAE | CPUID_MSR | CPUID_TSC | CPUID_PSE | CPUID_DE |
  5060. CPUID_VME | CPUID_FP87,
  5061. .features[FEAT_1_ECX] =
  5062. CPUID_EXT_RDRAND | CPUID_EXT_F16C | CPUID_EXT_AVX |
  5063. CPUID_EXT_XSAVE | CPUID_EXT_AES | CPUID_EXT_POPCNT |
  5064. CPUID_EXT_MOVBE | CPUID_EXT_SSE42 | CPUID_EXT_SSE41 |
  5065. CPUID_EXT_PCID | CPUID_EXT_CX16 | CPUID_EXT_FMA |
  5066. CPUID_EXT_SSSE3 | CPUID_EXT_MONITOR | CPUID_EXT_PCLMULQDQ |
  5067. CPUID_EXT_SSE3,
  5068. .features[FEAT_8000_0001_EDX] =
  5069. CPUID_EXT2_LM | CPUID_EXT2_RDTSCP | CPUID_EXT2_PDPE1GB |
  5070. CPUID_EXT2_FFXSR | CPUID_EXT2_MMXEXT | CPUID_EXT2_NX |
  5071. CPUID_EXT2_SYSCALL,
  5072. .features[FEAT_8000_0001_ECX] =
  5073. CPUID_EXT3_OSVW | CPUID_EXT3_3DNOWPREFETCH |
  5074. CPUID_EXT3_MISALIGNSSE | CPUID_EXT3_SSE4A | CPUID_EXT3_ABM |
  5075. CPUID_EXT3_CR8LEG | CPUID_EXT3_SVM | CPUID_EXT3_LAHF_LM |
  5076. CPUID_EXT3_TOPOEXT | CPUID_EXT3_PERFCORE,
  5077. .features[FEAT_8000_0008_EBX] =
  5078. CPUID_8000_0008_EBX_CLZERO | CPUID_8000_0008_EBX_XSAVEERPTR |
  5079. CPUID_8000_0008_EBX_WBNOINVD | CPUID_8000_0008_EBX_IBPB |
  5080. CPUID_8000_0008_EBX_IBRS | CPUID_8000_0008_EBX_STIBP |
  5081. CPUID_8000_0008_EBX_STIBP_ALWAYS_ON |
  5082. CPUID_8000_0008_EBX_AMD_SSBD | CPUID_8000_0008_EBX_AMD_PSFD,
  5083. .features[FEAT_8000_0021_EAX] =
  5084. CPUID_8000_0021_EAX_No_NESTED_DATA_BP |
  5085. CPUID_8000_0021_EAX_LFENCE_ALWAYS_SERIALIZING |
  5086. CPUID_8000_0021_EAX_NULL_SEL_CLR_BASE |
  5087. CPUID_8000_0021_EAX_AUTO_IBRS,
  5088. .features[FEAT_7_0_EBX] =
  5089. CPUID_7_0_EBX_FSGSBASE | CPUID_7_0_EBX_BMI1 | CPUID_7_0_EBX_AVX2 |
  5090. CPUID_7_0_EBX_SMEP | CPUID_7_0_EBX_BMI2 | CPUID_7_0_EBX_ERMS |
  5091. CPUID_7_0_EBX_INVPCID | CPUID_7_0_EBX_AVX512F |
  5092. CPUID_7_0_EBX_AVX512DQ | CPUID_7_0_EBX_RDSEED | CPUID_7_0_EBX_ADX |
  5093. CPUID_7_0_EBX_SMAP | CPUID_7_0_EBX_AVX512IFMA |
  5094. CPUID_7_0_EBX_CLFLUSHOPT | CPUID_7_0_EBX_CLWB |
  5095. CPUID_7_0_EBX_AVX512CD | CPUID_7_0_EBX_SHA_NI |
  5096. CPUID_7_0_EBX_AVX512BW | CPUID_7_0_EBX_AVX512VL,
  5097. .features[FEAT_7_0_ECX] =
  5098. CPUID_7_0_ECX_AVX512_VBMI | CPUID_7_0_ECX_UMIP | CPUID_7_0_ECX_PKU |
  5099. CPUID_7_0_ECX_AVX512_VBMI2 | CPUID_7_0_ECX_GFNI |
  5100. CPUID_7_0_ECX_VAES | CPUID_7_0_ECX_VPCLMULQDQ |
  5101. CPUID_7_0_ECX_AVX512VNNI | CPUID_7_0_ECX_AVX512BITALG |
  5102. CPUID_7_0_ECX_AVX512_VPOPCNTDQ | CPUID_7_0_ECX_LA57 |
  5103. CPUID_7_0_ECX_RDPID,
  5104. .features[FEAT_7_0_EDX] =
  5105. CPUID_7_0_EDX_FSRM,
  5106. .features[FEAT_7_1_EAX] =
  5107. CPUID_7_1_EAX_AVX512_BF16,
  5108. .features[FEAT_XSAVE] =
  5109. CPUID_XSAVE_XSAVEOPT | CPUID_XSAVE_XSAVEC |
  5110. CPUID_XSAVE_XGETBV1 | CPUID_XSAVE_XSAVES,
  5111. .features[FEAT_6_EAX] =
  5112. CPUID_6_EAX_ARAT,
  5113. .features[FEAT_SVM] =
  5114. CPUID_SVM_NPT | CPUID_SVM_NRIPSAVE | CPUID_SVM_VNMI |
  5115. CPUID_SVM_SVME_ADDR_CHK,
  5116. .xlevel = 0x80000022,
  5117. .model_id = "AMD EPYC-Genoa Processor",
  5118. .cache_info = &epyc_genoa_cache_info,
  5119. },
  5120. };
  5121. /*
  5122. * We resolve CPU model aliases using -v1 when using "-machine
  5123. * none", but this is just for compatibility while libvirt isn't
  5124. * adapted to resolve CPU model versions before creating VMs.
  5125. * See "Runnability guarantee of CPU models" at
  5126. * docs/about/deprecated.rst.
  5127. */
  5128. X86CPUVersion default_cpu_version = 1;
  5129. void x86_cpu_set_default_version(X86CPUVersion version)
  5130. {
  5131. /* Translating CPU_VERSION_AUTO to CPU_VERSION_AUTO doesn't make sense */
  5132. assert(version != CPU_VERSION_AUTO);
  5133. default_cpu_version = version;
  5134. }
  5135. static X86CPUVersion x86_cpu_model_last_version(const X86CPUModel *model)
  5136. {
  5137. int v = 0;
  5138. const X86CPUVersionDefinition *vdef =
  5139. x86_cpu_def_get_versions(model->cpudef);
  5140. while (vdef->version) {
  5141. v = vdef->version;
  5142. vdef++;
  5143. }
  5144. return v;
  5145. }
  5146. /* Return the actual version being used for a specific CPU model */
  5147. static X86CPUVersion x86_cpu_model_resolve_version(const X86CPUModel *model)
  5148. {
  5149. X86CPUVersion v = model->version;
  5150. if (v == CPU_VERSION_AUTO) {
  5151. v = default_cpu_version;
  5152. }
  5153. if (v == CPU_VERSION_LATEST) {
  5154. return x86_cpu_model_last_version(model);
  5155. }
  5156. return v;
  5157. }
  5158. static Property max_x86_cpu_properties[] = {
  5159. DEFINE_PROP_BOOL("migratable", X86CPU, migratable, true),
  5160. DEFINE_PROP_BOOL("host-cache-info", X86CPU, cache_info_passthrough, false),
  5161. DEFINE_PROP_END_OF_LIST()
  5162. };
  5163. static void max_x86_cpu_realize(DeviceState *dev, Error **errp)
  5164. {
  5165. Object *obj = OBJECT(dev);
  5166. if (!object_property_get_int(obj, "family", &error_abort)) {
  5167. if (X86_CPU(obj)->env.features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
  5168. object_property_set_int(obj, "family", 15, &error_abort);
  5169. object_property_set_int(obj, "model", 107, &error_abort);
  5170. object_property_set_int(obj, "stepping", 1, &error_abort);
  5171. } else {
  5172. object_property_set_int(obj, "family", 6, &error_abort);
  5173. object_property_set_int(obj, "model", 6, &error_abort);
  5174. object_property_set_int(obj, "stepping", 3, &error_abort);
  5175. }
  5176. }
  5177. x86_cpu_realizefn(dev, errp);
  5178. }
  5179. static void max_x86_cpu_class_init(ObjectClass *oc, void *data)
  5180. {
  5181. DeviceClass *dc = DEVICE_CLASS(oc);
  5182. X86CPUClass *xcc = X86_CPU_CLASS(oc);
  5183. xcc->ordering = 9;
  5184. xcc->model_description =
  5185. "Enables all features supported by the accelerator in the current host";
  5186. device_class_set_props(dc, max_x86_cpu_properties);
  5187. dc->realize = max_x86_cpu_realize;
  5188. }
  5189. static void max_x86_cpu_initfn(Object *obj)
  5190. {
  5191. X86CPU *cpu = X86_CPU(obj);
  5192. /* We can't fill the features array here because we don't know yet if
  5193. * "migratable" is true or false.
  5194. */
  5195. cpu->max_features = true;
  5196. object_property_set_bool(OBJECT(cpu), "pmu", true, &error_abort);
  5197. /*
  5198. * these defaults are used for TCG and all other accelerators
  5199. * besides KVM and HVF, which overwrite these values
  5200. */
  5201. object_property_set_str(OBJECT(cpu), "vendor", CPUID_VENDOR_AMD,
  5202. &error_abort);
  5203. object_property_set_str(OBJECT(cpu), "model-id",
  5204. "QEMU TCG CPU version " QEMU_HW_VERSION,
  5205. &error_abort);
  5206. }
  5207. static const TypeInfo max_x86_cpu_type_info = {
  5208. .name = X86_CPU_TYPE_NAME("max"),
  5209. .parent = TYPE_X86_CPU,
  5210. .instance_init = max_x86_cpu_initfn,
  5211. .class_init = max_x86_cpu_class_init,
  5212. };
  5213. static char *feature_word_description(FeatureWordInfo *f, uint32_t bit)
  5214. {
  5215. assert(f->type == CPUID_FEATURE_WORD || f->type == MSR_FEATURE_WORD);
  5216. switch (f->type) {
  5217. case CPUID_FEATURE_WORD:
  5218. {
  5219. const char *reg = get_register_name_32(f->cpuid.reg);
  5220. assert(reg);
  5221. return g_strdup_printf("CPUID.%02XH:%s",
  5222. f->cpuid.eax, reg);
  5223. }
  5224. case MSR_FEATURE_WORD:
  5225. return g_strdup_printf("MSR(%02XH)",
  5226. f->msr.index);
  5227. }
  5228. return NULL;
  5229. }
  5230. static bool x86_cpu_have_filtered_features(X86CPU *cpu)
  5231. {
  5232. FeatureWord w;
  5233. for (w = 0; w < FEATURE_WORDS; w++) {
  5234. if (cpu->filtered_features[w]) {
  5235. return true;
  5236. }
  5237. }
  5238. return false;
  5239. }
  5240. static void mark_unavailable_features(X86CPU *cpu, FeatureWord w, uint64_t mask,
  5241. const char *verbose_prefix)
  5242. {
  5243. CPUX86State *env = &cpu->env;
  5244. FeatureWordInfo *f = &feature_word_info[w];
  5245. int i;
  5246. if (!cpu->force_features) {
  5247. env->features[w] &= ~mask;
  5248. }
  5249. cpu->filtered_features[w] |= mask;
  5250. if (!verbose_prefix) {
  5251. return;
  5252. }
  5253. for (i = 0; i < 64; ++i) {
  5254. if ((1ULL << i) & mask) {
  5255. g_autofree char *feat_word_str = feature_word_description(f, i);
  5256. warn_report("%s: %s%s%s [bit %d]",
  5257. verbose_prefix,
  5258. feat_word_str,
  5259. f->feat_names[i] ? "." : "",
  5260. f->feat_names[i] ? f->feat_names[i] : "", i);
  5261. }
  5262. }
  5263. }
  5264. static void x86_cpuid_version_get_family(Object *obj, Visitor *v,
  5265. const char *name, void *opaque,
  5266. Error **errp)
  5267. {
  5268. X86CPU *cpu = X86_CPU(obj);
  5269. CPUX86State *env = &cpu->env;
  5270. int64_t value;
  5271. value = (env->cpuid_version >> 8) & 0xf;
  5272. if (value == 0xf) {
  5273. value += (env->cpuid_version >> 20) & 0xff;
  5274. }
  5275. visit_type_int(v, name, &value, errp);
  5276. }
  5277. static void x86_cpuid_version_set_family(Object *obj, Visitor *v,
  5278. const char *name, void *opaque,
  5279. Error **errp)
  5280. {
  5281. X86CPU *cpu = X86_CPU(obj);
  5282. CPUX86State *env = &cpu->env;
  5283. const int64_t min = 0;
  5284. const int64_t max = 0xff + 0xf;
  5285. int64_t value;
  5286. if (!visit_type_int(v, name, &value, errp)) {
  5287. return;
  5288. }
  5289. if (value < min || value > max) {
  5290. error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
  5291. name ? name : "null", value, min, max);
  5292. return;
  5293. }
  5294. env->cpuid_version &= ~0xff00f00;
  5295. if (value > 0x0f) {
  5296. env->cpuid_version |= 0xf00 | ((value - 0x0f) << 20);
  5297. } else {
  5298. env->cpuid_version |= value << 8;
  5299. }
  5300. }
  5301. static void x86_cpuid_version_get_model(Object *obj, Visitor *v,
  5302. const char *name, void *opaque,
  5303. Error **errp)
  5304. {
  5305. X86CPU *cpu = X86_CPU(obj);
  5306. CPUX86State *env = &cpu->env;
  5307. int64_t value;
  5308. value = (env->cpuid_version >> 4) & 0xf;
  5309. value |= ((env->cpuid_version >> 16) & 0xf) << 4;
  5310. visit_type_int(v, name, &value, errp);
  5311. }
  5312. static void x86_cpuid_version_set_model(Object *obj, Visitor *v,
  5313. const char *name, void *opaque,
  5314. Error **errp)
  5315. {
  5316. X86CPU *cpu = X86_CPU(obj);
  5317. CPUX86State *env = &cpu->env;
  5318. const int64_t min = 0;
  5319. const int64_t max = 0xff;
  5320. int64_t value;
  5321. if (!visit_type_int(v, name, &value, errp)) {
  5322. return;
  5323. }
  5324. if (value < min || value > max) {
  5325. error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
  5326. name ? name : "null", value, min, max);
  5327. return;
  5328. }
  5329. env->cpuid_version &= ~0xf00f0;
  5330. env->cpuid_version |= ((value & 0xf) << 4) | ((value >> 4) << 16);
  5331. }
  5332. static void x86_cpuid_version_get_stepping(Object *obj, Visitor *v,
  5333. const char *name, void *opaque,
  5334. Error **errp)
  5335. {
  5336. X86CPU *cpu = X86_CPU(obj);
  5337. CPUX86State *env = &cpu->env;
  5338. int64_t value;
  5339. value = env->cpuid_version & 0xf;
  5340. visit_type_int(v, name, &value, errp);
  5341. }
  5342. static void x86_cpuid_version_set_stepping(Object *obj, Visitor *v,
  5343. const char *name, void *opaque,
  5344. Error **errp)
  5345. {
  5346. X86CPU *cpu = X86_CPU(obj);
  5347. CPUX86State *env = &cpu->env;
  5348. const int64_t min = 0;
  5349. const int64_t max = 0xf;
  5350. int64_t value;
  5351. if (!visit_type_int(v, name, &value, errp)) {
  5352. return;
  5353. }
  5354. if (value < min || value > max) {
  5355. error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
  5356. name ? name : "null", value, min, max);
  5357. return;
  5358. }
  5359. env->cpuid_version &= ~0xf;
  5360. env->cpuid_version |= value & 0xf;
  5361. }
  5362. static char *x86_cpuid_get_vendor(Object *obj, Error **errp)
  5363. {
  5364. X86CPU *cpu = X86_CPU(obj);
  5365. CPUX86State *env = &cpu->env;
  5366. char *value;
  5367. value = g_malloc(CPUID_VENDOR_SZ + 1);
  5368. x86_cpu_vendor_words2str(value, env->cpuid_vendor1, env->cpuid_vendor2,
  5369. env->cpuid_vendor3);
  5370. return value;
  5371. }
  5372. static void x86_cpuid_set_vendor(Object *obj, const char *value,
  5373. Error **errp)
  5374. {
  5375. X86CPU *cpu = X86_CPU(obj);
  5376. CPUX86State *env = &cpu->env;
  5377. int i;
  5378. if (strlen(value) != CPUID_VENDOR_SZ) {
  5379. error_setg(errp, "value of property 'vendor' must consist of"
  5380. " exactly " stringify(CPUID_VENDOR_SZ) " characters");
  5381. return;
  5382. }
  5383. env->cpuid_vendor1 = 0;
  5384. env->cpuid_vendor2 = 0;
  5385. env->cpuid_vendor3 = 0;
  5386. for (i = 0; i < 4; i++) {
  5387. env->cpuid_vendor1 |= ((uint8_t)value[i ]) << (8 * i);
  5388. env->cpuid_vendor2 |= ((uint8_t)value[i + 4]) << (8 * i);
  5389. env->cpuid_vendor3 |= ((uint8_t)value[i + 8]) << (8 * i);
  5390. }
  5391. }
  5392. static char *x86_cpuid_get_model_id(Object *obj, Error **errp)
  5393. {
  5394. X86CPU *cpu = X86_CPU(obj);
  5395. CPUX86State *env = &cpu->env;
  5396. char *value;
  5397. int i;
  5398. value = g_malloc(48 + 1);
  5399. for (i = 0; i < 48; i++) {
  5400. value[i] = env->cpuid_model[i >> 2] >> (8 * (i & 3));
  5401. }
  5402. value[48] = '\0';
  5403. return value;
  5404. }
  5405. static void x86_cpuid_set_model_id(Object *obj, const char *model_id,
  5406. Error **errp)
  5407. {
  5408. X86CPU *cpu = X86_CPU(obj);
  5409. CPUX86State *env = &cpu->env;
  5410. int c, len, i;
  5411. if (model_id == NULL) {
  5412. model_id = "";
  5413. }
  5414. len = strlen(model_id);
  5415. memset(env->cpuid_model, 0, 48);
  5416. for (i = 0; i < 48; i++) {
  5417. if (i >= len) {
  5418. c = '\0';
  5419. } else {
  5420. c = (uint8_t)model_id[i];
  5421. }
  5422. env->cpuid_model[i >> 2] |= c << (8 * (i & 3));
  5423. }
  5424. }
  5425. static void x86_cpuid_get_tsc_freq(Object *obj, Visitor *v, const char *name,
  5426. void *opaque, Error **errp)
  5427. {
  5428. X86CPU *cpu = X86_CPU(obj);
  5429. int64_t value;
  5430. value = cpu->env.tsc_khz * 1000;
  5431. visit_type_int(v, name, &value, errp);
  5432. }
  5433. static void x86_cpuid_set_tsc_freq(Object *obj, Visitor *v, const char *name,
  5434. void *opaque, Error **errp)
  5435. {
  5436. X86CPU *cpu = X86_CPU(obj);
  5437. const int64_t min = 0;
  5438. const int64_t max = INT64_MAX;
  5439. int64_t value;
  5440. if (!visit_type_int(v, name, &value, errp)) {
  5441. return;
  5442. }
  5443. if (value < min || value > max) {
  5444. error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
  5445. name ? name : "null", value, min, max);
  5446. return;
  5447. }
  5448. cpu->env.tsc_khz = cpu->env.user_tsc_khz = value / 1000;
  5449. }
  5450. /* Generic getter for "feature-words" and "filtered-features" properties */
  5451. static void x86_cpu_get_feature_words(Object *obj, Visitor *v,
  5452. const char *name, void *opaque,
  5453. Error **errp)
  5454. {
  5455. uint64_t *array = (uint64_t *)opaque;
  5456. FeatureWord w;
  5457. X86CPUFeatureWordInfo word_infos[FEATURE_WORDS] = { };
  5458. X86CPUFeatureWordInfoList list_entries[FEATURE_WORDS] = { };
  5459. X86CPUFeatureWordInfoList *list = NULL;
  5460. for (w = 0; w < FEATURE_WORDS; w++) {
  5461. FeatureWordInfo *wi = &feature_word_info[w];
  5462. /*
  5463. * We didn't have MSR features when "feature-words" was
  5464. * introduced. Therefore skipped other type entries.
  5465. */
  5466. if (wi->type != CPUID_FEATURE_WORD) {
  5467. continue;
  5468. }
  5469. X86CPUFeatureWordInfo *qwi = &word_infos[w];
  5470. qwi->cpuid_input_eax = wi->cpuid.eax;
  5471. qwi->has_cpuid_input_ecx = wi->cpuid.needs_ecx;
  5472. qwi->cpuid_input_ecx = wi->cpuid.ecx;
  5473. qwi->cpuid_register = x86_reg_info_32[wi->cpuid.reg].qapi_enum;
  5474. qwi->features = array[w];
  5475. /* List will be in reverse order, but order shouldn't matter */
  5476. list_entries[w].next = list;
  5477. list_entries[w].value = &word_infos[w];
  5478. list = &list_entries[w];
  5479. }
  5480. visit_type_X86CPUFeatureWordInfoList(v, "feature-words", &list, errp);
  5481. }
  5482. /* Convert all '_' in a feature string option name to '-', to make feature
  5483. * name conform to QOM property naming rule, which uses '-' instead of '_'.
  5484. */
  5485. static inline void feat2prop(char *s)
  5486. {
  5487. while ((s = strchr(s, '_'))) {
  5488. *s = '-';
  5489. }
  5490. }
  5491. /* Return the feature property name for a feature flag bit */
  5492. static const char *x86_cpu_feature_name(FeatureWord w, int bitnr)
  5493. {
  5494. const char *name;
  5495. /* XSAVE components are automatically enabled by other features,
  5496. * so return the original feature name instead
  5497. */
  5498. if (w == FEAT_XSAVE_XCR0_LO || w == FEAT_XSAVE_XCR0_HI) {
  5499. int comp = (w == FEAT_XSAVE_XCR0_HI) ? bitnr + 32 : bitnr;
  5500. if (comp < ARRAY_SIZE(x86_ext_save_areas) &&
  5501. x86_ext_save_areas[comp].bits) {
  5502. w = x86_ext_save_areas[comp].feature;
  5503. bitnr = ctz32(x86_ext_save_areas[comp].bits);
  5504. }
  5505. }
  5506. assert(bitnr < 64);
  5507. assert(w < FEATURE_WORDS);
  5508. name = feature_word_info[w].feat_names[bitnr];
  5509. assert(bitnr < 32 || !(name && feature_word_info[w].type == CPUID_FEATURE_WORD));
  5510. return name;
  5511. }
  5512. /* Compatibility hack to maintain legacy +-feat semantic,
  5513. * where +-feat overwrites any feature set by
  5514. * feat=on|feat even if the later is parsed after +-feat
  5515. * (i.e. "-x2apic,x2apic=on" will result in x2apic disabled)
  5516. */
  5517. static GList *plus_features, *minus_features;
  5518. static gint compare_string(gconstpointer a, gconstpointer b)
  5519. {
  5520. return g_strcmp0(a, b);
  5521. }
  5522. /* Parse "+feature,-feature,feature=foo" CPU feature string
  5523. */
  5524. static void x86_cpu_parse_featurestr(const char *typename, char *features,
  5525. Error **errp)
  5526. {
  5527. char *featurestr; /* Single 'key=value" string being parsed */
  5528. static bool cpu_globals_initialized;
  5529. bool ambiguous = false;
  5530. if (cpu_globals_initialized) {
  5531. return;
  5532. }
  5533. cpu_globals_initialized = true;
  5534. if (!features) {
  5535. return;
  5536. }
  5537. for (featurestr = strtok(features, ",");
  5538. featurestr;
  5539. featurestr = strtok(NULL, ",")) {
  5540. const char *name;
  5541. const char *val = NULL;
  5542. char *eq = NULL;
  5543. char num[32];
  5544. GlobalProperty *prop;
  5545. /* Compatibility syntax: */
  5546. if (featurestr[0] == '+') {
  5547. plus_features = g_list_append(plus_features,
  5548. g_strdup(featurestr + 1));
  5549. continue;
  5550. } else if (featurestr[0] == '-') {
  5551. minus_features = g_list_append(minus_features,
  5552. g_strdup(featurestr + 1));
  5553. continue;
  5554. }
  5555. eq = strchr(featurestr, '=');
  5556. if (eq) {
  5557. *eq++ = 0;
  5558. val = eq;
  5559. } else {
  5560. val = "on";
  5561. }
  5562. feat2prop(featurestr);
  5563. name = featurestr;
  5564. if (g_list_find_custom(plus_features, name, compare_string)) {
  5565. warn_report("Ambiguous CPU model string. "
  5566. "Don't mix both \"+%s\" and \"%s=%s\"",
  5567. name, name, val);
  5568. ambiguous = true;
  5569. }
  5570. if (g_list_find_custom(minus_features, name, compare_string)) {
  5571. warn_report("Ambiguous CPU model string. "
  5572. "Don't mix both \"-%s\" and \"%s=%s\"",
  5573. name, name, val);
  5574. ambiguous = true;
  5575. }
  5576. /* Special case: */
  5577. if (!strcmp(name, "tsc-freq")) {
  5578. int ret;
  5579. uint64_t tsc_freq;
  5580. ret = qemu_strtosz_metric(val, NULL, &tsc_freq);
  5581. if (ret < 0 || tsc_freq > INT64_MAX) {
  5582. error_setg(errp, "bad numerical value %s", val);
  5583. return;
  5584. }
  5585. snprintf(num, sizeof(num), "%" PRId64, tsc_freq);
  5586. val = num;
  5587. name = "tsc-frequency";
  5588. }
  5589. prop = g_new0(typeof(*prop), 1);
  5590. prop->driver = typename;
  5591. prop->property = g_strdup(name);
  5592. prop->value = g_strdup(val);
  5593. qdev_prop_register_global(prop);
  5594. }
  5595. if (ambiguous) {
  5596. warn_report("Compatibility of ambiguous CPU model "
  5597. "strings won't be kept on future QEMU versions");
  5598. }
  5599. }
  5600. static void x86_cpu_filter_features(X86CPU *cpu, bool verbose);
  5601. /* Build a list with the name of all features on a feature word array */
  5602. static void x86_cpu_list_feature_names(FeatureWordArray features,
  5603. strList **list)
  5604. {
  5605. strList **tail = list;
  5606. FeatureWord w;
  5607. for (w = 0; w < FEATURE_WORDS; w++) {
  5608. uint64_t filtered = features[w];
  5609. int i;
  5610. for (i = 0; i < 64; i++) {
  5611. if (filtered & (1ULL << i)) {
  5612. QAPI_LIST_APPEND(tail, g_strdup(x86_cpu_feature_name(w, i)));
  5613. }
  5614. }
  5615. }
  5616. }
  5617. static void x86_cpu_get_unavailable_features(Object *obj, Visitor *v,
  5618. const char *name, void *opaque,
  5619. Error **errp)
  5620. {
  5621. X86CPU *xc = X86_CPU(obj);
  5622. strList *result = NULL;
  5623. x86_cpu_list_feature_names(xc->filtered_features, &result);
  5624. visit_type_strList(v, "unavailable-features", &result, errp);
  5625. }
  5626. /* Print all cpuid feature names in featureset
  5627. */
  5628. static void listflags(GList *features)
  5629. {
  5630. size_t len = 0;
  5631. GList *tmp;
  5632. for (tmp = features; tmp; tmp = tmp->next) {
  5633. const char *name = tmp->data;
  5634. if ((len + strlen(name) + 1) >= 75) {
  5635. qemu_printf("\n");
  5636. len = 0;
  5637. }
  5638. qemu_printf("%s%s", len == 0 ? " " : " ", name);
  5639. len += strlen(name) + 1;
  5640. }
  5641. qemu_printf("\n");
  5642. }
  5643. /* Sort alphabetically by type name, respecting X86CPUClass::ordering. */
  5644. static gint x86_cpu_list_compare(gconstpointer a, gconstpointer b)
  5645. {
  5646. ObjectClass *class_a = (ObjectClass *)a;
  5647. ObjectClass *class_b = (ObjectClass *)b;
  5648. X86CPUClass *cc_a = X86_CPU_CLASS(class_a);
  5649. X86CPUClass *cc_b = X86_CPU_CLASS(class_b);
  5650. int ret;
  5651. if (cc_a->ordering != cc_b->ordering) {
  5652. ret = cc_a->ordering - cc_b->ordering;
  5653. } else {
  5654. g_autofree char *name_a = x86_cpu_class_get_model_name(cc_a);
  5655. g_autofree char *name_b = x86_cpu_class_get_model_name(cc_b);
  5656. ret = strcmp(name_a, name_b);
  5657. }
  5658. return ret;
  5659. }
  5660. static GSList *get_sorted_cpu_model_list(void)
  5661. {
  5662. GSList *list = object_class_get_list(TYPE_X86_CPU, false);
  5663. list = g_slist_sort(list, x86_cpu_list_compare);
  5664. return list;
  5665. }
  5666. static char *x86_cpu_class_get_model_id(X86CPUClass *xc)
  5667. {
  5668. Object *obj = object_new_with_class(OBJECT_CLASS(xc));
  5669. char *r = object_property_get_str(obj, "model-id", &error_abort);
  5670. object_unref(obj);
  5671. return r;
  5672. }
  5673. static char *x86_cpu_class_get_alias_of(X86CPUClass *cc)
  5674. {
  5675. X86CPUVersion version;
  5676. if (!cc->model || !cc->model->is_alias) {
  5677. return NULL;
  5678. }
  5679. version = x86_cpu_model_resolve_version(cc->model);
  5680. if (version <= 0) {
  5681. return NULL;
  5682. }
  5683. return x86_cpu_versioned_model_name(cc->model->cpudef, version);
  5684. }
  5685. static void x86_cpu_list_entry(gpointer data, gpointer user_data)
  5686. {
  5687. ObjectClass *oc = data;
  5688. X86CPUClass *cc = X86_CPU_CLASS(oc);
  5689. g_autofree char *name = x86_cpu_class_get_model_name(cc);
  5690. g_autofree char *desc = g_strdup(cc->model_description);
  5691. g_autofree char *alias_of = x86_cpu_class_get_alias_of(cc);
  5692. g_autofree char *model_id = x86_cpu_class_get_model_id(cc);
  5693. if (!desc && alias_of) {
  5694. if (cc->model && cc->model->version == CPU_VERSION_AUTO) {
  5695. desc = g_strdup("(alias configured by machine type)");
  5696. } else {
  5697. desc = g_strdup_printf("(alias of %s)", alias_of);
  5698. }
  5699. }
  5700. if (!desc && cc->model && cc->model->note) {
  5701. desc = g_strdup_printf("%s [%s]", model_id, cc->model->note);
  5702. }
  5703. if (!desc) {
  5704. desc = g_strdup_printf("%s", model_id);
  5705. }
  5706. if (cc->model && cc->model->cpudef->deprecation_note) {
  5707. g_autofree char *olddesc = desc;
  5708. desc = g_strdup_printf("%s (deprecated)", olddesc);
  5709. }
  5710. qemu_printf(" %-20s %s\n", name, desc);
  5711. }
  5712. /* list available CPU models and flags */
  5713. void x86_cpu_list(void)
  5714. {
  5715. int i, j;
  5716. GSList *list;
  5717. GList *names = NULL;
  5718. qemu_printf("Available CPUs:\n");
  5719. list = get_sorted_cpu_model_list();
  5720. g_slist_foreach(list, x86_cpu_list_entry, NULL);
  5721. g_slist_free(list);
  5722. names = NULL;
  5723. for (i = 0; i < ARRAY_SIZE(feature_word_info); i++) {
  5724. FeatureWordInfo *fw = &feature_word_info[i];
  5725. for (j = 0; j < 64; j++) {
  5726. if (fw->feat_names[j]) {
  5727. names = g_list_append(names, (gpointer)fw->feat_names[j]);
  5728. }
  5729. }
  5730. }
  5731. names = g_list_sort(names, (GCompareFunc)strcmp);
  5732. qemu_printf("\nRecognized CPUID flags:\n");
  5733. listflags(names);
  5734. qemu_printf("\n");
  5735. g_list_free(names);
  5736. }
  5737. #ifndef CONFIG_USER_ONLY
  5738. /* Check for missing features that may prevent the CPU class from
  5739. * running using the current machine and accelerator.
  5740. */
  5741. static void x86_cpu_class_check_missing_features(X86CPUClass *xcc,
  5742. strList **list)
  5743. {
  5744. strList **tail = list;
  5745. X86CPU *xc;
  5746. Error *err = NULL;
  5747. if (xcc->host_cpuid_required && !accel_uses_host_cpuid()) {
  5748. QAPI_LIST_APPEND(tail, g_strdup("kvm"));
  5749. return;
  5750. }
  5751. xc = X86_CPU(object_new_with_class(OBJECT_CLASS(xcc)));
  5752. x86_cpu_expand_features(xc, &err);
  5753. if (err) {
  5754. /* Errors at x86_cpu_expand_features should never happen,
  5755. * but in case it does, just report the model as not
  5756. * runnable at all using the "type" property.
  5757. */
  5758. QAPI_LIST_APPEND(tail, g_strdup("type"));
  5759. error_free(err);
  5760. }
  5761. x86_cpu_filter_features(xc, false);
  5762. x86_cpu_list_feature_names(xc->filtered_features, tail);
  5763. object_unref(OBJECT(xc));
  5764. }
  5765. static void x86_cpu_definition_entry(gpointer data, gpointer user_data)
  5766. {
  5767. ObjectClass *oc = data;
  5768. X86CPUClass *cc = X86_CPU_CLASS(oc);
  5769. CpuDefinitionInfoList **cpu_list = user_data;
  5770. CpuDefinitionInfo *info;
  5771. info = g_malloc0(sizeof(*info));
  5772. info->name = x86_cpu_class_get_model_name(cc);
  5773. x86_cpu_class_check_missing_features(cc, &info->unavailable_features);
  5774. info->has_unavailable_features = true;
  5775. info->q_typename = g_strdup(object_class_get_name(oc));
  5776. info->migration_safe = cc->migration_safe;
  5777. info->has_migration_safe = true;
  5778. info->q_static = cc->static_model;
  5779. if (cc->model && cc->model->cpudef->deprecation_note) {
  5780. info->deprecated = true;
  5781. } else {
  5782. info->deprecated = false;
  5783. }
  5784. /*
  5785. * Old machine types won't report aliases, so that alias translation
  5786. * doesn't break compatibility with previous QEMU versions.
  5787. */
  5788. if (default_cpu_version != CPU_VERSION_LEGACY) {
  5789. info->alias_of = x86_cpu_class_get_alias_of(cc);
  5790. }
  5791. QAPI_LIST_PREPEND(*cpu_list, info);
  5792. }
  5793. CpuDefinitionInfoList *qmp_query_cpu_definitions(Error **errp)
  5794. {
  5795. CpuDefinitionInfoList *cpu_list = NULL;
  5796. GSList *list = get_sorted_cpu_model_list();
  5797. g_slist_foreach(list, x86_cpu_definition_entry, &cpu_list);
  5798. g_slist_free(list);
  5799. return cpu_list;
  5800. }
  5801. #endif /* !CONFIG_USER_ONLY */
  5802. uint64_t x86_cpu_get_supported_feature_word(X86CPU *cpu, FeatureWord w)
  5803. {
  5804. FeatureWordInfo *wi = &feature_word_info[w];
  5805. uint64_t r = 0;
  5806. uint64_t unavail = 0;
  5807. if (kvm_enabled()) {
  5808. switch (wi->type) {
  5809. case CPUID_FEATURE_WORD:
  5810. r = kvm_arch_get_supported_cpuid(kvm_state, wi->cpuid.eax,
  5811. wi->cpuid.ecx,
  5812. wi->cpuid.reg);
  5813. break;
  5814. case MSR_FEATURE_WORD:
  5815. r = kvm_arch_get_supported_msr_feature(kvm_state,
  5816. wi->msr.index);
  5817. break;
  5818. }
  5819. } else if (hvf_enabled()) {
  5820. if (wi->type != CPUID_FEATURE_WORD) {
  5821. return 0;
  5822. }
  5823. r = hvf_get_supported_cpuid(wi->cpuid.eax,
  5824. wi->cpuid.ecx,
  5825. wi->cpuid.reg);
  5826. } else if (tcg_enabled()) {
  5827. r = wi->tcg_features;
  5828. } else {
  5829. return ~0;
  5830. }
  5831. switch (w) {
  5832. #ifndef TARGET_X86_64
  5833. case FEAT_8000_0001_EDX:
  5834. /*
  5835. * 32-bit TCG can emulate 64-bit compatibility mode. If there is no
  5836. * way for userspace to get out of its 32-bit jail, we can leave
  5837. * the LM bit set.
  5838. */
  5839. unavail = tcg_enabled()
  5840. ? CPUID_EXT2_LM & ~CPUID_EXT2_KERNEL_FEATURES
  5841. : CPUID_EXT2_LM;
  5842. break;
  5843. #endif
  5844. case FEAT_8000_0007_EBX:
  5845. if (cpu && !IS_AMD_CPU(&cpu->env)) {
  5846. /* Disable AMD machine check architecture for Intel CPU. */
  5847. unavail = ~0;
  5848. }
  5849. break;
  5850. case FEAT_7_0_EBX:
  5851. #ifndef CONFIG_USER_ONLY
  5852. if (!check_sgx_support()) {
  5853. unavail = CPUID_7_0_EBX_SGX;
  5854. }
  5855. #endif
  5856. break;
  5857. case FEAT_7_0_ECX:
  5858. #ifndef CONFIG_USER_ONLY
  5859. if (!check_sgx_support()) {
  5860. unavail = CPUID_7_0_ECX_SGX_LC;
  5861. }
  5862. #endif
  5863. break;
  5864. default:
  5865. break;
  5866. }
  5867. r &= ~unavail;
  5868. if (cpu && cpu->migratable) {
  5869. r &= x86_cpu_get_migratable_flags(w);
  5870. }
  5871. return r;
  5872. }
  5873. static void x86_cpu_get_supported_cpuid(uint32_t func, uint32_t index,
  5874. uint32_t *eax, uint32_t *ebx,
  5875. uint32_t *ecx, uint32_t *edx)
  5876. {
  5877. if (kvm_enabled()) {
  5878. *eax = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_EAX);
  5879. *ebx = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_EBX);
  5880. *ecx = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_ECX);
  5881. *edx = kvm_arch_get_supported_cpuid(kvm_state, func, index, R_EDX);
  5882. } else if (hvf_enabled()) {
  5883. *eax = hvf_get_supported_cpuid(func, index, R_EAX);
  5884. *ebx = hvf_get_supported_cpuid(func, index, R_EBX);
  5885. *ecx = hvf_get_supported_cpuid(func, index, R_ECX);
  5886. *edx = hvf_get_supported_cpuid(func, index, R_EDX);
  5887. } else {
  5888. *eax = 0;
  5889. *ebx = 0;
  5890. *ecx = 0;
  5891. *edx = 0;
  5892. }
  5893. }
  5894. static void x86_cpu_get_cache_cpuid(uint32_t func, uint32_t index,
  5895. uint32_t *eax, uint32_t *ebx,
  5896. uint32_t *ecx, uint32_t *edx)
  5897. {
  5898. uint32_t level, unused;
  5899. /* Only return valid host leaves. */
  5900. switch (func) {
  5901. case 2:
  5902. case 4:
  5903. host_cpuid(0, 0, &level, &unused, &unused, &unused);
  5904. break;
  5905. case 0x80000005:
  5906. case 0x80000006:
  5907. case 0x8000001d:
  5908. host_cpuid(0x80000000, 0, &level, &unused, &unused, &unused);
  5909. break;
  5910. default:
  5911. return;
  5912. }
  5913. if (func > level) {
  5914. *eax = 0;
  5915. *ebx = 0;
  5916. *ecx = 0;
  5917. *edx = 0;
  5918. } else {
  5919. host_cpuid(func, index, eax, ebx, ecx, edx);
  5920. }
  5921. }
  5922. /*
  5923. * Only for builtin_x86_defs models initialized with x86_register_cpudef_types.
  5924. */
  5925. void x86_cpu_apply_props(X86CPU *cpu, PropValue *props)
  5926. {
  5927. PropValue *pv;
  5928. for (pv = props; pv->prop; pv++) {
  5929. if (!pv->value) {
  5930. continue;
  5931. }
  5932. object_property_parse(OBJECT(cpu), pv->prop, pv->value,
  5933. &error_abort);
  5934. }
  5935. }
  5936. /*
  5937. * Apply properties for the CPU model version specified in model.
  5938. * Only for builtin_x86_defs models initialized with x86_register_cpudef_types.
  5939. */
  5940. static void x86_cpu_apply_version_props(X86CPU *cpu, X86CPUModel *model)
  5941. {
  5942. const X86CPUVersionDefinition *vdef;
  5943. X86CPUVersion version = x86_cpu_model_resolve_version(model);
  5944. if (version == CPU_VERSION_LEGACY) {
  5945. return;
  5946. }
  5947. for (vdef = x86_cpu_def_get_versions(model->cpudef); vdef->version; vdef++) {
  5948. PropValue *p;
  5949. for (p = vdef->props; p && p->prop; p++) {
  5950. object_property_parse(OBJECT(cpu), p->prop, p->value,
  5951. &error_abort);
  5952. }
  5953. if (vdef->version == version) {
  5954. break;
  5955. }
  5956. }
  5957. /*
  5958. * If we reached the end of the list, version number was invalid
  5959. */
  5960. assert(vdef->version == version);
  5961. }
  5962. static const CPUCaches *x86_cpu_get_versioned_cache_info(X86CPU *cpu,
  5963. X86CPUModel *model)
  5964. {
  5965. const X86CPUVersionDefinition *vdef;
  5966. X86CPUVersion version = x86_cpu_model_resolve_version(model);
  5967. const CPUCaches *cache_info = model->cpudef->cache_info;
  5968. if (version == CPU_VERSION_LEGACY) {
  5969. return cache_info;
  5970. }
  5971. for (vdef = x86_cpu_def_get_versions(model->cpudef); vdef->version; vdef++) {
  5972. if (vdef->cache_info) {
  5973. cache_info = vdef->cache_info;
  5974. }
  5975. if (vdef->version == version) {
  5976. break;
  5977. }
  5978. }
  5979. assert(vdef->version == version);
  5980. return cache_info;
  5981. }
  5982. /*
  5983. * Load data from X86CPUDefinition into a X86CPU object.
  5984. * Only for builtin_x86_defs models initialized with x86_register_cpudef_types.
  5985. */
  5986. static void x86_cpu_load_model(X86CPU *cpu, X86CPUModel *model)
  5987. {
  5988. const X86CPUDefinition *def = model->cpudef;
  5989. CPUX86State *env = &cpu->env;
  5990. FeatureWord w;
  5991. /*NOTE: any property set by this function should be returned by
  5992. * x86_cpu_static_props(), so static expansion of
  5993. * query-cpu-model-expansion is always complete.
  5994. */
  5995. /* CPU models only set _minimum_ values for level/xlevel: */
  5996. object_property_set_uint(OBJECT(cpu), "min-level", def->level,
  5997. &error_abort);
  5998. object_property_set_uint(OBJECT(cpu), "min-xlevel", def->xlevel,
  5999. &error_abort);
  6000. object_property_set_int(OBJECT(cpu), "family", def->family, &error_abort);
  6001. object_property_set_int(OBJECT(cpu), "model", def->model, &error_abort);
  6002. object_property_set_int(OBJECT(cpu), "stepping", def->stepping,
  6003. &error_abort);
  6004. object_property_set_str(OBJECT(cpu), "model-id", def->model_id,
  6005. &error_abort);
  6006. for (w = 0; w < FEATURE_WORDS; w++) {
  6007. env->features[w] = def->features[w];
  6008. }
  6009. /* legacy-cache defaults to 'off' if CPU model provides cache info */
  6010. cpu->legacy_cache = !x86_cpu_get_versioned_cache_info(cpu, model);
  6011. env->features[FEAT_1_ECX] |= CPUID_EXT_HYPERVISOR;
  6012. /* sysenter isn't supported in compatibility mode on AMD,
  6013. * syscall isn't supported in compatibility mode on Intel.
  6014. * Normally we advertise the actual CPU vendor, but you can
  6015. * override this using the 'vendor' property if you want to use
  6016. * KVM's sysenter/syscall emulation in compatibility mode and
  6017. * when doing cross vendor migration
  6018. */
  6019. /*
  6020. * vendor property is set here but then overloaded with the
  6021. * host cpu vendor for KVM and HVF.
  6022. */
  6023. object_property_set_str(OBJECT(cpu), "vendor", def->vendor, &error_abort);
  6024. x86_cpu_apply_version_props(cpu, model);
  6025. /*
  6026. * Properties in versioned CPU model are not user specified features.
  6027. * We can simply clear env->user_features here since it will be filled later
  6028. * in x86_cpu_expand_features() based on plus_features and minus_features.
  6029. */
  6030. memset(&env->user_features, 0, sizeof(env->user_features));
  6031. }
  6032. static const gchar *x86_gdb_arch_name(CPUState *cs)
  6033. {
  6034. #ifdef TARGET_X86_64
  6035. return "i386:x86-64";
  6036. #else
  6037. return "i386";
  6038. #endif
  6039. }
  6040. static void x86_cpu_cpudef_class_init(ObjectClass *oc, void *data)
  6041. {
  6042. X86CPUModel *model = data;
  6043. X86CPUClass *xcc = X86_CPU_CLASS(oc);
  6044. CPUClass *cc = CPU_CLASS(oc);
  6045. xcc->model = model;
  6046. xcc->migration_safe = true;
  6047. cc->deprecation_note = model->cpudef->deprecation_note;
  6048. }
  6049. static void x86_register_cpu_model_type(const char *name, X86CPUModel *model)
  6050. {
  6051. g_autofree char *typename = x86_cpu_type_name(name);
  6052. TypeInfo ti = {
  6053. .name = typename,
  6054. .parent = TYPE_X86_CPU,
  6055. .class_init = x86_cpu_cpudef_class_init,
  6056. .class_data = model,
  6057. };
  6058. type_register(&ti);
  6059. }
  6060. /*
  6061. * register builtin_x86_defs;
  6062. * "max", "base" and subclasses ("host") are not registered here.
  6063. * See x86_cpu_register_types for all model registrations.
  6064. */
  6065. static void x86_register_cpudef_types(const X86CPUDefinition *def)
  6066. {
  6067. X86CPUModel *m;
  6068. const X86CPUVersionDefinition *vdef;
  6069. /* AMD aliases are handled at runtime based on CPUID vendor, so
  6070. * they shouldn't be set on the CPU model table.
  6071. */
  6072. assert(!(def->features[FEAT_8000_0001_EDX] & CPUID_EXT2_AMD_ALIASES));
  6073. /* catch mistakes instead of silently truncating model_id when too long */
  6074. assert(def->model_id && strlen(def->model_id) <= 48);
  6075. /* Unversioned model: */
  6076. m = g_new0(X86CPUModel, 1);
  6077. m->cpudef = def;
  6078. m->version = CPU_VERSION_AUTO;
  6079. m->is_alias = true;
  6080. x86_register_cpu_model_type(def->name, m);
  6081. /* Versioned models: */
  6082. for (vdef = x86_cpu_def_get_versions(def); vdef->version; vdef++) {
  6083. g_autofree char *name =
  6084. x86_cpu_versioned_model_name(def, vdef->version);
  6085. m = g_new0(X86CPUModel, 1);
  6086. m->cpudef = def;
  6087. m->version = vdef->version;
  6088. m->note = vdef->note;
  6089. x86_register_cpu_model_type(name, m);
  6090. if (vdef->alias) {
  6091. X86CPUModel *am = g_new0(X86CPUModel, 1);
  6092. am->cpudef = def;
  6093. am->version = vdef->version;
  6094. am->is_alias = true;
  6095. x86_register_cpu_model_type(vdef->alias, am);
  6096. }
  6097. }
  6098. }
  6099. uint32_t cpu_x86_virtual_addr_width(CPUX86State *env)
  6100. {
  6101. if (env->features[FEAT_7_0_ECX] & CPUID_7_0_ECX_LA57) {
  6102. return 57; /* 57 bits virtual */
  6103. } else {
  6104. return 48; /* 48 bits virtual */
  6105. }
  6106. }
  6107. void cpu_x86_cpuid(CPUX86State *env, uint32_t index, uint32_t count,
  6108. uint32_t *eax, uint32_t *ebx,
  6109. uint32_t *ecx, uint32_t *edx)
  6110. {
  6111. X86CPU *cpu = env_archcpu(env);
  6112. CPUState *cs = env_cpu(env);
  6113. uint32_t limit;
  6114. uint32_t signature[3];
  6115. X86CPUTopoInfo topo_info;
  6116. uint32_t cores_per_pkg;
  6117. uint32_t threads_per_pkg;
  6118. topo_info.dies_per_pkg = env->nr_dies;
  6119. topo_info.modules_per_die = env->nr_modules;
  6120. topo_info.cores_per_module = cs->nr_cores / env->nr_dies / env->nr_modules;
  6121. topo_info.threads_per_core = cs->nr_threads;
  6122. cores_per_pkg = topo_info.cores_per_module * topo_info.modules_per_die *
  6123. topo_info.dies_per_pkg;
  6124. threads_per_pkg = cores_per_pkg * topo_info.threads_per_core;
  6125. /* Calculate & apply limits for different index ranges */
  6126. if (index >= 0xC0000000) {
  6127. limit = env->cpuid_xlevel2;
  6128. } else if (index >= 0x80000000) {
  6129. limit = env->cpuid_xlevel;
  6130. } else if (index >= 0x40000000) {
  6131. limit = 0x40000001;
  6132. } else {
  6133. limit = env->cpuid_level;
  6134. }
  6135. if (index > limit) {
  6136. /* Intel documentation states that invalid EAX input will
  6137. * return the same information as EAX=cpuid_level
  6138. * (Intel SDM Vol. 2A - Instruction Set Reference - CPUID)
  6139. */
  6140. index = env->cpuid_level;
  6141. }
  6142. switch(index) {
  6143. case 0:
  6144. *eax = env->cpuid_level;
  6145. *ebx = env->cpuid_vendor1;
  6146. *edx = env->cpuid_vendor2;
  6147. *ecx = env->cpuid_vendor3;
  6148. break;
  6149. case 1:
  6150. *eax = env->cpuid_version;
  6151. *ebx = (cpu->apic_id << 24) |
  6152. 8 << 8; /* CLFLUSH size in quad words, Linux wants it. */
  6153. *ecx = env->features[FEAT_1_ECX];
  6154. if ((*ecx & CPUID_EXT_XSAVE) && (env->cr[4] & CR4_OSXSAVE_MASK)) {
  6155. *ecx |= CPUID_EXT_OSXSAVE;
  6156. }
  6157. *edx = env->features[FEAT_1_EDX];
  6158. if (threads_per_pkg > 1) {
  6159. *ebx |= threads_per_pkg << 16;
  6160. *edx |= CPUID_HT;
  6161. }
  6162. if (!cpu->enable_pmu) {
  6163. *ecx &= ~CPUID_EXT_PDCM;
  6164. }
  6165. break;
  6166. case 2:
  6167. /* cache info: needed for Pentium Pro compatibility */
  6168. if (cpu->cache_info_passthrough) {
  6169. x86_cpu_get_cache_cpuid(index, 0, eax, ebx, ecx, edx);
  6170. break;
  6171. } else if (cpu->vendor_cpuid_only && IS_AMD_CPU(env)) {
  6172. *eax = *ebx = *ecx = *edx = 0;
  6173. break;
  6174. }
  6175. *eax = 1; /* Number of CPUID[EAX=2] calls required */
  6176. *ebx = 0;
  6177. if (!cpu->enable_l3_cache) {
  6178. *ecx = 0;
  6179. } else {
  6180. *ecx = cpuid2_cache_descriptor(env->cache_info_cpuid2.l3_cache);
  6181. }
  6182. *edx = (cpuid2_cache_descriptor(env->cache_info_cpuid2.l1d_cache) << 16) |
  6183. (cpuid2_cache_descriptor(env->cache_info_cpuid2.l1i_cache) << 8) |
  6184. (cpuid2_cache_descriptor(env->cache_info_cpuid2.l2_cache));
  6185. break;
  6186. case 4:
  6187. /* cache info: needed for Core compatibility */
  6188. if (cpu->cache_info_passthrough) {
  6189. x86_cpu_get_cache_cpuid(index, count, eax, ebx, ecx, edx);
  6190. /*
  6191. * QEMU has its own number of cores/logical cpus,
  6192. * set 24..14, 31..26 bit to configured values
  6193. */
  6194. if (*eax & 31) {
  6195. int host_vcpus_per_cache = 1 + ((*eax & 0x3FFC000) >> 14);
  6196. *eax &= ~0xFC000000;
  6197. *eax |= max_core_ids_in_package(&topo_info) << 26;
  6198. if (host_vcpus_per_cache > threads_per_pkg) {
  6199. *eax &= ~0x3FFC000;
  6200. /* Share the cache at package level. */
  6201. *eax |= max_thread_ids_for_cache(&topo_info,
  6202. CPU_TOPO_LEVEL_PACKAGE) << 14;
  6203. }
  6204. }
  6205. } else if (cpu->vendor_cpuid_only && IS_AMD_CPU(env)) {
  6206. *eax = *ebx = *ecx = *edx = 0;
  6207. } else {
  6208. *eax = 0;
  6209. switch (count) {
  6210. case 0: /* L1 dcache info */
  6211. encode_cache_cpuid4(env->cache_info_cpuid4.l1d_cache,
  6212. &topo_info,
  6213. eax, ebx, ecx, edx);
  6214. if (!cpu->l1_cache_per_core) {
  6215. *eax &= ~MAKE_64BIT_MASK(14, 12);
  6216. }
  6217. break;
  6218. case 1: /* L1 icache info */
  6219. encode_cache_cpuid4(env->cache_info_cpuid4.l1i_cache,
  6220. &topo_info,
  6221. eax, ebx, ecx, edx);
  6222. if (!cpu->l1_cache_per_core) {
  6223. *eax &= ~MAKE_64BIT_MASK(14, 12);
  6224. }
  6225. break;
  6226. case 2: /* L2 cache info */
  6227. encode_cache_cpuid4(env->cache_info_cpuid4.l2_cache,
  6228. &topo_info,
  6229. eax, ebx, ecx, edx);
  6230. break;
  6231. case 3: /* L3 cache info */
  6232. if (cpu->enable_l3_cache) {
  6233. encode_cache_cpuid4(env->cache_info_cpuid4.l3_cache,
  6234. &topo_info,
  6235. eax, ebx, ecx, edx);
  6236. break;
  6237. }
  6238. /* fall through */
  6239. default: /* end of info */
  6240. *eax = *ebx = *ecx = *edx = 0;
  6241. break;
  6242. }
  6243. }
  6244. break;
  6245. case 5:
  6246. /* MONITOR/MWAIT Leaf */
  6247. *eax = cpu->mwait.eax; /* Smallest monitor-line size in bytes */
  6248. *ebx = cpu->mwait.ebx; /* Largest monitor-line size in bytes */
  6249. *ecx = cpu->mwait.ecx; /* flags */
  6250. *edx = cpu->mwait.edx; /* mwait substates */
  6251. break;
  6252. case 6:
  6253. /* Thermal and Power Leaf */
  6254. *eax = env->features[FEAT_6_EAX];
  6255. *ebx = 0;
  6256. *ecx = 0;
  6257. *edx = 0;
  6258. break;
  6259. case 7:
  6260. /* Structured Extended Feature Flags Enumeration Leaf */
  6261. if (count == 0) {
  6262. /* Maximum ECX value for sub-leaves */
  6263. *eax = env->cpuid_level_func7;
  6264. *ebx = env->features[FEAT_7_0_EBX]; /* Feature flags */
  6265. *ecx = env->features[FEAT_7_0_ECX]; /* Feature flags */
  6266. if ((*ecx & CPUID_7_0_ECX_PKU) && env->cr[4] & CR4_PKE_MASK) {
  6267. *ecx |= CPUID_7_0_ECX_OSPKE;
  6268. }
  6269. *edx = env->features[FEAT_7_0_EDX]; /* Feature flags */
  6270. } else if (count == 1) {
  6271. *eax = env->features[FEAT_7_1_EAX];
  6272. *edx = env->features[FEAT_7_1_EDX];
  6273. *ebx = 0;
  6274. *ecx = 0;
  6275. } else if (count == 2) {
  6276. *edx = env->features[FEAT_7_2_EDX];
  6277. *eax = 0;
  6278. *ebx = 0;
  6279. *ecx = 0;
  6280. } else {
  6281. *eax = 0;
  6282. *ebx = 0;
  6283. *ecx = 0;
  6284. *edx = 0;
  6285. }
  6286. break;
  6287. case 9:
  6288. /* Direct Cache Access Information Leaf */
  6289. *eax = 0; /* Bits 0-31 in DCA_CAP MSR */
  6290. *ebx = 0;
  6291. *ecx = 0;
  6292. *edx = 0;
  6293. break;
  6294. case 0xA:
  6295. /* Architectural Performance Monitoring Leaf */
  6296. if (cpu->enable_pmu) {
  6297. x86_cpu_get_supported_cpuid(0xA, count, eax, ebx, ecx, edx);
  6298. } else {
  6299. *eax = 0;
  6300. *ebx = 0;
  6301. *ecx = 0;
  6302. *edx = 0;
  6303. }
  6304. break;
  6305. case 0xB:
  6306. /* Extended Topology Enumeration Leaf */
  6307. if (!cpu->enable_cpuid_0xb) {
  6308. *eax = *ebx = *ecx = *edx = 0;
  6309. break;
  6310. }
  6311. *ecx = count & 0xff;
  6312. *edx = cpu->apic_id;
  6313. switch (count) {
  6314. case 0:
  6315. *eax = apicid_core_offset(&topo_info);
  6316. *ebx = topo_info.threads_per_core;
  6317. *ecx |= CPUID_B_ECX_TOPO_LEVEL_SMT << 8;
  6318. break;
  6319. case 1:
  6320. *eax = apicid_pkg_offset(&topo_info);
  6321. *ebx = threads_per_pkg;
  6322. *ecx |= CPUID_B_ECX_TOPO_LEVEL_CORE << 8;
  6323. break;
  6324. default:
  6325. *eax = 0;
  6326. *ebx = 0;
  6327. *ecx |= CPUID_B_ECX_TOPO_LEVEL_INVALID << 8;
  6328. }
  6329. assert(!(*eax & ~0x1f));
  6330. *ebx &= 0xffff; /* The count doesn't need to be reliable. */
  6331. break;
  6332. case 0x1C:
  6333. if (cpu->enable_pmu && (env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_ARCH_LBR)) {
  6334. x86_cpu_get_supported_cpuid(0x1C, 0, eax, ebx, ecx, edx);
  6335. *edx = 0;
  6336. }
  6337. break;
  6338. case 0x1F:
  6339. /* V2 Extended Topology Enumeration Leaf */
  6340. if (!x86_has_extended_topo(env->avail_cpu_topo)) {
  6341. *eax = *ebx = *ecx = *edx = 0;
  6342. break;
  6343. }
  6344. encode_topo_cpuid1f(env, count, &topo_info, eax, ebx, ecx, edx);
  6345. break;
  6346. case 0xD: {
  6347. /* Processor Extended State */
  6348. *eax = 0;
  6349. *ebx = 0;
  6350. *ecx = 0;
  6351. *edx = 0;
  6352. if (!(env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE)) {
  6353. break;
  6354. }
  6355. if (count == 0) {
  6356. *ecx = xsave_area_size(x86_cpu_xsave_xcr0_components(cpu), false);
  6357. *eax = env->features[FEAT_XSAVE_XCR0_LO];
  6358. *edx = env->features[FEAT_XSAVE_XCR0_HI];
  6359. /*
  6360. * The initial value of xcr0 and ebx == 0, On host without kvm
  6361. * commit 412a3c41(e.g., CentOS 6), the ebx's value always == 0
  6362. * even through guest update xcr0, this will crash some legacy guest
  6363. * (e.g., CentOS 6), So set ebx == ecx to workaround it.
  6364. */
  6365. *ebx = kvm_enabled() ? *ecx : xsave_area_size(env->xcr0, false);
  6366. } else if (count == 1) {
  6367. uint64_t xstate = x86_cpu_xsave_xcr0_components(cpu) |
  6368. x86_cpu_xsave_xss_components(cpu);
  6369. *eax = env->features[FEAT_XSAVE];
  6370. *ebx = xsave_area_size(xstate, true);
  6371. *ecx = env->features[FEAT_XSAVE_XSS_LO];
  6372. *edx = env->features[FEAT_XSAVE_XSS_HI];
  6373. if (kvm_enabled() && cpu->enable_pmu &&
  6374. (env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_ARCH_LBR) &&
  6375. (*eax & CPUID_XSAVE_XSAVES)) {
  6376. *ecx |= XSTATE_ARCH_LBR_MASK;
  6377. } else {
  6378. *ecx &= ~XSTATE_ARCH_LBR_MASK;
  6379. }
  6380. } else if (count == 0xf && cpu->enable_pmu
  6381. && (env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_ARCH_LBR)) {
  6382. x86_cpu_get_supported_cpuid(0xD, count, eax, ebx, ecx, edx);
  6383. } else if (count < ARRAY_SIZE(x86_ext_save_areas)) {
  6384. const ExtSaveArea *esa = &x86_ext_save_areas[count];
  6385. if (x86_cpu_xsave_xcr0_components(cpu) & (1ULL << count)) {
  6386. *eax = esa->size;
  6387. *ebx = esa->offset;
  6388. *ecx = esa->ecx &
  6389. (ESA_FEATURE_ALIGN64_MASK | ESA_FEATURE_XFD_MASK);
  6390. } else if (x86_cpu_xsave_xss_components(cpu) & (1ULL << count)) {
  6391. *eax = esa->size;
  6392. *ebx = 0;
  6393. *ecx = 1;
  6394. }
  6395. }
  6396. break;
  6397. }
  6398. case 0x12:
  6399. #ifndef CONFIG_USER_ONLY
  6400. if (!kvm_enabled() ||
  6401. !(env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_SGX)) {
  6402. *eax = *ebx = *ecx = *edx = 0;
  6403. break;
  6404. }
  6405. /*
  6406. * SGX sub-leafs CPUID.0x12.{0x2..N} enumerate EPC sections. Retrieve
  6407. * the EPC properties, e.g. confidentiality and integrity, from the
  6408. * host's first EPC section, i.e. assume there is one EPC section or
  6409. * that all EPC sections have the same security properties.
  6410. */
  6411. if (count > 1) {
  6412. uint64_t epc_addr, epc_size;
  6413. if (sgx_epc_get_section(count - 2, &epc_addr, &epc_size)) {
  6414. *eax = *ebx = *ecx = *edx = 0;
  6415. break;
  6416. }
  6417. host_cpuid(index, 2, eax, ebx, ecx, edx);
  6418. *eax = (uint32_t)(epc_addr & 0xfffff000) | 0x1;
  6419. *ebx = (uint32_t)(epc_addr >> 32);
  6420. *ecx = (uint32_t)(epc_size & 0xfffff000) | (*ecx & 0xf);
  6421. *edx = (uint32_t)(epc_size >> 32);
  6422. break;
  6423. }
  6424. /*
  6425. * SGX sub-leafs CPUID.0x12.{0x0,0x1} are heavily dependent on hardware
  6426. * and KVM, i.e. QEMU cannot emulate features to override what KVM
  6427. * supports. Features can be further restricted by userspace, but not
  6428. * made more permissive.
  6429. */
  6430. x86_cpu_get_supported_cpuid(0x12, count, eax, ebx, ecx, edx);
  6431. if (count == 0) {
  6432. *eax &= env->features[FEAT_SGX_12_0_EAX];
  6433. *ebx &= env->features[FEAT_SGX_12_0_EBX];
  6434. } else {
  6435. *eax &= env->features[FEAT_SGX_12_1_EAX];
  6436. *ebx &= 0; /* ebx reserve */
  6437. *ecx &= env->features[FEAT_XSAVE_XCR0_LO];
  6438. *edx &= env->features[FEAT_XSAVE_XCR0_HI];
  6439. /* FP and SSE are always allowed regardless of XSAVE/XCR0. */
  6440. *ecx |= XSTATE_FP_MASK | XSTATE_SSE_MASK;
  6441. /* Access to PROVISIONKEY requires additional credentials. */
  6442. if ((*eax & (1U << 4)) &&
  6443. !kvm_enable_sgx_provisioning(cs->kvm_state)) {
  6444. *eax &= ~(1U << 4);
  6445. }
  6446. }
  6447. #endif
  6448. break;
  6449. case 0x14: {
  6450. /* Intel Processor Trace Enumeration */
  6451. *eax = 0;
  6452. *ebx = 0;
  6453. *ecx = 0;
  6454. *edx = 0;
  6455. if (!(env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT) ||
  6456. !kvm_enabled()) {
  6457. break;
  6458. }
  6459. /*
  6460. * If these are changed, they should stay in sync with
  6461. * x86_cpu_filter_features().
  6462. */
  6463. if (count == 0) {
  6464. *eax = INTEL_PT_MAX_SUBLEAF;
  6465. *ebx = INTEL_PT_MINIMAL_EBX;
  6466. *ecx = INTEL_PT_MINIMAL_ECX;
  6467. if (env->features[FEAT_14_0_ECX] & CPUID_14_0_ECX_LIP) {
  6468. *ecx |= CPUID_14_0_ECX_LIP;
  6469. }
  6470. } else if (count == 1) {
  6471. *eax = INTEL_PT_MTC_BITMAP | INTEL_PT_ADDR_RANGES_NUM;
  6472. *ebx = INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP;
  6473. }
  6474. break;
  6475. }
  6476. case 0x1D: {
  6477. /* AMX TILE, for now hardcoded for Sapphire Rapids*/
  6478. *eax = 0;
  6479. *ebx = 0;
  6480. *ecx = 0;
  6481. *edx = 0;
  6482. if (!(env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_AMX_TILE)) {
  6483. break;
  6484. }
  6485. if (count == 0) {
  6486. /* Highest numbered palette subleaf */
  6487. *eax = INTEL_AMX_TILE_MAX_SUBLEAF;
  6488. } else if (count == 1) {
  6489. *eax = INTEL_AMX_TOTAL_TILE_BYTES |
  6490. (INTEL_AMX_BYTES_PER_TILE << 16);
  6491. *ebx = INTEL_AMX_BYTES_PER_ROW | (INTEL_AMX_TILE_MAX_NAMES << 16);
  6492. *ecx = INTEL_AMX_TILE_MAX_ROWS;
  6493. }
  6494. break;
  6495. }
  6496. case 0x1E: {
  6497. /* AMX TMUL, for now hardcoded for Sapphire Rapids */
  6498. *eax = 0;
  6499. *ebx = 0;
  6500. *ecx = 0;
  6501. *edx = 0;
  6502. if (!(env->features[FEAT_7_0_EDX] & CPUID_7_0_EDX_AMX_TILE)) {
  6503. break;
  6504. }
  6505. if (count == 0) {
  6506. /* Highest numbered palette subleaf */
  6507. *ebx = INTEL_AMX_TMUL_MAX_K | (INTEL_AMX_TMUL_MAX_N << 8);
  6508. }
  6509. break;
  6510. }
  6511. case 0x40000000:
  6512. /*
  6513. * CPUID code in kvm_arch_init_vcpu() ignores stuff
  6514. * set here, but we restrict to TCG none the less.
  6515. */
  6516. if (tcg_enabled() && cpu->expose_tcg) {
  6517. memcpy(signature, "TCGTCGTCGTCG", 12);
  6518. *eax = 0x40000001;
  6519. *ebx = signature[0];
  6520. *ecx = signature[1];
  6521. *edx = signature[2];
  6522. } else {
  6523. *eax = 0;
  6524. *ebx = 0;
  6525. *ecx = 0;
  6526. *edx = 0;
  6527. }
  6528. break;
  6529. case 0x40000001:
  6530. *eax = 0;
  6531. *ebx = 0;
  6532. *ecx = 0;
  6533. *edx = 0;
  6534. break;
  6535. case 0x80000000:
  6536. *eax = env->cpuid_xlevel;
  6537. *ebx = env->cpuid_vendor1;
  6538. *edx = env->cpuid_vendor2;
  6539. *ecx = env->cpuid_vendor3;
  6540. break;
  6541. case 0x80000001:
  6542. *eax = env->cpuid_version;
  6543. *ebx = 0;
  6544. *ecx = env->features[FEAT_8000_0001_ECX];
  6545. *edx = env->features[FEAT_8000_0001_EDX];
  6546. /* The Linux kernel checks for the CMPLegacy bit and
  6547. * discards multiple thread information if it is set.
  6548. * So don't set it here for Intel to make Linux guests happy.
  6549. */
  6550. if (threads_per_pkg > 1) {
  6551. if (env->cpuid_vendor1 != CPUID_VENDOR_INTEL_1 ||
  6552. env->cpuid_vendor2 != CPUID_VENDOR_INTEL_2 ||
  6553. env->cpuid_vendor3 != CPUID_VENDOR_INTEL_3) {
  6554. *ecx |= 1 << 1; /* CmpLegacy bit */
  6555. }
  6556. }
  6557. if (tcg_enabled() && env->cpuid_vendor1 == CPUID_VENDOR_INTEL_1 &&
  6558. !(env->hflags & HF_LMA_MASK)) {
  6559. *edx &= ~CPUID_EXT2_SYSCALL;
  6560. }
  6561. break;
  6562. case 0x80000002:
  6563. case 0x80000003:
  6564. case 0x80000004:
  6565. *eax = env->cpuid_model[(index - 0x80000002) * 4 + 0];
  6566. *ebx = env->cpuid_model[(index - 0x80000002) * 4 + 1];
  6567. *ecx = env->cpuid_model[(index - 0x80000002) * 4 + 2];
  6568. *edx = env->cpuid_model[(index - 0x80000002) * 4 + 3];
  6569. break;
  6570. case 0x80000005:
  6571. /* cache info (L1 cache) */
  6572. if (cpu->cache_info_passthrough) {
  6573. x86_cpu_get_cache_cpuid(index, 0, eax, ebx, ecx, edx);
  6574. break;
  6575. }
  6576. *eax = (L1_DTLB_2M_ASSOC << 24) | (L1_DTLB_2M_ENTRIES << 16) |
  6577. (L1_ITLB_2M_ASSOC << 8) | (L1_ITLB_2M_ENTRIES);
  6578. *ebx = (L1_DTLB_4K_ASSOC << 24) | (L1_DTLB_4K_ENTRIES << 16) |
  6579. (L1_ITLB_4K_ASSOC << 8) | (L1_ITLB_4K_ENTRIES);
  6580. *ecx = encode_cache_cpuid80000005(env->cache_info_amd.l1d_cache);
  6581. *edx = encode_cache_cpuid80000005(env->cache_info_amd.l1i_cache);
  6582. break;
  6583. case 0x80000006:
  6584. /* cache info (L2 cache) */
  6585. if (cpu->cache_info_passthrough) {
  6586. x86_cpu_get_cache_cpuid(index, 0, eax, ebx, ecx, edx);
  6587. break;
  6588. }
  6589. *eax = (AMD_ENC_ASSOC(L2_DTLB_2M_ASSOC) << 28) |
  6590. (L2_DTLB_2M_ENTRIES << 16) |
  6591. (AMD_ENC_ASSOC(L2_ITLB_2M_ASSOC) << 12) |
  6592. (L2_ITLB_2M_ENTRIES);
  6593. *ebx = (AMD_ENC_ASSOC(L2_DTLB_4K_ASSOC) << 28) |
  6594. (L2_DTLB_4K_ENTRIES << 16) |
  6595. (AMD_ENC_ASSOC(L2_ITLB_4K_ASSOC) << 12) |
  6596. (L2_ITLB_4K_ENTRIES);
  6597. encode_cache_cpuid80000006(env->cache_info_amd.l2_cache,
  6598. cpu->enable_l3_cache ?
  6599. env->cache_info_amd.l3_cache : NULL,
  6600. ecx, edx);
  6601. break;
  6602. case 0x80000007:
  6603. *eax = 0;
  6604. *ebx = env->features[FEAT_8000_0007_EBX];
  6605. *ecx = 0;
  6606. *edx = env->features[FEAT_8000_0007_EDX];
  6607. break;
  6608. case 0x80000008:
  6609. /* virtual & phys address size in low 2 bytes. */
  6610. *eax = cpu->phys_bits;
  6611. if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
  6612. /* 64 bit processor */
  6613. *eax |= (cpu_x86_virtual_addr_width(env) << 8);
  6614. *eax |= (cpu->guest_phys_bits << 16);
  6615. }
  6616. *ebx = env->features[FEAT_8000_0008_EBX];
  6617. if (threads_per_pkg > 1) {
  6618. /*
  6619. * Bits 15:12 is "The number of bits in the initial
  6620. * Core::X86::Apic::ApicId[ApicId] value that indicate
  6621. * thread ID within a package".
  6622. * Bits 7:0 is "The number of threads in the package is NC+1"
  6623. */
  6624. *ecx = (apicid_pkg_offset(&topo_info) << 12) |
  6625. (threads_per_pkg - 1);
  6626. } else {
  6627. *ecx = 0;
  6628. }
  6629. *edx = 0;
  6630. break;
  6631. case 0x8000000A:
  6632. if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
  6633. *eax = 0x00000001; /* SVM Revision */
  6634. *ebx = 0x00000010; /* nr of ASIDs */
  6635. *ecx = 0;
  6636. *edx = env->features[FEAT_SVM]; /* optional features */
  6637. } else {
  6638. *eax = 0;
  6639. *ebx = 0;
  6640. *ecx = 0;
  6641. *edx = 0;
  6642. }
  6643. break;
  6644. case 0x8000001D:
  6645. *eax = 0;
  6646. if (cpu->cache_info_passthrough) {
  6647. x86_cpu_get_cache_cpuid(index, count, eax, ebx, ecx, edx);
  6648. break;
  6649. }
  6650. switch (count) {
  6651. case 0: /* L1 dcache info */
  6652. encode_cache_cpuid8000001d(env->cache_info_amd.l1d_cache,
  6653. &topo_info, eax, ebx, ecx, edx);
  6654. break;
  6655. case 1: /* L1 icache info */
  6656. encode_cache_cpuid8000001d(env->cache_info_amd.l1i_cache,
  6657. &topo_info, eax, ebx, ecx, edx);
  6658. break;
  6659. case 2: /* L2 cache info */
  6660. encode_cache_cpuid8000001d(env->cache_info_amd.l2_cache,
  6661. &topo_info, eax, ebx, ecx, edx);
  6662. break;
  6663. case 3: /* L3 cache info */
  6664. encode_cache_cpuid8000001d(env->cache_info_amd.l3_cache,
  6665. &topo_info, eax, ebx, ecx, edx);
  6666. break;
  6667. default: /* end of info */
  6668. *eax = *ebx = *ecx = *edx = 0;
  6669. break;
  6670. }
  6671. if (cpu->amd_topoext_features_only) {
  6672. *edx &= CACHE_NO_INVD_SHARING | CACHE_INCLUSIVE;
  6673. }
  6674. break;
  6675. case 0x8000001E:
  6676. if (cpu->core_id <= 255) {
  6677. encode_topo_cpuid8000001e(cpu, &topo_info, eax, ebx, ecx, edx);
  6678. } else {
  6679. *eax = 0;
  6680. *ebx = 0;
  6681. *ecx = 0;
  6682. *edx = 0;
  6683. }
  6684. break;
  6685. case 0xC0000000:
  6686. *eax = env->cpuid_xlevel2;
  6687. *ebx = 0;
  6688. *ecx = 0;
  6689. *edx = 0;
  6690. break;
  6691. case 0xC0000001:
  6692. /* Support for VIA CPU's CPUID instruction */
  6693. *eax = env->cpuid_version;
  6694. *ebx = 0;
  6695. *ecx = 0;
  6696. *edx = env->features[FEAT_C000_0001_EDX];
  6697. break;
  6698. case 0xC0000002:
  6699. case 0xC0000003:
  6700. case 0xC0000004:
  6701. /* Reserved for the future, and now filled with zero */
  6702. *eax = 0;
  6703. *ebx = 0;
  6704. *ecx = 0;
  6705. *edx = 0;
  6706. break;
  6707. case 0x8000001F:
  6708. *eax = *ebx = *ecx = *edx = 0;
  6709. if (sev_enabled()) {
  6710. *eax = 0x2;
  6711. *eax |= sev_es_enabled() ? 0x8 : 0;
  6712. *eax |= sev_snp_enabled() ? 0x10 : 0;
  6713. *ebx = sev_get_cbit_position() & 0x3f; /* EBX[5:0] */
  6714. *ebx |= (sev_get_reduced_phys_bits() & 0x3f) << 6; /* EBX[11:6] */
  6715. }
  6716. break;
  6717. case 0x80000021:
  6718. *eax = env->features[FEAT_8000_0021_EAX];
  6719. *ebx = *ecx = *edx = 0;
  6720. break;
  6721. default:
  6722. /* reserved values: zero */
  6723. *eax = 0;
  6724. *ebx = 0;
  6725. *ecx = 0;
  6726. *edx = 0;
  6727. break;
  6728. }
  6729. }
  6730. static void x86_cpu_set_sgxlepubkeyhash(CPUX86State *env)
  6731. {
  6732. #ifndef CONFIG_USER_ONLY
  6733. /* Those default values are defined in Skylake HW */
  6734. env->msr_ia32_sgxlepubkeyhash[0] = 0xa6053e051270b7acULL;
  6735. env->msr_ia32_sgxlepubkeyhash[1] = 0x6cfbe8ba8b3b413dULL;
  6736. env->msr_ia32_sgxlepubkeyhash[2] = 0xc4916d99f2b3735dULL;
  6737. env->msr_ia32_sgxlepubkeyhash[3] = 0xd4f8c05909f9bb3bULL;
  6738. #endif
  6739. }
  6740. static void x86_cpu_reset_hold(Object *obj, ResetType type)
  6741. {
  6742. CPUState *cs = CPU(obj);
  6743. X86CPU *cpu = X86_CPU(cs);
  6744. X86CPUClass *xcc = X86_CPU_GET_CLASS(obj);
  6745. CPUX86State *env = &cpu->env;
  6746. target_ulong cr4;
  6747. uint64_t xcr0;
  6748. int i;
  6749. if (xcc->parent_phases.hold) {
  6750. xcc->parent_phases.hold(obj, type);
  6751. }
  6752. memset(env, 0, offsetof(CPUX86State, end_reset_fields));
  6753. env->old_exception = -1;
  6754. /* init to reset state */
  6755. env->int_ctl = 0;
  6756. env->hflags2 |= HF2_GIF_MASK;
  6757. env->hflags2 |= HF2_VGIF_MASK;
  6758. env->hflags &= ~HF_GUEST_MASK;
  6759. cpu_x86_update_cr0(env, 0x60000010);
  6760. env->a20_mask = ~0x0;
  6761. env->smbase = 0x30000;
  6762. env->msr_smi_count = 0;
  6763. env->idt.limit = 0xffff;
  6764. env->gdt.limit = 0xffff;
  6765. env->ldt.limit = 0xffff;
  6766. env->ldt.flags = DESC_P_MASK | (2 << DESC_TYPE_SHIFT);
  6767. env->tr.limit = 0xffff;
  6768. env->tr.flags = DESC_P_MASK | (11 << DESC_TYPE_SHIFT);
  6769. cpu_x86_load_seg_cache(env, R_CS, 0xf000, 0xffff0000, 0xffff,
  6770. DESC_P_MASK | DESC_S_MASK | DESC_CS_MASK |
  6771. DESC_R_MASK | DESC_A_MASK);
  6772. cpu_x86_load_seg_cache(env, R_DS, 0, 0, 0xffff,
  6773. DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
  6774. DESC_A_MASK);
  6775. cpu_x86_load_seg_cache(env, R_ES, 0, 0, 0xffff,
  6776. DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
  6777. DESC_A_MASK);
  6778. cpu_x86_load_seg_cache(env, R_SS, 0, 0, 0xffff,
  6779. DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
  6780. DESC_A_MASK);
  6781. cpu_x86_load_seg_cache(env, R_FS, 0, 0, 0xffff,
  6782. DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
  6783. DESC_A_MASK);
  6784. cpu_x86_load_seg_cache(env, R_GS, 0, 0, 0xffff,
  6785. DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
  6786. DESC_A_MASK);
  6787. env->eip = 0xfff0;
  6788. env->regs[R_EDX] = env->cpuid_version;
  6789. env->eflags = 0x2;
  6790. /* FPU init */
  6791. for (i = 0; i < 8; i++) {
  6792. env->fptags[i] = 1;
  6793. }
  6794. cpu_set_fpuc(env, 0x37f);
  6795. env->mxcsr = 0x1f80;
  6796. /* All units are in INIT state. */
  6797. env->xstate_bv = 0;
  6798. env->pat = 0x0007040600070406ULL;
  6799. if (kvm_enabled()) {
  6800. /*
  6801. * KVM handles TSC = 0 specially and thinks we are hot-plugging
  6802. * a new CPU, use 1 instead to force a reset.
  6803. */
  6804. if (env->tsc != 0) {
  6805. env->tsc = 1;
  6806. }
  6807. } else {
  6808. env->tsc = 0;
  6809. }
  6810. env->msr_ia32_misc_enable = MSR_IA32_MISC_ENABLE_DEFAULT;
  6811. if (env->features[FEAT_1_ECX] & CPUID_EXT_MONITOR) {
  6812. env->msr_ia32_misc_enable |= MSR_IA32_MISC_ENABLE_MWAIT;
  6813. }
  6814. memset(env->dr, 0, sizeof(env->dr));
  6815. env->dr[6] = DR6_FIXED_1;
  6816. env->dr[7] = DR7_FIXED_1;
  6817. cpu_breakpoint_remove_all(cs, BP_CPU);
  6818. cpu_watchpoint_remove_all(cs, BP_CPU);
  6819. cr4 = 0;
  6820. xcr0 = XSTATE_FP_MASK;
  6821. #ifdef CONFIG_USER_ONLY
  6822. /* Enable all the features for user-mode. */
  6823. if (env->features[FEAT_1_EDX] & CPUID_SSE) {
  6824. xcr0 |= XSTATE_SSE_MASK;
  6825. }
  6826. for (i = 2; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
  6827. const ExtSaveArea *esa = &x86_ext_save_areas[i];
  6828. if (!((1 << i) & CPUID_XSTATE_XCR0_MASK)) {
  6829. continue;
  6830. }
  6831. if (env->features[esa->feature] & esa->bits) {
  6832. xcr0 |= 1ull << i;
  6833. }
  6834. }
  6835. if (env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE) {
  6836. cr4 |= CR4_OSFXSR_MASK | CR4_OSXSAVE_MASK;
  6837. }
  6838. if (env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_FSGSBASE) {
  6839. cr4 |= CR4_FSGSBASE_MASK;
  6840. }
  6841. #endif
  6842. env->xcr0 = xcr0;
  6843. cpu_x86_update_cr4(env, cr4);
  6844. /*
  6845. * SDM 11.11.5 requires:
  6846. * - IA32_MTRR_DEF_TYPE MSR.E = 0
  6847. * - IA32_MTRR_PHYSMASKn.V = 0
  6848. * All other bits are undefined. For simplification, zero it all.
  6849. */
  6850. env->mtrr_deftype = 0;
  6851. memset(env->mtrr_var, 0, sizeof(env->mtrr_var));
  6852. memset(env->mtrr_fixed, 0, sizeof(env->mtrr_fixed));
  6853. env->interrupt_injected = -1;
  6854. env->exception_nr = -1;
  6855. env->exception_pending = 0;
  6856. env->exception_injected = 0;
  6857. env->exception_has_payload = false;
  6858. env->exception_payload = 0;
  6859. env->nmi_injected = false;
  6860. env->triple_fault_pending = false;
  6861. #if !defined(CONFIG_USER_ONLY)
  6862. /* We hard-wire the BSP to the first CPU. */
  6863. apic_designate_bsp(cpu->apic_state, cs->cpu_index == 0);
  6864. cs->halted = !cpu_is_bsp(cpu);
  6865. if (kvm_enabled()) {
  6866. kvm_arch_reset_vcpu(cpu);
  6867. }
  6868. x86_cpu_set_sgxlepubkeyhash(env);
  6869. env->amd_tsc_scale_msr = MSR_AMD64_TSC_RATIO_DEFAULT;
  6870. #endif
  6871. }
  6872. void x86_cpu_after_reset(X86CPU *cpu)
  6873. {
  6874. #ifndef CONFIG_USER_ONLY
  6875. if (kvm_enabled()) {
  6876. kvm_arch_after_reset_vcpu(cpu);
  6877. }
  6878. if (cpu->apic_state) {
  6879. device_cold_reset(cpu->apic_state);
  6880. }
  6881. #endif
  6882. }
  6883. static void mce_init(X86CPU *cpu)
  6884. {
  6885. CPUX86State *cenv = &cpu->env;
  6886. unsigned int bank;
  6887. if (((cenv->cpuid_version >> 8) & 0xf) >= 6
  6888. && (cenv->features[FEAT_1_EDX] & (CPUID_MCE | CPUID_MCA)) ==
  6889. (CPUID_MCE | CPUID_MCA)) {
  6890. cenv->mcg_cap = MCE_CAP_DEF | MCE_BANKS_DEF |
  6891. (cpu->enable_lmce ? MCG_LMCE_P : 0);
  6892. cenv->mcg_ctl = ~(uint64_t)0;
  6893. for (bank = 0; bank < MCE_BANKS_DEF; bank++) {
  6894. cenv->mce_banks[bank * 4] = ~(uint64_t)0;
  6895. }
  6896. }
  6897. }
  6898. static void x86_cpu_adjust_level(X86CPU *cpu, uint32_t *min, uint32_t value)
  6899. {
  6900. if (*min < value) {
  6901. *min = value;
  6902. }
  6903. }
  6904. /* Increase cpuid_min_{level,xlevel,xlevel2} automatically, if appropriate */
  6905. static void x86_cpu_adjust_feat_level(X86CPU *cpu, FeatureWord w)
  6906. {
  6907. CPUX86State *env = &cpu->env;
  6908. FeatureWordInfo *fi = &feature_word_info[w];
  6909. uint32_t eax = fi->cpuid.eax;
  6910. uint32_t region = eax & 0xF0000000;
  6911. assert(feature_word_info[w].type == CPUID_FEATURE_WORD);
  6912. if (!env->features[w]) {
  6913. return;
  6914. }
  6915. switch (region) {
  6916. case 0x00000000:
  6917. x86_cpu_adjust_level(cpu, &env->cpuid_min_level, eax);
  6918. break;
  6919. case 0x80000000:
  6920. x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, eax);
  6921. break;
  6922. case 0xC0000000:
  6923. x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel2, eax);
  6924. break;
  6925. }
  6926. if (eax == 7) {
  6927. x86_cpu_adjust_level(cpu, &env->cpuid_min_level_func7,
  6928. fi->cpuid.ecx);
  6929. }
  6930. }
  6931. /* Calculate XSAVE components based on the configured CPU feature flags */
  6932. static void x86_cpu_enable_xsave_components(X86CPU *cpu)
  6933. {
  6934. CPUX86State *env = &cpu->env;
  6935. int i;
  6936. uint64_t mask;
  6937. static bool request_perm;
  6938. if (!(env->features[FEAT_1_ECX] & CPUID_EXT_XSAVE)) {
  6939. env->features[FEAT_XSAVE_XCR0_LO] = 0;
  6940. env->features[FEAT_XSAVE_XCR0_HI] = 0;
  6941. env->features[FEAT_XSAVE_XSS_LO] = 0;
  6942. env->features[FEAT_XSAVE_XSS_HI] = 0;
  6943. return;
  6944. }
  6945. mask = 0;
  6946. for (i = 0; i < ARRAY_SIZE(x86_ext_save_areas); i++) {
  6947. const ExtSaveArea *esa = &x86_ext_save_areas[i];
  6948. if (env->features[esa->feature] & esa->bits) {
  6949. mask |= (1ULL << i);
  6950. }
  6951. }
  6952. /* Only request permission for first vcpu */
  6953. if (kvm_enabled() && !request_perm) {
  6954. kvm_request_xsave_components(cpu, mask);
  6955. request_perm = true;
  6956. }
  6957. env->features[FEAT_XSAVE_XCR0_LO] = mask & CPUID_XSTATE_XCR0_MASK;
  6958. env->features[FEAT_XSAVE_XCR0_HI] = (mask & CPUID_XSTATE_XCR0_MASK) >> 32;
  6959. env->features[FEAT_XSAVE_XSS_LO] = mask & CPUID_XSTATE_XSS_MASK;
  6960. env->features[FEAT_XSAVE_XSS_HI] = (mask & CPUID_XSTATE_XSS_MASK) >> 32;
  6961. }
  6962. /***** Steps involved on loading and filtering CPUID data
  6963. *
  6964. * When initializing and realizing a CPU object, the steps
  6965. * involved in setting up CPUID data are:
  6966. *
  6967. * 1) Loading CPU model definition (X86CPUDefinition). This is
  6968. * implemented by x86_cpu_load_model() and should be completely
  6969. * transparent, as it is done automatically by instance_init.
  6970. * No code should need to look at X86CPUDefinition structs
  6971. * outside instance_init.
  6972. *
  6973. * 2) CPU expansion. This is done by realize before CPUID
  6974. * filtering, and will make sure host/accelerator data is
  6975. * loaded for CPU models that depend on host capabilities
  6976. * (e.g. "host"). Done by x86_cpu_expand_features().
  6977. *
  6978. * 3) CPUID filtering. This initializes extra data related to
  6979. * CPUID, and checks if the host supports all capabilities
  6980. * required by the CPU. Runnability of a CPU model is
  6981. * determined at this step. Done by x86_cpu_filter_features().
  6982. *
  6983. * Some operations don't require all steps to be performed.
  6984. * More precisely:
  6985. *
  6986. * - CPU instance creation (instance_init) will run only CPU
  6987. * model loading. CPU expansion can't run at instance_init-time
  6988. * because host/accelerator data may be not available yet.
  6989. * - CPU realization will perform both CPU model expansion and CPUID
  6990. * filtering, and return an error in case one of them fails.
  6991. * - query-cpu-definitions needs to run all 3 steps. It needs
  6992. * to run CPUID filtering, as the 'unavailable-features'
  6993. * field is set based on the filtering results.
  6994. * - The query-cpu-model-expansion QMP command only needs to run
  6995. * CPU model loading and CPU expansion. It should not filter
  6996. * any CPUID data based on host capabilities.
  6997. */
  6998. /* Expand CPU configuration data, based on configured features
  6999. * and host/accelerator capabilities when appropriate.
  7000. */
  7001. void x86_cpu_expand_features(X86CPU *cpu, Error **errp)
  7002. {
  7003. CPUX86State *env = &cpu->env;
  7004. FeatureWord w;
  7005. int i;
  7006. GList *l;
  7007. for (l = plus_features; l; l = l->next) {
  7008. const char *prop = l->data;
  7009. if (!object_property_set_bool(OBJECT(cpu), prop, true, errp)) {
  7010. return;
  7011. }
  7012. }
  7013. for (l = minus_features; l; l = l->next) {
  7014. const char *prop = l->data;
  7015. if (!object_property_set_bool(OBJECT(cpu), prop, false, errp)) {
  7016. return;
  7017. }
  7018. }
  7019. /*TODO: Now cpu->max_features doesn't overwrite features
  7020. * set using QOM properties, and we can convert
  7021. * plus_features & minus_features to global properties
  7022. * inside x86_cpu_parse_featurestr() too.
  7023. */
  7024. if (cpu->max_features) {
  7025. for (w = 0; w < FEATURE_WORDS; w++) {
  7026. /* Override only features that weren't set explicitly
  7027. * by the user.
  7028. */
  7029. env->features[w] |=
  7030. x86_cpu_get_supported_feature_word(cpu, w) &
  7031. ~env->user_features[w] &
  7032. ~feature_word_info[w].no_autoenable_flags;
  7033. }
  7034. }
  7035. for (i = 0; i < ARRAY_SIZE(feature_dependencies); i++) {
  7036. FeatureDep *d = &feature_dependencies[i];
  7037. if (!(env->features[d->from.index] & d->from.mask)) {
  7038. uint64_t unavailable_features = env->features[d->to.index] & d->to.mask;
  7039. /* Not an error unless the dependent feature was added explicitly. */
  7040. mark_unavailable_features(cpu, d->to.index,
  7041. unavailable_features & env->user_features[d->to.index],
  7042. "This feature depends on other features that were not requested");
  7043. env->features[d->to.index] &= ~unavailable_features;
  7044. }
  7045. }
  7046. if (!kvm_enabled() || !cpu->expose_kvm) {
  7047. env->features[FEAT_KVM] = 0;
  7048. }
  7049. x86_cpu_enable_xsave_components(cpu);
  7050. /* CPUID[EAX=7,ECX=0].EBX always increased level automatically: */
  7051. x86_cpu_adjust_feat_level(cpu, FEAT_7_0_EBX);
  7052. if (cpu->full_cpuid_auto_level) {
  7053. x86_cpu_adjust_feat_level(cpu, FEAT_1_EDX);
  7054. x86_cpu_adjust_feat_level(cpu, FEAT_1_ECX);
  7055. x86_cpu_adjust_feat_level(cpu, FEAT_6_EAX);
  7056. x86_cpu_adjust_feat_level(cpu, FEAT_7_0_ECX);
  7057. x86_cpu_adjust_feat_level(cpu, FEAT_7_1_EAX);
  7058. x86_cpu_adjust_feat_level(cpu, FEAT_7_1_EDX);
  7059. x86_cpu_adjust_feat_level(cpu, FEAT_7_2_EDX);
  7060. x86_cpu_adjust_feat_level(cpu, FEAT_8000_0001_EDX);
  7061. x86_cpu_adjust_feat_level(cpu, FEAT_8000_0001_ECX);
  7062. x86_cpu_adjust_feat_level(cpu, FEAT_8000_0007_EDX);
  7063. x86_cpu_adjust_feat_level(cpu, FEAT_8000_0008_EBX);
  7064. x86_cpu_adjust_feat_level(cpu, FEAT_C000_0001_EDX);
  7065. x86_cpu_adjust_feat_level(cpu, FEAT_SVM);
  7066. x86_cpu_adjust_feat_level(cpu, FEAT_XSAVE);
  7067. /* Intel Processor Trace requires CPUID[0x14] */
  7068. if ((env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT)) {
  7069. if (cpu->intel_pt_auto_level) {
  7070. x86_cpu_adjust_level(cpu, &cpu->env.cpuid_min_level, 0x14);
  7071. } else if (cpu->env.cpuid_min_level < 0x14) {
  7072. mark_unavailable_features(cpu, FEAT_7_0_EBX,
  7073. CPUID_7_0_EBX_INTEL_PT,
  7074. "Intel PT need CPUID leaf 0x14, please set by \"-cpu ...,intel-pt=on,min-level=0x14\"");
  7075. }
  7076. }
  7077. /*
  7078. * Intel CPU topology with multi-dies support requires CPUID[0x1F].
  7079. * For AMD Rome/Milan, cpuid level is 0x10, and guest OS should detect
  7080. * extended toplogy by leaf 0xB. Only adjust it for Intel CPU, unless
  7081. * cpu->vendor_cpuid_only has been unset for compatibility with older
  7082. * machine types.
  7083. */
  7084. if (x86_has_extended_topo(env->avail_cpu_topo) &&
  7085. (IS_INTEL_CPU(env) || !cpu->vendor_cpuid_only)) {
  7086. x86_cpu_adjust_level(cpu, &env->cpuid_min_level, 0x1F);
  7087. }
  7088. /* SVM requires CPUID[0x8000000A] */
  7089. if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
  7090. x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x8000000A);
  7091. }
  7092. /* SEV requires CPUID[0x8000001F] */
  7093. if (sev_enabled()) {
  7094. x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x8000001F);
  7095. }
  7096. if (env->features[FEAT_8000_0021_EAX]) {
  7097. x86_cpu_adjust_level(cpu, &env->cpuid_min_xlevel, 0x80000021);
  7098. }
  7099. /* SGX requires CPUID[0x12] for EPC enumeration */
  7100. if (env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_SGX) {
  7101. x86_cpu_adjust_level(cpu, &env->cpuid_min_level, 0x12);
  7102. }
  7103. }
  7104. /* Set cpuid_*level* based on cpuid_min_*level, if not explicitly set */
  7105. if (env->cpuid_level_func7 == UINT32_MAX) {
  7106. env->cpuid_level_func7 = env->cpuid_min_level_func7;
  7107. }
  7108. if (env->cpuid_level == UINT32_MAX) {
  7109. env->cpuid_level = env->cpuid_min_level;
  7110. }
  7111. if (env->cpuid_xlevel == UINT32_MAX) {
  7112. env->cpuid_xlevel = env->cpuid_min_xlevel;
  7113. }
  7114. if (env->cpuid_xlevel2 == UINT32_MAX) {
  7115. env->cpuid_xlevel2 = env->cpuid_min_xlevel2;
  7116. }
  7117. if (kvm_enabled() && !kvm_hyperv_expand_features(cpu, errp)) {
  7118. return;
  7119. }
  7120. }
  7121. /*
  7122. * Finishes initialization of CPUID data, filters CPU feature
  7123. * words based on host availability of each feature.
  7124. *
  7125. * Returns: 0 if all flags are supported by the host, non-zero otherwise.
  7126. */
  7127. static void x86_cpu_filter_features(X86CPU *cpu, bool verbose)
  7128. {
  7129. CPUX86State *env = &cpu->env;
  7130. FeatureWord w;
  7131. const char *prefix = NULL;
  7132. if (verbose) {
  7133. prefix = accel_uses_host_cpuid()
  7134. ? "host doesn't support requested feature"
  7135. : "TCG doesn't support requested feature";
  7136. }
  7137. for (w = 0; w < FEATURE_WORDS; w++) {
  7138. uint64_t host_feat =
  7139. x86_cpu_get_supported_feature_word(NULL, w);
  7140. uint64_t requested_features = env->features[w];
  7141. uint64_t unavailable_features = requested_features & ~host_feat;
  7142. mark_unavailable_features(cpu, w, unavailable_features, prefix);
  7143. }
  7144. /*
  7145. * Check that KVM actually allows the processor tracing features that
  7146. * are advertised by cpu_x86_cpuid(). Keep these two in sync.
  7147. */
  7148. if ((env->features[FEAT_7_0_EBX] & CPUID_7_0_EBX_INTEL_PT) &&
  7149. kvm_enabled()) {
  7150. uint32_t eax_0, ebx_0, ecx_0, edx_0_unused;
  7151. uint32_t eax_1, ebx_1, ecx_1_unused, edx_1_unused;
  7152. x86_cpu_get_supported_cpuid(0x14, 0,
  7153. &eax_0, &ebx_0, &ecx_0, &edx_0_unused);
  7154. x86_cpu_get_supported_cpuid(0x14, 1,
  7155. &eax_1, &ebx_1, &ecx_1_unused, &edx_1_unused);
  7156. if (!eax_0 ||
  7157. ((ebx_0 & INTEL_PT_MINIMAL_EBX) != INTEL_PT_MINIMAL_EBX) ||
  7158. ((ecx_0 & INTEL_PT_MINIMAL_ECX) != INTEL_PT_MINIMAL_ECX) ||
  7159. ((eax_1 & INTEL_PT_MTC_BITMAP) != INTEL_PT_MTC_BITMAP) ||
  7160. ((eax_1 & INTEL_PT_ADDR_RANGES_NUM_MASK) <
  7161. INTEL_PT_ADDR_RANGES_NUM) ||
  7162. ((ebx_1 & (INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP)) !=
  7163. (INTEL_PT_PSB_BITMAP | INTEL_PT_CYCLE_BITMAP)) ||
  7164. ((ecx_0 & CPUID_14_0_ECX_LIP) !=
  7165. (env->features[FEAT_14_0_ECX] & CPUID_14_0_ECX_LIP))) {
  7166. /*
  7167. * Processor Trace capabilities aren't configurable, so if the
  7168. * host can't emulate the capabilities we report on
  7169. * cpu_x86_cpuid(), intel-pt can't be enabled on the current host.
  7170. */
  7171. mark_unavailable_features(cpu, FEAT_7_0_EBX, CPUID_7_0_EBX_INTEL_PT, prefix);
  7172. }
  7173. }
  7174. }
  7175. static void x86_cpu_hyperv_realize(X86CPU *cpu)
  7176. {
  7177. size_t len;
  7178. /* Hyper-V vendor id */
  7179. if (!cpu->hyperv_vendor) {
  7180. object_property_set_str(OBJECT(cpu), "hv-vendor-id", "Microsoft Hv",
  7181. &error_abort);
  7182. }
  7183. len = strlen(cpu->hyperv_vendor);
  7184. if (len > 12) {
  7185. warn_report("hv-vendor-id truncated to 12 characters");
  7186. len = 12;
  7187. }
  7188. memset(cpu->hyperv_vendor_id, 0, 12);
  7189. memcpy(cpu->hyperv_vendor_id, cpu->hyperv_vendor, len);
  7190. /* 'Hv#1' interface identification*/
  7191. cpu->hyperv_interface_id[0] = 0x31237648;
  7192. cpu->hyperv_interface_id[1] = 0;
  7193. cpu->hyperv_interface_id[2] = 0;
  7194. cpu->hyperv_interface_id[3] = 0;
  7195. /* Hypervisor implementation limits */
  7196. cpu->hyperv_limits[0] = 64;
  7197. cpu->hyperv_limits[1] = 0;
  7198. cpu->hyperv_limits[2] = 0;
  7199. }
  7200. static void x86_cpu_realizefn(DeviceState *dev, Error **errp)
  7201. {
  7202. CPUState *cs = CPU(dev);
  7203. X86CPU *cpu = X86_CPU(dev);
  7204. X86CPUClass *xcc = X86_CPU_GET_CLASS(dev);
  7205. CPUX86State *env = &cpu->env;
  7206. Error *local_err = NULL;
  7207. unsigned requested_lbr_fmt;
  7208. #if defined(CONFIG_TCG) && !defined(CONFIG_USER_ONLY)
  7209. /* Use pc-relative instructions in system-mode */
  7210. tcg_cflags_set(cs, CF_PCREL);
  7211. #endif
  7212. if (cpu->apic_id == UNASSIGNED_APIC_ID) {
  7213. error_setg(errp, "apic-id property was not initialized properly");
  7214. return;
  7215. }
  7216. /*
  7217. * Process Hyper-V enlightenments.
  7218. * Note: this currently has to happen before the expansion of CPU features.
  7219. */
  7220. x86_cpu_hyperv_realize(cpu);
  7221. x86_cpu_expand_features(cpu, &local_err);
  7222. if (local_err) {
  7223. goto out;
  7224. }
  7225. /*
  7226. * Override env->features[FEAT_PERF_CAPABILITIES].LBR_FMT
  7227. * with user-provided setting.
  7228. */
  7229. if (cpu->lbr_fmt != ~PERF_CAP_LBR_FMT) {
  7230. if ((cpu->lbr_fmt & PERF_CAP_LBR_FMT) != cpu->lbr_fmt) {
  7231. error_setg(errp, "invalid lbr-fmt");
  7232. return;
  7233. }
  7234. env->features[FEAT_PERF_CAPABILITIES] &= ~PERF_CAP_LBR_FMT;
  7235. env->features[FEAT_PERF_CAPABILITIES] |= cpu->lbr_fmt;
  7236. }
  7237. /*
  7238. * vPMU LBR is supported when 1) KVM is enabled 2) Option pmu=on and
  7239. * 3)vPMU LBR format matches that of host setting.
  7240. */
  7241. requested_lbr_fmt =
  7242. env->features[FEAT_PERF_CAPABILITIES] & PERF_CAP_LBR_FMT;
  7243. if (requested_lbr_fmt && kvm_enabled()) {
  7244. uint64_t host_perf_cap =
  7245. x86_cpu_get_supported_feature_word(NULL, FEAT_PERF_CAPABILITIES);
  7246. unsigned host_lbr_fmt = host_perf_cap & PERF_CAP_LBR_FMT;
  7247. if (!cpu->enable_pmu) {
  7248. error_setg(errp, "vPMU: LBR is unsupported without pmu=on");
  7249. return;
  7250. }
  7251. if (requested_lbr_fmt != host_lbr_fmt) {
  7252. error_setg(errp, "vPMU: the lbr-fmt value (0x%x) does not match "
  7253. "the host value (0x%x).",
  7254. requested_lbr_fmt, host_lbr_fmt);
  7255. return;
  7256. }
  7257. }
  7258. x86_cpu_filter_features(cpu, cpu->check_cpuid || cpu->enforce_cpuid);
  7259. if (cpu->enforce_cpuid && x86_cpu_have_filtered_features(cpu)) {
  7260. error_setg(&local_err,
  7261. accel_uses_host_cpuid() ?
  7262. "Host doesn't support requested features" :
  7263. "TCG doesn't support requested features");
  7264. goto out;
  7265. }
  7266. /* On AMD CPUs, some CPUID[8000_0001].EDX bits must match the bits on
  7267. * CPUID[1].EDX.
  7268. */
  7269. if (IS_AMD_CPU(env)) {
  7270. env->features[FEAT_8000_0001_EDX] &= ~CPUID_EXT2_AMD_ALIASES;
  7271. env->features[FEAT_8000_0001_EDX] |= (env->features[FEAT_1_EDX]
  7272. & CPUID_EXT2_AMD_ALIASES);
  7273. }
  7274. x86_cpu_set_sgxlepubkeyhash(env);
  7275. /*
  7276. * note: the call to the framework needs to happen after feature expansion,
  7277. * but before the checks/modifications to ucode_rev, mwait, phys_bits.
  7278. * These may be set by the accel-specific code,
  7279. * and the results are subsequently checked / assumed in this function.
  7280. */
  7281. cpu_exec_realizefn(cs, &local_err);
  7282. if (local_err != NULL) {
  7283. error_propagate(errp, local_err);
  7284. return;
  7285. }
  7286. if (xcc->host_cpuid_required && !accel_uses_host_cpuid()) {
  7287. g_autofree char *name = x86_cpu_class_get_model_name(xcc);
  7288. error_setg(&local_err, "CPU model '%s' requires KVM or HVF", name);
  7289. goto out;
  7290. }
  7291. if (cpu->guest_phys_bits == -1) {
  7292. /*
  7293. * If it was not set by the user, or by the accelerator via
  7294. * cpu_exec_realizefn, clear.
  7295. */
  7296. cpu->guest_phys_bits = 0;
  7297. }
  7298. if (cpu->ucode_rev == 0) {
  7299. /*
  7300. * The default is the same as KVM's. Note that this check
  7301. * needs to happen after the evenual setting of ucode_rev in
  7302. * accel-specific code in cpu_exec_realizefn.
  7303. */
  7304. if (IS_AMD_CPU(env)) {
  7305. cpu->ucode_rev = 0x01000065;
  7306. } else {
  7307. cpu->ucode_rev = 0x100000000ULL;
  7308. }
  7309. }
  7310. /*
  7311. * mwait extended info: needed for Core compatibility
  7312. * We always wake on interrupt even if host does not have the capability.
  7313. *
  7314. * requires the accel-specific code in cpu_exec_realizefn to
  7315. * have already acquired the CPUID data into cpu->mwait.
  7316. */
  7317. cpu->mwait.ecx |= CPUID_MWAIT_EMX | CPUID_MWAIT_IBE;
  7318. /* For 64bit systems think about the number of physical bits to present.
  7319. * ideally this should be the same as the host; anything other than matching
  7320. * the host can cause incorrect guest behaviour.
  7321. * QEMU used to pick the magic value of 40 bits that corresponds to
  7322. * consumer AMD devices but nothing else.
  7323. *
  7324. * Note that this code assumes features expansion has already been done
  7325. * (as it checks for CPUID_EXT2_LM), and also assumes that potential
  7326. * phys_bits adjustments to match the host have been already done in
  7327. * accel-specific code in cpu_exec_realizefn.
  7328. */
  7329. if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
  7330. if (cpu->phys_bits &&
  7331. (cpu->phys_bits > TARGET_PHYS_ADDR_SPACE_BITS ||
  7332. cpu->phys_bits < 32)) {
  7333. error_setg(errp, "phys-bits should be between 32 and %u "
  7334. " (but is %u)",
  7335. TARGET_PHYS_ADDR_SPACE_BITS, cpu->phys_bits);
  7336. return;
  7337. }
  7338. /*
  7339. * 0 means it was not explicitly set by the user (or by machine
  7340. * compat_props or by the host code in host-cpu.c).
  7341. * In this case, the default is the value used by TCG (40).
  7342. */
  7343. if (cpu->phys_bits == 0) {
  7344. cpu->phys_bits = TCG_PHYS_ADDR_BITS;
  7345. }
  7346. if (cpu->guest_phys_bits &&
  7347. (cpu->guest_phys_bits > cpu->phys_bits ||
  7348. cpu->guest_phys_bits < 32)) {
  7349. error_setg(errp, "guest-phys-bits should be between 32 and %u "
  7350. " (but is %u)",
  7351. cpu->phys_bits, cpu->guest_phys_bits);
  7352. return;
  7353. }
  7354. } else {
  7355. /* For 32 bit systems don't use the user set value, but keep
  7356. * phys_bits consistent with what we tell the guest.
  7357. */
  7358. if (cpu->phys_bits != 0) {
  7359. error_setg(errp, "phys-bits is not user-configurable in 32 bit");
  7360. return;
  7361. }
  7362. if (cpu->guest_phys_bits != 0) {
  7363. error_setg(errp, "guest-phys-bits is not user-configurable in 32 bit");
  7364. return;
  7365. }
  7366. if (env->features[FEAT_1_EDX] & (CPUID_PSE36 | CPUID_PAE)) {
  7367. cpu->phys_bits = 36;
  7368. } else {
  7369. cpu->phys_bits = 32;
  7370. }
  7371. }
  7372. /* Cache information initialization */
  7373. if (!cpu->legacy_cache) {
  7374. const CPUCaches *cache_info =
  7375. x86_cpu_get_versioned_cache_info(cpu, xcc->model);
  7376. if (!xcc->model || !cache_info) {
  7377. g_autofree char *name = x86_cpu_class_get_model_name(xcc);
  7378. error_setg(errp,
  7379. "CPU model '%s' doesn't support legacy-cache=off", name);
  7380. return;
  7381. }
  7382. env->cache_info_cpuid2 = env->cache_info_cpuid4 = env->cache_info_amd =
  7383. *cache_info;
  7384. } else {
  7385. /* Build legacy cache information */
  7386. env->cache_info_cpuid2.l1d_cache = &legacy_l1d_cache;
  7387. env->cache_info_cpuid2.l1i_cache = &legacy_l1i_cache;
  7388. env->cache_info_cpuid2.l2_cache = &legacy_l2_cache_cpuid2;
  7389. env->cache_info_cpuid2.l3_cache = &legacy_l3_cache;
  7390. env->cache_info_cpuid4.l1d_cache = &legacy_l1d_cache;
  7391. env->cache_info_cpuid4.l1i_cache = &legacy_l1i_cache;
  7392. env->cache_info_cpuid4.l2_cache = &legacy_l2_cache;
  7393. env->cache_info_cpuid4.l3_cache = &legacy_l3_cache;
  7394. env->cache_info_amd.l1d_cache = &legacy_l1d_cache_amd;
  7395. env->cache_info_amd.l1i_cache = &legacy_l1i_cache_amd;
  7396. env->cache_info_amd.l2_cache = &legacy_l2_cache_amd;
  7397. env->cache_info_amd.l3_cache = &legacy_l3_cache;
  7398. }
  7399. #ifndef CONFIG_USER_ONLY
  7400. MachineState *ms = MACHINE(qdev_get_machine());
  7401. qemu_register_reset(x86_cpu_machine_reset_cb, cpu);
  7402. if (cpu->env.features[FEAT_1_EDX] & CPUID_APIC || ms->smp.cpus > 1) {
  7403. x86_cpu_apic_create(cpu, &local_err);
  7404. if (local_err != NULL) {
  7405. goto out;
  7406. }
  7407. }
  7408. #endif
  7409. mce_init(cpu);
  7410. qemu_init_vcpu(cs);
  7411. /*
  7412. * Most Intel and certain AMD CPUs support hyperthreading. Even though QEMU
  7413. * fixes this issue by adjusting CPUID_0000_0001_EBX and CPUID_8000_0008_ECX
  7414. * based on inputs (sockets,cores,threads), it is still better to give
  7415. * users a warning.
  7416. *
  7417. * NOTE: the following code has to follow qemu_init_vcpu(). Otherwise
  7418. * cs->nr_threads hasn't be populated yet and the checking is incorrect.
  7419. */
  7420. if (IS_AMD_CPU(env) &&
  7421. !(env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_TOPOEXT) &&
  7422. cs->nr_threads > 1) {
  7423. warn_report_once("This family of AMD CPU doesn't support "
  7424. "hyperthreading(%d). Please configure -smp "
  7425. "options properly or try enabling topoext "
  7426. "feature.", cs->nr_threads);
  7427. }
  7428. #ifndef CONFIG_USER_ONLY
  7429. x86_cpu_apic_realize(cpu, &local_err);
  7430. if (local_err != NULL) {
  7431. goto out;
  7432. }
  7433. #endif /* !CONFIG_USER_ONLY */
  7434. cpu_reset(cs);
  7435. xcc->parent_realize(dev, &local_err);
  7436. out:
  7437. if (local_err != NULL) {
  7438. error_propagate(errp, local_err);
  7439. return;
  7440. }
  7441. }
  7442. static void x86_cpu_unrealizefn(DeviceState *dev)
  7443. {
  7444. X86CPU *cpu = X86_CPU(dev);
  7445. X86CPUClass *xcc = X86_CPU_GET_CLASS(dev);
  7446. #ifndef CONFIG_USER_ONLY
  7447. cpu_remove_sync(CPU(dev));
  7448. qemu_unregister_reset(x86_cpu_machine_reset_cb, dev);
  7449. #endif
  7450. if (cpu->apic_state) {
  7451. object_unparent(OBJECT(cpu->apic_state));
  7452. cpu->apic_state = NULL;
  7453. }
  7454. xcc->parent_unrealize(dev);
  7455. }
  7456. typedef struct BitProperty {
  7457. FeatureWord w;
  7458. uint64_t mask;
  7459. } BitProperty;
  7460. static void x86_cpu_get_bit_prop(Object *obj, Visitor *v, const char *name,
  7461. void *opaque, Error **errp)
  7462. {
  7463. X86CPU *cpu = X86_CPU(obj);
  7464. BitProperty *fp = opaque;
  7465. uint64_t f = cpu->env.features[fp->w];
  7466. bool value = (f & fp->mask) == fp->mask;
  7467. visit_type_bool(v, name, &value, errp);
  7468. }
  7469. static void x86_cpu_set_bit_prop(Object *obj, Visitor *v, const char *name,
  7470. void *opaque, Error **errp)
  7471. {
  7472. DeviceState *dev = DEVICE(obj);
  7473. X86CPU *cpu = X86_CPU(obj);
  7474. BitProperty *fp = opaque;
  7475. bool value;
  7476. if (dev->realized) {
  7477. qdev_prop_set_after_realize(dev, name, errp);
  7478. return;
  7479. }
  7480. if (!visit_type_bool(v, name, &value, errp)) {
  7481. return;
  7482. }
  7483. if (value) {
  7484. cpu->env.features[fp->w] |= fp->mask;
  7485. } else {
  7486. cpu->env.features[fp->w] &= ~fp->mask;
  7487. }
  7488. cpu->env.user_features[fp->w] |= fp->mask;
  7489. }
  7490. /* Register a boolean property to get/set a single bit in a uint32_t field.
  7491. *
  7492. * The same property name can be registered multiple times to make it affect
  7493. * multiple bits in the same FeatureWord. In that case, the getter will return
  7494. * true only if all bits are set.
  7495. */
  7496. static void x86_cpu_register_bit_prop(X86CPUClass *xcc,
  7497. const char *prop_name,
  7498. FeatureWord w,
  7499. int bitnr)
  7500. {
  7501. ObjectClass *oc = OBJECT_CLASS(xcc);
  7502. BitProperty *fp;
  7503. ObjectProperty *op;
  7504. uint64_t mask = (1ULL << bitnr);
  7505. op = object_class_property_find(oc, prop_name);
  7506. if (op) {
  7507. fp = op->opaque;
  7508. assert(fp->w == w);
  7509. fp->mask |= mask;
  7510. } else {
  7511. fp = g_new0(BitProperty, 1);
  7512. fp->w = w;
  7513. fp->mask = mask;
  7514. object_class_property_add(oc, prop_name, "bool",
  7515. x86_cpu_get_bit_prop,
  7516. x86_cpu_set_bit_prop,
  7517. NULL, fp);
  7518. }
  7519. }
  7520. static void x86_cpu_register_feature_bit_props(X86CPUClass *xcc,
  7521. FeatureWord w,
  7522. int bitnr)
  7523. {
  7524. FeatureWordInfo *fi = &feature_word_info[w];
  7525. const char *name = fi->feat_names[bitnr];
  7526. if (!name) {
  7527. return;
  7528. }
  7529. /* Property names should use "-" instead of "_".
  7530. * Old names containing underscores are registered as aliases
  7531. * using object_property_add_alias()
  7532. */
  7533. assert(!strchr(name, '_'));
  7534. /* aliases don't use "|" delimiters anymore, they are registered
  7535. * manually using object_property_add_alias() */
  7536. assert(!strchr(name, '|'));
  7537. x86_cpu_register_bit_prop(xcc, name, w, bitnr);
  7538. }
  7539. static void x86_cpu_post_initfn(Object *obj)
  7540. {
  7541. accel_cpu_instance_init(CPU(obj));
  7542. }
  7543. static void x86_cpu_init_default_topo(X86CPU *cpu)
  7544. {
  7545. CPUX86State *env = &cpu->env;
  7546. env->nr_modules = 1;
  7547. env->nr_dies = 1;
  7548. /* SMT, core and package levels are set by default. */
  7549. set_bit(CPU_TOPO_LEVEL_SMT, env->avail_cpu_topo);
  7550. set_bit(CPU_TOPO_LEVEL_CORE, env->avail_cpu_topo);
  7551. set_bit(CPU_TOPO_LEVEL_PACKAGE, env->avail_cpu_topo);
  7552. }
  7553. static void x86_cpu_initfn(Object *obj)
  7554. {
  7555. X86CPU *cpu = X86_CPU(obj);
  7556. X86CPUClass *xcc = X86_CPU_GET_CLASS(obj);
  7557. CPUX86State *env = &cpu->env;
  7558. x86_cpu_init_default_topo(cpu);
  7559. object_property_add(obj, "feature-words", "X86CPUFeatureWordInfo",
  7560. x86_cpu_get_feature_words,
  7561. NULL, NULL, (void *)env->features);
  7562. object_property_add(obj, "filtered-features", "X86CPUFeatureWordInfo",
  7563. x86_cpu_get_feature_words,
  7564. NULL, NULL, (void *)cpu->filtered_features);
  7565. object_property_add_alias(obj, "sse3", obj, "pni");
  7566. object_property_add_alias(obj, "pclmuldq", obj, "pclmulqdq");
  7567. object_property_add_alias(obj, "sse4-1", obj, "sse4.1");
  7568. object_property_add_alias(obj, "sse4-2", obj, "sse4.2");
  7569. object_property_add_alias(obj, "xd", obj, "nx");
  7570. object_property_add_alias(obj, "ffxsr", obj, "fxsr-opt");
  7571. object_property_add_alias(obj, "i64", obj, "lm");
  7572. object_property_add_alias(obj, "ds_cpl", obj, "ds-cpl");
  7573. object_property_add_alias(obj, "tsc_adjust", obj, "tsc-adjust");
  7574. object_property_add_alias(obj, "fxsr_opt", obj, "fxsr-opt");
  7575. object_property_add_alias(obj, "lahf_lm", obj, "lahf-lm");
  7576. object_property_add_alias(obj, "cmp_legacy", obj, "cmp-legacy");
  7577. object_property_add_alias(obj, "nodeid_msr", obj, "nodeid-msr");
  7578. object_property_add_alias(obj, "perfctr_core", obj, "perfctr-core");
  7579. object_property_add_alias(obj, "perfctr_nb", obj, "perfctr-nb");
  7580. object_property_add_alias(obj, "kvm_nopiodelay", obj, "kvm-nopiodelay");
  7581. object_property_add_alias(obj, "kvm_mmu", obj, "kvm-mmu");
  7582. object_property_add_alias(obj, "kvm_asyncpf", obj, "kvm-asyncpf");
  7583. object_property_add_alias(obj, "kvm_asyncpf_int", obj, "kvm-asyncpf-int");
  7584. object_property_add_alias(obj, "kvm_steal_time", obj, "kvm-steal-time");
  7585. object_property_add_alias(obj, "kvm_pv_eoi", obj, "kvm-pv-eoi");
  7586. object_property_add_alias(obj, "kvm_pv_unhalt", obj, "kvm-pv-unhalt");
  7587. object_property_add_alias(obj, "kvm_poll_control", obj, "kvm-poll-control");
  7588. object_property_add_alias(obj, "svm_lock", obj, "svm-lock");
  7589. object_property_add_alias(obj, "nrip_save", obj, "nrip-save");
  7590. object_property_add_alias(obj, "tsc_scale", obj, "tsc-scale");
  7591. object_property_add_alias(obj, "vmcb_clean", obj, "vmcb-clean");
  7592. object_property_add_alias(obj, "pause_filter", obj, "pause-filter");
  7593. object_property_add_alias(obj, "sse4_1", obj, "sse4.1");
  7594. object_property_add_alias(obj, "sse4_2", obj, "sse4.2");
  7595. object_property_add_alias(obj, "hv-apicv", obj, "hv-avic");
  7596. cpu->lbr_fmt = ~PERF_CAP_LBR_FMT;
  7597. object_property_add_alias(obj, "lbr_fmt", obj, "lbr-fmt");
  7598. if (xcc->model) {
  7599. x86_cpu_load_model(cpu, xcc->model);
  7600. }
  7601. }
  7602. static int64_t x86_cpu_get_arch_id(CPUState *cs)
  7603. {
  7604. X86CPU *cpu = X86_CPU(cs);
  7605. return cpu->apic_id;
  7606. }
  7607. #if !defined(CONFIG_USER_ONLY)
  7608. static bool x86_cpu_get_paging_enabled(const CPUState *cs)
  7609. {
  7610. X86CPU *cpu = X86_CPU(cs);
  7611. return cpu->env.cr[0] & CR0_PG_MASK;
  7612. }
  7613. #endif /* !CONFIG_USER_ONLY */
  7614. static void x86_cpu_set_pc(CPUState *cs, vaddr value)
  7615. {
  7616. X86CPU *cpu = X86_CPU(cs);
  7617. cpu->env.eip = value;
  7618. }
  7619. static vaddr x86_cpu_get_pc(CPUState *cs)
  7620. {
  7621. X86CPU *cpu = X86_CPU(cs);
  7622. /* Match cpu_get_tb_cpu_state. */
  7623. return cpu->env.eip + cpu->env.segs[R_CS].base;
  7624. }
  7625. int x86_cpu_pending_interrupt(CPUState *cs, int interrupt_request)
  7626. {
  7627. X86CPU *cpu = X86_CPU(cs);
  7628. CPUX86State *env = &cpu->env;
  7629. #if !defined(CONFIG_USER_ONLY)
  7630. if (interrupt_request & CPU_INTERRUPT_POLL) {
  7631. return CPU_INTERRUPT_POLL;
  7632. }
  7633. #endif
  7634. if (interrupt_request & CPU_INTERRUPT_SIPI) {
  7635. return CPU_INTERRUPT_SIPI;
  7636. }
  7637. if (env->hflags2 & HF2_GIF_MASK) {
  7638. if ((interrupt_request & CPU_INTERRUPT_SMI) &&
  7639. !(env->hflags & HF_SMM_MASK)) {
  7640. return CPU_INTERRUPT_SMI;
  7641. } else if ((interrupt_request & CPU_INTERRUPT_NMI) &&
  7642. !(env->hflags2 & HF2_NMI_MASK)) {
  7643. return CPU_INTERRUPT_NMI;
  7644. } else if (interrupt_request & CPU_INTERRUPT_MCE) {
  7645. return CPU_INTERRUPT_MCE;
  7646. } else if ((interrupt_request & CPU_INTERRUPT_HARD) &&
  7647. (((env->hflags2 & HF2_VINTR_MASK) &&
  7648. (env->hflags2 & HF2_HIF_MASK)) ||
  7649. (!(env->hflags2 & HF2_VINTR_MASK) &&
  7650. (env->eflags & IF_MASK &&
  7651. !(env->hflags & HF_INHIBIT_IRQ_MASK))))) {
  7652. return CPU_INTERRUPT_HARD;
  7653. #if !defined(CONFIG_USER_ONLY)
  7654. } else if (env->hflags2 & HF2_VGIF_MASK) {
  7655. if((interrupt_request & CPU_INTERRUPT_VIRQ) &&
  7656. (env->eflags & IF_MASK) &&
  7657. !(env->hflags & HF_INHIBIT_IRQ_MASK)) {
  7658. return CPU_INTERRUPT_VIRQ;
  7659. }
  7660. #endif
  7661. }
  7662. }
  7663. return 0;
  7664. }
  7665. static bool x86_cpu_has_work(CPUState *cs)
  7666. {
  7667. return x86_cpu_pending_interrupt(cs, cs->interrupt_request) != 0;
  7668. }
  7669. int x86_mmu_index_pl(CPUX86State *env, unsigned pl)
  7670. {
  7671. int mmu_index_32 = (env->hflags & HF_CS64_MASK) ? 0 : 1;
  7672. int mmu_index_base =
  7673. pl == 3 ? MMU_USER64_IDX :
  7674. !(env->hflags & HF_SMAP_MASK) ? MMU_KNOSMAP64_IDX :
  7675. (env->eflags & AC_MASK) ? MMU_KNOSMAP64_IDX : MMU_KSMAP64_IDX;
  7676. return mmu_index_base + mmu_index_32;
  7677. }
  7678. static int x86_cpu_mmu_index(CPUState *cs, bool ifetch)
  7679. {
  7680. CPUX86State *env = cpu_env(cs);
  7681. return x86_mmu_index_pl(env, env->hflags & HF_CPL_MASK);
  7682. }
  7683. static int x86_mmu_index_kernel_pl(CPUX86State *env, unsigned pl)
  7684. {
  7685. int mmu_index_32 = (env->hflags & HF_LMA_MASK) ? 0 : 1;
  7686. int mmu_index_base =
  7687. !(env->hflags & HF_SMAP_MASK) ? MMU_KNOSMAP64_IDX :
  7688. (pl < 3 && (env->eflags & AC_MASK)
  7689. ? MMU_KNOSMAP64_IDX : MMU_KSMAP64_IDX);
  7690. return mmu_index_base + mmu_index_32;
  7691. }
  7692. int cpu_mmu_index_kernel(CPUX86State *env)
  7693. {
  7694. return x86_mmu_index_kernel_pl(env, env->hflags & HF_CPL_MASK);
  7695. }
  7696. static void x86_disas_set_info(CPUState *cs, disassemble_info *info)
  7697. {
  7698. X86CPU *cpu = X86_CPU(cs);
  7699. CPUX86State *env = &cpu->env;
  7700. info->mach = (env->hflags & HF_CS64_MASK ? bfd_mach_x86_64
  7701. : env->hflags & HF_CS32_MASK ? bfd_mach_i386_i386
  7702. : bfd_mach_i386_i8086);
  7703. info->cap_arch = CS_ARCH_X86;
  7704. info->cap_mode = (env->hflags & HF_CS64_MASK ? CS_MODE_64
  7705. : env->hflags & HF_CS32_MASK ? CS_MODE_32
  7706. : CS_MODE_16);
  7707. info->cap_insn_unit = 1;
  7708. info->cap_insn_split = 8;
  7709. }
  7710. void x86_update_hflags(CPUX86State *env)
  7711. {
  7712. uint32_t hflags;
  7713. #define HFLAG_COPY_MASK \
  7714. ~( HF_CPL_MASK | HF_PE_MASK | HF_MP_MASK | HF_EM_MASK | \
  7715. HF_TS_MASK | HF_TF_MASK | HF_VM_MASK | HF_IOPL_MASK | \
  7716. HF_OSFXSR_MASK | HF_LMA_MASK | HF_CS32_MASK | \
  7717. HF_SS32_MASK | HF_CS64_MASK | HF_ADDSEG_MASK)
  7718. hflags = env->hflags & HFLAG_COPY_MASK;
  7719. hflags |= (env->segs[R_SS].flags >> DESC_DPL_SHIFT) & HF_CPL_MASK;
  7720. hflags |= (env->cr[0] & CR0_PE_MASK) << (HF_PE_SHIFT - CR0_PE_SHIFT);
  7721. hflags |= (env->cr[0] << (HF_MP_SHIFT - CR0_MP_SHIFT)) &
  7722. (HF_MP_MASK | HF_EM_MASK | HF_TS_MASK);
  7723. hflags |= (env->eflags & (HF_TF_MASK | HF_VM_MASK | HF_IOPL_MASK));
  7724. if (env->cr[4] & CR4_OSFXSR_MASK) {
  7725. hflags |= HF_OSFXSR_MASK;
  7726. }
  7727. if (env->efer & MSR_EFER_LMA) {
  7728. hflags |= HF_LMA_MASK;
  7729. }
  7730. if ((hflags & HF_LMA_MASK) && (env->segs[R_CS].flags & DESC_L_MASK)) {
  7731. hflags |= HF_CS32_MASK | HF_SS32_MASK | HF_CS64_MASK;
  7732. } else {
  7733. hflags |= (env->segs[R_CS].flags & DESC_B_MASK) >>
  7734. (DESC_B_SHIFT - HF_CS32_SHIFT);
  7735. hflags |= (env->segs[R_SS].flags & DESC_B_MASK) >>
  7736. (DESC_B_SHIFT - HF_SS32_SHIFT);
  7737. if (!(env->cr[0] & CR0_PE_MASK) || (env->eflags & VM_MASK) ||
  7738. !(hflags & HF_CS32_MASK)) {
  7739. hflags |= HF_ADDSEG_MASK;
  7740. } else {
  7741. hflags |= ((env->segs[R_DS].base | env->segs[R_ES].base |
  7742. env->segs[R_SS].base) != 0) << HF_ADDSEG_SHIFT;
  7743. }
  7744. }
  7745. env->hflags = hflags;
  7746. }
  7747. static Property x86_cpu_properties[] = {
  7748. #ifdef CONFIG_USER_ONLY
  7749. /* apic_id = 0 by default for *-user, see commit 9886e834 */
  7750. DEFINE_PROP_UINT32("apic-id", X86CPU, apic_id, 0),
  7751. DEFINE_PROP_INT32("thread-id", X86CPU, thread_id, 0),
  7752. DEFINE_PROP_INT32("core-id", X86CPU, core_id, 0),
  7753. DEFINE_PROP_INT32("module-id", X86CPU, module_id, 0),
  7754. DEFINE_PROP_INT32("die-id", X86CPU, die_id, 0),
  7755. DEFINE_PROP_INT32("socket-id", X86CPU, socket_id, 0),
  7756. #else
  7757. DEFINE_PROP_UINT32("apic-id", X86CPU, apic_id, UNASSIGNED_APIC_ID),
  7758. DEFINE_PROP_INT32("thread-id", X86CPU, thread_id, -1),
  7759. DEFINE_PROP_INT32("core-id", X86CPU, core_id, -1),
  7760. DEFINE_PROP_INT32("module-id", X86CPU, module_id, -1),
  7761. DEFINE_PROP_INT32("die-id", X86CPU, die_id, -1),
  7762. DEFINE_PROP_INT32("socket-id", X86CPU, socket_id, -1),
  7763. #endif
  7764. DEFINE_PROP_INT32("node-id", X86CPU, node_id, CPU_UNSET_NUMA_NODE_ID),
  7765. DEFINE_PROP_BOOL("pmu", X86CPU, enable_pmu, false),
  7766. DEFINE_PROP_UINT64_CHECKMASK("lbr-fmt", X86CPU, lbr_fmt, PERF_CAP_LBR_FMT),
  7767. DEFINE_PROP_UINT32("hv-spinlocks", X86CPU, hyperv_spinlock_attempts,
  7768. HYPERV_SPINLOCK_NEVER_NOTIFY),
  7769. DEFINE_PROP_BIT64("hv-relaxed", X86CPU, hyperv_features,
  7770. HYPERV_FEAT_RELAXED, 0),
  7771. DEFINE_PROP_BIT64("hv-vapic", X86CPU, hyperv_features,
  7772. HYPERV_FEAT_VAPIC, 0),
  7773. DEFINE_PROP_BIT64("hv-time", X86CPU, hyperv_features,
  7774. HYPERV_FEAT_TIME, 0),
  7775. DEFINE_PROP_BIT64("hv-crash", X86CPU, hyperv_features,
  7776. HYPERV_FEAT_CRASH, 0),
  7777. DEFINE_PROP_BIT64("hv-reset", X86CPU, hyperv_features,
  7778. HYPERV_FEAT_RESET, 0),
  7779. DEFINE_PROP_BIT64("hv-vpindex", X86CPU, hyperv_features,
  7780. HYPERV_FEAT_VPINDEX, 0),
  7781. DEFINE_PROP_BIT64("hv-runtime", X86CPU, hyperv_features,
  7782. HYPERV_FEAT_RUNTIME, 0),
  7783. DEFINE_PROP_BIT64("hv-synic", X86CPU, hyperv_features,
  7784. HYPERV_FEAT_SYNIC, 0),
  7785. DEFINE_PROP_BIT64("hv-stimer", X86CPU, hyperv_features,
  7786. HYPERV_FEAT_STIMER, 0),
  7787. DEFINE_PROP_BIT64("hv-frequencies", X86CPU, hyperv_features,
  7788. HYPERV_FEAT_FREQUENCIES, 0),
  7789. DEFINE_PROP_BIT64("hv-reenlightenment", X86CPU, hyperv_features,
  7790. HYPERV_FEAT_REENLIGHTENMENT, 0),
  7791. DEFINE_PROP_BIT64("hv-tlbflush", X86CPU, hyperv_features,
  7792. HYPERV_FEAT_TLBFLUSH, 0),
  7793. DEFINE_PROP_BIT64("hv-evmcs", X86CPU, hyperv_features,
  7794. HYPERV_FEAT_EVMCS, 0),
  7795. DEFINE_PROP_BIT64("hv-ipi", X86CPU, hyperv_features,
  7796. HYPERV_FEAT_IPI, 0),
  7797. DEFINE_PROP_BIT64("hv-stimer-direct", X86CPU, hyperv_features,
  7798. HYPERV_FEAT_STIMER_DIRECT, 0),
  7799. DEFINE_PROP_BIT64("hv-avic", X86CPU, hyperv_features,
  7800. HYPERV_FEAT_AVIC, 0),
  7801. DEFINE_PROP_BIT64("hv-emsr-bitmap", X86CPU, hyperv_features,
  7802. HYPERV_FEAT_MSR_BITMAP, 0),
  7803. DEFINE_PROP_BIT64("hv-xmm-input", X86CPU, hyperv_features,
  7804. HYPERV_FEAT_XMM_INPUT, 0),
  7805. DEFINE_PROP_BIT64("hv-tlbflush-ext", X86CPU, hyperv_features,
  7806. HYPERV_FEAT_TLBFLUSH_EXT, 0),
  7807. DEFINE_PROP_BIT64("hv-tlbflush-direct", X86CPU, hyperv_features,
  7808. HYPERV_FEAT_TLBFLUSH_DIRECT, 0),
  7809. DEFINE_PROP_ON_OFF_AUTO("hv-no-nonarch-coresharing", X86CPU,
  7810. hyperv_no_nonarch_cs, ON_OFF_AUTO_OFF),
  7811. DEFINE_PROP_BIT64("hv-syndbg", X86CPU, hyperv_features,
  7812. HYPERV_FEAT_SYNDBG, 0),
  7813. DEFINE_PROP_BOOL("hv-passthrough", X86CPU, hyperv_passthrough, false),
  7814. DEFINE_PROP_BOOL("hv-enforce-cpuid", X86CPU, hyperv_enforce_cpuid, false),
  7815. /* WS2008R2 identify by default */
  7816. DEFINE_PROP_UINT32("hv-version-id-build", X86CPU, hyperv_ver_id_build,
  7817. 0x3839),
  7818. DEFINE_PROP_UINT16("hv-version-id-major", X86CPU, hyperv_ver_id_major,
  7819. 0x000A),
  7820. DEFINE_PROP_UINT16("hv-version-id-minor", X86CPU, hyperv_ver_id_minor,
  7821. 0x0000),
  7822. DEFINE_PROP_UINT32("hv-version-id-spack", X86CPU, hyperv_ver_id_sp, 0),
  7823. DEFINE_PROP_UINT8("hv-version-id-sbranch", X86CPU, hyperv_ver_id_sb, 0),
  7824. DEFINE_PROP_UINT32("hv-version-id-snumber", X86CPU, hyperv_ver_id_sn, 0),
  7825. DEFINE_PROP_BOOL("check", X86CPU, check_cpuid, true),
  7826. DEFINE_PROP_BOOL("enforce", X86CPU, enforce_cpuid, false),
  7827. DEFINE_PROP_BOOL("x-force-features", X86CPU, force_features, false),
  7828. DEFINE_PROP_BOOL("kvm", X86CPU, expose_kvm, true),
  7829. DEFINE_PROP_UINT32("phys-bits", X86CPU, phys_bits, 0),
  7830. DEFINE_PROP_UINT32("guest-phys-bits", X86CPU, guest_phys_bits, -1),
  7831. DEFINE_PROP_BOOL("host-phys-bits", X86CPU, host_phys_bits, false),
  7832. DEFINE_PROP_UINT8("host-phys-bits-limit", X86CPU, host_phys_bits_limit, 0),
  7833. DEFINE_PROP_BOOL("fill-mtrr-mask", X86CPU, fill_mtrr_mask, true),
  7834. DEFINE_PROP_UINT32("level-func7", X86CPU, env.cpuid_level_func7,
  7835. UINT32_MAX),
  7836. DEFINE_PROP_UINT32("level", X86CPU, env.cpuid_level, UINT32_MAX),
  7837. DEFINE_PROP_UINT32("xlevel", X86CPU, env.cpuid_xlevel, UINT32_MAX),
  7838. DEFINE_PROP_UINT32("xlevel2", X86CPU, env.cpuid_xlevel2, UINT32_MAX),
  7839. DEFINE_PROP_UINT32("min-level", X86CPU, env.cpuid_min_level, 0),
  7840. DEFINE_PROP_UINT32("min-xlevel", X86CPU, env.cpuid_min_xlevel, 0),
  7841. DEFINE_PROP_UINT32("min-xlevel2", X86CPU, env.cpuid_min_xlevel2, 0),
  7842. DEFINE_PROP_UINT64("ucode-rev", X86CPU, ucode_rev, 0),
  7843. DEFINE_PROP_BOOL("full-cpuid-auto-level", X86CPU, full_cpuid_auto_level, true),
  7844. DEFINE_PROP_STRING("hv-vendor-id", X86CPU, hyperv_vendor),
  7845. DEFINE_PROP_BOOL("cpuid-0xb", X86CPU, enable_cpuid_0xb, true),
  7846. DEFINE_PROP_BOOL("x-vendor-cpuid-only", X86CPU, vendor_cpuid_only, true),
  7847. DEFINE_PROP_BOOL("x-amd-topoext-features-only", X86CPU, amd_topoext_features_only, true),
  7848. DEFINE_PROP_BOOL("lmce", X86CPU, enable_lmce, false),
  7849. DEFINE_PROP_BOOL("l3-cache", X86CPU, enable_l3_cache, true),
  7850. DEFINE_PROP_BOOL("kvm-pv-enforce-cpuid", X86CPU, kvm_pv_enforce_cpuid,
  7851. false),
  7852. DEFINE_PROP_BOOL("vmware-cpuid-freq", X86CPU, vmware_cpuid_freq, true),
  7853. DEFINE_PROP_BOOL("tcg-cpuid", X86CPU, expose_tcg, true),
  7854. DEFINE_PROP_BOOL("x-migrate-smi-count", X86CPU, migrate_smi_count,
  7855. true),
  7856. /*
  7857. * lecacy_cache defaults to true unless the CPU model provides its
  7858. * own cache information (see x86_cpu_load_def()).
  7859. */
  7860. DEFINE_PROP_BOOL("legacy-cache", X86CPU, legacy_cache, true),
  7861. DEFINE_PROP_BOOL("legacy-multi-node", X86CPU, legacy_multi_node, false),
  7862. DEFINE_PROP_BOOL("xen-vapic", X86CPU, xen_vapic, false),
  7863. /*
  7864. * From "Requirements for Implementing the Microsoft
  7865. * Hypervisor Interface":
  7866. * https://docs.microsoft.com/en-us/virtualization/hyper-v-on-windows/reference/tlfs
  7867. *
  7868. * "Starting with Windows Server 2012 and Windows 8, if
  7869. * CPUID.40000005.EAX contains a value of -1, Windows assumes that
  7870. * the hypervisor imposes no specific limit to the number of VPs.
  7871. * In this case, Windows Server 2012 guest VMs may use more than
  7872. * 64 VPs, up to the maximum supported number of processors applicable
  7873. * to the specific Windows version being used."
  7874. */
  7875. DEFINE_PROP_INT32("x-hv-max-vps", X86CPU, hv_max_vps, -1),
  7876. DEFINE_PROP_BOOL("x-hv-synic-kvm-only", X86CPU, hyperv_synic_kvm_only,
  7877. false),
  7878. DEFINE_PROP_BOOL("x-intel-pt-auto-level", X86CPU, intel_pt_auto_level,
  7879. true),
  7880. DEFINE_PROP_BOOL("x-l1-cache-per-thread", X86CPU, l1_cache_per_core, true),
  7881. DEFINE_PROP_END_OF_LIST()
  7882. };
  7883. #ifndef CONFIG_USER_ONLY
  7884. #include "hw/core/sysemu-cpu-ops.h"
  7885. static const struct SysemuCPUOps i386_sysemu_ops = {
  7886. .get_memory_mapping = x86_cpu_get_memory_mapping,
  7887. .get_paging_enabled = x86_cpu_get_paging_enabled,
  7888. .get_phys_page_attrs_debug = x86_cpu_get_phys_page_attrs_debug,
  7889. .asidx_from_attrs = x86_asidx_from_attrs,
  7890. .get_crash_info = x86_cpu_get_crash_info,
  7891. .write_elf32_note = x86_cpu_write_elf32_note,
  7892. .write_elf64_note = x86_cpu_write_elf64_note,
  7893. .write_elf32_qemunote = x86_cpu_write_elf32_qemunote,
  7894. .write_elf64_qemunote = x86_cpu_write_elf64_qemunote,
  7895. .legacy_vmsd = &vmstate_x86_cpu,
  7896. };
  7897. #endif
  7898. static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
  7899. {
  7900. X86CPUClass *xcc = X86_CPU_CLASS(oc);
  7901. CPUClass *cc = CPU_CLASS(oc);
  7902. DeviceClass *dc = DEVICE_CLASS(oc);
  7903. ResettableClass *rc = RESETTABLE_CLASS(oc);
  7904. FeatureWord w;
  7905. device_class_set_parent_realize(dc, x86_cpu_realizefn,
  7906. &xcc->parent_realize);
  7907. device_class_set_parent_unrealize(dc, x86_cpu_unrealizefn,
  7908. &xcc->parent_unrealize);
  7909. device_class_set_props(dc, x86_cpu_properties);
  7910. resettable_class_set_parent_phases(rc, NULL, x86_cpu_reset_hold, NULL,
  7911. &xcc->parent_phases);
  7912. cc->reset_dump_flags = CPU_DUMP_FPU | CPU_DUMP_CCOP;
  7913. cc->class_by_name = x86_cpu_class_by_name;
  7914. cc->parse_features = x86_cpu_parse_featurestr;
  7915. cc->has_work = x86_cpu_has_work;
  7916. cc->mmu_index = x86_cpu_mmu_index;
  7917. cc->dump_state = x86_cpu_dump_state;
  7918. cc->set_pc = x86_cpu_set_pc;
  7919. cc->get_pc = x86_cpu_get_pc;
  7920. cc->gdb_read_register = x86_cpu_gdb_read_register;
  7921. cc->gdb_write_register = x86_cpu_gdb_write_register;
  7922. cc->get_arch_id = x86_cpu_get_arch_id;
  7923. #ifndef CONFIG_USER_ONLY
  7924. cc->sysemu_ops = &i386_sysemu_ops;
  7925. #endif /* !CONFIG_USER_ONLY */
  7926. cc->gdb_arch_name = x86_gdb_arch_name;
  7927. #ifdef TARGET_X86_64
  7928. cc->gdb_core_xml_file = "i386-64bit.xml";
  7929. #else
  7930. cc->gdb_core_xml_file = "i386-32bit.xml";
  7931. #endif
  7932. cc->disas_set_info = x86_disas_set_info;
  7933. dc->user_creatable = true;
  7934. object_class_property_add(oc, "family", "int",
  7935. x86_cpuid_version_get_family,
  7936. x86_cpuid_version_set_family, NULL, NULL);
  7937. object_class_property_add(oc, "model", "int",
  7938. x86_cpuid_version_get_model,
  7939. x86_cpuid_version_set_model, NULL, NULL);
  7940. object_class_property_add(oc, "stepping", "int",
  7941. x86_cpuid_version_get_stepping,
  7942. x86_cpuid_version_set_stepping, NULL, NULL);
  7943. object_class_property_add_str(oc, "vendor",
  7944. x86_cpuid_get_vendor,
  7945. x86_cpuid_set_vendor);
  7946. object_class_property_add_str(oc, "model-id",
  7947. x86_cpuid_get_model_id,
  7948. x86_cpuid_set_model_id);
  7949. object_class_property_add(oc, "tsc-frequency", "int",
  7950. x86_cpuid_get_tsc_freq,
  7951. x86_cpuid_set_tsc_freq, NULL, NULL);
  7952. /*
  7953. * The "unavailable-features" property has the same semantics as
  7954. * CpuDefinitionInfo.unavailable-features on the "query-cpu-definitions"
  7955. * QMP command: they list the features that would have prevented the
  7956. * CPU from running if the "enforce" flag was set.
  7957. */
  7958. object_class_property_add(oc, "unavailable-features", "strList",
  7959. x86_cpu_get_unavailable_features,
  7960. NULL, NULL, NULL);
  7961. #if !defined(CONFIG_USER_ONLY)
  7962. object_class_property_add(oc, "crash-information", "GuestPanicInformation",
  7963. x86_cpu_get_crash_info_qom, NULL, NULL, NULL);
  7964. #endif
  7965. for (w = 0; w < FEATURE_WORDS; w++) {
  7966. int bitnr;
  7967. for (bitnr = 0; bitnr < 64; bitnr++) {
  7968. x86_cpu_register_feature_bit_props(xcc, w, bitnr);
  7969. }
  7970. }
  7971. }
  7972. static const TypeInfo x86_cpu_type_info = {
  7973. .name = TYPE_X86_CPU,
  7974. .parent = TYPE_CPU,
  7975. .instance_size = sizeof(X86CPU),
  7976. .instance_align = __alignof(X86CPU),
  7977. .instance_init = x86_cpu_initfn,
  7978. .instance_post_init = x86_cpu_post_initfn,
  7979. .abstract = true,
  7980. .class_size = sizeof(X86CPUClass),
  7981. .class_init = x86_cpu_common_class_init,
  7982. };
  7983. /* "base" CPU model, used by query-cpu-model-expansion */
  7984. static void x86_cpu_base_class_init(ObjectClass *oc, void *data)
  7985. {
  7986. X86CPUClass *xcc = X86_CPU_CLASS(oc);
  7987. xcc->static_model = true;
  7988. xcc->migration_safe = true;
  7989. xcc->model_description = "base CPU model type with no features enabled";
  7990. xcc->ordering = 8;
  7991. }
  7992. static const TypeInfo x86_base_cpu_type_info = {
  7993. .name = X86_CPU_TYPE_NAME("base"),
  7994. .parent = TYPE_X86_CPU,
  7995. .class_init = x86_cpu_base_class_init,
  7996. };
  7997. static void x86_cpu_register_types(void)
  7998. {
  7999. int i;
  8000. type_register_static(&x86_cpu_type_info);
  8001. for (i = 0; i < ARRAY_SIZE(builtin_x86_defs); i++) {
  8002. x86_register_cpudef_types(&builtin_x86_defs[i]);
  8003. }
  8004. type_register_static(&max_x86_cpu_type_info);
  8005. type_register_static(&x86_base_cpu_type_info);
  8006. }
  8007. type_init(x86_cpu_register_types)