Targets.cpp 218 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929
  1. //===--- Targets.cpp - Implement -arch option and targets -----------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. //
  10. // This file implements construction of a TargetInfo object from a
  11. // target triple.
  12. //
  13. //===----------------------------------------------------------------------===//
  14. #include "clang/Basic/TargetInfo.h"
  15. #include "clang/Basic/Builtins.h"
  16. #include "clang/Basic/Diagnostic.h"
  17. #include "clang/Basic/LangOptions.h"
  18. #include "clang/Basic/MacroBuilder.h"
  19. #include "clang/Basic/TargetBuiltins.h"
  20. #include "clang/Basic/TargetOptions.h"
  21. #include "llvm/ADT/APFloat.h"
  22. #include "llvm/ADT/STLExtras.h"
  23. #include "llvm/ADT/StringExtras.h"
  24. #include "llvm/ADT/StringRef.h"
  25. #include "llvm/ADT/StringSwitch.h"
  26. #include "llvm/ADT/Triple.h"
  27. #include "llvm/MC/MCSectionMachO.h"
  28. #include "llvm/Support/ErrorHandling.h"
  29. #include <algorithm>
  30. #include <memory>
  31. using namespace clang;
  32. //===----------------------------------------------------------------------===//
  33. // Common code shared among targets.
  34. //===----------------------------------------------------------------------===//
  35. /// DefineStd - Define a macro name and standard variants. For example if
  36. /// MacroName is "unix", then this will define "__unix", "__unix__", and "unix"
  37. /// when in GNU mode.
  38. static void DefineStd(MacroBuilder &Builder, StringRef MacroName,
  39. const LangOptions &Opts) {
  40. assert(MacroName[0] != '_' && "Identifier should be in the user's namespace");
  41. // If in GNU mode (e.g. -std=gnu99 but not -std=c99) define the raw identifier
  42. // in the user's namespace.
  43. if (Opts.GNUMode)
  44. Builder.defineMacro(MacroName);
  45. // Define __unix.
  46. Builder.defineMacro("__" + MacroName);
  47. // Define __unix__.
  48. Builder.defineMacro("__" + MacroName + "__");
  49. }
  50. static void defineCPUMacros(MacroBuilder &Builder, StringRef CPUName,
  51. bool Tuning = true) {
  52. Builder.defineMacro("__" + CPUName);
  53. Builder.defineMacro("__" + CPUName + "__");
  54. if (Tuning)
  55. Builder.defineMacro("__tune_" + CPUName + "__");
  56. }
  57. //===----------------------------------------------------------------------===//
  58. // Defines specific to certain operating systems.
  59. //===----------------------------------------------------------------------===//
  60. namespace {
  61. template<typename TgtInfo>
  62. class OSTargetInfo : public TgtInfo {
  63. protected:
  64. virtual void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  65. MacroBuilder &Builder) const=0;
  66. public:
  67. OSTargetInfo(const llvm::Triple &Triple) : TgtInfo(Triple) {}
  68. void getTargetDefines(const LangOptions &Opts,
  69. MacroBuilder &Builder) const override {
  70. TgtInfo::getTargetDefines(Opts, Builder);
  71. getOSDefines(Opts, TgtInfo::getTriple(), Builder);
  72. }
  73. };
  74. } // end anonymous namespace
  75. static void getDarwinDefines(MacroBuilder &Builder, const LangOptions &Opts,
  76. const llvm::Triple &Triple,
  77. StringRef &PlatformName,
  78. VersionTuple &PlatformMinVersion) {
  79. Builder.defineMacro("__APPLE_CC__", "6000");
  80. Builder.defineMacro("__APPLE__");
  81. Builder.defineMacro("OBJC_NEW_PROPERTIES");
  82. // AddressSanitizer doesn't play well with source fortification, which is on
  83. // by default on Darwin.
  84. if (Opts.Sanitize.has(SanitizerKind::Address))
  85. Builder.defineMacro("_FORTIFY_SOURCE", "0");
  86. if (!Opts.ObjCAutoRefCount) {
  87. // __weak is always defined, for use in blocks and with objc pointers.
  88. Builder.defineMacro("__weak", "__attribute__((objc_gc(weak)))");
  89. // Darwin defines __strong even in C mode (just to nothing).
  90. if (Opts.getGC() != LangOptions::NonGC)
  91. Builder.defineMacro("__strong", "__attribute__((objc_gc(strong)))");
  92. else
  93. Builder.defineMacro("__strong", "");
  94. // __unsafe_unretained is defined to nothing in non-ARC mode. We even
  95. // allow this in C, since one might have block pointers in structs that
  96. // are used in pure C code and in Objective-C ARC.
  97. Builder.defineMacro("__unsafe_unretained", "");
  98. }
  99. if (Opts.Static)
  100. Builder.defineMacro("__STATIC__");
  101. else
  102. Builder.defineMacro("__DYNAMIC__");
  103. if (Opts.POSIXThreads)
  104. Builder.defineMacro("_REENTRANT");
  105. // Get the platform type and version number from the triple.
  106. unsigned Maj, Min, Rev;
  107. if (Triple.isMacOSX()) {
  108. Triple.getMacOSXVersion(Maj, Min, Rev);
  109. PlatformName = "macosx";
  110. } else {
  111. Triple.getOSVersion(Maj, Min, Rev);
  112. PlatformName = llvm::Triple::getOSTypeName(Triple.getOS());
  113. }
  114. // If -target arch-pc-win32-macho option specified, we're
  115. // generating code for Win32 ABI. No need to emit
  116. // __ENVIRONMENT_XX_OS_VERSION_MIN_REQUIRED__.
  117. if (PlatformName == "win32") {
  118. PlatformMinVersion = VersionTuple(Maj, Min, Rev);
  119. return;
  120. }
  121. // Set the appropriate OS version define.
  122. if (Triple.isiOS()) {
  123. assert(Maj < 10 && Min < 100 && Rev < 100 && "Invalid version!");
  124. char Str[6];
  125. Str[0] = '0' + Maj;
  126. Str[1] = '0' + (Min / 10);
  127. Str[2] = '0' + (Min % 10);
  128. Str[3] = '0' + (Rev / 10);
  129. Str[4] = '0' + (Rev % 10);
  130. Str[5] = '\0';
  131. Builder.defineMacro("__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__",
  132. Str);
  133. } else if (Triple.isMacOSX()) {
  134. // Note that the Driver allows versions which aren't representable in the
  135. // define (because we only get a single digit for the minor and micro
  136. // revision numbers). So, we limit them to the maximum representable
  137. // version.
  138. assert(Maj < 100 && Min < 100 && Rev < 100 && "Invalid version!");
  139. char Str[7];
  140. if (Maj < 10 || (Maj == 10 && Min < 10)) {
  141. Str[0] = '0' + (Maj / 10);
  142. Str[1] = '0' + (Maj % 10);
  143. Str[2] = '0' + std::min(Min, 9U);
  144. Str[3] = '0' + std::min(Rev, 9U);
  145. Str[4] = '\0';
  146. } else {
  147. // Handle versions > 10.9.
  148. Str[0] = '0' + (Maj / 10);
  149. Str[1] = '0' + (Maj % 10);
  150. Str[2] = '0' + (Min / 10);
  151. Str[3] = '0' + (Min % 10);
  152. Str[4] = '0' + (Rev / 10);
  153. Str[5] = '0' + (Rev % 10);
  154. Str[6] = '\0';
  155. }
  156. Builder.defineMacro("__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__", Str);
  157. }
  158. // Tell users about the kernel if there is one.
  159. if (Triple.isOSDarwin())
  160. Builder.defineMacro("__MACH__");
  161. PlatformMinVersion = VersionTuple(Maj, Min, Rev);
  162. }
  163. namespace {
  164. template<typename Target>
  165. class DarwinTargetInfo : public OSTargetInfo<Target> {
  166. protected:
  167. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  168. MacroBuilder &Builder) const override {
  169. getDarwinDefines(Builder, Opts, Triple, this->PlatformName,
  170. this->PlatformMinVersion);
  171. }
  172. public:
  173. DarwinTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  174. this->TLSSupported = Triple.isMacOSX() && !Triple.isMacOSXVersionLT(10, 7);
  175. this->MCountName = "\01mcount";
  176. }
  177. std::string isValidSectionSpecifier(StringRef SR) const override {
  178. // Let MCSectionMachO validate this.
  179. StringRef Segment, Section;
  180. unsigned TAA, StubSize;
  181. bool HasTAA;
  182. return llvm::MCSectionMachO::ParseSectionSpecifier(SR, Segment, Section,
  183. TAA, HasTAA, StubSize);
  184. }
  185. const char *getStaticInitSectionSpecifier() const override {
  186. // FIXME: We should return 0 when building kexts.
  187. return "__TEXT,__StaticInit,regular,pure_instructions";
  188. }
  189. /// Darwin does not support protected visibility. Darwin's "default"
  190. /// is very similar to ELF's "protected"; Darwin requires a "weak"
  191. /// attribute on declarations that can be dynamically replaced.
  192. bool hasProtectedVisibility() const override {
  193. return false;
  194. }
  195. };
  196. // DragonFlyBSD Target
  197. template<typename Target>
  198. class DragonFlyBSDTargetInfo : public OSTargetInfo<Target> {
  199. protected:
  200. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  201. MacroBuilder &Builder) const override {
  202. // DragonFly defines; list based off of gcc output
  203. Builder.defineMacro("__DragonFly__");
  204. Builder.defineMacro("__DragonFly_cc_version", "100001");
  205. Builder.defineMacro("__ELF__");
  206. Builder.defineMacro("__KPRINTF_ATTRIBUTE__");
  207. Builder.defineMacro("__tune_i386__");
  208. DefineStd(Builder, "unix", Opts);
  209. }
  210. public:
  211. DragonFlyBSDTargetInfo(const llvm::Triple &Triple)
  212. : OSTargetInfo<Target>(Triple) {
  213. this->UserLabelPrefix = "";
  214. switch (Triple.getArch()) {
  215. default:
  216. case llvm::Triple::x86:
  217. case llvm::Triple::x86_64:
  218. this->MCountName = ".mcount";
  219. break;
  220. }
  221. }
  222. };
  223. // FreeBSD Target
  224. template<typename Target>
  225. class FreeBSDTargetInfo : public OSTargetInfo<Target> {
  226. protected:
  227. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  228. MacroBuilder &Builder) const override {
  229. // FreeBSD defines; list based off of gcc output
  230. unsigned Release = Triple.getOSMajorVersion();
  231. if (Release == 0U)
  232. Release = 8;
  233. Builder.defineMacro("__FreeBSD__", Twine(Release));
  234. Builder.defineMacro("__FreeBSD_cc_version", Twine(Release * 100000U + 1U));
  235. Builder.defineMacro("__KPRINTF_ATTRIBUTE__");
  236. DefineStd(Builder, "unix", Opts);
  237. Builder.defineMacro("__ELF__");
  238. // On FreeBSD, wchar_t contains the number of the code point as
  239. // used by the character set of the locale. These character sets are
  240. // not necessarily a superset of ASCII.
  241. //
  242. // FIXME: This is wrong; the macro refers to the numerical values
  243. // of wchar_t *literals*, which are not locale-dependent. However,
  244. // FreeBSD systems apparently depend on us getting this wrong, and
  245. // setting this to 1 is conforming even if all the basic source
  246. // character literals have the same encoding as char and wchar_t.
  247. Builder.defineMacro("__STDC_MB_MIGHT_NEQ_WC__", "1");
  248. }
  249. public:
  250. FreeBSDTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  251. this->UserLabelPrefix = "";
  252. switch (Triple.getArch()) {
  253. default:
  254. case llvm::Triple::x86:
  255. case llvm::Triple::x86_64:
  256. this->MCountName = ".mcount";
  257. break;
  258. case llvm::Triple::mips:
  259. case llvm::Triple::mipsel:
  260. case llvm::Triple::ppc:
  261. case llvm::Triple::ppc64:
  262. case llvm::Triple::ppc64le:
  263. this->MCountName = "_mcount";
  264. break;
  265. case llvm::Triple::arm:
  266. this->MCountName = "__mcount";
  267. break;
  268. }
  269. }
  270. };
  271. // GNU/kFreeBSD Target
  272. template<typename Target>
  273. class KFreeBSDTargetInfo : public OSTargetInfo<Target> {
  274. protected:
  275. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  276. MacroBuilder &Builder) const override {
  277. // GNU/kFreeBSD defines; list based off of gcc output
  278. DefineStd(Builder, "unix", Opts);
  279. Builder.defineMacro("__FreeBSD_kernel__");
  280. Builder.defineMacro("__GLIBC__");
  281. Builder.defineMacro("__ELF__");
  282. if (Opts.POSIXThreads)
  283. Builder.defineMacro("_REENTRANT");
  284. if (Opts.CPlusPlus)
  285. Builder.defineMacro("_GNU_SOURCE");
  286. }
  287. public:
  288. KFreeBSDTargetInfo(const llvm::Triple &Triple)
  289. : OSTargetInfo<Target>(Triple) {
  290. this->UserLabelPrefix = "";
  291. }
  292. };
  293. // Minix Target
  294. template<typename Target>
  295. class MinixTargetInfo : public OSTargetInfo<Target> {
  296. protected:
  297. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  298. MacroBuilder &Builder) const override {
  299. // Minix defines
  300. Builder.defineMacro("__minix", "3");
  301. Builder.defineMacro("_EM_WSIZE", "4");
  302. Builder.defineMacro("_EM_PSIZE", "4");
  303. Builder.defineMacro("_EM_SSIZE", "2");
  304. Builder.defineMacro("_EM_LSIZE", "4");
  305. Builder.defineMacro("_EM_FSIZE", "4");
  306. Builder.defineMacro("_EM_DSIZE", "8");
  307. Builder.defineMacro("__ELF__");
  308. DefineStd(Builder, "unix", Opts);
  309. }
  310. public:
  311. MinixTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  312. this->UserLabelPrefix = "";
  313. }
  314. };
  315. // Linux target
  316. template<typename Target>
  317. class LinuxTargetInfo : public OSTargetInfo<Target> {
  318. protected:
  319. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  320. MacroBuilder &Builder) const override {
  321. // Linux defines; list based off of gcc output
  322. DefineStd(Builder, "unix", Opts);
  323. DefineStd(Builder, "linux", Opts);
  324. Builder.defineMacro("__gnu_linux__");
  325. Builder.defineMacro("__ELF__");
  326. if (Triple.getEnvironment() == llvm::Triple::Android)
  327. Builder.defineMacro("__ANDROID__", "1");
  328. if (Opts.POSIXThreads)
  329. Builder.defineMacro("_REENTRANT");
  330. if (Opts.CPlusPlus)
  331. Builder.defineMacro("_GNU_SOURCE");
  332. }
  333. public:
  334. LinuxTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  335. this->UserLabelPrefix = "";
  336. this->WIntType = TargetInfo::UnsignedInt;
  337. switch (Triple.getArch()) {
  338. default:
  339. break;
  340. case llvm::Triple::ppc:
  341. case llvm::Triple::ppc64:
  342. case llvm::Triple::ppc64le:
  343. this->MCountName = "_mcount";
  344. break;
  345. }
  346. }
  347. const char *getStaticInitSectionSpecifier() const override {
  348. return ".text.startup";
  349. }
  350. };
  351. // NetBSD Target
  352. template<typename Target>
  353. class NetBSDTargetInfo : public OSTargetInfo<Target> {
  354. protected:
  355. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  356. MacroBuilder &Builder) const override {
  357. // NetBSD defines; list based off of gcc output
  358. Builder.defineMacro("__NetBSD__");
  359. Builder.defineMacro("__unix__");
  360. Builder.defineMacro("__ELF__");
  361. if (Opts.POSIXThreads)
  362. Builder.defineMacro("_POSIX_THREADS");
  363. switch (Triple.getArch()) {
  364. default:
  365. break;
  366. case llvm::Triple::arm:
  367. case llvm::Triple::armeb:
  368. case llvm::Triple::thumb:
  369. case llvm::Triple::thumbeb:
  370. Builder.defineMacro("__ARM_DWARF_EH__");
  371. break;
  372. }
  373. }
  374. public:
  375. NetBSDTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  376. this->UserLabelPrefix = "";
  377. }
  378. };
  379. // OpenBSD Target
  380. template<typename Target>
  381. class OpenBSDTargetInfo : public OSTargetInfo<Target> {
  382. protected:
  383. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  384. MacroBuilder &Builder) const override {
  385. // OpenBSD defines; list based off of gcc output
  386. Builder.defineMacro("__OpenBSD__");
  387. DefineStd(Builder, "unix", Opts);
  388. Builder.defineMacro("__ELF__");
  389. if (Opts.POSIXThreads)
  390. Builder.defineMacro("_REENTRANT");
  391. }
  392. public:
  393. OpenBSDTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  394. this->UserLabelPrefix = "";
  395. this->TLSSupported = false;
  396. switch (Triple.getArch()) {
  397. default:
  398. case llvm::Triple::x86:
  399. case llvm::Triple::x86_64:
  400. case llvm::Triple::arm:
  401. case llvm::Triple::sparc:
  402. this->MCountName = "__mcount";
  403. break;
  404. case llvm::Triple::mips64:
  405. case llvm::Triple::mips64el:
  406. case llvm::Triple::ppc:
  407. case llvm::Triple::sparcv9:
  408. this->MCountName = "_mcount";
  409. break;
  410. }
  411. }
  412. };
  413. // Bitrig Target
  414. template<typename Target>
  415. class BitrigTargetInfo : public OSTargetInfo<Target> {
  416. protected:
  417. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  418. MacroBuilder &Builder) const override {
  419. // Bitrig defines; list based off of gcc output
  420. Builder.defineMacro("__Bitrig__");
  421. DefineStd(Builder, "unix", Opts);
  422. Builder.defineMacro("__ELF__");
  423. if (Opts.POSIXThreads)
  424. Builder.defineMacro("_REENTRANT");
  425. }
  426. public:
  427. BitrigTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  428. this->UserLabelPrefix = "";
  429. this->MCountName = "__mcount";
  430. }
  431. };
  432. // PSP Target
  433. template<typename Target>
  434. class PSPTargetInfo : public OSTargetInfo<Target> {
  435. protected:
  436. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  437. MacroBuilder &Builder) const override {
  438. // PSP defines; list based on the output of the pspdev gcc toolchain.
  439. Builder.defineMacro("PSP");
  440. Builder.defineMacro("_PSP");
  441. Builder.defineMacro("__psp__");
  442. Builder.defineMacro("__ELF__");
  443. }
  444. public:
  445. PSPTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  446. this->UserLabelPrefix = "";
  447. }
  448. };
  449. // PS3 PPU Target
  450. template<typename Target>
  451. class PS3PPUTargetInfo : public OSTargetInfo<Target> {
  452. protected:
  453. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  454. MacroBuilder &Builder) const override {
  455. // PS3 PPU defines.
  456. Builder.defineMacro("__PPC__");
  457. Builder.defineMacro("__PPU__");
  458. Builder.defineMacro("__CELLOS_LV2__");
  459. Builder.defineMacro("__ELF__");
  460. Builder.defineMacro("__LP32__");
  461. Builder.defineMacro("_ARCH_PPC64");
  462. Builder.defineMacro("__powerpc64__");
  463. }
  464. public:
  465. PS3PPUTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  466. this->UserLabelPrefix = "";
  467. this->LongWidth = this->LongAlign = 32;
  468. this->PointerWidth = this->PointerAlign = 32;
  469. this->IntMaxType = TargetInfo::SignedLongLong;
  470. this->Int64Type = TargetInfo::SignedLongLong;
  471. this->SizeType = TargetInfo::UnsignedInt;
  472. this->DescriptionString = "E-m:e-p:32:32-i64:64-n32:64";
  473. }
  474. };
  475. template <typename Target>
  476. class PS4OSTargetInfo : public OSTargetInfo<Target> {
  477. protected:
  478. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  479. MacroBuilder &Builder) const override {
  480. Builder.defineMacro("__FreeBSD__", "9");
  481. Builder.defineMacro("__FreeBSD_cc_version", "900001");
  482. Builder.defineMacro("__KPRINTF_ATTRIBUTE__");
  483. DefineStd(Builder, "unix", Opts);
  484. Builder.defineMacro("__ELF__");
  485. Builder.defineMacro("__PS4__");
  486. }
  487. public:
  488. PS4OSTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  489. this->WCharType = this->UnsignedShort;
  490. this->UserLabelPrefix = "";
  491. switch (Triple.getArch()) {
  492. default:
  493. case llvm::Triple::x86_64:
  494. this->MCountName = ".mcount";
  495. break;
  496. }
  497. }
  498. };
  499. // Solaris target
  500. template<typename Target>
  501. class SolarisTargetInfo : public OSTargetInfo<Target> {
  502. protected:
  503. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  504. MacroBuilder &Builder) const override {
  505. DefineStd(Builder, "sun", Opts);
  506. DefineStd(Builder, "unix", Opts);
  507. Builder.defineMacro("__ELF__");
  508. Builder.defineMacro("__svr4__");
  509. Builder.defineMacro("__SVR4");
  510. // Solaris headers require _XOPEN_SOURCE to be set to 600 for C99 and
  511. // newer, but to 500 for everything else. feature_test.h has a check to
  512. // ensure that you are not using C99 with an old version of X/Open or C89
  513. // with a new version.
  514. if (Opts.C99)
  515. Builder.defineMacro("_XOPEN_SOURCE", "600");
  516. else
  517. Builder.defineMacro("_XOPEN_SOURCE", "500");
  518. if (Opts.CPlusPlus)
  519. Builder.defineMacro("__C99FEATURES__");
  520. Builder.defineMacro("_LARGEFILE_SOURCE");
  521. Builder.defineMacro("_LARGEFILE64_SOURCE");
  522. Builder.defineMacro("__EXTENSIONS__");
  523. Builder.defineMacro("_REENTRANT");
  524. }
  525. public:
  526. SolarisTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  527. this->UserLabelPrefix = "";
  528. this->WCharType = this->SignedInt;
  529. // FIXME: WIntType should be SignedLong
  530. }
  531. };
  532. // Windows target
  533. template<typename Target>
  534. class WindowsTargetInfo : public OSTargetInfo<Target> {
  535. protected:
  536. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  537. MacroBuilder &Builder) const override {
  538. Builder.defineMacro("_WIN32");
  539. }
  540. void getVisualStudioDefines(const LangOptions &Opts,
  541. MacroBuilder &Builder) const {
  542. if (Opts.CPlusPlus) {
  543. if (Opts.RTTIData)
  544. Builder.defineMacro("_CPPRTTI");
  545. if (Opts.CXXExceptions)
  546. Builder.defineMacro("_CPPUNWIND");
  547. }
  548. if (!Opts.CharIsSigned)
  549. Builder.defineMacro("_CHAR_UNSIGNED");
  550. // FIXME: POSIXThreads isn't exactly the option this should be defined for,
  551. // but it works for now.
  552. if (Opts.POSIXThreads)
  553. Builder.defineMacro("_MT");
  554. if (Opts.MSCompatibilityVersion) {
  555. Builder.defineMacro("_MSC_VER",
  556. Twine(Opts.MSCompatibilityVersion / 100000));
  557. Builder.defineMacro("_MSC_FULL_VER", Twine(Opts.MSCompatibilityVersion));
  558. // FIXME We cannot encode the revision information into 32-bits
  559. Builder.defineMacro("_MSC_BUILD", Twine(1));
  560. }
  561. if (Opts.MicrosoftExt) {
  562. Builder.defineMacro("_MSC_EXTENSIONS");
  563. if (Opts.CPlusPlus11) {
  564. Builder.defineMacro("_RVALUE_REFERENCES_V2_SUPPORTED");
  565. Builder.defineMacro("_RVALUE_REFERENCES_SUPPORTED");
  566. Builder.defineMacro("_NATIVE_NULLPTR_SUPPORTED");
  567. }
  568. }
  569. Builder.defineMacro("_INTEGRAL_MAX_BITS", "64");
  570. }
  571. public:
  572. WindowsTargetInfo(const llvm::Triple &Triple)
  573. : OSTargetInfo<Target>(Triple) {}
  574. };
  575. template <typename Target>
  576. class NaClTargetInfo : public OSTargetInfo<Target> {
  577. protected:
  578. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  579. MacroBuilder &Builder) const override {
  580. if (Opts.POSIXThreads)
  581. Builder.defineMacro("_REENTRANT");
  582. if (Opts.CPlusPlus)
  583. Builder.defineMacro("_GNU_SOURCE");
  584. DefineStd(Builder, "unix", Opts);
  585. Builder.defineMacro("__ELF__");
  586. Builder.defineMacro("__native_client__");
  587. }
  588. public:
  589. NaClTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  590. this->UserLabelPrefix = "";
  591. this->LongAlign = 32;
  592. this->LongWidth = 32;
  593. this->PointerAlign = 32;
  594. this->PointerWidth = 32;
  595. this->IntMaxType = TargetInfo::SignedLongLong;
  596. this->Int64Type = TargetInfo::SignedLongLong;
  597. this->DoubleAlign = 64;
  598. this->LongDoubleWidth = 64;
  599. this->LongDoubleAlign = 64;
  600. this->LongLongWidth = 64;
  601. this->LongLongAlign = 64;
  602. this->SizeType = TargetInfo::UnsignedInt;
  603. this->PtrDiffType = TargetInfo::SignedInt;
  604. this->IntPtrType = TargetInfo::SignedInt;
  605. // RegParmMax is inherited from the underlying architecture
  606. this->LongDoubleFormat = &llvm::APFloat::IEEEdouble;
  607. if (Triple.getArch() == llvm::Triple::arm) {
  608. this->DescriptionString =
  609. "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S128";
  610. } else if (Triple.getArch() == llvm::Triple::x86) {
  611. this->DescriptionString = "e-m:e-p:32:32-i64:64-n8:16:32-S128";
  612. } else if (Triple.getArch() == llvm::Triple::x86_64) {
  613. this->DescriptionString = "e-m:e-p:32:32-i64:64-n8:16:32:64-S128";
  614. } else if (Triple.getArch() == llvm::Triple::mipsel) {
  615. // Handled on mips' setDescriptionString.
  616. } else {
  617. assert(Triple.getArch() == llvm::Triple::le32);
  618. this->DescriptionString = "e-p:32:32-i64:64";
  619. }
  620. }
  621. };
  622. } // end anonymous namespace.
  623. //===----------------------------------------------------------------------===//
  624. // Specific target implementations.
  625. //===----------------------------------------------------------------------===//
  626. namespace {
  627. // PPC abstract base class
  628. class PPCTargetInfo : public TargetInfo {
  629. static const Builtin::Info BuiltinInfo[];
  630. static const char * const GCCRegNames[];
  631. static const TargetInfo::GCCRegAlias GCCRegAliases[];
  632. std::string CPU;
  633. // Target cpu features.
  634. bool HasVSX;
  635. bool HasP8Vector;
  636. protected:
  637. std::string ABI;
  638. public:
  639. PPCTargetInfo(const llvm::Triple &Triple)
  640. : TargetInfo(Triple), HasVSX(false), HasP8Vector(false) {
  641. BigEndian = (Triple.getArch() != llvm::Triple::ppc64le);
  642. LongDoubleWidth = LongDoubleAlign = 128;
  643. LongDoubleFormat = &llvm::APFloat::PPCDoubleDouble;
  644. }
  645. /// \brief Flags for architecture specific defines.
  646. typedef enum {
  647. ArchDefineNone = 0,
  648. ArchDefineName = 1 << 0, // <name> is substituted for arch name.
  649. ArchDefinePpcgr = 1 << 1,
  650. ArchDefinePpcsq = 1 << 2,
  651. ArchDefine440 = 1 << 3,
  652. ArchDefine603 = 1 << 4,
  653. ArchDefine604 = 1 << 5,
  654. ArchDefinePwr4 = 1 << 6,
  655. ArchDefinePwr5 = 1 << 7,
  656. ArchDefinePwr5x = 1 << 8,
  657. ArchDefinePwr6 = 1 << 9,
  658. ArchDefinePwr6x = 1 << 10,
  659. ArchDefinePwr7 = 1 << 11,
  660. ArchDefinePwr8 = 1 << 12,
  661. ArchDefineA2 = 1 << 13,
  662. ArchDefineA2q = 1 << 14
  663. } ArchDefineTypes;
  664. // Note: GCC recognizes the following additional cpus:
  665. // 401, 403, 405, 405fp, 440fp, 464, 464fp, 476, 476fp, 505, 740, 801,
  666. // 821, 823, 8540, 8548, e300c2, e300c3, e500mc64, e6500, 860, cell,
  667. // titan, rs64.
  668. bool setCPU(const std::string &Name) override {
  669. bool CPUKnown = llvm::StringSwitch<bool>(Name)
  670. .Case("generic", true)
  671. .Case("440", true)
  672. .Case("450", true)
  673. .Case("601", true)
  674. .Case("602", true)
  675. .Case("603", true)
  676. .Case("603e", true)
  677. .Case("603ev", true)
  678. .Case("604", true)
  679. .Case("604e", true)
  680. .Case("620", true)
  681. .Case("630", true)
  682. .Case("g3", true)
  683. .Case("7400", true)
  684. .Case("g4", true)
  685. .Case("7450", true)
  686. .Case("g4+", true)
  687. .Case("750", true)
  688. .Case("970", true)
  689. .Case("g5", true)
  690. .Case("a2", true)
  691. .Case("a2q", true)
  692. .Case("e500mc", true)
  693. .Case("e5500", true)
  694. .Case("power3", true)
  695. .Case("pwr3", true)
  696. .Case("power4", true)
  697. .Case("pwr4", true)
  698. .Case("power5", true)
  699. .Case("pwr5", true)
  700. .Case("power5x", true)
  701. .Case("pwr5x", true)
  702. .Case("power6", true)
  703. .Case("pwr6", true)
  704. .Case("power6x", true)
  705. .Case("pwr6x", true)
  706. .Case("power7", true)
  707. .Case("pwr7", true)
  708. .Case("power8", true)
  709. .Case("pwr8", true)
  710. .Case("powerpc", true)
  711. .Case("ppc", true)
  712. .Case("powerpc64", true)
  713. .Case("ppc64", true)
  714. .Case("powerpc64le", true)
  715. .Case("ppc64le", true)
  716. .Default(false);
  717. if (CPUKnown)
  718. CPU = Name;
  719. return CPUKnown;
  720. }
  721. StringRef getABI() const override { return ABI; }
  722. void getTargetBuiltins(const Builtin::Info *&Records,
  723. unsigned &NumRecords) const override {
  724. Records = BuiltinInfo;
  725. NumRecords = clang::PPC::LastTSBuiltin-Builtin::FirstTSBuiltin;
  726. }
  727. bool isCLZForZeroUndef() const override { return false; }
  728. void getTargetDefines(const LangOptions &Opts,
  729. MacroBuilder &Builder) const override;
  730. void getDefaultFeatures(llvm::StringMap<bool> &Features) const override;
  731. bool handleTargetFeatures(std::vector<std::string> &Features,
  732. DiagnosticsEngine &Diags) override;
  733. bool hasFeature(StringRef Feature) const override;
  734. void getGCCRegNames(const char * const *&Names,
  735. unsigned &NumNames) const override;
  736. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  737. unsigned &NumAliases) const override;
  738. bool validateAsmConstraint(const char *&Name,
  739. TargetInfo::ConstraintInfo &Info) const override {
  740. switch (*Name) {
  741. default: return false;
  742. case 'O': // Zero
  743. break;
  744. case 'b': // Base register
  745. case 'f': // Floating point register
  746. Info.setAllowsRegister();
  747. break;
  748. // FIXME: The following are added to allow parsing.
  749. // I just took a guess at what the actions should be.
  750. // Also, is more specific checking needed? I.e. specific registers?
  751. case 'd': // Floating point register (containing 64-bit value)
  752. case 'v': // Altivec vector register
  753. Info.setAllowsRegister();
  754. break;
  755. case 'w':
  756. switch (Name[1]) {
  757. case 'd':// VSX vector register to hold vector double data
  758. case 'f':// VSX vector register to hold vector float data
  759. case 's':// VSX vector register to hold scalar float data
  760. case 'a':// Any VSX register
  761. case 'c':// An individual CR bit
  762. break;
  763. default:
  764. return false;
  765. }
  766. Info.setAllowsRegister();
  767. Name++; // Skip over 'w'.
  768. break;
  769. case 'h': // `MQ', `CTR', or `LINK' register
  770. case 'q': // `MQ' register
  771. case 'c': // `CTR' register
  772. case 'l': // `LINK' register
  773. case 'x': // `CR' register (condition register) number 0
  774. case 'y': // `CR' register (condition register)
  775. case 'z': // `XER[CA]' carry bit (part of the XER register)
  776. Info.setAllowsRegister();
  777. break;
  778. case 'I': // Signed 16-bit constant
  779. case 'J': // Unsigned 16-bit constant shifted left 16 bits
  780. // (use `L' instead for SImode constants)
  781. case 'K': // Unsigned 16-bit constant
  782. case 'L': // Signed 16-bit constant shifted left 16 bits
  783. case 'M': // Constant larger than 31
  784. case 'N': // Exact power of 2
  785. case 'P': // Constant whose negation is a signed 16-bit constant
  786. case 'G': // Floating point constant that can be loaded into a
  787. // register with one instruction per word
  788. case 'H': // Integer/Floating point constant that can be loaded
  789. // into a register using three instructions
  790. break;
  791. case 'm': // Memory operand. Note that on PowerPC targets, m can
  792. // include addresses that update the base register. It
  793. // is therefore only safe to use `m' in an asm statement
  794. // if that asm statement accesses the operand exactly once.
  795. // The asm statement must also use `%U<opno>' as a
  796. // placeholder for the "update" flag in the corresponding
  797. // load or store instruction. For example:
  798. // asm ("st%U0 %1,%0" : "=m" (mem) : "r" (val));
  799. // is correct but:
  800. // asm ("st %1,%0" : "=m" (mem) : "r" (val));
  801. // is not. Use es rather than m if you don't want the base
  802. // register to be updated.
  803. case 'e':
  804. if (Name[1] != 's')
  805. return false;
  806. // es: A "stable" memory operand; that is, one which does not
  807. // include any automodification of the base register. Unlike
  808. // `m', this constraint can be used in asm statements that
  809. // might access the operand several times, or that might not
  810. // access it at all.
  811. Info.setAllowsMemory();
  812. Name++; // Skip over 'e'.
  813. break;
  814. case 'Q': // Memory operand that is an offset from a register (it is
  815. // usually better to use `m' or `es' in asm statements)
  816. case 'Z': // Memory operand that is an indexed or indirect from a
  817. // register (it is usually better to use `m' or `es' in
  818. // asm statements)
  819. Info.setAllowsMemory();
  820. Info.setAllowsRegister();
  821. break;
  822. case 'R': // AIX TOC entry
  823. case 'a': // Address operand that is an indexed or indirect from a
  824. // register (`p' is preferable for asm statements)
  825. case 'S': // Constant suitable as a 64-bit mask operand
  826. case 'T': // Constant suitable as a 32-bit mask operand
  827. case 'U': // System V Release 4 small data area reference
  828. case 't': // AND masks that can be performed by two rldic{l, r}
  829. // instructions
  830. case 'W': // Vector constant that does not require memory
  831. case 'j': // Vector constant that is all zeros.
  832. break;
  833. // End FIXME.
  834. }
  835. return true;
  836. }
  837. std::string convertConstraint(const char *&Constraint) const override {
  838. std::string R;
  839. switch (*Constraint) {
  840. case 'e':
  841. case 'w':
  842. // Two-character constraint; add "^" hint for later parsing.
  843. R = std::string("^") + std::string(Constraint, 2);
  844. Constraint++;
  845. break;
  846. default:
  847. return TargetInfo::convertConstraint(Constraint);
  848. }
  849. return R;
  850. }
  851. const char *getClobbers() const override {
  852. return "";
  853. }
  854. int getEHDataRegisterNumber(unsigned RegNo) const override {
  855. if (RegNo == 0) return 3;
  856. if (RegNo == 1) return 4;
  857. return -1;
  858. }
  859. };
  860. const Builtin::Info PPCTargetInfo::BuiltinInfo[] = {
  861. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  862. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  863. ALL_LANGUAGES },
  864. #include "clang/Basic/BuiltinsPPC.def"
  865. };
  866. /// handleTargetFeatures - Perform initialization based on the user
  867. /// configured set of features.
  868. bool PPCTargetInfo::handleTargetFeatures(std::vector<std::string> &Features,
  869. DiagnosticsEngine &Diags) {
  870. for (unsigned i = 0, e = Features.size(); i !=e; ++i) {
  871. // Ignore disabled features.
  872. if (Features[i][0] == '-')
  873. continue;
  874. StringRef Feature = StringRef(Features[i]).substr(1);
  875. if (Feature == "vsx") {
  876. HasVSX = true;
  877. continue;
  878. }
  879. if (Feature == "power8-vector") {
  880. HasP8Vector = true;
  881. continue;
  882. }
  883. // TODO: Finish this list and add an assert that we've handled them
  884. // all.
  885. }
  886. return true;
  887. }
  888. /// PPCTargetInfo::getTargetDefines - Return a set of the PowerPC-specific
  889. /// #defines that are not tied to a specific subtarget.
  890. void PPCTargetInfo::getTargetDefines(const LangOptions &Opts,
  891. MacroBuilder &Builder) const {
  892. // Target identification.
  893. Builder.defineMacro("__ppc__");
  894. Builder.defineMacro("__PPC__");
  895. Builder.defineMacro("_ARCH_PPC");
  896. Builder.defineMacro("__powerpc__");
  897. Builder.defineMacro("__POWERPC__");
  898. if (PointerWidth == 64) {
  899. Builder.defineMacro("_ARCH_PPC64");
  900. Builder.defineMacro("__powerpc64__");
  901. Builder.defineMacro("__ppc64__");
  902. Builder.defineMacro("__PPC64__");
  903. }
  904. // Target properties.
  905. if (getTriple().getArch() == llvm::Triple::ppc64le) {
  906. Builder.defineMacro("_LITTLE_ENDIAN");
  907. } else {
  908. if (getTriple().getOS() != llvm::Triple::NetBSD &&
  909. getTriple().getOS() != llvm::Triple::OpenBSD)
  910. Builder.defineMacro("_BIG_ENDIAN");
  911. }
  912. // ABI options.
  913. if (ABI == "elfv1")
  914. Builder.defineMacro("_CALL_ELF", "1");
  915. if (ABI == "elfv2")
  916. Builder.defineMacro("_CALL_ELF", "2");
  917. // Subtarget options.
  918. Builder.defineMacro("__NATURAL_ALIGNMENT__");
  919. Builder.defineMacro("__REGISTER_PREFIX__", "");
  920. // FIXME: Should be controlled by command line option.
  921. if (LongDoubleWidth == 128)
  922. Builder.defineMacro("__LONG_DOUBLE_128__");
  923. if (Opts.AltiVec) {
  924. Builder.defineMacro("__VEC__", "10206");
  925. Builder.defineMacro("__ALTIVEC__");
  926. }
  927. // CPU identification.
  928. ArchDefineTypes defs = (ArchDefineTypes)llvm::StringSwitch<int>(CPU)
  929. .Case("440", ArchDefineName)
  930. .Case("450", ArchDefineName | ArchDefine440)
  931. .Case("601", ArchDefineName)
  932. .Case("602", ArchDefineName | ArchDefinePpcgr)
  933. .Case("603", ArchDefineName | ArchDefinePpcgr)
  934. .Case("603e", ArchDefineName | ArchDefine603 | ArchDefinePpcgr)
  935. .Case("603ev", ArchDefineName | ArchDefine603 | ArchDefinePpcgr)
  936. .Case("604", ArchDefineName | ArchDefinePpcgr)
  937. .Case("604e", ArchDefineName | ArchDefine604 | ArchDefinePpcgr)
  938. .Case("620", ArchDefineName | ArchDefinePpcgr)
  939. .Case("630", ArchDefineName | ArchDefinePpcgr)
  940. .Case("7400", ArchDefineName | ArchDefinePpcgr)
  941. .Case("7450", ArchDefineName | ArchDefinePpcgr)
  942. .Case("750", ArchDefineName | ArchDefinePpcgr)
  943. .Case("970", ArchDefineName | ArchDefinePwr4 | ArchDefinePpcgr
  944. | ArchDefinePpcsq)
  945. .Case("a2", ArchDefineA2)
  946. .Case("a2q", ArchDefineName | ArchDefineA2 | ArchDefineA2q)
  947. .Case("pwr3", ArchDefinePpcgr)
  948. .Case("pwr4", ArchDefineName | ArchDefinePpcgr | ArchDefinePpcsq)
  949. .Case("pwr5", ArchDefineName | ArchDefinePwr4 | ArchDefinePpcgr
  950. | ArchDefinePpcsq)
  951. .Case("pwr5x", ArchDefineName | ArchDefinePwr5 | ArchDefinePwr4
  952. | ArchDefinePpcgr | ArchDefinePpcsq)
  953. .Case("pwr6", ArchDefineName | ArchDefinePwr5x | ArchDefinePwr5
  954. | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
  955. .Case("pwr6x", ArchDefineName | ArchDefinePwr6 | ArchDefinePwr5x
  956. | ArchDefinePwr5 | ArchDefinePwr4 | ArchDefinePpcgr
  957. | ArchDefinePpcsq)
  958. .Case("pwr7", ArchDefineName | ArchDefinePwr6x | ArchDefinePwr6
  959. | ArchDefinePwr5x | ArchDefinePwr5 | ArchDefinePwr4
  960. | ArchDefinePpcgr | ArchDefinePpcsq)
  961. .Case("pwr8", ArchDefineName | ArchDefinePwr7 | ArchDefinePwr6x
  962. | ArchDefinePwr6 | ArchDefinePwr5x | ArchDefinePwr5
  963. | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
  964. .Case("power3", ArchDefinePpcgr)
  965. .Case("power4", ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
  966. .Case("power5", ArchDefinePwr5 | ArchDefinePwr4 | ArchDefinePpcgr
  967. | ArchDefinePpcsq)
  968. .Case("power5x", ArchDefinePwr5x | ArchDefinePwr5 | ArchDefinePwr4
  969. | ArchDefinePpcgr | ArchDefinePpcsq)
  970. .Case("power6", ArchDefinePwr6 | ArchDefinePwr5x | ArchDefinePwr5
  971. | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
  972. .Case("power6x", ArchDefinePwr6x | ArchDefinePwr6 | ArchDefinePwr5x
  973. | ArchDefinePwr5 | ArchDefinePwr4 | ArchDefinePpcgr
  974. | ArchDefinePpcsq)
  975. .Case("power7", ArchDefinePwr7 | ArchDefinePwr6x | ArchDefinePwr6
  976. | ArchDefinePwr5x | ArchDefinePwr5 | ArchDefinePwr4
  977. | ArchDefinePpcgr | ArchDefinePpcsq)
  978. .Case("power8", ArchDefinePwr8 | ArchDefinePwr7 | ArchDefinePwr6x
  979. | ArchDefinePwr6 | ArchDefinePwr5x | ArchDefinePwr5
  980. | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
  981. .Default(ArchDefineNone);
  982. if (defs & ArchDefineName)
  983. Builder.defineMacro(Twine("_ARCH_", StringRef(CPU).upper()));
  984. if (defs & ArchDefinePpcgr)
  985. Builder.defineMacro("_ARCH_PPCGR");
  986. if (defs & ArchDefinePpcsq)
  987. Builder.defineMacro("_ARCH_PPCSQ");
  988. if (defs & ArchDefine440)
  989. Builder.defineMacro("_ARCH_440");
  990. if (defs & ArchDefine603)
  991. Builder.defineMacro("_ARCH_603");
  992. if (defs & ArchDefine604)
  993. Builder.defineMacro("_ARCH_604");
  994. if (defs & ArchDefinePwr4)
  995. Builder.defineMacro("_ARCH_PWR4");
  996. if (defs & ArchDefinePwr5)
  997. Builder.defineMacro("_ARCH_PWR5");
  998. if (defs & ArchDefinePwr5x)
  999. Builder.defineMacro("_ARCH_PWR5X");
  1000. if (defs & ArchDefinePwr6)
  1001. Builder.defineMacro("_ARCH_PWR6");
  1002. if (defs & ArchDefinePwr6x)
  1003. Builder.defineMacro("_ARCH_PWR6X");
  1004. if (defs & ArchDefinePwr7)
  1005. Builder.defineMacro("_ARCH_PWR7");
  1006. if (defs & ArchDefinePwr8)
  1007. Builder.defineMacro("_ARCH_PWR8");
  1008. if (defs & ArchDefineA2)
  1009. Builder.defineMacro("_ARCH_A2");
  1010. if (defs & ArchDefineA2q) {
  1011. Builder.defineMacro("_ARCH_A2Q");
  1012. Builder.defineMacro("_ARCH_QP");
  1013. }
  1014. if (getTriple().getVendor() == llvm::Triple::BGQ) {
  1015. Builder.defineMacro("__bg__");
  1016. Builder.defineMacro("__THW_BLUEGENE__");
  1017. Builder.defineMacro("__bgq__");
  1018. Builder.defineMacro("__TOS_BGQ__");
  1019. }
  1020. if (HasVSX)
  1021. Builder.defineMacro("__VSX__");
  1022. if (HasP8Vector)
  1023. Builder.defineMacro("__POWER8_VECTOR__");
  1024. // FIXME: The following are not yet generated here by Clang, but are
  1025. // generated by GCC:
  1026. //
  1027. // _SOFT_FLOAT_
  1028. // __RECIP_PRECISION__
  1029. // __APPLE_ALTIVEC__
  1030. // __RECIP__
  1031. // __RECIPF__
  1032. // __RSQRTE__
  1033. // __RSQRTEF__
  1034. // _SOFT_DOUBLE_
  1035. // __NO_LWSYNC__
  1036. // __HAVE_BSWAP__
  1037. // __LONGDOUBLE128
  1038. // __CMODEL_MEDIUM__
  1039. // __CMODEL_LARGE__
  1040. // _CALL_SYSV
  1041. // _CALL_DARWIN
  1042. // __NO_FPRS__
  1043. }
  1044. void PPCTargetInfo::getDefaultFeatures(llvm::StringMap<bool> &Features) const {
  1045. Features["altivec"] = llvm::StringSwitch<bool>(CPU)
  1046. .Case("7400", true)
  1047. .Case("g4", true)
  1048. .Case("7450", true)
  1049. .Case("g4+", true)
  1050. .Case("970", true)
  1051. .Case("g5", true)
  1052. .Case("pwr6", true)
  1053. .Case("pwr7", true)
  1054. .Case("pwr8", true)
  1055. .Case("ppc64", true)
  1056. .Case("ppc64le", true)
  1057. .Default(false);
  1058. Features["qpx"] = (CPU == "a2q");
  1059. }
  1060. bool PPCTargetInfo::hasFeature(StringRef Feature) const {
  1061. return llvm::StringSwitch<bool>(Feature)
  1062. .Case("powerpc", true)
  1063. .Case("vsx", HasVSX)
  1064. .Case("power8-vector", HasP8Vector)
  1065. .Default(false);
  1066. }
  1067. const char * const PPCTargetInfo::GCCRegNames[] = {
  1068. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  1069. "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
  1070. "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
  1071. "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31",
  1072. "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
  1073. "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
  1074. "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
  1075. "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31",
  1076. "mq", "lr", "ctr", "ap",
  1077. "cr0", "cr1", "cr2", "cr3", "cr4", "cr5", "cr6", "cr7",
  1078. "xer",
  1079. "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v7",
  1080. "v8", "v9", "v10", "v11", "v12", "v13", "v14", "v15",
  1081. "v16", "v17", "v18", "v19", "v20", "v21", "v22", "v23",
  1082. "v24", "v25", "v26", "v27", "v28", "v29", "v30", "v31",
  1083. "vrsave", "vscr",
  1084. "spe_acc", "spefscr",
  1085. "sfp"
  1086. };
  1087. void PPCTargetInfo::getGCCRegNames(const char * const *&Names,
  1088. unsigned &NumNames) const {
  1089. Names = GCCRegNames;
  1090. NumNames = llvm::array_lengthof(GCCRegNames);
  1091. }
  1092. const TargetInfo::GCCRegAlias PPCTargetInfo::GCCRegAliases[] = {
  1093. // While some of these aliases do map to different registers
  1094. // they still share the same register name.
  1095. { { "0" }, "r0" },
  1096. { { "1"}, "r1" },
  1097. { { "2" }, "r2" },
  1098. { { "3" }, "r3" },
  1099. { { "4" }, "r4" },
  1100. { { "5" }, "r5" },
  1101. { { "6" }, "r6" },
  1102. { { "7" }, "r7" },
  1103. { { "8" }, "r8" },
  1104. { { "9" }, "r9" },
  1105. { { "10" }, "r10" },
  1106. { { "11" }, "r11" },
  1107. { { "12" }, "r12" },
  1108. { { "13" }, "r13" },
  1109. { { "14" }, "r14" },
  1110. { { "15" }, "r15" },
  1111. { { "16" }, "r16" },
  1112. { { "17" }, "r17" },
  1113. { { "18" }, "r18" },
  1114. { { "19" }, "r19" },
  1115. { { "20" }, "r20" },
  1116. { { "21" }, "r21" },
  1117. { { "22" }, "r22" },
  1118. { { "23" }, "r23" },
  1119. { { "24" }, "r24" },
  1120. { { "25" }, "r25" },
  1121. { { "26" }, "r26" },
  1122. { { "27" }, "r27" },
  1123. { { "28" }, "r28" },
  1124. { { "29" }, "r29" },
  1125. { { "30" }, "r30" },
  1126. { { "31" }, "r31" },
  1127. { { "fr0" }, "f0" },
  1128. { { "fr1" }, "f1" },
  1129. { { "fr2" }, "f2" },
  1130. { { "fr3" }, "f3" },
  1131. { { "fr4" }, "f4" },
  1132. { { "fr5" }, "f5" },
  1133. { { "fr6" }, "f6" },
  1134. { { "fr7" }, "f7" },
  1135. { { "fr8" }, "f8" },
  1136. { { "fr9" }, "f9" },
  1137. { { "fr10" }, "f10" },
  1138. { { "fr11" }, "f11" },
  1139. { { "fr12" }, "f12" },
  1140. { { "fr13" }, "f13" },
  1141. { { "fr14" }, "f14" },
  1142. { { "fr15" }, "f15" },
  1143. { { "fr16" }, "f16" },
  1144. { { "fr17" }, "f17" },
  1145. { { "fr18" }, "f18" },
  1146. { { "fr19" }, "f19" },
  1147. { { "fr20" }, "f20" },
  1148. { { "fr21" }, "f21" },
  1149. { { "fr22" }, "f22" },
  1150. { { "fr23" }, "f23" },
  1151. { { "fr24" }, "f24" },
  1152. { { "fr25" }, "f25" },
  1153. { { "fr26" }, "f26" },
  1154. { { "fr27" }, "f27" },
  1155. { { "fr28" }, "f28" },
  1156. { { "fr29" }, "f29" },
  1157. { { "fr30" }, "f30" },
  1158. { { "fr31" }, "f31" },
  1159. { { "cc" }, "cr0" },
  1160. };
  1161. void PPCTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
  1162. unsigned &NumAliases) const {
  1163. Aliases = GCCRegAliases;
  1164. NumAliases = llvm::array_lengthof(GCCRegAliases);
  1165. }
  1166. } // end anonymous namespace.
  1167. namespace {
  1168. class PPC32TargetInfo : public PPCTargetInfo {
  1169. public:
  1170. PPC32TargetInfo(const llvm::Triple &Triple) : PPCTargetInfo(Triple) {
  1171. DescriptionString = "E-m:e-p:32:32-i64:64-n32";
  1172. switch (getTriple().getOS()) {
  1173. case llvm::Triple::Linux:
  1174. case llvm::Triple::FreeBSD:
  1175. case llvm::Triple::NetBSD:
  1176. SizeType = UnsignedInt;
  1177. PtrDiffType = SignedInt;
  1178. IntPtrType = SignedInt;
  1179. break;
  1180. default:
  1181. break;
  1182. }
  1183. if (getTriple().getOS() == llvm::Triple::FreeBSD) {
  1184. LongDoubleWidth = LongDoubleAlign = 64;
  1185. LongDoubleFormat = &llvm::APFloat::IEEEdouble;
  1186. }
  1187. // PPC32 supports atomics up to 4 bytes.
  1188. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 32;
  1189. }
  1190. BuiltinVaListKind getBuiltinVaListKind() const override {
  1191. // This is the ELF definition, and is overridden by the Darwin sub-target
  1192. return TargetInfo::PowerABIBuiltinVaList;
  1193. }
  1194. };
  1195. } // end anonymous namespace.
  1196. // Note: ABI differences may eventually require us to have a separate
  1197. // TargetInfo for little endian.
  1198. namespace {
  1199. class PPC64TargetInfo : public PPCTargetInfo {
  1200. public:
  1201. PPC64TargetInfo(const llvm::Triple &Triple) : PPCTargetInfo(Triple) {
  1202. LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
  1203. IntMaxType = SignedLong;
  1204. Int64Type = SignedLong;
  1205. if ((Triple.getArch() == llvm::Triple::ppc64le)) {
  1206. DescriptionString = "e-m:e-i64:64-n32:64";
  1207. ABI = "elfv2";
  1208. } else {
  1209. DescriptionString = "E-m:e-i64:64-n32:64";
  1210. ABI = "elfv1";
  1211. }
  1212. switch (getTriple().getOS()) {
  1213. case llvm::Triple::FreeBSD:
  1214. LongDoubleWidth = LongDoubleAlign = 64;
  1215. LongDoubleFormat = &llvm::APFloat::IEEEdouble;
  1216. break;
  1217. case llvm::Triple::NetBSD:
  1218. IntMaxType = SignedLongLong;
  1219. Int64Type = SignedLongLong;
  1220. break;
  1221. default:
  1222. break;
  1223. }
  1224. // PPC64 supports atomics up to 8 bytes.
  1225. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
  1226. }
  1227. BuiltinVaListKind getBuiltinVaListKind() const override {
  1228. return TargetInfo::CharPtrBuiltinVaList;
  1229. }
  1230. // PPC64 Linux-specifc ABI options.
  1231. bool setABI(const std::string &Name) override {
  1232. if (Name == "elfv1" || Name == "elfv2") {
  1233. ABI = Name;
  1234. return true;
  1235. }
  1236. return false;
  1237. }
  1238. };
  1239. } // end anonymous namespace.
  1240. namespace {
  1241. class DarwinPPC32TargetInfo :
  1242. public DarwinTargetInfo<PPC32TargetInfo> {
  1243. public:
  1244. DarwinPPC32TargetInfo(const llvm::Triple &Triple)
  1245. : DarwinTargetInfo<PPC32TargetInfo>(Triple) {
  1246. HasAlignMac68kSupport = true;
  1247. BoolWidth = BoolAlign = 32; //XXX support -mone-byte-bool?
  1248. PtrDiffType = SignedInt; // for http://llvm.org/bugs/show_bug.cgi?id=15726
  1249. LongLongAlign = 32;
  1250. SuitableAlign = 128;
  1251. DescriptionString = "E-m:o-p:32:32-f64:32:64-n32";
  1252. }
  1253. BuiltinVaListKind getBuiltinVaListKind() const override {
  1254. return TargetInfo::CharPtrBuiltinVaList;
  1255. }
  1256. };
  1257. class DarwinPPC64TargetInfo :
  1258. public DarwinTargetInfo<PPC64TargetInfo> {
  1259. public:
  1260. DarwinPPC64TargetInfo(const llvm::Triple &Triple)
  1261. : DarwinTargetInfo<PPC64TargetInfo>(Triple) {
  1262. HasAlignMac68kSupport = true;
  1263. SuitableAlign = 128;
  1264. DescriptionString = "E-m:o-i64:64-n32:64";
  1265. }
  1266. };
  1267. } // end anonymous namespace.
  1268. namespace {
  1269. static const unsigned NVPTXAddrSpaceMap[] = {
  1270. 1, // opencl_global
  1271. 3, // opencl_local
  1272. 4, // opencl_constant
  1273. // FIXME: generic has to be added to the target
  1274. 0, // opencl_generic
  1275. 1, // cuda_device
  1276. 4, // cuda_constant
  1277. 3, // cuda_shared
  1278. };
  1279. class NVPTXTargetInfo : public TargetInfo {
  1280. static const char * const GCCRegNames[];
  1281. static const Builtin::Info BuiltinInfo[];
  1282. // The GPU profiles supported by the NVPTX backend
  1283. enum GPUKind {
  1284. GK_NONE,
  1285. GK_SM20,
  1286. GK_SM21,
  1287. GK_SM30,
  1288. GK_SM35,
  1289. } GPU;
  1290. public:
  1291. NVPTXTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  1292. BigEndian = false;
  1293. TLSSupported = false;
  1294. LongWidth = LongAlign = 64;
  1295. AddrSpaceMap = &NVPTXAddrSpaceMap;
  1296. UseAddrSpaceMapMangling = true;
  1297. // Define available target features
  1298. // These must be defined in sorted order!
  1299. NoAsmVariants = true;
  1300. // Set the default GPU to sm20
  1301. GPU = GK_SM20;
  1302. }
  1303. void getTargetDefines(const LangOptions &Opts,
  1304. MacroBuilder &Builder) const override {
  1305. Builder.defineMacro("__PTX__");
  1306. Builder.defineMacro("__NVPTX__");
  1307. if (Opts.CUDAIsDevice) {
  1308. // Set __CUDA_ARCH__ for the GPU specified.
  1309. std::string CUDAArchCode;
  1310. switch (GPU) {
  1311. case GK_SM20:
  1312. CUDAArchCode = "200";
  1313. break;
  1314. case GK_SM21:
  1315. CUDAArchCode = "210";
  1316. break;
  1317. case GK_SM30:
  1318. CUDAArchCode = "300";
  1319. break;
  1320. case GK_SM35:
  1321. CUDAArchCode = "350";
  1322. break;
  1323. default:
  1324. llvm_unreachable("Unhandled target CPU");
  1325. }
  1326. Builder.defineMacro("__CUDA_ARCH__", CUDAArchCode);
  1327. }
  1328. }
  1329. void getTargetBuiltins(const Builtin::Info *&Records,
  1330. unsigned &NumRecords) const override {
  1331. Records = BuiltinInfo;
  1332. NumRecords = clang::NVPTX::LastTSBuiltin-Builtin::FirstTSBuiltin;
  1333. }
  1334. bool hasFeature(StringRef Feature) const override {
  1335. return Feature == "ptx" || Feature == "nvptx";
  1336. }
  1337. void getGCCRegNames(const char * const *&Names,
  1338. unsigned &NumNames) const override;
  1339. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  1340. unsigned &NumAliases) const override {
  1341. // No aliases.
  1342. Aliases = nullptr;
  1343. NumAliases = 0;
  1344. }
  1345. bool
  1346. validateAsmConstraint(const char *&Name,
  1347. TargetInfo::ConstraintInfo &Info) const override {
  1348. switch (*Name) {
  1349. default: return false;
  1350. case 'c':
  1351. case 'h':
  1352. case 'r':
  1353. case 'l':
  1354. case 'f':
  1355. case 'd':
  1356. Info.setAllowsRegister();
  1357. return true;
  1358. }
  1359. }
  1360. const char *getClobbers() const override {
  1361. // FIXME: Is this really right?
  1362. return "";
  1363. }
  1364. BuiltinVaListKind getBuiltinVaListKind() const override {
  1365. // FIXME: implement
  1366. return TargetInfo::CharPtrBuiltinVaList;
  1367. }
  1368. bool setCPU(const std::string &Name) override {
  1369. GPU = llvm::StringSwitch<GPUKind>(Name)
  1370. .Case("sm_20", GK_SM20)
  1371. .Case("sm_21", GK_SM21)
  1372. .Case("sm_30", GK_SM30)
  1373. .Case("sm_35", GK_SM35)
  1374. .Default(GK_NONE);
  1375. return GPU != GK_NONE;
  1376. }
  1377. };
  1378. const Builtin::Info NVPTXTargetInfo::BuiltinInfo[] = {
  1379. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  1380. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  1381. ALL_LANGUAGES },
  1382. #include "clang/Basic/BuiltinsNVPTX.def"
  1383. };
  1384. const char * const NVPTXTargetInfo::GCCRegNames[] = {
  1385. "r0"
  1386. };
  1387. void NVPTXTargetInfo::getGCCRegNames(const char * const *&Names,
  1388. unsigned &NumNames) const {
  1389. Names = GCCRegNames;
  1390. NumNames = llvm::array_lengthof(GCCRegNames);
  1391. }
  1392. class NVPTX32TargetInfo : public NVPTXTargetInfo {
  1393. public:
  1394. NVPTX32TargetInfo(const llvm::Triple &Triple) : NVPTXTargetInfo(Triple) {
  1395. PointerWidth = PointerAlign = 32;
  1396. SizeType = PtrDiffType = TargetInfo::UnsignedInt;
  1397. IntPtrType = TargetInfo::SignedInt;
  1398. DescriptionString = "e-p:32:32-i64:64-v16:16-v32:32-n16:32:64";
  1399. }
  1400. };
  1401. class NVPTX64TargetInfo : public NVPTXTargetInfo {
  1402. public:
  1403. NVPTX64TargetInfo(const llvm::Triple &Triple) : NVPTXTargetInfo(Triple) {
  1404. PointerWidth = PointerAlign = 64;
  1405. SizeType = PtrDiffType = TargetInfo::UnsignedLongLong;
  1406. IntPtrType = TargetInfo::SignedLongLong;
  1407. DescriptionString = "e-i64:64-v16:16-v32:32-n16:32:64";
  1408. }
  1409. };
  1410. }
  1411. namespace {
  1412. static const unsigned R600AddrSpaceMap[] = {
  1413. 1, // opencl_global
  1414. 3, // opencl_local
  1415. 2, // opencl_constant
  1416. 4, // opencl_generic
  1417. 1, // cuda_device
  1418. 2, // cuda_constant
  1419. 3 // cuda_shared
  1420. };
  1421. // If you edit the description strings, make sure you update
  1422. // getPointerWidthV().
  1423. static const char *DescriptionStringR600 =
  1424. "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128"
  1425. "-v192:256-v256:256-v512:512-v1024:1024-v2048:2048-n32:64";
  1426. static const char *DescriptionStringR600DoubleOps =
  1427. "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128"
  1428. "-v192:256-v256:256-v512:512-v1024:1024-v2048:2048-n32:64";
  1429. static const char *DescriptionStringSI =
  1430. "e-p:32:32-p1:64:64-p2:64:64-p3:32:32-p4:64:64-p5:32:32-p24:64:64"
  1431. "-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128"
  1432. "-v192:256-v256:256-v512:512-v1024:1024-v2048:2048-n32:64";
  1433. class R600TargetInfo : public TargetInfo {
  1434. static const Builtin::Info BuiltinInfo[];
  1435. /// \brief The GPU profiles supported by the R600 target.
  1436. enum GPUKind {
  1437. GK_NONE,
  1438. GK_R600,
  1439. GK_R600_DOUBLE_OPS,
  1440. GK_R700,
  1441. GK_R700_DOUBLE_OPS,
  1442. GK_EVERGREEN,
  1443. GK_EVERGREEN_DOUBLE_OPS,
  1444. GK_NORTHERN_ISLANDS,
  1445. GK_CAYMAN,
  1446. GK_SOUTHERN_ISLANDS,
  1447. GK_SEA_ISLANDS
  1448. } GPU;
  1449. public:
  1450. R600TargetInfo(const llvm::Triple &Triple)
  1451. : TargetInfo(Triple) {
  1452. if (Triple.getArch() == llvm::Triple::amdgcn) {
  1453. DescriptionString = DescriptionStringSI;
  1454. GPU = GK_SOUTHERN_ISLANDS;
  1455. } else {
  1456. DescriptionString = DescriptionStringR600;
  1457. GPU = GK_R600;
  1458. }
  1459. AddrSpaceMap = &R600AddrSpaceMap;
  1460. UseAddrSpaceMapMangling = true;
  1461. }
  1462. uint64_t getPointerWidthV(unsigned AddrSpace) const override {
  1463. if (GPU <= GK_CAYMAN)
  1464. return 32;
  1465. switch(AddrSpace) {
  1466. default:
  1467. return 64;
  1468. case 0:
  1469. case 3:
  1470. case 5:
  1471. return 32;
  1472. }
  1473. }
  1474. const char * getClobbers() const override {
  1475. return "";
  1476. }
  1477. void getGCCRegNames(const char * const *&Names,
  1478. unsigned &numNames) const override {
  1479. Names = nullptr;
  1480. numNames = 0;
  1481. }
  1482. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  1483. unsigned &NumAliases) const override {
  1484. Aliases = nullptr;
  1485. NumAliases = 0;
  1486. }
  1487. bool validateAsmConstraint(const char *&Name,
  1488. TargetInfo::ConstraintInfo &info) const override {
  1489. return true;
  1490. }
  1491. void getTargetBuiltins(const Builtin::Info *&Records,
  1492. unsigned &NumRecords) const override {
  1493. Records = BuiltinInfo;
  1494. NumRecords = clang::R600::LastTSBuiltin - Builtin::FirstTSBuiltin;
  1495. }
  1496. void getTargetDefines(const LangOptions &Opts,
  1497. MacroBuilder &Builder) const override {
  1498. Builder.defineMacro("__R600__");
  1499. }
  1500. BuiltinVaListKind getBuiltinVaListKind() const override {
  1501. return TargetInfo::CharPtrBuiltinVaList;
  1502. }
  1503. bool setCPU(const std::string &Name) override {
  1504. GPU = llvm::StringSwitch<GPUKind>(Name)
  1505. .Case("r600" , GK_R600)
  1506. .Case("rv610", GK_R600)
  1507. .Case("rv620", GK_R600)
  1508. .Case("rv630", GK_R600)
  1509. .Case("rv635", GK_R600)
  1510. .Case("rs780", GK_R600)
  1511. .Case("rs880", GK_R600)
  1512. .Case("rv670", GK_R600_DOUBLE_OPS)
  1513. .Case("rv710", GK_R700)
  1514. .Case("rv730", GK_R700)
  1515. .Case("rv740", GK_R700_DOUBLE_OPS)
  1516. .Case("rv770", GK_R700_DOUBLE_OPS)
  1517. .Case("palm", GK_EVERGREEN)
  1518. .Case("cedar", GK_EVERGREEN)
  1519. .Case("sumo", GK_EVERGREEN)
  1520. .Case("sumo2", GK_EVERGREEN)
  1521. .Case("redwood", GK_EVERGREEN)
  1522. .Case("juniper", GK_EVERGREEN)
  1523. .Case("hemlock", GK_EVERGREEN_DOUBLE_OPS)
  1524. .Case("cypress", GK_EVERGREEN_DOUBLE_OPS)
  1525. .Case("barts", GK_NORTHERN_ISLANDS)
  1526. .Case("turks", GK_NORTHERN_ISLANDS)
  1527. .Case("caicos", GK_NORTHERN_ISLANDS)
  1528. .Case("cayman", GK_CAYMAN)
  1529. .Case("aruba", GK_CAYMAN)
  1530. .Case("tahiti", GK_SOUTHERN_ISLANDS)
  1531. .Case("pitcairn", GK_SOUTHERN_ISLANDS)
  1532. .Case("verde", GK_SOUTHERN_ISLANDS)
  1533. .Case("oland", GK_SOUTHERN_ISLANDS)
  1534. .Case("hainan", GK_SOUTHERN_ISLANDS)
  1535. .Case("bonaire", GK_SEA_ISLANDS)
  1536. .Case("kabini", GK_SEA_ISLANDS)
  1537. .Case("kaveri", GK_SEA_ISLANDS)
  1538. .Case("hawaii", GK_SEA_ISLANDS)
  1539. .Case("mullins", GK_SEA_ISLANDS)
  1540. .Default(GK_NONE);
  1541. if (GPU == GK_NONE) {
  1542. return false;
  1543. }
  1544. // Set the correct data layout
  1545. switch (GPU) {
  1546. case GK_NONE:
  1547. case GK_R600:
  1548. case GK_R700:
  1549. case GK_EVERGREEN:
  1550. case GK_NORTHERN_ISLANDS:
  1551. DescriptionString = DescriptionStringR600;
  1552. break;
  1553. case GK_R600_DOUBLE_OPS:
  1554. case GK_R700_DOUBLE_OPS:
  1555. case GK_EVERGREEN_DOUBLE_OPS:
  1556. case GK_CAYMAN:
  1557. DescriptionString = DescriptionStringR600DoubleOps;
  1558. break;
  1559. case GK_SOUTHERN_ISLANDS:
  1560. case GK_SEA_ISLANDS:
  1561. DescriptionString = DescriptionStringSI;
  1562. break;
  1563. }
  1564. return true;
  1565. }
  1566. };
  1567. const Builtin::Info R600TargetInfo::BuiltinInfo[] = {
  1568. #define BUILTIN(ID, TYPE, ATTRS) \
  1569. { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  1570. #include "clang/Basic/BuiltinsR600.def"
  1571. };
  1572. } // end anonymous namespace
  1573. namespace {
  1574. // Namespace for x86 abstract base class
  1575. const Builtin::Info BuiltinInfo[] = {
  1576. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  1577. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  1578. ALL_LANGUAGES },
  1579. #include "clang/Basic/BuiltinsX86.def"
  1580. };
  1581. static const char* const GCCRegNames[] = {
  1582. "ax", "dx", "cx", "bx", "si", "di", "bp", "sp",
  1583. "st", "st(1)", "st(2)", "st(3)", "st(4)", "st(5)", "st(6)", "st(7)",
  1584. "argp", "flags", "fpcr", "fpsr", "dirflag", "frame",
  1585. "xmm0", "xmm1", "xmm2", "xmm3", "xmm4", "xmm5", "xmm6", "xmm7",
  1586. "mm0", "mm1", "mm2", "mm3", "mm4", "mm5", "mm6", "mm7",
  1587. "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
  1588. "xmm8", "xmm9", "xmm10", "xmm11", "xmm12", "xmm13", "xmm14", "xmm15",
  1589. "ymm0", "ymm1", "ymm2", "ymm3", "ymm4", "ymm5", "ymm6", "ymm7",
  1590. "ymm8", "ymm9", "ymm10", "ymm11", "ymm12", "ymm13", "ymm14", "ymm15",
  1591. };
  1592. const TargetInfo::AddlRegName AddlRegNames[] = {
  1593. { { "al", "ah", "eax", "rax" }, 0 },
  1594. { { "bl", "bh", "ebx", "rbx" }, 3 },
  1595. { { "cl", "ch", "ecx", "rcx" }, 2 },
  1596. { { "dl", "dh", "edx", "rdx" }, 1 },
  1597. { { "esi", "rsi" }, 4 },
  1598. { { "edi", "rdi" }, 5 },
  1599. { { "esp", "rsp" }, 7 },
  1600. { { "ebp", "rbp" }, 6 },
  1601. };
  1602. // X86 target abstract base class; x86-32 and x86-64 are very close, so
  1603. // most of the implementation can be shared.
  1604. class X86TargetInfo : public TargetInfo {
  1605. enum X86SSEEnum {
  1606. NoSSE, SSE1, SSE2, SSE3, SSSE3, SSE41, SSE42, AVX, AVX2, AVX512F
  1607. } SSELevel;
  1608. enum MMX3DNowEnum {
  1609. NoMMX3DNow, MMX, AMD3DNow, AMD3DNowAthlon
  1610. } MMX3DNowLevel;
  1611. enum XOPEnum {
  1612. NoXOP,
  1613. SSE4A,
  1614. FMA4,
  1615. XOP
  1616. } XOPLevel;
  1617. bool HasAES;
  1618. bool HasPCLMUL;
  1619. bool HasLZCNT;
  1620. bool HasRDRND;
  1621. bool HasFSGSBASE;
  1622. bool HasBMI;
  1623. bool HasBMI2;
  1624. bool HasPOPCNT;
  1625. bool HasRTM;
  1626. bool HasPRFCHW;
  1627. bool HasRDSEED;
  1628. bool HasADX;
  1629. bool HasTBM;
  1630. bool HasFMA;
  1631. bool HasF16C;
  1632. bool HasAVX512CD, HasAVX512ER, HasAVX512PF, HasAVX512DQ, HasAVX512BW,
  1633. HasAVX512VL;
  1634. bool HasSHA;
  1635. bool HasCX16;
  1636. /// \brief Enumeration of all of the X86 CPUs supported by Clang.
  1637. ///
  1638. /// Each enumeration represents a particular CPU supported by Clang. These
  1639. /// loosely correspond to the options passed to '-march' or '-mtune' flags.
  1640. enum CPUKind {
  1641. CK_Generic,
  1642. /// \name i386
  1643. /// i386-generation processors.
  1644. //@{
  1645. CK_i386,
  1646. //@}
  1647. /// \name i486
  1648. /// i486-generation processors.
  1649. //@{
  1650. CK_i486,
  1651. CK_WinChipC6,
  1652. CK_WinChip2,
  1653. CK_C3,
  1654. //@}
  1655. /// \name i586
  1656. /// i586-generation processors, P5 microarchitecture based.
  1657. //@{
  1658. CK_i586,
  1659. CK_Pentium,
  1660. CK_PentiumMMX,
  1661. //@}
  1662. /// \name i686
  1663. /// i686-generation processors, P6 / Pentium M microarchitecture based.
  1664. //@{
  1665. CK_i686,
  1666. CK_PentiumPro,
  1667. CK_Pentium2,
  1668. CK_Pentium3,
  1669. CK_Pentium3M,
  1670. CK_PentiumM,
  1671. CK_C3_2,
  1672. /// This enumerator is a bit odd, as GCC no longer accepts -march=yonah.
  1673. /// Clang however has some logic to suport this.
  1674. // FIXME: Warn, deprecate, and potentially remove this.
  1675. CK_Yonah,
  1676. //@}
  1677. /// \name Netburst
  1678. /// Netburst microarchitecture based processors.
  1679. //@{
  1680. CK_Pentium4,
  1681. CK_Pentium4M,
  1682. CK_Prescott,
  1683. CK_Nocona,
  1684. //@}
  1685. /// \name Core
  1686. /// Core microarchitecture based processors.
  1687. //@{
  1688. CK_Core2,
  1689. /// This enumerator, like \see CK_Yonah, is a bit odd. It is another
  1690. /// codename which GCC no longer accepts as an option to -march, but Clang
  1691. /// has some logic for recognizing it.
  1692. // FIXME: Warn, deprecate, and potentially remove this.
  1693. CK_Penryn,
  1694. //@}
  1695. /// \name Atom
  1696. /// Atom processors
  1697. //@{
  1698. CK_Bonnell,
  1699. CK_Silvermont,
  1700. //@}
  1701. /// \name Nehalem
  1702. /// Nehalem microarchitecture based processors.
  1703. CK_Nehalem,
  1704. /// \name Westmere
  1705. /// Westmere microarchitecture based processors.
  1706. CK_Westmere,
  1707. /// \name Sandy Bridge
  1708. /// Sandy Bridge microarchitecture based processors.
  1709. CK_SandyBridge,
  1710. /// \name Ivy Bridge
  1711. /// Ivy Bridge microarchitecture based processors.
  1712. CK_IvyBridge,
  1713. /// \name Haswell
  1714. /// Haswell microarchitecture based processors.
  1715. CK_Haswell,
  1716. /// \name Broadwell
  1717. /// Broadwell microarchitecture based processors.
  1718. CK_Broadwell,
  1719. /// \name Skylake
  1720. /// Skylake microarchitecture based processors.
  1721. CK_Skylake,
  1722. /// \name Knights Landing
  1723. /// Knights Landing processor.
  1724. CK_KNL,
  1725. /// \name K6
  1726. /// K6 architecture processors.
  1727. //@{
  1728. CK_K6,
  1729. CK_K6_2,
  1730. CK_K6_3,
  1731. //@}
  1732. /// \name K7
  1733. /// K7 architecture processors.
  1734. //@{
  1735. CK_Athlon,
  1736. CK_AthlonThunderbird,
  1737. CK_Athlon4,
  1738. CK_AthlonXP,
  1739. CK_AthlonMP,
  1740. //@}
  1741. /// \name K8
  1742. /// K8 architecture processors.
  1743. //@{
  1744. CK_Athlon64,
  1745. CK_Athlon64SSE3,
  1746. CK_AthlonFX,
  1747. CK_K8,
  1748. CK_K8SSE3,
  1749. CK_Opteron,
  1750. CK_OpteronSSE3,
  1751. CK_AMDFAM10,
  1752. //@}
  1753. /// \name Bobcat
  1754. /// Bobcat architecture processors.
  1755. //@{
  1756. CK_BTVER1,
  1757. CK_BTVER2,
  1758. //@}
  1759. /// \name Bulldozer
  1760. /// Bulldozer architecture processors.
  1761. //@{
  1762. CK_BDVER1,
  1763. CK_BDVER2,
  1764. CK_BDVER3,
  1765. CK_BDVER4,
  1766. //@}
  1767. /// This specification is deprecated and will be removed in the future.
  1768. /// Users should prefer \see CK_K8.
  1769. // FIXME: Warn on this when the CPU is set to it.
  1770. //@{
  1771. CK_x86_64,
  1772. //@}
  1773. /// \name Geode
  1774. /// Geode processors.
  1775. //@{
  1776. CK_Geode
  1777. //@}
  1778. } CPU;
  1779. enum FPMathKind {
  1780. FP_Default,
  1781. FP_SSE,
  1782. FP_387
  1783. } FPMath;
  1784. public:
  1785. X86TargetInfo(const llvm::Triple &Triple)
  1786. : TargetInfo(Triple), SSELevel(NoSSE), MMX3DNowLevel(NoMMX3DNow),
  1787. XOPLevel(NoXOP), HasAES(false), HasPCLMUL(false), HasLZCNT(false),
  1788. HasRDRND(false), HasFSGSBASE(false), HasBMI(false), HasBMI2(false),
  1789. HasPOPCNT(false), HasRTM(false), HasPRFCHW(false), HasRDSEED(false),
  1790. HasADX(false), HasTBM(false), HasFMA(false), HasF16C(false),
  1791. HasAVX512CD(false), HasAVX512ER(false), HasAVX512PF(false),
  1792. HasAVX512DQ(false), HasAVX512BW(false), HasAVX512VL(false),
  1793. HasSHA(false), HasCX16(false), CPU(CK_Generic), FPMath(FP_Default) {
  1794. BigEndian = false;
  1795. LongDoubleFormat = &llvm::APFloat::x87DoubleExtended;
  1796. }
  1797. unsigned getFloatEvalMethod() const override {
  1798. // X87 evaluates with 80 bits "long double" precision.
  1799. return SSELevel == NoSSE ? 2 : 0;
  1800. }
  1801. void getTargetBuiltins(const Builtin::Info *&Records,
  1802. unsigned &NumRecords) const override {
  1803. Records = BuiltinInfo;
  1804. NumRecords = clang::X86::LastTSBuiltin-Builtin::FirstTSBuiltin;
  1805. }
  1806. void getGCCRegNames(const char * const *&Names,
  1807. unsigned &NumNames) const override {
  1808. Names = GCCRegNames;
  1809. NumNames = llvm::array_lengthof(GCCRegNames);
  1810. }
  1811. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  1812. unsigned &NumAliases) const override {
  1813. Aliases = nullptr;
  1814. NumAliases = 0;
  1815. }
  1816. void getGCCAddlRegNames(const AddlRegName *&Names,
  1817. unsigned &NumNames) const override {
  1818. Names = AddlRegNames;
  1819. NumNames = llvm::array_lengthof(AddlRegNames);
  1820. }
  1821. bool validateAsmConstraint(const char *&Name,
  1822. TargetInfo::ConstraintInfo &info) const override;
  1823. bool validateOutputSize(StringRef Constraint, unsigned Size) const override;
  1824. bool validateInputSize(StringRef Constraint, unsigned Size) const override;
  1825. virtual bool validateOperandSize(StringRef Constraint, unsigned Size) const;
  1826. std::string convertConstraint(const char *&Constraint) const override;
  1827. const char *getClobbers() const override {
  1828. return "~{dirflag},~{fpsr},~{flags}";
  1829. }
  1830. void getTargetDefines(const LangOptions &Opts,
  1831. MacroBuilder &Builder) const override;
  1832. static void setSSELevel(llvm::StringMap<bool> &Features, X86SSEEnum Level,
  1833. bool Enabled);
  1834. static void setMMXLevel(llvm::StringMap<bool> &Features, MMX3DNowEnum Level,
  1835. bool Enabled);
  1836. static void setXOPLevel(llvm::StringMap<bool> &Features, XOPEnum Level,
  1837. bool Enabled);
  1838. void setFeatureEnabled(llvm::StringMap<bool> &Features,
  1839. StringRef Name, bool Enabled) const override {
  1840. setFeatureEnabledImpl(Features, Name, Enabled);
  1841. }
  1842. // This exists purely to cut down on the number of virtual calls in
  1843. // getDefaultFeatures which calls this repeatedly.
  1844. static void setFeatureEnabledImpl(llvm::StringMap<bool> &Features,
  1845. StringRef Name, bool Enabled);
  1846. void getDefaultFeatures(llvm::StringMap<bool> &Features) const override;
  1847. bool hasFeature(StringRef Feature) const override;
  1848. bool handleTargetFeatures(std::vector<std::string> &Features,
  1849. DiagnosticsEngine &Diags) override;
  1850. StringRef getABI() const override {
  1851. if (getTriple().getArch() == llvm::Triple::x86_64 && SSELevel >= AVX)
  1852. return "avx";
  1853. else if (getTriple().getArch() == llvm::Triple::x86 &&
  1854. MMX3DNowLevel == NoMMX3DNow)
  1855. return "no-mmx";
  1856. return "";
  1857. }
  1858. bool setCPU(const std::string &Name) override {
  1859. CPU = llvm::StringSwitch<CPUKind>(Name)
  1860. .Case("i386", CK_i386)
  1861. .Case("i486", CK_i486)
  1862. .Case("winchip-c6", CK_WinChipC6)
  1863. .Case("winchip2", CK_WinChip2)
  1864. .Case("c3", CK_C3)
  1865. .Case("i586", CK_i586)
  1866. .Case("pentium", CK_Pentium)
  1867. .Case("pentium-mmx", CK_PentiumMMX)
  1868. .Case("i686", CK_i686)
  1869. .Case("pentiumpro", CK_PentiumPro)
  1870. .Case("pentium2", CK_Pentium2)
  1871. .Case("pentium3", CK_Pentium3)
  1872. .Case("pentium3m", CK_Pentium3M)
  1873. .Case("pentium-m", CK_PentiumM)
  1874. .Case("c3-2", CK_C3_2)
  1875. .Case("yonah", CK_Yonah)
  1876. .Case("pentium4", CK_Pentium4)
  1877. .Case("pentium4m", CK_Pentium4M)
  1878. .Case("prescott", CK_Prescott)
  1879. .Case("nocona", CK_Nocona)
  1880. .Case("core2", CK_Core2)
  1881. .Case("penryn", CK_Penryn)
  1882. .Case("bonnell", CK_Bonnell)
  1883. .Case("atom", CK_Bonnell) // Legacy name.
  1884. .Case("silvermont", CK_Silvermont)
  1885. .Case("slm", CK_Silvermont) // Legacy name.
  1886. .Case("nehalem", CK_Nehalem)
  1887. .Case("corei7", CK_Nehalem) // Legacy name.
  1888. .Case("westmere", CK_Westmere)
  1889. .Case("sandybridge", CK_SandyBridge)
  1890. .Case("corei7-avx", CK_SandyBridge) // Legacy name.
  1891. .Case("ivybridge", CK_IvyBridge)
  1892. .Case("core-avx-i", CK_IvyBridge) // Legacy name.
  1893. .Case("haswell", CK_Haswell)
  1894. .Case("core-avx2", CK_Haswell) // Legacy name.
  1895. .Case("broadwell", CK_Broadwell)
  1896. .Case("skylake", CK_Skylake)
  1897. .Case("skx", CK_Skylake) // Legacy name.
  1898. .Case("knl", CK_KNL)
  1899. .Case("k6", CK_K6)
  1900. .Case("k6-2", CK_K6_2)
  1901. .Case("k6-3", CK_K6_3)
  1902. .Case("athlon", CK_Athlon)
  1903. .Case("athlon-tbird", CK_AthlonThunderbird)
  1904. .Case("athlon-4", CK_Athlon4)
  1905. .Case("athlon-xp", CK_AthlonXP)
  1906. .Case("athlon-mp", CK_AthlonMP)
  1907. .Case("athlon64", CK_Athlon64)
  1908. .Case("athlon64-sse3", CK_Athlon64SSE3)
  1909. .Case("athlon-fx", CK_AthlonFX)
  1910. .Case("k8", CK_K8)
  1911. .Case("k8-sse3", CK_K8SSE3)
  1912. .Case("opteron", CK_Opteron)
  1913. .Case("opteron-sse3", CK_OpteronSSE3)
  1914. .Case("barcelona", CK_AMDFAM10)
  1915. .Case("amdfam10", CK_AMDFAM10)
  1916. .Case("btver1", CK_BTVER1)
  1917. .Case("btver2", CK_BTVER2)
  1918. .Case("bdver1", CK_BDVER1)
  1919. .Case("bdver2", CK_BDVER2)
  1920. .Case("bdver3", CK_BDVER3)
  1921. .Case("bdver4", CK_BDVER4)
  1922. .Case("x86-64", CK_x86_64)
  1923. .Case("geode", CK_Geode)
  1924. .Default(CK_Generic);
  1925. // Perform any per-CPU checks necessary to determine if this CPU is
  1926. // acceptable.
  1927. // FIXME: This results in terrible diagnostics. Clang just says the CPU is
  1928. // invalid without explaining *why*.
  1929. switch (CPU) {
  1930. case CK_Generic:
  1931. // No processor selected!
  1932. return false;
  1933. case CK_i386:
  1934. case CK_i486:
  1935. case CK_WinChipC6:
  1936. case CK_WinChip2:
  1937. case CK_C3:
  1938. case CK_i586:
  1939. case CK_Pentium:
  1940. case CK_PentiumMMX:
  1941. case CK_i686:
  1942. case CK_PentiumPro:
  1943. case CK_Pentium2:
  1944. case CK_Pentium3:
  1945. case CK_Pentium3M:
  1946. case CK_PentiumM:
  1947. case CK_Yonah:
  1948. case CK_C3_2:
  1949. case CK_Pentium4:
  1950. case CK_Pentium4M:
  1951. case CK_Prescott:
  1952. case CK_K6:
  1953. case CK_K6_2:
  1954. case CK_K6_3:
  1955. case CK_Athlon:
  1956. case CK_AthlonThunderbird:
  1957. case CK_Athlon4:
  1958. case CK_AthlonXP:
  1959. case CK_AthlonMP:
  1960. case CK_Geode:
  1961. // Only accept certain architectures when compiling in 32-bit mode.
  1962. if (getTriple().getArch() != llvm::Triple::x86)
  1963. return false;
  1964. // Fallthrough
  1965. case CK_Nocona:
  1966. case CK_Core2:
  1967. case CK_Penryn:
  1968. case CK_Bonnell:
  1969. case CK_Silvermont:
  1970. case CK_Nehalem:
  1971. case CK_Westmere:
  1972. case CK_SandyBridge:
  1973. case CK_IvyBridge:
  1974. case CK_Haswell:
  1975. case CK_Broadwell:
  1976. case CK_Skylake:
  1977. case CK_KNL:
  1978. case CK_Athlon64:
  1979. case CK_Athlon64SSE3:
  1980. case CK_AthlonFX:
  1981. case CK_K8:
  1982. case CK_K8SSE3:
  1983. case CK_Opteron:
  1984. case CK_OpteronSSE3:
  1985. case CK_AMDFAM10:
  1986. case CK_BTVER1:
  1987. case CK_BTVER2:
  1988. case CK_BDVER1:
  1989. case CK_BDVER2:
  1990. case CK_BDVER3:
  1991. case CK_BDVER4:
  1992. case CK_x86_64:
  1993. return true;
  1994. }
  1995. llvm_unreachable("Unhandled CPU kind");
  1996. }
  1997. bool setFPMath(StringRef Name) override;
  1998. CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
  1999. // We accept all non-ARM calling conventions
  2000. return (CC == CC_X86ThisCall ||
  2001. CC == CC_X86FastCall ||
  2002. CC == CC_X86StdCall ||
  2003. CC == CC_X86VectorCall ||
  2004. CC == CC_C ||
  2005. CC == CC_X86Pascal ||
  2006. CC == CC_IntelOclBicc) ? CCCR_OK : CCCR_Warning;
  2007. }
  2008. CallingConv getDefaultCallingConv(CallingConvMethodType MT) const override {
  2009. return MT == CCMT_Member ? CC_X86ThisCall : CC_C;
  2010. }
  2011. };
  2012. bool X86TargetInfo::setFPMath(StringRef Name) {
  2013. if (Name == "387") {
  2014. FPMath = FP_387;
  2015. return true;
  2016. }
  2017. if (Name == "sse") {
  2018. FPMath = FP_SSE;
  2019. return true;
  2020. }
  2021. return false;
  2022. }
  2023. void X86TargetInfo::getDefaultFeatures(llvm::StringMap<bool> &Features) const {
  2024. // FIXME: This *really* should not be here.
  2025. // X86_64 always has SSE2.
  2026. if (getTriple().getArch() == llvm::Triple::x86_64)
  2027. setFeatureEnabledImpl(Features, "sse2", true);
  2028. switch (CPU) {
  2029. case CK_Generic:
  2030. case CK_i386:
  2031. case CK_i486:
  2032. case CK_i586:
  2033. case CK_Pentium:
  2034. case CK_i686:
  2035. case CK_PentiumPro:
  2036. break;
  2037. case CK_PentiumMMX:
  2038. case CK_Pentium2:
  2039. case CK_K6:
  2040. case CK_WinChipC6:
  2041. setFeatureEnabledImpl(Features, "mmx", true);
  2042. break;
  2043. case CK_Pentium3:
  2044. case CK_Pentium3M:
  2045. case CK_C3_2:
  2046. setFeatureEnabledImpl(Features, "sse", true);
  2047. break;
  2048. case CK_PentiumM:
  2049. case CK_Pentium4:
  2050. case CK_Pentium4M:
  2051. case CK_x86_64:
  2052. setFeatureEnabledImpl(Features, "sse2", true);
  2053. break;
  2054. case CK_Yonah:
  2055. case CK_Prescott:
  2056. case CK_Nocona:
  2057. setFeatureEnabledImpl(Features, "sse3", true);
  2058. setFeatureEnabledImpl(Features, "cx16", true);
  2059. break;
  2060. case CK_Core2:
  2061. case CK_Bonnell:
  2062. setFeatureEnabledImpl(Features, "ssse3", true);
  2063. setFeatureEnabledImpl(Features, "cx16", true);
  2064. break;
  2065. case CK_Penryn:
  2066. setFeatureEnabledImpl(Features, "sse4.1", true);
  2067. setFeatureEnabledImpl(Features, "cx16", true);
  2068. break;
  2069. case CK_Skylake:
  2070. setFeatureEnabledImpl(Features, "avx512f", true);
  2071. setFeatureEnabledImpl(Features, "avx512cd", true);
  2072. setFeatureEnabledImpl(Features, "avx512dq", true);
  2073. setFeatureEnabledImpl(Features, "avx512bw", true);
  2074. setFeatureEnabledImpl(Features, "avx512vl", true);
  2075. // FALLTHROUGH
  2076. case CK_Broadwell:
  2077. setFeatureEnabledImpl(Features, "rdseed", true);
  2078. setFeatureEnabledImpl(Features, "adx", true);
  2079. // FALLTHROUGH
  2080. case CK_Haswell:
  2081. setFeatureEnabledImpl(Features, "avx2", true);
  2082. setFeatureEnabledImpl(Features, "lzcnt", true);
  2083. setFeatureEnabledImpl(Features, "bmi", true);
  2084. setFeatureEnabledImpl(Features, "bmi2", true);
  2085. setFeatureEnabledImpl(Features, "rtm", true);
  2086. setFeatureEnabledImpl(Features, "fma", true);
  2087. // FALLTHROUGH
  2088. case CK_IvyBridge:
  2089. setFeatureEnabledImpl(Features, "rdrnd", true);
  2090. setFeatureEnabledImpl(Features, "f16c", true);
  2091. setFeatureEnabledImpl(Features, "fsgsbase", true);
  2092. // FALLTHROUGH
  2093. case CK_SandyBridge:
  2094. setFeatureEnabledImpl(Features, "avx", true);
  2095. // FALLTHROUGH
  2096. case CK_Westmere:
  2097. case CK_Silvermont:
  2098. setFeatureEnabledImpl(Features, "aes", true);
  2099. setFeatureEnabledImpl(Features, "pclmul", true);
  2100. // FALLTHROUGH
  2101. case CK_Nehalem:
  2102. setFeatureEnabledImpl(Features, "sse4.2", true);
  2103. setFeatureEnabledImpl(Features, "cx16", true);
  2104. break;
  2105. case CK_KNL:
  2106. setFeatureEnabledImpl(Features, "avx512f", true);
  2107. setFeatureEnabledImpl(Features, "avx512cd", true);
  2108. setFeatureEnabledImpl(Features, "avx512er", true);
  2109. setFeatureEnabledImpl(Features, "avx512pf", true);
  2110. setFeatureEnabledImpl(Features, "rdseed", true);
  2111. setFeatureEnabledImpl(Features, "adx", true);
  2112. setFeatureEnabledImpl(Features, "lzcnt", true);
  2113. setFeatureEnabledImpl(Features, "bmi", true);
  2114. setFeatureEnabledImpl(Features, "bmi2", true);
  2115. setFeatureEnabledImpl(Features, "rtm", true);
  2116. setFeatureEnabledImpl(Features, "fma", true);
  2117. setFeatureEnabledImpl(Features, "rdrnd", true);
  2118. setFeatureEnabledImpl(Features, "f16c", true);
  2119. setFeatureEnabledImpl(Features, "fsgsbase", true);
  2120. setFeatureEnabledImpl(Features, "aes", true);
  2121. setFeatureEnabledImpl(Features, "pclmul", true);
  2122. setFeatureEnabledImpl(Features, "cx16", true);
  2123. break;
  2124. case CK_K6_2:
  2125. case CK_K6_3:
  2126. case CK_WinChip2:
  2127. case CK_C3:
  2128. setFeatureEnabledImpl(Features, "3dnow", true);
  2129. break;
  2130. case CK_Athlon:
  2131. case CK_AthlonThunderbird:
  2132. case CK_Geode:
  2133. setFeatureEnabledImpl(Features, "3dnowa", true);
  2134. break;
  2135. case CK_Athlon4:
  2136. case CK_AthlonXP:
  2137. case CK_AthlonMP:
  2138. setFeatureEnabledImpl(Features, "sse", true);
  2139. setFeatureEnabledImpl(Features, "3dnowa", true);
  2140. break;
  2141. case CK_K8:
  2142. case CK_Opteron:
  2143. case CK_Athlon64:
  2144. case CK_AthlonFX:
  2145. setFeatureEnabledImpl(Features, "sse2", true);
  2146. setFeatureEnabledImpl(Features, "3dnowa", true);
  2147. break;
  2148. case CK_AMDFAM10:
  2149. setFeatureEnabledImpl(Features, "sse4a", true);
  2150. setFeatureEnabledImpl(Features, "lzcnt", true);
  2151. setFeatureEnabledImpl(Features, "popcnt", true);
  2152. // FALLTHROUGH
  2153. case CK_K8SSE3:
  2154. case CK_OpteronSSE3:
  2155. case CK_Athlon64SSE3:
  2156. setFeatureEnabledImpl(Features, "sse3", true);
  2157. setFeatureEnabledImpl(Features, "3dnowa", true);
  2158. break;
  2159. case CK_BTVER2:
  2160. setFeatureEnabledImpl(Features, "avx", true);
  2161. setFeatureEnabledImpl(Features, "aes", true);
  2162. setFeatureEnabledImpl(Features, "pclmul", true);
  2163. setFeatureEnabledImpl(Features, "bmi", true);
  2164. setFeatureEnabledImpl(Features, "f16c", true);
  2165. // FALLTHROUGH
  2166. case CK_BTVER1:
  2167. setFeatureEnabledImpl(Features, "ssse3", true);
  2168. setFeatureEnabledImpl(Features, "sse4a", true);
  2169. setFeatureEnabledImpl(Features, "lzcnt", true);
  2170. setFeatureEnabledImpl(Features, "popcnt", true);
  2171. setFeatureEnabledImpl(Features, "prfchw", true);
  2172. setFeatureEnabledImpl(Features, "cx16", true);
  2173. break;
  2174. case CK_BDVER4:
  2175. setFeatureEnabledImpl(Features, "avx2", true);
  2176. setFeatureEnabledImpl(Features, "bmi2", true);
  2177. // FALLTHROUGH
  2178. case CK_BDVER3:
  2179. setFeatureEnabledImpl(Features, "fsgsbase", true);
  2180. // FALLTHROUGH
  2181. case CK_BDVER2:
  2182. setFeatureEnabledImpl(Features, "bmi", true);
  2183. setFeatureEnabledImpl(Features, "fma", true);
  2184. setFeatureEnabledImpl(Features, "f16c", true);
  2185. setFeatureEnabledImpl(Features, "tbm", true);
  2186. // FALLTHROUGH
  2187. case CK_BDVER1:
  2188. // xop implies avx, sse4a and fma4.
  2189. setFeatureEnabledImpl(Features, "xop", true);
  2190. setFeatureEnabledImpl(Features, "lzcnt", true);
  2191. setFeatureEnabledImpl(Features, "aes", true);
  2192. setFeatureEnabledImpl(Features, "pclmul", true);
  2193. setFeatureEnabledImpl(Features, "prfchw", true);
  2194. setFeatureEnabledImpl(Features, "cx16", true);
  2195. break;
  2196. }
  2197. }
  2198. void X86TargetInfo::setSSELevel(llvm::StringMap<bool> &Features,
  2199. X86SSEEnum Level, bool Enabled) {
  2200. if (Enabled) {
  2201. switch (Level) {
  2202. case AVX512F:
  2203. Features["avx512f"] = true;
  2204. case AVX2:
  2205. Features["avx2"] = true;
  2206. case AVX:
  2207. Features["avx"] = true;
  2208. case SSE42:
  2209. Features["sse4.2"] = true;
  2210. case SSE41:
  2211. Features["sse4.1"] = true;
  2212. case SSSE3:
  2213. Features["ssse3"] = true;
  2214. case SSE3:
  2215. Features["sse3"] = true;
  2216. case SSE2:
  2217. Features["sse2"] = true;
  2218. case SSE1:
  2219. Features["sse"] = true;
  2220. case NoSSE:
  2221. break;
  2222. }
  2223. return;
  2224. }
  2225. switch (Level) {
  2226. case NoSSE:
  2227. case SSE1:
  2228. Features["sse"] = false;
  2229. case SSE2:
  2230. Features["sse2"] = Features["pclmul"] = Features["aes"] =
  2231. Features["sha"] = false;
  2232. case SSE3:
  2233. Features["sse3"] = false;
  2234. setXOPLevel(Features, NoXOP, false);
  2235. case SSSE3:
  2236. Features["ssse3"] = false;
  2237. case SSE41:
  2238. Features["sse4.1"] = false;
  2239. case SSE42:
  2240. Features["sse4.2"] = false;
  2241. case AVX:
  2242. Features["fma"] = Features["avx"] = Features["f16c"] = false;
  2243. setXOPLevel(Features, FMA4, false);
  2244. case AVX2:
  2245. Features["avx2"] = false;
  2246. case AVX512F:
  2247. Features["avx512f"] = Features["avx512cd"] = Features["avx512er"] =
  2248. Features["avx512pf"] = Features["avx512dq"] = Features["avx512bw"] =
  2249. Features["avx512vl"] = false;
  2250. }
  2251. }
  2252. void X86TargetInfo::setMMXLevel(llvm::StringMap<bool> &Features,
  2253. MMX3DNowEnum Level, bool Enabled) {
  2254. if (Enabled) {
  2255. switch (Level) {
  2256. case AMD3DNowAthlon:
  2257. Features["3dnowa"] = true;
  2258. case AMD3DNow:
  2259. Features["3dnow"] = true;
  2260. case MMX:
  2261. Features["mmx"] = true;
  2262. case NoMMX3DNow:
  2263. break;
  2264. }
  2265. return;
  2266. }
  2267. switch (Level) {
  2268. case NoMMX3DNow:
  2269. case MMX:
  2270. Features["mmx"] = false;
  2271. case AMD3DNow:
  2272. Features["3dnow"] = false;
  2273. case AMD3DNowAthlon:
  2274. Features["3dnowa"] = false;
  2275. }
  2276. }
  2277. void X86TargetInfo::setXOPLevel(llvm::StringMap<bool> &Features, XOPEnum Level,
  2278. bool Enabled) {
  2279. if (Enabled) {
  2280. switch (Level) {
  2281. case XOP:
  2282. Features["xop"] = true;
  2283. case FMA4:
  2284. Features["fma4"] = true;
  2285. setSSELevel(Features, AVX, true);
  2286. case SSE4A:
  2287. Features["sse4a"] = true;
  2288. setSSELevel(Features, SSE3, true);
  2289. case NoXOP:
  2290. break;
  2291. }
  2292. return;
  2293. }
  2294. switch (Level) {
  2295. case NoXOP:
  2296. case SSE4A:
  2297. Features["sse4a"] = false;
  2298. case FMA4:
  2299. Features["fma4"] = false;
  2300. case XOP:
  2301. Features["xop"] = false;
  2302. }
  2303. }
  2304. void X86TargetInfo::setFeatureEnabledImpl(llvm::StringMap<bool> &Features,
  2305. StringRef Name, bool Enabled) {
  2306. // FIXME: This *really* should not be here. We need some way of translating
  2307. // options into llvm subtarget features.
  2308. if (Name == "sse4")
  2309. Name = "sse4.2";
  2310. Features[Name] = Enabled;
  2311. if (Name == "mmx") {
  2312. setMMXLevel(Features, MMX, Enabled);
  2313. } else if (Name == "sse") {
  2314. setSSELevel(Features, SSE1, Enabled);
  2315. } else if (Name == "sse2") {
  2316. setSSELevel(Features, SSE2, Enabled);
  2317. } else if (Name == "sse3") {
  2318. setSSELevel(Features, SSE3, Enabled);
  2319. } else if (Name == "ssse3") {
  2320. setSSELevel(Features, SSSE3, Enabled);
  2321. } else if (Name == "sse4.2") {
  2322. setSSELevel(Features, SSE42, Enabled);
  2323. } else if (Name == "sse4.1") {
  2324. setSSELevel(Features, SSE41, Enabled);
  2325. } else if (Name == "3dnow") {
  2326. setMMXLevel(Features, AMD3DNow, Enabled);
  2327. } else if (Name == "3dnowa") {
  2328. setMMXLevel(Features, AMD3DNowAthlon, Enabled);
  2329. } else if (Name == "aes") {
  2330. if (Enabled)
  2331. setSSELevel(Features, SSE2, Enabled);
  2332. } else if (Name == "pclmul") {
  2333. if (Enabled)
  2334. setSSELevel(Features, SSE2, Enabled);
  2335. } else if (Name == "avx") {
  2336. setSSELevel(Features, AVX, Enabled);
  2337. } else if (Name == "avx2") {
  2338. setSSELevel(Features, AVX2, Enabled);
  2339. } else if (Name == "avx512f") {
  2340. setSSELevel(Features, AVX512F, Enabled);
  2341. } else if (Name == "avx512cd" || Name == "avx512er" || Name == "avx512pf"
  2342. || Name == "avx512dq" || Name == "avx512bw" || Name == "avx512vl") {
  2343. if (Enabled)
  2344. setSSELevel(Features, AVX512F, Enabled);
  2345. } else if (Name == "fma") {
  2346. if (Enabled)
  2347. setSSELevel(Features, AVX, Enabled);
  2348. } else if (Name == "fma4") {
  2349. setXOPLevel(Features, FMA4, Enabled);
  2350. } else if (Name == "xop") {
  2351. setXOPLevel(Features, XOP, Enabled);
  2352. } else if (Name == "sse4a") {
  2353. setXOPLevel(Features, SSE4A, Enabled);
  2354. } else if (Name == "f16c") {
  2355. if (Enabled)
  2356. setSSELevel(Features, AVX, Enabled);
  2357. } else if (Name == "sha") {
  2358. if (Enabled)
  2359. setSSELevel(Features, SSE2, Enabled);
  2360. }
  2361. }
  2362. /// handleTargetFeatures - Perform initialization based on the user
  2363. /// configured set of features.
  2364. bool X86TargetInfo::handleTargetFeatures(std::vector<std::string> &Features,
  2365. DiagnosticsEngine &Diags) {
  2366. // Remember the maximum enabled sselevel.
  2367. for (unsigned i = 0, e = Features.size(); i !=e; ++i) {
  2368. // Ignore disabled features.
  2369. if (Features[i][0] == '-')
  2370. continue;
  2371. StringRef Feature = StringRef(Features[i]).substr(1);
  2372. if (Feature == "aes") {
  2373. HasAES = true;
  2374. continue;
  2375. }
  2376. if (Feature == "pclmul") {
  2377. HasPCLMUL = true;
  2378. continue;
  2379. }
  2380. if (Feature == "lzcnt") {
  2381. HasLZCNT = true;
  2382. continue;
  2383. }
  2384. if (Feature == "rdrnd") {
  2385. HasRDRND = true;
  2386. continue;
  2387. }
  2388. if (Feature == "fsgsbase") {
  2389. HasFSGSBASE = true;
  2390. continue;
  2391. }
  2392. if (Feature == "bmi") {
  2393. HasBMI = true;
  2394. continue;
  2395. }
  2396. if (Feature == "bmi2") {
  2397. HasBMI2 = true;
  2398. continue;
  2399. }
  2400. if (Feature == "popcnt") {
  2401. HasPOPCNT = true;
  2402. continue;
  2403. }
  2404. if (Feature == "rtm") {
  2405. HasRTM = true;
  2406. continue;
  2407. }
  2408. if (Feature == "prfchw") {
  2409. HasPRFCHW = true;
  2410. continue;
  2411. }
  2412. if (Feature == "rdseed") {
  2413. HasRDSEED = true;
  2414. continue;
  2415. }
  2416. if (Feature == "adx") {
  2417. HasADX = true;
  2418. continue;
  2419. }
  2420. if (Feature == "tbm") {
  2421. HasTBM = true;
  2422. continue;
  2423. }
  2424. if (Feature == "fma") {
  2425. HasFMA = true;
  2426. continue;
  2427. }
  2428. if (Feature == "f16c") {
  2429. HasF16C = true;
  2430. continue;
  2431. }
  2432. if (Feature == "avx512cd") {
  2433. HasAVX512CD = true;
  2434. continue;
  2435. }
  2436. if (Feature == "avx512er") {
  2437. HasAVX512ER = true;
  2438. continue;
  2439. }
  2440. if (Feature == "avx512pf") {
  2441. HasAVX512PF = true;
  2442. continue;
  2443. }
  2444. if (Feature == "avx512dq") {
  2445. HasAVX512DQ = true;
  2446. continue;
  2447. }
  2448. if (Feature == "avx512bw") {
  2449. HasAVX512BW = true;
  2450. continue;
  2451. }
  2452. if (Feature == "avx512vl") {
  2453. HasAVX512VL = true;
  2454. continue;
  2455. }
  2456. if (Feature == "sha") {
  2457. HasSHA = true;
  2458. continue;
  2459. }
  2460. if (Feature == "cx16") {
  2461. HasCX16 = true;
  2462. continue;
  2463. }
  2464. assert(Features[i][0] == '+' && "Invalid target feature!");
  2465. X86SSEEnum Level = llvm::StringSwitch<X86SSEEnum>(Feature)
  2466. .Case("avx512f", AVX512F)
  2467. .Case("avx2", AVX2)
  2468. .Case("avx", AVX)
  2469. .Case("sse4.2", SSE42)
  2470. .Case("sse4.1", SSE41)
  2471. .Case("ssse3", SSSE3)
  2472. .Case("sse3", SSE3)
  2473. .Case("sse2", SSE2)
  2474. .Case("sse", SSE1)
  2475. .Default(NoSSE);
  2476. SSELevel = std::max(SSELevel, Level);
  2477. MMX3DNowEnum ThreeDNowLevel =
  2478. llvm::StringSwitch<MMX3DNowEnum>(Feature)
  2479. .Case("3dnowa", AMD3DNowAthlon)
  2480. .Case("3dnow", AMD3DNow)
  2481. .Case("mmx", MMX)
  2482. .Default(NoMMX3DNow);
  2483. MMX3DNowLevel = std::max(MMX3DNowLevel, ThreeDNowLevel);
  2484. XOPEnum XLevel = llvm::StringSwitch<XOPEnum>(Feature)
  2485. .Case("xop", XOP)
  2486. .Case("fma4", FMA4)
  2487. .Case("sse4a", SSE4A)
  2488. .Default(NoXOP);
  2489. XOPLevel = std::max(XOPLevel, XLevel);
  2490. }
  2491. // Enable popcnt if sse4.2 is enabled and popcnt is not explicitly disabled.
  2492. // Can't do this earlier because we need to be able to explicitly enable
  2493. // popcnt and still disable sse4.2.
  2494. if (!HasPOPCNT && SSELevel >= SSE42 &&
  2495. std::find(Features.begin(), Features.end(), "-popcnt") == Features.end()){
  2496. HasPOPCNT = true;
  2497. Features.push_back("+popcnt");
  2498. }
  2499. // Enable prfchw if 3DNow! is enabled and prfchw is not explicitly disabled.
  2500. if (!HasPRFCHW && MMX3DNowLevel >= AMD3DNow &&
  2501. std::find(Features.begin(), Features.end(), "-prfchw") == Features.end()){
  2502. HasPRFCHW = true;
  2503. Features.push_back("+prfchw");
  2504. }
  2505. // LLVM doesn't have a separate switch for fpmath, so only accept it if it
  2506. // matches the selected sse level.
  2507. if (FPMath == FP_SSE && SSELevel < SSE1) {
  2508. Diags.Report(diag::err_target_unsupported_fpmath) << "sse";
  2509. return false;
  2510. } else if (FPMath == FP_387 && SSELevel >= SSE1) {
  2511. Diags.Report(diag::err_target_unsupported_fpmath) << "387";
  2512. return false;
  2513. }
  2514. // Don't tell the backend if we're turning off mmx; it will end up disabling
  2515. // SSE, which we don't want.
  2516. // Additionally, if SSE is enabled and mmx is not explicitly disabled,
  2517. // then enable MMX.
  2518. std::vector<std::string>::iterator it;
  2519. it = std::find(Features.begin(), Features.end(), "-mmx");
  2520. if (it != Features.end())
  2521. Features.erase(it);
  2522. else if (SSELevel > NoSSE)
  2523. MMX3DNowLevel = std::max(MMX3DNowLevel, MMX);
  2524. return true;
  2525. }
  2526. /// X86TargetInfo::getTargetDefines - Return the set of the X86-specific macro
  2527. /// definitions for this particular subtarget.
  2528. void X86TargetInfo::getTargetDefines(const LangOptions &Opts,
  2529. MacroBuilder &Builder) const {
  2530. // Target identification.
  2531. if (getTriple().getArch() == llvm::Triple::x86_64) {
  2532. Builder.defineMacro("__amd64__");
  2533. Builder.defineMacro("__amd64");
  2534. Builder.defineMacro("__x86_64");
  2535. Builder.defineMacro("__x86_64__");
  2536. if (getTriple().getArchName() == "x86_64h") {
  2537. Builder.defineMacro("__x86_64h");
  2538. Builder.defineMacro("__x86_64h__");
  2539. }
  2540. } else {
  2541. DefineStd(Builder, "i386", Opts);
  2542. }
  2543. // Subtarget options.
  2544. // FIXME: We are hard-coding the tune parameters based on the CPU, but they
  2545. // truly should be based on -mtune options.
  2546. switch (CPU) {
  2547. case CK_Generic:
  2548. break;
  2549. case CK_i386:
  2550. // The rest are coming from the i386 define above.
  2551. Builder.defineMacro("__tune_i386__");
  2552. break;
  2553. case CK_i486:
  2554. case CK_WinChipC6:
  2555. case CK_WinChip2:
  2556. case CK_C3:
  2557. defineCPUMacros(Builder, "i486");
  2558. break;
  2559. case CK_PentiumMMX:
  2560. Builder.defineMacro("__pentium_mmx__");
  2561. Builder.defineMacro("__tune_pentium_mmx__");
  2562. // Fallthrough
  2563. case CK_i586:
  2564. case CK_Pentium:
  2565. defineCPUMacros(Builder, "i586");
  2566. defineCPUMacros(Builder, "pentium");
  2567. break;
  2568. case CK_Pentium3:
  2569. case CK_Pentium3M:
  2570. case CK_PentiumM:
  2571. Builder.defineMacro("__tune_pentium3__");
  2572. // Fallthrough
  2573. case CK_Pentium2:
  2574. case CK_C3_2:
  2575. Builder.defineMacro("__tune_pentium2__");
  2576. // Fallthrough
  2577. case CK_PentiumPro:
  2578. Builder.defineMacro("__tune_i686__");
  2579. Builder.defineMacro("__tune_pentiumpro__");
  2580. // Fallthrough
  2581. case CK_i686:
  2582. Builder.defineMacro("__i686");
  2583. Builder.defineMacro("__i686__");
  2584. // Strangely, __tune_i686__ isn't defined by GCC when CPU == i686.
  2585. Builder.defineMacro("__pentiumpro");
  2586. Builder.defineMacro("__pentiumpro__");
  2587. break;
  2588. case CK_Pentium4:
  2589. case CK_Pentium4M:
  2590. defineCPUMacros(Builder, "pentium4");
  2591. break;
  2592. case CK_Yonah:
  2593. case CK_Prescott:
  2594. case CK_Nocona:
  2595. defineCPUMacros(Builder, "nocona");
  2596. break;
  2597. case CK_Core2:
  2598. case CK_Penryn:
  2599. defineCPUMacros(Builder, "core2");
  2600. break;
  2601. case CK_Bonnell:
  2602. defineCPUMacros(Builder, "atom");
  2603. break;
  2604. case CK_Silvermont:
  2605. defineCPUMacros(Builder, "slm");
  2606. break;
  2607. case CK_Nehalem:
  2608. case CK_Westmere:
  2609. case CK_SandyBridge:
  2610. case CK_IvyBridge:
  2611. case CK_Haswell:
  2612. case CK_Broadwell:
  2613. // FIXME: Historically, we defined this legacy name, it would be nice to
  2614. // remove it at some point. We've never exposed fine-grained names for
  2615. // recent primary x86 CPUs, and we should keep it that way.
  2616. defineCPUMacros(Builder, "corei7");
  2617. break;
  2618. case CK_Skylake:
  2619. // FIXME: Historically, we defined this legacy name, it would be nice to
  2620. // remove it at some point. This is the only fine-grained CPU macro in the
  2621. // main intel CPU line, and it would be better to not have these and force
  2622. // people to use ISA macros.
  2623. defineCPUMacros(Builder, "skx");
  2624. break;
  2625. case CK_KNL:
  2626. defineCPUMacros(Builder, "knl");
  2627. break;
  2628. case CK_K6_2:
  2629. Builder.defineMacro("__k6_2__");
  2630. Builder.defineMacro("__tune_k6_2__");
  2631. // Fallthrough
  2632. case CK_K6_3:
  2633. if (CPU != CK_K6_2) { // In case of fallthrough
  2634. // FIXME: GCC may be enabling these in cases where some other k6
  2635. // architecture is specified but -m3dnow is explicitly provided. The
  2636. // exact semantics need to be determined and emulated here.
  2637. Builder.defineMacro("__k6_3__");
  2638. Builder.defineMacro("__tune_k6_3__");
  2639. }
  2640. // Fallthrough
  2641. case CK_K6:
  2642. defineCPUMacros(Builder, "k6");
  2643. break;
  2644. case CK_Athlon:
  2645. case CK_AthlonThunderbird:
  2646. case CK_Athlon4:
  2647. case CK_AthlonXP:
  2648. case CK_AthlonMP:
  2649. defineCPUMacros(Builder, "athlon");
  2650. if (SSELevel != NoSSE) {
  2651. Builder.defineMacro("__athlon_sse__");
  2652. Builder.defineMacro("__tune_athlon_sse__");
  2653. }
  2654. break;
  2655. case CK_K8:
  2656. case CK_K8SSE3:
  2657. case CK_x86_64:
  2658. case CK_Opteron:
  2659. case CK_OpteronSSE3:
  2660. case CK_Athlon64:
  2661. case CK_Athlon64SSE3:
  2662. case CK_AthlonFX:
  2663. defineCPUMacros(Builder, "k8");
  2664. break;
  2665. case CK_AMDFAM10:
  2666. defineCPUMacros(Builder, "amdfam10");
  2667. break;
  2668. case CK_BTVER1:
  2669. defineCPUMacros(Builder, "btver1");
  2670. break;
  2671. case CK_BTVER2:
  2672. defineCPUMacros(Builder, "btver2");
  2673. break;
  2674. case CK_BDVER1:
  2675. defineCPUMacros(Builder, "bdver1");
  2676. break;
  2677. case CK_BDVER2:
  2678. defineCPUMacros(Builder, "bdver2");
  2679. break;
  2680. case CK_BDVER3:
  2681. defineCPUMacros(Builder, "bdver3");
  2682. break;
  2683. case CK_BDVER4:
  2684. defineCPUMacros(Builder, "bdver4");
  2685. break;
  2686. case CK_Geode:
  2687. defineCPUMacros(Builder, "geode");
  2688. break;
  2689. }
  2690. // Target properties.
  2691. Builder.defineMacro("__REGISTER_PREFIX__", "");
  2692. // Define __NO_MATH_INLINES on linux/x86 so that we don't get inline
  2693. // functions in glibc header files that use FP Stack inline asm which the
  2694. // backend can't deal with (PR879).
  2695. Builder.defineMacro("__NO_MATH_INLINES");
  2696. if (HasAES)
  2697. Builder.defineMacro("__AES__");
  2698. if (HasPCLMUL)
  2699. Builder.defineMacro("__PCLMUL__");
  2700. if (HasLZCNT)
  2701. Builder.defineMacro("__LZCNT__");
  2702. if (HasRDRND)
  2703. Builder.defineMacro("__RDRND__");
  2704. if (HasFSGSBASE)
  2705. Builder.defineMacro("__FSGSBASE__");
  2706. if (HasBMI)
  2707. Builder.defineMacro("__BMI__");
  2708. if (HasBMI2)
  2709. Builder.defineMacro("__BMI2__");
  2710. if (HasPOPCNT)
  2711. Builder.defineMacro("__POPCNT__");
  2712. if (HasRTM)
  2713. Builder.defineMacro("__RTM__");
  2714. if (HasPRFCHW)
  2715. Builder.defineMacro("__PRFCHW__");
  2716. if (HasRDSEED)
  2717. Builder.defineMacro("__RDSEED__");
  2718. if (HasADX)
  2719. Builder.defineMacro("__ADX__");
  2720. if (HasTBM)
  2721. Builder.defineMacro("__TBM__");
  2722. switch (XOPLevel) {
  2723. case XOP:
  2724. Builder.defineMacro("__XOP__");
  2725. case FMA4:
  2726. Builder.defineMacro("__FMA4__");
  2727. case SSE4A:
  2728. Builder.defineMacro("__SSE4A__");
  2729. case NoXOP:
  2730. break;
  2731. }
  2732. if (HasFMA)
  2733. Builder.defineMacro("__FMA__");
  2734. if (HasF16C)
  2735. Builder.defineMacro("__F16C__");
  2736. if (HasAVX512CD)
  2737. Builder.defineMacro("__AVX512CD__");
  2738. if (HasAVX512ER)
  2739. Builder.defineMacro("__AVX512ER__");
  2740. if (HasAVX512PF)
  2741. Builder.defineMacro("__AVX512PF__");
  2742. if (HasAVX512DQ)
  2743. Builder.defineMacro("__AVX512DQ__");
  2744. if (HasAVX512BW)
  2745. Builder.defineMacro("__AVX512BW__");
  2746. if (HasAVX512VL)
  2747. Builder.defineMacro("__AVX512VL__");
  2748. if (HasSHA)
  2749. Builder.defineMacro("__SHA__");
  2750. if (HasCX16)
  2751. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_16");
  2752. // Each case falls through to the previous one here.
  2753. switch (SSELevel) {
  2754. case AVX512F:
  2755. Builder.defineMacro("__AVX512F__");
  2756. case AVX2:
  2757. Builder.defineMacro("__AVX2__");
  2758. case AVX:
  2759. Builder.defineMacro("__AVX__");
  2760. case SSE42:
  2761. Builder.defineMacro("__SSE4_2__");
  2762. case SSE41:
  2763. Builder.defineMacro("__SSE4_1__");
  2764. case SSSE3:
  2765. Builder.defineMacro("__SSSE3__");
  2766. case SSE3:
  2767. Builder.defineMacro("__SSE3__");
  2768. case SSE2:
  2769. Builder.defineMacro("__SSE2__");
  2770. Builder.defineMacro("__SSE2_MATH__"); // -mfp-math=sse always implied.
  2771. case SSE1:
  2772. Builder.defineMacro("__SSE__");
  2773. Builder.defineMacro("__SSE_MATH__"); // -mfp-math=sse always implied.
  2774. case NoSSE:
  2775. break;
  2776. }
  2777. if (Opts.MicrosoftExt && getTriple().getArch() == llvm::Triple::x86) {
  2778. switch (SSELevel) {
  2779. case AVX512F:
  2780. case AVX2:
  2781. case AVX:
  2782. case SSE42:
  2783. case SSE41:
  2784. case SSSE3:
  2785. case SSE3:
  2786. case SSE2:
  2787. Builder.defineMacro("_M_IX86_FP", Twine(2));
  2788. break;
  2789. case SSE1:
  2790. Builder.defineMacro("_M_IX86_FP", Twine(1));
  2791. break;
  2792. default:
  2793. Builder.defineMacro("_M_IX86_FP", Twine(0));
  2794. }
  2795. }
  2796. // Each case falls through to the previous one here.
  2797. switch (MMX3DNowLevel) {
  2798. case AMD3DNowAthlon:
  2799. Builder.defineMacro("__3dNOW_A__");
  2800. case AMD3DNow:
  2801. Builder.defineMacro("__3dNOW__");
  2802. case MMX:
  2803. Builder.defineMacro("__MMX__");
  2804. case NoMMX3DNow:
  2805. break;
  2806. }
  2807. if (CPU >= CK_i486) {
  2808. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_1");
  2809. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_2");
  2810. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4");
  2811. }
  2812. if (CPU >= CK_i586)
  2813. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8");
  2814. }
  2815. bool X86TargetInfo::hasFeature(StringRef Feature) const {
  2816. return llvm::StringSwitch<bool>(Feature)
  2817. .Case("aes", HasAES)
  2818. .Case("avx", SSELevel >= AVX)
  2819. .Case("avx2", SSELevel >= AVX2)
  2820. .Case("avx512f", SSELevel >= AVX512F)
  2821. .Case("avx512cd", HasAVX512CD)
  2822. .Case("avx512er", HasAVX512ER)
  2823. .Case("avx512pf", HasAVX512PF)
  2824. .Case("avx512dq", HasAVX512DQ)
  2825. .Case("avx512bw", HasAVX512BW)
  2826. .Case("avx512vl", HasAVX512VL)
  2827. .Case("bmi", HasBMI)
  2828. .Case("bmi2", HasBMI2)
  2829. .Case("cx16", HasCX16)
  2830. .Case("f16c", HasF16C)
  2831. .Case("fma", HasFMA)
  2832. .Case("fma4", XOPLevel >= FMA4)
  2833. .Case("fsgsbase", HasFSGSBASE)
  2834. .Case("lzcnt", HasLZCNT)
  2835. .Case("mm3dnow", MMX3DNowLevel >= AMD3DNow)
  2836. .Case("mm3dnowa", MMX3DNowLevel >= AMD3DNowAthlon)
  2837. .Case("mmx", MMX3DNowLevel >= MMX)
  2838. .Case("pclmul", HasPCLMUL)
  2839. .Case("popcnt", HasPOPCNT)
  2840. .Case("prfchw", HasPRFCHW)
  2841. .Case("rdrnd", HasRDRND)
  2842. .Case("rdseed", HasRDSEED)
  2843. .Case("rtm", HasRTM)
  2844. .Case("sha", HasSHA)
  2845. .Case("sse", SSELevel >= SSE1)
  2846. .Case("sse2", SSELevel >= SSE2)
  2847. .Case("sse3", SSELevel >= SSE3)
  2848. .Case("ssse3", SSELevel >= SSSE3)
  2849. .Case("sse4.1", SSELevel >= SSE41)
  2850. .Case("sse4.2", SSELevel >= SSE42)
  2851. .Case("sse4a", XOPLevel >= SSE4A)
  2852. .Case("tbm", HasTBM)
  2853. .Case("x86", true)
  2854. .Case("x86_32", getTriple().getArch() == llvm::Triple::x86)
  2855. .Case("x86_64", getTriple().getArch() == llvm::Triple::x86_64)
  2856. .Case("xop", XOPLevel >= XOP)
  2857. .Default(false);
  2858. }
  2859. bool
  2860. X86TargetInfo::validateAsmConstraint(const char *&Name,
  2861. TargetInfo::ConstraintInfo &Info) const {
  2862. switch (*Name) {
  2863. default: return false;
  2864. case 'I':
  2865. Info.setRequiresImmediate(0, 31);
  2866. return true;
  2867. case 'J':
  2868. Info.setRequiresImmediate(0, 63);
  2869. return true;
  2870. case 'K':
  2871. Info.setRequiresImmediate(-128, 127);
  2872. return true;
  2873. case 'L':
  2874. // FIXME: properly analyze this constraint:
  2875. // must be one of 0xff, 0xffff, or 0xffffffff
  2876. return true;
  2877. case 'M':
  2878. Info.setRequiresImmediate(0, 3);
  2879. return true;
  2880. case 'N':
  2881. Info.setRequiresImmediate(0, 255);
  2882. return true;
  2883. case 'O':
  2884. Info.setRequiresImmediate(0, 127);
  2885. return true;
  2886. case 'Y': // first letter of a pair:
  2887. switch (*(Name+1)) {
  2888. default: return false;
  2889. case '0': // First SSE register.
  2890. case 't': // Any SSE register, when SSE2 is enabled.
  2891. case 'i': // Any SSE register, when SSE2 and inter-unit moves enabled.
  2892. case 'm': // any MMX register, when inter-unit moves enabled.
  2893. break; // falls through to setAllowsRegister.
  2894. }
  2895. case 'f': // any x87 floating point stack register.
  2896. // Constraint 'f' cannot be used for output operands.
  2897. if (Info.ConstraintStr[0] == '=')
  2898. return false;
  2899. Info.setAllowsRegister();
  2900. return true;
  2901. case 'a': // eax.
  2902. case 'b': // ebx.
  2903. case 'c': // ecx.
  2904. case 'd': // edx.
  2905. case 'S': // esi.
  2906. case 'D': // edi.
  2907. case 'A': // edx:eax.
  2908. case 't': // top of floating point stack.
  2909. case 'u': // second from top of floating point stack.
  2910. case 'q': // Any register accessible as [r]l: a, b, c, and d.
  2911. case 'y': // Any MMX register.
  2912. case 'x': // Any SSE register.
  2913. case 'Q': // Any register accessible as [r]h: a, b, c, and d.
  2914. case 'R': // "Legacy" registers: ax, bx, cx, dx, di, si, sp, bp.
  2915. case 'l': // "Index" registers: any general register that can be used as an
  2916. // index in a base+index memory access.
  2917. Info.setAllowsRegister();
  2918. return true;
  2919. case 'C': // SSE floating point constant.
  2920. case 'G': // x87 floating point constant.
  2921. case 'e': // 32-bit signed integer constant for use with zero-extending
  2922. // x86_64 instructions.
  2923. case 'Z': // 32-bit unsigned integer constant for use with zero-extending
  2924. // x86_64 instructions.
  2925. return true;
  2926. }
  2927. }
  2928. bool X86TargetInfo::validateOutputSize(StringRef Constraint,
  2929. unsigned Size) const {
  2930. // Strip off constraint modifiers.
  2931. while (Constraint[0] == '=' ||
  2932. Constraint[0] == '+' ||
  2933. Constraint[0] == '&')
  2934. Constraint = Constraint.substr(1);
  2935. return validateOperandSize(Constraint, Size);
  2936. }
  2937. bool X86TargetInfo::validateInputSize(StringRef Constraint,
  2938. unsigned Size) const {
  2939. return validateOperandSize(Constraint, Size);
  2940. }
  2941. bool X86TargetInfo::validateOperandSize(StringRef Constraint,
  2942. unsigned Size) const {
  2943. switch (Constraint[0]) {
  2944. default: break;
  2945. case 'y':
  2946. return Size <= 64;
  2947. case 'f':
  2948. case 't':
  2949. case 'u':
  2950. return Size <= 128;
  2951. case 'x':
  2952. // 256-bit ymm registers can be used if target supports AVX.
  2953. return Size <= (SSELevel >= AVX ? 256U : 128U);
  2954. }
  2955. return true;
  2956. }
  2957. std::string
  2958. X86TargetInfo::convertConstraint(const char *&Constraint) const {
  2959. switch (*Constraint) {
  2960. case 'a': return std::string("{ax}");
  2961. case 'b': return std::string("{bx}");
  2962. case 'c': return std::string("{cx}");
  2963. case 'd': return std::string("{dx}");
  2964. case 'S': return std::string("{si}");
  2965. case 'D': return std::string("{di}");
  2966. case 'p': // address
  2967. return std::string("im");
  2968. case 't': // top of floating point stack.
  2969. return std::string("{st}");
  2970. case 'u': // second from top of floating point stack.
  2971. return std::string("{st(1)}"); // second from top of floating point stack.
  2972. default:
  2973. return std::string(1, *Constraint);
  2974. }
  2975. }
  2976. } // end anonymous namespace
  2977. namespace {
  2978. // X86-32 generic target
  2979. class X86_32TargetInfo : public X86TargetInfo {
  2980. public:
  2981. X86_32TargetInfo(const llvm::Triple &Triple) : X86TargetInfo(Triple) {
  2982. DoubleAlign = LongLongAlign = 32;
  2983. LongDoubleWidth = 96;
  2984. LongDoubleAlign = 32;
  2985. SuitableAlign = 128;
  2986. DescriptionString = "e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128";
  2987. SizeType = UnsignedInt;
  2988. PtrDiffType = SignedInt;
  2989. IntPtrType = SignedInt;
  2990. RegParmMax = 3;
  2991. // Use fpret for all types.
  2992. RealTypeUsesObjCFPRet = ((1 << TargetInfo::Float) |
  2993. (1 << TargetInfo::Double) |
  2994. (1 << TargetInfo::LongDouble));
  2995. // x86-32 has atomics up to 8 bytes
  2996. // FIXME: Check that we actually have cmpxchg8b before setting
  2997. // MaxAtomicInlineWidth. (cmpxchg8b is an i586 instruction.)
  2998. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
  2999. }
  3000. BuiltinVaListKind getBuiltinVaListKind() const override {
  3001. return TargetInfo::CharPtrBuiltinVaList;
  3002. }
  3003. int getEHDataRegisterNumber(unsigned RegNo) const override {
  3004. if (RegNo == 0) return 0;
  3005. if (RegNo == 1) return 2;
  3006. return -1;
  3007. }
  3008. bool validateOperandSize(StringRef Constraint,
  3009. unsigned Size) const override {
  3010. switch (Constraint[0]) {
  3011. default: break;
  3012. case 'R':
  3013. case 'q':
  3014. case 'Q':
  3015. case 'a':
  3016. case 'b':
  3017. case 'c':
  3018. case 'd':
  3019. case 'S':
  3020. case 'D':
  3021. return Size <= 32;
  3022. case 'A':
  3023. return Size <= 64;
  3024. }
  3025. return X86TargetInfo::validateOperandSize(Constraint, Size);
  3026. }
  3027. };
  3028. } // end anonymous namespace
  3029. namespace {
  3030. class NetBSDI386TargetInfo : public NetBSDTargetInfo<X86_32TargetInfo> {
  3031. public:
  3032. NetBSDI386TargetInfo(const llvm::Triple &Triple)
  3033. : NetBSDTargetInfo<X86_32TargetInfo>(Triple) {}
  3034. unsigned getFloatEvalMethod() const override {
  3035. unsigned Major, Minor, Micro;
  3036. getTriple().getOSVersion(Major, Minor, Micro);
  3037. // New NetBSD uses the default rounding mode.
  3038. if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 26) || Major == 0)
  3039. return X86_32TargetInfo::getFloatEvalMethod();
  3040. // NetBSD before 6.99.26 defaults to "double" rounding.
  3041. return 1;
  3042. }
  3043. };
  3044. } // end anonymous namespace
  3045. namespace {
  3046. class OpenBSDI386TargetInfo : public OpenBSDTargetInfo<X86_32TargetInfo> {
  3047. public:
  3048. OpenBSDI386TargetInfo(const llvm::Triple &Triple)
  3049. : OpenBSDTargetInfo<X86_32TargetInfo>(Triple) {
  3050. SizeType = UnsignedLong;
  3051. IntPtrType = SignedLong;
  3052. PtrDiffType = SignedLong;
  3053. }
  3054. };
  3055. } // end anonymous namespace
  3056. namespace {
  3057. class BitrigI386TargetInfo : public BitrigTargetInfo<X86_32TargetInfo> {
  3058. public:
  3059. BitrigI386TargetInfo(const llvm::Triple &Triple)
  3060. : BitrigTargetInfo<X86_32TargetInfo>(Triple) {
  3061. SizeType = UnsignedLong;
  3062. IntPtrType = SignedLong;
  3063. PtrDiffType = SignedLong;
  3064. }
  3065. };
  3066. } // end anonymous namespace
  3067. namespace {
  3068. class DarwinI386TargetInfo : public DarwinTargetInfo<X86_32TargetInfo> {
  3069. public:
  3070. DarwinI386TargetInfo(const llvm::Triple &Triple)
  3071. : DarwinTargetInfo<X86_32TargetInfo>(Triple) {
  3072. LongDoubleWidth = 128;
  3073. LongDoubleAlign = 128;
  3074. SuitableAlign = 128;
  3075. MaxVectorAlign = 256;
  3076. SizeType = UnsignedLong;
  3077. IntPtrType = SignedLong;
  3078. DescriptionString = "e-m:o-p:32:32-f64:32:64-f80:128-n8:16:32-S128";
  3079. HasAlignMac68kSupport = true;
  3080. }
  3081. };
  3082. } // end anonymous namespace
  3083. namespace {
  3084. // x86-32 Windows target
  3085. class WindowsX86_32TargetInfo : public WindowsTargetInfo<X86_32TargetInfo> {
  3086. public:
  3087. WindowsX86_32TargetInfo(const llvm::Triple &Triple)
  3088. : WindowsTargetInfo<X86_32TargetInfo>(Triple) {
  3089. WCharType = UnsignedShort;
  3090. DoubleAlign = LongLongAlign = 64;
  3091. DescriptionString = "e-m:w-p:32:32-i64:64-f80:32-n8:16:32-S32";
  3092. }
  3093. void getTargetDefines(const LangOptions &Opts,
  3094. MacroBuilder &Builder) const override {
  3095. WindowsTargetInfo<X86_32TargetInfo>::getTargetDefines(Opts, Builder);
  3096. }
  3097. };
  3098. // x86-32 Windows Visual Studio target
  3099. class MicrosoftX86_32TargetInfo : public WindowsX86_32TargetInfo {
  3100. public:
  3101. MicrosoftX86_32TargetInfo(const llvm::Triple &Triple)
  3102. : WindowsX86_32TargetInfo(Triple) {
  3103. LongDoubleWidth = LongDoubleAlign = 64;
  3104. LongDoubleFormat = &llvm::APFloat::IEEEdouble;
  3105. }
  3106. void getTargetDefines(const LangOptions &Opts,
  3107. MacroBuilder &Builder) const override {
  3108. WindowsX86_32TargetInfo::getTargetDefines(Opts, Builder);
  3109. WindowsX86_32TargetInfo::getVisualStudioDefines(Opts, Builder);
  3110. // The value of the following reflects processor type.
  3111. // 300=386, 400=486, 500=Pentium, 600=Blend (default)
  3112. // We lost the original triple, so we use the default.
  3113. Builder.defineMacro("_M_IX86", "600");
  3114. }
  3115. };
  3116. } // end anonymous namespace
  3117. static void addMinGWDefines(const LangOptions &Opts, MacroBuilder &Builder) {
  3118. Builder.defineMacro("__MSVCRT__");
  3119. Builder.defineMacro("__MINGW32__");
  3120. // Mingw defines __declspec(a) to __attribute__((a)). Clang supports
  3121. // __declspec natively under -fms-extensions, but we define a no-op __declspec
  3122. // macro anyway for pre-processor compatibility.
  3123. if (Opts.MicrosoftExt)
  3124. Builder.defineMacro("__declspec", "__declspec");
  3125. else
  3126. Builder.defineMacro("__declspec(a)", "__attribute__((a))");
  3127. if (!Opts.MicrosoftExt) {
  3128. // Provide macros for all the calling convention keywords. Provide both
  3129. // single and double underscore prefixed variants. These are available on
  3130. // x64 as well as x86, even though they have no effect.
  3131. const char *CCs[] = {"cdecl", "stdcall", "fastcall", "thiscall", "pascal"};
  3132. for (const char *CC : CCs) {
  3133. std::string GCCSpelling = "__attribute__((__";
  3134. GCCSpelling += CC;
  3135. GCCSpelling += "__))";
  3136. Builder.defineMacro(Twine("_") + CC, GCCSpelling);
  3137. Builder.defineMacro(Twine("__") + CC, GCCSpelling);
  3138. }
  3139. }
  3140. }
  3141. namespace {
  3142. // x86-32 MinGW target
  3143. class MinGWX86_32TargetInfo : public WindowsX86_32TargetInfo {
  3144. public:
  3145. MinGWX86_32TargetInfo(const llvm::Triple &Triple)
  3146. : WindowsX86_32TargetInfo(Triple) {}
  3147. void getTargetDefines(const LangOptions &Opts,
  3148. MacroBuilder &Builder) const override {
  3149. WindowsX86_32TargetInfo::getTargetDefines(Opts, Builder);
  3150. DefineStd(Builder, "WIN32", Opts);
  3151. DefineStd(Builder, "WINNT", Opts);
  3152. Builder.defineMacro("_X86_");
  3153. addMinGWDefines(Opts, Builder);
  3154. }
  3155. };
  3156. } // end anonymous namespace
  3157. namespace {
  3158. // x86-32 Cygwin target
  3159. class CygwinX86_32TargetInfo : public X86_32TargetInfo {
  3160. public:
  3161. CygwinX86_32TargetInfo(const llvm::Triple &Triple)
  3162. : X86_32TargetInfo(Triple) {
  3163. TLSSupported = false;
  3164. WCharType = UnsignedShort;
  3165. DoubleAlign = LongLongAlign = 64;
  3166. DescriptionString = "e-m:w-p:32:32-i64:64-f80:32-n8:16:32-S32";
  3167. }
  3168. void getTargetDefines(const LangOptions &Opts,
  3169. MacroBuilder &Builder) const override {
  3170. X86_32TargetInfo::getTargetDefines(Opts, Builder);
  3171. Builder.defineMacro("_X86_");
  3172. Builder.defineMacro("__CYGWIN__");
  3173. Builder.defineMacro("__CYGWIN32__");
  3174. DefineStd(Builder, "unix", Opts);
  3175. if (Opts.CPlusPlus)
  3176. Builder.defineMacro("_GNU_SOURCE");
  3177. }
  3178. };
  3179. } // end anonymous namespace
  3180. namespace {
  3181. // x86-32 Haiku target
  3182. class HaikuX86_32TargetInfo : public X86_32TargetInfo {
  3183. public:
  3184. HaikuX86_32TargetInfo(const llvm::Triple &Triple) : X86_32TargetInfo(Triple) {
  3185. SizeType = UnsignedLong;
  3186. IntPtrType = SignedLong;
  3187. PtrDiffType = SignedLong;
  3188. ProcessIDType = SignedLong;
  3189. this->UserLabelPrefix = "";
  3190. this->TLSSupported = false;
  3191. }
  3192. void getTargetDefines(const LangOptions &Opts,
  3193. MacroBuilder &Builder) const override {
  3194. X86_32TargetInfo::getTargetDefines(Opts, Builder);
  3195. Builder.defineMacro("__INTEL__");
  3196. Builder.defineMacro("__HAIKU__");
  3197. }
  3198. };
  3199. } // end anonymous namespace
  3200. // RTEMS Target
  3201. template<typename Target>
  3202. class RTEMSTargetInfo : public OSTargetInfo<Target> {
  3203. protected:
  3204. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  3205. MacroBuilder &Builder) const override {
  3206. // RTEMS defines; list based off of gcc output
  3207. Builder.defineMacro("__rtems__");
  3208. Builder.defineMacro("__ELF__");
  3209. }
  3210. public:
  3211. RTEMSTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
  3212. this->UserLabelPrefix = "";
  3213. switch (Triple.getArch()) {
  3214. default:
  3215. case llvm::Triple::x86:
  3216. // this->MCountName = ".mcount";
  3217. break;
  3218. case llvm::Triple::mips:
  3219. case llvm::Triple::mipsel:
  3220. case llvm::Triple::ppc:
  3221. case llvm::Triple::ppc64:
  3222. case llvm::Triple::ppc64le:
  3223. // this->MCountName = "_mcount";
  3224. break;
  3225. case llvm::Triple::arm:
  3226. // this->MCountName = "__mcount";
  3227. break;
  3228. }
  3229. }
  3230. };
  3231. namespace {
  3232. // x86-32 RTEMS target
  3233. class RTEMSX86_32TargetInfo : public X86_32TargetInfo {
  3234. public:
  3235. RTEMSX86_32TargetInfo(const llvm::Triple &Triple) : X86_32TargetInfo(Triple) {
  3236. SizeType = UnsignedLong;
  3237. IntPtrType = SignedLong;
  3238. PtrDiffType = SignedLong;
  3239. this->UserLabelPrefix = "";
  3240. }
  3241. void getTargetDefines(const LangOptions &Opts,
  3242. MacroBuilder &Builder) const override {
  3243. X86_32TargetInfo::getTargetDefines(Opts, Builder);
  3244. Builder.defineMacro("__INTEL__");
  3245. Builder.defineMacro("__rtems__");
  3246. }
  3247. };
  3248. } // end anonymous namespace
  3249. namespace {
  3250. // x86-64 generic target
  3251. class X86_64TargetInfo : public X86TargetInfo {
  3252. public:
  3253. X86_64TargetInfo(const llvm::Triple &Triple) : X86TargetInfo(Triple) {
  3254. const bool IsX32 = getTriple().getEnvironment() == llvm::Triple::GNUX32;
  3255. LongWidth = LongAlign = PointerWidth = PointerAlign = IsX32 ? 32 : 64;
  3256. LongDoubleWidth = 128;
  3257. LongDoubleAlign = 128;
  3258. LargeArrayMinWidth = 128;
  3259. LargeArrayAlign = 128;
  3260. SuitableAlign = 128;
  3261. SizeType = IsX32 ? UnsignedInt : UnsignedLong;
  3262. PtrDiffType = IsX32 ? SignedInt : SignedLong;
  3263. IntPtrType = IsX32 ? SignedInt : SignedLong;
  3264. IntMaxType = IsX32 ? SignedLongLong : SignedLong;
  3265. Int64Type = IsX32 ? SignedLongLong : SignedLong;
  3266. RegParmMax = 6;
  3267. // Pointers are 32-bit in x32.
  3268. DescriptionString = (IsX32)
  3269. ? "e-m:e-p:32:32-i64:64-f80:128-n8:16:32:64-S128"
  3270. : "e-m:e-i64:64-f80:128-n8:16:32:64-S128";
  3271. // Use fpret only for long double.
  3272. RealTypeUsesObjCFPRet = (1 << TargetInfo::LongDouble);
  3273. // Use fp2ret for _Complex long double.
  3274. ComplexLongDoubleUsesFP2Ret = true;
  3275. // x86-64 has atomics up to 16 bytes.
  3276. MaxAtomicPromoteWidth = 128;
  3277. MaxAtomicInlineWidth = 128;
  3278. }
  3279. BuiltinVaListKind getBuiltinVaListKind() const override {
  3280. return TargetInfo::X86_64ABIBuiltinVaList;
  3281. }
  3282. int getEHDataRegisterNumber(unsigned RegNo) const override {
  3283. if (RegNo == 0) return 0;
  3284. if (RegNo == 1) return 1;
  3285. return -1;
  3286. }
  3287. CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
  3288. return (CC == CC_C ||
  3289. CC == CC_X86VectorCall ||
  3290. CC == CC_IntelOclBicc ||
  3291. CC == CC_X86_64Win64) ? CCCR_OK : CCCR_Warning;
  3292. }
  3293. CallingConv getDefaultCallingConv(CallingConvMethodType MT) const override {
  3294. return CC_C;
  3295. }
  3296. // for x32 we need it here explicitly
  3297. bool hasInt128Type() const override { return true; }
  3298. };
  3299. } // end anonymous namespace
  3300. namespace {
  3301. // x86-64 Windows target
  3302. class WindowsX86_64TargetInfo : public WindowsTargetInfo<X86_64TargetInfo> {
  3303. public:
  3304. WindowsX86_64TargetInfo(const llvm::Triple &Triple)
  3305. : WindowsTargetInfo<X86_64TargetInfo>(Triple) {
  3306. WCharType = UnsignedShort;
  3307. LongWidth = LongAlign = 32;
  3308. DoubleAlign = LongLongAlign = 64;
  3309. IntMaxType = SignedLongLong;
  3310. Int64Type = SignedLongLong;
  3311. SizeType = UnsignedLongLong;
  3312. PtrDiffType = SignedLongLong;
  3313. IntPtrType = SignedLongLong;
  3314. this->UserLabelPrefix = "";
  3315. }
  3316. void getTargetDefines(const LangOptions &Opts,
  3317. MacroBuilder &Builder) const override {
  3318. WindowsTargetInfo<X86_64TargetInfo>::getTargetDefines(Opts, Builder);
  3319. Builder.defineMacro("_WIN64");
  3320. }
  3321. BuiltinVaListKind getBuiltinVaListKind() const override {
  3322. return TargetInfo::CharPtrBuiltinVaList;
  3323. }
  3324. CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
  3325. return (CC == CC_C ||
  3326. CC == CC_X86VectorCall ||
  3327. CC == CC_IntelOclBicc ||
  3328. CC == CC_X86_64SysV) ? CCCR_OK : CCCR_Warning;
  3329. }
  3330. };
  3331. } // end anonymous namespace
  3332. namespace {
  3333. // x86-64 Windows Visual Studio target
  3334. class MicrosoftX86_64TargetInfo : public WindowsX86_64TargetInfo {
  3335. public:
  3336. MicrosoftX86_64TargetInfo(const llvm::Triple &Triple)
  3337. : WindowsX86_64TargetInfo(Triple) {
  3338. LongDoubleWidth = LongDoubleAlign = 64;
  3339. LongDoubleFormat = &llvm::APFloat::IEEEdouble;
  3340. }
  3341. void getTargetDefines(const LangOptions &Opts,
  3342. MacroBuilder &Builder) const override {
  3343. WindowsX86_64TargetInfo::getTargetDefines(Opts, Builder);
  3344. WindowsX86_64TargetInfo::getVisualStudioDefines(Opts, Builder);
  3345. Builder.defineMacro("_M_X64");
  3346. Builder.defineMacro("_M_AMD64");
  3347. }
  3348. };
  3349. } // end anonymous namespace
  3350. namespace {
  3351. // x86-64 MinGW target
  3352. class MinGWX86_64TargetInfo : public WindowsX86_64TargetInfo {
  3353. public:
  3354. MinGWX86_64TargetInfo(const llvm::Triple &Triple)
  3355. : WindowsX86_64TargetInfo(Triple) {}
  3356. void getTargetDefines(const LangOptions &Opts,
  3357. MacroBuilder &Builder) const override {
  3358. WindowsX86_64TargetInfo::getTargetDefines(Opts, Builder);
  3359. DefineStd(Builder, "WIN64", Opts);
  3360. Builder.defineMacro("__MINGW64__");
  3361. addMinGWDefines(Opts, Builder);
  3362. // GCC defines this macro when it is using __gxx_personality_seh0.
  3363. if (!Opts.SjLjExceptions)
  3364. Builder.defineMacro("__SEH__");
  3365. }
  3366. };
  3367. } // end anonymous namespace
  3368. namespace {
  3369. class DarwinX86_64TargetInfo : public DarwinTargetInfo<X86_64TargetInfo> {
  3370. public:
  3371. DarwinX86_64TargetInfo(const llvm::Triple &Triple)
  3372. : DarwinTargetInfo<X86_64TargetInfo>(Triple) {
  3373. Int64Type = SignedLongLong;
  3374. MaxVectorAlign = 256;
  3375. // The 64-bit iOS simulator uses the builtin bool type for Objective-C.
  3376. llvm::Triple T = llvm::Triple(Triple);
  3377. if (T.isiOS())
  3378. UseSignedCharForObjCBool = false;
  3379. DescriptionString = "e-m:o-i64:64-f80:128-n8:16:32:64-S128";
  3380. }
  3381. };
  3382. } // end anonymous namespace
  3383. namespace {
  3384. class OpenBSDX86_64TargetInfo : public OpenBSDTargetInfo<X86_64TargetInfo> {
  3385. public:
  3386. OpenBSDX86_64TargetInfo(const llvm::Triple &Triple)
  3387. : OpenBSDTargetInfo<X86_64TargetInfo>(Triple) {
  3388. IntMaxType = SignedLongLong;
  3389. Int64Type = SignedLongLong;
  3390. }
  3391. };
  3392. } // end anonymous namespace
  3393. namespace {
  3394. class BitrigX86_64TargetInfo : public BitrigTargetInfo<X86_64TargetInfo> {
  3395. public:
  3396. BitrigX86_64TargetInfo(const llvm::Triple &Triple)
  3397. : BitrigTargetInfo<X86_64TargetInfo>(Triple) {
  3398. IntMaxType = SignedLongLong;
  3399. Int64Type = SignedLongLong;
  3400. }
  3401. };
  3402. }
  3403. namespace {
  3404. class ARMTargetInfo : public TargetInfo {
  3405. // Possible FPU choices.
  3406. enum FPUMode {
  3407. VFP2FPU = (1 << 0),
  3408. VFP3FPU = (1 << 1),
  3409. VFP4FPU = (1 << 2),
  3410. NeonFPU = (1 << 3),
  3411. FPARMV8 = (1 << 4)
  3412. };
  3413. // Possible HWDiv features.
  3414. enum HWDivMode {
  3415. HWDivThumb = (1 << 0),
  3416. HWDivARM = (1 << 1)
  3417. };
  3418. static bool FPUModeIsVFP(FPUMode Mode) {
  3419. return Mode & (VFP2FPU | VFP3FPU | VFP4FPU | NeonFPU | FPARMV8);
  3420. }
  3421. static const TargetInfo::GCCRegAlias GCCRegAliases[];
  3422. static const char * const GCCRegNames[];
  3423. std::string ABI, CPU;
  3424. enum {
  3425. FP_Default,
  3426. FP_VFP,
  3427. FP_Neon
  3428. } FPMath;
  3429. unsigned FPU : 5;
  3430. unsigned IsAAPCS : 1;
  3431. unsigned IsThumb : 1;
  3432. unsigned HWDiv : 2;
  3433. // Initialized via features.
  3434. unsigned SoftFloat : 1;
  3435. unsigned SoftFloatABI : 1;
  3436. unsigned CRC : 1;
  3437. unsigned Crypto : 1;
  3438. // ACLE 6.5.1 Hardware floating point
  3439. enum {
  3440. HW_FP_HP = (1 << 1), /// half (16-bit)
  3441. HW_FP_SP = (1 << 2), /// single (32-bit)
  3442. HW_FP_DP = (1 << 3), /// double (64-bit)
  3443. };
  3444. uint32_t HW_FP;
  3445. static const Builtin::Info BuiltinInfo[];
  3446. static bool shouldUseInlineAtomic(const llvm::Triple &T) {
  3447. StringRef ArchName = T.getArchName();
  3448. if (T.getArch() == llvm::Triple::arm ||
  3449. T.getArch() == llvm::Triple::armeb) {
  3450. StringRef VersionStr;
  3451. if (ArchName.startswith("armv"))
  3452. VersionStr = ArchName.substr(4, 1);
  3453. else if (ArchName.startswith("armebv"))
  3454. VersionStr = ArchName.substr(6, 1);
  3455. else
  3456. return false;
  3457. unsigned Version;
  3458. if (VersionStr.getAsInteger(10, Version))
  3459. return false;
  3460. return Version >= 6;
  3461. }
  3462. assert(T.getArch() == llvm::Triple::thumb ||
  3463. T.getArch() == llvm::Triple::thumbeb);
  3464. StringRef VersionStr;
  3465. if (ArchName.startswith("thumbv"))
  3466. VersionStr = ArchName.substr(6, 1);
  3467. else if (ArchName.startswith("thumbebv"))
  3468. VersionStr = ArchName.substr(8, 1);
  3469. else
  3470. return false;
  3471. unsigned Version;
  3472. if (VersionStr.getAsInteger(10, Version))
  3473. return false;
  3474. return Version >= 7;
  3475. }
  3476. void setABIAAPCS() {
  3477. IsAAPCS = true;
  3478. DoubleAlign = LongLongAlign = LongDoubleAlign = SuitableAlign = 64;
  3479. const llvm::Triple &T = getTriple();
  3480. // size_t is unsigned long on MachO-derived environments and NetBSD.
  3481. if (T.isOSBinFormatMachO() || T.getOS() == llvm::Triple::NetBSD)
  3482. SizeType = UnsignedLong;
  3483. else
  3484. SizeType = UnsignedInt;
  3485. switch (T.getOS()) {
  3486. case llvm::Triple::NetBSD:
  3487. WCharType = SignedInt;
  3488. break;
  3489. case llvm::Triple::Win32:
  3490. WCharType = UnsignedShort;
  3491. break;
  3492. case llvm::Triple::Linux:
  3493. default:
  3494. // AAPCS 7.1.1, ARM-Linux ABI 2.4: type of wchar_t is unsigned int.
  3495. WCharType = UnsignedInt;
  3496. break;
  3497. }
  3498. UseBitFieldTypeAlignment = true;
  3499. ZeroLengthBitfieldBoundary = 0;
  3500. // Thumb1 add sp, #imm requires the immediate value be multiple of 4,
  3501. // so set preferred for small types to 32.
  3502. if (T.isOSBinFormatMachO()) {
  3503. DescriptionString =
  3504. BigEndian ? "E-m:o-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
  3505. : "e-m:o-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64";
  3506. } else if (T.isOSWindows()) {
  3507. // FIXME: this is invalid for WindowsCE
  3508. assert(!BigEndian && "Windows on ARM does not support big endian");
  3509. DescriptionString = "e"
  3510. "-m:e"
  3511. "-p:32:32"
  3512. "-i64:64"
  3513. "-v128:64:128"
  3514. "-a:0:32"
  3515. "-n32"
  3516. "-S64";
  3517. } else {
  3518. DescriptionString =
  3519. BigEndian ? "E-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
  3520. : "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64";
  3521. }
  3522. // FIXME: Enumerated types are variable width in straight AAPCS.
  3523. }
  3524. void setABIAPCS() {
  3525. const llvm::Triple &T = getTriple();
  3526. IsAAPCS = false;
  3527. DoubleAlign = LongLongAlign = LongDoubleAlign = SuitableAlign = 32;
  3528. // size_t is unsigned int on FreeBSD.
  3529. if (T.getOS() == llvm::Triple::FreeBSD)
  3530. SizeType = UnsignedInt;
  3531. else
  3532. SizeType = UnsignedLong;
  3533. // Revert to using SignedInt on apcs-gnu to comply with existing behaviour.
  3534. WCharType = SignedInt;
  3535. // Do not respect the alignment of bit-field types when laying out
  3536. // structures. This corresponds to PCC_BITFIELD_TYPE_MATTERS in gcc.
  3537. UseBitFieldTypeAlignment = false;
  3538. /// gcc forces the alignment to 4 bytes, regardless of the type of the
  3539. /// zero length bitfield. This corresponds to EMPTY_FIELD_BOUNDARY in
  3540. /// gcc.
  3541. ZeroLengthBitfieldBoundary = 32;
  3542. if (T.isOSBinFormatMachO())
  3543. DescriptionString =
  3544. BigEndian
  3545. ? "E-m:o-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
  3546. : "e-m:o-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32";
  3547. else
  3548. DescriptionString =
  3549. BigEndian
  3550. ? "E-m:e-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
  3551. : "e-m:e-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32";
  3552. // FIXME: Override "preferred align" for double and long long.
  3553. }
  3554. public:
  3555. ARMTargetInfo(const llvm::Triple &Triple, bool IsBigEndian)
  3556. : TargetInfo(Triple), CPU("arm1136j-s"), FPMath(FP_Default),
  3557. IsAAPCS(true), HW_FP(0) {
  3558. BigEndian = IsBigEndian;
  3559. switch (getTriple().getOS()) {
  3560. case llvm::Triple::NetBSD:
  3561. PtrDiffType = SignedLong;
  3562. break;
  3563. default:
  3564. PtrDiffType = SignedInt;
  3565. break;
  3566. }
  3567. // {} in inline assembly are neon specifiers, not assembly variant
  3568. // specifiers.
  3569. NoAsmVariants = true;
  3570. // FIXME: Should we just treat this as a feature?
  3571. IsThumb = getTriple().getArchName().startswith("thumb");
  3572. // FIXME: This duplicates code from the driver that sets the -target-abi
  3573. // option - this code is used if -target-abi isn't passed and should
  3574. // be unified in some way.
  3575. if (Triple.isOSBinFormatMachO()) {
  3576. // The backend is hardwired to assume AAPCS for M-class processors, ensure
  3577. // the frontend matches that.
  3578. if (Triple.getEnvironment() == llvm::Triple::EABI ||
  3579. Triple.getOS() == llvm::Triple::UnknownOS ||
  3580. StringRef(CPU).startswith("cortex-m")) {
  3581. setABI("aapcs");
  3582. } else {
  3583. setABI("apcs-gnu");
  3584. }
  3585. } else if (Triple.isOSWindows()) {
  3586. // FIXME: this is invalid for WindowsCE
  3587. setABI("aapcs");
  3588. } else {
  3589. // Select the default based on the platform.
  3590. switch (Triple.getEnvironment()) {
  3591. case llvm::Triple::Android:
  3592. case llvm::Triple::GNUEABI:
  3593. case llvm::Triple::GNUEABIHF:
  3594. setABI("aapcs-linux");
  3595. break;
  3596. case llvm::Triple::EABIHF:
  3597. case llvm::Triple::EABI:
  3598. setABI("aapcs");
  3599. break;
  3600. case llvm::Triple::GNU:
  3601. setABI("apcs-gnu");
  3602. break;
  3603. default:
  3604. if (Triple.getOS() == llvm::Triple::NetBSD)
  3605. setABI("apcs-gnu");
  3606. else
  3607. setABI("aapcs");
  3608. break;
  3609. }
  3610. }
  3611. // ARM targets default to using the ARM C++ ABI.
  3612. TheCXXABI.set(TargetCXXABI::GenericARM);
  3613. // ARM has atomics up to 8 bytes
  3614. MaxAtomicPromoteWidth = 64;
  3615. if (shouldUseInlineAtomic(getTriple()))
  3616. MaxAtomicInlineWidth = 64;
  3617. // Do force alignment of members that follow zero length bitfields. If
  3618. // the alignment of the zero-length bitfield is greater than the member
  3619. // that follows it, `bar', `bar' will be aligned as the type of the
  3620. // zero length bitfield.
  3621. UseZeroLengthBitfieldAlignment = true;
  3622. }
  3623. StringRef getABI() const override { return ABI; }
  3624. bool setABI(const std::string &Name) override {
  3625. ABI = Name;
  3626. // The defaults (above) are for AAPCS, check if we need to change them.
  3627. //
  3628. // FIXME: We need support for -meabi... we could just mangle it into the
  3629. // name.
  3630. if (Name == "apcs-gnu") {
  3631. setABIAPCS();
  3632. return true;
  3633. }
  3634. if (Name == "aapcs" || Name == "aapcs-vfp" || Name == "aapcs-linux") {
  3635. setABIAAPCS();
  3636. return true;
  3637. }
  3638. return false;
  3639. }
  3640. void getDefaultFeatures(llvm::StringMap<bool> &Features) const override {
  3641. StringRef ArchName = getTriple().getArchName();
  3642. if (CPU == "arm1136jf-s" || CPU == "arm1176jzf-s" || CPU == "mpcore")
  3643. Features["vfp2"] = true;
  3644. else if (CPU == "cortex-a8" || CPU == "cortex-a9") {
  3645. Features["vfp3"] = true;
  3646. Features["neon"] = true;
  3647. }
  3648. else if (CPU == "cortex-a5") {
  3649. Features["vfp4"] = true;
  3650. Features["neon"] = true;
  3651. } else if (CPU == "swift" || CPU == "cortex-a7" ||
  3652. CPU == "cortex-a12" || CPU == "cortex-a15" ||
  3653. CPU == "cortex-a17" || CPU == "krait") {
  3654. Features["vfp4"] = true;
  3655. Features["neon"] = true;
  3656. Features["hwdiv"] = true;
  3657. Features["hwdiv-arm"] = true;
  3658. } else if (CPU == "cyclone") {
  3659. Features["v8fp"] = true;
  3660. Features["neon"] = true;
  3661. Features["hwdiv"] = true;
  3662. Features["hwdiv-arm"] = true;
  3663. } else if (CPU == "cortex-a53" || CPU == "cortex-a57" || CPU == "cortex-a72") {
  3664. Features["fp-armv8"] = true;
  3665. Features["neon"] = true;
  3666. Features["hwdiv"] = true;
  3667. Features["hwdiv-arm"] = true;
  3668. Features["crc"] = true;
  3669. Features["crypto"] = true;
  3670. } else if (CPU == "cortex-r5" || CPU == "cortex-r7" ||
  3671. // Enable the hwdiv extension for all v8a AArch32 cores by
  3672. // default.
  3673. ArchName == "armv8a" || ArchName == "armv8" ||
  3674. ArchName == "armebv8a" || ArchName == "armebv8" ||
  3675. ArchName == "thumbv8a" || ArchName == "thumbv8" ||
  3676. ArchName == "thumbebv8a" || ArchName == "thumbebv8") {
  3677. Features["hwdiv"] = true;
  3678. Features["hwdiv-arm"] = true;
  3679. } else if (CPU == "cortex-m3" || CPU == "cortex-m4" || CPU == "cortex-m7" ||
  3680. CPU == "sc300") {
  3681. Features["hwdiv"] = true;
  3682. }
  3683. }
  3684. bool handleTargetFeatures(std::vector<std::string> &Features,
  3685. DiagnosticsEngine &Diags) override {
  3686. FPU = 0;
  3687. CRC = 0;
  3688. Crypto = 0;
  3689. SoftFloat = SoftFloatABI = false;
  3690. HWDiv = 0;
  3691. for (const auto &Feature : Features) {
  3692. if (Feature == "+soft-float") {
  3693. SoftFloat = true;
  3694. } else if (Feature == "+soft-float-abi") {
  3695. SoftFloatABI = true;
  3696. } else if (Feature == "+vfp2") {
  3697. FPU |= VFP2FPU;
  3698. HW_FP = HW_FP_SP | HW_FP_DP;
  3699. } else if (Feature == "+vfp3") {
  3700. FPU |= VFP3FPU;
  3701. HW_FP = HW_FP_SP | HW_FP_DP;
  3702. } else if (Feature == "+vfp4") {
  3703. FPU |= VFP4FPU;
  3704. HW_FP = HW_FP_SP | HW_FP_DP | HW_FP_HP;
  3705. } else if (Feature == "+fp-armv8") {
  3706. FPU |= FPARMV8;
  3707. HW_FP = HW_FP_SP | HW_FP_DP | HW_FP_HP;
  3708. } else if (Feature == "+neon") {
  3709. FPU |= NeonFPU;
  3710. HW_FP = HW_FP_SP | HW_FP_DP;
  3711. } else if (Feature == "+hwdiv") {
  3712. HWDiv |= HWDivThumb;
  3713. } else if (Feature == "+hwdiv-arm") {
  3714. HWDiv |= HWDivARM;
  3715. } else if (Feature == "+crc") {
  3716. CRC = 1;
  3717. } else if (Feature == "+crypto") {
  3718. Crypto = 1;
  3719. } else if (Feature == "+fp-only-sp") {
  3720. HW_FP &= ~HW_FP_DP;
  3721. }
  3722. }
  3723. if (!(FPU & NeonFPU) && FPMath == FP_Neon) {
  3724. Diags.Report(diag::err_target_unsupported_fpmath) << "neon";
  3725. return false;
  3726. }
  3727. if (FPMath == FP_Neon)
  3728. Features.push_back("+neonfp");
  3729. else if (FPMath == FP_VFP)
  3730. Features.push_back("-neonfp");
  3731. // Remove front-end specific options which the backend handles differently.
  3732. const StringRef FrontEndFeatures[] = { "+soft-float", "+soft-float-abi" };
  3733. for (const auto &FEFeature : FrontEndFeatures) {
  3734. auto Feature = std::find(Features.begin(), Features.end(), FEFeature);
  3735. if (Feature != Features.end())
  3736. Features.erase(Feature);
  3737. }
  3738. return true;
  3739. }
  3740. bool hasFeature(StringRef Feature) const override {
  3741. return llvm::StringSwitch<bool>(Feature)
  3742. .Case("arm", true)
  3743. .Case("softfloat", SoftFloat)
  3744. .Case("thumb", IsThumb)
  3745. .Case("neon", (FPU & NeonFPU) && !SoftFloat)
  3746. .Case("hwdiv", HWDiv & HWDivThumb)
  3747. .Case("hwdiv-arm", HWDiv & HWDivARM)
  3748. .Default(false);
  3749. }
  3750. // FIXME: Should we actually have some table instead of these switches?
  3751. static const char *getCPUDefineSuffix(StringRef Name) {
  3752. return llvm::StringSwitch<const char *>(Name)
  3753. .Cases("arm8", "arm810", "4")
  3754. .Cases("strongarm", "strongarm110", "strongarm1100", "strongarm1110",
  3755. "4")
  3756. .Cases("arm7tdmi", "arm7tdmi-s", "arm710t", "arm720t", "arm9", "4T")
  3757. .Cases("arm9tdmi", "arm920", "arm920t", "arm922t", "arm940t", "4T")
  3758. .Case("ep9312", "4T")
  3759. .Cases("arm10tdmi", "arm1020t", "5T")
  3760. .Cases("arm9e", "arm946e-s", "arm966e-s", "arm968e-s", "5TE")
  3761. .Case("arm926ej-s", "5TEJ")
  3762. .Cases("arm10e", "arm1020e", "arm1022e", "5TE")
  3763. .Cases("xscale", "iwmmxt", "5TE")
  3764. .Case("arm1136j-s", "6J")
  3765. .Cases("arm1176jz-s", "arm1176jzf-s", "6ZK")
  3766. .Cases("arm1136jf-s", "mpcorenovfp", "mpcore", "6K")
  3767. .Cases("arm1156t2-s", "arm1156t2f-s", "6T2")
  3768. .Cases("cortex-a5", "cortex-a7", "cortex-a8", "7A")
  3769. .Cases("cortex-a9", "cortex-a12", "cortex-a15", "cortex-a17", "krait",
  3770. "7A")
  3771. .Cases("cortex-r4", "cortex-r5", "cortex-r7", "7R")
  3772. .Case("swift", "7S")
  3773. .Case("cyclone", "8A")
  3774. .Cases("sc300", "cortex-m3", "7M")
  3775. .Cases("cortex-m4", "cortex-m7", "7EM")
  3776. .Cases("sc000", "cortex-m0", "cortex-m0plus", "cortex-m1", "6M")
  3777. .Cases("cortex-a53", "cortex-a57", "cortex-a72", "8A")
  3778. .Default(nullptr);
  3779. }
  3780. static const char *getCPUProfile(StringRef Name) {
  3781. return llvm::StringSwitch<const char *>(Name)
  3782. .Cases("cortex-a5", "cortex-a7", "cortex-a8", "A")
  3783. .Cases("cortex-a9", "cortex-a12", "cortex-a15", "cortex-a17", "krait",
  3784. "A")
  3785. .Cases("cortex-a53", "cortex-a57", "cortex-a72", "A")
  3786. .Cases("cortex-m3", "cortex-m4", "cortex-m0", "cortex-m0plus", "M")
  3787. .Cases("cortex-m1", "cortex-m7", "sc000", "sc300", "M")
  3788. .Cases("cortex-r4", "cortex-r5", "cortex-r7", "R")
  3789. .Default("");
  3790. }
  3791. bool setCPU(const std::string &Name) override {
  3792. if (!getCPUDefineSuffix(Name))
  3793. return false;
  3794. // Cortex M does not support 8 byte atomics, while general Thumb2 does.
  3795. StringRef Profile = getCPUProfile(Name);
  3796. if (Profile == "M" && MaxAtomicInlineWidth) {
  3797. MaxAtomicPromoteWidth = 32;
  3798. MaxAtomicInlineWidth = 32;
  3799. }
  3800. CPU = Name;
  3801. return true;
  3802. }
  3803. bool setFPMath(StringRef Name) override;
  3804. bool supportsThumb(StringRef ArchName, StringRef CPUArch,
  3805. unsigned CPUArchVer) const {
  3806. return CPUArchVer >= 7 || (CPUArch.find('T') != StringRef::npos) ||
  3807. (CPUArch.find('M') != StringRef::npos);
  3808. }
  3809. bool supportsThumb2(StringRef ArchName, StringRef CPUArch,
  3810. unsigned CPUArchVer) const {
  3811. // We check both CPUArchVer and ArchName because when only triple is
  3812. // specified, the default CPU is arm1136j-s.
  3813. return ArchName.endswith("v6t2") || ArchName.endswith("v7") ||
  3814. ArchName.endswith("v8") || CPUArch == "6T2" || CPUArchVer >= 7;
  3815. }
  3816. void getTargetDefines(const LangOptions &Opts,
  3817. MacroBuilder &Builder) const override {
  3818. // Target identification.
  3819. Builder.defineMacro("__arm");
  3820. Builder.defineMacro("__arm__");
  3821. // Target properties.
  3822. Builder.defineMacro("__REGISTER_PREFIX__", "");
  3823. StringRef CPUArch = getCPUDefineSuffix(CPU);
  3824. unsigned int CPUArchVer;
  3825. if (CPUArch.substr(0, 1).getAsInteger<unsigned int>(10, CPUArchVer))
  3826. llvm_unreachable("Invalid char for architecture version number");
  3827. Builder.defineMacro("__ARM_ARCH_" + CPUArch + "__");
  3828. // ACLE 6.4.1 ARM/Thumb instruction set architecture
  3829. StringRef CPUProfile = getCPUProfile(CPU);
  3830. StringRef ArchName = getTriple().getArchName();
  3831. // __ARM_ARCH is defined as an integer value indicating the current ARM ISA
  3832. Builder.defineMacro("__ARM_ARCH", CPUArch.substr(0, 1));
  3833. if (CPUArch[0] >= '8') {
  3834. Builder.defineMacro("__ARM_FEATURE_NUMERIC_MAXMIN");
  3835. Builder.defineMacro("__ARM_FEATURE_DIRECTED_ROUNDING");
  3836. }
  3837. // __ARM_ARCH_ISA_ARM is defined to 1 if the core supports the ARM ISA. It
  3838. // is not defined for the M-profile.
  3839. // NOTE that the deffault profile is assumed to be 'A'
  3840. if (CPUProfile.empty() || CPUProfile != "M")
  3841. Builder.defineMacro("__ARM_ARCH_ISA_ARM", "1");
  3842. // __ARM_ARCH_ISA_THUMB is defined to 1 if the core supporst the original
  3843. // Thumb ISA (including v6-M). It is set to 2 if the core supports the
  3844. // Thumb-2 ISA as found in the v6T2 architecture and all v7 architecture.
  3845. if (supportsThumb2(ArchName, CPUArch, CPUArchVer))
  3846. Builder.defineMacro("__ARM_ARCH_ISA_THUMB", "2");
  3847. else if (supportsThumb(ArchName, CPUArch, CPUArchVer))
  3848. Builder.defineMacro("__ARM_ARCH_ISA_THUMB", "1");
  3849. // __ARM_32BIT_STATE is defined to 1 if code is being generated for a 32-bit
  3850. // instruction set such as ARM or Thumb.
  3851. Builder.defineMacro("__ARM_32BIT_STATE", "1");
  3852. // ACLE 6.4.2 Architectural Profile (A, R, M or pre-Cortex)
  3853. // __ARM_ARCH_PROFILE is defined as 'A', 'R', 'M' or 'S', or unset.
  3854. if (!CPUProfile.empty())
  3855. Builder.defineMacro("__ARM_ARCH_PROFILE", "'" + CPUProfile + "'");
  3856. // ACLE 6.5.1 Hardware Floating Point
  3857. if (HW_FP)
  3858. Builder.defineMacro("__ARM_FP", "0x" + llvm::utohexstr(HW_FP));
  3859. // ACLE predefines.
  3860. Builder.defineMacro("__ARM_ACLE", "200");
  3861. // Subtarget options.
  3862. // FIXME: It's more complicated than this and we don't really support
  3863. // interworking.
  3864. // Windows on ARM does not "support" interworking
  3865. if (5 <= CPUArchVer && CPUArchVer <= 8 && !getTriple().isOSWindows())
  3866. Builder.defineMacro("__THUMB_INTERWORK__");
  3867. if (ABI == "aapcs" || ABI == "aapcs-linux" || ABI == "aapcs-vfp") {
  3868. // Embedded targets on Darwin follow AAPCS, but not EABI.
  3869. // Windows on ARM follows AAPCS VFP, but does not conform to EABI.
  3870. if (!getTriple().isOSDarwin() && !getTriple().isOSWindows())
  3871. Builder.defineMacro("__ARM_EABI__");
  3872. Builder.defineMacro("__ARM_PCS", "1");
  3873. if ((!SoftFloat && !SoftFloatABI) || ABI == "aapcs-vfp")
  3874. Builder.defineMacro("__ARM_PCS_VFP", "1");
  3875. }
  3876. if (SoftFloat)
  3877. Builder.defineMacro("__SOFTFP__");
  3878. if (CPU == "xscale")
  3879. Builder.defineMacro("__XSCALE__");
  3880. if (IsThumb) {
  3881. Builder.defineMacro("__THUMBEL__");
  3882. Builder.defineMacro("__thumb__");
  3883. if (supportsThumb2(ArchName, CPUArch, CPUArchVer))
  3884. Builder.defineMacro("__thumb2__");
  3885. }
  3886. if (((HWDiv & HWDivThumb) && IsThumb) || ((HWDiv & HWDivARM) && !IsThumb))
  3887. Builder.defineMacro("__ARM_ARCH_EXT_IDIV__", "1");
  3888. // Note, this is always on in gcc, even though it doesn't make sense.
  3889. Builder.defineMacro("__APCS_32__");
  3890. if (FPUModeIsVFP((FPUMode) FPU)) {
  3891. Builder.defineMacro("__VFP_FP__");
  3892. if (FPU & VFP2FPU)
  3893. Builder.defineMacro("__ARM_VFPV2__");
  3894. if (FPU & VFP3FPU)
  3895. Builder.defineMacro("__ARM_VFPV3__");
  3896. if (FPU & VFP4FPU)
  3897. Builder.defineMacro("__ARM_VFPV4__");
  3898. }
  3899. // This only gets set when Neon instructions are actually available, unlike
  3900. // the VFP define, hence the soft float and arch check. This is subtly
  3901. // different from gcc, we follow the intent which was that it should be set
  3902. // when Neon instructions are actually available.
  3903. if ((FPU & NeonFPU) && !SoftFloat && CPUArchVer >= 7) {
  3904. Builder.defineMacro("__ARM_NEON");
  3905. Builder.defineMacro("__ARM_NEON__");
  3906. }
  3907. Builder.defineMacro("__ARM_SIZEOF_WCHAR_T",
  3908. Opts.ShortWChar ? "2" : "4");
  3909. Builder.defineMacro("__ARM_SIZEOF_MINIMAL_ENUM",
  3910. Opts.ShortEnums ? "1" : "4");
  3911. if (CRC)
  3912. Builder.defineMacro("__ARM_FEATURE_CRC32");
  3913. if (Crypto)
  3914. Builder.defineMacro("__ARM_FEATURE_CRYPTO");
  3915. if (CPUArchVer >= 6 && CPUArch != "6M") {
  3916. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_1");
  3917. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_2");
  3918. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4");
  3919. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8");
  3920. }
  3921. bool is5EOrAbove = (CPUArchVer >= 6 ||
  3922. (CPUArchVer == 5 &&
  3923. CPUArch.find('E') != StringRef::npos));
  3924. bool is32Bit = (!IsThumb || supportsThumb2(ArchName, CPUArch, CPUArchVer));
  3925. if (is5EOrAbove && is32Bit && (CPUProfile != "M" || CPUArch == "7EM"))
  3926. Builder.defineMacro("__ARM_FEATURE_DSP");
  3927. }
  3928. void getTargetBuiltins(const Builtin::Info *&Records,
  3929. unsigned &NumRecords) const override {
  3930. Records = BuiltinInfo;
  3931. NumRecords = clang::ARM::LastTSBuiltin-Builtin::FirstTSBuiltin;
  3932. }
  3933. bool isCLZForZeroUndef() const override { return false; }
  3934. BuiltinVaListKind getBuiltinVaListKind() const override {
  3935. return IsAAPCS ? AAPCSABIBuiltinVaList : TargetInfo::VoidPtrBuiltinVaList;
  3936. }
  3937. void getGCCRegNames(const char * const *&Names,
  3938. unsigned &NumNames) const override;
  3939. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  3940. unsigned &NumAliases) const override;
  3941. bool validateAsmConstraint(const char *&Name,
  3942. TargetInfo::ConstraintInfo &Info) const override {
  3943. switch (*Name) {
  3944. default: break;
  3945. case 'l': // r0-r7
  3946. case 'h': // r8-r15
  3947. case 'w': // VFP Floating point register single precision
  3948. case 'P': // VFP Floating point register double precision
  3949. Info.setAllowsRegister();
  3950. return true;
  3951. case 'I':
  3952. case 'J':
  3953. case 'K':
  3954. case 'L':
  3955. case 'M':
  3956. // FIXME
  3957. return true;
  3958. case 'Q': // A memory address that is a single base register.
  3959. Info.setAllowsMemory();
  3960. return true;
  3961. case 'U': // a memory reference...
  3962. switch (Name[1]) {
  3963. case 'q': // ...ARMV4 ldrsb
  3964. case 'v': // ...VFP load/store (reg+constant offset)
  3965. case 'y': // ...iWMMXt load/store
  3966. case 't': // address valid for load/store opaque types wider
  3967. // than 128-bits
  3968. case 'n': // valid address for Neon doubleword vector load/store
  3969. case 'm': // valid address for Neon element and structure load/store
  3970. case 's': // valid address for non-offset loads/stores of quad-word
  3971. // values in four ARM registers
  3972. Info.setAllowsMemory();
  3973. Name++;
  3974. return true;
  3975. }
  3976. }
  3977. return false;
  3978. }
  3979. std::string convertConstraint(const char *&Constraint) const override {
  3980. std::string R;
  3981. switch (*Constraint) {
  3982. case 'U': // Two-character constraint; add "^" hint for later parsing.
  3983. R = std::string("^") + std::string(Constraint, 2);
  3984. Constraint++;
  3985. break;
  3986. case 'p': // 'p' should be translated to 'r' by default.
  3987. R = std::string("r");
  3988. break;
  3989. default:
  3990. return std::string(1, *Constraint);
  3991. }
  3992. return R;
  3993. }
  3994. bool
  3995. validateConstraintModifier(StringRef Constraint, char Modifier, unsigned Size,
  3996. std::string &SuggestedModifier) const override {
  3997. bool isOutput = (Constraint[0] == '=');
  3998. bool isInOut = (Constraint[0] == '+');
  3999. // Strip off constraint modifiers.
  4000. while (Constraint[0] == '=' ||
  4001. Constraint[0] == '+' ||
  4002. Constraint[0] == '&')
  4003. Constraint = Constraint.substr(1);
  4004. switch (Constraint[0]) {
  4005. default: break;
  4006. case 'r': {
  4007. switch (Modifier) {
  4008. default:
  4009. return (isInOut || isOutput || Size <= 64);
  4010. case 'q':
  4011. // A register of size 32 cannot fit a vector type.
  4012. return false;
  4013. }
  4014. }
  4015. }
  4016. return true;
  4017. }
  4018. const char *getClobbers() const override {
  4019. // FIXME: Is this really right?
  4020. return "";
  4021. }
  4022. CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
  4023. return (CC == CC_AAPCS || CC == CC_AAPCS_VFP) ? CCCR_OK : CCCR_Warning;
  4024. }
  4025. int getEHDataRegisterNumber(unsigned RegNo) const override {
  4026. if (RegNo == 0) return 0;
  4027. if (RegNo == 1) return 1;
  4028. return -1;
  4029. }
  4030. };
  4031. bool ARMTargetInfo::setFPMath(StringRef Name) {
  4032. if (Name == "neon") {
  4033. FPMath = FP_Neon;
  4034. return true;
  4035. } else if (Name == "vfp" || Name == "vfp2" || Name == "vfp3" ||
  4036. Name == "vfp4") {
  4037. FPMath = FP_VFP;
  4038. return true;
  4039. }
  4040. return false;
  4041. }
  4042. const char * const ARMTargetInfo::GCCRegNames[] = {
  4043. // Integer registers
  4044. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  4045. "r8", "r9", "r10", "r11", "r12", "sp", "lr", "pc",
  4046. // Float registers
  4047. "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7",
  4048. "s8", "s9", "s10", "s11", "s12", "s13", "s14", "s15",
  4049. "s16", "s17", "s18", "s19", "s20", "s21", "s22", "s23",
  4050. "s24", "s25", "s26", "s27", "s28", "s29", "s30", "s31",
  4051. // Double registers
  4052. "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7",
  4053. "d8", "d9", "d10", "d11", "d12", "d13", "d14", "d15",
  4054. "d16", "d17", "d18", "d19", "d20", "d21", "d22", "d23",
  4055. "d24", "d25", "d26", "d27", "d28", "d29", "d30", "d31",
  4056. // Quad registers
  4057. "q0", "q1", "q2", "q3", "q4", "q5", "q6", "q7",
  4058. "q8", "q9", "q10", "q11", "q12", "q13", "q14", "q15"
  4059. };
  4060. void ARMTargetInfo::getGCCRegNames(const char * const *&Names,
  4061. unsigned &NumNames) const {
  4062. Names = GCCRegNames;
  4063. NumNames = llvm::array_lengthof(GCCRegNames);
  4064. }
  4065. const TargetInfo::GCCRegAlias ARMTargetInfo::GCCRegAliases[] = {
  4066. { { "a1" }, "r0" },
  4067. { { "a2" }, "r1" },
  4068. { { "a3" }, "r2" },
  4069. { { "a4" }, "r3" },
  4070. { { "v1" }, "r4" },
  4071. { { "v2" }, "r5" },
  4072. { { "v3" }, "r6" },
  4073. { { "v4" }, "r7" },
  4074. { { "v5" }, "r8" },
  4075. { { "v6", "rfp" }, "r9" },
  4076. { { "sl" }, "r10" },
  4077. { { "fp" }, "r11" },
  4078. { { "ip" }, "r12" },
  4079. { { "r13" }, "sp" },
  4080. { { "r14" }, "lr" },
  4081. { { "r15" }, "pc" },
  4082. // The S, D and Q registers overlap, but aren't really aliases; we
  4083. // don't want to substitute one of these for a different-sized one.
  4084. };
  4085. void ARMTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
  4086. unsigned &NumAliases) const {
  4087. Aliases = GCCRegAliases;
  4088. NumAliases = llvm::array_lengthof(GCCRegAliases);
  4089. }
  4090. const Builtin::Info ARMTargetInfo::BuiltinInfo[] = {
  4091. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  4092. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  4093. ALL_LANGUAGES },
  4094. #include "clang/Basic/BuiltinsNEON.def"
  4095. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  4096. #define LANGBUILTIN(ID, TYPE, ATTRS, LANG) { #ID, TYPE, ATTRS, 0, LANG },
  4097. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  4098. ALL_LANGUAGES },
  4099. #include "clang/Basic/BuiltinsARM.def"
  4100. };
  4101. class ARMleTargetInfo : public ARMTargetInfo {
  4102. public:
  4103. ARMleTargetInfo(const llvm::Triple &Triple)
  4104. : ARMTargetInfo(Triple, false) { }
  4105. virtual void getTargetDefines(const LangOptions &Opts,
  4106. MacroBuilder &Builder) const {
  4107. Builder.defineMacro("__ARMEL__");
  4108. ARMTargetInfo::getTargetDefines(Opts, Builder);
  4109. }
  4110. };
  4111. class ARMbeTargetInfo : public ARMTargetInfo {
  4112. public:
  4113. ARMbeTargetInfo(const llvm::Triple &Triple)
  4114. : ARMTargetInfo(Triple, true) { }
  4115. virtual void getTargetDefines(const LangOptions &Opts,
  4116. MacroBuilder &Builder) const {
  4117. Builder.defineMacro("__ARMEB__");
  4118. Builder.defineMacro("__ARM_BIG_ENDIAN");
  4119. ARMTargetInfo::getTargetDefines(Opts, Builder);
  4120. }
  4121. };
  4122. } // end anonymous namespace.
  4123. namespace {
  4124. class WindowsARMTargetInfo : public WindowsTargetInfo<ARMleTargetInfo> {
  4125. const llvm::Triple Triple;
  4126. public:
  4127. WindowsARMTargetInfo(const llvm::Triple &Triple)
  4128. : WindowsTargetInfo<ARMleTargetInfo>(Triple), Triple(Triple) {
  4129. TLSSupported = false;
  4130. WCharType = UnsignedShort;
  4131. SizeType = UnsignedInt;
  4132. UserLabelPrefix = "";
  4133. }
  4134. void getVisualStudioDefines(const LangOptions &Opts,
  4135. MacroBuilder &Builder) const {
  4136. WindowsTargetInfo<ARMleTargetInfo>::getVisualStudioDefines(Opts, Builder);
  4137. // FIXME: this is invalid for WindowsCE
  4138. Builder.defineMacro("_M_ARM_NT", "1");
  4139. Builder.defineMacro("_M_ARMT", "_M_ARM");
  4140. Builder.defineMacro("_M_THUMB", "_M_ARM");
  4141. assert((Triple.getArch() == llvm::Triple::arm ||
  4142. Triple.getArch() == llvm::Triple::thumb) &&
  4143. "invalid architecture for Windows ARM target info");
  4144. unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
  4145. Builder.defineMacro("_M_ARM", Triple.getArchName().substr(Offset));
  4146. // TODO map the complete set of values
  4147. // 31: VFPv3 40: VFPv4
  4148. Builder.defineMacro("_M_ARM_FP", "31");
  4149. }
  4150. BuiltinVaListKind getBuiltinVaListKind() const override {
  4151. return TargetInfo::CharPtrBuiltinVaList;
  4152. }
  4153. };
  4154. // Windows ARM + Itanium C++ ABI Target
  4155. class ItaniumWindowsARMleTargetInfo : public WindowsARMTargetInfo {
  4156. public:
  4157. ItaniumWindowsARMleTargetInfo(const llvm::Triple &Triple)
  4158. : WindowsARMTargetInfo(Triple) {
  4159. TheCXXABI.set(TargetCXXABI::GenericARM);
  4160. }
  4161. void getTargetDefines(const LangOptions &Opts,
  4162. MacroBuilder &Builder) const override {
  4163. WindowsARMTargetInfo::getTargetDefines(Opts, Builder);
  4164. if (Opts.MSVCCompat)
  4165. WindowsARMTargetInfo::getVisualStudioDefines(Opts, Builder);
  4166. }
  4167. };
  4168. // Windows ARM, MS (C++) ABI
  4169. class MicrosoftARMleTargetInfo : public WindowsARMTargetInfo {
  4170. public:
  4171. MicrosoftARMleTargetInfo(const llvm::Triple &Triple)
  4172. : WindowsARMTargetInfo(Triple) {
  4173. TheCXXABI.set(TargetCXXABI::Microsoft);
  4174. }
  4175. void getTargetDefines(const LangOptions &Opts,
  4176. MacroBuilder &Builder) const override {
  4177. WindowsARMTargetInfo::getTargetDefines(Opts, Builder);
  4178. WindowsARMTargetInfo::getVisualStudioDefines(Opts, Builder);
  4179. }
  4180. };
  4181. }
  4182. namespace {
  4183. class DarwinARMTargetInfo :
  4184. public DarwinTargetInfo<ARMleTargetInfo> {
  4185. protected:
  4186. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  4187. MacroBuilder &Builder) const override {
  4188. getDarwinDefines(Builder, Opts, Triple, PlatformName, PlatformMinVersion);
  4189. }
  4190. public:
  4191. DarwinARMTargetInfo(const llvm::Triple &Triple)
  4192. : DarwinTargetInfo<ARMleTargetInfo>(Triple) {
  4193. HasAlignMac68kSupport = true;
  4194. // iOS always has 64-bit atomic instructions.
  4195. // FIXME: This should be based off of the target features in
  4196. // ARMleTargetInfo.
  4197. MaxAtomicInlineWidth = 64;
  4198. // Darwin on iOS uses a variant of the ARM C++ ABI.
  4199. TheCXXABI.set(TargetCXXABI::iOS);
  4200. }
  4201. };
  4202. } // end anonymous namespace.
  4203. namespace {
  4204. class AArch64TargetInfo : public TargetInfo {
  4205. virtual void setDescriptionString() = 0;
  4206. static const TargetInfo::GCCRegAlias GCCRegAliases[];
  4207. static const char *const GCCRegNames[];
  4208. enum FPUModeEnum {
  4209. FPUMode,
  4210. NeonMode
  4211. };
  4212. unsigned FPU;
  4213. unsigned CRC;
  4214. unsigned Crypto;
  4215. static const Builtin::Info BuiltinInfo[];
  4216. std::string ABI;
  4217. public:
  4218. AArch64TargetInfo(const llvm::Triple &Triple)
  4219. : TargetInfo(Triple), ABI("aapcs") {
  4220. if (getTriple().getOS() == llvm::Triple::NetBSD) {
  4221. WCharType = SignedInt;
  4222. // NetBSD apparently prefers consistency across ARM targets to consistency
  4223. // across 64-bit targets.
  4224. Int64Type = SignedLongLong;
  4225. IntMaxType = SignedLongLong;
  4226. } else {
  4227. WCharType = UnsignedInt;
  4228. Int64Type = SignedLong;
  4229. IntMaxType = SignedLong;
  4230. }
  4231. LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
  4232. MaxVectorAlign = 128;
  4233. RegParmMax = 8;
  4234. MaxAtomicInlineWidth = 128;
  4235. MaxAtomicPromoteWidth = 128;
  4236. LongDoubleWidth = LongDoubleAlign = SuitableAlign = 128;
  4237. LongDoubleFormat = &llvm::APFloat::IEEEquad;
  4238. // {} in inline assembly are neon specifiers, not assembly variant
  4239. // specifiers.
  4240. NoAsmVariants = true;
  4241. // AAPCS gives rules for bitfields. 7.1.7 says: "The container type
  4242. // contributes to the alignment of the containing aggregate in the same way
  4243. // a plain (non bit-field) member of that type would, without exception for
  4244. // zero-sized or anonymous bit-fields."
  4245. UseBitFieldTypeAlignment = true;
  4246. UseZeroLengthBitfieldAlignment = true;
  4247. // AArch64 targets default to using the ARM C++ ABI.
  4248. TheCXXABI.set(TargetCXXABI::GenericAArch64);
  4249. }
  4250. StringRef getABI() const override { return ABI; }
  4251. bool setABI(const std::string &Name) override {
  4252. if (Name != "aapcs" && Name != "darwinpcs")
  4253. return false;
  4254. ABI = Name;
  4255. return true;
  4256. }
  4257. bool setCPU(const std::string &Name) override {
  4258. bool CPUKnown = llvm::StringSwitch<bool>(Name)
  4259. .Case("generic", true)
  4260. .Cases("cortex-a53", "cortex-a57", "cortex-a72", true)
  4261. .Case("cyclone", true)
  4262. .Default(false);
  4263. return CPUKnown;
  4264. }
  4265. virtual void getTargetDefines(const LangOptions &Opts,
  4266. MacroBuilder &Builder) const override {
  4267. // Target identification.
  4268. Builder.defineMacro("__aarch64__");
  4269. // Target properties.
  4270. Builder.defineMacro("_LP64");
  4271. Builder.defineMacro("__LP64__");
  4272. // ACLE predefines. Many can only have one possible value on v8 AArch64.
  4273. Builder.defineMacro("__ARM_ACLE", "200");
  4274. Builder.defineMacro("__ARM_ARCH", "8");
  4275. Builder.defineMacro("__ARM_ARCH_PROFILE", "'A'");
  4276. Builder.defineMacro("__ARM_64BIT_STATE");
  4277. Builder.defineMacro("__ARM_PCS_AAPCS64");
  4278. Builder.defineMacro("__ARM_ARCH_ISA_A64");
  4279. Builder.defineMacro("__ARM_FEATURE_UNALIGNED");
  4280. Builder.defineMacro("__ARM_FEATURE_CLZ");
  4281. Builder.defineMacro("__ARM_FEATURE_FMA");
  4282. Builder.defineMacro("__ARM_FEATURE_DIV");
  4283. Builder.defineMacro("__ARM_FEATURE_IDIV"); // As specified in ACLE
  4284. Builder.defineMacro("__ARM_FEATURE_DIV"); // For backwards compatibility
  4285. Builder.defineMacro("__ARM_FEATURE_NUMERIC_MAXMIN");
  4286. Builder.defineMacro("__ARM_FEATURE_DIRECTED_ROUNDING");
  4287. Builder.defineMacro("__ARM_ALIGN_MAX_STACK_PWR", "4");
  4288. // 0xe implies support for half, single and double precision operations.
  4289. Builder.defineMacro("__ARM_FP", "0xe");
  4290. // PCS specifies this for SysV variants, which is all we support. Other ABIs
  4291. // may choose __ARM_FP16_FORMAT_ALTERNATIVE.
  4292. Builder.defineMacro("__ARM_FP16_FORMAT_IEEE");
  4293. if (Opts.FastMath || Opts.FiniteMathOnly)
  4294. Builder.defineMacro("__ARM_FP_FAST");
  4295. if (Opts.C99 && !Opts.Freestanding)
  4296. Builder.defineMacro("__ARM_FP_FENV_ROUNDING");
  4297. Builder.defineMacro("__ARM_SIZEOF_WCHAR_T", Opts.ShortWChar ? "2" : "4");
  4298. Builder.defineMacro("__ARM_SIZEOF_MINIMAL_ENUM",
  4299. Opts.ShortEnums ? "1" : "4");
  4300. if (FPU == NeonMode) {
  4301. Builder.defineMacro("__ARM_NEON");
  4302. // 64-bit NEON supports half, single and double precision operations.
  4303. Builder.defineMacro("__ARM_NEON_FP", "0xe");
  4304. }
  4305. if (CRC)
  4306. Builder.defineMacro("__ARM_FEATURE_CRC32");
  4307. if (Crypto)
  4308. Builder.defineMacro("__ARM_FEATURE_CRYPTO");
  4309. }
  4310. virtual void getTargetBuiltins(const Builtin::Info *&Records,
  4311. unsigned &NumRecords) const override {
  4312. Records = BuiltinInfo;
  4313. NumRecords = clang::AArch64::LastTSBuiltin - Builtin::FirstTSBuiltin;
  4314. }
  4315. bool hasFeature(StringRef Feature) const override {
  4316. return Feature == "aarch64" ||
  4317. Feature == "arm64" ||
  4318. (Feature == "neon" && FPU == NeonMode);
  4319. }
  4320. bool handleTargetFeatures(std::vector<std::string> &Features,
  4321. DiagnosticsEngine &Diags) override {
  4322. FPU = FPUMode;
  4323. CRC = 0;
  4324. Crypto = 0;
  4325. for (unsigned i = 0, e = Features.size(); i != e; ++i) {
  4326. if (Features[i] == "+neon")
  4327. FPU = NeonMode;
  4328. if (Features[i] == "+crc")
  4329. CRC = 1;
  4330. if (Features[i] == "+crypto")
  4331. Crypto = 1;
  4332. }
  4333. setDescriptionString();
  4334. return true;
  4335. }
  4336. bool isCLZForZeroUndef() const override { return false; }
  4337. BuiltinVaListKind getBuiltinVaListKind() const override {
  4338. return TargetInfo::AArch64ABIBuiltinVaList;
  4339. }
  4340. virtual void getGCCRegNames(const char *const *&Names,
  4341. unsigned &NumNames) const override;
  4342. virtual void getGCCRegAliases(const GCCRegAlias *&Aliases,
  4343. unsigned &NumAliases) const override;
  4344. virtual bool
  4345. validateAsmConstraint(const char *&Name,
  4346. TargetInfo::ConstraintInfo &Info) const override {
  4347. switch (*Name) {
  4348. default:
  4349. return false;
  4350. case 'w': // Floating point and SIMD registers (V0-V31)
  4351. Info.setAllowsRegister();
  4352. return true;
  4353. case 'I': // Constant that can be used with an ADD instruction
  4354. case 'J': // Constant that can be used with a SUB instruction
  4355. case 'K': // Constant that can be used with a 32-bit logical instruction
  4356. case 'L': // Constant that can be used with a 64-bit logical instruction
  4357. case 'M': // Constant that can be used as a 32-bit MOV immediate
  4358. case 'N': // Constant that can be used as a 64-bit MOV immediate
  4359. case 'Y': // Floating point constant zero
  4360. case 'Z': // Integer constant zero
  4361. return true;
  4362. case 'Q': // A memory reference with base register and no offset
  4363. Info.setAllowsMemory();
  4364. return true;
  4365. case 'S': // A symbolic address
  4366. Info.setAllowsRegister();
  4367. return true;
  4368. case 'U':
  4369. // Ump: A memory address suitable for ldp/stp in SI, DI, SF and DF modes.
  4370. // Utf: A memory address suitable for ldp/stp in TF mode.
  4371. // Usa: An absolute symbolic address.
  4372. // Ush: The high part (bits 32:12) of a pc-relative symbolic address.
  4373. llvm_unreachable("FIXME: Unimplemented support for U* constraints.");
  4374. case 'z': // Zero register, wzr or xzr
  4375. Info.setAllowsRegister();
  4376. return true;
  4377. case 'x': // Floating point and SIMD registers (V0-V15)
  4378. Info.setAllowsRegister();
  4379. return true;
  4380. }
  4381. return false;
  4382. }
  4383. bool
  4384. validateConstraintModifier(StringRef Constraint, char Modifier, unsigned Size,
  4385. std::string &SuggestedModifier) const override {
  4386. // Strip off constraint modifiers.
  4387. while (Constraint[0] == '=' || Constraint[0] == '+' || Constraint[0] == '&')
  4388. Constraint = Constraint.substr(1);
  4389. switch (Constraint[0]) {
  4390. default:
  4391. return true;
  4392. case 'z':
  4393. case 'r': {
  4394. switch (Modifier) {
  4395. case 'x':
  4396. case 'w':
  4397. // For now assume that the person knows what they're
  4398. // doing with the modifier.
  4399. return true;
  4400. default:
  4401. // By default an 'r' constraint will be in the 'x'
  4402. // registers.
  4403. if (Size == 64)
  4404. return true;
  4405. SuggestedModifier = "w";
  4406. return false;
  4407. }
  4408. }
  4409. }
  4410. }
  4411. const char *getClobbers() const override { return ""; }
  4412. int getEHDataRegisterNumber(unsigned RegNo) const override {
  4413. if (RegNo == 0)
  4414. return 0;
  4415. if (RegNo == 1)
  4416. return 1;
  4417. return -1;
  4418. }
  4419. };
  4420. const char *const AArch64TargetInfo::GCCRegNames[] = {
  4421. // 32-bit Integer registers
  4422. "w0", "w1", "w2", "w3", "w4", "w5", "w6", "w7", "w8", "w9", "w10",
  4423. "w11", "w12", "w13", "w14", "w15", "w16", "w17", "w18", "w19", "w20", "w21",
  4424. "w22", "w23", "w24", "w25", "w26", "w27", "w28", "w29", "w30", "wsp",
  4425. // 64-bit Integer registers
  4426. "x0", "x1", "x2", "x3", "x4", "x5", "x6", "x7", "x8", "x9", "x10",
  4427. "x11", "x12", "x13", "x14", "x15", "x16", "x17", "x18", "x19", "x20", "x21",
  4428. "x22", "x23", "x24", "x25", "x26", "x27", "x28", "fp", "lr", "sp",
  4429. // 32-bit floating point regsisters
  4430. "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7", "s8", "s9", "s10",
  4431. "s11", "s12", "s13", "s14", "s15", "s16", "s17", "s18", "s19", "s20", "s21",
  4432. "s22", "s23", "s24", "s25", "s26", "s27", "s28", "s29", "s30", "s31",
  4433. // 64-bit floating point regsisters
  4434. "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7", "d8", "d9", "d10",
  4435. "d11", "d12", "d13", "d14", "d15", "d16", "d17", "d18", "d19", "d20", "d21",
  4436. "d22", "d23", "d24", "d25", "d26", "d27", "d28", "d29", "d30", "d31",
  4437. // Vector registers
  4438. "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v7", "v8", "v9", "v10",
  4439. "v11", "v12", "v13", "v14", "v15", "v16", "v17", "v18", "v19", "v20", "v21",
  4440. "v22", "v23", "v24", "v25", "v26", "v27", "v28", "v29", "v30", "v31"
  4441. };
  4442. void AArch64TargetInfo::getGCCRegNames(const char *const *&Names,
  4443. unsigned &NumNames) const {
  4444. Names = GCCRegNames;
  4445. NumNames = llvm::array_lengthof(GCCRegNames);
  4446. }
  4447. const TargetInfo::GCCRegAlias AArch64TargetInfo::GCCRegAliases[] = {
  4448. { { "w31" }, "wsp" },
  4449. { { "x29" }, "fp" },
  4450. { { "x30" }, "lr" },
  4451. { { "x31" }, "sp" },
  4452. // The S/D/Q and W/X registers overlap, but aren't really aliases; we
  4453. // don't want to substitute one of these for a different-sized one.
  4454. };
  4455. void AArch64TargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
  4456. unsigned &NumAliases) const {
  4457. Aliases = GCCRegAliases;
  4458. NumAliases = llvm::array_lengthof(GCCRegAliases);
  4459. }
  4460. const Builtin::Info AArch64TargetInfo::BuiltinInfo[] = {
  4461. #define BUILTIN(ID, TYPE, ATTRS) \
  4462. { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  4463. #include "clang/Basic/BuiltinsNEON.def"
  4464. #define BUILTIN(ID, TYPE, ATTRS) \
  4465. { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  4466. #include "clang/Basic/BuiltinsAArch64.def"
  4467. };
  4468. class AArch64leTargetInfo : public AArch64TargetInfo {
  4469. void setDescriptionString() override {
  4470. if (getTriple().isOSBinFormatMachO())
  4471. DescriptionString = "e-m:o-i64:64-i128:128-n32:64-S128";
  4472. else
  4473. DescriptionString = "e-m:e-i64:64-i128:128-n32:64-S128";
  4474. }
  4475. public:
  4476. AArch64leTargetInfo(const llvm::Triple &Triple)
  4477. : AArch64TargetInfo(Triple) {
  4478. BigEndian = false;
  4479. }
  4480. void getTargetDefines(const LangOptions &Opts,
  4481. MacroBuilder &Builder) const override {
  4482. Builder.defineMacro("__AARCH64EL__");
  4483. AArch64TargetInfo::getTargetDefines(Opts, Builder);
  4484. }
  4485. };
  4486. class AArch64beTargetInfo : public AArch64TargetInfo {
  4487. void setDescriptionString() override {
  4488. assert(!getTriple().isOSBinFormatMachO());
  4489. DescriptionString = "E-m:e-i64:64-i128:128-n32:64-S128";
  4490. }
  4491. public:
  4492. AArch64beTargetInfo(const llvm::Triple &Triple)
  4493. : AArch64TargetInfo(Triple) { }
  4494. void getTargetDefines(const LangOptions &Opts,
  4495. MacroBuilder &Builder) const override {
  4496. Builder.defineMacro("__AARCH64EB__");
  4497. Builder.defineMacro("__AARCH_BIG_ENDIAN");
  4498. Builder.defineMacro("__ARM_BIG_ENDIAN");
  4499. AArch64TargetInfo::getTargetDefines(Opts, Builder);
  4500. }
  4501. };
  4502. } // end anonymous namespace.
  4503. namespace {
  4504. class DarwinAArch64TargetInfo : public DarwinTargetInfo<AArch64leTargetInfo> {
  4505. protected:
  4506. void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
  4507. MacroBuilder &Builder) const override {
  4508. Builder.defineMacro("__AARCH64_SIMD__");
  4509. Builder.defineMacro("__ARM64_ARCH_8__");
  4510. Builder.defineMacro("__ARM_NEON__");
  4511. Builder.defineMacro("__LITTLE_ENDIAN__");
  4512. Builder.defineMacro("__REGISTER_PREFIX__", "");
  4513. Builder.defineMacro("__arm64", "1");
  4514. Builder.defineMacro("__arm64__", "1");
  4515. getDarwinDefines(Builder, Opts, Triple, PlatformName, PlatformMinVersion);
  4516. }
  4517. public:
  4518. DarwinAArch64TargetInfo(const llvm::Triple &Triple)
  4519. : DarwinTargetInfo<AArch64leTargetInfo>(Triple) {
  4520. Int64Type = SignedLongLong;
  4521. WCharType = SignedInt;
  4522. UseSignedCharForObjCBool = false;
  4523. LongDoubleWidth = LongDoubleAlign = SuitableAlign = 64;
  4524. LongDoubleFormat = &llvm::APFloat::IEEEdouble;
  4525. TheCXXABI.set(TargetCXXABI::iOS64);
  4526. }
  4527. BuiltinVaListKind getBuiltinVaListKind() const override {
  4528. return TargetInfo::CharPtrBuiltinVaList;
  4529. }
  4530. };
  4531. } // end anonymous namespace
  4532. namespace {
  4533. // Hexagon abstract base class
  4534. class HexagonTargetInfo : public TargetInfo {
  4535. static const Builtin::Info BuiltinInfo[];
  4536. static const char * const GCCRegNames[];
  4537. static const TargetInfo::GCCRegAlias GCCRegAliases[];
  4538. std::string CPU;
  4539. public:
  4540. HexagonTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  4541. BigEndian = false;
  4542. DescriptionString = "e-m:e-p:32:32-i1:32-i64:64-a:0-n32";
  4543. // {} in inline assembly are packet specifiers, not assembly variant
  4544. // specifiers.
  4545. NoAsmVariants = true;
  4546. }
  4547. void getTargetBuiltins(const Builtin::Info *&Records,
  4548. unsigned &NumRecords) const override {
  4549. Records = BuiltinInfo;
  4550. NumRecords = clang::Hexagon::LastTSBuiltin-Builtin::FirstTSBuiltin;
  4551. }
  4552. bool validateAsmConstraint(const char *&Name,
  4553. TargetInfo::ConstraintInfo &Info) const override {
  4554. return true;
  4555. }
  4556. void getTargetDefines(const LangOptions &Opts,
  4557. MacroBuilder &Builder) const override;
  4558. bool hasFeature(StringRef Feature) const override {
  4559. return Feature == "hexagon";
  4560. }
  4561. BuiltinVaListKind getBuiltinVaListKind() const override {
  4562. return TargetInfo::CharPtrBuiltinVaList;
  4563. }
  4564. void getGCCRegNames(const char * const *&Names,
  4565. unsigned &NumNames) const override;
  4566. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  4567. unsigned &NumAliases) const override;
  4568. const char *getClobbers() const override {
  4569. return "";
  4570. }
  4571. static const char *getHexagonCPUSuffix(StringRef Name) {
  4572. return llvm::StringSwitch<const char*>(Name)
  4573. .Case("hexagonv4", "4")
  4574. .Case("hexagonv5", "5")
  4575. .Default(nullptr);
  4576. }
  4577. bool setCPU(const std::string &Name) override {
  4578. if (!getHexagonCPUSuffix(Name))
  4579. return false;
  4580. CPU = Name;
  4581. return true;
  4582. }
  4583. };
  4584. void HexagonTargetInfo::getTargetDefines(const LangOptions &Opts,
  4585. MacroBuilder &Builder) const {
  4586. Builder.defineMacro("qdsp6");
  4587. Builder.defineMacro("__qdsp6", "1");
  4588. Builder.defineMacro("__qdsp6__", "1");
  4589. Builder.defineMacro("hexagon");
  4590. Builder.defineMacro("__hexagon", "1");
  4591. Builder.defineMacro("__hexagon__", "1");
  4592. if(CPU == "hexagonv1") {
  4593. Builder.defineMacro("__HEXAGON_V1__");
  4594. Builder.defineMacro("__HEXAGON_ARCH__", "1");
  4595. if(Opts.HexagonQdsp6Compat) {
  4596. Builder.defineMacro("__QDSP6_V1__");
  4597. Builder.defineMacro("__QDSP6_ARCH__", "1");
  4598. }
  4599. }
  4600. else if(CPU == "hexagonv2") {
  4601. Builder.defineMacro("__HEXAGON_V2__");
  4602. Builder.defineMacro("__HEXAGON_ARCH__", "2");
  4603. if(Opts.HexagonQdsp6Compat) {
  4604. Builder.defineMacro("__QDSP6_V2__");
  4605. Builder.defineMacro("__QDSP6_ARCH__", "2");
  4606. }
  4607. }
  4608. else if(CPU == "hexagonv3") {
  4609. Builder.defineMacro("__HEXAGON_V3__");
  4610. Builder.defineMacro("__HEXAGON_ARCH__", "3");
  4611. if(Opts.HexagonQdsp6Compat) {
  4612. Builder.defineMacro("__QDSP6_V3__");
  4613. Builder.defineMacro("__QDSP6_ARCH__", "3");
  4614. }
  4615. }
  4616. else if(CPU == "hexagonv4") {
  4617. Builder.defineMacro("__HEXAGON_V4__");
  4618. Builder.defineMacro("__HEXAGON_ARCH__", "4");
  4619. if(Opts.HexagonQdsp6Compat) {
  4620. Builder.defineMacro("__QDSP6_V4__");
  4621. Builder.defineMacro("__QDSP6_ARCH__", "4");
  4622. }
  4623. }
  4624. else if(CPU == "hexagonv5") {
  4625. Builder.defineMacro("__HEXAGON_V5__");
  4626. Builder.defineMacro("__HEXAGON_ARCH__", "5");
  4627. if(Opts.HexagonQdsp6Compat) {
  4628. Builder.defineMacro("__QDSP6_V5__");
  4629. Builder.defineMacro("__QDSP6_ARCH__", "5");
  4630. }
  4631. }
  4632. }
  4633. const char * const HexagonTargetInfo::GCCRegNames[] = {
  4634. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  4635. "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
  4636. "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
  4637. "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31",
  4638. "p0", "p1", "p2", "p3",
  4639. "sa0", "lc0", "sa1", "lc1", "m0", "m1", "usr", "ugp"
  4640. };
  4641. void HexagonTargetInfo::getGCCRegNames(const char * const *&Names,
  4642. unsigned &NumNames) const {
  4643. Names = GCCRegNames;
  4644. NumNames = llvm::array_lengthof(GCCRegNames);
  4645. }
  4646. const TargetInfo::GCCRegAlias HexagonTargetInfo::GCCRegAliases[] = {
  4647. { { "sp" }, "r29" },
  4648. { { "fp" }, "r30" },
  4649. { { "lr" }, "r31" },
  4650. };
  4651. void HexagonTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
  4652. unsigned &NumAliases) const {
  4653. Aliases = GCCRegAliases;
  4654. NumAliases = llvm::array_lengthof(GCCRegAliases);
  4655. }
  4656. const Builtin::Info HexagonTargetInfo::BuiltinInfo[] = {
  4657. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  4658. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  4659. ALL_LANGUAGES },
  4660. #include "clang/Basic/BuiltinsHexagon.def"
  4661. };
  4662. }
  4663. namespace {
  4664. // Shared base class for SPARC v8 (32-bit) and SPARC v9 (64-bit).
  4665. class SparcTargetInfo : public TargetInfo {
  4666. static const TargetInfo::GCCRegAlias GCCRegAliases[];
  4667. static const char * const GCCRegNames[];
  4668. bool SoftFloat;
  4669. public:
  4670. SparcTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {}
  4671. bool handleTargetFeatures(std::vector<std::string> &Features,
  4672. DiagnosticsEngine &Diags) override {
  4673. SoftFloat = false;
  4674. for (unsigned i = 0, e = Features.size(); i != e; ++i)
  4675. if (Features[i] == "+soft-float")
  4676. SoftFloat = true;
  4677. return true;
  4678. }
  4679. void getTargetDefines(const LangOptions &Opts,
  4680. MacroBuilder &Builder) const override {
  4681. DefineStd(Builder, "sparc", Opts);
  4682. Builder.defineMacro("__REGISTER_PREFIX__", "");
  4683. if (SoftFloat)
  4684. Builder.defineMacro("SOFT_FLOAT", "1");
  4685. }
  4686. bool hasFeature(StringRef Feature) const override {
  4687. return llvm::StringSwitch<bool>(Feature)
  4688. .Case("softfloat", SoftFloat)
  4689. .Case("sparc", true)
  4690. .Default(false);
  4691. }
  4692. void getTargetBuiltins(const Builtin::Info *&Records,
  4693. unsigned &NumRecords) const override {
  4694. // FIXME: Implement!
  4695. }
  4696. BuiltinVaListKind getBuiltinVaListKind() const override {
  4697. return TargetInfo::VoidPtrBuiltinVaList;
  4698. }
  4699. void getGCCRegNames(const char * const *&Names,
  4700. unsigned &NumNames) const override;
  4701. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  4702. unsigned &NumAliases) const override;
  4703. bool validateAsmConstraint(const char *&Name,
  4704. TargetInfo::ConstraintInfo &info) const override {
  4705. // FIXME: Implement!
  4706. switch (*Name) {
  4707. case 'I': // Signed 13-bit constant
  4708. case 'J': // Zero
  4709. case 'K': // 32-bit constant with the low 12 bits clear
  4710. case 'L': // A constant in the range supported by movcc (11-bit signed imm)
  4711. case 'M': // A constant in the range supported by movrcc (19-bit signed imm)
  4712. case 'N': // Same as 'K' but zext (required for SIMode)
  4713. case 'O': // The constant 4096
  4714. return true;
  4715. }
  4716. return false;
  4717. }
  4718. const char *getClobbers() const override {
  4719. // FIXME: Implement!
  4720. return "";
  4721. }
  4722. };
  4723. const char * const SparcTargetInfo::GCCRegNames[] = {
  4724. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  4725. "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
  4726. "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
  4727. "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31"
  4728. };
  4729. void SparcTargetInfo::getGCCRegNames(const char * const *&Names,
  4730. unsigned &NumNames) const {
  4731. Names = GCCRegNames;
  4732. NumNames = llvm::array_lengthof(GCCRegNames);
  4733. }
  4734. const TargetInfo::GCCRegAlias SparcTargetInfo::GCCRegAliases[] = {
  4735. { { "g0" }, "r0" },
  4736. { { "g1" }, "r1" },
  4737. { { "g2" }, "r2" },
  4738. { { "g3" }, "r3" },
  4739. { { "g4" }, "r4" },
  4740. { { "g5" }, "r5" },
  4741. { { "g6" }, "r6" },
  4742. { { "g7" }, "r7" },
  4743. { { "o0" }, "r8" },
  4744. { { "o1" }, "r9" },
  4745. { { "o2" }, "r10" },
  4746. { { "o3" }, "r11" },
  4747. { { "o4" }, "r12" },
  4748. { { "o5" }, "r13" },
  4749. { { "o6", "sp" }, "r14" },
  4750. { { "o7" }, "r15" },
  4751. { { "l0" }, "r16" },
  4752. { { "l1" }, "r17" },
  4753. { { "l2" }, "r18" },
  4754. { { "l3" }, "r19" },
  4755. { { "l4" }, "r20" },
  4756. { { "l5" }, "r21" },
  4757. { { "l6" }, "r22" },
  4758. { { "l7" }, "r23" },
  4759. { { "i0" }, "r24" },
  4760. { { "i1" }, "r25" },
  4761. { { "i2" }, "r26" },
  4762. { { "i3" }, "r27" },
  4763. { { "i4" }, "r28" },
  4764. { { "i5" }, "r29" },
  4765. { { "i6", "fp" }, "r30" },
  4766. { { "i7" }, "r31" },
  4767. };
  4768. void SparcTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
  4769. unsigned &NumAliases) const {
  4770. Aliases = GCCRegAliases;
  4771. NumAliases = llvm::array_lengthof(GCCRegAliases);
  4772. }
  4773. // SPARC v8 is the 32-bit mode selected by Triple::sparc.
  4774. class SparcV8TargetInfo : public SparcTargetInfo {
  4775. public:
  4776. SparcV8TargetInfo(const llvm::Triple &Triple) : SparcTargetInfo(Triple) {
  4777. DescriptionString = "E-m:e-p:32:32-i64:64-f128:64-n32-S64";
  4778. }
  4779. void getTargetDefines(const LangOptions &Opts,
  4780. MacroBuilder &Builder) const override {
  4781. SparcTargetInfo::getTargetDefines(Opts, Builder);
  4782. Builder.defineMacro("__sparcv8");
  4783. }
  4784. };
  4785. // SPARC v9 is the 64-bit mode selected by Triple::sparcv9.
  4786. class SparcV9TargetInfo : public SparcTargetInfo {
  4787. public:
  4788. SparcV9TargetInfo(const llvm::Triple &Triple) : SparcTargetInfo(Triple) {
  4789. // FIXME: Support Sparc quad-precision long double?
  4790. DescriptionString = "E-m:e-i64:64-n32:64-S128";
  4791. // This is an LP64 platform.
  4792. LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
  4793. // OpenBSD uses long long for int64_t and intmax_t.
  4794. if (getTriple().getOS() == llvm::Triple::OpenBSD)
  4795. IntMaxType = SignedLongLong;
  4796. else
  4797. IntMaxType = SignedLong;
  4798. Int64Type = IntMaxType;
  4799. // The SPARCv8 System V ABI has long double 128-bits in size, but 64-bit
  4800. // aligned. The SPARCv9 SCD 2.4.1 says 16-byte aligned.
  4801. LongDoubleWidth = 128;
  4802. LongDoubleAlign = 128;
  4803. LongDoubleFormat = &llvm::APFloat::IEEEquad;
  4804. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
  4805. }
  4806. void getTargetDefines(const LangOptions &Opts,
  4807. MacroBuilder &Builder) const override {
  4808. SparcTargetInfo::getTargetDefines(Opts, Builder);
  4809. Builder.defineMacro("__sparcv9");
  4810. Builder.defineMacro("__arch64__");
  4811. // Solaris doesn't need these variants, but the BSDs do.
  4812. if (getTriple().getOS() != llvm::Triple::Solaris) {
  4813. Builder.defineMacro("__sparc64__");
  4814. Builder.defineMacro("__sparc_v9__");
  4815. Builder.defineMacro("__sparcv9__");
  4816. }
  4817. }
  4818. bool setCPU(const std::string &Name) override {
  4819. bool CPUKnown = llvm::StringSwitch<bool>(Name)
  4820. .Case("v9", true)
  4821. .Case("ultrasparc", true)
  4822. .Case("ultrasparc3", true)
  4823. .Case("niagara", true)
  4824. .Case("niagara2", true)
  4825. .Case("niagara3", true)
  4826. .Case("niagara4", true)
  4827. .Default(false);
  4828. // No need to store the CPU yet. There aren't any CPU-specific
  4829. // macros to define.
  4830. return CPUKnown;
  4831. }
  4832. };
  4833. } // end anonymous namespace.
  4834. namespace {
  4835. class SolarisSparcV8TargetInfo : public SolarisTargetInfo<SparcV8TargetInfo> {
  4836. public:
  4837. SolarisSparcV8TargetInfo(const llvm::Triple &Triple)
  4838. : SolarisTargetInfo<SparcV8TargetInfo>(Triple) {
  4839. SizeType = UnsignedInt;
  4840. PtrDiffType = SignedInt;
  4841. }
  4842. };
  4843. } // end anonymous namespace.
  4844. namespace {
  4845. class SystemZTargetInfo : public TargetInfo {
  4846. static const char *const GCCRegNames[];
  4847. public:
  4848. SystemZTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  4849. TLSSupported = true;
  4850. IntWidth = IntAlign = 32;
  4851. LongWidth = LongLongWidth = LongAlign = LongLongAlign = 64;
  4852. PointerWidth = PointerAlign = 64;
  4853. LongDoubleWidth = 128;
  4854. LongDoubleAlign = 64;
  4855. LongDoubleFormat = &llvm::APFloat::IEEEquad;
  4856. MinGlobalAlign = 16;
  4857. DescriptionString = "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-a:8:16-n32:64";
  4858. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
  4859. }
  4860. void getTargetDefines(const LangOptions &Opts,
  4861. MacroBuilder &Builder) const override {
  4862. Builder.defineMacro("__s390__");
  4863. Builder.defineMacro("__s390x__");
  4864. Builder.defineMacro("__zarch__");
  4865. Builder.defineMacro("__LONG_DOUBLE_128__");
  4866. }
  4867. void getTargetBuiltins(const Builtin::Info *&Records,
  4868. unsigned &NumRecords) const override {
  4869. // FIXME: Implement.
  4870. Records = nullptr;
  4871. NumRecords = 0;
  4872. }
  4873. void getGCCRegNames(const char *const *&Names,
  4874. unsigned &NumNames) const override;
  4875. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  4876. unsigned &NumAliases) const override {
  4877. // No aliases.
  4878. Aliases = nullptr;
  4879. NumAliases = 0;
  4880. }
  4881. bool validateAsmConstraint(const char *&Name,
  4882. TargetInfo::ConstraintInfo &info) const override;
  4883. const char *getClobbers() const override {
  4884. // FIXME: Is this really right?
  4885. return "";
  4886. }
  4887. BuiltinVaListKind getBuiltinVaListKind() const override {
  4888. return TargetInfo::SystemZBuiltinVaList;
  4889. }
  4890. bool setCPU(const std::string &Name) override {
  4891. bool CPUKnown = llvm::StringSwitch<bool>(Name)
  4892. .Case("z10", true)
  4893. .Case("z196", true)
  4894. .Case("zEC12", true)
  4895. .Default(false);
  4896. // No need to store the CPU yet. There aren't any CPU-specific
  4897. // macros to define.
  4898. return CPUKnown;
  4899. }
  4900. };
  4901. const char *const SystemZTargetInfo::GCCRegNames[] = {
  4902. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  4903. "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
  4904. "f0", "f2", "f4", "f6", "f1", "f3", "f5", "f7",
  4905. "f8", "f10", "f12", "f14", "f9", "f11", "f13", "f15"
  4906. };
  4907. void SystemZTargetInfo::getGCCRegNames(const char *const *&Names,
  4908. unsigned &NumNames) const {
  4909. Names = GCCRegNames;
  4910. NumNames = llvm::array_lengthof(GCCRegNames);
  4911. }
  4912. bool SystemZTargetInfo::
  4913. validateAsmConstraint(const char *&Name,
  4914. TargetInfo::ConstraintInfo &Info) const {
  4915. switch (*Name) {
  4916. default:
  4917. return false;
  4918. case 'a': // Address register
  4919. case 'd': // Data register (equivalent to 'r')
  4920. case 'f': // Floating-point register
  4921. Info.setAllowsRegister();
  4922. return true;
  4923. case 'I': // Unsigned 8-bit constant
  4924. case 'J': // Unsigned 12-bit constant
  4925. case 'K': // Signed 16-bit constant
  4926. case 'L': // Signed 20-bit displacement (on all targets we support)
  4927. case 'M': // 0x7fffffff
  4928. return true;
  4929. case 'Q': // Memory with base and unsigned 12-bit displacement
  4930. case 'R': // Likewise, plus an index
  4931. case 'S': // Memory with base and signed 20-bit displacement
  4932. case 'T': // Likewise, plus an index
  4933. Info.setAllowsMemory();
  4934. return true;
  4935. }
  4936. }
  4937. }
  4938. namespace {
  4939. class MSP430TargetInfo : public TargetInfo {
  4940. static const char * const GCCRegNames[];
  4941. public:
  4942. MSP430TargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  4943. BigEndian = false;
  4944. TLSSupported = false;
  4945. IntWidth = 16; IntAlign = 16;
  4946. LongWidth = 32; LongLongWidth = 64;
  4947. LongAlign = LongLongAlign = 16;
  4948. PointerWidth = 16; PointerAlign = 16;
  4949. SuitableAlign = 16;
  4950. SizeType = UnsignedInt;
  4951. IntMaxType = SignedLongLong;
  4952. IntPtrType = SignedInt;
  4953. PtrDiffType = SignedInt;
  4954. SigAtomicType = SignedLong;
  4955. DescriptionString = "e-m:e-p:16:16-i32:16:32-a:16-n8:16";
  4956. }
  4957. void getTargetDefines(const LangOptions &Opts,
  4958. MacroBuilder &Builder) const override {
  4959. Builder.defineMacro("MSP430");
  4960. Builder.defineMacro("__MSP430__");
  4961. // FIXME: defines for different 'flavours' of MCU
  4962. }
  4963. void getTargetBuiltins(const Builtin::Info *&Records,
  4964. unsigned &NumRecords) const override {
  4965. // FIXME: Implement.
  4966. Records = nullptr;
  4967. NumRecords = 0;
  4968. }
  4969. bool hasFeature(StringRef Feature) const override {
  4970. return Feature == "msp430";
  4971. }
  4972. void getGCCRegNames(const char * const *&Names,
  4973. unsigned &NumNames) const override;
  4974. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  4975. unsigned &NumAliases) const override {
  4976. // No aliases.
  4977. Aliases = nullptr;
  4978. NumAliases = 0;
  4979. }
  4980. bool
  4981. validateAsmConstraint(const char *&Name,
  4982. TargetInfo::ConstraintInfo &info) const override {
  4983. // FIXME: implement
  4984. switch (*Name) {
  4985. case 'K': // the constant 1
  4986. case 'L': // constant -1^20 .. 1^19
  4987. case 'M': // constant 1-4:
  4988. return true;
  4989. }
  4990. // No target constraints for now.
  4991. return false;
  4992. }
  4993. const char *getClobbers() const override {
  4994. // FIXME: Is this really right?
  4995. return "";
  4996. }
  4997. BuiltinVaListKind getBuiltinVaListKind() const override {
  4998. // FIXME: implement
  4999. return TargetInfo::CharPtrBuiltinVaList;
  5000. }
  5001. };
  5002. const char * const MSP430TargetInfo::GCCRegNames[] = {
  5003. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  5004. "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"
  5005. };
  5006. void MSP430TargetInfo::getGCCRegNames(const char * const *&Names,
  5007. unsigned &NumNames) const {
  5008. Names = GCCRegNames;
  5009. NumNames = llvm::array_lengthof(GCCRegNames);
  5010. }
  5011. }
  5012. namespace {
  5013. // LLVM and Clang cannot be used directly to output native binaries for
  5014. // target, but is used to compile C code to llvm bitcode with correct
  5015. // type and alignment information.
  5016. //
  5017. // TCE uses the llvm bitcode as input and uses it for generating customized
  5018. // target processor and program binary. TCE co-design environment is
  5019. // publicly available in http://tce.cs.tut.fi
  5020. static const unsigned TCEOpenCLAddrSpaceMap[] = {
  5021. 3, // opencl_global
  5022. 4, // opencl_local
  5023. 5, // opencl_constant
  5024. // FIXME: generic has to be added to the target
  5025. 0, // opencl_generic
  5026. 0, // cuda_device
  5027. 0, // cuda_constant
  5028. 0 // cuda_shared
  5029. };
  5030. class TCETargetInfo : public TargetInfo{
  5031. public:
  5032. TCETargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  5033. TLSSupported = false;
  5034. IntWidth = 32;
  5035. LongWidth = LongLongWidth = 32;
  5036. PointerWidth = 32;
  5037. IntAlign = 32;
  5038. LongAlign = LongLongAlign = 32;
  5039. PointerAlign = 32;
  5040. SuitableAlign = 32;
  5041. SizeType = UnsignedInt;
  5042. IntMaxType = SignedLong;
  5043. IntPtrType = SignedInt;
  5044. PtrDiffType = SignedInt;
  5045. FloatWidth = 32;
  5046. FloatAlign = 32;
  5047. DoubleWidth = 32;
  5048. DoubleAlign = 32;
  5049. LongDoubleWidth = 32;
  5050. LongDoubleAlign = 32;
  5051. FloatFormat = &llvm::APFloat::IEEEsingle;
  5052. DoubleFormat = &llvm::APFloat::IEEEsingle;
  5053. LongDoubleFormat = &llvm::APFloat::IEEEsingle;
  5054. DescriptionString = "E-p:32:32-i8:8:32-i16:16:32-i64:32"
  5055. "-f64:32-v64:32-v128:32-a:0:32-n32";
  5056. AddrSpaceMap = &TCEOpenCLAddrSpaceMap;
  5057. UseAddrSpaceMapMangling = true;
  5058. }
  5059. void getTargetDefines(const LangOptions &Opts,
  5060. MacroBuilder &Builder) const override {
  5061. DefineStd(Builder, "tce", Opts);
  5062. Builder.defineMacro("__TCE__");
  5063. Builder.defineMacro("__TCE_V1__");
  5064. }
  5065. bool hasFeature(StringRef Feature) const override {
  5066. return Feature == "tce";
  5067. }
  5068. void getTargetBuiltins(const Builtin::Info *&Records,
  5069. unsigned &NumRecords) const override {}
  5070. const char *getClobbers() const override {
  5071. return "";
  5072. }
  5073. BuiltinVaListKind getBuiltinVaListKind() const override {
  5074. return TargetInfo::VoidPtrBuiltinVaList;
  5075. }
  5076. void getGCCRegNames(const char * const *&Names,
  5077. unsigned &NumNames) const override {}
  5078. bool validateAsmConstraint(const char *&Name,
  5079. TargetInfo::ConstraintInfo &info) const override{
  5080. return true;
  5081. }
  5082. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5083. unsigned &NumAliases) const override {}
  5084. };
  5085. }
  5086. namespace {
  5087. class MipsTargetInfoBase : public TargetInfo {
  5088. virtual void setDescriptionString() = 0;
  5089. static const Builtin::Info BuiltinInfo[];
  5090. std::string CPU;
  5091. bool IsMips16;
  5092. bool IsMicromips;
  5093. bool IsNan2008;
  5094. bool IsSingleFloat;
  5095. enum MipsFloatABI {
  5096. HardFloat, SoftFloat
  5097. } FloatABI;
  5098. enum DspRevEnum {
  5099. NoDSP, DSP1, DSP2
  5100. } DspRev;
  5101. bool HasMSA;
  5102. protected:
  5103. bool HasFP64;
  5104. std::string ABI;
  5105. public:
  5106. MipsTargetInfoBase(const llvm::Triple &Triple, const std::string &ABIStr,
  5107. const std::string &CPUStr)
  5108. : TargetInfo(Triple), CPU(CPUStr), IsMips16(false), IsMicromips(false),
  5109. IsNan2008(false), IsSingleFloat(false), FloatABI(HardFloat),
  5110. DspRev(NoDSP), HasMSA(false), HasFP64(false), ABI(ABIStr) {
  5111. TheCXXABI.set(TargetCXXABI::GenericMIPS);
  5112. }
  5113. bool isNaN2008Default() const {
  5114. return CPU == "mips32r6" || CPU == "mips64r6";
  5115. }
  5116. bool isFP64Default() const {
  5117. return CPU == "mips32r6" || ABI == "n32" || ABI == "n64" || ABI == "64";
  5118. }
  5119. StringRef getABI() const override { return ABI; }
  5120. bool setCPU(const std::string &Name) override {
  5121. bool IsMips32 = getTriple().getArch() == llvm::Triple::mips ||
  5122. getTriple().getArch() == llvm::Triple::mipsel;
  5123. CPU = Name;
  5124. return llvm::StringSwitch<bool>(Name)
  5125. .Case("mips1", IsMips32)
  5126. .Case("mips2", IsMips32)
  5127. .Case("mips3", true)
  5128. .Case("mips4", true)
  5129. .Case("mips5", true)
  5130. .Case("mips32", IsMips32)
  5131. .Case("mips32r2", IsMips32)
  5132. .Case("mips32r3", IsMips32)
  5133. .Case("mips32r5", IsMips32)
  5134. .Case("mips32r6", IsMips32)
  5135. .Case("mips64", true)
  5136. .Case("mips64r2", true)
  5137. .Case("mips64r3", true)
  5138. .Case("mips64r5", true)
  5139. .Case("mips64r6", true)
  5140. .Case("octeon", true)
  5141. .Default(false);
  5142. }
  5143. const std::string& getCPU() const { return CPU; }
  5144. void getDefaultFeatures(llvm::StringMap<bool> &Features) const override {
  5145. if (CPU == "octeon")
  5146. Features["mips64r2"] = Features["cnmips"] = true;
  5147. else
  5148. Features[CPU] = true;
  5149. }
  5150. void getTargetDefines(const LangOptions &Opts,
  5151. MacroBuilder &Builder) const override {
  5152. Builder.defineMacro("__mips__");
  5153. Builder.defineMacro("_mips");
  5154. if (Opts.GNUMode)
  5155. Builder.defineMacro("mips");
  5156. Builder.defineMacro("__REGISTER_PREFIX__", "");
  5157. switch (FloatABI) {
  5158. case HardFloat:
  5159. Builder.defineMacro("__mips_hard_float", Twine(1));
  5160. break;
  5161. case SoftFloat:
  5162. Builder.defineMacro("__mips_soft_float", Twine(1));
  5163. break;
  5164. }
  5165. if (IsSingleFloat)
  5166. Builder.defineMacro("__mips_single_float", Twine(1));
  5167. Builder.defineMacro("__mips_fpr", HasFP64 ? Twine(64) : Twine(32));
  5168. Builder.defineMacro("_MIPS_FPSET",
  5169. Twine(32 / (HasFP64 || IsSingleFloat ? 1 : 2)));
  5170. if (IsMips16)
  5171. Builder.defineMacro("__mips16", Twine(1));
  5172. if (IsMicromips)
  5173. Builder.defineMacro("__mips_micromips", Twine(1));
  5174. if (IsNan2008)
  5175. Builder.defineMacro("__mips_nan2008", Twine(1));
  5176. switch (DspRev) {
  5177. default:
  5178. break;
  5179. case DSP1:
  5180. Builder.defineMacro("__mips_dsp_rev", Twine(1));
  5181. Builder.defineMacro("__mips_dsp", Twine(1));
  5182. break;
  5183. case DSP2:
  5184. Builder.defineMacro("__mips_dsp_rev", Twine(2));
  5185. Builder.defineMacro("__mips_dspr2", Twine(1));
  5186. Builder.defineMacro("__mips_dsp", Twine(1));
  5187. break;
  5188. }
  5189. if (HasMSA)
  5190. Builder.defineMacro("__mips_msa", Twine(1));
  5191. Builder.defineMacro("_MIPS_SZPTR", Twine(getPointerWidth(0)));
  5192. Builder.defineMacro("_MIPS_SZINT", Twine(getIntWidth()));
  5193. Builder.defineMacro("_MIPS_SZLONG", Twine(getLongWidth()));
  5194. Builder.defineMacro("_MIPS_ARCH", "\"" + CPU + "\"");
  5195. Builder.defineMacro("_MIPS_ARCH_" + StringRef(CPU).upper());
  5196. }
  5197. void getTargetBuiltins(const Builtin::Info *&Records,
  5198. unsigned &NumRecords) const override {
  5199. Records = BuiltinInfo;
  5200. NumRecords = clang::Mips::LastTSBuiltin - Builtin::FirstTSBuiltin;
  5201. }
  5202. bool hasFeature(StringRef Feature) const override {
  5203. return llvm::StringSwitch<bool>(Feature)
  5204. .Case("mips", true)
  5205. .Case("fp64", HasFP64)
  5206. .Default(false);
  5207. }
  5208. BuiltinVaListKind getBuiltinVaListKind() const override {
  5209. return TargetInfo::VoidPtrBuiltinVaList;
  5210. }
  5211. void getGCCRegNames(const char * const *&Names,
  5212. unsigned &NumNames) const override {
  5213. static const char *const GCCRegNames[] = {
  5214. // CPU register names
  5215. // Must match second column of GCCRegAliases
  5216. "$0", "$1", "$2", "$3", "$4", "$5", "$6", "$7",
  5217. "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15",
  5218. "$16", "$17", "$18", "$19", "$20", "$21", "$22", "$23",
  5219. "$24", "$25", "$26", "$27", "$28", "$29", "$30", "$31",
  5220. // Floating point register names
  5221. "$f0", "$f1", "$f2", "$f3", "$f4", "$f5", "$f6", "$f7",
  5222. "$f8", "$f9", "$f10", "$f11", "$f12", "$f13", "$f14", "$f15",
  5223. "$f16", "$f17", "$f18", "$f19", "$f20", "$f21", "$f22", "$f23",
  5224. "$f24", "$f25", "$f26", "$f27", "$f28", "$f29", "$f30", "$f31",
  5225. // Hi/lo and condition register names
  5226. "hi", "lo", "", "$fcc0","$fcc1","$fcc2","$fcc3","$fcc4",
  5227. "$fcc5","$fcc6","$fcc7",
  5228. // MSA register names
  5229. "$w0", "$w1", "$w2", "$w3", "$w4", "$w5", "$w6", "$w7",
  5230. "$w8", "$w9", "$w10", "$w11", "$w12", "$w13", "$w14", "$w15",
  5231. "$w16", "$w17", "$w18", "$w19", "$w20", "$w21", "$w22", "$w23",
  5232. "$w24", "$w25", "$w26", "$w27", "$w28", "$w29", "$w30", "$w31",
  5233. // MSA control register names
  5234. "$msair", "$msacsr", "$msaaccess", "$msasave", "$msamodify",
  5235. "$msarequest", "$msamap", "$msaunmap"
  5236. };
  5237. Names = GCCRegNames;
  5238. NumNames = llvm::array_lengthof(GCCRegNames);
  5239. }
  5240. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5241. unsigned &NumAliases) const override = 0;
  5242. bool validateAsmConstraint(const char *&Name,
  5243. TargetInfo::ConstraintInfo &Info) const override {
  5244. switch (*Name) {
  5245. default:
  5246. return false;
  5247. case 'r': // CPU registers.
  5248. case 'd': // Equivalent to "r" unless generating MIPS16 code.
  5249. case 'y': // Equivalent to "r", backward compatibility only.
  5250. case 'f': // floating-point registers.
  5251. case 'c': // $25 for indirect jumps
  5252. case 'l': // lo register
  5253. case 'x': // hilo register pair
  5254. Info.setAllowsRegister();
  5255. return true;
  5256. case 'I': // Signed 16-bit constant
  5257. case 'J': // Integer 0
  5258. case 'K': // Unsigned 16-bit constant
  5259. case 'L': // Signed 32-bit constant, lower 16-bit zeros (for lui)
  5260. case 'M': // Constants not loadable via lui, addiu, or ori
  5261. case 'N': // Constant -1 to -65535
  5262. case 'O': // A signed 15-bit constant
  5263. case 'P': // A constant between 1 go 65535
  5264. return true;
  5265. case 'R': // An address that can be used in a non-macro load or store
  5266. Info.setAllowsMemory();
  5267. return true;
  5268. }
  5269. }
  5270. const char *getClobbers() const override {
  5271. // In GCC, $1 is not widely used in generated code (it's used only in a few
  5272. // specific situations), so there is no real need for users to add it to
  5273. // the clobbers list if they want to use it in their inline assembly code.
  5274. //
  5275. // In LLVM, $1 is treated as a normal GPR and is always allocatable during
  5276. // code generation, so using it in inline assembly without adding it to the
  5277. // clobbers list can cause conflicts between the inline assembly code and
  5278. // the surrounding generated code.
  5279. //
  5280. // Another problem is that LLVM is allowed to choose $1 for inline assembly
  5281. // operands, which will conflict with the ".set at" assembler option (which
  5282. // we use only for inline assembly, in order to maintain compatibility with
  5283. // GCC) and will also conflict with the user's usage of $1.
  5284. //
  5285. // The easiest way to avoid these conflicts and keep $1 as an allocatable
  5286. // register for generated code is to automatically clobber $1 for all inline
  5287. // assembly code.
  5288. //
  5289. // FIXME: We should automatically clobber $1 only for inline assembly code
  5290. // which actually uses it. This would allow LLVM to use $1 for inline
  5291. // assembly operands if the user's assembly code doesn't use it.
  5292. return "~{$1}";
  5293. }
  5294. bool handleTargetFeatures(std::vector<std::string> &Features,
  5295. DiagnosticsEngine &Diags) override {
  5296. IsMips16 = false;
  5297. IsMicromips = false;
  5298. IsNan2008 = isNaN2008Default();
  5299. IsSingleFloat = false;
  5300. FloatABI = HardFloat;
  5301. DspRev = NoDSP;
  5302. HasFP64 = isFP64Default();
  5303. for (std::vector<std::string>::iterator it = Features.begin(),
  5304. ie = Features.end(); it != ie; ++it) {
  5305. if (*it == "+single-float")
  5306. IsSingleFloat = true;
  5307. else if (*it == "+soft-float")
  5308. FloatABI = SoftFloat;
  5309. else if (*it == "+mips16")
  5310. IsMips16 = true;
  5311. else if (*it == "+micromips")
  5312. IsMicromips = true;
  5313. else if (*it == "+dsp")
  5314. DspRev = std::max(DspRev, DSP1);
  5315. else if (*it == "+dspr2")
  5316. DspRev = std::max(DspRev, DSP2);
  5317. else if (*it == "+msa")
  5318. HasMSA = true;
  5319. else if (*it == "+fp64")
  5320. HasFP64 = true;
  5321. else if (*it == "-fp64")
  5322. HasFP64 = false;
  5323. else if (*it == "+nan2008")
  5324. IsNan2008 = true;
  5325. else if (*it == "-nan2008")
  5326. IsNan2008 = false;
  5327. }
  5328. // Remove front-end specific options.
  5329. std::vector<std::string>::iterator it =
  5330. std::find(Features.begin(), Features.end(), "+soft-float");
  5331. if (it != Features.end())
  5332. Features.erase(it);
  5333. setDescriptionString();
  5334. return true;
  5335. }
  5336. int getEHDataRegisterNumber(unsigned RegNo) const override {
  5337. if (RegNo == 0) return 4;
  5338. if (RegNo == 1) return 5;
  5339. return -1;
  5340. }
  5341. bool isCLZForZeroUndef() const override { return false; }
  5342. };
  5343. const Builtin::Info MipsTargetInfoBase::BuiltinInfo[] = {
  5344. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  5345. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  5346. ALL_LANGUAGES },
  5347. #include "clang/Basic/BuiltinsMips.def"
  5348. };
  5349. class Mips32TargetInfoBase : public MipsTargetInfoBase {
  5350. public:
  5351. Mips32TargetInfoBase(const llvm::Triple &Triple)
  5352. : MipsTargetInfoBase(Triple, "o32", "mips32r2") {
  5353. SizeType = UnsignedInt;
  5354. PtrDiffType = SignedInt;
  5355. Int64Type = SignedLongLong;
  5356. IntMaxType = Int64Type;
  5357. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 32;
  5358. }
  5359. bool setABI(const std::string &Name) override {
  5360. if (Name == "o32" || Name == "eabi") {
  5361. ABI = Name;
  5362. return true;
  5363. }
  5364. return false;
  5365. }
  5366. void getTargetDefines(const LangOptions &Opts,
  5367. MacroBuilder &Builder) const override {
  5368. MipsTargetInfoBase::getTargetDefines(Opts, Builder);
  5369. Builder.defineMacro("__mips", "32");
  5370. Builder.defineMacro("_MIPS_ISA", "_MIPS_ISA_MIPS32");
  5371. const std::string& CPUStr = getCPU();
  5372. if (CPUStr == "mips32")
  5373. Builder.defineMacro("__mips_isa_rev", "1");
  5374. else if (CPUStr == "mips32r2")
  5375. Builder.defineMacro("__mips_isa_rev", "2");
  5376. else if (CPUStr == "mips32r3")
  5377. Builder.defineMacro("__mips_isa_rev", "3");
  5378. else if (CPUStr == "mips32r5")
  5379. Builder.defineMacro("__mips_isa_rev", "5");
  5380. else if (CPUStr == "mips32r6")
  5381. Builder.defineMacro("__mips_isa_rev", "6");
  5382. if (ABI == "o32") {
  5383. Builder.defineMacro("__mips_o32");
  5384. Builder.defineMacro("_ABIO32", "1");
  5385. Builder.defineMacro("_MIPS_SIM", "_ABIO32");
  5386. }
  5387. else if (ABI == "eabi")
  5388. Builder.defineMacro("__mips_eabi");
  5389. else
  5390. llvm_unreachable("Invalid ABI for Mips32.");
  5391. }
  5392. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5393. unsigned &NumAliases) const override {
  5394. static const TargetInfo::GCCRegAlias GCCRegAliases[] = {
  5395. { { "at" }, "$1" },
  5396. { { "v0" }, "$2" },
  5397. { { "v1" }, "$3" },
  5398. { { "a0" }, "$4" },
  5399. { { "a1" }, "$5" },
  5400. { { "a2" }, "$6" },
  5401. { { "a3" }, "$7" },
  5402. { { "t0" }, "$8" },
  5403. { { "t1" }, "$9" },
  5404. { { "t2" }, "$10" },
  5405. { { "t3" }, "$11" },
  5406. { { "t4" }, "$12" },
  5407. { { "t5" }, "$13" },
  5408. { { "t6" }, "$14" },
  5409. { { "t7" }, "$15" },
  5410. { { "s0" }, "$16" },
  5411. { { "s1" }, "$17" },
  5412. { { "s2" }, "$18" },
  5413. { { "s3" }, "$19" },
  5414. { { "s4" }, "$20" },
  5415. { { "s5" }, "$21" },
  5416. { { "s6" }, "$22" },
  5417. { { "s7" }, "$23" },
  5418. { { "t8" }, "$24" },
  5419. { { "t9" }, "$25" },
  5420. { { "k0" }, "$26" },
  5421. { { "k1" }, "$27" },
  5422. { { "gp" }, "$28" },
  5423. { { "sp","$sp" }, "$29" },
  5424. { { "fp","$fp" }, "$30" },
  5425. { { "ra" }, "$31" }
  5426. };
  5427. Aliases = GCCRegAliases;
  5428. NumAliases = llvm::array_lengthof(GCCRegAliases);
  5429. }
  5430. };
  5431. class Mips32EBTargetInfo : public Mips32TargetInfoBase {
  5432. void setDescriptionString() override {
  5433. DescriptionString = "E-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32-S64";
  5434. }
  5435. public:
  5436. Mips32EBTargetInfo(const llvm::Triple &Triple)
  5437. : Mips32TargetInfoBase(Triple) {
  5438. }
  5439. void getTargetDefines(const LangOptions &Opts,
  5440. MacroBuilder &Builder) const override {
  5441. DefineStd(Builder, "MIPSEB", Opts);
  5442. Builder.defineMacro("_MIPSEB");
  5443. Mips32TargetInfoBase::getTargetDefines(Opts, Builder);
  5444. }
  5445. };
  5446. class Mips32ELTargetInfo : public Mips32TargetInfoBase {
  5447. void setDescriptionString() override {
  5448. DescriptionString = "e-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32-S64";
  5449. }
  5450. public:
  5451. Mips32ELTargetInfo(const llvm::Triple &Triple)
  5452. : Mips32TargetInfoBase(Triple) {
  5453. BigEndian = false;
  5454. }
  5455. void getTargetDefines(const LangOptions &Opts,
  5456. MacroBuilder &Builder) const override {
  5457. DefineStd(Builder, "MIPSEL", Opts);
  5458. Builder.defineMacro("_MIPSEL");
  5459. Mips32TargetInfoBase::getTargetDefines(Opts, Builder);
  5460. }
  5461. };
  5462. class Mips64TargetInfoBase : public MipsTargetInfoBase {
  5463. public:
  5464. Mips64TargetInfoBase(const llvm::Triple &Triple)
  5465. : MipsTargetInfoBase(Triple, "n64", "mips64r2") {
  5466. LongDoubleWidth = LongDoubleAlign = 128;
  5467. LongDoubleFormat = &llvm::APFloat::IEEEquad;
  5468. if (getTriple().getOS() == llvm::Triple::FreeBSD) {
  5469. LongDoubleWidth = LongDoubleAlign = 64;
  5470. LongDoubleFormat = &llvm::APFloat::IEEEdouble;
  5471. }
  5472. setN64ABITypes();
  5473. SuitableAlign = 128;
  5474. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
  5475. }
  5476. void setN64ABITypes() {
  5477. LongWidth = LongAlign = 64;
  5478. PointerWidth = PointerAlign = 64;
  5479. SizeType = UnsignedLong;
  5480. PtrDiffType = SignedLong;
  5481. Int64Type = SignedLong;
  5482. IntMaxType = Int64Type;
  5483. }
  5484. void setN32ABITypes() {
  5485. LongWidth = LongAlign = 32;
  5486. PointerWidth = PointerAlign = 32;
  5487. SizeType = UnsignedInt;
  5488. PtrDiffType = SignedInt;
  5489. Int64Type = SignedLongLong;
  5490. IntMaxType = Int64Type;
  5491. }
  5492. bool setABI(const std::string &Name) override {
  5493. if (Name == "n32") {
  5494. setN32ABITypes();
  5495. ABI = Name;
  5496. return true;
  5497. }
  5498. if (Name == "n64") {
  5499. setN64ABITypes();
  5500. ABI = Name;
  5501. return true;
  5502. }
  5503. return false;
  5504. }
  5505. void getTargetDefines(const LangOptions &Opts,
  5506. MacroBuilder &Builder) const override {
  5507. MipsTargetInfoBase::getTargetDefines(Opts, Builder);
  5508. Builder.defineMacro("__mips", "64");
  5509. Builder.defineMacro("__mips64");
  5510. Builder.defineMacro("__mips64__");
  5511. Builder.defineMacro("_MIPS_ISA", "_MIPS_ISA_MIPS64");
  5512. const std::string& CPUStr = getCPU();
  5513. if (CPUStr == "mips64")
  5514. Builder.defineMacro("__mips_isa_rev", "1");
  5515. else if (CPUStr == "mips64r2")
  5516. Builder.defineMacro("__mips_isa_rev", "2");
  5517. else if (CPUStr == "mips64r3")
  5518. Builder.defineMacro("__mips_isa_rev", "3");
  5519. else if (CPUStr == "mips64r5")
  5520. Builder.defineMacro("__mips_isa_rev", "5");
  5521. else if (CPUStr == "mips64r6")
  5522. Builder.defineMacro("__mips_isa_rev", "6");
  5523. if (ABI == "n32") {
  5524. Builder.defineMacro("__mips_n32");
  5525. Builder.defineMacro("_ABIN32", "2");
  5526. Builder.defineMacro("_MIPS_SIM", "_ABIN32");
  5527. }
  5528. else if (ABI == "n64") {
  5529. Builder.defineMacro("__mips_n64");
  5530. Builder.defineMacro("_ABI64", "3");
  5531. Builder.defineMacro("_MIPS_SIM", "_ABI64");
  5532. }
  5533. else
  5534. llvm_unreachable("Invalid ABI for Mips64.");
  5535. }
  5536. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5537. unsigned &NumAliases) const override {
  5538. static const TargetInfo::GCCRegAlias GCCRegAliases[] = {
  5539. { { "at" }, "$1" },
  5540. { { "v0" }, "$2" },
  5541. { { "v1" }, "$3" },
  5542. { { "a0" }, "$4" },
  5543. { { "a1" }, "$5" },
  5544. { { "a2" }, "$6" },
  5545. { { "a3" }, "$7" },
  5546. { { "a4" }, "$8" },
  5547. { { "a5" }, "$9" },
  5548. { { "a6" }, "$10" },
  5549. { { "a7" }, "$11" },
  5550. { { "t0" }, "$12" },
  5551. { { "t1" }, "$13" },
  5552. { { "t2" }, "$14" },
  5553. { { "t3" }, "$15" },
  5554. { { "s0" }, "$16" },
  5555. { { "s1" }, "$17" },
  5556. { { "s2" }, "$18" },
  5557. { { "s3" }, "$19" },
  5558. { { "s4" }, "$20" },
  5559. { { "s5" }, "$21" },
  5560. { { "s6" }, "$22" },
  5561. { { "s7" }, "$23" },
  5562. { { "t8" }, "$24" },
  5563. { { "t9" }, "$25" },
  5564. { { "k0" }, "$26" },
  5565. { { "k1" }, "$27" },
  5566. { { "gp" }, "$28" },
  5567. { { "sp","$sp" }, "$29" },
  5568. { { "fp","$fp" }, "$30" },
  5569. { { "ra" }, "$31" }
  5570. };
  5571. Aliases = GCCRegAliases;
  5572. NumAliases = llvm::array_lengthof(GCCRegAliases);
  5573. }
  5574. bool hasInt128Type() const override { return true; }
  5575. };
  5576. class Mips64EBTargetInfo : public Mips64TargetInfoBase {
  5577. void setDescriptionString() override {
  5578. if (ABI == "n32")
  5579. DescriptionString = "E-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32:64-S128";
  5580. else
  5581. DescriptionString = "E-m:m-i8:8:32-i16:16:32-i64:64-n32:64-S128";
  5582. }
  5583. public:
  5584. Mips64EBTargetInfo(const llvm::Triple &Triple)
  5585. : Mips64TargetInfoBase(Triple) {}
  5586. void getTargetDefines(const LangOptions &Opts,
  5587. MacroBuilder &Builder) const override {
  5588. DefineStd(Builder, "MIPSEB", Opts);
  5589. Builder.defineMacro("_MIPSEB");
  5590. Mips64TargetInfoBase::getTargetDefines(Opts, Builder);
  5591. }
  5592. };
  5593. class Mips64ELTargetInfo : public Mips64TargetInfoBase {
  5594. void setDescriptionString() override {
  5595. if (ABI == "n32")
  5596. DescriptionString = "e-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32:64-S128";
  5597. else
  5598. DescriptionString = "e-m:m-i8:8:32-i16:16:32-i64:64-n32:64-S128";
  5599. }
  5600. public:
  5601. Mips64ELTargetInfo(const llvm::Triple &Triple)
  5602. : Mips64TargetInfoBase(Triple) {
  5603. // Default ABI is n64.
  5604. BigEndian = false;
  5605. }
  5606. void getTargetDefines(const LangOptions &Opts,
  5607. MacroBuilder &Builder) const override {
  5608. DefineStd(Builder, "MIPSEL", Opts);
  5609. Builder.defineMacro("_MIPSEL");
  5610. Mips64TargetInfoBase::getTargetDefines(Opts, Builder);
  5611. }
  5612. };
  5613. } // end anonymous namespace.
  5614. namespace {
  5615. class PNaClTargetInfo : public TargetInfo {
  5616. public:
  5617. PNaClTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  5618. BigEndian = false;
  5619. this->UserLabelPrefix = "";
  5620. this->LongAlign = 32;
  5621. this->LongWidth = 32;
  5622. this->PointerAlign = 32;
  5623. this->PointerWidth = 32;
  5624. this->IntMaxType = TargetInfo::SignedLongLong;
  5625. this->Int64Type = TargetInfo::SignedLongLong;
  5626. this->DoubleAlign = 64;
  5627. this->LongDoubleWidth = 64;
  5628. this->LongDoubleAlign = 64;
  5629. this->SizeType = TargetInfo::UnsignedInt;
  5630. this->PtrDiffType = TargetInfo::SignedInt;
  5631. this->IntPtrType = TargetInfo::SignedInt;
  5632. this->RegParmMax = 0; // Disallow regparm
  5633. }
  5634. void getDefaultFeatures(llvm::StringMap<bool> &Features) const override {
  5635. }
  5636. void getArchDefines(const LangOptions &Opts, MacroBuilder &Builder) const {
  5637. Builder.defineMacro("__le32__");
  5638. Builder.defineMacro("__pnacl__");
  5639. }
  5640. void getTargetDefines(const LangOptions &Opts,
  5641. MacroBuilder &Builder) const override {
  5642. getArchDefines(Opts, Builder);
  5643. }
  5644. bool hasFeature(StringRef Feature) const override {
  5645. return Feature == "pnacl";
  5646. }
  5647. void getTargetBuiltins(const Builtin::Info *&Records,
  5648. unsigned &NumRecords) const override {
  5649. }
  5650. BuiltinVaListKind getBuiltinVaListKind() const override {
  5651. return TargetInfo::PNaClABIBuiltinVaList;
  5652. }
  5653. void getGCCRegNames(const char * const *&Names,
  5654. unsigned &NumNames) const override;
  5655. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5656. unsigned &NumAliases) const override;
  5657. bool validateAsmConstraint(const char *&Name,
  5658. TargetInfo::ConstraintInfo &Info) const override {
  5659. return false;
  5660. }
  5661. const char *getClobbers() const override {
  5662. return "";
  5663. }
  5664. };
  5665. void PNaClTargetInfo::getGCCRegNames(const char * const *&Names,
  5666. unsigned &NumNames) const {
  5667. Names = nullptr;
  5668. NumNames = 0;
  5669. }
  5670. void PNaClTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
  5671. unsigned &NumAliases) const {
  5672. Aliases = nullptr;
  5673. NumAliases = 0;
  5674. }
  5675. } // end anonymous namespace.
  5676. namespace {
  5677. class Le64TargetInfo : public TargetInfo {
  5678. static const Builtin::Info BuiltinInfo[];
  5679. public:
  5680. Le64TargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  5681. BigEndian = false;
  5682. NoAsmVariants = true;
  5683. LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
  5684. MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
  5685. DescriptionString =
  5686. "e-m:e-v128:32-v16:16-v32:32-v96:32-n8:16:32:64-S128";
  5687. }
  5688. void getTargetDefines(const LangOptions &Opts,
  5689. MacroBuilder &Builder) const override {
  5690. DefineStd(Builder, "unix", Opts);
  5691. defineCPUMacros(Builder, "le64", /*Tuning=*/false);
  5692. Builder.defineMacro("__ELF__");
  5693. }
  5694. void getTargetBuiltins(const Builtin::Info *&Records,
  5695. unsigned &NumRecords) const override {
  5696. Records = BuiltinInfo;
  5697. NumRecords = clang::Le64::LastTSBuiltin - Builtin::FirstTSBuiltin;
  5698. }
  5699. BuiltinVaListKind getBuiltinVaListKind() const override {
  5700. return TargetInfo::PNaClABIBuiltinVaList;
  5701. }
  5702. const char *getClobbers() const override { return ""; }
  5703. void getGCCRegNames(const char *const *&Names,
  5704. unsigned &NumNames) const override {
  5705. Names = nullptr;
  5706. NumNames = 0;
  5707. }
  5708. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5709. unsigned &NumAliases) const override {
  5710. Aliases = nullptr;
  5711. NumAliases = 0;
  5712. }
  5713. bool validateAsmConstraint(const char *&Name,
  5714. TargetInfo::ConstraintInfo &Info) const override {
  5715. return false;
  5716. }
  5717. bool hasProtectedVisibility() const override { return false; }
  5718. };
  5719. } // end anonymous namespace.
  5720. const Builtin::Info Le64TargetInfo::BuiltinInfo[] = {
  5721. #define BUILTIN(ID, TYPE, ATTRS) \
  5722. { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  5723. #include "clang/Basic/BuiltinsLe64.def"
  5724. };
  5725. namespace {
  5726. static const unsigned SPIRAddrSpaceMap[] = {
  5727. 1, // opencl_global
  5728. 3, // opencl_local
  5729. 2, // opencl_constant
  5730. 4, // opencl_generic
  5731. 0, // cuda_device
  5732. 0, // cuda_constant
  5733. 0 // cuda_shared
  5734. };
  5735. class SPIRTargetInfo : public TargetInfo {
  5736. public:
  5737. SPIRTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  5738. assert(getTriple().getOS() == llvm::Triple::UnknownOS &&
  5739. "SPIR target must use unknown OS");
  5740. assert(getTriple().getEnvironment() == llvm::Triple::UnknownEnvironment &&
  5741. "SPIR target must use unknown environment type");
  5742. BigEndian = false;
  5743. TLSSupported = false;
  5744. LongWidth = LongAlign = 64;
  5745. AddrSpaceMap = &SPIRAddrSpaceMap;
  5746. UseAddrSpaceMapMangling = true;
  5747. // Define available target features
  5748. // These must be defined in sorted order!
  5749. NoAsmVariants = true;
  5750. }
  5751. void getTargetDefines(const LangOptions &Opts,
  5752. MacroBuilder &Builder) const override {
  5753. DefineStd(Builder, "SPIR", Opts);
  5754. }
  5755. bool hasFeature(StringRef Feature) const override {
  5756. return Feature == "spir";
  5757. }
  5758. void getTargetBuiltins(const Builtin::Info *&Records,
  5759. unsigned &NumRecords) const override {}
  5760. const char *getClobbers() const override {
  5761. return "";
  5762. }
  5763. void getGCCRegNames(const char * const *&Names,
  5764. unsigned &NumNames) const override {}
  5765. bool
  5766. validateAsmConstraint(const char *&Name,
  5767. TargetInfo::ConstraintInfo &info) const override {
  5768. return true;
  5769. }
  5770. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5771. unsigned &NumAliases) const override {}
  5772. BuiltinVaListKind getBuiltinVaListKind() const override {
  5773. return TargetInfo::VoidPtrBuiltinVaList;
  5774. }
  5775. CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
  5776. return (CC == CC_SpirFunction ||
  5777. CC == CC_SpirKernel) ? CCCR_OK : CCCR_Warning;
  5778. }
  5779. CallingConv getDefaultCallingConv(CallingConvMethodType MT) const override {
  5780. return CC_SpirFunction;
  5781. }
  5782. };
  5783. class SPIR32TargetInfo : public SPIRTargetInfo {
  5784. public:
  5785. SPIR32TargetInfo(const llvm::Triple &Triple) : SPIRTargetInfo(Triple) {
  5786. PointerWidth = PointerAlign = 32;
  5787. SizeType = TargetInfo::UnsignedInt;
  5788. PtrDiffType = IntPtrType = TargetInfo::SignedInt;
  5789. DescriptionString
  5790. = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-"
  5791. "v96:128-v192:256-v256:256-v512:512-v1024:1024";
  5792. }
  5793. void getTargetDefines(const LangOptions &Opts,
  5794. MacroBuilder &Builder) const override {
  5795. DefineStd(Builder, "SPIR32", Opts);
  5796. }
  5797. };
  5798. class SPIR64TargetInfo : public SPIRTargetInfo {
  5799. public:
  5800. SPIR64TargetInfo(const llvm::Triple &Triple) : SPIRTargetInfo(Triple) {
  5801. PointerWidth = PointerAlign = 64;
  5802. SizeType = TargetInfo::UnsignedLong;
  5803. PtrDiffType = IntPtrType = TargetInfo::SignedLong;
  5804. DescriptionString = "e-i64:64-v16:16-v24:32-v32:32-v48:64-"
  5805. "v96:128-v192:256-v256:256-v512:512-v1024:1024";
  5806. }
  5807. void getTargetDefines(const LangOptions &Opts,
  5808. MacroBuilder &Builder) const override {
  5809. DefineStd(Builder, "SPIR64", Opts);
  5810. }
  5811. };
  5812. }
  5813. namespace {
  5814. class XCoreTargetInfo : public TargetInfo {
  5815. static const Builtin::Info BuiltinInfo[];
  5816. public:
  5817. XCoreTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
  5818. BigEndian = false;
  5819. NoAsmVariants = true;
  5820. LongLongAlign = 32;
  5821. SuitableAlign = 32;
  5822. DoubleAlign = LongDoubleAlign = 32;
  5823. SizeType = UnsignedInt;
  5824. PtrDiffType = SignedInt;
  5825. IntPtrType = SignedInt;
  5826. WCharType = UnsignedChar;
  5827. WIntType = UnsignedInt;
  5828. UseZeroLengthBitfieldAlignment = true;
  5829. DescriptionString = "e-m:e-p:32:32-i1:8:32-i8:8:32-i16:16:32-i64:32"
  5830. "-f64:32-a:0:32-n32";
  5831. }
  5832. void getTargetDefines(const LangOptions &Opts,
  5833. MacroBuilder &Builder) const override {
  5834. Builder.defineMacro("__XS1B__");
  5835. }
  5836. void getTargetBuiltins(const Builtin::Info *&Records,
  5837. unsigned &NumRecords) const override {
  5838. Records = BuiltinInfo;
  5839. NumRecords = clang::XCore::LastTSBuiltin-Builtin::FirstTSBuiltin;
  5840. }
  5841. BuiltinVaListKind getBuiltinVaListKind() const override {
  5842. return TargetInfo::VoidPtrBuiltinVaList;
  5843. }
  5844. const char *getClobbers() const override {
  5845. return "";
  5846. }
  5847. void getGCCRegNames(const char * const *&Names,
  5848. unsigned &NumNames) const override {
  5849. static const char * const GCCRegNames[] = {
  5850. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  5851. "r8", "r9", "r10", "r11", "cp", "dp", "sp", "lr"
  5852. };
  5853. Names = GCCRegNames;
  5854. NumNames = llvm::array_lengthof(GCCRegNames);
  5855. }
  5856. void getGCCRegAliases(const GCCRegAlias *&Aliases,
  5857. unsigned &NumAliases) const override {
  5858. Aliases = nullptr;
  5859. NumAliases = 0;
  5860. }
  5861. bool validateAsmConstraint(const char *&Name,
  5862. TargetInfo::ConstraintInfo &Info) const override {
  5863. return false;
  5864. }
  5865. int getEHDataRegisterNumber(unsigned RegNo) const override {
  5866. // R0=ExceptionPointerRegister R1=ExceptionSelectorRegister
  5867. return (RegNo < 2)? RegNo : -1;
  5868. }
  5869. };
  5870. const Builtin::Info XCoreTargetInfo::BuiltinInfo[] = {
  5871. #define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
  5872. #define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
  5873. ALL_LANGUAGES },
  5874. #include "clang/Basic/BuiltinsXCore.def"
  5875. };
  5876. } // end anonymous namespace.
  5877. //===----------------------------------------------------------------------===//
  5878. // Driver code
  5879. //===----------------------------------------------------------------------===//
  5880. static TargetInfo *AllocateTarget(const llvm::Triple &Triple) {
  5881. llvm::Triple::OSType os = Triple.getOS();
  5882. switch (Triple.getArch()) {
  5883. default:
  5884. return nullptr;
  5885. case llvm::Triple::xcore:
  5886. return new XCoreTargetInfo(Triple);
  5887. case llvm::Triple::hexagon:
  5888. return new HexagonTargetInfo(Triple);
  5889. case llvm::Triple::aarch64:
  5890. if (Triple.isOSDarwin())
  5891. return new DarwinAArch64TargetInfo(Triple);
  5892. switch (os) {
  5893. case llvm::Triple::FreeBSD:
  5894. return new FreeBSDTargetInfo<AArch64leTargetInfo>(Triple);
  5895. case llvm::Triple::Linux:
  5896. return new LinuxTargetInfo<AArch64leTargetInfo>(Triple);
  5897. case llvm::Triple::NetBSD:
  5898. return new NetBSDTargetInfo<AArch64leTargetInfo>(Triple);
  5899. default:
  5900. return new AArch64leTargetInfo(Triple);
  5901. }
  5902. case llvm::Triple::aarch64_be:
  5903. switch (os) {
  5904. case llvm::Triple::FreeBSD:
  5905. return new FreeBSDTargetInfo<AArch64beTargetInfo>(Triple);
  5906. case llvm::Triple::Linux:
  5907. return new LinuxTargetInfo<AArch64beTargetInfo>(Triple);
  5908. case llvm::Triple::NetBSD:
  5909. return new NetBSDTargetInfo<AArch64beTargetInfo>(Triple);
  5910. default:
  5911. return new AArch64beTargetInfo(Triple);
  5912. }
  5913. case llvm::Triple::arm:
  5914. case llvm::Triple::thumb:
  5915. if (Triple.isOSBinFormatMachO())
  5916. return new DarwinARMTargetInfo(Triple);
  5917. switch (os) {
  5918. case llvm::Triple::Linux:
  5919. return new LinuxTargetInfo<ARMleTargetInfo>(Triple);
  5920. case llvm::Triple::FreeBSD:
  5921. return new FreeBSDTargetInfo<ARMleTargetInfo>(Triple);
  5922. case llvm::Triple::NetBSD:
  5923. return new NetBSDTargetInfo<ARMleTargetInfo>(Triple);
  5924. case llvm::Triple::OpenBSD:
  5925. return new OpenBSDTargetInfo<ARMleTargetInfo>(Triple);
  5926. case llvm::Triple::Bitrig:
  5927. return new BitrigTargetInfo<ARMleTargetInfo>(Triple);
  5928. case llvm::Triple::RTEMS:
  5929. return new RTEMSTargetInfo<ARMleTargetInfo>(Triple);
  5930. case llvm::Triple::NaCl:
  5931. return new NaClTargetInfo<ARMleTargetInfo>(Triple);
  5932. case llvm::Triple::Win32:
  5933. switch (Triple.getEnvironment()) {
  5934. default:
  5935. return new ARMleTargetInfo(Triple);
  5936. case llvm::Triple::Itanium:
  5937. return new ItaniumWindowsARMleTargetInfo(Triple);
  5938. case llvm::Triple::MSVC:
  5939. return new MicrosoftARMleTargetInfo(Triple);
  5940. }
  5941. default:
  5942. return new ARMleTargetInfo(Triple);
  5943. }
  5944. case llvm::Triple::armeb:
  5945. case llvm::Triple::thumbeb:
  5946. if (Triple.isOSDarwin())
  5947. return new DarwinARMTargetInfo(Triple);
  5948. switch (os) {
  5949. case llvm::Triple::Linux:
  5950. return new LinuxTargetInfo<ARMbeTargetInfo>(Triple);
  5951. case llvm::Triple::FreeBSD:
  5952. return new FreeBSDTargetInfo<ARMbeTargetInfo>(Triple);
  5953. case llvm::Triple::NetBSD:
  5954. return new NetBSDTargetInfo<ARMbeTargetInfo>(Triple);
  5955. case llvm::Triple::OpenBSD:
  5956. return new OpenBSDTargetInfo<ARMbeTargetInfo>(Triple);
  5957. case llvm::Triple::Bitrig:
  5958. return new BitrigTargetInfo<ARMbeTargetInfo>(Triple);
  5959. case llvm::Triple::RTEMS:
  5960. return new RTEMSTargetInfo<ARMbeTargetInfo>(Triple);
  5961. case llvm::Triple::NaCl:
  5962. return new NaClTargetInfo<ARMbeTargetInfo>(Triple);
  5963. default:
  5964. return new ARMbeTargetInfo(Triple);
  5965. }
  5966. case llvm::Triple::msp430:
  5967. return new MSP430TargetInfo(Triple);
  5968. case llvm::Triple::mips:
  5969. switch (os) {
  5970. case llvm::Triple::Linux:
  5971. return new LinuxTargetInfo<Mips32EBTargetInfo>(Triple);
  5972. case llvm::Triple::RTEMS:
  5973. return new RTEMSTargetInfo<Mips32EBTargetInfo>(Triple);
  5974. case llvm::Triple::FreeBSD:
  5975. return new FreeBSDTargetInfo<Mips32EBTargetInfo>(Triple);
  5976. case llvm::Triple::NetBSD:
  5977. return new NetBSDTargetInfo<Mips32EBTargetInfo>(Triple);
  5978. default:
  5979. return new Mips32EBTargetInfo(Triple);
  5980. }
  5981. case llvm::Triple::mipsel:
  5982. switch (os) {
  5983. case llvm::Triple::Linux:
  5984. return new LinuxTargetInfo<Mips32ELTargetInfo>(Triple);
  5985. case llvm::Triple::RTEMS:
  5986. return new RTEMSTargetInfo<Mips32ELTargetInfo>(Triple);
  5987. case llvm::Triple::FreeBSD:
  5988. return new FreeBSDTargetInfo<Mips32ELTargetInfo>(Triple);
  5989. case llvm::Triple::NetBSD:
  5990. return new NetBSDTargetInfo<Mips32ELTargetInfo>(Triple);
  5991. case llvm::Triple::NaCl:
  5992. return new NaClTargetInfo<Mips32ELTargetInfo>(Triple);
  5993. default:
  5994. return new Mips32ELTargetInfo(Triple);
  5995. }
  5996. case llvm::Triple::mips64:
  5997. switch (os) {
  5998. case llvm::Triple::Linux:
  5999. return new LinuxTargetInfo<Mips64EBTargetInfo>(Triple);
  6000. case llvm::Triple::RTEMS:
  6001. return new RTEMSTargetInfo<Mips64EBTargetInfo>(Triple);
  6002. case llvm::Triple::FreeBSD:
  6003. return new FreeBSDTargetInfo<Mips64EBTargetInfo>(Triple);
  6004. case llvm::Triple::NetBSD:
  6005. return new NetBSDTargetInfo<Mips64EBTargetInfo>(Triple);
  6006. case llvm::Triple::OpenBSD:
  6007. return new OpenBSDTargetInfo<Mips64EBTargetInfo>(Triple);
  6008. default:
  6009. return new Mips64EBTargetInfo(Triple);
  6010. }
  6011. case llvm::Triple::mips64el:
  6012. switch (os) {
  6013. case llvm::Triple::Linux:
  6014. return new LinuxTargetInfo<Mips64ELTargetInfo>(Triple);
  6015. case llvm::Triple::RTEMS:
  6016. return new RTEMSTargetInfo<Mips64ELTargetInfo>(Triple);
  6017. case llvm::Triple::FreeBSD:
  6018. return new FreeBSDTargetInfo<Mips64ELTargetInfo>(Triple);
  6019. case llvm::Triple::NetBSD:
  6020. return new NetBSDTargetInfo<Mips64ELTargetInfo>(Triple);
  6021. case llvm::Triple::OpenBSD:
  6022. return new OpenBSDTargetInfo<Mips64ELTargetInfo>(Triple);
  6023. default:
  6024. return new Mips64ELTargetInfo(Triple);
  6025. }
  6026. case llvm::Triple::le32:
  6027. switch (os) {
  6028. case llvm::Triple::NaCl:
  6029. return new NaClTargetInfo<PNaClTargetInfo>(Triple);
  6030. default:
  6031. return nullptr;
  6032. }
  6033. case llvm::Triple::le64:
  6034. return new Le64TargetInfo(Triple);
  6035. case llvm::Triple::ppc:
  6036. if (Triple.isOSDarwin())
  6037. return new DarwinPPC32TargetInfo(Triple);
  6038. switch (os) {
  6039. case llvm::Triple::Linux:
  6040. return new LinuxTargetInfo<PPC32TargetInfo>(Triple);
  6041. case llvm::Triple::FreeBSD:
  6042. return new FreeBSDTargetInfo<PPC32TargetInfo>(Triple);
  6043. case llvm::Triple::NetBSD:
  6044. return new NetBSDTargetInfo<PPC32TargetInfo>(Triple);
  6045. case llvm::Triple::OpenBSD:
  6046. return new OpenBSDTargetInfo<PPC32TargetInfo>(Triple);
  6047. case llvm::Triple::RTEMS:
  6048. return new RTEMSTargetInfo<PPC32TargetInfo>(Triple);
  6049. default:
  6050. return new PPC32TargetInfo(Triple);
  6051. }
  6052. case llvm::Triple::ppc64:
  6053. if (Triple.isOSDarwin())
  6054. return new DarwinPPC64TargetInfo(Triple);
  6055. switch (os) {
  6056. case llvm::Triple::Linux:
  6057. return new LinuxTargetInfo<PPC64TargetInfo>(Triple);
  6058. case llvm::Triple::Lv2:
  6059. return new PS3PPUTargetInfo<PPC64TargetInfo>(Triple);
  6060. case llvm::Triple::FreeBSD:
  6061. return new FreeBSDTargetInfo<PPC64TargetInfo>(Triple);
  6062. case llvm::Triple::NetBSD:
  6063. return new NetBSDTargetInfo<PPC64TargetInfo>(Triple);
  6064. default:
  6065. return new PPC64TargetInfo(Triple);
  6066. }
  6067. case llvm::Triple::ppc64le:
  6068. switch (os) {
  6069. case llvm::Triple::Linux:
  6070. return new LinuxTargetInfo<PPC64TargetInfo>(Triple);
  6071. default:
  6072. return new PPC64TargetInfo(Triple);
  6073. }
  6074. case llvm::Triple::nvptx:
  6075. return new NVPTX32TargetInfo(Triple);
  6076. case llvm::Triple::nvptx64:
  6077. return new NVPTX64TargetInfo(Triple);
  6078. case llvm::Triple::amdgcn:
  6079. case llvm::Triple::r600:
  6080. return new R600TargetInfo(Triple);
  6081. case llvm::Triple::sparc:
  6082. switch (os) {
  6083. case llvm::Triple::Linux:
  6084. return new LinuxTargetInfo<SparcV8TargetInfo>(Triple);
  6085. case llvm::Triple::Solaris:
  6086. return new SolarisSparcV8TargetInfo(Triple);
  6087. case llvm::Triple::NetBSD:
  6088. return new NetBSDTargetInfo<SparcV8TargetInfo>(Triple);
  6089. case llvm::Triple::OpenBSD:
  6090. return new OpenBSDTargetInfo<SparcV8TargetInfo>(Triple);
  6091. case llvm::Triple::RTEMS:
  6092. return new RTEMSTargetInfo<SparcV8TargetInfo>(Triple);
  6093. default:
  6094. return new SparcV8TargetInfo(Triple);
  6095. }
  6096. case llvm::Triple::sparcv9:
  6097. switch (os) {
  6098. case llvm::Triple::Linux:
  6099. return new LinuxTargetInfo<SparcV9TargetInfo>(Triple);
  6100. case llvm::Triple::Solaris:
  6101. return new SolarisTargetInfo<SparcV9TargetInfo>(Triple);
  6102. case llvm::Triple::NetBSD:
  6103. return new NetBSDTargetInfo<SparcV9TargetInfo>(Triple);
  6104. case llvm::Triple::OpenBSD:
  6105. return new OpenBSDTargetInfo<SparcV9TargetInfo>(Triple);
  6106. case llvm::Triple::FreeBSD:
  6107. return new FreeBSDTargetInfo<SparcV9TargetInfo>(Triple);
  6108. default:
  6109. return new SparcV9TargetInfo(Triple);
  6110. }
  6111. case llvm::Triple::systemz:
  6112. switch (os) {
  6113. case llvm::Triple::Linux:
  6114. return new LinuxTargetInfo<SystemZTargetInfo>(Triple);
  6115. default:
  6116. return new SystemZTargetInfo(Triple);
  6117. }
  6118. case llvm::Triple::tce:
  6119. return new TCETargetInfo(Triple);
  6120. case llvm::Triple::x86:
  6121. if (Triple.isOSDarwin())
  6122. return new DarwinI386TargetInfo(Triple);
  6123. switch (os) {
  6124. case llvm::Triple::Linux:
  6125. return new LinuxTargetInfo<X86_32TargetInfo>(Triple);
  6126. case llvm::Triple::DragonFly:
  6127. return new DragonFlyBSDTargetInfo<X86_32TargetInfo>(Triple);
  6128. case llvm::Triple::NetBSD:
  6129. return new NetBSDI386TargetInfo(Triple);
  6130. case llvm::Triple::OpenBSD:
  6131. return new OpenBSDI386TargetInfo(Triple);
  6132. case llvm::Triple::Bitrig:
  6133. return new BitrigI386TargetInfo(Triple);
  6134. case llvm::Triple::FreeBSD:
  6135. return new FreeBSDTargetInfo<X86_32TargetInfo>(Triple);
  6136. case llvm::Triple::KFreeBSD:
  6137. return new KFreeBSDTargetInfo<X86_32TargetInfo>(Triple);
  6138. case llvm::Triple::Minix:
  6139. return new MinixTargetInfo<X86_32TargetInfo>(Triple);
  6140. case llvm::Triple::Solaris:
  6141. return new SolarisTargetInfo<X86_32TargetInfo>(Triple);
  6142. case llvm::Triple::Win32: {
  6143. switch (Triple.getEnvironment()) {
  6144. default:
  6145. return new X86_32TargetInfo(Triple);
  6146. case llvm::Triple::Cygnus:
  6147. return new CygwinX86_32TargetInfo(Triple);
  6148. case llvm::Triple::GNU:
  6149. return new MinGWX86_32TargetInfo(Triple);
  6150. case llvm::Triple::Itanium:
  6151. case llvm::Triple::MSVC:
  6152. return new MicrosoftX86_32TargetInfo(Triple);
  6153. }
  6154. }
  6155. case llvm::Triple::Haiku:
  6156. return new HaikuX86_32TargetInfo(Triple);
  6157. case llvm::Triple::RTEMS:
  6158. return new RTEMSX86_32TargetInfo(Triple);
  6159. case llvm::Triple::NaCl:
  6160. return new NaClTargetInfo<X86_32TargetInfo>(Triple);
  6161. default:
  6162. return new X86_32TargetInfo(Triple);
  6163. }
  6164. case llvm::Triple::x86_64:
  6165. if (Triple.isOSDarwin() || Triple.isOSBinFormatMachO())
  6166. return new DarwinX86_64TargetInfo(Triple);
  6167. switch (os) {
  6168. case llvm::Triple::Linux:
  6169. return new LinuxTargetInfo<X86_64TargetInfo>(Triple);
  6170. case llvm::Triple::DragonFly:
  6171. return new DragonFlyBSDTargetInfo<X86_64TargetInfo>(Triple);
  6172. case llvm::Triple::NetBSD:
  6173. return new NetBSDTargetInfo<X86_64TargetInfo>(Triple);
  6174. case llvm::Triple::OpenBSD:
  6175. return new OpenBSDX86_64TargetInfo(Triple);
  6176. case llvm::Triple::Bitrig:
  6177. return new BitrigX86_64TargetInfo(Triple);
  6178. case llvm::Triple::FreeBSD:
  6179. return new FreeBSDTargetInfo<X86_64TargetInfo>(Triple);
  6180. case llvm::Triple::KFreeBSD:
  6181. return new KFreeBSDTargetInfo<X86_64TargetInfo>(Triple);
  6182. case llvm::Triple::Solaris:
  6183. return new SolarisTargetInfo<X86_64TargetInfo>(Triple);
  6184. case llvm::Triple::Win32: {
  6185. switch (Triple.getEnvironment()) {
  6186. default:
  6187. return new X86_64TargetInfo(Triple);
  6188. case llvm::Triple::GNU:
  6189. return new MinGWX86_64TargetInfo(Triple);
  6190. case llvm::Triple::MSVC:
  6191. return new MicrosoftX86_64TargetInfo(Triple);
  6192. }
  6193. }
  6194. case llvm::Triple::NaCl:
  6195. return new NaClTargetInfo<X86_64TargetInfo>(Triple);
  6196. case llvm::Triple::PS4:
  6197. return new PS4OSTargetInfo<X86_64TargetInfo>(Triple);
  6198. default:
  6199. return new X86_64TargetInfo(Triple);
  6200. }
  6201. case llvm::Triple::spir: {
  6202. if (Triple.getOS() != llvm::Triple::UnknownOS ||
  6203. Triple.getEnvironment() != llvm::Triple::UnknownEnvironment)
  6204. return nullptr;
  6205. return new SPIR32TargetInfo(Triple);
  6206. }
  6207. case llvm::Triple::spir64: {
  6208. if (Triple.getOS() != llvm::Triple::UnknownOS ||
  6209. Triple.getEnvironment() != llvm::Triple::UnknownEnvironment)
  6210. return nullptr;
  6211. return new SPIR64TargetInfo(Triple);
  6212. }
  6213. }
  6214. }
  6215. /// CreateTargetInfo - Return the target info object for the specified target
  6216. /// triple.
  6217. TargetInfo *
  6218. TargetInfo::CreateTargetInfo(DiagnosticsEngine &Diags,
  6219. const std::shared_ptr<TargetOptions> &Opts) {
  6220. llvm::Triple Triple(Opts->Triple);
  6221. // Construct the target
  6222. std::unique_ptr<TargetInfo> Target(AllocateTarget(Triple));
  6223. if (!Target) {
  6224. Diags.Report(diag::err_target_unknown_triple) << Triple.str();
  6225. return nullptr;
  6226. }
  6227. Target->TargetOpts = Opts;
  6228. // Set the target CPU if specified.
  6229. if (!Opts->CPU.empty() && !Target->setCPU(Opts->CPU)) {
  6230. Diags.Report(diag::err_target_unknown_cpu) << Opts->CPU;
  6231. return nullptr;
  6232. }
  6233. // Set the target ABI if specified.
  6234. if (!Opts->ABI.empty() && !Target->setABI(Opts->ABI)) {
  6235. Diags.Report(diag::err_target_unknown_abi) << Opts->ABI;
  6236. return nullptr;
  6237. }
  6238. // Set the fp math unit.
  6239. if (!Opts->FPMath.empty() && !Target->setFPMath(Opts->FPMath)) {
  6240. Diags.Report(diag::err_target_unknown_fpmath) << Opts->FPMath;
  6241. return nullptr;
  6242. }
  6243. // Compute the default target features, we need the target to handle this
  6244. // because features may have dependencies on one another.
  6245. llvm::StringMap<bool> Features;
  6246. Target->getDefaultFeatures(Features);
  6247. // Apply the user specified deltas.
  6248. for (unsigned I = 0, N = Opts->FeaturesAsWritten.size();
  6249. I < N; ++I) {
  6250. const char *Name = Opts->FeaturesAsWritten[I].c_str();
  6251. // Apply the feature via the target.
  6252. bool Enabled = Name[0] == '+';
  6253. Target->setFeatureEnabled(Features, Name + 1, Enabled);
  6254. }
  6255. // Add the features to the compile options.
  6256. //
  6257. // FIXME: If we are completely confident that we have the right set, we only
  6258. // need to pass the minuses.
  6259. Opts->Features.clear();
  6260. for (llvm::StringMap<bool>::const_iterator it = Features.begin(),
  6261. ie = Features.end(); it != ie; ++it)
  6262. Opts->Features.push_back((it->second ? "+" : "-") + it->first().str());
  6263. if (!Target->handleTargetFeatures(Opts->Features, Diags))
  6264. return nullptr;
  6265. return Target.release();
  6266. }