12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560 |
- //=-- SVEInstrFormats.td - AArch64 SVE Instruction classes -*- tablegen -*--=//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- //
- // AArch64 Scalable Vector Extension (SVE) Instruction Class Definitions.
- //
- //===----------------------------------------------------------------------===//
- def SDT_AArch64Setcc : SDTypeProfile<1, 4, [
- SDTCisVec<0>, SDTCisVec<1>, SDTCisVec<2>, SDTCisVec<3>,
- SDTCVecEltisVT<0, i1>, SDTCVecEltisVT<1, i1>, SDTCisSameAs<2, 3>,
- SDTCisVT<4, OtherVT>
- ]>;
- def AArch64setcc_z : SDNode<"AArch64ISD::SETCC_MERGE_ZERO", SDT_AArch64Setcc>;
- def SVEPatternOperand : AsmOperandClass {
- let Name = "SVEPattern";
- let ParserMethod = "tryParseSVEPattern";
- let PredicateMethod = "isSVEPattern";
- let RenderMethod = "addImmOperands";
- let DiagnosticType = "InvalidSVEPattern";
- }
- def sve_pred_enum : Operand<i32>, TImmLeaf<i32, [{
- return (((uint32_t)Imm) < 32);
- }]> {
- let PrintMethod = "printSVEPattern";
- let ParserMatchClass = SVEPatternOperand;
- }
- def SVEVecLenSpecifierOperand : AsmOperandClass {
- let Name = "SVEVecLenSpecifier";
- let ParserMethod = "tryParseSVEVecLenSpecifier";
- let PredicateMethod = "isSVEVecLenSpecifier";
- let RenderMethod = "addImmOperands";
- let DiagnosticType = "InvalidSVEVecLenSpecifier";
- }
- def sve_vec_len_specifier_enum : Operand<i32>, TImmLeaf<i32, [{
- return (((uint32_t)Imm) < 2);
- }]> {
- let PrintMethod = "printSVEVecLenSpecifier";
- let ParserMatchClass = SVEVecLenSpecifierOperand;
- }
- def SVEPrefetchOperand : AsmOperandClass {
- let Name = "SVEPrefetch";
- let ParserMethod = "tryParsePrefetch<true>";
- let PredicateMethod = "isPrefetch";
- let RenderMethod = "addPrefetchOperands";
- }
- def sve_prfop : Operand<i32>, TImmLeaf<i32, [{
- return (((uint32_t)Imm) <= 15);
- }]> {
- let PrintMethod = "printPrefetchOp<true>";
- let ParserMatchClass = SVEPrefetchOperand;
- }
- class SVELogicalImmOperand<int Width> : AsmOperandClass {
- let Name = "SVELogicalImm" # Width;
- let DiagnosticType = "LogicalSecondSource";
- let PredicateMethod = "isLogicalImm<int" # Width # "_t>";
- let RenderMethod = "addLogicalImmOperands<int" # Width # "_t>";
- }
- def sve_logical_imm8 : Operand<i64> {
- let ParserMatchClass = SVELogicalImmOperand<8>;
- let PrintMethod = "printLogicalImm<int8_t>";
- let MCOperandPredicate = [{
- if (!MCOp.isImm())
- return false;
- int64_t Val = AArch64_AM::decodeLogicalImmediate(MCOp.getImm(), 64);
- return AArch64_AM::isSVEMaskOfIdenticalElements<int8_t>(Val);
- }];
- }
- def sve_logical_imm16 : Operand<i64> {
- let ParserMatchClass = SVELogicalImmOperand<16>;
- let PrintMethod = "printLogicalImm<int16_t>";
- let MCOperandPredicate = [{
- if (!MCOp.isImm())
- return false;
- int64_t Val = AArch64_AM::decodeLogicalImmediate(MCOp.getImm(), 64);
- return AArch64_AM::isSVEMaskOfIdenticalElements<int16_t>(Val);
- }];
- }
- def sve_logical_imm32 : Operand<i64> {
- let ParserMatchClass = SVELogicalImmOperand<32>;
- let PrintMethod = "printLogicalImm<int32_t>";
- let MCOperandPredicate = [{
- if (!MCOp.isImm())
- return false;
- int64_t Val = AArch64_AM::decodeLogicalImmediate(MCOp.getImm(), 64);
- return AArch64_AM::isSVEMaskOfIdenticalElements<int32_t>(Val);
- }];
- }
- class SVEPreferredLogicalImmOperand<int Width> : AsmOperandClass {
- let Name = "SVEPreferredLogicalImm" # Width;
- let PredicateMethod = "isSVEPreferredLogicalImm<int" # Width # "_t>";
- let RenderMethod = "addLogicalImmOperands<int" # Width # "_t>";
- }
- def sve_preferred_logical_imm16 : Operand<i64> {
- let ParserMatchClass = SVEPreferredLogicalImmOperand<16>;
- let PrintMethod = "printSVELogicalImm<int16_t>";
- let MCOperandPredicate = [{
- if (!MCOp.isImm())
- return false;
- int64_t Val = AArch64_AM::decodeLogicalImmediate(MCOp.getImm(), 64);
- return AArch64_AM::isSVEMaskOfIdenticalElements<int16_t>(Val) &&
- AArch64_AM::isSVEMoveMaskPreferredLogicalImmediate(Val);
- }];
- }
- def sve_preferred_logical_imm32 : Operand<i64> {
- let ParserMatchClass = SVEPreferredLogicalImmOperand<32>;
- let PrintMethod = "printSVELogicalImm<int32_t>";
- let MCOperandPredicate = [{
- if (!MCOp.isImm())
- return false;
- int64_t Val = AArch64_AM::decodeLogicalImmediate(MCOp.getImm(), 64);
- return AArch64_AM::isSVEMaskOfIdenticalElements<int32_t>(Val) &&
- AArch64_AM::isSVEMoveMaskPreferredLogicalImmediate(Val);
- }];
- }
- def sve_preferred_logical_imm64 : Operand<i64> {
- let ParserMatchClass = SVEPreferredLogicalImmOperand<64>;
- let PrintMethod = "printSVELogicalImm<int64_t>";
- let MCOperandPredicate = [{
- if (!MCOp.isImm())
- return false;
- int64_t Val = AArch64_AM::decodeLogicalImmediate(MCOp.getImm(), 64);
- return AArch64_AM::isSVEMaskOfIdenticalElements<int64_t>(Val) &&
- AArch64_AM::isSVEMoveMaskPreferredLogicalImmediate(Val);
- }];
- }
- class SVELogicalImmNotOperand<int Width> : AsmOperandClass {
- let Name = "SVELogicalImm" # Width # "Not";
- let DiagnosticType = "LogicalSecondSource";
- let PredicateMethod = "isLogicalImm<int" # Width # "_t>";
- let RenderMethod = "addLogicalImmNotOperands<int" # Width # "_t>";
- }
- def sve_logical_imm8_not : Operand<i64> {
- let ParserMatchClass = SVELogicalImmNotOperand<8>;
- }
- def sve_logical_imm16_not : Operand<i64> {
- let ParserMatchClass = SVELogicalImmNotOperand<16>;
- }
- def sve_logical_imm32_not : Operand<i64> {
- let ParserMatchClass = SVELogicalImmNotOperand<32>;
- }
- class SVEShiftedImmOperand<int ElementWidth, string Infix, string Predicate>
- : AsmOperandClass {
- let Name = "SVE" # Infix # "Imm" # ElementWidth;
- let DiagnosticType = "Invalid" # Name;
- let RenderMethod = "addImmWithOptionalShiftOperands<8>";
- let ParserMethod = "tryParseImmWithOptionalShift";
- let PredicateMethod = Predicate;
- }
- def SVECpyImmOperand8 : SVEShiftedImmOperand<8, "Cpy", "isSVECpyImm<int8_t>">;
- def SVECpyImmOperand16 : SVEShiftedImmOperand<16, "Cpy", "isSVECpyImm<int16_t>">;
- def SVECpyImmOperand32 : SVEShiftedImmOperand<32, "Cpy", "isSVECpyImm<int32_t>">;
- def SVECpyImmOperand64 : SVEShiftedImmOperand<64, "Cpy", "isSVECpyImm<int64_t>">;
- def SVEAddSubImmOperand8 : SVEShiftedImmOperand<8, "AddSub", "isSVEAddSubImm<int8_t>">;
- def SVEAddSubImmOperand16 : SVEShiftedImmOperand<16, "AddSub", "isSVEAddSubImm<int16_t>">;
- def SVEAddSubImmOperand32 : SVEShiftedImmOperand<32, "AddSub", "isSVEAddSubImm<int32_t>">;
- def SVEAddSubImmOperand64 : SVEShiftedImmOperand<64, "AddSub", "isSVEAddSubImm<int64_t>">;
- class imm8_opt_lsl<int ElementWidth, string printType,
- AsmOperandClass OpndClass>
- : Operand<i32> {
- let EncoderMethod = "getImm8OptLsl";
- let DecoderMethod = "DecodeImm8OptLsl<" # ElementWidth # ">";
- let PrintMethod = "printImm8OptLsl<" # printType # ">";
- let ParserMatchClass = OpndClass;
- let MIOperandInfo = (ops i32imm, i32imm);
- }
- def cpy_imm8_opt_lsl_i8 : imm8_opt_lsl<8, "int8_t", SVECpyImmOperand8>;
- def cpy_imm8_opt_lsl_i16 : imm8_opt_lsl<16, "int16_t", SVECpyImmOperand16>;
- def cpy_imm8_opt_lsl_i32 : imm8_opt_lsl<32, "int32_t", SVECpyImmOperand32>;
- def cpy_imm8_opt_lsl_i64 : imm8_opt_lsl<64, "int64_t", SVECpyImmOperand64>;
- def addsub_imm8_opt_lsl_i8 : imm8_opt_lsl<8, "uint8_t", SVEAddSubImmOperand8>;
- def addsub_imm8_opt_lsl_i16 : imm8_opt_lsl<16, "uint16_t", SVEAddSubImmOperand16>;
- def addsub_imm8_opt_lsl_i32 : imm8_opt_lsl<32, "uint32_t", SVEAddSubImmOperand32>;
- def addsub_imm8_opt_lsl_i64 : imm8_opt_lsl<64, "uint64_t", SVEAddSubImmOperand64>;
- def SVEAddSubImm8Pat : ComplexPattern<i32, 2, "SelectSVEAddSubImm<MVT::i8>", []>;
- def SVEAddSubImm16Pat : ComplexPattern<i32, 2, "SelectSVEAddSubImm<MVT::i16>", []>;
- def SVEAddSubImm32Pat : ComplexPattern<i32, 2, "SelectSVEAddSubImm<MVT::i32>", []>;
- def SVEAddSubImm64Pat : ComplexPattern<i64, 2, "SelectSVEAddSubImm<MVT::i64>", []>;
- def SVECpyDupImm8Pat : ComplexPattern<i32, 2, "SelectSVECpyDupImm<MVT::i8>", []>;
- def SVECpyDupImm16Pat : ComplexPattern<i32, 2, "SelectSVECpyDupImm<MVT::i16>", []>;
- def SVECpyDupImm32Pat : ComplexPattern<i32, 2, "SelectSVECpyDupImm<MVT::i32>", []>;
- def SVECpyDupImm64Pat : ComplexPattern<i64, 2, "SelectSVECpyDupImm<MVT::i64>", []>;
- def SVELogicalImm8Pat : ComplexPattern<i32, 1, "SelectSVELogicalImm<MVT::i8>", []>;
- def SVELogicalImm16Pat : ComplexPattern<i32, 1, "SelectSVELogicalImm<MVT::i16>", []>;
- def SVELogicalImm32Pat : ComplexPattern<i32, 1, "SelectSVELogicalImm<MVT::i32>", []>;
- def SVELogicalImm64Pat : ComplexPattern<i64, 1, "SelectSVELogicalImm<MVT::i64>", []>;
- def SVELogicalImm8NotPat : ComplexPattern<i32, 1, "SelectSVELogicalImm<MVT::i8, true>", []>;
- def SVELogicalImm16NotPat : ComplexPattern<i32, 1, "SelectSVELogicalImm<MVT::i16, true>", []>;
- def SVELogicalImm32NotPat : ComplexPattern<i32, 1, "SelectSVELogicalImm<MVT::i32, true>", []>;
- def SVELogicalImm64NotPat : ComplexPattern<i64, 1, "SelectSVELogicalImm<MVT::i64, true>", []>;
- def SVEArithUImm8Pat : ComplexPattern<i32, 1, "SelectSVEArithImm<MVT::i8>", []>;
- def SVEArithUImm16Pat : ComplexPattern<i32, 1, "SelectSVEArithImm<MVT::i16>", []>;
- def SVEArithUImm32Pat : ComplexPattern<i32, 1, "SelectSVEArithImm<MVT::i32>", []>;
- def SVEArithUImm64Pat : ComplexPattern<i64, 1, "SelectSVEArithImm<MVT::i64>", []>;
- def SVEArithSImmPat32 : ComplexPattern<i32, 1, "SelectSVESignedArithImm", []>;
- def SVEArithSImmPat64 : ComplexPattern<i64, 1, "SelectSVESignedArithImm", []>;
- def SVEShiftImmL8 : ComplexPattern<i32, 1, "SelectSVEShiftImm<0, 7>", []>;
- def SVEShiftImmL16 : ComplexPattern<i32, 1, "SelectSVEShiftImm<0, 15>", []>;
- def SVEShiftImmL32 : ComplexPattern<i32, 1, "SelectSVEShiftImm<0, 31>", []>;
- def SVEShiftImmL64 : ComplexPattern<i64, 1, "SelectSVEShiftImm<0, 63>", []>;
- def SVEShiftImmR8 : ComplexPattern<i32, 1, "SelectSVEShiftImm<1, 8, true>", []>;
- def SVEShiftImmR16 : ComplexPattern<i32, 1, "SelectSVEShiftImm<1, 16, true>", []>;
- def SVEShiftImmR32 : ComplexPattern<i32, 1, "SelectSVEShiftImm<1, 32, true>", []>;
- def SVEShiftImmR64 : ComplexPattern<i64, 1, "SelectSVEShiftImm<1, 64, true>", []>;
- def SVEShiftSplatImmR : ComplexPattern<iAny, 1, "SelectSVEShiftSplatImmR", []>;
- def SVEAllActive : ComplexPattern<untyped, 0, "SelectAllActivePredicate", []>;
- class SVEExactFPImm<string Suffix, string ValA, string ValB> : AsmOperandClass {
- let Name = "SVEExactFPImmOperand" # Suffix;
- let DiagnosticType = "Invalid" # Name;
- let ParserMethod = "tryParseFPImm<false>";
- let PredicateMethod = "isExactFPImm<" # ValA # ", " # ValB # ">";
- let RenderMethod = "addExactFPImmOperands<" # ValA # ", " # ValB # ">";
- }
- class SVEExactFPImmOperand<string Suffix, string ValA, string ValB> : Operand<i32> {
- let PrintMethod = "printExactFPImm<" # ValA # ", " # ValB # ">";
- let ParserMatchClass = SVEExactFPImm<Suffix, ValA, ValB>;
- }
- def sve_fpimm_half_one
- : SVEExactFPImmOperand<"HalfOne", "AArch64ExactFPImm::half",
- "AArch64ExactFPImm::one">;
- def sve_fpimm_half_two
- : SVEExactFPImmOperand<"HalfTwo", "AArch64ExactFPImm::half",
- "AArch64ExactFPImm::two">;
- def sve_fpimm_zero_one
- : SVEExactFPImmOperand<"ZeroOne", "AArch64ExactFPImm::zero",
- "AArch64ExactFPImm::one">;
- def sve_incdec_imm : Operand<i32>, TImmLeaf<i32, [{
- return (((uint32_t)Imm) > 0) && (((uint32_t)Imm) < 17);
- }]> {
- let ParserMatchClass = Imm1_16Operand;
- let EncoderMethod = "getSVEIncDecImm";
- let DecoderMethod = "DecodeSVEIncDecImm";
- }
- // This allows i32 immediate extraction from i64 based arithmetic.
- def sve_cnt_mul_imm_i32 : ComplexPattern<i32, 1, "SelectCntImm<1, 16, 1, false>">;
- def sve_cnt_mul_imm_i64 : ComplexPattern<i64, 1, "SelectCntImm<1, 16, 1, false>">;
- def sve_cnt_shl_imm : ComplexPattern<i64, 1, "SelectCntImm<1, 16, 1, true>">;
- def sve_ext_imm_0_31 : ComplexPattern<i64, 1, "SelectEXTImm<31, 8>">;
- def sve_ext_imm_0_63 : ComplexPattern<i64, 1, "SelectEXTImm<63, 4>">;
- def sve_ext_imm_0_127 : ComplexPattern<i64, 1, "SelectEXTImm<127, 2>">;
- def sve_ext_imm_0_255 : ComplexPattern<i64, 1, "SelectEXTImm<255, 1>">;
- def int_aarch64_sve_cntp_oneuse : PatFrag<(ops node:$pred, node:$src2),
- (int_aarch64_sve_cntp node:$pred, node:$src2), [{
- return N->hasOneUse();
- }]>;
- def step_vector_oneuse : PatFrag<(ops node:$idx),
- (step_vector node:$idx), [{
- return N->hasOneUse();
- }]>;
- //===----------------------------------------------------------------------===//
- // SVE PTrue - These are used extensively throughout the pattern matching so
- // it's important we define them first.
- //===----------------------------------------------------------------------===//
- class sve_int_ptrue<bits<2> sz8_64, bits<3> opc, string asm, PPRRegOp pprty,
- ValueType vt, SDPatternOperator op>
- : I<(outs pprty:$Pd), (ins sve_pred_enum:$pattern),
- asm, "\t$Pd, $pattern",
- "",
- [(set (vt pprty:$Pd), (op sve_pred_enum:$pattern))]>, Sched<[]> {
- bits<4> Pd;
- bits<5> pattern;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-19} = 0b011;
- let Inst{18-17} = opc{2-1};
- let Inst{16} = opc{0};
- let Inst{15-10} = 0b111000;
- let Inst{9-5} = pattern;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pd;
- let Defs = !if(!eq (opc{0}, 1), [NZCV], []);
- let ElementSize = pprty.ElementSize;
- let isReMaterializable = 1;
- }
- multiclass sve_int_ptrue<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_ptrue<0b00, opc, asm, PPR8, nxv16i1, op>;
- def _H : sve_int_ptrue<0b01, opc, asm, PPR16, nxv8i1, op>;
- def _S : sve_int_ptrue<0b10, opc, asm, PPR32, nxv4i1, op>;
- def _D : sve_int_ptrue<0b11, opc, asm, PPR64, nxv2i1, op>;
- def : InstAlias<asm # "\t$Pd",
- (!cast<Instruction>(NAME # _B) PPR8:$Pd, 0b11111), 1>;
- def : InstAlias<asm # "\t$Pd",
- (!cast<Instruction>(NAME # _H) PPR16:$Pd, 0b11111), 1>;
- def : InstAlias<asm # "\t$Pd",
- (!cast<Instruction>(NAME # _S) PPR32:$Pd, 0b11111), 1>;
- def : InstAlias<asm # "\t$Pd",
- (!cast<Instruction>(NAME # _D) PPR64:$Pd, 0b11111), 1>;
- }
- def SDT_AArch64PTrue : SDTypeProfile<1, 1, [SDTCisVec<0>, SDTCisVT<1, i32>]>;
- def AArch64ptrue : SDNode<"AArch64ISD::PTRUE", SDT_AArch64PTrue>;
- let Predicates = [HasSVEorSME] in {
- defm PTRUE : sve_int_ptrue<0b000, "ptrue", AArch64ptrue>;
- defm PTRUES : sve_int_ptrue<0b001, "ptrues", null_frag>;
- def : Pat<(nxv16i1 immAllOnesV), (PTRUE_B 31)>;
- def : Pat<(nxv8i1 immAllOnesV), (PTRUE_H 31)>;
- def : Pat<(nxv4i1 immAllOnesV), (PTRUE_S 31)>;
- def : Pat<(nxv2i1 immAllOnesV), (PTRUE_D 31)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE pattern match helpers.
- //===----------------------------------------------------------------------===//
- class SVE_1_Op_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- Instruction inst>
- : Pat<(vtd (op vt1:$Op1)),
- (inst $Op1)>;
- class SVE_1_Op_Passthru_Pat<ValueType vtd, SDPatternOperator op, ValueType pg,
- ValueType vts, Instruction inst>
- : Pat<(vtd (op pg:$Op1, vts:$Op2, vtd:$Op3)),
- (inst $Op3, $Op1, $Op2)>;
- multiclass SVE_1_Op_PassthruUndef_Pat<ValueType vtd, SDPatternOperator op, ValueType pg,
- ValueType vts, Instruction inst> {
- def : Pat<(vtd (op pg:$Op1, vts:$Op2, (vtd undef))),
- (inst (IMPLICIT_DEF), $Op1, $Op2)>;
- def : Pat<(vtd (op (pg (SVEAllActive:$Op1)), vts:$Op2, vtd:$Op3)),
- (inst $Op3, $Op1, $Op2)>;
- }
- // Used to match FP_ROUND_MERGE_PASSTHRU, which has an additional flag for the
- // type of rounding. This is matched by timm0_1 in pattern below and ignored.
- class SVE_1_Op_Passthru_Round_Pat<ValueType vtd, SDPatternOperator op, ValueType pg,
- ValueType vts, Instruction inst>
- : Pat<(vtd (op pg:$Op1, vts:$Op2, (i64 timm0_1), vtd:$Op3)),
- (inst $Op3, $Op1, $Op2)>;
- multiclass SVE_1_Op_PassthruUndef_Round_Pat<ValueType vtd, SDPatternOperator op, ValueType pg,
- ValueType vts, Instruction inst>{
- def : Pat<(vtd (op pg:$Op1, vts:$Op2, (i64 timm0_1), (vtd undef))),
- (inst (IMPLICIT_DEF), $Op1, $Op2)>;
- def : Pat<(vtd (op (pg (SVEAllActive:$Op1)), vts:$Op2, (i64 timm0_1), vtd:$Op3)),
- (inst $Op3, $Op1, $Op2)>;
- }
- class SVE_1_Op_Imm_OptLsl_Pat<ValueType vt, SDPatternOperator op, ZPRRegOp zprty,
- ValueType it, ComplexPattern cpx, Instruction inst>
- : Pat<(vt (op (vt zprty:$Op1), (vt (splat_vector (it (cpx i32:$imm, i32:$shift)))))),
- (inst $Op1, i32:$imm, i32:$shift)>;
- class SVE_1_Op_Imm_Arith_All_Active<ValueType vt, ValueType pt, SDPatternOperator op,
- ZPRRegOp zprty, ValueType it, ComplexPattern cpx, Instruction inst>
- : Pat<(vt (op (pt (SVEAllActive)), (vt zprty:$Op1), (vt (splat_vector (it (cpx i32:$imm)))))),
- (inst $Op1, i32:$imm)>;
- class SVE_1_Op_Imm_Log_Pat<ValueType vt, SDPatternOperator op, ZPRRegOp zprty,
- ValueType it, ComplexPattern cpx, Instruction inst>
- : Pat<(vt (op (vt zprty:$Op1), (vt (splat_vector (it (cpx i64:$imm)))))),
- (inst $Op1, i64:$imm)>;
- class SVE_2_Op_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, Instruction inst>
- : Pat<(vtd (op vt1:$Op1, vt2:$Op2)),
- (inst $Op1, $Op2)>;
- class SVE_2_Op_Pred_All_Active<ValueType vtd, SDPatternOperator op,
- ValueType pt, ValueType vt1, ValueType vt2,
- Instruction inst>
- : Pat<(vtd (op (pt (SVEAllActive)), vt1:$Op1, vt2:$Op2)),
- (inst $Op1, $Op2)>;
- class SVE_2_Op_Pred_All_Active_Pt<ValueType vtd, SDPatternOperator op,
- ValueType pt, ValueType vt1, ValueType vt2,
- Instruction inst>
- : Pat<(vtd (op (pt (SVEAllActive:$Op1)), vt1:$Op2, vt2:$Op3)),
- (inst $Op1, $Op2, $Op3)>;
- class SVE_3_Op_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, ValueType vt3, Instruction inst>
- : Pat<(vtd (op vt1:$Op1, vt2:$Op2, vt3:$Op3)),
- (inst $Op1, $Op2, $Op3)>;
- multiclass SVE_3_Op_Undef_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, ValueType vt3, Instruction inst> {
- def : Pat<(vtd (op (vt1 undef), vt2:$Op1, vt3:$Op2)),
- (inst (IMPLICIT_DEF), $Op1, $Op2)>;
- def : Pat<(vtd (op vt1:$Op1, (vt2 (SVEAllActive:$Op2)), vt3:$Op3)),
- (inst $Op1, $Op2, $Op3)>;
- }
- class SVE_4_Op_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, ValueType vt3, ValueType vt4,
- Instruction inst>
- : Pat<(vtd (op vt1:$Op1, vt2:$Op2, vt3:$Op3, vt4:$Op4)),
- (inst $Op1, $Op2, $Op3, $Op4)>;
- class SVE_2_Op_Imm_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, Operand ImmTy, Instruction inst>
- : Pat<(vtd (op vt1:$Op1, (vt2 ImmTy:$Op2))),
- (inst $Op1, ImmTy:$Op2)>;
- class SVE_3_Op_Imm_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, ValueType vt3, Operand ImmTy,
- Instruction inst>
- : Pat<(vtd (op vt1:$Op1, vt2:$Op2, (vt3 ImmTy:$Op3))),
- (inst $Op1, $Op2, ImmTy:$Op3)>;
- class SVE_4_Op_Imm_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, ValueType vt3, ValueType vt4,
- Operand ImmTy, Instruction inst>
- : Pat<(vtd (op vt1:$Op1, vt2:$Op2, vt3:$Op3, (vt4 ImmTy:$Op4))),
- (inst $Op1, $Op2, $Op3, ImmTy:$Op4)>;
- def SVEDup0 : ComplexPattern<vAny, 0, "SelectDupZero", []>;
- def SVEDup0Undef : ComplexPattern<vAny, 0, "SelectDupZeroOrUndef", []>;
- let AddedComplexity = 1 in {
- class SVE_3_Op_Pat_SelZero<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, ValueType vt3, Instruction inst>
- : Pat<(vtd (vtd (op vt1:$Op1, (vselect vt1:$Op1, vt2:$Op2, (SVEDup0)), vt3:$Op3))),
- (inst $Op1, $Op2, $Op3)>;
- class SVE_3_Op_Pat_Shift_Imm_SelZero<ValueType vtd, SDPatternOperator op,
- ValueType vt1, ValueType vt2,
- Operand vt3, Instruction inst>
- : Pat<(vtd (op vt1:$Op1, (vselect vt1:$Op1, vt2:$Op2, (SVEDup0)), (i32 (vt3:$Op3)))),
- (inst $Op1, $Op2, vt3:$Op3)>;
- }
- //
- // Common but less generic patterns.
- //
- class SVE_1_Op_AllActive_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- Instruction inst, Instruction ptrue>
- : Pat<(vtd (op vt1:$Op1)),
- (inst (IMPLICIT_DEF), (ptrue 31), $Op1)>;
- class SVE_2_Op_AllActive_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, Instruction inst, Instruction ptrue>
- : Pat<(vtd (op vt1:$Op1, vt2:$Op2)),
- (inst (ptrue 31), $Op1, $Op2)>;
- class SVE_InReg_Extend<ValueType vt, SDPatternOperator op, ValueType pt,
- ValueType inreg_vt, Instruction inst>
- : Pat<(vt (op pt:$Pg, vt:$Src, inreg_vt, vt:$PassThru)),
- (inst $PassThru, $Pg, $Src)>;
- multiclass SVE_InReg_Extend_PassthruUndef<ValueType vt, SDPatternOperator op, ValueType pt,
- ValueType inreg_vt, Instruction inst> {
- def : Pat<(vt (op pt:$Pg, vt:$Src, inreg_vt, (vt undef))),
- (inst (IMPLICIT_DEF), $Pg, $Src)>;
- def : Pat<(vt (op (pt (SVEAllActive:$Pg)), vt:$Src, inreg_vt, vt:$PassThru)),
- (inst $PassThru, $Pg, $Src)>;
- }
- class SVE_Shift_DupImm_Pred_Pat<ValueType vt, SDPatternOperator op,
- ValueType pt, ValueType it,
- ComplexPattern cast, Instruction inst>
- : Pat<(vt (op pt:$Pg, vt:$Rn, (vt (splat_vector (it (cast i32:$imm)))))),
- (inst $Pg, $Rn, i32:$imm)>;
- class SVE_Shift_DupImm_All_Active_Pat<ValueType vt, SDPatternOperator op,
- ValueType pt, ValueType it,
- ComplexPattern cast, Instruction inst>
- : Pat<(vt (op (pt (SVEAllActive)), vt:$Rn, (vt (splat_vector (it (cast i32:$imm)))))),
- (inst $Rn, i32:$imm)>;
- class SVE_2_Op_Fp_Imm_Pat<ValueType vt, SDPatternOperator op,
- ValueType pt, ValueType it,
- FPImmLeaf immL, int imm,
- Instruction inst>
- : Pat<(vt (op (pt PPR_3b:$Pg), (vt ZPR:$Zs1), (vt (splat_vector (it immL))))),
- (inst $Pg, $Zs1, imm)>;
- class SVE_2_Op_Fp_Imm_Pat_Zero<ValueType vt, SDPatternOperator op,
- ValueType pt, ValueType it,
- FPImmLeaf immL, int imm,
- Instruction inst>
- : Pat<(vt (op pt:$Pg, (vselect pt:$Pg, vt:$Zs1, (SVEDup0)),
- (vt (splat_vector (it immL))))),
- (inst $Pg, $Zs1, imm)>;
- // Used to re-order the operands of BSP when lowering to BSL. BSP has the order:
- // mask, in1, in2 whereas BSL for SVE2 has them ordered in1, in2, mask
- class SVE_3_Op_BSP_Pat<ValueType vtd, SDPatternOperator op, ValueType vt1,
- ValueType vt2, ValueType vt3, Instruction inst>
- : Pat<(vtd (op vt1:$Op1, vt2:$Op2, vt3:$Op3)),
- (inst $Op2, $Op3, $Op1)>;
- class SVE_Shift_Add_All_Active_Pat<ValueType vtd, SDPatternOperator op, ValueType pt,
- ValueType vt1, ValueType vt2, ValueType vt3,
- Instruction inst>
- : Pat<(vtd (add vt1:$Op1, (op (pt (SVEAllActive)), vt2:$Op2, vt3:$Op3))),
- (inst $Op1, $Op2, $Op3)>;
- class SVE2p1_Cvt_VG2_Pat<string name, SDPatternOperator intrinsic, ValueType out_vt, ValueType in_vt>
- : Pat<(out_vt (intrinsic in_vt:$Zn1, in_vt:$Zn2)),
- (!cast<Instruction>(name) (REG_SEQUENCE ZPR2Mul2, in_vt:$Zn1, zsub0, in_vt:$Zn2, zsub1))>;
- //===----------------------------------------------------------------------===//
- // SVE pattern match helpers.
- //===----------------------------------------------------------------------===//
- // Matches either an intrinsic, or a predicated operation with an all active predicate
- class EitherVSelectOrPassthruPatFrags<SDPatternOperator intrinsic, SDPatternOperator sdnode>
- : PatFrags<(ops node:$Pg, node:$Op1, node:$Op2), [
- (intrinsic node:$Pg, node:$Op1, node:$Op2),
- (vselect node:$Pg, (sdnode (SVEAllActive), node:$Op1, node:$Op2), node:$Op1),
- ]>;
- //
- // Pseudo -> Instruction mappings
- //
- def getSVEPseudoMap : InstrMapping {
- let FilterClass = "SVEPseudo2Instr";
- let RowFields = ["PseudoName"];
- let ColFields = ["IsInstr"];
- let KeyCol = ["0"];
- let ValueCols = [["1"]];
- }
- class SVEPseudo2Instr<string name, bit instr> {
- string PseudoName = name;
- bit IsInstr = instr;
- }
- // Lookup e.g. DIV -> DIVR
- def getSVERevInstr : InstrMapping {
- let FilterClass = "SVEInstr2Rev";
- let RowFields = ["InstrName"];
- let ColFields = ["isReverseInstr"];
- let KeyCol = ["0"];
- let ValueCols = [["1"]];
- }
- // Lookup e.g. DIVR -> DIV
- def getSVENonRevInstr : InstrMapping {
- let FilterClass = "SVEInstr2Rev";
- let RowFields = ["InstrName"];
- let ColFields = ["isReverseInstr"];
- let KeyCol = ["1"];
- let ValueCols = [["0"]];
- }
- class SVEInstr2Rev<string name1, string name2, bit name1IsReverseInstr> {
- string InstrName = !if(name1IsReverseInstr, name1, name2);
- bit isReverseInstr = name1IsReverseInstr;
- }
- //
- // Pseudos for destructive operands
- //
- let hasNoSchedulingInfo = 1 in {
- class PredTwoOpPseudo<string name, ZPRRegOp zprty,
- FalseLanesEnum flags = FalseLanesNone>
- : SVEPseudo2Instr<name, 0>,
- Pseudo<(outs zprty:$Zd), (ins PPR3bAny:$Pg, zprty:$Zs1, zprty:$Zs2), []> {
- let FalseLanes = flags;
- }
- class PredTwoOpImmPseudo<string name, ZPRRegOp zprty, Operand immty,
- FalseLanesEnum flags = FalseLanesNone>
- : SVEPseudo2Instr<name, 0>,
- Pseudo<(outs zprty:$Zd), (ins PPR3bAny:$Pg, zprty:$Zs1, immty:$imm), []> {
- let FalseLanes = flags;
- }
- class PredThreeOpPseudo<string name, ZPRRegOp zprty,
- FalseLanesEnum flags = FalseLanesNone>
- : SVEPseudo2Instr<name, 0>,
- Pseudo<(outs zprty:$Zd), (ins PPR3bAny:$Pg, zprty:$Zs1, zprty:$Zs2, zprty:$Zs3), []> {
- let FalseLanes = flags;
- }
- }
- //
- // Pseudos for passthru operands
- //
- let hasNoSchedulingInfo = 1 in {
- class PredOneOpPassthruPseudo<string name, ZPRRegOp zprty>
- : SVEPseudo2Instr<name, 0>,
- Pseudo<(outs zprty:$Zd), (ins zprty:$Passthru, PPR3bAny:$Pg, zprty:$Zs), []>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Predicate Misc Group
- //===----------------------------------------------------------------------===//
- class sve_int_pfalse<bits<6> opc, string asm>
- : I<(outs PPR8:$Pd), (ins),
- asm, "\t$Pd",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = opc{5-4};
- let Inst{21-19} = 0b011;
- let Inst{18-16} = opc{3-1};
- let Inst{15-10} = 0b111001;
- let Inst{9} = opc{0};
- let Inst{8-4} = 0b00000;
- let Inst{3-0} = Pd;
- let isReMaterializable = 1;
- }
- multiclass sve_int_pfalse<bits<6> opc, string asm> {
- def NAME : sve_int_pfalse<opc, asm>;
- def : InstAlias<"pfalse\t$Pd", (!cast<Instruction>(NAME) PNR8:$Pd), 0>;
- def : Pat<(nxv16i1 immAllZerosV), (!cast<Instruction>(NAME))>;
- def : Pat<(nxv8i1 immAllZerosV), (!cast<Instruction>(NAME))>;
- def : Pat<(nxv4i1 immAllZerosV), (!cast<Instruction>(NAME))>;
- def : Pat<(nxv2i1 immAllZerosV), (!cast<Instruction>(NAME))>;
- def : Pat<(nxv1i1 immAllZerosV), (!cast<Instruction>(NAME))>;
- }
- class sve_int_ptest<bits<6> opc, string asm, SDPatternOperator op>
- : I<(outs), (ins PPRAny:$Pg, PPR8:$Pn),
- asm, "\t$Pg, $Pn",
- "",
- [(op (nxv16i1 PPRAny:$Pg), (nxv16i1 PPR8:$Pn))]>, Sched<[]> {
- bits<4> Pg;
- bits<4> Pn;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = opc{5-4};
- let Inst{21-19} = 0b010;
- let Inst{18-16} = opc{3-1};
- let Inst{15-14} = 0b11;
- let Inst{13-10} = Pg;
- let Inst{9} = opc{0};
- let Inst{8-5} = Pn;
- let Inst{4-0} = 0b00000;
- let Defs = [NZCV];
- let isCompare = 1;
- }
- multiclass sve_int_ptest<bits<6> opc, string asm, SDPatternOperator op,
- SDPatternOperator op_any> {
- def NAME : sve_int_ptest<opc, asm, op>;
- let hasNoSchedulingInfo = 1, isCompare = 1, Defs = [NZCV] in {
- def _ANY : Pseudo<(outs), (ins PPRAny:$Pg, PPR8:$Pn),
- [(op_any (nxv16i1 PPRAny:$Pg), (nxv16i1 PPR8:$Pn))]>,
- PseudoInstExpansion<(!cast<Instruction>(NAME) PPRAny:$Pg, PPR8:$Pn)>;
- }
- }
- class sve_int_pfirst_next<bits<2> sz8_64, bits<5> opc, string asm,
- PPRRegOp pprty>
- : I<(outs pprty:$Pdn), (ins PPRAny:$Pg, pprty:$_Pdn),
- asm, "\t$Pdn, $Pg, $_Pdn",
- "",
- []>, Sched<[]> {
- bits<4> Pdn;
- bits<4> Pg;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-19} = 0b011;
- let Inst{18-16} = opc{4-2};
- let Inst{15-11} = 0b11000;
- let Inst{10-9} = opc{1-0};
- let Inst{8-5} = Pg;
- let Inst{4} = 0;
- let Inst{3-0} = Pdn;
- let Constraints = "$Pdn = $_Pdn";
- let Defs = [NZCV];
- let isPTestLike = 1;
- let ElementSize = pprty.ElementSize;
- }
- multiclass sve_int_pfirst<bits<5> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_pfirst_next<0b01, opc, asm, PPR8>;
- def : SVE_2_Op_Pat<nxv16i1, op, nxv16i1, nxv16i1, !cast<Instruction>(NAME # _B)>;
- }
- multiclass sve_int_pnext<bits<5> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_pfirst_next<0b00, opc, asm, PPR8>;
- def _H : sve_int_pfirst_next<0b01, opc, asm, PPR16>;
- def _S : sve_int_pfirst_next<0b10, opc, asm, PPR32>;
- def _D : sve_int_pfirst_next<0b11, opc, asm, PPR64>;
- def : SVE_2_Op_Pat<nxv16i1, op, nxv16i1, nxv16i1, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i1, op, nxv8i1, nxv8i1, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i1, op, nxv4i1, nxv4i1, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i1, op, nxv2i1, nxv2i1, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Predicate Count Group
- //===----------------------------------------------------------------------===//
- class sve_int_count_r<bits<2> sz8_64, bits<5> opc, string asm,
- RegisterOperand dty, PPRRegOp pprty, RegisterOperand sty>
- : I<(outs dty:$Rdn), (ins pprty:$Pg, sty:$_Rdn),
- asm, "\t$Rdn, $Pg",
- "",
- []>, Sched<[]> {
- bits<5> Rdn;
- bits<4> Pg;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-19} = 0b101;
- let Inst{18-16} = opc{4-2};
- let Inst{15-11} = 0b10001;
- let Inst{10-9} = opc{1-0};
- let Inst{8-5} = Pg;
- let Inst{4-0} = Rdn;
- // Signed 32bit forms require their GPR operand printed.
- let AsmString = !if(!eq(opc{4,2-0}, 0b0000),
- !strconcat(asm, "\t$Rdn, $Pg, $_Rdn"),
- !strconcat(asm, "\t$Rdn, $Pg"));
- let Constraints = "$Rdn = $_Rdn";
- }
- multiclass sve_int_count_r_s32<bits<5> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_count_r<0b00, opc, asm, GPR64z, PPR8, GPR64as32>;
- def _H : sve_int_count_r<0b01, opc, asm, GPR64z, PPR16, GPR64as32>;
- def _S : sve_int_count_r<0b10, opc, asm, GPR64z, PPR32, GPR64as32>;
- def _D : sve_int_count_r<0b11, opc, asm, GPR64z, PPR64, GPR64as32>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv16i1 PPRAny:$Pg))),
- (EXTRACT_SUBREG (!cast<Instruction>(NAME # _B) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32)), sub_32)>;
- def : Pat<(i64 (sext (i32 (op GPR32:$Rn, (nxv16i1 PPRAny:$Pg))))),
- (!cast<Instruction>(NAME # _B) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32))>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv8i1 PPRAny:$Pg))),
- (EXTRACT_SUBREG (!cast<Instruction>(NAME # _H) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32)), sub_32)>;
- def : Pat<(i64 (sext (i32 (op GPR32:$Rn, (nxv8i1 PPRAny:$Pg))))),
- (!cast<Instruction>(NAME # _H) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32))>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv4i1 PPRAny:$Pg))),
- (EXTRACT_SUBREG (!cast<Instruction>(NAME # _S) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32)), sub_32)>;
- def : Pat<(i64 (sext (i32 (op GPR32:$Rn, (nxv4i1 PPRAny:$Pg))))),
- (!cast<Instruction>(NAME # _S) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32))>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv2i1 PPRAny:$Pg))),
- (EXTRACT_SUBREG (!cast<Instruction>(NAME # _D) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32)), sub_32)>;
- def : Pat<(i64 (sext (i32 (op GPR32:$Rn, (nxv2i1 PPRAny:$Pg))))),
- (!cast<Instruction>(NAME # _D) PPRAny:$Pg, (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32))>;
- }
- multiclass sve_int_count_r_u32<bits<5> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_count_r<0b00, opc, asm, GPR32z, PPR8, GPR32z>;
- def _H : sve_int_count_r<0b01, opc, asm, GPR32z, PPR16, GPR32z>;
- def _S : sve_int_count_r<0b10, opc, asm, GPR32z, PPR32, GPR32z>;
- def _D : sve_int_count_r<0b11, opc, asm, GPR32z, PPR64, GPR32z>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv16i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _B) PPRAny:$Pg, $Rn)>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv8i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _H) PPRAny:$Pg, $Rn)>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv4i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _S) PPRAny:$Pg, $Rn)>;
- def : Pat<(i32 (op GPR32:$Rn, (nxv2i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _D) PPRAny:$Pg, $Rn)>;
- }
- multiclass sve_int_count_r_x64<bits<5> opc, string asm,
- SDPatternOperator op,
- SDPatternOperator combine_op = null_frag> {
- def _B : sve_int_count_r<0b00, opc, asm, GPR64z, PPR8, GPR64z>;
- def _H : sve_int_count_r<0b01, opc, asm, GPR64z, PPR16, GPR64z>;
- def _S : sve_int_count_r<0b10, opc, asm, GPR64z, PPR32, GPR64z>;
- def _D : sve_int_count_r<0b11, opc, asm, GPR64z, PPR64, GPR64z>;
- def : Pat<(i64 (op GPR64:$Rn, (nxv16i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _B) PPRAny:$Pg, $Rn)>;
- def : Pat<(i64 (op GPR64:$Rn, (nxv8i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _H) PPRAny:$Pg, $Rn)>;
- def : Pat<(i64 (op GPR64:$Rn, (nxv4i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _S) PPRAny:$Pg, $Rn)>;
- def : Pat<(i64 (op GPR64:$Rn, (nxv2i1 PPRAny:$Pg))),
- (!cast<Instruction>(NAME # _D) PPRAny:$Pg, $Rn)>;
- // combine_op(x, cntp(all_active, p)) ==> inst p, x
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv16i1 (SVEAllActive)), (nxv16i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _B) PPRAny:$pred, $Rn)>;
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv8i1 (SVEAllActive)), (nxv8i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _H) PPRAny:$pred, $Rn)>;
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv4i1 (SVEAllActive)), (nxv4i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _S) PPRAny:$pred, $Rn)>;
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv2i1 (SVEAllActive)), (nxv2i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _D) PPRAny:$pred, $Rn)>;
- // combine_op(x, cntp(p, p)) ==> inst p, x
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv16i1 PPRAny:$pred), (nxv16i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _B) PPRAny:$pred, $Rn)>;
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv8i1 PPRAny:$pred), (nxv8i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _H) PPRAny:$pred, $Rn)>;
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv4i1 PPRAny:$pred), (nxv4i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _S) PPRAny:$pred, $Rn)>;
- def : Pat<(i64 (combine_op GPR64:$Rn, (int_aarch64_sve_cntp_oneuse (nxv2i1 PPRAny:$pred), (nxv2i1 PPRAny:$pred)))),
- (!cast<Instruction>(NAME # _D) PPRAny:$pred, $Rn)>;
- }
- class sve_int_count_v<bits<2> sz8_64, bits<5> opc, string asm,
- ZPRRegOp zprty, PPRRegOp pprty>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, pprty:$Pm),
- asm, "\t$Zdn, $Pm",
- "",
- []>, Sched<[]> {
- bits<4> Pm;
- bits<5> Zdn;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-19} = 0b101;
- let Inst{18-16} = opc{4-2};
- let Inst{15-11} = 0b10000;
- let Inst{10-9} = opc{1-0};
- let Inst{8-5} = Pm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_count_v<bits<5> opc, string asm,
- SDPatternOperator op = null_frag> {
- def _H : sve_int_count_v<0b01, opc, asm, ZPR16, PPR16>;
- def _S : sve_int_count_v<0b10, opc, asm, ZPR32, PPR32>;
- def _D : sve_int_count_v<0b11, opc, asm, ZPR64, PPR64>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i1, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i1, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i1, !cast<Instruction>(NAME # _D)>;
- def : InstAlias<asm # "\t$Zdn, $Pm",
- (!cast<Instruction>(NAME # "_H") ZPR16:$Zdn, PPRAny:$Pm), 0>;
- def : InstAlias<asm # "\t$Zdn, $Pm",
- (!cast<Instruction>(NAME # "_S") ZPR32:$Zdn, PPRAny:$Pm), 0>;
- def : InstAlias<asm # "\t$Zdn, $Pm",
- (!cast<Instruction>(NAME # "_D") ZPR64:$Zdn, PPRAny:$Pm), 0>;
- }
- class sve_int_pcount_pred<bits<2> sz8_64, bits<4> opc, string asm,
- PPRRegOp pprty>
- : I<(outs GPR64:$Rd), (ins PPRAny:$Pg, pprty:$Pn),
- asm, "\t$Rd, $Pg, $Pn",
- "",
- []>, Sched<[]> {
- bits<4> Pg;
- bits<4> Pn;
- bits<5> Rd;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-19} = 0b100;
- let Inst{18-16} = opc{3-1};
- let Inst{15-14} = 0b10;
- let Inst{13-10} = Pg;
- let Inst{9} = opc{0};
- let Inst{8-5} = Pn;
- let Inst{4-0} = Rd;
- }
- multiclass sve_int_pcount_pred<bits<4> opc, string asm,
- SDPatternOperator int_op> {
- def _B : sve_int_pcount_pred<0b00, opc, asm, PPR8>;
- def _H : sve_int_pcount_pred<0b01, opc, asm, PPR16>;
- def _S : sve_int_pcount_pred<0b10, opc, asm, PPR32>;
- def _D : sve_int_pcount_pred<0b11, opc, asm, PPR64>;
- def : SVE_2_Op_Pat<i64, int_op, nxv16i1, nxv16i1, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<i64, int_op, nxv8i1, nxv8i1, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<i64, int_op, nxv4i1, nxv4i1, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<i64, int_op, nxv2i1, nxv2i1, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Element Count Group
- //===----------------------------------------------------------------------===//
- class sve_int_count<bits<3> opc, string asm>
- : I<(outs GPR64:$Rd), (ins sve_pred_enum:$pattern, sve_incdec_imm:$imm4),
- asm, "\t$Rd, $pattern, mul $imm4",
- "",
- []>, Sched<[]> {
- bits<5> Rd;
- bits<4> imm4;
- bits<5> pattern;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc{2-1};
- let Inst{21-20} = 0b10;
- let Inst{19-16} = imm4;
- let Inst{15-11} = 0b11100;
- let Inst{10} = opc{0};
- let Inst{9-5} = pattern;
- let Inst{4-0} = Rd;
- let isReMaterializable = 1;
- }
- multiclass sve_int_count<bits<3> opc, string asm, SDPatternOperator op> {
- def NAME : sve_int_count<opc, asm>;
- def : InstAlias<asm # "\t$Rd, $pattern",
- (!cast<Instruction>(NAME) GPR64:$Rd, sve_pred_enum:$pattern, 1), 1>;
- def : InstAlias<asm # "\t$Rd",
- (!cast<Instruction>(NAME) GPR64:$Rd, 0b11111, 1), 2>;
- def : Pat<(i64 (mul (op sve_pred_enum:$pattern), (sve_cnt_mul_imm_i64 i32:$imm))),
- (!cast<Instruction>(NAME) sve_pred_enum:$pattern, sve_incdec_imm:$imm)>;
- def : Pat<(i64 (shl (op sve_pred_enum:$pattern), (sve_cnt_shl_imm i32:$imm))),
- (!cast<Instruction>(NAME) sve_pred_enum:$pattern, sve_incdec_imm:$imm)>;
- def : Pat<(i64 (op sve_pred_enum:$pattern)),
- (!cast<Instruction>(NAME) sve_pred_enum:$pattern, 1)>;
- }
- class sve_int_countvlv<bits<5> opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, sve_pred_enum:$pattern, sve_incdec_imm:$imm4),
- asm, "\t$Zdn, $pattern, mul $imm4",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> pattern;
- bits<4> imm4;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc{4-3};
- let Inst{21} = 0b1;
- let Inst{20} = opc{2};
- let Inst{19-16} = imm4;
- let Inst{15-12} = 0b1100;
- let Inst{11-10} = opc{1-0};
- let Inst{9-5} = pattern;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_countvlv<bits<5> opc, string asm, ZPRRegOp zprty,
- SDPatternOperator op = null_frag,
- ValueType vt = OtherVT> {
- def NAME : sve_int_countvlv<opc, asm, zprty>;
- def : InstAlias<asm # "\t$Zdn, $pattern",
- (!cast<Instruction>(NAME) zprty:$Zdn, sve_pred_enum:$pattern, 1), 1>;
- def : InstAlias<asm # "\t$Zdn",
- (!cast<Instruction>(NAME) zprty:$Zdn, 0b11111, 1), 2>;
- def : Pat<(vt (op (vt zprty:$Zn), (sve_pred_enum:$pattern), (sve_incdec_imm:$imm4))),
- (!cast<Instruction>(NAME) $Zn, sve_pred_enum:$pattern, sve_incdec_imm:$imm4)>;
- }
- class sve_int_pred_pattern_a<bits<3> opc, string asm>
- : I<(outs GPR64:$Rdn), (ins GPR64:$_Rdn, sve_pred_enum:$pattern, sve_incdec_imm:$imm4),
- asm, "\t$Rdn, $pattern, mul $imm4",
- "",
- []>, Sched<[]> {
- bits<5> Rdn;
- bits<5> pattern;
- bits<4> imm4;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc{2-1};
- let Inst{21-20} = 0b11;
- let Inst{19-16} = imm4;
- let Inst{15-11} = 0b11100;
- let Inst{10} = opc{0};
- let Inst{9-5} = pattern;
- let Inst{4-0} = Rdn;
- let Constraints = "$Rdn = $_Rdn";
- }
- multiclass sve_int_pred_pattern_a<bits<3> opc, string asm,
- SDPatternOperator op,
- SDPatternOperator opcnt> {
- let Predicates = [HasSVEorSME] in {
- def NAME : sve_int_pred_pattern_a<opc, asm>;
- def : InstAlias<asm # "\t$Rdn, $pattern",
- (!cast<Instruction>(NAME) GPR64:$Rdn, sve_pred_enum:$pattern, 1), 1>;
- def : InstAlias<asm # "\t$Rdn",
- (!cast<Instruction>(NAME) GPR64:$Rdn, 0b11111, 1), 2>;
- }
- let Predicates = [HasSVEorSME, UseScalarIncVL] in {
- def : Pat<(i64 (op GPR64:$Rdn, (opcnt sve_pred_enum:$pattern))),
- (!cast<Instruction>(NAME) GPR64:$Rdn, sve_pred_enum:$pattern, 1)>;
- def : Pat<(i64 (op GPR64:$Rdn, (mul (opcnt sve_pred_enum:$pattern), (sve_cnt_mul_imm_i64 i32:$imm)))),
- (!cast<Instruction>(NAME) GPR64:$Rdn, sve_pred_enum:$pattern, $imm)>;
- def : Pat<(i64 (op GPR64:$Rdn, (shl (opcnt sve_pred_enum:$pattern), (sve_cnt_shl_imm i32:$imm)))),
- (!cast<Instruction>(NAME) GPR64:$Rdn, sve_pred_enum:$pattern, $imm)>;
- def : Pat<(i32 (op GPR32:$Rdn, (i32 (trunc (opcnt (sve_pred_enum:$pattern)))))),
- (i32 (EXTRACT_SUBREG (!cast<Instruction>(NAME) (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
- GPR32:$Rdn, sub_32), sve_pred_enum:$pattern, 1),
- sub_32))>;
- def : Pat<(i32 (op GPR32:$Rdn, (mul (i32 (trunc (opcnt (sve_pred_enum:$pattern)))), (sve_cnt_mul_imm_i32 i32:$imm)))),
- (i32 (EXTRACT_SUBREG (!cast<Instruction>(NAME) (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
- GPR32:$Rdn, sub_32), sve_pred_enum:$pattern, $imm),
- sub_32))>;
- def : Pat<(i32 (op GPR32:$Rdn, (shl (i32 (trunc (opcnt (sve_pred_enum:$pattern)))), (sve_cnt_shl_imm i32:$imm)))),
- (i32 (EXTRACT_SUBREG (!cast<Instruction>(NAME) (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
- GPR32:$Rdn, sub_32), sve_pred_enum:$pattern, $imm),
- sub_32))>;
- }
- }
- class sve_int_pred_pattern_b<bits<5> opc, string asm, RegisterOperand dt,
- RegisterOperand st>
- : I<(outs dt:$Rdn), (ins st:$_Rdn, sve_pred_enum:$pattern, sve_incdec_imm:$imm4),
- asm, "\t$Rdn, $pattern, mul $imm4",
- "",
- []>, Sched<[]> {
- bits<5> Rdn;
- bits<5> pattern;
- bits<4> imm4;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc{4-3};
- let Inst{21} = 0b1;
- let Inst{20} = opc{2};
- let Inst{19-16} = imm4;
- let Inst{15-12} = 0b1111;
- let Inst{11-10} = opc{1-0};
- let Inst{9-5} = pattern;
- let Inst{4-0} = Rdn;
- // Signed 32bit forms require their GPR operand printed.
- let AsmString = !if(!eq(opc{2,0}, 0b00),
- !strconcat(asm, "\t$Rdn, $_Rdn, $pattern, mul $imm4"),
- !strconcat(asm, "\t$Rdn, $pattern, mul $imm4"));
- let Constraints = "$Rdn = $_Rdn";
- }
- multiclass sve_int_pred_pattern_b_s32<bits<5> opc, string asm,
- SDPatternOperator op> {
- def NAME : sve_int_pred_pattern_b<opc, asm, GPR64z, GPR64as32>;
- def : InstAlias<asm # "\t$Rd, $Rn, $pattern",
- (!cast<Instruction>(NAME) GPR64z:$Rd, GPR64as32:$Rn, sve_pred_enum:$pattern, 1), 1>;
- def : InstAlias<asm # "\t$Rd, $Rn",
- (!cast<Instruction>(NAME) GPR64z:$Rd, GPR64as32:$Rn, 0b11111, 1), 2>;
- // NOTE: Register allocation doesn't like tied operands of differing register
- // class, hence the extra INSERT_SUBREG complication.
- def : Pat<(i32 (op GPR32:$Rn, (sve_pred_enum:$pattern), (sve_incdec_imm:$imm4))),
- (EXTRACT_SUBREG (!cast<Instruction>(NAME) (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32), sve_pred_enum:$pattern, sve_incdec_imm:$imm4), sub_32)>;
- def : Pat<(i64 (sext (i32 (op GPR32:$Rn, (sve_pred_enum:$pattern), (sve_incdec_imm:$imm4))))),
- (!cast<Instruction>(NAME) (INSERT_SUBREG (IMPLICIT_DEF), $Rn, sub_32), sve_pred_enum:$pattern, sve_incdec_imm:$imm4)>;
- }
- multiclass sve_int_pred_pattern_b_u32<bits<5> opc, string asm,
- SDPatternOperator op> {
- def NAME : sve_int_pred_pattern_b<opc, asm, GPR32z, GPR32z>;
- def : InstAlias<asm # "\t$Rdn, $pattern",
- (!cast<Instruction>(NAME) GPR32z:$Rdn, sve_pred_enum:$pattern, 1), 1>;
- def : InstAlias<asm # "\t$Rdn",
- (!cast<Instruction>(NAME) GPR32z:$Rdn, 0b11111, 1), 2>;
- def : Pat<(i32 (op GPR32:$Rn, (sve_pred_enum:$pattern), (sve_incdec_imm:$imm4))),
- (!cast<Instruction>(NAME) $Rn, sve_pred_enum:$pattern, sve_incdec_imm:$imm4)>;
- }
- multiclass sve_int_pred_pattern_b_x64<bits<5> opc, string asm,
- SDPatternOperator op> {
- def NAME : sve_int_pred_pattern_b<opc, asm, GPR64z, GPR64z>;
- def : InstAlias<asm # "\t$Rdn, $pattern",
- (!cast<Instruction>(NAME) GPR64z:$Rdn, sve_pred_enum:$pattern, 1), 1>;
- def : InstAlias<asm # "\t$Rdn",
- (!cast<Instruction>(NAME) GPR64z:$Rdn, 0b11111, 1), 2>;
- def : Pat<(i64 (op GPR64:$Rn, (sve_pred_enum:$pattern), (sve_incdec_imm:$imm4))),
- (!cast<Instruction>(NAME) $Rn, sve_pred_enum:$pattern, sve_incdec_imm:$imm4)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Permute - Cross Lane Group
- //===----------------------------------------------------------------------===//
- class sve_int_perm_dup_r<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- ValueType vt, RegisterClass srcRegType,
- SDPatternOperator op>
- : I<(outs zprty:$Zd), (ins srcRegType:$Rn),
- asm, "\t$Zd, $Rn",
- "",
- [(set (vt zprty:$Zd), (op srcRegType:$Rn))]>, Sched<[]> {
- bits<5> Rn;
- bits<5> Zd;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-10} = 0b100000001110;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_dup_r<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_dup_r<0b00, asm, ZPR8, nxv16i8, GPR32sp, op>;
- def _H : sve_int_perm_dup_r<0b01, asm, ZPR16, nxv8i16, GPR32sp, op>;
- def _S : sve_int_perm_dup_r<0b10, asm, ZPR32, nxv4i32, GPR32sp, op>;
- def _D : sve_int_perm_dup_r<0b11, asm, ZPR64, nxv2i64, GPR64sp, op>;
- def : InstAlias<"mov $Zd, $Rn",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, GPR32sp:$Rn), 1>;
- def : InstAlias<"mov $Zd, $Rn",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, GPR32sp:$Rn), 1>;
- def : InstAlias<"mov $Zd, $Rn",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, GPR32sp:$Rn), 1>;
- def : InstAlias<"mov $Zd, $Rn",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, GPR64sp:$Rn), 1>;
- }
- class sve_int_perm_dup_i<bits<5> tsz, Operand immtype, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, immtype:$idx),
- asm, "\t$Zd, $Zn$idx",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<7> idx;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = {?,?}; // imm3h
- let Inst{21} = 0b1;
- let Inst{20-16} = tsz;
- let Inst{15-10} = 0b001000;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_dup_i<string asm> {
- def _B : sve_int_perm_dup_i<{?,?,?,?,1}, sve_elm_idx_extdup_b, asm, ZPR8> {
- let Inst{23-22} = idx{5-4};
- let Inst{20-17} = idx{3-0};
- }
- def _H : sve_int_perm_dup_i<{?,?,?,1,0}, sve_elm_idx_extdup_h, asm, ZPR16> {
- let Inst{23-22} = idx{4-3};
- let Inst{20-18} = idx{2-0};
- }
- def _S : sve_int_perm_dup_i<{?,?,1,0,0}, sve_elm_idx_extdup_s, asm, ZPR32> {
- let Inst{23-22} = idx{3-2};
- let Inst{20-19} = idx{1-0};
- }
- def _D : sve_int_perm_dup_i<{?,1,0,0,0}, sve_elm_idx_extdup_d, asm, ZPR64> {
- let Inst{23-22} = idx{2-1};
- let Inst{20} = idx{0};
- }
- def _Q : sve_int_perm_dup_i<{1,0,0,0,0}, sve_elm_idx_extdup_q, asm, ZPR128> {
- let Inst{23-22} = idx{1-0};
- }
- def : InstAlias<"mov $Zd, $Zn$idx",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, ZPR8:$Zn, sve_elm_idx_extdup_b:$idx), 1>;
- def : InstAlias<"mov $Zd, $Zn$idx",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, ZPR16:$Zn, sve_elm_idx_extdup_h:$idx), 1>;
- def : InstAlias<"mov $Zd, $Zn$idx",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, ZPR32:$Zn, sve_elm_idx_extdup_s:$idx), 1>;
- def : InstAlias<"mov $Zd, $Zn$idx",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, ZPR64:$Zn, sve_elm_idx_extdup_d:$idx), 1>;
- def : InstAlias<"mov $Zd, $Zn$idx",
- (!cast<Instruction>(NAME # _Q) ZPR128:$Zd, ZPR128:$Zn, sve_elm_idx_extdup_q:$idx), 1>;
- def : InstAlias<"mov $Zd, $Bn",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, FPR8asZPR:$Bn, 0), 2>;
- def : InstAlias<"mov $Zd, $Hn",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, FPR16asZPR:$Hn, 0), 2>;
- def : InstAlias<"mov $Zd, $Sn",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, FPR32asZPR:$Sn, 0), 2>;
- def : InstAlias<"mov $Zd, $Dn",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, FPR64asZPR:$Dn, 0), 2>;
- def : InstAlias<"mov $Zd, $Qn",
- (!cast<Instruction>(NAME # _Q) ZPR128:$Zd, FPR128asZPR:$Qn, 0), 2>;
- // Duplicate extracted element of vector into all vector elements
- def : Pat<(nxv16i8 (splat_vector (i32 (vector_extract (nxv16i8 ZPR:$vec), sve_elm_idx_extdup_b:$index)))),
- (!cast<Instruction>(NAME # _B) ZPR:$vec, sve_elm_idx_extdup_b:$index)>;
- def : Pat<(nxv8i16 (splat_vector (i32 (vector_extract (nxv8i16 ZPR:$vec), sve_elm_idx_extdup_h:$index)))),
- (!cast<Instruction>(NAME # _H) ZPR:$vec, sve_elm_idx_extdup_h:$index)>;
- def : Pat<(nxv4i32 (splat_vector (i32 (vector_extract (nxv4i32 ZPR:$vec), sve_elm_idx_extdup_s:$index)))),
- (!cast<Instruction>(NAME # _S) ZPR:$vec, sve_elm_idx_extdup_s:$index)>;
- def : Pat<(nxv2i64 (splat_vector (i64 (vector_extract (nxv2i64 ZPR:$vec), sve_elm_idx_extdup_d:$index)))),
- (!cast<Instruction>(NAME # _D) ZPR:$vec, sve_elm_idx_extdup_d:$index)>;
- def : Pat<(nxv8f16 (splat_vector (f16 (vector_extract (nxv8f16 ZPR:$vec), sve_elm_idx_extdup_h:$index)))),
- (!cast<Instruction>(NAME # _H) ZPR:$vec, sve_elm_idx_extdup_h:$index)>;
- def : Pat<(nxv8bf16 (splat_vector (bf16 (vector_extract (nxv8bf16 ZPR:$vec), sve_elm_idx_extdup_h:$index)))),
- (!cast<Instruction>(NAME # _H) ZPR:$vec, sve_elm_idx_extdup_h:$index)>;
- def : Pat<(nxv4f16 (splat_vector (f16 (vector_extract (nxv4f16 ZPR:$vec), sve_elm_idx_extdup_s:$index)))),
- (!cast<Instruction>(NAME # _S) ZPR:$vec, sve_elm_idx_extdup_s:$index)>;
- def : Pat<(nxv2f16 (splat_vector (f16 (vector_extract (nxv2f16 ZPR:$vec), sve_elm_idx_extdup_d:$index)))),
- (!cast<Instruction>(NAME # _D) ZPR:$vec, sve_elm_idx_extdup_d:$index)>;
- def : Pat<(nxv4f32 (splat_vector (f32 (vector_extract (nxv4f32 ZPR:$vec), sve_elm_idx_extdup_s:$index)))),
- (!cast<Instruction>(NAME # _S) ZPR:$vec, sve_elm_idx_extdup_s:$index)>;
- def : Pat<(nxv2f32 (splat_vector (f32 (vector_extract (nxv2f32 ZPR:$vec), sve_elm_idx_extdup_d:$index)))),
- (!cast<Instruction>(NAME # _D) ZPR:$vec, sve_elm_idx_extdup_d:$index)>;
- def : Pat<(nxv2f64 (splat_vector (f64 (vector_extract (nxv2f64 ZPR:$vec), sve_elm_idx_extdup_d:$index)))),
- (!cast<Instruction>(NAME # _D) ZPR:$vec, sve_elm_idx_extdup_d:$index)>;
- def : Pat<(nxv16i8 (AArch64duplane128 nxv16i8:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- def : Pat<(nxv8i16 (AArch64duplane128 nxv8i16:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- def : Pat<(nxv4i32 (AArch64duplane128 nxv4i32:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- def : Pat<(nxv2i64 (AArch64duplane128 nxv2i64:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- def : Pat<(nxv8f16 (AArch64duplane128 nxv8f16:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- def : Pat<(nxv4f32 (AArch64duplane128 nxv4f32:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- def : Pat<(nxv2f64 (AArch64duplane128 nxv2f64:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- def : Pat<(nxv8bf16 (AArch64duplane128 nxv8bf16:$Op1, i64:$imm)),
- (!cast<Instruction>(NAME # _Q) $Op1, $imm)>;
- }
- class sve_int_perm_tbl<bits<2> sz8_64, bits<2> opc, string asm, ZPRRegOp zprty,
- RegisterOperand VecList>
- : I<(outs zprty:$Zd), (ins VecList:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b001;
- let Inst{12-11} = opc;
- let Inst{10} = 0b0;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_tbl<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_tbl<0b00, 0b10, asm, ZPR8, Z_b>;
- def _H : sve_int_perm_tbl<0b01, 0b10, asm, ZPR16, Z_h>;
- def _S : sve_int_perm_tbl<0b10, 0b10, asm, ZPR32, Z_s>;
- def _D : sve_int_perm_tbl<0b11, 0b10, asm, ZPR64, Z_d>;
- def : InstAlias<asm # "\t$Zd, $Zn, $Zm",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, ZPR8:$Zn, ZPR8:$Zm), 0>;
- def : InstAlias<asm # "\t$Zd, $Zn, $Zm",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, ZPR16:$Zn, ZPR16:$Zm), 0>;
- def : InstAlias<asm # "\t$Zd, $Zn, $Zm",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, ZPR32:$Zn, ZPR32:$Zm), 0>;
- def : InstAlias<asm # "\t$Zd, $Zn, $Zm",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, ZPR64:$Zn, ZPR64:$Zm), 0>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<nxv8f16, op, nxv8f16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4f32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2f64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<nxv8bf16, op, nxv8bf16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- }
- multiclass sve2_int_perm_tbl<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_tbl<0b00, 0b01, asm, ZPR8, ZZ_b>;
- def _H : sve_int_perm_tbl<0b01, 0b01, asm, ZPR16, ZZ_h>;
- def _S : sve_int_perm_tbl<0b10, 0b01, asm, ZPR32, ZZ_s>;
- def _D : sve_int_perm_tbl<0b11, 0b01, asm, ZPR64, ZZ_d>;
- def : Pat<(nxv16i8 (op nxv16i8:$Op1, nxv16i8:$Op2, nxv16i8:$Op3)),
- (nxv16i8 (!cast<Instruction>(NAME # _B) (REG_SEQUENCE ZPR2, nxv16i8:$Op1, zsub0,
- nxv16i8:$Op2, zsub1),
- nxv16i8:$Op3))>;
- def : Pat<(nxv8i16 (op nxv8i16:$Op1, nxv8i16:$Op2, nxv8i16:$Op3)),
- (nxv8i16 (!cast<Instruction>(NAME # _H) (REG_SEQUENCE ZPR2, nxv8i16:$Op1, zsub0,
- nxv8i16:$Op2, zsub1),
- nxv8i16:$Op3))>;
- def : Pat<(nxv4i32 (op nxv4i32:$Op1, nxv4i32:$Op2, nxv4i32:$Op3)),
- (nxv4i32 (!cast<Instruction>(NAME # _S) (REG_SEQUENCE ZPR2, nxv4i32:$Op1, zsub0,
- nxv4i32:$Op2, zsub1),
- nxv4i32:$Op3))>;
- def : Pat<(nxv2i64 (op nxv2i64:$Op1, nxv2i64:$Op2, nxv2i64:$Op3)),
- (nxv2i64 (!cast<Instruction>(NAME # _D) (REG_SEQUENCE ZPR2, nxv2i64:$Op1, zsub0,
- nxv2i64:$Op2, zsub1),
- nxv2i64:$Op3))>;
- def : Pat<(nxv8f16 (op nxv8f16:$Op1, nxv8f16:$Op2, nxv8i16:$Op3)),
- (nxv8f16 (!cast<Instruction>(NAME # _H) (REG_SEQUENCE ZPR2, nxv8f16:$Op1, zsub0,
- nxv8f16:$Op2, zsub1),
- nxv8i16:$Op3))>;
- def : Pat<(nxv4f32 (op nxv4f32:$Op1, nxv4f32:$Op2, nxv4i32:$Op3)),
- (nxv4f32 (!cast<Instruction>(NAME # _S) (REG_SEQUENCE ZPR2, nxv4f32:$Op1, zsub0,
- nxv4f32:$Op2, zsub1),
- nxv4i32:$Op3))>;
- def : Pat<(nxv2f64 (op nxv2f64:$Op1, nxv2f64:$Op2, nxv2i64:$Op3)),
- (nxv2f64 (!cast<Instruction>(NAME # _D) (REG_SEQUENCE ZPR2, nxv2f64:$Op1, zsub0,
- nxv2f64:$Op2, zsub1),
- nxv2i64:$Op3))>;
- def : Pat<(nxv8bf16 (op nxv8bf16:$Op1, nxv8bf16:$Op2, nxv8i16:$Op3)),
- (nxv8bf16 (!cast<Instruction>(NAME # _H) (REG_SEQUENCE ZPR2, nxv8bf16:$Op1, zsub0,
- nxv8bf16:$Op2, zsub1),
- nxv8i16:$Op3))>;
- }
- class sve2_int_perm_tbx<bits<2> sz8_64, bits<2> opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b001;
- let Inst{12-11} = opc;
- let Inst{10} = 0b1;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2_int_perm_tbx<string asm, bits<2> opc, SDPatternOperator op> {
- def _B : sve2_int_perm_tbx<0b00, opc, asm, ZPR8>;
- def _H : sve2_int_perm_tbx<0b01, opc, asm, ZPR16>;
- def _S : sve2_int_perm_tbx<0b10, opc, asm, ZPR32>;
- def _D : sve2_int_perm_tbx<0b11, opc, asm, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8f16, nxv8f16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4f32, nxv4f32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2f64, nxv2f64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8bf16, op, nxv8bf16, nxv8bf16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- }
- class sve_int_perm_reverse_z<bits<2> sz8_64, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn),
- asm, "\t$Zd, $Zn",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-10} = 0b111000001110;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_reverse_z<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_reverse_z<0b00, asm, ZPR8>;
- def _H : sve_int_perm_reverse_z<0b01, asm, ZPR16>;
- def _S : sve_int_perm_reverse_z<0b10, asm, ZPR32>;
- def _D : sve_int_perm_reverse_z<0b11, asm, ZPR64>;
- def : SVE_1_Op_Pat<nxv16i8, op, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Pat<nxv8i16, op, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv4i32, op, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv2i64, op, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_1_Op_Pat<nxv2f16, op, nxv2f16, !cast<Instruction>(NAME # _D)>;
- def : SVE_1_Op_Pat<nxv4f16, op, nxv4f16, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv8f16, op, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv2f32, op, nxv2f32, !cast<Instruction>(NAME # _D)>;
- def : SVE_1_Op_Pat<nxv4f32, op, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv2f64, op, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_1_Op_Pat<nxv2bf16, op, nxv2bf16, !cast<Instruction>(NAME # _D)>;
- def : SVE_1_Op_Pat<nxv4bf16, op, nxv4bf16, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv8bf16, op, nxv8bf16, !cast<Instruction>(NAME # _H)>;
- }
- class sve_int_perm_reverse_p<bits<2> sz8_64, string asm, PPRRegOp pprty,
- SDPatternOperator op>
- : I<(outs pprty:$Pd), (ins pprty:$Pn),
- asm, "\t$Pd, $Pn",
- "",
- [(set nxv16i1:$Pd, (op nxv16i1:$Pn))]>, Sched<[]> {
- bits<4> Pd;
- bits<4> Pn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-9} = 0b1101000100000;
- let Inst{8-5} = Pn;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pd;
- }
- multiclass sve_int_perm_reverse_p<string asm, SDPatternOperator ir_op,
- SDPatternOperator op_b16,
- SDPatternOperator op_b32,
- SDPatternOperator op_b64> {
- def _B : sve_int_perm_reverse_p<0b00, asm, PPR8, ir_op>;
- def _H : sve_int_perm_reverse_p<0b01, asm, PPR16, op_b16>;
- def _S : sve_int_perm_reverse_p<0b10, asm, PPR32, op_b32>;
- def _D : sve_int_perm_reverse_p<0b11, asm, PPR64, op_b64>;
- def : SVE_1_Op_Pat<nxv8i1, ir_op, nxv8i1, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv4i1, ir_op, nxv4i1, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv2i1, ir_op, nxv2i1, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_perm_unpk<bits<2> sz16_64, bits<2> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn),
- asm, "\t$Zd, $Zn",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz16_64;
- let Inst{21-18} = 0b1100;
- let Inst{17-16} = opc;
- let Inst{15-10} = 0b001110;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_unpk<bits<2> opc, string asm, SDPatternOperator op> {
- def _H : sve_int_perm_unpk<0b01, opc, asm, ZPR16, ZPR8>;
- def _S : sve_int_perm_unpk<0b10, opc, asm, ZPR32, ZPR16>;
- def _D : sve_int_perm_unpk<0b11, opc, asm, ZPR64, ZPR32>;
- def : SVE_1_Op_Pat<nxv8i16, op, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv4i32, op, nxv8i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv2i64, op, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_perm_insrs<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- RegisterClass srcRegType>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, srcRegType:$Rm),
- asm, "\t$Zdn, $Rm",
- "",
- []>, Sched<[]> {
- bits<5> Rm;
- bits<5> Zdn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-10} = 0b100100001110;
- let Inst{9-5} = Rm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- }
- multiclass sve_int_perm_insrs<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_insrs<0b00, asm, ZPR8, GPR32>;
- def _H : sve_int_perm_insrs<0b01, asm, ZPR16, GPR32>;
- def _S : sve_int_perm_insrs<0b10, asm, ZPR32, GPR32>;
- def _D : sve_int_perm_insrs<0b11, asm, ZPR64, GPR64>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, i32, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, i32, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_perm_insrv<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- FPRasZPROperand srcOpType>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, srcOpType:$Vm),
- asm, "\t$Zdn, $Vm",
- "",
- []>, Sched<[]> {
- bits<5> Vm;
- bits<5> Zdn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-10} = 0b110100001110;
- let Inst{9-5} = Vm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- }
- multiclass sve_int_perm_insrv<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_insrv<0b00, asm, ZPR8, FPR8asZPR>;
- def _H : sve_int_perm_insrv<0b01, asm, ZPR16, FPR16asZPR>;
- def _S : sve_int_perm_insrv<0b10, asm, ZPR32, FPR32asZPR>;
- def _D : sve_int_perm_insrv<0b11, asm, ZPR64, FPR64asZPR>;
- def : Pat<(nxv8f16 (op nxv8f16:$Zn, f16:$Vm)),
- (!cast<Instruction>(NAME # _H) $Zn, (INSERT_SUBREG (IMPLICIT_DEF), $Vm, hsub))>;
- def : Pat<(nxv4f32 (op nxv4f32:$Zn, f32:$Vm)),
- (!cast<Instruction>(NAME # _S) $Zn, (INSERT_SUBREG (IMPLICIT_DEF), $Vm, ssub))>;
- def : Pat<(nxv2f64 (op nxv2f64:$Zn, f64:$Vm)),
- (!cast<Instruction>(NAME # _D) $Zn, (INSERT_SUBREG (IMPLICIT_DEF), $Vm, dsub))>;
- def : Pat<(nxv8bf16 (op nxv8bf16:$Zn, bf16:$Vm)),
- (!cast<Instruction>(NAME # _H) $Zn, (INSERT_SUBREG (IMPLICIT_DEF), $Vm, hsub))>;
- // Keep integer insertions within the vector unit.
- def : Pat<(nxv16i8 (op (nxv16i8 ZPR:$Zn), (i32 (vector_extract (nxv16i8 ZPR:$Vm), 0)))),
- (!cast<Instruction>(NAME # _B) $Zn, ZPR:$Vm)>;
- def : Pat<(nxv8i16 (op (nxv8i16 ZPR:$Zn), (i32 (vector_extract (nxv8i16 ZPR:$Vm), 0)))),
- (!cast<Instruction>(NAME # _H) $Zn, ZPR:$Vm)>;
- def : Pat<(nxv4i32 (op (nxv4i32 ZPR:$Zn), (i32 (vector_extract (nxv4i32 ZPR:$Vm), 0)))),
- (!cast<Instruction>(NAME # _S) $Zn, ZPR: $Vm)>;
- def : Pat<(nxv2i64 (op (nxv2i64 ZPR:$Zn), (i64 (vector_extract (nxv2i64 ZPR:$Vm), 0)))),
- (!cast<Instruction>(NAME # _D) $Zn, ZPR:$Vm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Permute - Extract Group
- //===----------------------------------------------------------------------===//
- class sve_int_perm_extract_i<string asm>
- : I<(outs ZPR8:$Zdn), (ins ZPR8:$_Zdn, ZPR8:$Zm, imm0_255:$imm8),
- asm, "\t$Zdn, $_Zdn, $Zm, $imm8",
- "", []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zm;
- bits<8> imm8;
- let Inst{31-21} = 0b00000101001;
- let Inst{20-16} = imm8{7-3};
- let Inst{15-13} = 0b000;
- let Inst{12-10} = imm8{2-0};
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_perm_extract_i<string asm, SDPatternOperator op> {
- def NAME : sve_int_perm_extract_i<asm>;
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv16i8, i32, imm0_255,
- !cast<Instruction>(NAME)>;
- }
- class sve2_int_perm_extract_i_cons<string asm>
- : I<(outs ZPR8:$Zd), (ins ZZ_b:$Zn, imm0_255:$imm8),
- asm, "\t$Zd, $Zn, $imm8",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<8> imm8;
- let Inst{31-21} = 0b00000101011;
- let Inst{20-16} = imm8{7-3};
- let Inst{15-13} = 0b000;
- let Inst{12-10} = imm8{2-0};
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- //===----------------------------------------------------------------------===//
- // SVE Vector Select Group
- //===----------------------------------------------------------------------===//
- class sve_int_sel_vvv<bits<2> sz8_64, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins PPRAny:$Pg, zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Pg, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<4> Pg;
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-14} = 0b11;
- let Inst{13-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_sel_vvv<string asm, SDPatternOperator op> {
- def _B : sve_int_sel_vvv<0b00, asm, ZPR8>;
- def _H : sve_int_sel_vvv<0b01, asm, ZPR16>;
- def _S : sve_int_sel_vvv<0b10, asm, ZPR32>;
- def _D : sve_int_sel_vvv<0b11, asm, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f16, op, nxv4i1, nxv4f16, nxv4f16, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f16, op, nxv2i1, nxv2f16, nxv2f16, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv2f32, op, nxv2i1, nxv2f32, nxv2f32, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8bf16, op, nxv8i1, nxv8bf16, nxv8bf16, !cast<Instruction>(NAME # _H)>;
- def : InstAlias<"mov $Zd, $Pg/m, $Zn",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, PPRAny:$Pg, ZPR8:$Zn, ZPR8:$Zd), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Zn",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, PPRAny:$Pg, ZPR16:$Zn, ZPR16:$Zd), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Zn",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, PPRAny:$Pg, ZPR32:$Zn, ZPR32:$Zd), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Zn",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, PPRAny:$Pg, ZPR64:$Zn, ZPR64:$Zd), 1>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Predicate Logical Operations Group
- //===----------------------------------------------------------------------===//
- class sve_int_pred_log<bits<4> opc, string asm>
- : I<(outs PPR8:$Pd), (ins PPRAny:$Pg, PPR8:$Pn, PPR8:$Pm),
- asm, "\t$Pd, $Pg/z, $Pn, $Pm",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<4> Pg;
- bits<4> Pm;
- bits<4> Pn;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = opc{3-2};
- let Inst{21-20} = 0b00;
- let Inst{19-16} = Pm;
- let Inst{15-14} = 0b01;
- let Inst{13-10} = Pg;
- let Inst{9} = opc{1};
- let Inst{8-5} = Pn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- // SEL has no predication qualifier.
- let AsmString = !if(!eq(opc, 0b0011),
- !strconcat(asm, "\t$Pd, $Pg, $Pn, $Pm"),
- !strconcat(asm, "\t$Pd, $Pg/z, $Pn, $Pm"));
- let Defs = !if(!eq (opc{2}, 1), [NZCV], []);
- }
- multiclass sve_int_pred_log<bits<4> opc, string asm, SDPatternOperator op,
- SDPatternOperator op_nopred = null_frag> {
- def NAME : sve_int_pred_log<opc, asm>;
- def : SVE_3_Op_Pat<nxv16i1, op, nxv16i1, nxv16i1, nxv16i1, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_Pat<nxv8i1, op, nxv8i1, nxv8i1, nxv8i1, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_Pat<nxv4i1, op, nxv4i1, nxv4i1, nxv4i1, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_Pat<nxv2i1, op, nxv2i1, nxv2i1, nxv2i1, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_Pat<nxv1i1, op, nxv1i1, nxv1i1, nxv1i1, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_AllActive_Pat<nxv16i1, op_nopred, nxv16i1, nxv16i1,
- !cast<Instruction>(NAME), PTRUE_B>;
- def : SVE_2_Op_AllActive_Pat<nxv8i1, op_nopred, nxv8i1, nxv8i1,
- !cast<Instruction>(NAME), PTRUE_H>;
- def : SVE_2_Op_AllActive_Pat<nxv4i1, op_nopred, nxv4i1, nxv4i1,
- !cast<Instruction>(NAME), PTRUE_S>;
- def : SVE_2_Op_AllActive_Pat<nxv2i1, op_nopred, nxv2i1, nxv2i1,
- !cast<Instruction>(NAME), PTRUE_D>;
- // Emulate .Q operation using a PTRUE_D when the other lanes don't matter.
- def : SVE_2_Op_AllActive_Pat<nxv1i1, op_nopred, nxv1i1, nxv1i1,
- !cast<Instruction>(NAME), PTRUE_D>;
- }
- // An instance of sve_int_pred_log_and but uses op_nopred's first operand as the
- // general predicate.
- multiclass sve_int_pred_log_v2<bits<4> opc, string asm, SDPatternOperator op,
- SDPatternOperator op_nopred> :
- sve_int_pred_log<opc, asm, op> {
- def : Pat<(nxv16i1 (op_nopred nxv16i1:$Op1, nxv16i1:$Op2)),
- (!cast<Instruction>(NAME) $Op1, $Op1, $Op2)>;
- def : Pat<(nxv8i1 (op_nopred nxv8i1:$Op1, nxv8i1:$Op2)),
- (!cast<Instruction>(NAME) $Op1, $Op1, $Op2)>;
- def : Pat<(nxv4i1 (op_nopred nxv4i1:$Op1, nxv4i1:$Op2)),
- (!cast<Instruction>(NAME) $Op1, $Op1, $Op2)>;
- def : Pat<(nxv2i1 (op_nopred nxv2i1:$Op1, nxv2i1:$Op2)),
- (!cast<Instruction>(NAME) $Op1, $Op1, $Op2)>;
- // Emulate .Q operation using a PTRUE_D when the other lanes don't matter.
- def : Pat<(nxv1i1 (op_nopred nxv1i1:$Op1, nxv1i1:$Op2)),
- (!cast<Instruction>(NAME) $Op1, $Op1, $Op2)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Logical Mask Immediate Group
- //===----------------------------------------------------------------------===//
- class sve_int_log_imm<bits<2> opc, string asm>
- : I<(outs ZPR64:$Zdn), (ins ZPR64:$_Zdn, logical_imm64:$imms13),
- asm, "\t$Zdn, $_Zdn, $imms13",
- "", []>, Sched<[]> {
- bits<5> Zdn;
- bits<13> imms13;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = opc;
- let Inst{21-18} = 0b0000;
- let Inst{17-5} = imms13;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DecoderMethod = "DecodeSVELogicalImmInstruction";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_log_imm<bits<2> opc, string asm, string alias, SDPatternOperator op> {
- def NAME : sve_int_log_imm<opc, asm>;
- def : SVE_1_Op_Imm_Log_Pat<nxv16i8, op, ZPR8, i32, SVELogicalImm8Pat, !cast<Instruction>(NAME)>;
- def : SVE_1_Op_Imm_Log_Pat<nxv8i16, op, ZPR16, i32, SVELogicalImm16Pat, !cast<Instruction>(NAME)>;
- def : SVE_1_Op_Imm_Log_Pat<nxv4i32, op, ZPR32, i32, SVELogicalImm32Pat, !cast<Instruction>(NAME)>;
- def : SVE_1_Op_Imm_Log_Pat<nxv2i64, op, ZPR64, i64, SVELogicalImm64Pat, !cast<Instruction>(NAME)>;
- def : InstAlias<asm # "\t$Zdn, $Zdn, $imm",
- (!cast<Instruction>(NAME) ZPR8:$Zdn, sve_logical_imm8:$imm), 4>;
- def : InstAlias<asm # "\t$Zdn, $Zdn, $imm",
- (!cast<Instruction>(NAME) ZPR16:$Zdn, sve_logical_imm16:$imm), 3>;
- def : InstAlias<asm # "\t$Zdn, $Zdn, $imm",
- (!cast<Instruction>(NAME) ZPR32:$Zdn, sve_logical_imm32:$imm), 2>;
- def : InstAlias<alias # "\t$Zdn, $Zdn, $imm",
- (!cast<Instruction>(NAME) ZPR8:$Zdn, sve_logical_imm8_not:$imm), 0>;
- def : InstAlias<alias # "\t$Zdn, $Zdn, $imm",
- (!cast<Instruction>(NAME) ZPR16:$Zdn, sve_logical_imm16_not:$imm), 0>;
- def : InstAlias<alias # "\t$Zdn, $Zdn, $imm",
- (!cast<Instruction>(NAME) ZPR32:$Zdn, sve_logical_imm32_not:$imm), 0>;
- def : InstAlias<alias # "\t$Zdn, $Zdn, $imm",
- (!cast<Instruction>(NAME) ZPR64:$Zdn, logical_imm64_not:$imm), 0>;
- }
- multiclass sve_int_log_imm_bic<SDPatternOperator op> {
- def : SVE_1_Op_Imm_Log_Pat<nxv16i8, op, ZPR8, i32, SVELogicalImm8NotPat, !cast<Instruction>("AND_ZI")>;
- def : SVE_1_Op_Imm_Log_Pat<nxv8i16, op, ZPR16, i32, SVELogicalImm16NotPat, !cast<Instruction>("AND_ZI")>;
- def : SVE_1_Op_Imm_Log_Pat<nxv4i32, op, ZPR32, i32, SVELogicalImm32NotPat, !cast<Instruction>("AND_ZI")>;
- def : SVE_1_Op_Imm_Log_Pat<nxv2i64, op, ZPR64, i64, SVELogicalImm64NotPat, !cast<Instruction>("AND_ZI")>;
- }
- class sve_int_dup_mask_imm<string asm>
- : I<(outs ZPR64:$Zd), (ins logical_imm64:$imms),
- asm, "\t$Zd, $imms",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<13> imms;
- let Inst{31-18} = 0b00000101110000;
- let Inst{17-5} = imms;
- let Inst{4-0} = Zd;
- let isReMaterializable = 1;
- let DecoderMethod = "DecodeSVELogicalImmInstruction";
- }
- multiclass sve_int_dup_mask_imm<string asm> {
- def NAME : sve_int_dup_mask_imm<asm>;
- def : InstAlias<"dupm $Zd, $imm",
- (!cast<Instruction>(NAME) ZPR8:$Zd, sve_logical_imm8:$imm), 4>;
- def : InstAlias<"dupm $Zd, $imm",
- (!cast<Instruction>(NAME) ZPR16:$Zd, sve_logical_imm16:$imm), 3>;
- def : InstAlias<"dupm $Zd, $imm",
- (!cast<Instruction>(NAME) ZPR32:$Zd, sve_logical_imm32:$imm), 2>;
- // All Zd.b forms have a CPY/DUP equivalent, hence no byte alias here.
- def : InstAlias<"mov $Zd, $imm",
- (!cast<Instruction>(NAME) ZPR16:$Zd, sve_preferred_logical_imm16:$imm), 7>;
- def : InstAlias<"mov $Zd, $imm",
- (!cast<Instruction>(NAME) ZPR32:$Zd, sve_preferred_logical_imm32:$imm), 6>;
- def : InstAlias<"mov $Zd, $imm",
- (!cast<Instruction>(NAME) ZPR64:$Zd, sve_preferred_logical_imm64:$imm), 5>;
- // NOTE: No pattern for nxv16i8 because DUP has full coverage.
- def : Pat<(nxv8i16 (splat_vector (i32 (SVELogicalImm16Pat i64:$imm)))),
- (!cast<Instruction>(NAME) i64:$imm)>;
- def : Pat<(nxv4i32 (splat_vector (i32 (SVELogicalImm32Pat i64:$imm)))),
- (!cast<Instruction>(NAME) i64:$imm)>;
- def : Pat<(nxv2i64 (splat_vector (i64 (SVELogicalImm64Pat i64:$imm)))),
- (!cast<Instruction>(NAME) i64:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Arithmetic - Unpredicated Group.
- //===----------------------------------------------------------------------===//
- class sve_int_bin_cons_arit_0<bits<2> sz8_64, bits<3> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b000;
- let Inst{12-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_bin_cons_arit_0<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_bin_cons_arit_0<0b00, opc, asm, ZPR8>;
- def _H : sve_int_bin_cons_arit_0<0b01, opc, asm, ZPR16>;
- def _S : sve_int_bin_cons_arit_0<0b10, opc, asm, ZPR32>;
- def _D : sve_int_bin_cons_arit_0<0b11, opc, asm, ZPR64>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Arithmetic - Predicated Group
- //===----------------------------------------------------------------------===//
- class sve_fp_2op_i_p_zds<bits<2> sz, bits<3> opc, string asm,
- ZPRRegOp zprty,
- Operand imm_ty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, imm_ty:$i1),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $i1",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bit i1;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b011;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-6} = 0b0000;
- let Inst{5} = i1;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_fp_2op_i_p_zds<bits<3> opc, string asm, string Ps, Operand imm_ty, FPImmLeaf A, FPImmLeaf B, SDPatternOperator op> {
- let DestructiveInstType = DestructiveBinaryImm in {
- def _H : SVEPseudo2Instr<Ps # _H, 1>, sve_fp_2op_i_p_zds<0b01, opc, asm, ZPR16, imm_ty>;
- def _S : SVEPseudo2Instr<Ps # _S, 1>, sve_fp_2op_i_p_zds<0b10, opc, asm, ZPR32, imm_ty>;
- def _D : SVEPseudo2Instr<Ps # _D, 1>, sve_fp_2op_i_p_zds<0b11, opc, asm, ZPR64, imm_ty>;
- }
- def : SVE_2_Op_Fp_Imm_Pat<nxv8f16, op, nxv8i1, f16, A, 0, !cast<Instruction>(NAME # "_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv8f16, op, nxv8i1, f16, B, 1, !cast<Instruction>(NAME # "_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv4f32, op, nxv4i1, f32, A, 0, !cast<Instruction>(NAME # "_S")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv4f32, op, nxv4i1, f32, B, 1, !cast<Instruction>(NAME # "_S")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f64, op, nxv2i1, f64, A, 0, !cast<Instruction>(NAME # "_D")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f64, op, nxv2i1, f64, B, 1, !cast<Instruction>(NAME # "_D")>;
- }
- class sve_fp_2op_p_zds<bits<2> sz, bits<4> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bits<5> Zm;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21-20} = 0b00;
- let Inst{19-16} = opc;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_fp_2op_p_zds<bits<4> opc, string asm, string Ps,
- SDPatternOperator op, DestructiveInstTypeEnum flags,
- string revname="", bit isReverseInstr=0> {
- let DestructiveInstType = flags in {
- def _H : sve_fp_2op_p_zds<0b01, opc, asm, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>, SVEInstr2Rev<NAME # _H, revname # _H, isReverseInstr>;
- def _S : sve_fp_2op_p_zds<0b10, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>, SVEInstr2Rev<NAME # _S, revname # _S, isReverseInstr>;
- def _D : sve_fp_2op_p_zds<0b11, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>, SVEInstr2Rev<NAME # _D, revname # _D, isReverseInstr>;
- }
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_fp_2op_p_zds_fscale<bits<4> opc, string asm,
- SDPatternOperator op> {
- def _H : sve_fp_2op_p_zds<0b01, opc, asm, ZPR16>;
- def _S : sve_fp_2op_p_zds<0b10, opc, asm, ZPR32>;
- def _D : sve_fp_2op_p_zds<0b11, opc, asm, ZPR64>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_fp_2op_p_zds_zeroing_hsd<SDPatternOperator op> {
- def _ZERO_H : PredTwoOpPseudo<NAME # _H, ZPR16, FalseLanesZero>;
- def _ZERO_S : PredTwoOpPseudo<NAME # _S, ZPR32, FalseLanesZero>;
- def _ZERO_D : PredTwoOpPseudo<NAME # _D, ZPR64, FalseLanesZero>;
- def : SVE_3_Op_Pat_SelZero<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Pseudo>(NAME # _ZERO_H)>;
- def : SVE_3_Op_Pat_SelZero<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Pseudo>(NAME # _ZERO_S)>;
- def : SVE_3_Op_Pat_SelZero<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Pseudo>(NAME # _ZERO_D)>;
- }
- class sve_fp_ftmad<bits<2> sz, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, zprty:$Zm, timm32_0_7:$imm3),
- asm, "\t$Zdn, $_Zdn, $Zm, $imm3",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zm;
- bits<3> imm3;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b010;
- let Inst{18-16} = imm3;
- let Inst{15-10} = 0b100000;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_fp_ftmad<string asm, SDPatternOperator op> {
- def _H : sve_fp_ftmad<0b01, asm, ZPR16>;
- def _S : sve_fp_ftmad<0b10, asm, ZPR32>;
- def _D : sve_fp_ftmad<0b11, asm, ZPR64>;
- def : Pat<(nxv8f16 (op (nxv8f16 ZPR16:$Zn), (nxv8f16 ZPR16:$Zm), (i32 timm32_0_7:$imm))),
- (!cast<Instruction>(NAME # _H) ZPR16:$Zn, ZPR16:$Zm, timm32_0_7:$imm)>;
- def : Pat<(nxv4f32 (op (nxv4f32 ZPR32:$Zn), (nxv4f32 ZPR32:$Zm), (i32 timm32_0_7:$imm))),
- (!cast<Instruction>(NAME # _S) ZPR32:$Zn, ZPR32:$Zm, timm32_0_7:$imm)>;
- def : Pat<(nxv2f64 (op (nxv2f64 ZPR64:$Zn), (nxv2f64 ZPR64:$Zm), (i32 timm32_0_7:$imm))),
- (!cast<Instruction>(NAME # _D) ZPR64:$Zn, ZPR64:$Zm, timm32_0_7:$imm)>;
- }
- multiclass sve_fp_2op_i_p_zds_hfd<Operand imm_ty, FPImmLeaf A, FPImmLeaf B, SDPatternOperator ir_op = null_frag> {
- def _UNDEF_H : PredTwoOpImmPseudo<NAME # _H, ZPR16, imm_ty, FalseLanesUndef>;
- def _UNDEF_S : PredTwoOpImmPseudo<NAME # _S, ZPR32, imm_ty, FalseLanesUndef>;
- def _UNDEF_D : PredTwoOpImmPseudo<NAME # _D, ZPR64, imm_ty, FalseLanesUndef>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv8f16, ir_op, nxv8i1, f16, A, 0, !cast<Instruction>(NAME # "_UNDEF_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv8f16, ir_op, nxv8i1, f16, B, 1, !cast<Instruction>(NAME # "_UNDEF_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv4f16, ir_op, nxv4i1, f16, A, 0, !cast<Instruction>(NAME # "_UNDEF_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv4f16, ir_op, nxv4i1, f16, B, 1, !cast<Instruction>(NAME # "_UNDEF_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f16, ir_op, nxv2i1, f16, A, 0, !cast<Instruction>(NAME # "_UNDEF_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f16, ir_op, nxv2i1, f16, B, 1, !cast<Instruction>(NAME # "_UNDEF_H")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv4f32, ir_op, nxv4i1, f32, A, 0, !cast<Instruction>(NAME # "_UNDEF_S")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv4f32, ir_op, nxv4i1, f32, B, 1, !cast<Instruction>(NAME # "_UNDEF_S")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f32, ir_op, nxv2i1, f32, A, 0, !cast<Instruction>(NAME # "_UNDEF_S")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f32, ir_op, nxv2i1, f32, B, 1, !cast<Instruction>(NAME # "_UNDEF_S")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f64, ir_op, nxv2i1, f64, A, 0, !cast<Instruction>(NAME # "_UNDEF_D")>;
- def : SVE_2_Op_Fp_Imm_Pat<nxv2f64, ir_op, nxv2i1, f64, B, 1, !cast<Instruction>(NAME # "_UNDEF_D")>;
- }
- multiclass sve_fp_2op_i_p_zds_zeroing_hfd<Operand imm_ty, FPImmLeaf A, FPImmLeaf B, SDPatternOperator op> {
- def _ZERO_H : PredTwoOpImmPseudo<NAME # _H, ZPR16, imm_ty, FalseLanesZero>;
- def _ZERO_S : PredTwoOpImmPseudo<NAME # _S, ZPR32, imm_ty, FalseLanesZero>;
- def _ZERO_D : PredTwoOpImmPseudo<NAME # _D, ZPR64, imm_ty, FalseLanesZero>;
- let AddedComplexity = 2 in {
- def : SVE_2_Op_Fp_Imm_Pat_Zero<nxv8f16, op, nxv8i1, f16, A, 0, !cast<Instruction>(NAME # "_ZERO_H")>;
- def : SVE_2_Op_Fp_Imm_Pat_Zero<nxv8f16, op, nxv8i1, f16, B, 1, !cast<Instruction>(NAME # "_ZERO_H")>;
- def : SVE_2_Op_Fp_Imm_Pat_Zero<nxv4f32, op, nxv4i1, f32, A, 0, !cast<Instruction>(NAME # "_ZERO_S")>;
- def : SVE_2_Op_Fp_Imm_Pat_Zero<nxv4f32, op, nxv4i1, f32, B, 1, !cast<Instruction>(NAME # "_ZERO_S")>;
- def : SVE_2_Op_Fp_Imm_Pat_Zero<nxv2f64, op, nxv2i1, f64, A, 0, !cast<Instruction>(NAME # "_ZERO_D")>;
- def : SVE_2_Op_Fp_Imm_Pat_Zero<nxv2f64, op, nxv2i1, f64, B, 1, !cast<Instruction>(NAME # "_ZERO_D")>;
- }
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Arithmetic - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve_fp_3op_u_zd<bits<2> sz, bits<3> opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b000;
- let Inst{12-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_fp_3op_u_zd<bits<3> opc, string asm, SDPatternOperator op,
- SDPatternOperator predicated_op = null_frag> {
- def _H : sve_fp_3op_u_zd<0b01, opc, asm, ZPR16>;
- def _S : sve_fp_3op_u_zd<0b10, opc, asm, ZPR32>;
- def _D : sve_fp_3op_u_zd<0b11, opc, asm, ZPR64>;
- def : SVE_2_Op_Pat<nxv8f16, op, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pred_All_Active<nxv8f16, predicated_op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pred_All_Active<nxv4f32, predicated_op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pred_All_Active<nxv2f64, predicated_op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_fp_3op_u_zd_ftsmul<bits<3> opc, string asm, SDPatternOperator op> {
- def _H : sve_fp_3op_u_zd<0b01, opc, asm, ZPR16>;
- def _S : sve_fp_3op_u_zd<0b10, opc, asm, ZPR32>;
- def _D : sve_fp_3op_u_zd<0b11, opc, asm, ZPR64>;
- def : SVE_2_Op_Pat<nxv8f16, op, nxv8f16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4f32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2f64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Fused Multiply-Add Group
- //===----------------------------------------------------------------------===//
- class sve_fp_3op_p_zds_a<bits<2> sz, bits<2> opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zda), (ins PPR3bAny:$Pg, zprty:$_Zda, zprty:$Zn, zprty:$Zm),
- asm, "\t$Zda, $Pg/m, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zda;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15} = 0b0;
- let Inst{14-13} = opc;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let ElementSize = zprty.ElementSize;
- let DestructiveInstType = DestructiveTernaryCommWithRev;
- }
- multiclass sve_fp_3op_p_zds_a<bits<2> opc, string asm, string Ps,
- SDPatternOperator op, string revname,
- bit isReverseInstr=0> {
- def _H : sve_fp_3op_p_zds_a<0b01, opc, asm, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>, SVEInstr2Rev<NAME # _H, revname # _H, isReverseInstr>;
- def _S : sve_fp_3op_p_zds_a<0b10, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>, SVEInstr2Rev<NAME # _S, revname # _S, isReverseInstr>;
- def _D : sve_fp_3op_p_zds_a<0b11, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>, SVEInstr2Rev<NAME # _D, revname # _D, isReverseInstr>;
- def : SVE_4_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_4_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_fp_3op_p_zds_b<bits<2> sz, bits<2> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm, zprty:$Za),
- asm, "\t$Zdn, $Pg/m, $Zm, $Za",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Za;
- bits<5> Zdn;
- bits<5> Zm;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Za;
- let Inst{15} = 0b1;
- let Inst{14-13} = opc;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_fp_3op_p_zds_b<bits<2> opc, string asm, SDPatternOperator op,
- string revname, bit isReverseInstr> {
- def _H : sve_fp_3op_p_zds_b<0b01, opc, asm, ZPR16>,
- SVEInstr2Rev<NAME # _H, revname # _H, isReverseInstr>;
- def _S : sve_fp_3op_p_zds_b<0b10, opc, asm, ZPR32>,
- SVEInstr2Rev<NAME # _S, revname # _S, isReverseInstr>;
- def _D : sve_fp_3op_p_zds_b<0b11, opc, asm, ZPR64>,
- SVEInstr2Rev<NAME # _D, revname # _D, isReverseInstr>;
- def : SVE_4_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_4_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_fp_3op_p_zds_zx {
- def _UNDEF_H : PredThreeOpPseudo<NAME # _H, ZPR16, FalseLanesUndef>;
- def _UNDEF_S : PredThreeOpPseudo<NAME # _S, ZPR32, FalseLanesUndef>;
- def _UNDEF_D : PredThreeOpPseudo<NAME # _D, ZPR64, FalseLanesUndef>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Multiply-Add - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve_fp_fma_by_indexed_elem<bits<2> sz, bits<2> opc, string asm,
- ZPRRegOp zprty1,
- ZPRRegOp zprty2, Operand itype>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty1:$Zn, zprty2:$Zm, itype:$iop),
- asm, "\t$Zda, $Zn, $Zm$iop", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{15-12} = 0b0000;
- let Inst{11-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2p1_fp_bfma_by_indexed_elem<string asm, bits<2> opc> {
- def NAME : sve_fp_fma_by_indexed_elem<{0, ?}, opc, asm, ZPR16, ZPR3b16,
- VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{22} = iop{2};
- let Inst{20-19} = iop{1-0};
- let Inst{18-16} = Zm;
- }
- }
- multiclass sve_fp_fma_by_indexed_elem<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _H : sve_fp_fma_by_indexed_elem<{0, ?}, opc, asm, ZPR16, ZPR3b16, VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{22} = iop{2};
- let Inst{20-19} = iop{1-0};
- let Inst{18-16} = Zm;
- }
- def _S : sve_fp_fma_by_indexed_elem<0b10, opc, asm, ZPR32, ZPR3b32, VectorIndexS32b> {
- bits<3> Zm;
- bits<2> iop;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _D : sve_fp_fma_by_indexed_elem<0b11, opc, asm, ZPR64, ZPR4b64, VectorIndexD32b> {
- bits<4> Zm;
- bit iop;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : Pat<(nxv8f16 (op nxv8f16:$Op1, nxv8f16:$Op2, nxv8f16:$Op3, (i32 VectorIndexH32b_timm:$idx))),
- (!cast<Instruction>(NAME # _H) $Op1, $Op2, $Op3, VectorIndexH32b_timm:$idx)>;
- def : Pat<(nxv4f32 (op nxv4f32:$Op1, nxv4f32:$Op2, nxv4f32:$Op3, (i32 VectorIndexS32b_timm:$idx))),
- (!cast<Instruction>(NAME # _S) $Op1, $Op2, $Op3, VectorIndexS32b_timm:$idx)>;
- def : Pat<(nxv2f64 (op nxv2f64:$Op1, nxv2f64:$Op2, nxv2f64:$Op3, (i32 VectorIndexD32b_timm:$idx))),
- (!cast<Instruction>(NAME # _D) $Op1, $Op2, $Op3, VectorIndexD32b_timm:$idx)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Multiply - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve_fp_fmul_by_indexed_elem<bits<2> sz, bit o2, string asm, ZPRRegOp zprty,
- ZPRRegOp zprty2, Operand itype>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprty2:$Zm, itype:$iop),
- asm, "\t$Zd, $Zn, $Zm$iop", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{15-12} = 0b0010;
- let Inst{11} = o2;
- let Inst{10} = 0b0;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2p1_fp_bfmul_by_indexed_elem<string asm> {
- def NAME : sve_fp_fmul_by_indexed_elem<{0, ?}, 0b1, asm, ZPR16, ZPR3b16, VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{22} = iop{2};
- let Inst{20-19} = iop{1-0};
- let Inst{18-16} = Zm;
- }
- }
- multiclass sve_fp_fmul_by_indexed_elem<string asm, SDPatternOperator op> {
- def _H : sve_fp_fmul_by_indexed_elem<{0, ?}, 0b0, asm, ZPR16, ZPR3b16, VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{22} = iop{2};
- let Inst{20-19} = iop{1-0};
- let Inst{18-16} = Zm;
- }
- def _S : sve_fp_fmul_by_indexed_elem<0b10, 0b0, asm, ZPR32, ZPR3b32, VectorIndexS32b> {
- bits<3> Zm;
- bits<2> iop;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _D : sve_fp_fmul_by_indexed_elem<0b11, 0b0, asm, ZPR64, ZPR4b64, VectorIndexD32b> {
- bits<4> Zm;
- bit iop;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : Pat<(nxv8f16 (op nxv8f16:$Op1, nxv8f16:$Op2, (i32 VectorIndexH32b_timm:$idx))),
- (!cast<Instruction>(NAME # _H) $Op1, $Op2, VectorIndexH32b_timm:$idx)>;
- def : Pat<(nxv4f32 (op nxv4f32:$Op1, nxv4f32:$Op2, (i32 VectorIndexS32b_timm:$idx))),
- (!cast<Instruction>(NAME # _S) $Op1, $Op2, VectorIndexS32b_timm:$idx)>;
- def : Pat<(nxv2f64 (op nxv2f64:$Op1, nxv2f64:$Op2, (i32 VectorIndexD32b_timm:$idx))),
- (!cast<Instruction>(NAME # _D) $Op1, $Op2, VectorIndexD32b_timm:$idx)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Complex Multiply-Add Group
- //===----------------------------------------------------------------------===//
- class sve_fp_fcmla<bits<2> sz, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zda), (ins PPR3bAny:$Pg, zprty:$_Zda, zprty:$Zn, zprty:$Zm,
- complexrotateop:$imm),
- asm, "\t$Zda, $Pg/m, $Zn, $Zm, $imm",
- "", []>, Sched<[]> {
- bits<5> Zda;
- bits<3> Pg;
- bits<5> Zn;
- bits<5> Zm;
- bits<2> imm;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21} = 0;
- let Inst{20-16} = Zm;
- let Inst{15} = 0;
- let Inst{14-13} = imm;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_fp_fcmla<string asm, SDPatternOperator op> {
- def _H : sve_fp_fcmla<0b01, asm, ZPR16>;
- def _S : sve_fp_fcmla<0b10, asm, ZPR32>;
- def _D : sve_fp_fcmla<0b11, asm, ZPR64>;
- def : Pat<(nxv8f16 (op nxv8i1:$Op1, nxv8f16:$Op2, nxv8f16:$Op3, nxv8f16:$Op4, (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # _H) $Op1, $Op2, $Op3, $Op4, complexrotateop:$imm)>;
- def : Pat<(nxv4f32 (op nxv4i1:$Op1, nxv4f32:$Op2, nxv4f32:$Op3, nxv4f32:$Op4, (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # _S) $Op1, $Op2, $Op3, $Op4, complexrotateop:$imm)>;
- def : Pat<(nxv2f64 (op nxv2i1:$Op1, nxv2f64:$Op2, nxv2f64:$Op3, nxv2f64:$Op4, (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # _D) $Op1, $Op2, $Op3, $Op4, complexrotateop:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Complex Multiply-Add - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve_fp_fcmla_by_indexed_elem<bits<2> sz, string asm,
- ZPRRegOp zprty,
- ZPRRegOp zprty2, Operand itype>
- : I<(outs zprty:$Zda), (ins zprty:$_Zda, zprty:$Zn, zprty2:$Zm, itype:$iop,
- complexrotateop:$imm),
- asm, "\t$Zda, $Zn, $Zm$iop, $imm",
- "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<2> imm;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{15-12} = 0b0001;
- let Inst{11-10} = imm;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_fp_fcmla_by_indexed_elem<string asm, SDPatternOperator op> {
- def _H : sve_fp_fcmla_by_indexed_elem<0b10, asm, ZPR16, ZPR3b16, VectorIndexS32b> {
- bits<3> Zm;
- bits<2> iop;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _S : sve_fp_fcmla_by_indexed_elem<0b11, asm, ZPR32, ZPR4b32, VectorIndexD32b> {
- bits<4> Zm;
- bits<1> iop;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : Pat<(nxv8f16 (op nxv8f16:$Op1, nxv8f16:$Op2, nxv8f16:$Op3, (i32 VectorIndexS32b_timm:$idx), (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # _H) $Op1, $Op2, $Op3, VectorIndexS32b_timm:$idx, complexrotateop:$imm)>;
- def : Pat<(nxv4f32 (op nxv4f32:$Op1, nxv4f32:$Op2, nxv4f32:$Op3, (i32 VectorIndexD32b_timm:$idx), (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # _S) $Op1, $Op2, $Op3, VectorIndexD32b_timm:$idx, complexrotateop:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Complex Addition Group
- //===----------------------------------------------------------------------===//
- class sve_fp_fcadd<bits<2> sz, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm,
- complexrotateopodd:$imm),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $Zm, $imm",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zm;
- bits<3> Pg;
- bit imm;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21-17} = 0;
- let Inst{16} = imm;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_fp_fcadd<string asm, SDPatternOperator op> {
- def _H : sve_fp_fcadd<0b01, asm, ZPR16>;
- def _S : sve_fp_fcadd<0b10, asm, ZPR32>;
- def _D : sve_fp_fcadd<0b11, asm, ZPR64>;
- def : Pat<(nxv8f16 (op nxv8i1:$Op1, nxv8f16:$Op2, nxv8f16:$Op3, (i32 complexrotateopodd:$imm))),
- (!cast<Instruction>(NAME # _H) $Op1, $Op2, $Op3, complexrotateopodd:$imm)>;
- def : Pat<(nxv4f32 (op nxv4i1:$Op1, nxv4f32:$Op2, nxv4f32:$Op3, (i32 complexrotateopodd:$imm))),
- (!cast<Instruction>(NAME # _S) $Op1, $Op2, $Op3, complexrotateopodd:$imm)>;
- def : Pat<(nxv2f64 (op nxv2i1:$Op1, nxv2f64:$Op2, nxv2f64:$Op3, (i32 complexrotateopodd:$imm))),
- (!cast<Instruction>(NAME # _D) $Op1, $Op2, $Op3, complexrotateopodd:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Floating Point Convert Group
- //===----------------------------------------------------------------------===//
- class sve2_fp_convert_precision<bits<4> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty1:$_Zd, PPR3bAny:$Pg, zprty2:$Zn),
- asm, "\t$Zd, $Pg/m, $Zn",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<3> Pg;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = opc{3-2};
- let Inst{21-18} = 0b0010;
- let Inst{17-16} = opc{1-0};
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2_fp_convert_down_narrow<string asm, string op> {
- def _StoH : sve2_fp_convert_precision<0b1000, asm, ZPR16, ZPR32>;
- def _DtoS : sve2_fp_convert_precision<0b1110, asm, ZPR32, ZPR64>;
- def : SVE_3_Op_Pat<nxv8f16, !cast<SDPatternOperator>(op # _f16f32), nxv8f16, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _StoH)>;
- def : SVE_3_Op_Pat<nxv4f32, !cast<SDPatternOperator>(op # _f32f64), nxv4f32, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _DtoS)>;
- }
- multiclass sve2_fp_convert_up_long<string asm, string op> {
- def _HtoS : sve2_fp_convert_precision<0b1001, asm, ZPR32, ZPR16>;
- def _StoD : sve2_fp_convert_precision<0b1111, asm, ZPR64, ZPR32>;
- def : SVE_3_Op_Pat<nxv4f32, !cast<SDPatternOperator>(op # _f32f16), nxv4f32, nxv4i1, nxv8f16, !cast<Instruction>(NAME # _HtoS)>;
- def : SVE_3_Op_Pat<nxv2f64, !cast<SDPatternOperator>(op # _f64f32), nxv2f64, nxv2i1, nxv4f32, !cast<Instruction>(NAME # _StoD)>;
- }
- multiclass sve2_fp_convert_down_odd_rounding_top<string asm, string op> {
- def _DtoS : sve2_fp_convert_precision<0b0010, asm, ZPR32, ZPR64>;
- def : SVE_3_Op_Pat<nxv4f32, !cast<SDPatternOperator>(op # _f32f64), nxv4f32, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _DtoS)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Floating Point Pairwise Group
- //===----------------------------------------------------------------------===//
- class sve2_fp_pairwise_pred<bits<2> sz, bits<3> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zm;
- bits<5> Zdn;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b010;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve2_fp_pairwise_pred<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_fp_pairwise_pred<0b01, opc, asm, ZPR16>;
- def _S : sve2_fp_pairwise_pred<0b10, opc, asm, ZPR32>;
- def _D : sve2_fp_pairwise_pred<0b11, opc, asm, ZPR64>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Floating Point Widening Multiply-Add - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve2_fp_mla_long_by_indexed_elem<bits<3> opc, string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR3b16:$Zm,
- VectorIndexH32b:$iop),
- asm, "\t$Zda, $Zn, $Zm$iop",
- "",
- []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<3> Zm;
- bits<3> iop;
- let Inst{31-23} = 0b011001001;
- let Inst{22} = opc{2};
- let Inst{21} = 0b1;
- let Inst{20-19} = iop{2-1};
- let Inst{18-16} = Zm;
- let Inst{15-14} = 0b01;
- let Inst{13} = opc{1};
- let Inst{12} = 0b0;
- let Inst{11} = iop{0};
- let Inst{10} = opc{0};
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_fp_mla_long_by_indexed_elem<bits<3> opc, string asm,
- ValueType OutVT, ValueType InVT,
- SDPatternOperator op> {
- def NAME : sve2_fp_mla_long_by_indexed_elem<opc, asm>;
- def : SVE_4_Op_Imm_Pat<OutVT, op, OutVT, InVT, InVT, i32, VectorIndexH32b_timm, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Floating Point Widening Multiply-Add Group
- //===----------------------------------------------------------------------===//
- class sve2_fp_mla_long<bits<3> opc, string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR16:$Zm),
- asm, "\t$Zda, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-23} = 0b011001001;
- let Inst{22} = opc{2};
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-14} = 0b10;
- let Inst{13} = opc{1};
- let Inst{12-11} = 0b00;
- let Inst{10} = opc{0};
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_fp_mla_long<bits<3> opc, string asm, ValueType OutVT,
- ValueType InVT, SDPatternOperator op> {
- def NAME : sve2_fp_mla_long<opc, asm>;
- def : SVE_3_Op_Pat<OutVT, op, OutVT, InVT, InVT, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Stack Allocation Group
- //===----------------------------------------------------------------------===//
- class sve_int_arith_vl<bit opc, string asm, bit streaming_sve = 0b0>
- : I<(outs GPR64sp:$Rd), (ins GPR64sp:$Rn, simm6_32b:$imm6),
- asm, "\t$Rd, $Rn, $imm6",
- "",
- []>, Sched<[]> {
- bits<5> Rd;
- bits<5> Rn;
- bits<6> imm6;
- let Inst{31-23} = 0b000001000;
- let Inst{22} = opc;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rn;
- let Inst{15-12} = 0b0101;
- let Inst{11} = streaming_sve;
- let Inst{10-5} = imm6;
- let Inst{4-0} = Rd;
- }
- class sve_int_read_vl_a<bit op, bits<5> opc2, string asm, bit streaming_sve = 0b0>
- : I<(outs GPR64:$Rd), (ins simm6_32b:$imm6),
- asm, "\t$Rd, $imm6",
- "",
- []>, Sched<[]> {
- bits<5> Rd;
- bits<6> imm6;
- let Inst{31-23} = 0b000001001;
- let Inst{22} = op;
- let Inst{21} = 0b1;
- let Inst{20-16} = opc2{4-0};
- let Inst{15-12} = 0b0101;
- let Inst{11} = streaming_sve;
- let Inst{10-5} = imm6;
- let Inst{4-0} = Rd;
- let isReMaterializable = 1;
- }
- //===----------------------------------------------------------------------===//
- // SVE Permute - In Lane Group
- //===----------------------------------------------------------------------===//
- class sve_int_perm_bin_perm_zz<bits<3> opc, bits<2> sz8_64, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b011;
- let Inst{12-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_bin_perm_zz<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_perm_bin_perm_zz<opc, 0b00, asm, ZPR8>;
- def _H : sve_int_perm_bin_perm_zz<opc, 0b01, asm, ZPR16>;
- def _S : sve_int_perm_bin_perm_zz<opc, 0b10, asm, ZPR32>;
- def _D : sve_int_perm_bin_perm_zz<opc, 0b11, asm, ZPR64>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<nxv8f16, op, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4f16, op, nxv4f16, nxv4f16, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2f16, op, nxv2f16, nxv2f16, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<nxv2f32, op, nxv2f32, nxv2f32, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<nxv8bf16, op, nxv8bf16, nxv8bf16, !cast<Instruction>(NAME # _H)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Unary Operations Group
- //===----------------------------------------------------------------------===//
- class sve_fp_2op_p_zd<bits<7> opc, string asm, RegisterOperand i_zprtype,
- RegisterOperand o_zprtype, ElementSizeEnum Sz>
- : I<(outs o_zprtype:$Zd), (ins i_zprtype:$_Zd, PPR3bAny:$Pg, i_zprtype:$Zn),
- asm, "\t$Zd, $Pg/m, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = opc{6-5};
- let Inst{21} = 0b0;
- let Inst{20-16} = opc{4-0};
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveUnaryPassthru;
- let ElementSize = Sz;
- }
- multiclass sve_fp_2op_p_zd<bits<7> opc, string asm,
- RegisterOperand i_zprtype,
- RegisterOperand o_zprtype,
- SDPatternOperator int_op,
- SDPatternOperator ir_op, ValueType vt1,
- ValueType vt2, ValueType vt3, ElementSizeEnum Sz> {
- def NAME : sve_fp_2op_p_zd<opc, asm, i_zprtype, o_zprtype, Sz>,
- SVEPseudo2Instr<NAME, 1>;
- // convert vt1 to a packed type for the intrinsic patterns
- defvar packedvt1 = !cond(!eq(!cast<string>(vt1), "nxv2f16"): nxv8f16,
- !eq(!cast<string>(vt1), "nxv4f16"): nxv8f16,
- !eq(!cast<string>(vt1), "nxv2f32"): nxv4f32,
- 1 : vt1);
- // convert vt3 to a packed type for the intrinsic patterns
- defvar packedvt3 = !cond(!eq(!cast<string>(vt3), "nxv2f16"): nxv8f16,
- !eq(!cast<string>(vt3), "nxv4f16"): nxv8f16,
- !eq(!cast<string>(vt3), "nxv2f32"): nxv4f32,
- 1 : vt3);
- def : SVE_3_Op_Pat<packedvt1, int_op, packedvt1, vt2, packedvt3, !cast<Instruction>(NAME)>;
- def : SVE_1_Op_Passthru_Pat<vt1, ir_op, vt2, vt3, !cast<Instruction>(NAME)>;
- def _UNDEF : PredOneOpPassthruPseudo<NAME, !cast<ZPRRegOp>(i_zprtype)>;
- defm : SVE_1_Op_PassthruUndef_Pat<vt1, ir_op, vt2, vt3, !cast<Instruction>(NAME # _UNDEF)>;
- }
- multiclass sve_fp_2op_p_zdr<bits<7> opc, string asm,
- RegisterOperand i_zprtype,
- RegisterOperand o_zprtype,
- SDPatternOperator int_op,
- SDPatternOperator ir_op, ValueType vt1,
- ValueType vt2, ValueType vt3, ElementSizeEnum Sz> {
- def NAME : sve_fp_2op_p_zd<opc, asm, i_zprtype, o_zprtype, Sz>,
- SVEPseudo2Instr<NAME, 1>;
- // convert vt1 to a packed type for the intrinsic patterns
- defvar packedvt1 = !cond(!eq(!cast<string>(vt1), "nxv2f16"): nxv8f16,
- !eq(!cast<string>(vt1), "nxv4f16"): nxv8f16,
- !eq(!cast<string>(vt1), "nxv2f32"): nxv4f32,
- 1 : vt1);
- def : SVE_3_Op_Pat<packedvt1, int_op, packedvt1, vt2, vt3, !cast<Instruction>(NAME)>;
- def : SVE_1_Op_Passthru_Round_Pat<vt1, ir_op, vt2, vt3, !cast<Instruction>(NAME)>;
- def _UNDEF : PredOneOpPassthruPseudo<NAME, !cast<ZPRRegOp>(i_zprtype)>;
- defm : SVE_1_Op_PassthruUndef_Round_Pat<vt1, ir_op, vt2, vt3, !cast<Instruction>(NAME # _UNDEF)>;
- }
- multiclass sve_fp_2op_p_zd_HSD<bits<5> opc, string asm, SDPatternOperator op> {
- def _H : sve_fp_2op_p_zd<{ 0b01, opc }, asm, ZPR16, ZPR16, ElementSizeH>,
- SVEPseudo2Instr<NAME # _H, 1>;
- def _S : sve_fp_2op_p_zd<{ 0b10, opc }, asm, ZPR32, ZPR32, ElementSizeS>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def _D : sve_fp_2op_p_zd<{ 0b11, opc }, asm, ZPR64, ZPR64, ElementSizeD>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_1_Op_Passthru_Pat<nxv8f16, op, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4f16, op, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv2f16, op, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4f32, op, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2f32, op, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2f64, op, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_H : PredOneOpPassthruPseudo<NAME # _H, ZPR16>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv8f16, op, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv4f16, op, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2f16, op, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv4f32, op, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _UNDEF_S)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2f32, op, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _UNDEF_S)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2f64, op, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _UNDEF_D)>;
- }
- multiclass sve2_fp_flogb<string asm, SDPatternOperator op> {
- def _H : sve_fp_2op_p_zd<0b0011010, asm, ZPR16, ZPR16, ElementSizeH>;
- def _S : sve_fp_2op_p_zd<0b0011100, asm, ZPR32, ZPR32, ElementSizeS>;
- def _D : sve_fp_2op_p_zd<0b0011110, asm, ZPR64, ZPR64, ElementSizeD>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_fp_convert_down_odd_rounding<string asm, string op> {
- def _DtoS : sve_fp_2op_p_zd<0b0001010, asm, ZPR64, ZPR32, ElementSizeD>;
- def : SVE_3_Op_Pat<nxv4f32, !cast<SDPatternOperator>(op # _f32f64), nxv4f32, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _DtoS)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Unary Operations - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve_fp_2op_u_zd<bits<2> sz, bits<3> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn),
- asm, "\t$Zd, $Zn",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b001;
- let Inst{18-16} = opc;
- let Inst{15-10} = 0b001100;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_fp_2op_u_zd<bits<3> opc, string asm, SDPatternOperator op> {
- def _H : sve_fp_2op_u_zd<0b01, opc, asm, ZPR16>;
- def _S : sve_fp_2op_u_zd<0b10, opc, asm, ZPR32>;
- def _D : sve_fp_2op_u_zd<0b11, opc, asm, ZPR64>;
- def : SVE_1_Op_Pat<nxv8f16, op, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv4f32, op, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv2f64, op, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Arithmetic - Binary Predicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_bin_pred_arit_log<bits<2> sz8_64, bits<2> fmt, bits<3> opc,
- string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $Zm", "", []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bits<5> Zm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b0;
- let Inst{20-19} = fmt;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b000;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_bin_pred_log<bits<3> opc, string asm, string Ps,
- SDPatternOperator op,
- DestructiveInstTypeEnum flags> {
- let DestructiveInstType = flags in {
- def _B : sve_int_bin_pred_arit_log<0b00, 0b11, opc, asm, ZPR8>,
- SVEPseudo2Instr<Ps # _B, 1>;
- def _H : sve_int_bin_pred_arit_log<0b01, 0b11, opc, asm, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>;
- def _S : sve_int_bin_pred_arit_log<0b10, 0b11, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>;
- def _D : sve_int_bin_pred_arit_log<0b11, 0b11, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>;
- }
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_bin_pred_arit_0<bits<3> opc, string asm, string Ps,
- SDPatternOperator op,
- DestructiveInstTypeEnum flags,
- string revname="", bit isReverseInstr=0> {
- let DestructiveInstType = flags in {
- def _B : sve_int_bin_pred_arit_log<0b00, 0b00, opc, asm, ZPR8>,
- SVEPseudo2Instr<Ps # _B, 1>, SVEInstr2Rev<NAME # _B, revname # _B, isReverseInstr>;
- def _H : sve_int_bin_pred_arit_log<0b01, 0b00, opc, asm, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>, SVEInstr2Rev<NAME # _H, revname # _H, isReverseInstr>;
- def _S : sve_int_bin_pred_arit_log<0b10, 0b00, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>, SVEInstr2Rev<NAME # _S, revname # _S, isReverseInstr>;
- def _D : sve_int_bin_pred_arit_log<0b11, 0b00, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>, SVEInstr2Rev<NAME # _D, revname # _D, isReverseInstr>;
- }
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_bin_pred_arit_1<bits<3> opc, string asm, string Ps,
- SDPatternOperator op,
- DestructiveInstTypeEnum flags> {
- let DestructiveInstType = flags in {
- def _B : sve_int_bin_pred_arit_log<0b00, 0b01, opc, asm, ZPR8>,
- SVEPseudo2Instr<Ps # _B, 1>;
- def _H : sve_int_bin_pred_arit_log<0b01, 0b01, opc, asm, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>;
- def _S : sve_int_bin_pred_arit_log<0b10, 0b01, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>;
- def _D : sve_int_bin_pred_arit_log<0b11, 0b01, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>;
- }
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_bin_pred_arit_2<bits<3> opc, string asm, string Ps,
- SDPatternOperator op,
- DestructiveInstTypeEnum flags> {
- let DestructiveInstType = flags in {
- def _B : sve_int_bin_pred_arit_log<0b00, 0b10, opc, asm, ZPR8>,
- SVEPseudo2Instr<Ps # _B, 1>;
- def _H : sve_int_bin_pred_arit_log<0b01, 0b10, opc, asm, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>;
- def _S : sve_int_bin_pred_arit_log<0b10, 0b10, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>;
- def _D : sve_int_bin_pred_arit_log<0b11, 0b10, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>;
- }
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- // Special case for divides which are not defined for 8b/16b elements.
- multiclass sve_int_bin_pred_arit_2_div<bits<3> opc, string asm, string Ps,
- SDPatternOperator op,
- DestructiveInstTypeEnum flags,
- string revname="", bit isReverseInstr=0> {
- let DestructiveInstType = flags in {
- def _S : sve_int_bin_pred_arit_log<0b10, 0b10, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>, SVEInstr2Rev<NAME # _S, revname # _S, isReverseInstr>;
- def _D : sve_int_bin_pred_arit_log<0b11, 0b10, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>, SVEInstr2Rev<NAME # _D, revname # _D, isReverseInstr>;
- }
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Multiply-Add Group
- //===----------------------------------------------------------------------===//
- class sve_int_mladdsub_vvv_pred<bits<2> sz8_64, bits<1> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm, zprty:$Za),
- asm, "\t$Zdn, $Pg/m, $Zm, $Za",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bits<5> Za;
- bits<5> Zm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-14} = 0b11;
- let Inst{13} = opc;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Za;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_mladdsub_vvv_pred<bits<1> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_mladdsub_vvv_pred<0b00, opc, asm, ZPR8>;
- def _H : sve_int_mladdsub_vvv_pred<0b01, opc, asm, ZPR16>;
- def _S : sve_int_mladdsub_vvv_pred<0b10, opc, asm, ZPR32>;
- def _D : sve_int_mladdsub_vvv_pred<0b11, opc, asm, ZPR64>;
- def : SVE_4_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_4_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_4_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_mlas_vvv_pred<bits<2> sz8_64, bits<1> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zda), (ins PPR3bAny:$Pg, zprty:$_Zda, zprty:$Zn, zprty:$Zm),
- asm, "\t$Zda, $Pg/m, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zda;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-14} = 0b01;
- let Inst{13} = opc;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_mlas_vvv_pred<bits<1> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_mlas_vvv_pred<0b00, opc, asm, ZPR8>;
- def _H : sve_int_mlas_vvv_pred<0b01, opc, asm, ZPR16>;
- def _S : sve_int_mlas_vvv_pred<0b10, opc, asm, ZPR32>;
- def _D : sve_int_mlas_vvv_pred<0b11, opc, asm, ZPR64>;
- def : SVE_4_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_4_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_4_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Integer Multiply-Add - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve2_int_mla<bits<2> sz, bits<5> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty2:$Zn, zprty2:$Zm),
- asm, "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15} = 0b0;
- let Inst{14-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_int_mla<bit S, string asm, SDPatternOperator op> {
- def _B : sve2_int_mla<0b00, { 0b1110, S }, asm, ZPR8, ZPR8>;
- def _H : sve2_int_mla<0b01, { 0b1110, S }, asm, ZPR16, ZPR16>;
- def _S : sve2_int_mla<0b10, { 0b1110, S }, asm, ZPR32, ZPR32>;
- def _D : sve2_int_mla<0b11, { 0b1110, S }, asm, ZPR64, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_int_mla_long<bits<5> opc, string asm, SDPatternOperator op> {
- def _H : sve2_int_mla<0b01, opc, asm, ZPR16, ZPR8>;
- def _S : sve2_int_mla<0b10, opc, asm, ZPR32, ZPR16>;
- def _D : sve2_int_mla<0b11, opc, asm, ZPR64, ZPR32>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Integer Multiply-Add - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve2_int_mla_by_indexed_elem<bits<2> sz, bits<6> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2,
- ZPRRegOp zprty3, Operand itype>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty2:$Zn, zprty3:$Zm, itype:$iop),
- asm, "\t$Zda, $Zn, $Zm$iop", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{15-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_int_mla_by_indexed_elem<bits<2> opc, bit S, string asm,
- SDPatternOperator op> {
- def _H : sve2_int_mla_by_indexed_elem<{0, ?}, { 0b000, opc, S }, asm, ZPR16, ZPR16, ZPR3b16, VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{22} = iop{2};
- let Inst{20-19} = iop{1-0};
- let Inst{18-16} = Zm;
- }
- def _S : sve2_int_mla_by_indexed_elem<0b10, { 0b000, opc, S }, asm, ZPR32, ZPR32, ZPR3b32, VectorIndexS32b> {
- bits<3> Zm;
- bits<2> iop;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _D : sve2_int_mla_by_indexed_elem<0b11, { 0b000, opc, S }, asm, ZPR64, ZPR64, ZPR4b64, VectorIndexD32b> {
- bits<4> Zm;
- bit iop;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : SVE_4_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, nxv8i16, i32, VectorIndexH32b_timm, !cast<Instruction>(NAME # _H)>;
- def : SVE_4_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, i32, VectorIndexS32b_timm, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, i32, VectorIndexD32b_timm, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Integer Multiply-Add Long - Indexed Group
- //===----------------------------------------------------------------------===//
- multiclass sve2_int_mla_long_by_indexed_elem<bits<4> opc, string asm,
- SDPatternOperator op> {
- def _S : sve2_int_mla_by_indexed_elem<0b10, { opc{3}, 0b0, opc{2-1}, ?, opc{0} },
- asm, ZPR32, ZPR16, ZPR3b16, VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{20-19} = iop{2-1};
- let Inst{18-16} = Zm;
- let Inst{11} = iop{0};
- }
- def _D : sve2_int_mla_by_indexed_elem<0b11, { opc{3}, 0b0, opc{2-1}, ?, opc{0} },
- asm, ZPR64, ZPR32, ZPR4b32, VectorIndexS32b> {
- bits<4> Zm;
- bits<2> iop;
- let Inst{20} = iop{1};
- let Inst{19-16} = Zm;
- let Inst{11} = iop{0};
- }
- def : SVE_4_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv8i16, nxv8i16, i32, VectorIndexH32b_timm, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv4i32, nxv4i32, i32, VectorIndexS32b_timm, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Dot Product Group
- //===----------------------------------------------------------------------===//
- class sve_intx_dot<bit sz, bit U, string asm, ZPRRegOp zprty1,
- ZPRRegOp zprty2>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty2:$Zn, zprty2:$Zm), asm,
- "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-23} = 0b010001001;
- let Inst{22} = sz;
- let Inst{21} = 0;
- let Inst{20-16} = Zm;
- let Inst{15-11} = 0;
- let Inst{10} = U;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- }
- multiclass sve_intx_dot<bit opc, string asm, SDPatternOperator op> {
- def _S : sve_intx_dot<0b0, opc, asm, ZPR32, ZPR8>;
- def _D : sve_intx_dot<0b1, opc, asm, ZPR64, ZPR16>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Dot Product Group - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve_intx_dot_by_indexed_elem<bit sz, bit U, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2,
- ZPRRegOp zprty3, Operand itype>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty2:$Zn, zprty3:$Zm, itype:$iop),
- asm, "\t$Zda, $Zn, $Zm$iop",
- "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- let Inst{31-23} = 0b010001001;
- let Inst{22} = sz;
- let Inst{21} = 0b1;
- let Inst{15-11} = 0;
- let Inst{10} = U;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- }
- multiclass sve_intx_dot_by_indexed_elem<bit opc, string asm,
- SDPatternOperator op> {
- def _S : sve_intx_dot_by_indexed_elem<0b0, opc, asm, ZPR32, ZPR8, ZPR3b8, VectorIndexS32b_timm> {
- bits<2> iop;
- bits<3> Zm;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _D : sve_intx_dot_by_indexed_elem<0b1, opc, asm, ZPR64, ZPR16, ZPR4b16, VectorIndexD32b_timm> {
- bits<1> iop;
- bits<4> Zm;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : SVE_4_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv16i8, nxv16i8, i32, VectorIndexS32b_timm, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv8i16, nxv8i16, i32, VectorIndexD32b_timm, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Complex Integer Dot Product Group
- //===----------------------------------------------------------------------===//
- class sve2_complex_int_arith<bits<2> sz, bits<4> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty2:$Zn, zprty2:$Zm,
- complexrotateop:$rot),
- asm, "\t$Zda, $Zn, $Zm, $rot", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- bits<2> rot;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-12} = opc;
- let Inst{11-10} = rot;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_cintx_dot<string asm, SDPatternOperator op> {
- def _S : sve2_complex_int_arith<0b10, 0b0001, asm, ZPR32, ZPR8>;
- def _D : sve2_complex_int_arith<0b11, 0b0001, asm, ZPR64, ZPR16>;
- def : Pat<(nxv4i32 (op (nxv4i32 ZPR32:$Op1), (nxv16i8 ZPR8:$Op2), (nxv16i8 ZPR8:$Op3),
- (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # "_S") ZPR32:$Op1, ZPR8:$Op2, ZPR8:$Op3, complexrotateop:$imm)>;
- def : Pat<(nxv2i64 (op (nxv2i64 ZPR64:$Op1), (nxv8i16 ZPR16:$Op2), (nxv8i16 ZPR16:$Op3),
- (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # "_D") ZPR64:$Op1, ZPR16:$Op2, ZPR16:$Op3, complexrotateop:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Complex Multiply-Add Group
- //===----------------------------------------------------------------------===//
- multiclass sve2_int_cmla<bit opc, string asm, SDPatternOperator op> {
- def _B : sve2_complex_int_arith<0b00, { 0b001, opc }, asm, ZPR8, ZPR8>;
- def _H : sve2_complex_int_arith<0b01, { 0b001, opc }, asm, ZPR16, ZPR16>;
- def _S : sve2_complex_int_arith<0b10, { 0b001, opc }, asm, ZPR32, ZPR32>;
- def _D : sve2_complex_int_arith<0b11, { 0b001, opc }, asm, ZPR64, ZPR64>;
- def : SVE_4_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv16i8, nxv16i8, i32, complexrotateop, !cast<Instruction>(NAME # _B)>;
- def : SVE_4_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, nxv8i16, i32, complexrotateop, !cast<Instruction>(NAME # _H)>;
- def : SVE_4_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, i32, complexrotateop, !cast<Instruction>(NAME # _S)>;
- def : SVE_4_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, i32, complexrotateop, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Complex Integer Dot Product - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve2_complex_int_arith_indexed<bits<2> sz, bits<4> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2,
- ZPRRegOp zprty3, Operand itype>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty2:$Zn, zprty3:$Zm, itype:$iop,
- complexrotateop:$rot),
- asm, "\t$Zda, $Zn, $Zm$iop, $rot", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<2> rot;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{15-12} = opc;
- let Inst{11-10} = rot;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_cintx_dot_by_indexed_elem<string asm, SDPatternOperator op> {
- def _S : sve2_complex_int_arith_indexed<0b10, 0b0100, asm, ZPR32, ZPR8, ZPR3b8, VectorIndexS32b> {
- bits<2> iop;
- bits<3> Zm;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _D : sve2_complex_int_arith_indexed<0b11, 0b0100, asm, ZPR64, ZPR16, ZPR4b16, VectorIndexD32b> {
- bit iop;
- bits<4> Zm;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : Pat<(nxv4i32 (op (nxv4i32 ZPR32:$Op1), (nxv16i8 ZPR8:$Op2), (nxv16i8 ZPR8:$Op3),
- (i32 VectorIndexS32b_timm:$idx), (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # "_S") ZPR32:$Op1, ZPR8:$Op2, ZPR8:$Op3, VectorIndexS32b_timm:$idx, complexrotateop:$imm)>;
- def : Pat<(nxv2i64 (op (nxv2i64 ZPR64:$Op1), (nxv8i16 ZPR16:$Op2), (nxv8i16 ZPR16:$Op3),
- (i32 VectorIndexD32b_timm:$idx), (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # "_D") ZPR64:$Op1, ZPR16:$Op2, ZPR16:$Op3, VectorIndexD32b_timm:$idx, complexrotateop:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Complex Multiply-Add - Indexed Group
- //===----------------------------------------------------------------------===//
- multiclass sve2_cmla_by_indexed_elem<bit opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_complex_int_arith_indexed<0b10, { 0b011, opc }, asm, ZPR16, ZPR16, ZPR3b16, VectorIndexS32b> {
- bits<2> iop;
- bits<3> Zm;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _S : sve2_complex_int_arith_indexed<0b11, { 0b011, opc }, asm, ZPR32, ZPR32, ZPR4b32, VectorIndexD32b> {
- bit iop;
- bits<4> Zm;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : Pat<(nxv8i16 (op (nxv8i16 ZPR16:$Op1), (nxv8i16 ZPR16:$Op2), (nxv8i16 ZPR16:$Op3),
- (i32 VectorIndexS32b_timm:$idx), (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # "_H") ZPR16:$Op1, ZPR16:$Op2, ZPR16:$Op3, VectorIndexS32b_timm:$idx, complexrotateop:$imm)>;
- def : Pat<(nxv4i32 (op (nxv4i32 ZPR32:$Op1), (nxv4i32 ZPR32:$Op2), (nxv4i32 ZPR32:$Op3),
- (i32 VectorIndexD32b_timm:$idx), (i32 complexrotateop:$imm))),
- (!cast<Instruction>(NAME # "_S") ZPR32:$Op1, ZPR32:$Op2, ZPR32:$Op3, VectorIndexD32b_timm:$idx, complexrotateop:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Integer Multiply - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve2_int_mul<bits<2> sz, bits<3> opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b011;
- let Inst{12-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_int_mul<bits<3> opc, string asm, SDPatternOperator op,
- SDPatternOperator op_pred = null_frag> {
- def _B : sve2_int_mul<0b00, opc, asm, ZPR8>;
- def _H : sve2_int_mul<0b01, opc, asm, ZPR16>;
- def _S : sve2_int_mul<0b10, opc, asm, ZPR32>;
- def _D : sve2_int_mul<0b11, opc, asm, ZPR64>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pred_All_Active<nxv16i8, op_pred, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pred_All_Active<nxv8i16, op_pred, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pred_All_Active<nxv4i32, op_pred, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pred_All_Active<nxv2i64, op_pred, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_int_mul_single<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve2_int_mul<0b00, opc, asm, ZPR8>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Integer Multiply - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve2_int_mul_by_indexed_elem<bits<2> sz, bits<4> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2,
- ZPRRegOp zprty3, Operand itype>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn, zprty3:$Zm, itype:$iop),
- asm, "\t$Zd, $Zn, $Zm$iop", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{15-14} = 0b11;
- let Inst{13-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_int_mul_by_indexed_elem<bits<4> opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_int_mul_by_indexed_elem<{0, ?}, opc, asm, ZPR16, ZPR16, ZPR3b16, VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{22} = iop{2};
- let Inst{20-19} = iop{1-0};
- let Inst{18-16} = Zm;
- }
- def _S : sve2_int_mul_by_indexed_elem<0b10, opc, asm, ZPR32, ZPR32, ZPR3b32, VectorIndexS32b> {
- bits<3> Zm;
- bits<2> iop;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- def _D : sve2_int_mul_by_indexed_elem<0b11, opc, asm, ZPR64, ZPR64, ZPR4b64, VectorIndexD32b> {
- bits<4> Zm;
- bit iop;
- let Inst{20} = iop;
- let Inst{19-16} = Zm;
- }
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, i32, VectorIndexH32b_timm, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, i32, VectorIndexS32b_timm, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, i32, VectorIndexD32b_timm, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_int_mul_long_by_indexed_elem<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _S : sve2_int_mul_by_indexed_elem<0b10, { opc{2-1}, ?, opc{0} }, asm,
- ZPR32, ZPR16, ZPR3b16, VectorIndexH32b> {
- bits<3> Zm;
- bits<3> iop;
- let Inst{20-19} = iop{2-1};
- let Inst{18-16} = Zm;
- let Inst{11} = iop{0};
- }
- def _D : sve2_int_mul_by_indexed_elem<0b11, { opc{2-1}, ?, opc{0} }, asm,
- ZPR64, ZPR32, ZPR4b32, VectorIndexS32b> {
- bits<4> Zm;
- bits<2> iop;
- let Inst{20} = iop{1};
- let Inst{19-16} = Zm;
- let Inst{11} = iop{0};
- }
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv8i16, nxv8i16, i32, VectorIndexH32b_timm, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv4i32, nxv4i32, i32, VectorIndexS32b_timm, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Integer - Predicated Group
- //===----------------------------------------------------------------------===//
- class sve2_int_arith_pred<bits<2> sz, bits<6> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $Zm", "", []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zm;
- bits<5> Zdn;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21-20} = 0b01;
- let Inst{20-16} = opc{5-1};
- let Inst{15-14} = 0b10;
- let Inst{13} = opc{0};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve2_int_arith_pred<bits<6> opc, string asm, SDPatternOperator op,
- string Ps = "",
- DestructiveInstTypeEnum flags=DestructiveOther,
- string revname="", bit isReverseInstr=0> {
- let DestructiveInstType = flags in {
- def _B : sve2_int_arith_pred<0b00, opc, asm, ZPR8>,
- SVEPseudo2Instr<Ps # _B, 1>, SVEInstr2Rev<NAME # _B, revname # _B, isReverseInstr>;
- def _H : sve2_int_arith_pred<0b01, opc, asm, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>, SVEInstr2Rev<NAME # _H, revname # _H, isReverseInstr>;
- def _S : sve2_int_arith_pred<0b10, opc, asm, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>, SVEInstr2Rev<NAME # _S, revname # _S, isReverseInstr>;
- def _D : sve2_int_arith_pred<0b11, opc, asm, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>, SVEInstr2Rev<NAME # _D, revname # _D, isReverseInstr>;
- }
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_int_sadd_long_accum_pairwise<bits<2> sz, bit U, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zda), (ins PPR3bAny:$Pg, zprty1:$_Zda, zprty2:$Zn),
- asm, "\t$Zda, $Pg/m, $Zn", "", []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zn;
- bits<5> Zda;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21-17} = 0b00010;
- let Inst{16} = U;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty1.ElementSize;
- }
- multiclass sve2_int_sadd_long_accum_pairwise<bit U, string asm, SDPatternOperator op> {
- def _H : sve2_int_sadd_long_accum_pairwise<0b01, U, asm, ZPR16, ZPR8>;
- def _S : sve2_int_sadd_long_accum_pairwise<0b10, U, asm, ZPR32, ZPR16>;
- def _D : sve2_int_sadd_long_accum_pairwise<0b11, U, asm, ZPR64, ZPR32>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv8i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_int_un_pred_arit<bits<2> sz, bit Q, bits<2> opc,
- string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Zd, $Pg/m, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21-20} = 0b00;
- let Inst{19} = Q;
- let Inst{18} = 0b0;
- let Inst{17-16} = opc;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveUnaryPassthru;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve2_int_un_pred_arit_s<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _S : sve2_int_un_pred_arit<0b10, opc{2}, opc{1-0}, asm, ZPR32>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- defm : SVE_3_Op_Undef_Pat<nxv4i32, op, nxv4i32, nxv4i1, nxv4i32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- }
- multiclass sve2_int_un_pred_arit<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve2_int_un_pred_arit<0b00, opc{2}, opc{1-0}, asm, ZPR8>,
- SVEPseudo2Instr<NAME # _B, 1>;
- def _H : sve2_int_un_pred_arit<0b01, opc{2}, opc{1-0}, asm, ZPR16>,
- SVEPseudo2Instr<NAME # _H, 1>;
- def _S : sve2_int_un_pred_arit<0b10, opc{2}, opc{1-0}, asm, ZPR32>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def _D : sve2_int_un_pred_arit<0b11, opc{2}, opc{1-0}, asm, ZPR64>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i8, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_B : PredOneOpPassthruPseudo<NAME # _B, ZPR8>;
- def _UNDEF_H : PredOneOpPassthruPseudo<NAME # _H, ZPR16>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_3_Op_Undef_Pat<nxv16i8, op, nxv16i8, nxv16i1, nxv16i8, !cast<Pseudo>(NAME # _UNDEF_B)>;
- defm : SVE_3_Op_Undef_Pat<nxv8i16, op, nxv8i16, nxv8i1, nxv8i16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- defm : SVE_3_Op_Undef_Pat<nxv4i32, op, nxv4i32, nxv4i1, nxv4i32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- defm : SVE_3_Op_Undef_Pat<nxv2i64, op, nxv2i64, nxv2i1, nxv2i64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Widening Integer Arithmetic Group
- //===----------------------------------------------------------------------===//
- class sve2_wide_int_arith<bits<2> sz, bits<5> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2, ZPRRegOp zprty3>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn, zprty3:$Zm),
- asm, "\t$Zd, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15} = 0b0;
- let Inst{14-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_wide_int_arith_long<bits<5> opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_wide_int_arith<0b01, opc, asm, ZPR16, ZPR8, ZPR8>;
- def _S : sve2_wide_int_arith<0b10, opc, asm, ZPR32, ZPR16, ZPR16>;
- def _D : sve2_wide_int_arith<0b11, opc, asm, ZPR64, ZPR32, ZPR32>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_wide_int_arith_wide<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_wide_int_arith<0b01, { 0b10, opc }, asm, ZPR16, ZPR16, ZPR8>;
- def _S : sve2_wide_int_arith<0b10, { 0b10, opc }, asm, ZPR32, ZPR32, ZPR16>;
- def _D : sve2_wide_int_arith<0b11, { 0b10, opc }, asm, ZPR64, ZPR64, ZPR32>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv8i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_wide_int_arith_pmul<bits<2> sz, bits<5> opc, string asm,
- SDPatternOperator op> {
- def NAME : sve2_wide_int_arith<sz, opc, asm, ZPR128, ZPR64, ZPR64>;
- // To avoid using 128 bit elements in the IR, the pattern below works with
- // llvm intrinsics with the _pair suffix, to reflect that
- // _Q is implemented as a pair of _D.
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME)>;
- }
- multiclass sve2_pmul_long<bits<1> opc, string asm, SDPatternOperator op> {
- def _H : sve2_wide_int_arith<0b01, {0b1101, opc}, asm, ZPR16, ZPR8, ZPR8>;
- def _D : sve2_wide_int_arith<0b11, {0b1101, opc}, asm, ZPR64, ZPR32, ZPR32>;
- // To avoid using 128 bit elements in the IR, the patterns below work with
- // llvm intrinsics with the _pair suffix, to reflect that
- // _H is implemented as a pair of _B and _D is implemented as a pair of _S.
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Misc Group
- //===----------------------------------------------------------------------===//
- class sve2_misc<bits<2> sz, bits<4> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn, zprty2:$Zm),
- asm, "\t$Zd, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-14} = 0b10;
- let Inst{13-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_misc_bitwise<bits<4> opc, string asm, SDPatternOperator op> {
- def _B : sve2_misc<0b00, opc, asm, ZPR8, ZPR8>;
- def _H : sve2_misc<0b01, opc, asm, ZPR16, ZPR16>;
- def _S : sve2_misc<0b10, opc, asm, ZPR32, ZPR32>;
- def _D : sve2_misc<0b11, opc, asm, ZPR64, ZPR64>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_misc_int_addsub_long_interleaved<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_misc<0b01, { 0b00, opc }, asm, ZPR16, ZPR8>;
- def _S : sve2_misc<0b10, { 0b00, opc }, asm, ZPR32, ZPR16>;
- def _D : sve2_misc<0b11, { 0b00, opc }, asm, ZPR64, ZPR32>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_bitwise_xor_interleaved<bits<2> sz, bits<1> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty1:$_Zd, zprty2:$Zn, zprty2:$Zm),
- asm, "\t$Zd, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-11} = 0b10010;
- let Inst{10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_bitwise_xor_interleaved<bit opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_bitwise_xor_interleaved<0b00, opc, asm, ZPR8, ZPR8>;
- def _H : sve2_bitwise_xor_interleaved<0b01, opc, asm, ZPR16, ZPR16>;
- def _S : sve2_bitwise_xor_interleaved<0b10, opc, asm, ZPR32, ZPR32>;
- def _D : sve2_bitwise_xor_interleaved<0b11, opc, asm, ZPR64, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_bitwise_shift_left_long<bits<3> tsz8_64, bits<2> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2,
- Operand immtype>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn, immtype:$imm),
- asm, "\t$Zd, $Zn, $imm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> imm;
- let Inst{31-23} = 0b010001010;
- let Inst{22} = tsz8_64{2};
- let Inst{21} = 0b0;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-16} = imm{2-0}; // imm3
- let Inst{15-12} = 0b1010;
- let Inst{11-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_bitwise_shift_left_long<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_bitwise_shift_left_long<{0,0,1}, opc, asm,
- ZPR16, ZPR8, vecshiftL8>;
- def _S : sve2_bitwise_shift_left_long<{0,1,?}, opc, asm,
- ZPR32, ZPR16, vecshiftL16> {
- let Inst{19} = imm{3};
- }
- def _D : sve2_bitwise_shift_left_long<{1,?,?}, opc, asm,
- ZPR64, ZPR32, vecshiftL32> {
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_2_Op_Imm_Pat<nxv8i16, op, nxv16i8, i32, tvecshiftL8, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Imm_Pat<nxv4i32, op, nxv8i16, i32, tvecshiftL16, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Imm_Pat<nxv2i64, op, nxv4i32, i32, tvecshiftL32, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Accumulate Group
- //===----------------------------------------------------------------------===//
- class sve2_int_bin_shift_imm<bits<4> tsz8_64, bit opc, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, zprty:$Zn, immtype:$imm),
- asm, "\t$Zd, $Zn, $imm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<6> imm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = tsz8_64{3-2};
- let Inst{21} = 0b0;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-16} = imm{2-0}; // imm3
- let Inst{15-11} = 0b11110;
- let Inst{10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2_int_bin_shift_imm_left<bit opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_bin_shift_imm<{0,0,0,1}, opc, asm, ZPR8, vecshiftL8>;
- def _H : sve2_int_bin_shift_imm<{0,0,1,?}, opc, asm, ZPR16, vecshiftL16> {
- let Inst{19} = imm{3};
- }
- def _S : sve2_int_bin_shift_imm<{0,1,?,?}, opc, asm, ZPR32, vecshiftL32> {
- let Inst{20-19} = imm{4-3};
- }
- def _D : sve2_int_bin_shift_imm<{1,?,?,?}, opc, asm, ZPR64, vecshiftL64> {
- let Inst{22} = imm{5};
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv16i8, i32, tvecshiftL8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, i32, tvecshiftL16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, i32, tvecshiftL32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, i32, tvecshiftL64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_int_bin_shift_imm_right<bit opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_bin_shift_imm<{0,0,0,1}, opc, asm, ZPR8, vecshiftR8>;
- def _H : sve2_int_bin_shift_imm<{0,0,1,?}, opc, asm, ZPR16, vecshiftR16> {
- let Inst{19} = imm{3};
- }
- def _S : sve2_int_bin_shift_imm<{0,1,?,?}, opc, asm, ZPR32, vecshiftR32> {
- let Inst{20-19} = imm{4-3};
- }
- def _D : sve2_int_bin_shift_imm<{1,?,?,?}, opc, asm, ZPR64, vecshiftR64> {
- let Inst{22} = imm{5};
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv16i8, i32, tvecshiftR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, i32, tvecshiftR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, i32, tvecshiftR32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, i32, tvecshiftR64, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_int_bin_accum_shift_imm<bits<4> tsz8_64, bits<2> opc, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zda), (ins zprty:$_Zda, zprty:$Zn, immtype:$imm),
- asm, "\t$Zda, $Zn, $imm",
- "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<6> imm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = tsz8_64{3-2};
- let Inst{21} = 0b0;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-16} = imm{2-0}; // imm3
- let Inst{15-12} = 0b1110;
- let Inst{11-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_int_bin_accum_shift_imm_right<bits<2> opc, string asm,
- SDPatternOperator op,
- SDPatternOperator shift_op = null_frag> {
- def _B : sve2_int_bin_accum_shift_imm<{0,0,0,1}, opc, asm, ZPR8, vecshiftR8>;
- def _H : sve2_int_bin_accum_shift_imm<{0,0,1,?}, opc, asm, ZPR16, vecshiftR16> {
- let Inst{19} = imm{3};
- }
- def _S : sve2_int_bin_accum_shift_imm<{0,1,?,?}, opc, asm, ZPR32, vecshiftR32> {
- let Inst{20-19} = imm{4-3};
- }
- def _D : sve2_int_bin_accum_shift_imm<{1,?,?,?}, opc, asm, ZPR64, vecshiftR64> {
- let Inst{22} = imm{5};
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv16i8, i32, tvecshiftR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, i32, tvecshiftR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, i32, tvecshiftR32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, i32, tvecshiftR64, !cast<Instruction>(NAME # _D)>;
- def : SVE_Shift_Add_All_Active_Pat<nxv16i8, shift_op, nxv16i1, nxv16i8, nxv16i8, i32, !cast<Instruction>(NAME # _B)>;
- def : SVE_Shift_Add_All_Active_Pat<nxv8i16, shift_op, nxv8i1, nxv8i16, nxv8i16, i32, !cast<Instruction>(NAME # _H)>;
- def : SVE_Shift_Add_All_Active_Pat<nxv4i32, shift_op, nxv4i1, nxv4i32, nxv4i32, i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_Shift_Add_All_Active_Pat<nxv2i64, shift_op, nxv2i1, nxv2i64, nxv2i64, i32, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_int_cadd<bits<2> sz, bit opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, zprty:$Zm, complexrotateopodd:$rot),
- asm, "\t$Zdn, $_Zdn, $Zm, $rot", "", []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zm;
- bit rot;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = sz;
- let Inst{21-17} = 0b00000;
- let Inst{16} = opc;
- let Inst{15-11} = 0b11011;
- let Inst{10} = rot;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_int_cadd<bit opc, string asm, SDPatternOperator op> {
- def _B : sve2_int_cadd<0b00, opc, asm, ZPR8>;
- def _H : sve2_int_cadd<0b01, opc, asm, ZPR16>;
- def _S : sve2_int_cadd<0b10, opc, asm, ZPR32>;
- def _D : sve2_int_cadd<0b11, opc, asm, ZPR64>;
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv16i8, i32, complexrotateopodd, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, i32, complexrotateopodd, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, i32, complexrotateopodd, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, i32, complexrotateopodd, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_int_absdiff_accum<bits<2> sz, bits<4> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zda), (ins zprty1:$_Zda, zprty2:$Zn, zprty2:$Zm),
- asm, "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-14} = 0b11;
- let Inst{13-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_int_absdiff_accum<bit opc, string asm, SDPatternOperator op> {
- def _B : sve2_int_absdiff_accum<0b00, { 0b111, opc }, asm, ZPR8, ZPR8>;
- def _H : sve2_int_absdiff_accum<0b01, { 0b111, opc }, asm, ZPR16, ZPR16>;
- def _S : sve2_int_absdiff_accum<0b10, { 0b111, opc }, asm, ZPR32, ZPR32>;
- def _D : sve2_int_absdiff_accum<0b11, { 0b111, opc }, asm, ZPR64, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_int_absdiff_accum_long<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _H : sve2_int_absdiff_accum<0b01, { 0b00, opc }, asm, ZPR16, ZPR8>;
- def _S : sve2_int_absdiff_accum<0b10, { 0b00, opc }, asm, ZPR32, ZPR16>;
- def _D : sve2_int_absdiff_accum<0b11, { 0b00, opc }, asm, ZPR64, ZPR32>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve2_int_addsub_long_carry<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _S : sve2_int_absdiff_accum<{ opc{1}, 0b0 }, { 0b010, opc{0} }, asm,
- ZPR32, ZPR32>;
- def _D : sve2_int_absdiff_accum<{ opc{1}, 0b1 }, { 0b010, opc{0} }, asm,
- ZPR64, ZPR64>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Narrowing Group
- //===----------------------------------------------------------------------===//
- class sve2_int_bin_shift_imm_narrow_bottom<bits<3> tsz8_64, bits<3> opc,
- string asm, ZPRRegOp zprty1,
- ZPRRegOp zprty2, Operand immtype>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn, immtype:$imm),
- asm, "\t$Zd, $Zn, $imm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> imm;
- let Inst{31-23} = 0b010001010;
- let Inst{22} = tsz8_64{2};
- let Inst{21} = 0b1;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-16} = imm{2-0}; // imm3
- let Inst{15-14} = 0b00;
- let Inst{13-11} = opc;
- let Inst{10} = 0b0;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_int_bin_shift_imm_right_narrow_bottom<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_bin_shift_imm_narrow_bottom<{0,0,1}, opc, asm, ZPR8, ZPR16,
- tvecshiftR8>;
- def _H : sve2_int_bin_shift_imm_narrow_bottom<{0,1,?}, opc, asm, ZPR16, ZPR32,
- tvecshiftR16> {
- let Inst{19} = imm{3};
- }
- def _S : sve2_int_bin_shift_imm_narrow_bottom<{1,?,?}, opc, asm, ZPR32, ZPR64,
- tvecshiftR32> {
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_2_Op_Imm_Pat<nxv16i8, op, nxv8i16, i32, tvecshiftR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Imm_Pat<nxv8i16, op, nxv4i32, i32, tvecshiftR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Imm_Pat<nxv4i32, op, nxv2i64, i32, tvecshiftR32, !cast<Instruction>(NAME # _S)>;
- }
- class sve2_int_bin_shift_imm_narrow_top<bits<3> tsz8_64, bits<3> opc,
- string asm, ZPRRegOp zprty1,
- ZPRRegOp zprty2, Operand immtype>
- : I<(outs zprty1:$Zd), (ins zprty1:$_Zd, zprty2:$Zn, immtype:$imm),
- asm, "\t$Zd, $Zn, $imm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> imm;
- let Inst{31-23} = 0b010001010;
- let Inst{22} = tsz8_64{2};
- let Inst{21} = 0b1;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-16} = imm{2-0}; // imm3
- let Inst{15-14} = 0b00;
- let Inst{13-11} = opc;
- let Inst{10} = 0b1;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2_int_bin_shift_imm_right_narrow_top<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_bin_shift_imm_narrow_top<{0,0,1}, opc, asm, ZPR8, ZPR16,
- tvecshiftR8>;
- def _H : sve2_int_bin_shift_imm_narrow_top<{0,1,?}, opc, asm, ZPR16, ZPR32,
- tvecshiftR16> {
- let Inst{19} = imm{3};
- }
- def _S : sve2_int_bin_shift_imm_narrow_top<{1,?,?}, opc, asm, ZPR32, ZPR64,
- tvecshiftR32> {
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv8i16, i32, tvecshiftR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv4i32, i32, tvecshiftR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv2i64, i32, tvecshiftR32, !cast<Instruction>(NAME # _S)>;
- }
- class sve2_int_addsub_narrow_high_bottom<bits<2> sz, bits<2> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn, zprty2:$Zm),
- asm, "\t$Zd, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b011;
- let Inst{12-11} = opc; // S, R
- let Inst{10} = 0b0; // Top
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_int_addsub_narrow_high_bottom<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_addsub_narrow_high_bottom<0b01, opc, asm, ZPR8, ZPR16>;
- def _H : sve2_int_addsub_narrow_high_bottom<0b10, opc, asm, ZPR16, ZPR32>;
- def _S : sve2_int_addsub_narrow_high_bottom<0b11, opc, asm, ZPR32, ZPR64>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- class sve2_int_addsub_narrow_high_top<bits<2> sz, bits<2> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty1:$_Zd, zprty2:$Zn, zprty2:$Zm),
- asm, "\t$Zd, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b011;
- let Inst{12-11} = opc; // S, R
- let Inst{10} = 0b1; // Top
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2_int_addsub_narrow_high_top<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_addsub_narrow_high_top<0b01, opc, asm, ZPR8, ZPR16>;
- def _H : sve2_int_addsub_narrow_high_top<0b10, opc, asm, ZPR16, ZPR32>;
- def _S : sve2_int_addsub_narrow_high_top<0b11, opc, asm, ZPR32, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i8, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- class sve2_int_sat_extract_narrow_bottom<bits<3> tsz8_64, bits<2> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty2:$Zn),
- asm, "\t$Zd, $Zn", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-23} = 0b010001010;
- let Inst{22} = tsz8_64{2};
- let Inst{21} = 0b1;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-13} = 0b000010;
- let Inst{12-11} = opc;
- let Inst{10} = 0b0;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_int_sat_extract_narrow_bottom<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_sat_extract_narrow_bottom<0b001, opc, asm, ZPR8, ZPR16>;
- def _H : sve2_int_sat_extract_narrow_bottom<0b010, opc, asm, ZPR16, ZPR32>;
- def _S : sve2_int_sat_extract_narrow_bottom<0b100, opc, asm, ZPR32, ZPR64>;
- def : SVE_1_Op_Pat<nxv16i8, op, nxv8i16, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Pat<nxv8i16, op, nxv4i32, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv4i32, op, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- class sve2_int_sat_extract_narrow_top<bits<3> tsz8_64, bits<2> opc, string asm,
- ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs zprty1:$Zd), (ins zprty1:$_Zd, zprty2:$Zn),
- asm, "\t$Zd, $Zn", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-23} = 0b010001010;
- let Inst{22} = tsz8_64{2};
- let Inst{21} = 0b1;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-13} = 0b000010;
- let Inst{12-11} = opc;
- let Inst{10} = 0b1;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2_int_sat_extract_narrow_top<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _B : sve2_int_sat_extract_narrow_top<0b001, opc, asm, ZPR8, ZPR16>;
- def _H : sve2_int_sat_extract_narrow_top<0b010, opc, asm, ZPR16, ZPR32>;
- def _S : sve2_int_sat_extract_narrow_top<0b100, opc, asm, ZPR32, ZPR64>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv8i16, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv4i32, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Arithmetic - Unary Predicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_un_pred_arit<bits<2> sz8_64, bits<4> opc,
- string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Zd, $Pg/m, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21-20} = 0b01;
- let Inst{19} = opc{0};
- let Inst{18-16} = opc{3-1};
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveUnaryPassthru;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_un_pred_arit_0<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_un_pred_arit<0b00, { opc, 0b0 }, asm, ZPR8>,
- SVEPseudo2Instr<NAME # _B, 1>;
- def _H : sve_int_un_pred_arit<0b01, { opc, 0b0 }, asm, ZPR16>,
- SVEPseudo2Instr<NAME # _H, 1>;
- def _S : sve_int_un_pred_arit<0b10, { opc, 0b0 }, asm, ZPR32>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def _D : sve_int_un_pred_arit<0b11, { opc, 0b0 }, asm, ZPR64>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_1_Op_Passthru_Pat<nxv16i8, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Passthru_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_B : PredOneOpPassthruPseudo<NAME # _B, ZPR8>;
- def _UNDEF_H : PredOneOpPassthruPseudo<NAME # _H, ZPR16>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv16i8, op, nxv16i1, nxv16i8, !cast<Pseudo>(NAME # _UNDEF_B)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- multiclass sve_int_un_pred_arit_0_h<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _H : sve_int_un_pred_arit<0b01, { opc, 0b0 }, asm, ZPR16>,
- SVEPseudo2Instr<NAME # _H, 1>;
- def _S : sve_int_un_pred_arit<0b10, { opc, 0b0 }, asm, ZPR32>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def _D : sve_int_un_pred_arit<0b11, { opc, 0b0 }, asm, ZPR64>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_InReg_Extend<nxv8i16, op, nxv8i1, nxv8i8, !cast<Instruction>(NAME # _H)>;
- def : SVE_InReg_Extend<nxv4i32, op, nxv4i1, nxv4i8, !cast<Instruction>(NAME # _S)>;
- def : SVE_InReg_Extend<nxv2i64, op, nxv2i1, nxv2i8, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_H : PredOneOpPassthruPseudo<NAME # _H, ZPR16>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_InReg_Extend_PassthruUndef<nxv8i16, op, nxv8i1, nxv8i8, !cast<Pseudo>(NAME # _UNDEF_H)>;
- defm : SVE_InReg_Extend_PassthruUndef<nxv4i32, op, nxv4i1, nxv4i8, !cast<Pseudo>(NAME # _UNDEF_S)>;
- defm : SVE_InReg_Extend_PassthruUndef<nxv2i64, op, nxv2i1, nxv2i8, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- multiclass sve_int_un_pred_arit_0_w<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _S : sve_int_un_pred_arit<0b10, { opc, 0b0 }, asm, ZPR32>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def _D : sve_int_un_pred_arit<0b11, { opc, 0b0 }, asm, ZPR64>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_InReg_Extend<nxv4i32, op, nxv4i1, nxv4i16, !cast<Instruction>(NAME # _S)>;
- def : SVE_InReg_Extend<nxv2i64, op, nxv2i1, nxv2i16, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_InReg_Extend_PassthruUndef<nxv4i32, op, nxv4i1, nxv4i16, !cast<Pseudo>(NAME # _UNDEF_S)>;
- defm : SVE_InReg_Extend_PassthruUndef<nxv2i64, op, nxv2i1, nxv2i16, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- multiclass sve_int_un_pred_arit_0_d<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _D : sve_int_un_pred_arit<0b11, { opc, 0b0 }, asm, ZPR64>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_InReg_Extend<nxv2i64, op, nxv2i1, nxv2i32, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_InReg_Extend_PassthruUndef<nxv2i64, op, nxv2i1, nxv2i32, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- multiclass sve_int_un_pred_arit_1<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_un_pred_arit<0b00, { opc, 0b1 }, asm, ZPR8>,
- SVEPseudo2Instr<NAME # _B, 1>;
- def _H : sve_int_un_pred_arit<0b01, { opc, 0b1 }, asm, ZPR16>,
- SVEPseudo2Instr<NAME # _H, 1>;
- def _S : sve_int_un_pred_arit<0b10, { opc, 0b1 }, asm, ZPR32>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def _D : sve_int_un_pred_arit<0b11, { opc, 0b1 }, asm, ZPR64>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_1_Op_Passthru_Pat<nxv16i8, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Passthru_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_B : PredOneOpPassthruPseudo<NAME # _B, ZPR8>;
- def _UNDEF_H : PredOneOpPassthruPseudo<NAME # _H, ZPR16>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv16i8, op, nxv16i1, nxv16i8, !cast<Pseudo>(NAME # _UNDEF_B)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- multiclass sve_int_un_pred_arit_1_fp<bits<3> opc, string asm, SDPatternOperator op> {
- def _H : sve_int_un_pred_arit<0b01, { opc, 0b1 }, asm, ZPR16>,
- SVEPseudo2Instr<NAME # _H, 1>;
- def _S : sve_int_un_pred_arit<0b10, { opc, 0b1 }, asm, ZPR32>,
- SVEPseudo2Instr<NAME # _S, 1>;
- def _D : sve_int_un_pred_arit<0b11, { opc, 0b1 }, asm, ZPR64>,
- SVEPseudo2Instr<NAME # _D, 1>;
- def : SVE_1_Op_Passthru_Pat<nxv8f16, op, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4f16, op, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv2f16, op, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4f32, op, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2f32, op, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2f64, op, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def _UNDEF_H : PredOneOpPassthruPseudo<NAME # _H, ZPR16>;
- def _UNDEF_S : PredOneOpPassthruPseudo<NAME # _S, ZPR32>;
- def _UNDEF_D : PredOneOpPassthruPseudo<NAME # _D, ZPR64>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv8f16, op, nxv8i1, nxv8f16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv4f16, op, nxv4i1, nxv4f16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2f16, op, nxv2i1, nxv2f16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv4f32, op, nxv4i1, nxv4f32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2f32, op, nxv2i1, nxv2f32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- defm : SVE_1_Op_PassthruUndef_Pat<nxv2f64, op, nxv2i1, nxv2f64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Wide Immediate - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_dup_imm<bits<2> sz8_64, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zd), (ins immtype:$imm),
- asm, "\t$Zd, $imm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<9> imm;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-14} = 0b11100011;
- let Inst{13} = imm{8}; // sh
- let Inst{12-5} = imm{7-0}; // imm8
- let Inst{4-0} = Zd;
- let isReMaterializable = 1;
- }
- multiclass sve_int_dup_imm<string asm> {
- def _B : sve_int_dup_imm<0b00, asm, ZPR8, cpy_imm8_opt_lsl_i8>;
- def _H : sve_int_dup_imm<0b01, asm, ZPR16, cpy_imm8_opt_lsl_i16>;
- def _S : sve_int_dup_imm<0b10, asm, ZPR32, cpy_imm8_opt_lsl_i32>;
- def _D : sve_int_dup_imm<0b11, asm, ZPR64, cpy_imm8_opt_lsl_i64>;
- def : InstAlias<"mov $Zd, $imm",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, cpy_imm8_opt_lsl_i8:$imm), 1>;
- def : InstAlias<"mov $Zd, $imm",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, cpy_imm8_opt_lsl_i16:$imm), 1>;
- def : InstAlias<"mov $Zd, $imm",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, cpy_imm8_opt_lsl_i32:$imm), 1>;
- def : InstAlias<"mov $Zd, $imm",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, cpy_imm8_opt_lsl_i64:$imm), 1>;
- def : InstAlias<"fmov $Zd, #0.0",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, 0, 0), 1>;
- def : InstAlias<"fmov $Zd, #0.0",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, 0, 0), 1>;
- def : InstAlias<"fmov $Zd, #0.0",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, 0, 0), 1>;
- }
- class sve_int_dup_fpimm<bits<2> sz8_64, Operand fpimmtype,
- string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins fpimmtype:$imm8),
- asm, "\t$Zd, $imm8",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<8> imm8;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-14} = 0b11100111;
- let Inst{13} = 0b0;
- let Inst{12-5} = imm8;
- let Inst{4-0} = Zd;
- let isReMaterializable = 1;
- }
- multiclass sve_int_dup_fpimm<string asm> {
- def _H : sve_int_dup_fpimm<0b01, fpimm16, asm, ZPR16>;
- def _S : sve_int_dup_fpimm<0b10, fpimm32, asm, ZPR32>;
- def _D : sve_int_dup_fpimm<0b11, fpimm64, asm, ZPR64>;
- def : InstAlias<"fmov $Zd, $imm8",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, fpimm16:$imm8), 1>;
- def : InstAlias<"fmov $Zd, $imm8",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, fpimm32:$imm8), 1>;
- def : InstAlias<"fmov $Zd, $imm8",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, fpimm64:$imm8), 1>;
- }
- class sve_int_arith_imm0<bits<2> sz8_64, bits<3> opc, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, immtype:$imm),
- asm, "\t$Zdn, $_Zdn, $imm",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<9> imm;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-19} = 0b100;
- let Inst{18-16} = opc;
- let Inst{15-14} = 0b11;
- let Inst{13} = imm{8}; // sh
- let Inst{12-5} = imm{7-0}; // imm8
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_arith_imm0<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_arith_imm0<0b00, opc, asm, ZPR8, addsub_imm8_opt_lsl_i8>;
- def _H : sve_int_arith_imm0<0b01, opc, asm, ZPR16, addsub_imm8_opt_lsl_i16>;
- def _S : sve_int_arith_imm0<0b10, opc, asm, ZPR32, addsub_imm8_opt_lsl_i32>;
- def _D : sve_int_arith_imm0<0b11, opc, asm, ZPR64, addsub_imm8_opt_lsl_i64>;
- def : SVE_1_Op_Imm_OptLsl_Pat<nxv16i8, op, ZPR8, i32, SVEAddSubImm8Pat, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Imm_OptLsl_Pat<nxv8i16, op, ZPR16, i32, SVEAddSubImm16Pat, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Imm_OptLsl_Pat<nxv4i32, op, ZPR32, i32, SVEAddSubImm32Pat, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Imm_OptLsl_Pat<nxv2i64, op, ZPR64, i64, SVEAddSubImm64Pat, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_arith_imm<bits<2> sz8_64, bits<6> opc, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, immtype:$imm),
- asm, "\t$Zdn, $_Zdn, $imm",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<8> imm;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21-16} = opc;
- let Inst{15-13} = 0b110;
- let Inst{12-5} = imm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_arith_imm1<bits<2> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_arith_imm<0b00, { 0b1010, opc }, asm, ZPR8, simm8_32b>;
- def _H : sve_int_arith_imm<0b01, { 0b1010, opc }, asm, ZPR16, simm8_32b>;
- def _S : sve_int_arith_imm<0b10, { 0b1010, opc }, asm, ZPR32, simm8_32b>;
- def _D : sve_int_arith_imm<0b11, { 0b1010, opc }, asm, ZPR64, simm8_32b>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv16i8, nxv16i1, op, ZPR8, i32, SVEArithSImmPat32, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv8i16, nxv8i1, op, ZPR16, i32, SVEArithSImmPat32, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv4i32, nxv4i1, op, ZPR32, i32, SVEArithSImmPat32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv2i64, nxv2i1, op, ZPR64, i64, SVEArithSImmPat64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_arith_imm1_unsigned<bits<2> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_arith_imm<0b00, { 0b1010, opc }, asm, ZPR8, imm0_255>;
- def _H : sve_int_arith_imm<0b01, { 0b1010, opc }, asm, ZPR16, imm0_255>;
- def _S : sve_int_arith_imm<0b10, { 0b1010, opc }, asm, ZPR32, imm0_255>;
- def _D : sve_int_arith_imm<0b11, { 0b1010, opc }, asm, ZPR64, imm0_255>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv16i8, nxv16i1, op, ZPR8, i32, SVEArithUImm8Pat, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv8i16, nxv8i1, op, ZPR16, i32, SVEArithUImm16Pat, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv4i32, nxv4i1, op, ZPR32, i32, SVEArithUImm32Pat, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv2i64, nxv2i1, op, ZPR64, i64, SVEArithUImm64Pat, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_arith_imm2<string asm, SDPatternOperator op> {
- def _B : sve_int_arith_imm<0b00, 0b110000, asm, ZPR8, simm8_32b>;
- def _H : sve_int_arith_imm<0b01, 0b110000, asm, ZPR16, simm8_32b>;
- def _S : sve_int_arith_imm<0b10, 0b110000, asm, ZPR32, simm8_32b>;
- def _D : sve_int_arith_imm<0b11, 0b110000, asm, ZPR64, simm8_32b>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv16i8, nxv16i1, op, ZPR8, i32, SVEArithSImmPat32, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv8i16, nxv8i1, op, ZPR16, i32, SVEArithSImmPat32, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv4i32, nxv4i1, op, ZPR32, i32, SVEArithSImmPat32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Imm_Arith_All_Active<nxv2i64, nxv2i1, op, ZPR64, i64, SVEArithSImmPat64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Bitwise Logical - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_bin_cons_log<bits<2> opc, string asm>
- : I<(outs ZPR64:$Zd), (ins ZPR64:$Zn, ZPR64:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc{1-0};
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b001100;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_bin_cons_log<bits<2> opc, string asm, SDPatternOperator op> {
- def NAME : sve_int_bin_cons_log<opc, asm>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME)>;
- def : InstAlias<asm # "\t$Zd, $Zn, $Zm",
- (!cast<Instruction>(NAME) ZPR8:$Zd, ZPR8:$Zn, ZPR8:$Zm), 1>;
- def : InstAlias<asm # "\t$Zd, $Zn, $Zm",
- (!cast<Instruction>(NAME) ZPR16:$Zd, ZPR16:$Zn, ZPR16:$Zm), 1>;
- def : InstAlias<asm # "\t$Zd, $Zn, $Zm",
- (!cast<Instruction>(NAME) ZPR32:$Zd, ZPR32:$Zn, ZPR32:$Zm), 1>;
- }
- class sve2_int_bitwise_ternary_op_d<bits<3> opc, string asm>
- : I<(outs ZPR64:$Zdn), (ins ZPR64:$_Zdn, ZPR64:$Zm, ZPR64:$Zk),
- asm, "\t$Zdn, $_Zdn, $Zm, $Zk",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zk;
- bits<5> Zm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc{2-1};
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-11} = 0b00111;
- let Inst{10} = opc{0};
- let Inst{9-5} = Zk;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_int_bitwise_ternary_op<bits<3> opc, string asm, SDPatternOperator op,
- SDPatternOperator ir_op = null_frag> {
- def NAME : sve2_int_bitwise_ternary_op_d<opc, asm>;
- def : InstAlias<asm # "\t$Zdn, $Zdn, $Zm, $Zk",
- (!cast<Instruction>(NAME) ZPR8:$Zdn, ZPR8:$Zm, ZPR8:$Zk), 1>;
- def : InstAlias<asm # "\t$Zdn, $Zdn, $Zm, $Zk",
- (!cast<Instruction>(NAME) ZPR16:$Zdn, ZPR16:$Zm, ZPR16:$Zk), 1>;
- def : InstAlias<asm # "\t$Zdn, $Zdn, $Zm, $Zk",
- (!cast<Instruction>(NAME) ZPR32:$Zdn, ZPR32:$Zm, ZPR32:$Zk), 1>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_BSP_Pat<nxv16i8, ir_op, nxv16i8, nxv16i8, nxv16i8, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_BSP_Pat<nxv8i16, ir_op, nxv8i16, nxv8i16, nxv8i16, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_BSP_Pat<nxv4i32, ir_op, nxv4i32, nxv4i32, nxv4i32, !cast<Instruction>(NAME)>;
- def : SVE_3_Op_BSP_Pat<nxv2i64, ir_op, nxv2i64, nxv2i64, nxv2i64, !cast<Instruction>(NAME)>;
- }
- class sve2_int_rotate_right_imm<bits<4> tsz8_64, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, zprty:$Zm, immtype:$imm),
- asm, "\t$Zdn, $_Zdn, $Zm, $imm",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zm;
- bits<6> imm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = tsz8_64{3-2};
- let Inst{21} = 0b1;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-16} = imm{2-0}; // imm3
- let Inst{15-10} = 0b001101;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve2_int_rotate_right_imm<string asm, SDPatternOperator op> {
- def _B : sve2_int_rotate_right_imm<{0,0,0,1}, asm, ZPR8, vecshiftR8>;
- def _H : sve2_int_rotate_right_imm<{0,0,1,?}, asm, ZPR16, vecshiftR16> {
- let Inst{19} = imm{3};
- }
- def _S : sve2_int_rotate_right_imm<{0,1,?,?}, asm, ZPR32, vecshiftR32> {
- let Inst{20-19} = imm{4-3};
- }
- def _D : sve2_int_rotate_right_imm<{1,?,?,?}, asm, ZPR64, vecshiftR64> {
- let Inst{22} = imm{5};
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i8, nxv16i8, i32, tvecshiftR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i16, nxv8i16, i32, tvecshiftR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv4i32, i32, tvecshiftR32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i64, nxv2i64, i32, tvecshiftR64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Wide Immediate - Predicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_dup_fpimm_pred<bits<2> sz, Operand fpimmtype,
- string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, PPRAny:$Pg, fpimmtype:$imm8),
- asm, "\t$Zd, $Pg/m, $imm8",
- "",
- []>, Sched<[]> {
- bits<4> Pg;
- bits<5> Zd;
- bits<8> imm8;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz;
- let Inst{21-20} = 0b01;
- let Inst{19-16} = Pg;
- let Inst{15-13} = 0b110;
- let Inst{12-5} = imm8;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_dup_fpimm_pred<string asm> {
- def _H : sve_int_dup_fpimm_pred<0b01, fpimm16, asm, ZPR16>;
- def _S : sve_int_dup_fpimm_pred<0b10, fpimm32, asm, ZPR32>;
- def _D : sve_int_dup_fpimm_pred<0b11, fpimm64, asm, ZPR64>;
- def : InstAlias<"fmov $Zd, $Pg/m, $imm8",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, PPRAny:$Pg, fpimm16:$imm8), 1>;
- def : InstAlias<"fmov $Zd, $Pg/m, $imm8",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, PPRAny:$Pg, fpimm32:$imm8), 1>;
- def : InstAlias<"fmov $Zd, $Pg/m, $imm8",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, PPRAny:$Pg, fpimm64:$imm8), 1>;
- }
- class sve_int_dup_imm_pred<bits<2> sz8_64, bit m, string asm,
- ZPRRegOp zprty, string pred_qual, dag iops>
- : I<(outs zprty:$Zd), iops,
- asm, "\t$Zd, $Pg"#pred_qual#", $imm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<4> Pg;
- bits<9> imm;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-20} = 0b01;
- let Inst{19-16} = Pg;
- let Inst{15} = 0b0;
- let Inst{14} = m;
- let Inst{13} = imm{8}; // sh
- let Inst{12-5} = imm{7-0}; // imm8
- let Inst{4-0} = Zd;
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_dup_imm_pred_merge_inst<
- bits<2> sz8_64, string asm, ZPRRegOp zprty, imm8_opt_lsl cpyimm,
- ValueType intty, ValueType predty, ValueType scalarty, ComplexPattern cpx> {
- let Constraints = "$Zd = $_Zd" in
- def NAME : sve_int_dup_imm_pred<sz8_64, 1, asm, zprty, "/m",
- (ins zprty:$_Zd, PPRAny:$Pg, cpyimm:$imm)>;
- def : InstAlias<"mov $Zd, $Pg/m, $imm",
- (!cast<Instruction>(NAME) zprty:$Zd, PPRAny:$Pg, cpyimm:$imm), 1>;
- def : Pat<(vselect predty:$Pg,
- (intty (splat_vector (scalarty (cpx i32:$imm, i32:$shift)))),
- ZPR:$Zd),
- (!cast<Instruction>(NAME) $Zd, $Pg, $imm, $shift)>;
- }
- multiclass sve_int_dup_imm_pred_merge<string asm> {
- defm _B : sve_int_dup_imm_pred_merge_inst<0b00, asm, ZPR8, cpy_imm8_opt_lsl_i8,
- nxv16i8, nxv16i1, i32, SVECpyDupImm8Pat>;
- defm _H : sve_int_dup_imm_pred_merge_inst<0b01, asm, ZPR16, cpy_imm8_opt_lsl_i16,
- nxv8i16, nxv8i1, i32, SVECpyDupImm16Pat>;
- defm _S : sve_int_dup_imm_pred_merge_inst<0b10, asm, ZPR32, cpy_imm8_opt_lsl_i32,
- nxv4i32, nxv4i1, i32, SVECpyDupImm32Pat>;
- defm _D : sve_int_dup_imm_pred_merge_inst<0b11, asm, ZPR64, cpy_imm8_opt_lsl_i64,
- nxv2i64, nxv2i1, i64, SVECpyDupImm64Pat>;
- def : InstAlias<"fmov $Zd, $Pg/m, #0.0",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, PPRAny:$Pg, 0, 0), 0>;
- def : InstAlias<"fmov $Zd, $Pg/m, #0.0",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, PPRAny:$Pg, 0, 0), 0>;
- def : InstAlias<"fmov $Zd, $Pg/m, #0.0",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, PPRAny:$Pg, 0, 0), 0>;
- def : Pat<(vselect PPRAny:$Pg, (SVEDup0), (nxv8f16 ZPR:$Zd)),
- (!cast<Instruction>(NAME # _H) $Zd, $Pg, 0, 0)>;
- def : Pat<(vselect PPRAny:$Pg, (SVEDup0), (nxv4f16 ZPR:$Zd)),
- (!cast<Instruction>(NAME # _S) $Zd, $Pg, 0, 0)>;
- def : Pat<(vselect PPRAny:$Pg, (SVEDup0), (nxv2f16 ZPR:$Zd)),
- (!cast<Instruction>(NAME # _D) $Zd, $Pg, 0, 0)>;
- def : Pat<(vselect PPRAny:$Pg, (SVEDup0), (nxv4f32 ZPR:$Zd)),
- (!cast<Instruction>(NAME # _S) $Zd, $Pg, 0, 0)>;
- def : Pat<(vselect PPRAny:$Pg, (SVEDup0), (nxv2f32 ZPR:$Zd)),
- (!cast<Instruction>(NAME # _D) $Zd, $Pg, 0, 0)>;
- def : Pat<(vselect PPRAny:$Pg, (SVEDup0), (nxv2f64 ZPR:$Zd)),
- (!cast<Instruction>(NAME # _D) $Zd, $Pg, 0, 0)>;
- }
- multiclass sve_int_dup_imm_pred_zero_inst<
- bits<2> sz8_64, string asm, ZPRRegOp zprty, imm8_opt_lsl cpyimm,
- ValueType intty, ValueType predty, ValueType scalarty, ComplexPattern cpx> {
- def NAME : sve_int_dup_imm_pred<sz8_64, 0, asm, zprty, "/z",
- (ins PPRAny:$Pg, cpyimm:$imm)>;
- def : InstAlias<"mov $Zd, $Pg/z, $imm",
- (!cast<Instruction>(NAME) zprty:$Zd, PPRAny:$Pg, cpyimm:$imm), 1>;
- def : Pat<(intty (zext (predty PPRAny:$Ps1))),
- (!cast<Instruction>(NAME) PPRAny:$Ps1, 1, 0)>;
- def : Pat<(intty (sext (predty PPRAny:$Ps1))),
- (!cast<Instruction>(NAME) PPRAny:$Ps1, -1, 0)>;
- def : Pat<(intty (anyext (predty PPRAny:$Ps1))),
- (!cast<Instruction>(NAME) PPRAny:$Ps1, 1, 0)>;
- def : Pat<(vselect predty:$Pg,
- (intty (splat_vector (scalarty (cpx i32:$imm, i32:$shift)))),
- (intty (splat_vector (scalarty 0)))),
- (!cast<Instruction>(NAME) $Pg, $imm, $shift)>;
- }
- multiclass sve_int_dup_imm_pred_zero<string asm> {
- defm _B : sve_int_dup_imm_pred_zero_inst<0b00, asm, ZPR8, cpy_imm8_opt_lsl_i8,
- nxv16i8, nxv16i1, i32, SVECpyDupImm8Pat>;
- defm _H : sve_int_dup_imm_pred_zero_inst<0b01, asm, ZPR16, cpy_imm8_opt_lsl_i16,
- nxv8i16, nxv8i1, i32, SVECpyDupImm16Pat>;
- defm _S : sve_int_dup_imm_pred_zero_inst<0b10, asm, ZPR32, cpy_imm8_opt_lsl_i32,
- nxv4i32, nxv4i1, i32, SVECpyDupImm32Pat>;
- defm _D : sve_int_dup_imm_pred_zero_inst<0b11, asm, ZPR64, cpy_imm8_opt_lsl_i64,
- nxv2i64, nxv2i1, i64, SVECpyDupImm64Pat>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Compare - Vectors Group
- //===----------------------------------------------------------------------===//
- class sve_int_cmp<bit cmp_1, bits<2> sz8_64, bits<3> opc, string asm,
- PPRRegOp pprty, ZPRRegOp zprty1, ZPRRegOp zprty2>
- : I<(outs pprty:$Pd), (ins PPR3bAny:$Pg, zprty1:$Zn, zprty2:$Zm),
- asm, "\t$Pd, $Pg/z, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<3> Pg;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00100100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15} = opc{2};
- let Inst{14} = cmp_1;
- let Inst{13} = opc{1};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- let Defs = [NZCV];
- let ElementSize = pprty.ElementSize;
- let isPTestLike = 1;
- }
- multiclass SVE_SETCC_Pat<CondCode cc, CondCode invcc, ValueType predvt,
- ValueType intvt, Instruction cmp> {
- def : Pat<(predvt (AArch64setcc_z predvt:$Op1, intvt:$Op2, intvt:$Op3, cc)),
- (cmp $Op1, $Op2, $Op3)>;
- def : Pat<(predvt (AArch64setcc_z predvt:$Op1, intvt:$Op2, intvt:$Op3, invcc)),
- (cmp $Op1, $Op3, $Op2)>;
- def : Pat<(predvt (and predvt:$Pg, (AArch64setcc_z (predvt (AArch64ptrue 31)), intvt:$Op2, intvt:$Op3, cc))),
- (cmp $Pg, $Op2, $Op3)>;
- def : Pat<(predvt (and predvt:$Pg, (AArch64setcc_z (predvt (AArch64ptrue 31)), intvt:$Op2, intvt:$Op3, invcc))),
- (cmp $Pg, $Op3, $Op2)>;
- }
- multiclass SVE_SETCC_Pat_With_Zero<CondCode cc, CondCode invcc, ValueType predvt,
- ValueType intvt, Instruction cmp> {
- def : Pat<(predvt (AArch64setcc_z predvt:$Op1, intvt:$Op2, (SVEDup0), cc)),
- (cmp $Op1, $Op2)>;
- def : Pat<(predvt (AArch64setcc_z predvt:$Op1, (SVEDup0), intvt:$Op2, invcc)),
- (cmp $Op1, $Op2)>;
- def : Pat<(predvt (and predvt:$Pg, (AArch64setcc_z (predvt (AArch64ptrue 31)), intvt:$Op1, (SVEDup0), cc))),
- (cmp $Pg, $Op1)>;
- def : Pat<(predvt (and predvt:$Pg, (AArch64setcc_z (predvt (AArch64ptrue 31)), (SVEDup0), intvt:$Op1, invcc))),
- (cmp $Pg, $Op1)>;
- }
- multiclass sve_int_cmp_0<bits<3> opc, string asm, CondCode cc, CondCode invcc> {
- def _B : sve_int_cmp<0b0, 0b00, opc, asm, PPR8, ZPR8, ZPR8>;
- def _H : sve_int_cmp<0b0, 0b01, opc, asm, PPR16, ZPR16, ZPR16>;
- def _S : sve_int_cmp<0b0, 0b10, opc, asm, PPR32, ZPR32, ZPR32>;
- def _D : sve_int_cmp<0b0, 0b11, opc, asm, PPR64, ZPR64, ZPR64>;
- defm : SVE_SETCC_Pat<cc, invcc, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- defm : SVE_SETCC_Pat<cc, invcc, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat<cc, invcc, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat<cc, invcc, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_cmp_0_wide<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_cmp<0b0, 0b00, opc, asm, PPR8, ZPR8, ZPR64>;
- def _H : sve_int_cmp<0b0, 0b01, opc, asm, PPR16, ZPR16, ZPR64>;
- def _S : sve_int_cmp<0b0, 0b10, opc, asm, PPR32, ZPR32, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i1, op, nxv16i1, nxv16i8, nxv2i64, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i1, op, nxv8i1, nxv8i16, nxv2i64, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i1, op, nxv4i1, nxv4i32, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- multiclass sve_int_cmp_1_wide<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_cmp<0b1, 0b00, opc, asm, PPR8, ZPR8, ZPR64>;
- def _H : sve_int_cmp<0b1, 0b01, opc, asm, PPR16, ZPR16, ZPR64>;
- def _S : sve_int_cmp<0b1, 0b10, opc, asm, PPR32, ZPR32, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i1, op, nxv16i1, nxv16i8, nxv2i64, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i1, op, nxv8i1, nxv8i16, nxv2i64, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i1, op, nxv4i1, nxv4i32, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Compare - Signed Immediate Group
- //===----------------------------------------------------------------------===//
- class sve_int_scmp_vi<bits<2> sz8_64, bits<3> opc, string asm, PPRRegOp pprty,
- ZPRRegOp zprty,
- Operand immtype>
- : I<(outs pprty:$Pd), (ins PPR3bAny:$Pg, zprty:$Zn, immtype:$imm5),
- asm, "\t$Pd, $Pg/z, $Zn, $imm5",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<3> Pg;
- bits<5> Zn;
- bits<5> imm5;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b0;
- let Inst{20-16} = imm5;
- let Inst{15} = opc{2};
- let Inst{14} = 0b0;
- let Inst{13} = opc{1};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- let Defs = [NZCV];
- let ElementSize = pprty.ElementSize;
- let isPTestLike = 1;
- }
- multiclass SVE_SETCC_Imm_Pat<CondCode cc, CondCode commuted_cc,
- ValueType predvt, ValueType intvt,
- Operand immtype, Instruction cmp> {
- def : Pat<(predvt (AArch64setcc_z (predvt PPR_3b:$Pg),
- (intvt ZPR:$Zs1),
- (intvt (splat_vector (immtype:$imm))),
- cc)),
- (cmp $Pg, $Zs1, immtype:$imm)>;
- def : Pat<(predvt (AArch64setcc_z (predvt PPR_3b:$Pg),
- (intvt (splat_vector (immtype:$imm))),
- (intvt ZPR:$Zs1),
- commuted_cc)),
- (cmp $Pg, $Zs1, immtype:$imm)>;
- def : Pat<(predvt (and predvt:$Pg,
- (AArch64setcc_z (predvt (AArch64ptrue 31)),
- (intvt ZPR:$Zs1),
- (intvt (splat_vector (immtype:$imm))),
- cc))),
- (cmp $Pg, $Zs1, immtype:$imm)>;
- def : Pat<(predvt (and predvt:$Pg,
- (AArch64setcc_z (predvt (AArch64ptrue 31)),
- (intvt (splat_vector (immtype:$imm))),
- (intvt ZPR:$Zs1),
- commuted_cc))),
- (cmp $Pg, $Zs1, immtype:$imm)>;
- }
- multiclass sve_int_scmp_vi<bits<3> opc, string asm, CondCode cc, CondCode commuted_cc> {
- def _B : sve_int_scmp_vi<0b00, opc, asm, PPR8, ZPR8, simm5_32b>;
- def _H : sve_int_scmp_vi<0b01, opc, asm, PPR16, ZPR16, simm5_32b>;
- def _S : sve_int_scmp_vi<0b10, opc, asm, PPR32, ZPR32, simm5_32b>;
- def _D : sve_int_scmp_vi<0b11, opc, asm, PPR64, ZPR64, simm5_64b>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv16i1, nxv16i8, simm5_32b,
- !cast<Instruction>(NAME # _B)>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv8i1, nxv8i16, simm5_32b,
- !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv4i1, nxv4i32, simm5_32b,
- !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv2i1, nxv2i64, simm5_64b,
- !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Compare - Unsigned Immediate Group
- //===----------------------------------------------------------------------===//
- class sve_int_ucmp_vi<bits<2> sz8_64, bits<2> opc, string asm, PPRRegOp pprty,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs pprty:$Pd), (ins PPR3bAny:$Pg, zprty:$Zn, immtype:$imm7),
- asm, "\t$Pd, $Pg/z, $Zn, $imm7",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<3> Pg;
- bits<5> Zn;
- bits<7> imm7;
- let Inst{31-24} = 0b00100100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 1;
- let Inst{20-14} = imm7;
- let Inst{13} = opc{1};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- let Defs = [NZCV];
- let ElementSize = pprty.ElementSize;
- let isPTestLike = 1;
- }
- multiclass sve_int_ucmp_vi<bits<2> opc, string asm, CondCode cc,
- CondCode commuted_cc> {
- def _B : sve_int_ucmp_vi<0b00, opc, asm, PPR8, ZPR8, imm0_127>;
- def _H : sve_int_ucmp_vi<0b01, opc, asm, PPR16, ZPR16, imm0_127>;
- def _S : sve_int_ucmp_vi<0b10, opc, asm, PPR32, ZPR32, imm0_127>;
- def _D : sve_int_ucmp_vi<0b11, opc, asm, PPR64, ZPR64, imm0_127_64b>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv16i1, nxv16i8, imm0_127,
- !cast<Instruction>(NAME # _B)>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv8i1, nxv8i16, imm0_127,
- !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv4i1, nxv4i32, imm0_127,
- !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Imm_Pat<cc, commuted_cc, nxv2i1, nxv2i64, imm0_127_64b,
- !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Compare - Scalars Group
- //===----------------------------------------------------------------------===//
- class sve_int_cterm<bit sz, bit opc, string asm, RegisterClass rt>
- : I<(outs), (ins rt:$Rn, rt:$Rm),
- asm, "\t$Rn, $Rm",
- "",
- []>, Sched<[]> {
- bits<5> Rm;
- bits<5> Rn;
- let Inst{31-23} = 0b001001011;
- let Inst{22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-10} = 0b001000;
- let Inst{9-5} = Rn;
- let Inst{4} = opc;
- let Inst{3-0} = 0b0000;
- let Defs = [NZCV];
- }
- class sve_int_while_rr<bits<2> sz8_64, bits<4> opc, string asm,
- RegisterClass gprty, PPRRegOp pprty>
- : I<(outs pprty:$Pd), (ins gprty:$Rn, gprty:$Rm),
- asm, "\t$Pd, $Rn, $Rm",
- "", []>, Sched<[]> {
- bits<4> Pd;
- bits<5> Rm;
- bits<5> Rn;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b000;
- let Inst{12-10} = opc{3-1};
- let Inst{9-5} = Rn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- let Defs = [NZCV];
- let ElementSize = pprty.ElementSize;
- let isWhile = 1;
- }
- multiclass sve_int_while4_rr<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_while_rr<0b00, { 0, opc }, asm, GPR32, PPR8>;
- def _H : sve_int_while_rr<0b01, { 0, opc }, asm, GPR32, PPR16>;
- def _S : sve_int_while_rr<0b10, { 0, opc }, asm, GPR32, PPR32>;
- def _D : sve_int_while_rr<0b11, { 0, opc }, asm, GPR32, PPR64>;
- def : SVE_2_Op_Pat<nxv16i1, op, i32, i32, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i1, op, i32, i32, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i1, op, i32, i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i1, op, i32, i32, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_while8_rr<bits<3> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_while_rr<0b00, { 1, opc }, asm, GPR64, PPR8>;
- def _H : sve_int_while_rr<0b01, { 1, opc }, asm, GPR64, PPR16>;
- def _S : sve_int_while_rr<0b10, { 1, opc }, asm, GPR64, PPR32>;
- def _D : sve_int_while_rr<0b11, { 1, opc }, asm, GPR64, PPR64>;
- def : SVE_2_Op_Pat<nxv16i1, op, i64, i64, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i1, op, i64, i64, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i1, op, i64, i64, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i1, op, i64, i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve2_int_while_rr<bits<2> sz8_64, bits<1> rw, string asm,
- PPRRegOp pprty>
- : I<(outs pprty:$Pd), (ins GPR64:$Rn, GPR64:$Rm),
- asm, "\t$Pd, $Rn, $Rm",
- "", []>, Sched<[]> {
- bits<4> Pd;
- bits<5> Rm;
- bits<5> Rn;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-10} = 0b001100;
- let Inst{9-5} = Rn;
- let Inst{4} = rw;
- let Inst{3-0} = Pd;
- let Defs = [NZCV];
- let ElementSize = pprty.ElementSize;
- let isWhile = 1;
- }
- multiclass sve2_int_while_rr<bits<1> rw, string asm, string op> {
- def _B : sve2_int_while_rr<0b00, rw, asm, PPR8>;
- def _H : sve2_int_while_rr<0b01, rw, asm, PPR16>;
- def _S : sve2_int_while_rr<0b10, rw, asm, PPR32>;
- def _D : sve2_int_while_rr<0b11, rw, asm, PPR64>;
- def : SVE_2_Op_Pat<nxv16i1, !cast<SDPatternOperator>(op # _b), i64, i64, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i1, !cast<SDPatternOperator>(op # _h), i64, i64, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i1, !cast<SDPatternOperator>(op # _s), i64, i64, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i1, !cast<SDPatternOperator>(op # _d), i64, i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Fast Reduction Group
- //===----------------------------------------------------------------------===//
- class sve_fp_fast_red<bits<2> sz, bits<3> opc, string asm,
- ZPRRegOp zprty, FPRasZPROperand dstOpType>
- : I<(outs dstOpType:$Vd), (ins PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Vd, $Pg, $Zn",
- "",
- []>, Sched<[]> {
- bits<5> Zn;
- bits<5> Vd;
- bits<3> Pg;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b000;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Vd;
- }
- multiclass sve_fp_fast_red<bits<3> opc, string asm, SDPatternOperator op> {
- def _H : sve_fp_fast_red<0b01, opc, asm, ZPR16, FPR16asZPR>;
- def _S : sve_fp_fast_red<0b10, opc, asm, ZPR32, FPR32asZPR>;
- def _D : sve_fp_fast_red<0b11, opc, asm, ZPR64, FPR64asZPR>;
- def : SVE_2_Op_Pat<nxv2f16, op, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4f16, op, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv2f32, op, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Accumulating Reduction Group
- //===----------------------------------------------------------------------===//
- class sve_fp_2op_p_vd<bits<2> sz, bits<3> opc, string asm,
- ZPRRegOp zprty, FPRasZPROperand dstOpType>
- : I<(outs dstOpType:$Vdn), (ins PPR3bAny:$Pg, dstOpType:$_Vdn, zprty:$Zm),
- asm, "\t$Vdn, $Pg, $_Vdn, $Zm",
- "",
- []>,
- Sched<[]> {
- bits<3> Pg;
- bits<5> Vdn;
- bits<5> Zm;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b011;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Vdn;
- let Constraints = "$Vdn = $_Vdn";
- }
- multiclass sve_fp_2op_p_vd<bits<3> opc, string asm, SDPatternOperator op> {
- def _H : sve_fp_2op_p_vd<0b01, opc, asm, ZPR16, FPR16asZPR>;
- def _S : sve_fp_2op_p_vd<0b10, opc, asm, ZPR32, FPR32asZPR>;
- def _D : sve_fp_2op_p_vd<0b11, opc, asm, ZPR64, FPR64asZPR>;
- def : SVE_3_Op_Pat<nxv2f16, op, nxv2i1, nxv2f16, nxv2f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f16, op, nxv4i1, nxv4f16, nxv4f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv2f32, op, nxv2i1, nxv2f32, nxv2f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Compare - Vectors Group
- //===----------------------------------------------------------------------===//
- class sve_fp_3op_p_pd<bits<2> sz, bits<3> opc, string asm, PPRRegOp pprty,
- ZPRRegOp zprty>
- : I<(outs pprty:$Pd), (ins PPR3bAny:$Pg, zprty:$Zn, zprty:$Zm),
- asm, "\t$Pd, $Pg/z, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<3> Pg;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15} = opc{2};
- let Inst{14} = 0b1;
- let Inst{13} = opc{1};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- }
- multiclass sve_fp_3op_p_pd<bits<3> opc, string asm, SDPatternOperator op> {
- def _H : sve_fp_3op_p_pd<0b01, opc, asm, PPR16, ZPR16>;
- def _S : sve_fp_3op_p_pd<0b10, opc, asm, PPR32, ZPR32>;
- def _D : sve_fp_3op_p_pd<0b11, opc, asm, PPR64, ZPR64>;
- def : SVE_3_Op_Pat<nxv8i1, op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i1, op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i1, op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_fp_3op_p_pd_cc<bits<3> opc, string asm,
- CondCode cc1, CondCode cc2,
- CondCode invcc1, CondCode invcc2> {
- def _H : sve_fp_3op_p_pd<0b01, opc, asm, PPR16, ZPR16>;
- def _S : sve_fp_3op_p_pd<0b10, opc, asm, PPR32, ZPR32>;
- def _D : sve_fp_3op_p_pd<0b11, opc, asm, PPR64, ZPR64>;
- defm : SVE_SETCC_Pat<cc1, invcc1, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat<cc1, invcc1, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat<cc1, invcc1, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat<cc1, invcc1, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat<cc1, invcc1, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat<cc1, invcc1, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- defm : SVE_SETCC_Pat<cc2, invcc2, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat<cc2, invcc2, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat<cc2, invcc2, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat<cc2, invcc2, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat<cc2, invcc2, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat<cc2, invcc2, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Compare - with Zero Group
- //===----------------------------------------------------------------------===//
- class sve_fp_2op_p_pd<bits<2> sz, bits<3> opc, string asm, PPRRegOp pprty,
- ZPRRegOp zprty>
- : I<(outs pprty:$Pd), (ins PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Pd, $Pg/z, $Zn, #0.0",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<3> Pg;
- bits<5> Zn;
- let Inst{31-24} = 0b01100101;
- let Inst{23-22} = sz;
- let Inst{21-18} = 0b0100;
- let Inst{17-16} = opc{2-1};
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- }
- multiclass sve_fp_2op_p_pd<bits<3> opc, string asm,
- CondCode cc1, CondCode cc2,
- CondCode invcc1, CondCode invcc2> {
- def _H : sve_fp_2op_p_pd<0b01, opc, asm, PPR16, ZPR16>;
- def _S : sve_fp_2op_p_pd<0b10, opc, asm, PPR32, ZPR32>;
- def _D : sve_fp_2op_p_pd<0b11, opc, asm, PPR64, ZPR64>;
- defm : SVE_SETCC_Pat_With_Zero<cc1, invcc1, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat_With_Zero<cc1, invcc1, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat_With_Zero<cc1, invcc1, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat_With_Zero<cc1, invcc1, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat_With_Zero<cc1, invcc1, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat_With_Zero<cc1, invcc1, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- defm : SVE_SETCC_Pat_With_Zero<cc2, invcc2, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat_With_Zero<cc2, invcc2, nxv4i1, nxv4f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat_With_Zero<cc2, invcc2, nxv2i1, nxv2f16, !cast<Instruction>(NAME # _H)>;
- defm : SVE_SETCC_Pat_With_Zero<cc2, invcc2, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat_With_Zero<cc2, invcc2, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- defm : SVE_SETCC_Pat_With_Zero<cc2, invcc2, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- //SVE Index Generation Group
- //===----------------------------------------------------------------------===//
- def simm5_8b_tgt : TImmLeaf<i8, [{ return (int8_t)Imm >= -16 && (int8_t)Imm < 16; }]>;
- def simm5_16b_tgt : TImmLeaf<i16, [{ return (int16_t)Imm >= -16 && (int16_t)Imm < 16; }]>;
- def simm5_32b_tgt : TImmLeaf<i32, [{ return (int32_t)Imm >= -16 && (int32_t)Imm < 16; }]>;
- def simm5_64b_tgt : TImmLeaf<i64, [{ return (int64_t)Imm >= -16 && (int64_t)Imm < 16; }]>;
- def i64imm_32bit_tgt : TImmLeaf<i64, [{
- return (Imm & 0xffffffffULL) == static_cast<uint64_t>(Imm);
- }]>;
- class sve_int_index_ii<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- Operand imm_ty>
- : I<(outs zprty:$Zd), (ins imm_ty:$imm5, imm_ty:$imm5b),
- asm, "\t$Zd, $imm5, $imm5b",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> imm5;
- bits<5> imm5b;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = imm5b;
- let Inst{15-10} = 0b010000;
- let Inst{9-5} = imm5;
- let Inst{4-0} = Zd;
- let isReMaterializable = 1;
- }
- multiclass sve_int_index_ii<string asm> {
- def _B : sve_int_index_ii<0b00, asm, ZPR8, simm5_8b>;
- def _H : sve_int_index_ii<0b01, asm, ZPR16, simm5_16b>;
- def _S : sve_int_index_ii<0b10, asm, ZPR32, simm5_32b>;
- def _D : sve_int_index_ii<0b11, asm, ZPR64, simm5_64b>;
- def : Pat<(nxv16i8 (step_vector simm5_8b_tgt:$imm5b)),
- (!cast<Instruction>(NAME # "_B") (i32 0), (!cast<SDNodeXForm>("trunc_imm") $imm5b))>;
- def : Pat<(nxv8i16 (step_vector simm5_16b_tgt:$imm5b)),
- (!cast<Instruction>(NAME # "_H") (i32 0), (!cast<SDNodeXForm>("trunc_imm") $imm5b))>;
- def : Pat<(nxv4i32 (step_vector simm5_32b_tgt:$imm5b)),
- (!cast<Instruction>(NAME # "_S") (i32 0), simm5_32b:$imm5b)>;
- def : Pat<(nxv2i64 (step_vector simm5_64b_tgt:$imm5b)),
- (!cast<Instruction>(NAME # "_D") (i64 0), simm5_64b:$imm5b)>;
- // add(step_vector(step), dup(X)) -> index(X, step).
- def : Pat<(add (nxv16i8 (step_vector_oneuse simm5_8b_tgt:$imm5b)), (nxv16i8 (splat_vector(simm5_8b:$imm5)))),
- (!cast<Instruction>(NAME # "_B") simm5_8b:$imm5, (!cast<SDNodeXForm>("trunc_imm") $imm5b))>;
- def : Pat<(add (nxv8i16 (step_vector_oneuse simm5_16b_tgt:$imm5b)), (nxv8i16 (splat_vector(simm5_16b:$imm5)))),
- (!cast<Instruction>(NAME # "_H") simm5_16b:$imm5, (!cast<SDNodeXForm>("trunc_imm") $imm5b))>;
- def : Pat<(add (nxv4i32 (step_vector_oneuse simm5_32b_tgt:$imm5b)), (nxv4i32 (splat_vector(simm5_32b:$imm5)))),
- (!cast<Instruction>(NAME # "_S") simm5_32b:$imm5, simm5_32b:$imm5b)>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse simm5_64b_tgt:$imm5b)), (nxv2i64 (splat_vector(simm5_64b:$imm5)))),
- (!cast<Instruction>(NAME # "_D") simm5_64b:$imm5, simm5_64b:$imm5b)>;
- }
- class sve_int_index_ir<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- RegisterClass srcRegType, Operand imm_ty>
- : I<(outs zprty:$Zd), (ins imm_ty:$imm5, srcRegType:$Rm),
- asm, "\t$Zd, $imm5, $Rm",
- "", []>, Sched<[]> {
- bits<5> Rm;
- bits<5> Zd;
- bits<5> imm5;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-10} = 0b010010;
- let Inst{9-5} = imm5;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_index_ir<string asm, SDPatternOperator mulop, SDPatternOperator muloneuseop> {
- def _B : sve_int_index_ir<0b00, asm, ZPR8, GPR32, simm5_8b>;
- def _H : sve_int_index_ir<0b01, asm, ZPR16, GPR32, simm5_16b>;
- def _S : sve_int_index_ir<0b10, asm, ZPR32, GPR32, simm5_32b>;
- def _D : sve_int_index_ir<0b11, asm, ZPR64, GPR64, simm5_64b>;
- def : Pat<(nxv16i8 (step_vector i8:$imm)),
- (!cast<Instruction>(NAME # "_B") (i32 0), (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)))>;
- def : Pat<(nxv8i16 (step_vector i16:$imm)),
- (!cast<Instruction>(NAME # "_H") (i32 0), (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)))>;
- def : Pat<(nxv4i32 (step_vector i32:$imm)),
- (!cast<Instruction>(NAME # "_S") (i32 0), (!cast<Instruction>("MOVi32imm") $imm))>;
- def : Pat<(nxv2i64 (step_vector i64:$imm)),
- (!cast<Instruction>(NAME # "_D") (i64 0), (!cast<Instruction>("MOVi64imm") $imm))>;
- def : Pat<(nxv2i64 (step_vector i64imm_32bit_tgt:$imm)),
- (!cast<Instruction>(NAME # "_D") (i64 0), (SUBREG_TO_REG (i64 0), (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)), sub_32))>;
- // add(step_vector(step), dup(X)) -> index(X, step).
- def : Pat<(add (nxv16i8 (step_vector_oneuse i8:$imm)), (nxv16i8 (splat_vector(simm5_8b:$imm5)))),
- (!cast<Instruction>(NAME # "_B") simm5_8b:$imm5, (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)))>;
- def : Pat<(add (nxv8i16 (step_vector_oneuse i16:$imm)), (nxv8i16 (splat_vector(simm5_16b:$imm5)))),
- (!cast<Instruction>(NAME # "_H") simm5_16b:$imm5, (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)))>;
- def : Pat<(add (nxv4i32 (step_vector_oneuse i32:$imm)), (nxv4i32 (splat_vector(simm5_32b:$imm5)))),
- (!cast<Instruction>(NAME # "_S") simm5_32b:$imm5, (!cast<Instruction>("MOVi32imm") $imm))>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse i64:$imm)), (nxv2i64 (splat_vector(simm5_64b:$imm5)))),
- (!cast<Instruction>(NAME # "_D") simm5_64b:$imm5, (!cast<Instruction>("MOVi64imm") $imm))>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse i64imm_32bit_tgt:$imm)), (nxv2i64 (splat_vector(simm5_64b:$imm5)))),
- (!cast<Instruction>(NAME # "_D") simm5_64b:$imm5, (SUBREG_TO_REG (i64 0), (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)), sub_32))>;
- // mul(step_vector(1), dup(Y)) -> index(0, Y).
- def : Pat<(mulop (nxv16i1 (AArch64ptrue 31)), (nxv16i8 (step_vector_oneuse (i8 1))), (nxv16i8 (splat_vector(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_B") (i32 0), GPR32:$Rm)>;
- def : Pat<(mulop (nxv8i1 (AArch64ptrue 31)), (nxv8i16 (step_vector_oneuse (i16 1))), (nxv8i16 (splat_vector(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_H") (i32 0), GPR32:$Rm)>;
- def : Pat<(mulop (nxv4i1 (AArch64ptrue 31)), (nxv4i32 (step_vector_oneuse (i32 1))), (nxv4i32 (splat_vector(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_S") (i32 0), GPR32:$Rm)>;
- def : Pat<(mulop (nxv2i1 (AArch64ptrue 31)), (nxv2i64 (step_vector_oneuse (i64 1))), (nxv2i64 (splat_vector(i64 GPR64:$Rm)))),
- (!cast<Instruction>(NAME # "_D") (i64 0), GPR64:$Rm)>;
- // add(mul(step_vector(1), dup(Y)), dup(X)) -> index(X, Y).
- def : Pat<(add (muloneuseop (nxv16i1 (AArch64ptrue 31)), (nxv16i8 (step_vector_oneuse (i8 1))), (nxv16i8 (splat_vector(i32 GPR32:$Rm)))), (nxv16i8 (splat_vector(simm5_8b:$imm5)))),
- (!cast<Instruction>(NAME # "_B") simm5_8b:$imm5, GPR32:$Rm)>;
- def : Pat<(add (muloneuseop (nxv8i1 (AArch64ptrue 31)), (nxv8i16 (step_vector_oneuse (i16 1))), (nxv8i16 (splat_vector(i32 GPR32:$Rm)))), (nxv8i16 (splat_vector(simm5_16b:$imm5)))),
- (!cast<Instruction>(NAME # "_H") simm5_16b:$imm5, GPR32:$Rm)>;
- def : Pat<(add (muloneuseop (nxv4i1 (AArch64ptrue 31)), (nxv4i32 (step_vector_oneuse (i32 1))), (nxv4i32 (splat_vector(i32 GPR32:$Rm)))), (nxv4i32 (splat_vector(simm5_32b:$imm5)))),
- (!cast<Instruction>(NAME # "_S") simm5_32b:$imm5, GPR32:$Rm)>;
- def : Pat<(add (muloneuseop (nxv2i1 (AArch64ptrue 31)), (nxv2i64 (step_vector_oneuse (i64 1))), (nxv2i64 (splat_vector(i64 GPR64:$Rm)))), (nxv2i64 (splat_vector(simm5_64b:$imm5)))),
- (!cast<Instruction>(NAME # "_D") simm5_64b:$imm5, GPR64:$Rm)>;
- }
- class sve_int_index_ri<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- RegisterClass srcRegType, Operand imm_ty>
- : I<(outs zprty:$Zd), (ins srcRegType:$Rn, imm_ty:$imm5),
- asm, "\t$Zd, $Rn, $imm5",
- "", []>, Sched<[]> {
- bits<5> Rn;
- bits<5> Zd;
- bits<5> imm5;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = imm5;
- let Inst{15-10} = 0b010001;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_index_ri<string asm> {
- def _B : sve_int_index_ri<0b00, asm, ZPR8, GPR32, simm5_8b>;
- def _H : sve_int_index_ri<0b01, asm, ZPR16, GPR32, simm5_16b>;
- def _S : sve_int_index_ri<0b10, asm, ZPR32, GPR32, simm5_32b>;
- def _D : sve_int_index_ri<0b11, asm, ZPR64, GPR64, simm5_64b>;
- // add(step_vector(step), dup(X)) -> index(X, step).
- def : Pat<(add (nxv16i8 (step_vector_oneuse simm5_8b_tgt:$imm5)), (nxv16i8 (splat_vector(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_B") GPR32:$Rm, (!cast<SDNodeXForm>("trunc_imm") $imm5))>;
- def : Pat<(add (nxv8i16 (step_vector_oneuse simm5_16b_tgt:$imm5)), (nxv8i16 (splat_vector(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_H") GPR32:$Rm, (!cast<SDNodeXForm>("trunc_imm") $imm5))>;
- def : Pat<(add (nxv4i32 (step_vector_oneuse simm5_32b_tgt:$imm5)), (nxv4i32 (splat_vector(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_S") GPR32:$Rm, simm5_32b:$imm5)>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse simm5_64b_tgt:$imm5)), (nxv2i64 (splat_vector(i64 GPR64:$Rm)))),
- (!cast<Instruction>(NAME # "_D") GPR64:$Rm, simm5_64b:$imm5)>;
- }
- class sve_int_index_rr<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- RegisterClass srcRegType>
- : I<(outs zprty:$Zd), (ins srcRegType:$Rn, srcRegType:$Rm),
- asm, "\t$Zd, $Rn, $Rm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Rm;
- bits<5> Rn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-10} = 0b010011;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_index_rr<string asm, SDPatternOperator mulop> {
- def _B : sve_int_index_rr<0b00, asm, ZPR8, GPR32>;
- def _H : sve_int_index_rr<0b01, asm, ZPR16, GPR32>;
- def _S : sve_int_index_rr<0b10, asm, ZPR32, GPR32>;
- def _D : sve_int_index_rr<0b11, asm, ZPR64, GPR64>;
- // add(step_vector(step), dup(X)) -> index(X, step).
- def : Pat<(add (nxv16i8 (step_vector_oneuse i8:$imm)), (nxv16i8 (splat_vector(i32 GPR32:$Rn)))),
- (!cast<Instruction>(NAME # "_B") GPR32:$Rn, (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)))>;
- def : Pat<(add (nxv8i16 (step_vector_oneuse i16:$imm)), (nxv8i16 (splat_vector(i32 GPR32:$Rn)))),
- (!cast<Instruction>(NAME # "_H") GPR32:$Rn, (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)))>;
- def : Pat<(add (nxv4i32 (step_vector_oneuse i32:$imm)), (nxv4i32 (splat_vector(i32 GPR32:$Rn)))),
- (!cast<Instruction>(NAME # "_S") GPR32:$Rn, (!cast<Instruction>("MOVi32imm") $imm))>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse i64:$imm)), (nxv2i64 (splat_vector(i64 GPR64:$Rn)))),
- (!cast<Instruction>(NAME # "_D") GPR64:$Rn, (!cast<Instruction>("MOVi64imm") $imm))>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse i64imm_32bit_tgt:$imm)), (nxv2i64 (splat_vector(i64 GPR64:$Rn)))),
- (!cast<Instruction>(NAME # "_D") GPR64:$Rn, (SUBREG_TO_REG (i64 0), (!cast<Instruction>("MOVi32imm") (!cast<SDNodeXForm>("trunc_imm") $imm)), sub_32))>;
- // add(mul(step_vector(1), dup(Y)), dup(X)) -> index(X, Y).
- def : Pat<(add (mulop (nxv16i1 (AArch64ptrue 31)), (nxv16i8 (step_vector_oneuse (i8 1))), (nxv16i8 (splat_vector(i32 GPR32:$Rm)))), (nxv16i8 (splat_vector(i32 GPR32:$Rn)))),
- (!cast<Instruction>(NAME # "_B") GPR32:$Rn, GPR32:$Rm)>;
- def : Pat<(add (mulop (nxv8i1 (AArch64ptrue 31)), (nxv8i16 (step_vector_oneuse (i16 1))), (nxv8i16 (splat_vector(i32 GPR32:$Rm)))),(nxv8i16 (splat_vector(i32 GPR32:$Rn)))),
- (!cast<Instruction>(NAME # "_H") GPR32:$Rn, GPR32:$Rm)>;
- def : Pat<(add (mulop (nxv4i1 (AArch64ptrue 31)), (nxv4i32 (step_vector_oneuse (i32 1))), (nxv4i32 (splat_vector(i32 GPR32:$Rm)))),(nxv4i32 (splat_vector(i32 GPR32:$Rn)))),
- (!cast<Instruction>(NAME # "_S") GPR32:$Rn, GPR32:$Rm)>;
- def : Pat<(add (mulop (nxv2i1 (AArch64ptrue 31)), (nxv2i64 (step_vector_oneuse (i64 1))), (nxv2i64 (splat_vector(i64 GPR64:$Rm)))),(nxv2i64 (splat_vector(i64 GPR64:$Rn)))),
- (!cast<Instruction>(NAME # "_D") GPR64:$Rn, GPR64:$Rm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Bitwise Shift - Predicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_bin_pred_shift_imm<bits<4> tsz8_64, bits<4> opc, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, immtype:$imm),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $imm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bits<6> imm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = tsz8_64{3-2};
- let Inst{21-20} = 0b00;
- let Inst{19-16} = opc;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-8} = tsz8_64{1-0};
- let Inst{7-5} = imm{2-0}; // imm3
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveBinaryImm;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_bin_pred_shift_imm_left<bits<4> opc, string asm, string Ps,
- SDPatternOperator op = null_frag> {
- def _B : SVEPseudo2Instr<Ps # _B, 1>,
- sve_int_bin_pred_shift_imm<{0,0,0,1}, opc, asm, ZPR8, vecshiftL8>;
- def _H : SVEPseudo2Instr<Ps # _H, 1>,
- sve_int_bin_pred_shift_imm<{0,0,1,?}, opc, asm, ZPR16, vecshiftL16> {
- let Inst{8} = imm{3};
- }
- def _S : SVEPseudo2Instr<Ps # _S, 1>,
- sve_int_bin_pred_shift_imm<{0,1,?,?}, opc, asm, ZPR32, vecshiftL32> {
- let Inst{9-8} = imm{4-3};
- }
- def _D : SVEPseudo2Instr<Ps # _D, 1>,
- sve_int_bin_pred_shift_imm<{1,?,?,?}, opc, asm, ZPR64, vecshiftL64> {
- let Inst{22} = imm{5};
- let Inst{9-8} = imm{4-3};
- }
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i1, nxv16i8, i32, tvecshiftL8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i1, nxv8i16, i32, tvecshiftL16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i1, nxv4i32, i32, tvecshiftL32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i1, nxv2i64, i32, tvecshiftL64, !cast<Instruction>(NAME # _D)>;
- }
- // As above but shift amount takes the form of a "vector immediate".
- multiclass sve_int_bin_pred_shift_imm_left_dup<bits<4> opc, string asm,
- string Ps, SDPatternOperator op>
- : sve_int_bin_pred_shift_imm_left<opc, asm, Ps, null_frag> {
- def : SVE_Shift_DupImm_Pred_Pat<nxv16i8, op, nxv16i1, i32, SVEShiftImmL8, !cast<Instruction>(NAME # _B)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv8i16, op, nxv8i1, i32, SVEShiftImmL16, !cast<Instruction>(NAME # _H)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv4i32, op, nxv4i1, i32, SVEShiftImmL32, !cast<Instruction>(NAME # _S)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv2i64, op, nxv2i1, i64, SVEShiftImmL64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_bin_pred_shift_imm_left_zeroing_bhsd<SDPatternOperator op> {
- def _ZERO_B : PredTwoOpImmPseudo<NAME # _B, ZPR8, tvecshiftL8, FalseLanesZero>;
- def _ZERO_H : PredTwoOpImmPseudo<NAME # _H, ZPR16, tvecshiftL16, FalseLanesZero>;
- def _ZERO_S : PredTwoOpImmPseudo<NAME # _S, ZPR32, tvecshiftL32, FalseLanesZero>;
- def _ZERO_D : PredTwoOpImmPseudo<NAME # _D, ZPR64, tvecshiftL64, FalseLanesZero>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv16i8, op, nxv16i1, nxv16i8, tvecshiftL8, !cast<Pseudo>(NAME # _ZERO_B)>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv8i16, op, nxv8i1, nxv8i16, tvecshiftL16, !cast<Pseudo>(NAME # _ZERO_H)>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv4i32, op, nxv4i1, nxv4i32, tvecshiftL32, !cast<Pseudo>(NAME # _ZERO_S)>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv2i64, op, nxv2i1, nxv2i64, tvecshiftL64, !cast<Pseudo>(NAME # _ZERO_D)>;
- }
- multiclass sve_int_bin_pred_shift_imm_right<bits<4> opc, string asm, string Ps,
- SDPatternOperator op = null_frag> {
- def _B : SVEPseudo2Instr<Ps # _B, 1>,
- sve_int_bin_pred_shift_imm<{0,0,0,1}, opc, asm, ZPR8, vecshiftR8>;
- def _H : SVEPseudo2Instr<Ps # _H, 1>,
- sve_int_bin_pred_shift_imm<{0,0,1,?}, opc, asm, ZPR16, vecshiftR16> {
- let Inst{8} = imm{3};
- }
- def _S : SVEPseudo2Instr<Ps # _S, 1>,
- sve_int_bin_pred_shift_imm<{0,1,?,?}, opc, asm, ZPR32, vecshiftR32> {
- let Inst{9-8} = imm{4-3};
- }
- def _D : SVEPseudo2Instr<Ps # _D, 1>,
- sve_int_bin_pred_shift_imm<{1,?,?,?}, opc, asm, ZPR64, vecshiftR64> {
- let Inst{22} = imm{5};
- let Inst{9-8} = imm{4-3};
- }
- def : SVE_3_Op_Imm_Pat<nxv16i8, op, nxv16i1, nxv16i8, i32, tvecshiftR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Imm_Pat<nxv8i16, op, nxv8i1, nxv8i16, i32, tvecshiftR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Imm_Pat<nxv4i32, op, nxv4i1, nxv4i32, i32, tvecshiftR32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Imm_Pat<nxv2i64, op, nxv2i1, nxv2i64, i32, tvecshiftR64, !cast<Instruction>(NAME # _D)>;
- }
- // As above but shift amount takes the form of a "vector immediate".
- multiclass sve_int_bin_pred_shift_imm_right_dup<bits<4> opc, string asm,
- string Ps, SDPatternOperator op>
- : sve_int_bin_pred_shift_imm_right<opc, asm, Ps, null_frag> {
- def : SVE_Shift_DupImm_Pred_Pat<nxv16i8, op, nxv16i1, i32, SVEShiftImmR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv8i16, op, nxv8i1, i32, SVEShiftImmR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv4i32, op, nxv4i1, i32, SVEShiftImmR32, !cast<Instruction>(NAME # _S)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv2i64, op, nxv2i1, i64, SVEShiftImmR64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_bin_pred_shift_imm_right_zeroing_bhsd<SDPatternOperator op = null_frag> {
- def _ZERO_B : PredTwoOpImmPseudo<NAME # _B, ZPR8, vecshiftR8, FalseLanesZero>;
- def _ZERO_H : PredTwoOpImmPseudo<NAME # _H, ZPR16, vecshiftR16, FalseLanesZero>;
- def _ZERO_S : PredTwoOpImmPseudo<NAME # _S, ZPR32, vecshiftR32, FalseLanesZero>;
- def _ZERO_D : PredTwoOpImmPseudo<NAME # _D, ZPR64, vecshiftR64, FalseLanesZero>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv16i8, op, nxv16i1, nxv16i8, tvecshiftR8, !cast<Pseudo>(NAME # _ZERO_B)>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv8i16, op, nxv8i1, nxv8i16, tvecshiftR16, !cast<Pseudo>(NAME # _ZERO_H)>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv4i32, op, nxv4i1, nxv4i32, tvecshiftR32, !cast<Pseudo>(NAME # _ZERO_S)>;
- def : SVE_3_Op_Pat_Shift_Imm_SelZero<nxv2i64, op, nxv2i1, nxv2i64, tvecshiftR64, !cast<Pseudo>(NAME # _ZERO_D)>;
- }
- class sve_int_bin_pred_shift<bits<2> sz8_64, bit wide, bits<3> opc,
- string asm, ZPRRegOp zprty, ZPRRegOp zprty2>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty2:$Zm),
- asm, "\t$Zdn, $Pg/m, $_Zdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bits<5> Zm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21-20} = 0b01;
- let Inst{19} = wide;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_bin_pred_shift<bits<3> opc, string asm, string Ps,
- SDPatternOperator op, string revname, bit isReverseInstr = 0> {
- let DestructiveInstType = DestructiveBinaryCommWithRev in {
- def _B : sve_int_bin_pred_shift<0b00, 0b0, opc, asm, ZPR8, ZPR8>,
- SVEPseudo2Instr<Ps # _B, 1>, SVEInstr2Rev<NAME # _B, revname # _B, isReverseInstr>;
- def _H : sve_int_bin_pred_shift<0b01, 0b0, opc, asm, ZPR16, ZPR16>,
- SVEPseudo2Instr<Ps # _H, 1>, SVEInstr2Rev<NAME # _H, revname # _H, isReverseInstr>;
- def _S : sve_int_bin_pred_shift<0b10, 0b0, opc, asm, ZPR32, ZPR32>,
- SVEPseudo2Instr<Ps # _S, 1>, SVEInstr2Rev<NAME # _S, revname # _S, isReverseInstr>;
- def _D : sve_int_bin_pred_shift<0b11, 0b0, opc, asm, ZPR64, ZPR64>,
- SVEPseudo2Instr<Ps # _D, 1>, SVEInstr2Rev<NAME # _D, revname # _D, isReverseInstr>;
- }
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_bin_pred_zeroing_bhsd<SDPatternOperator op> {
- def _ZERO_B : PredTwoOpPseudo<NAME # _B, ZPR8, FalseLanesZero>;
- def _ZERO_H : PredTwoOpPseudo<NAME # _H, ZPR16, FalseLanesZero>;
- def _ZERO_S : PredTwoOpPseudo<NAME # _S, ZPR32, FalseLanesZero>;
- def _ZERO_D : PredTwoOpPseudo<NAME # _D, ZPR64, FalseLanesZero>;
- def : SVE_3_Op_Pat_SelZero<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Pseudo>(NAME # _ZERO_B)>;
- def : SVE_3_Op_Pat_SelZero<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Pseudo>(NAME # _ZERO_H)>;
- def : SVE_3_Op_Pat_SelZero<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Pseudo>(NAME # _ZERO_S)>;
- def : SVE_3_Op_Pat_SelZero<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Pseudo>(NAME # _ZERO_D)>;
- }
- multiclass sve_int_bin_pred_shift_wide<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_bin_pred_shift<0b00, 0b1, opc, asm, ZPR8, ZPR64>;
- def _H : sve_int_bin_pred_shift<0b01, 0b1, opc, asm, ZPR16, ZPR64>;
- def _S : sve_int_bin_pred_shift<0b10, 0b1, opc, asm, ZPR32, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv2i64, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv2i64, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Shift - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_bin_cons_shift_wide<bits<2> sz8_64, bits<2> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, ZPR64:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_64;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-12} = 0b1000;
- let Inst{11-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_bin_cons_shift_wide<bits<2> opc, string asm, SDPatternOperator op> {
- def _B : sve_int_bin_cons_shift_wide<0b00, opc, asm, ZPR8>;
- def _H : sve_int_bin_cons_shift_wide<0b01, opc, asm, ZPR16>;
- def _S : sve_int_bin_cons_shift_wide<0b10, opc, asm, ZPR32>;
- def : SVE_2_Op_Pred_All_Active<nxv16i8, op, nxv16i1, nxv16i8, nxv2i64, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pred_All_Active<nxv8i16, op, nxv8i1, nxv8i16, nxv2i64, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pred_All_Active<nxv4i32, op, nxv4i1, nxv4i32, nxv2i64, !cast<Instruction>(NAME # _S)>;
- }
- class sve_int_bin_cons_shift_imm<bits<4> tsz8_64, bits<2> opc, string asm,
- ZPRRegOp zprty, Operand immtype>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, immtype:$imm),
- asm, "\t$Zd, $Zn, $imm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<6> imm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = tsz8_64{3-2};
- let Inst{21} = 0b1;
- let Inst{20-19} = tsz8_64{1-0};
- let Inst{18-16} = imm{2-0}; // imm3
- let Inst{15-12} = 0b1001;
- let Inst{11-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_bin_cons_shift_imm_left<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_bin_cons_shift_imm<{0,0,0,1}, opc, asm, ZPR8, vecshiftL8>;
- def _H : sve_int_bin_cons_shift_imm<{0,0,1,?}, opc, asm, ZPR16, vecshiftL16> {
- let Inst{19} = imm{3};
- }
- def _S : sve_int_bin_cons_shift_imm<{0,1,?,?}, opc, asm, ZPR32, vecshiftL32> {
- let Inst{20-19} = imm{4-3};
- }
- def _D : sve_int_bin_cons_shift_imm<{1,?,?,?}, opc, asm, ZPR64, vecshiftL64> {
- let Inst{22} = imm{5};
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_Shift_DupImm_All_Active_Pat<nxv16i8, op, nxv16i1, i32, SVEShiftImmL8, !cast<Instruction>(NAME # _B)>;
- def : SVE_Shift_DupImm_All_Active_Pat<nxv8i16, op, nxv8i1, i32, SVEShiftImmL16, !cast<Instruction>(NAME # _H)>;
- def : SVE_Shift_DupImm_All_Active_Pat<nxv4i32, op, nxv4i1, i32, SVEShiftImmL32, !cast<Instruction>(NAME # _S)>;
- def : SVE_Shift_DupImm_All_Active_Pat<nxv2i64, op, nxv2i1, i64, SVEShiftImmL64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_bin_cons_shift_imm_right<bits<2> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_bin_cons_shift_imm<{0,0,0,1}, opc, asm, ZPR8, vecshiftR8>;
- def _H : sve_int_bin_cons_shift_imm<{0,0,1,?}, opc, asm, ZPR16, vecshiftR16> {
- let Inst{19} = imm{3};
- }
- def _S : sve_int_bin_cons_shift_imm<{0,1,?,?}, opc, asm, ZPR32, vecshiftR32> {
- let Inst{20-19} = imm{4-3};
- }
- def _D : sve_int_bin_cons_shift_imm<{1,?,?,?}, opc, asm, ZPR64, vecshiftR64> {
- let Inst{22} = imm{5};
- let Inst{20-19} = imm{4-3};
- }
- def : SVE_Shift_DupImm_All_Active_Pat<nxv16i8, op, nxv16i1, i32, SVEShiftImmR8, !cast<Instruction>(NAME # _B)>;
- def : SVE_Shift_DupImm_All_Active_Pat<nxv8i16, op, nxv8i1, i32, SVEShiftImmR16, !cast<Instruction>(NAME # _H)>;
- def : SVE_Shift_DupImm_All_Active_Pat<nxv4i32, op, nxv4i1, i32, SVEShiftImmR32, !cast<Instruction>(NAME # _S)>;
- def : SVE_Shift_DupImm_All_Active_Pat<nxv2i64, op, nxv2i1, i64, SVEShiftImmR64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Memory - Store Group
- //===----------------------------------------------------------------------===//
- class sve_mem_cst_si<bits<2> msz, bits<2> esz, string asm,
- RegisterOperand VecList>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4),
- asm, "\t$Zt, $Pg, [$Rn, $imm4, mul vl]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zt;
- bits<4> imm4;
- let Inst{31-25} = 0b1110010;
- let Inst{24-23} = msz;
- let Inst{22-21} = esz;
- let Inst{20} = 0;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_cst_si<bits<2> msz, bits<2> esz, string asm,
- RegisterOperand listty, ZPRRegOp zprty>
- {
- def NAME : sve_mem_cst_si<msz, esz, asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $imm4, mul vl]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn]",
- (!cast<Instruction>(NAME) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_est_si<bits<2> sz, bits<2> nregs, RegisterOperand VecList,
- string asm, Operand immtype>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, immtype:$imm4),
- asm, "\t$Zt, $Pg, [$Rn, $imm4, mul vl]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zt;
- bits<4> imm4;
- let Inst{31-25} = 0b1110010;
- let Inst{24-23} = sz;
- let Inst{22-21} = nregs;
- let Inst{20} = 1;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_est_si<bits<2> sz, bits<2> nregs, RegisterOperand VecList,
- string asm, Operand immtype> {
- def NAME : sve_mem_est_si<sz, nregs, VecList, asm, immtype>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn]",
- (!cast<Instruction>(NAME) VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- // SVE store multiple structures (quadwords, scalar plus immediate)
- class sve_mem_128b_est_si<bits<2> nregs, RegisterOperand VecList,
- string asm, Operand immtype>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, immtype:$imm4),
- asm, "\t$Zt, $Pg, [$Rn, $imm4, mul vl]",
- "", []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Rn;
- bits<3> Pg;
- bits<4> imm4;
- let Inst{31-24} = 0b11100100;
- let Inst{23-22} = nregs;
- let Inst{21-20} = 0b00;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b000;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_128b_est_si<bits<2> nregs, RegisterOperand VecList,
- string asm, Operand immtype> {
- def NAME : sve_mem_128b_est_si<nregs, VecList, asm, immtype>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn]",
- (!cast<Instruction>(NAME) VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_est_ss<bits<2> sz, bits<2> nregs, RegisterOperand VecList,
- string asm, RegisterOperand gprty>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg, [$Rn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Rn;
- bits<5> Zt;
- let Inst{31-25} = 0b1110010;
- let Inst{24-23} = sz;
- let Inst{22-21} = nregs;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b011;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- // SVE store multiple structures (quadwords, scalar plus scalar)
- class sve_mem_128b_est_ss<bits<2> nregs, RegisterOperand VecList,
- string asm, RegisterOperand gprty>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg, [$Rn, $Rm]",
- "", []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Rn;
- bits<3> Pg;
- bits<5> Rm;
- let Inst{31-24} = 0b11100100;
- let Inst{23-22} = nregs;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b000;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- class sve_mem_cst_ss_base<bits<4> dtype, string asm,
- RegisterOperand listty, RegisterOperand gprty>
- : I<(outs), (ins listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg, [$Rn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Rn;
- bits<5> Zt;
- let Inst{31-25} = 0b1110010;
- let Inst{24-21} = dtype;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b010;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_cst_ss<bits<4> dtype, string asm,
- RegisterOperand listty, ZPRRegOp zprty,
- RegisterOperand gprty> {
- def NAME : sve_mem_cst_ss_base<dtype, asm, listty, gprty>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Rm]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), 0>;
- }
- class sve_mem_cstnt_si<bits<2> msz, string asm, RegisterOperand VecList>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4),
- asm, "\t$Zt, $Pg, [$Rn, $imm4, mul vl]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zt;
- bits<4> imm4;
- let Inst{31-25} = 0b1110010;
- let Inst{24-23} = msz;
- let Inst{22-20} = 0b001;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_cstnt_si<bits<2> msz, string asm, RegisterOperand listty,
- ZPRRegOp zprty> {
- def NAME : sve_mem_cstnt_si<msz, asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $imm4, mul vl]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn]",
- (!cast<Instruction>(NAME) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_cstnt_ss_base<bits<2> msz, string asm, RegisterOperand listty,
- RegisterOperand gprty>
- : I<(outs), (ins listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg, [$Rn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Rn;
- bits<5> Zt;
- let Inst{31-25} = 0b1110010;
- let Inst{24-23} = msz;
- let Inst{22-21} = 0b00;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b011;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_cstnt_ss<bits<2> msz, string asm, RegisterOperand listty,
- ZPRRegOp zprty, RegisterOperand gprty> {
- def NAME : sve_mem_cstnt_ss_base<msz, asm, listty, gprty>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Rm]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), 0>;
- }
- class sve2_mem_sstnt_vs_base<bits<3> opc, string asm,
- RegisterOperand listty, ZPRRegOp zprty>
- : I<(outs), (ins listty:$Zt, PPR3bAny:$Pg, zprty:$Zn, GPR64:$Rm),
- asm, "\t$Zt, $Pg, [$Zn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Zn;
- bits<5> Zt;
- let Inst{31-25} = 0b1110010;
- let Inst{24-22} = opc;
- let Inst{21} = 0b0;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve2_mem_sstnt_vs_32_ptrs<bits<3> opc, string asm,
- SDPatternOperator op,
- ValueType vt> {
- def _REAL : sve2_mem_sstnt_vs_base<opc, asm, Z_s, ZPR32>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn, $Rm]",
- (!cast<Instruction>(NAME # _REAL) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, GPR64:$Rm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, XZR), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) Z_s:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, XZR), 1>;
- def : Pat <(op (nxv4i32 ZPR32:$Zt), (nxv4i1 PPR3bAny:$Pg), (nxv4i32 ZPR32:$Zn), (i64 GPR64:$Rm), vt),
- (!cast<Instruction>(NAME # _REAL) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, GPR64:$Rm)>;
- }
- multiclass sve2_mem_sstnt_vs_64_ptrs<bits<3> opc, string asm,
- SDPatternOperator op,
- ValueType vt> {
- def _REAL : sve2_mem_sstnt_vs_base<opc, asm, Z_d, ZPR64>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn, $Rm]",
- (!cast<Instruction>(NAME # _REAL) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, GPR64:$Rm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, XZR), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) Z_d:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, XZR), 1>;
- def : Pat <(op (nxv2i64 ZPR64:$Zt), (nxv2i1 PPR3bAny:$Pg), (nxv2i64 ZPR64:$Zn), (i64 GPR64:$Rm), vt),
- (!cast<Instruction>(NAME # _REAL) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, GPR64:$Rm)>;
- }
- class sve_mem_sst_sv<bits<3> opc, bit xs, bit scaled, string asm,
- RegisterOperand VecList, RegisterOperand zprext>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm),
- asm, "\t$Zt, $Pg, [$Rn, $Zm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zm;
- bits<5> Zt;
- let Inst{31-25} = 0b1110010;
- let Inst{24-22} = opc;
- let Inst{21} = scaled;
- let Inst{20-16} = Zm;
- let Inst{15} = 0b1;
- let Inst{14} = xs;
- let Inst{13} = 0;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_32b_sst_sv_32_scaled<bits<3> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt > {
- def _UXTW_SCALED : sve_mem_sst_sv<opc, 0, 1, asm, Z_s, uxtw_opnd>;
- def _SXTW_SCALED : sve_mem_sst_sv<opc, 1, 1, asm, Z_s, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW_SCALED) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW_SCALED) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- def : Pat<(uxtw_op (nxv4i32 ZPR:$data), (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _UXTW_SCALED) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- def : Pat<(sxtw_op (nxv4i32 ZPR:$data), (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _SXTW_SCALED) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- multiclass sve_mem_64b_sst_sv_32_scaled<bits<3> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt > {
- def _UXTW_SCALED : sve_mem_sst_sv<opc, 0, 1, asm, Z_d, uxtw_opnd>;
- def _SXTW_SCALED : sve_mem_sst_sv<opc, 1, 1, asm, Z_d, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW_SCALED) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW_SCALED) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- def : Pat<(uxtw_op (nxv2i64 ZPR:$data), (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _UXTW_SCALED) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- def : Pat<(sxtw_op (nxv2i64 ZPR:$data), (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _SXTW_SCALED) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- multiclass sve_mem_64b_sst_sv_32_unscaled<bits<3> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt> {
- def _UXTW : sve_mem_sst_sv<opc, 0, 0, asm, Z_d, uxtw_opnd>;
- def _SXTW : sve_mem_sst_sv<opc, 1, 0, asm, Z_d, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- def : Pat<(uxtw_op (nxv2i64 ZPR:$data), (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _UXTW) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- def : Pat<(sxtw_op (nxv2i64 ZPR:$data), (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _SXTW) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- multiclass sve_mem_32b_sst_sv_32_unscaled<bits<3> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt> {
- def _UXTW : sve_mem_sst_sv<opc, 0, 0, asm, Z_s, uxtw_opnd>;
- def _SXTW : sve_mem_sst_sv<opc, 1, 0, asm, Z_s, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- def : Pat<(uxtw_op (nxv4i32 ZPR:$data), (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _UXTW) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- def : Pat<(sxtw_op (nxv4i32 ZPR:$data), (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME # _SXTW) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- class sve_mem_sst_sv2<bits<2> msz, bit scaled, string asm,
- RegisterOperand zprext>
- : I<(outs), (ins Z_d:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm),
- asm, "\t$Zt, $Pg, [$Rn, $Zm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zm;
- bits<5> Zt;
- let Inst{31-25} = 0b1110010;
- let Inst{24-23} = msz;
- let Inst{22} = 0b0;
- let Inst{21} = scaled;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_sst_sv_64_scaled<bits<2> msz, string asm,
- SDPatternOperator op,
- RegisterOperand zprext,
- ValueType vt> {
- def _SCALED : sve_mem_sst_sv2<msz, 1, asm, zprext>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SCALED) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm), 0>;
- def : Pat<(op (nxv2i64 ZPR:$data), (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$indices), vt),
- (!cast<Instruction>(NAME # _SCALED) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$indices)>;
- }
- multiclass sve_mem_sst_sv_64_unscaled<bits<2> msz, string asm,
- SDPatternOperator op,
- ValueType vt> {
- def NAME : sve_mem_sst_sv2<msz, 0, asm, ZPR64ExtLSL8>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, ZPR64ExtLSL8:$Zm), 0>;
- def : Pat<(op (nxv2i64 ZPR:$data), (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt),
- (!cast<Instruction>(NAME) ZPR:$data, PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- class sve_mem_sst_vi<bits<3> opc, string asm, ZPRRegOp zprty,
- RegisterOperand VecList, Operand imm_ty>
- : I<(outs), (ins VecList:$Zt, PPR3bAny:$Pg, zprty:$Zn, imm_ty:$imm5),
- asm, "\t$Zt, $Pg, [$Zn, $imm5]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> imm5;
- bits<5> Zn;
- bits<5> Zt;
- let Inst{31-25} = 0b1110010;
- let Inst{24-23} = opc{2-1};
- let Inst{22} = 0b1;
- let Inst{21} = opc{0};
- let Inst{20-16} = imm5;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_32b_sst_vi_ptrs<bits<3> opc, string asm,
- Operand imm_ty,
- SDPatternOperator op,
- ValueType vt> {
- def _IMM : sve_mem_sst_vi<opc, asm, ZPR32, Z_s, imm_ty>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _IMM) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn, $imm5]",
- (!cast<Instruction>(NAME # _IMM) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, imm_ty:$imm5), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _IMM) Z_s:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, 0), 1>;
- def : Pat<(op (nxv4i32 ZPR:$data), (nxv4i1 PPR:$gp), (nxv4i32 ZPR:$ptrs), imm_ty:$index, vt),
- (!cast<Instruction>(NAME # _IMM) ZPR:$data, PPR:$gp, ZPR:$ptrs, imm_ty:$index)>;
- }
- multiclass sve_mem_64b_sst_vi_ptrs<bits<3> opc, string asm,
- Operand imm_ty,
- SDPatternOperator op,
- ValueType vt> {
- def _IMM : sve_mem_sst_vi<opc, asm, ZPR64, Z_d, imm_ty>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _IMM) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn, $imm5]",
- (!cast<Instruction>(NAME # _IMM) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, imm_ty:$imm5), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME # _IMM) Z_d:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, 0), 1>;
- def : Pat<(op (nxv2i64 ZPR:$data), (nxv2i1 PPR:$gp), (nxv2i64 ZPR:$ptrs), imm_ty:$index, vt),
- (!cast<Instruction>(NAME # _IMM) ZPR:$data, PPR:$gp, ZPR:$ptrs, imm_ty:$index)>;
- }
- class sve_mem_z_spill<string asm>
- : I<(outs), (ins ZPRAny:$Zt, GPR64sp:$Rn, simm9:$imm9),
- asm, "\t$Zt, [$Rn, $imm9, mul vl]",
- "",
- []>, Sched<[]> {
- bits<5> Rn;
- bits<5> Zt;
- bits<9> imm9;
- let Inst{31-22} = 0b1110010110;
- let Inst{21-16} = imm9{8-3};
- let Inst{15-13} = 0b010;
- let Inst{12-10} = imm9{2-0};
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_z_spill<string asm> {
- def NAME : sve_mem_z_spill<asm>;
- def : InstAlias<asm # "\t$Zt, [$Rn]",
- (!cast<Instruction>(NAME) ZPRAny:$Zt, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_p_spill<string asm>
- : I<(outs), (ins PPRAny:$Pt, GPR64sp:$Rn, simm9:$imm9),
- asm, "\t$Pt, [$Rn, $imm9, mul vl]",
- "",
- []>, Sched<[]> {
- bits<4> Pt;
- bits<5> Rn;
- bits<9> imm9;
- let Inst{31-22} = 0b1110010110;
- let Inst{21-16} = imm9{8-3};
- let Inst{15-13} = 0b000;
- let Inst{12-10} = imm9{2-0};
- let Inst{9-5} = Rn;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pt;
- let mayStore = 1;
- }
- multiclass sve_mem_p_spill<string asm> {
- def NAME : sve_mem_p_spill<asm>;
- def : InstAlias<asm # "\t$Pt, [$Rn]",
- (!cast<Instruction>(NAME) PPRAny:$Pt, GPR64sp:$Rn, 0), 1>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Permute - Predicates Group
- //===----------------------------------------------------------------------===//
- class sve_int_perm_bin_perm_pp<bits<3> opc, bits<2> sz8_64, string asm,
- PPRRegOp pprty, SDPatternOperator op>
- : I<(outs pprty:$Pd), (ins pprty:$Pn, pprty:$Pm),
- asm, "\t$Pd, $Pn, $Pm",
- "",
- [(set nxv16i1:$Pd, (op nxv16i1:$Pn, nxv16i1:$Pm))]>, Sched<[]> {
- bits<4> Pd;
- bits<4> Pm;
- bits<4> Pn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-20} = 0b10;
- let Inst{19-16} = Pm;
- let Inst{15-13} = 0b010;
- let Inst{12-10} = opc;
- let Inst{9} = 0b0;
- let Inst{8-5} = Pn;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pd;
- }
- multiclass sve_int_perm_bin_perm_pp<bits<3> opc, string asm,
- SDPatternOperator ir_op,
- SDPatternOperator op_b16,
- SDPatternOperator op_b32,
- SDPatternOperator op_b64> {
- def _B : sve_int_perm_bin_perm_pp<opc, 0b00, asm, PPR8, ir_op>;
- def _H : sve_int_perm_bin_perm_pp<opc, 0b01, asm, PPR16, op_b16>;
- def _S : sve_int_perm_bin_perm_pp<opc, 0b10, asm, PPR32, op_b32>;
- def _D : sve_int_perm_bin_perm_pp<opc, 0b11, asm, PPR64, op_b64>;
- def : SVE_2_Op_Pat<nxv8i1, ir_op, nxv8i1, nxv8i1, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i1, ir_op, nxv4i1, nxv4i1, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i1, ir_op, nxv2i1, nxv2i1, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_perm_punpk<bit opc, string asm>
- : I<(outs PPR16:$Pd), (ins PPR8:$Pn),
- asm, "\t$Pd, $Pn",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<4> Pn;
- let Inst{31-17} = 0b000001010011000;
- let Inst{16} = opc;
- let Inst{15-9} = 0b0100000;
- let Inst{8-5} = Pn;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pd;
- }
- multiclass sve_int_perm_punpk<bit opc, string asm, SDPatternOperator op> {
- def NAME : sve_int_perm_punpk<opc, asm>;
- def : SVE_1_Op_Pat<nxv8i1, op, nxv16i1, !cast<Instruction>(NAME)>;
- def : SVE_1_Op_Pat<nxv4i1, op, nxv8i1, !cast<Instruction>(NAME)>;
- def : SVE_1_Op_Pat<nxv2i1, op, nxv4i1, !cast<Instruction>(NAME)>;
- }
- class sve_int_rdffr_pred<bit s, string asm>
- : I<(outs PPR8:$Pd), (ins PPRAny:$Pg),
- asm, "\t$Pd, $Pg/z",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<4> Pg;
- let Inst{31-23} = 0b001001010;
- let Inst{22} = s;
- let Inst{21-9} = 0b0110001111000;
- let Inst{8-5} = Pg;
- let Inst{4} = 0;
- let Inst{3-0} = Pd;
- let Defs = !if(s, [NZCV], []);
- let Uses = [FFR];
- }
- multiclass sve_int_rdffr_pred<bit s, string asm, SDPatternOperator op> {
- def _REAL : sve_int_rdffr_pred<s, asm>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def "" : Pseudo<(outs PPR8:$Pd), (ins PPRAny:$Pg), [(set (nxv16i1 PPR8:$Pd), (op (nxv16i1 PPRAny:$Pg)))]>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _REAL) PPR8:$Pd, PPRAny:$Pg)>;
- }
- }
- class sve_int_rdffr_unpred<string asm> : I<
- (outs PPR8:$Pd), (ins),
- asm, "\t$Pd",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- let Inst{31-4} = 0b0010010100011001111100000000;
- let Inst{3-0} = Pd;
- let Uses = [FFR];
- }
- multiclass sve_int_rdffr_unpred<string asm, SDPatternOperator op> {
- def _REAL : sve_int_rdffr_unpred<asm>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def "" : Pseudo<(outs PPR8:$Pd), (ins), [(set (nxv16i1 PPR8:$Pd), (op))]>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _REAL) PPR8:$Pd)>;
- }
- }
- class sve_int_wrffr<string asm, SDPatternOperator op>
- : I<(outs), (ins PPR8:$Pn),
- asm, "\t$Pn",
- "",
- [(op (nxv16i1 PPR8:$Pn))]>, Sched<[]> {
- bits<4> Pn;
- let Inst{31-9} = 0b00100101001010001001000;
- let Inst{8-5} = Pn;
- let Inst{4-0} = 0b00000;
- let hasSideEffects = 1;
- let Defs = [FFR];
- }
- class sve_int_setffr<string asm, SDPatternOperator op>
- : I<(outs), (ins),
- asm, "",
- "",
- [(op)]>, Sched<[]> {
- let Inst{31-0} = 0b00100101001011001001000000000000;
- let hasSideEffects = 1;
- let Defs = [FFR];
- }
- //===----------------------------------------------------------------------===//
- // SVE Permute Vector - Predicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_perm_clast_rz<bits<2> sz8_64, bit ab, string asm,
- ZPRRegOp zprty, RegisterClass rt>
- : I<(outs rt:$Rdn), (ins PPR3bAny:$Pg, rt:$_Rdn, zprty:$Zm),
- asm, "\t$Rdn, $Pg, $_Rdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rdn;
- bits<5> Zm;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-17} = 0b11000;
- let Inst{16} = ab;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Rdn;
- let Constraints = "$Rdn = $_Rdn";
- }
- multiclass sve_int_perm_clast_rz<bit ab, string asm, SDPatternOperator op> {
- def _B : sve_int_perm_clast_rz<0b00, ab, asm, ZPR8, GPR32>;
- def _H : sve_int_perm_clast_rz<0b01, ab, asm, ZPR16, GPR32>;
- def _S : sve_int_perm_clast_rz<0b10, ab, asm, ZPR32, GPR32>;
- def _D : sve_int_perm_clast_rz<0b11, ab, asm, ZPR64, GPR64>;
- def : SVE_3_Op_Pat<i32, op, nxv16i1, i32, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<i32, op, nxv8i1, i32, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<i32, op, nxv4i1, i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<i64, op, nxv2i1, i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_perm_clast_vz<bits<2> sz8_64, bit ab, string asm,
- ZPRRegOp zprty, RegisterClass rt>
- : I<(outs rt:$Vdn), (ins PPR3bAny:$Pg, rt:$_Vdn, zprty:$Zm),
- asm, "\t$Vdn, $Pg, $_Vdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Vdn;
- bits<5> Zm;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-17} = 0b10101;
- let Inst{16} = ab;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Vdn;
- let Constraints = "$Vdn = $_Vdn";
- }
- multiclass sve_int_perm_clast_vz<bit ab, string asm, SDPatternOperator op> {
- def _B : sve_int_perm_clast_vz<0b00, ab, asm, ZPR8, FPR8>;
- def _H : sve_int_perm_clast_vz<0b01, ab, asm, ZPR16, FPR16>;
- def _S : sve_int_perm_clast_vz<0b10, ab, asm, ZPR32, FPR32>;
- def _D : sve_int_perm_clast_vz<0b11, ab, asm, ZPR64, FPR64>;
- def : SVE_3_Op_Pat<f16, op, nxv8i1, f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<f32, op, nxv4i1, f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<f64, op, nxv2i1, f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<bf16, op, nxv8i1, bf16, nxv8bf16, !cast<Instruction>(NAME # _H)>;
- }
- class sve_int_perm_clast_zz<bits<2> sz8_64, bit ab, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm),
- asm, "\t$Zdn, $Pg, $_Zdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bits<5> Zm;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-17} = 0b10100;
- let Inst{16} = ab;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_perm_clast_zz<bit ab, string asm, SDPatternOperator op> {
- def _B : sve_int_perm_clast_zz<0b00, ab, asm, ZPR8>;
- def _H : sve_int_perm_clast_zz<0b01, ab, asm, ZPR16>;
- def _S : sve_int_perm_clast_zz<0b10, ab, asm, ZPR32>;
- def _D : sve_int_perm_clast_zz<0b11, ab, asm, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8bf16, op, nxv8i1, nxv8bf16, nxv8bf16, !cast<Instruction>(NAME # _H)>;
- }
- class sve_int_perm_last_r<bits<2> sz8_64, bit ab, string asm,
- ZPRRegOp zprty, RegisterClass resultRegType>
- : I<(outs resultRegType:$Rd), (ins PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Rd, $Pg, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-17} = 0b10000;
- let Inst{16} = ab;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Rd;
- }
- multiclass sve_int_perm_last_r<bit ab, string asm, SDPatternOperator op> {
- def _B : sve_int_perm_last_r<0b00, ab, asm, ZPR8, GPR32>;
- def _H : sve_int_perm_last_r<0b01, ab, asm, ZPR16, GPR32>;
- def _S : sve_int_perm_last_r<0b10, ab, asm, ZPR32, GPR32>;
- def _D : sve_int_perm_last_r<0b11, ab, asm, ZPR64, GPR64>;
- def : SVE_2_Op_Pat<i32, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<i32, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_perm_last_v<bits<2> sz8_64, bit ab, string asm,
- ZPRRegOp zprty, RegisterClass dstRegtype>
- : I<(outs dstRegtype:$Vd), (ins PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Vd, $Pg, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Vd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-17} = 0b10001;
- let Inst{16} = ab;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Vd;
- }
- multiclass sve_int_perm_last_v<bit ab, string asm, SDPatternOperator op> {
- def _B : sve_int_perm_last_v<0b00, ab, asm, ZPR8, FPR8>;
- def _H : sve_int_perm_last_v<0b01, ab, asm, ZPR16, FPR16>;
- def _S : sve_int_perm_last_v<0b10, ab, asm, ZPR32, FPR32>;
- def _D : sve_int_perm_last_v<0b11, ab, asm, ZPR64, FPR64>;
- def : SVE_2_Op_Pat<f16, op, nxv8i1, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<f32, op, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<f32, op, nxv2i1, nxv2f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<f64, op, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<bf16, op, nxv8i1, nxv8bf16, !cast<Instruction>(NAME # _H)>;
- }
- class sve_int_perm_splice<bits<2> sz8_64, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins PPR3bAny:$Pg, zprty:$_Zdn, zprty:$Zm),
- asm, "\t$Zdn, $Pg, $_Zdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zdn;
- bits<5> Zm;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-13} = 0b101100100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_int_perm_splice<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_splice<0b00, asm, ZPR8>;
- def _H : sve_int_perm_splice<0b01, asm, ZPR16>;
- def _S : sve_int_perm_splice<0b10, asm, ZPR32>;
- def _D : sve_int_perm_splice<0b11, asm, ZPR64>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- def : SVE_3_Op_Pat<nxv8bf16, op, nxv8i1, nxv8bf16, nxv8bf16, !cast<Instruction>(NAME # _H)>;
- }
- class sve2_int_perm_splice_cons<bits<2> sz8_64, string asm,
- ZPRRegOp zprty, RegisterOperand VecList>
- : I<(outs zprty:$Zd), (ins PPR3bAny:$Pg, VecList:$Zn),
- asm, "\t$Zd, $Pg, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zn;
- bits<5> Zd;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-13} = 0b101101100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_int_perm_splice_cons<string asm> {
- def _B : sve2_int_perm_splice_cons<0b00, asm, ZPR8, ZZ_b>;
- def _H : sve2_int_perm_splice_cons<0b01, asm, ZPR16, ZZ_h>;
- def _S : sve2_int_perm_splice_cons<0b10, asm, ZPR32, ZZ_s>;
- def _D : sve2_int_perm_splice_cons<0b11, asm, ZPR64, ZZ_d>;
- }
- class sve_int_perm_rev<bits<2> sz8_64, bits<2> opc, string asm,
- ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Zd, $Pg/m, $Zn",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<3> Pg;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-18} = 0b1001;
- let Inst{17-16} = opc;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_perm_rev_rbit<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_rev<0b00, 0b11, asm, ZPR8>;
- def _H : sve_int_perm_rev<0b01, 0b11, asm, ZPR16>;
- def _S : sve_int_perm_rev<0b10, 0b11, asm, ZPR32>;
- def _D : sve_int_perm_rev<0b11, 0b11, asm, ZPR64>;
- def : SVE_1_Op_Passthru_Pat<nxv16i8, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Passthru_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_perm_rev_revb<string asm, SDPatternOperator op> {
- def _H : sve_int_perm_rev<0b01, 0b00, asm, ZPR16>;
- def _S : sve_int_perm_rev<0b10, 0b00, asm, ZPR32>;
- def _D : sve_int_perm_rev<0b11, 0b00, asm, ZPR64>;
- def : SVE_1_Op_Passthru_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Passthru_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_perm_rev_revh<string asm, SDPatternOperator op> {
- def _S : sve_int_perm_rev<0b10, 0b01, asm, ZPR32>;
- def _D : sve_int_perm_rev<0b11, 0b01, asm, ZPR64>;
- def : SVE_1_Op_Passthru_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Passthru_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_perm_rev_revw<string asm, SDPatternOperator op> {
- def _D : sve_int_perm_rev<0b11, 0b10, asm, ZPR64>;
- def : SVE_1_Op_Passthru_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_perm_cpy_r<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- RegisterClass srcRegType>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, PPR3bAny:$Pg, srcRegType:$Rn),
- asm, "\t$Zd, $Pg/m, $Rn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zd;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-13} = 0b101000101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_perm_cpy_r<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_cpy_r<0b00, asm, ZPR8, GPR32sp>;
- def _H : sve_int_perm_cpy_r<0b01, asm, ZPR16, GPR32sp>;
- def _S : sve_int_perm_cpy_r<0b10, asm, ZPR32, GPR32sp>;
- def _D : sve_int_perm_cpy_r<0b11, asm, ZPR64, GPR64sp>;
- def : InstAlias<"mov $Zd, $Pg/m, $Rn",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, PPR3bAny:$Pg, GPR32sp:$Rn), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Rn",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, PPR3bAny:$Pg, GPR32sp:$Rn), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Rn",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, PPR3bAny:$Pg, GPR32sp:$Rn), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Rn",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, PPR3bAny:$Pg, GPR64sp:$Rn), 1>;
- def : Pat<(nxv16i8 (op nxv16i1:$pg, i32:$splat, nxv16i8:$passthru)),
- (!cast<Instruction>(NAME # _B) $passthru, $pg, $splat)>;
- def : Pat<(nxv8i16 (op nxv8i1:$pg, i32:$splat, nxv8i16:$passthru)),
- (!cast<Instruction>(NAME # _H) $passthru, $pg, $splat)>;
- def : Pat<(nxv4i32 (op nxv4i1:$pg, i32:$splat, nxv4i32:$passthru)),
- (!cast<Instruction>(NAME # _S) $passthru, $pg, $splat)>;
- def : Pat<(nxv2i64 (op nxv2i1:$pg, i64:$splat, nxv2i64:$passthru)),
- (!cast<Instruction>(NAME # _D) $passthru, $pg, $splat)>;
- }
- class sve_int_perm_cpy_v<bits<2> sz8_64, string asm, ZPRRegOp zprty,
- RegisterClass srcRegtype>
- : I<(outs zprty:$Zd), (ins zprty:$_Zd, PPR3bAny:$Pg, srcRegtype:$Vn),
- asm, "\t$Zd, $Pg/m, $Vn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Vn;
- bits<5> Zd;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = sz8_64;
- let Inst{21-13} = 0b100000100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Vn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_perm_cpy_v<string asm, SDPatternOperator op> {
- def _B : sve_int_perm_cpy_v<0b00, asm, ZPR8, FPR8>;
- def _H : sve_int_perm_cpy_v<0b01, asm, ZPR16, FPR16>;
- def _S : sve_int_perm_cpy_v<0b10, asm, ZPR32, FPR32>;
- def _D : sve_int_perm_cpy_v<0b11, asm, ZPR64, FPR64>;
- def : InstAlias<"mov $Zd, $Pg/m, $Vn",
- (!cast<Instruction>(NAME # _B) ZPR8:$Zd, PPR3bAny:$Pg, FPR8:$Vn), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Vn",
- (!cast<Instruction>(NAME # _H) ZPR16:$Zd, PPR3bAny:$Pg, FPR16:$Vn), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Vn",
- (!cast<Instruction>(NAME # _S) ZPR32:$Zd, PPR3bAny:$Pg, FPR32:$Vn), 1>;
- def : InstAlias<"mov $Zd, $Pg/m, $Vn",
- (!cast<Instruction>(NAME # _D) ZPR64:$Zd, PPR3bAny:$Pg, FPR64:$Vn), 1>;
- def : Pat<(nxv8f16 (op nxv8i1:$pg, f16:$splat, nxv8f16:$passthru)),
- (!cast<Instruction>(NAME # _H) $passthru, $pg, $splat)>;
- def : Pat<(nxv2f32 (op nxv2i1:$pg, f32:$splat, nxv2f32:$passthru)),
- (!cast<Instruction>(NAME # _S) $passthru, $pg, $splat)>;
- def : Pat<(nxv4f32 (op nxv4i1:$pg, f32:$splat, nxv4f32:$passthru)),
- (!cast<Instruction>(NAME # _S) $passthru, $pg, $splat)>;
- def : Pat<(nxv2f64 (op nxv2i1:$pg, f64:$splat, nxv2f64:$passthru)),
- (!cast<Instruction>(NAME # _D) $passthru, $pg, $splat)>;
- def : Pat<(nxv8bf16 (op nxv8i1:$pg, bf16:$splat, nxv8bf16:$passthru)),
- (!cast<Instruction>(NAME # _H) $passthru, $pg, $splat)>;
- }
- class sve_int_perm_compact<bit sz, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Zd, $Pg, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-23} = 0b000001011;
- let Inst{22} = sz;
- let Inst{21-13} = 0b100001100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_compact<string asm, SDPatternOperator op> {
- def _S : sve_int_perm_compact<0b0, asm, ZPR32>;
- def _D : sve_int_perm_compact<0b1, asm, ZPR64>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Memory - Contiguous Load Group
- //===----------------------------------------------------------------------===//
- class sve_mem_cld_si_base<bits<4> dtype, bit nf, string asm,
- RegisterOperand VecList>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4),
- asm, "\t$Zt, $Pg/z, [$Rn, $imm4, mul vl]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zt;
- bits<4> imm4;
- let Inst{31-25} = 0b1010010;
- let Inst{24-21} = dtype;
- let Inst{20} = nf;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- let Uses = !if(nf, [FFR], []);
- let Defs = !if(nf, [FFR], []);
- }
- multiclass sve_mem_cld_si_base<bits<4> dtype, bit nf, string asm,
- RegisterOperand listty, ZPRRegOp zprty> {
- def _REAL : sve_mem_cld_si_base<dtype, nf, asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME # _REAL) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $imm4, mul vl]",
- (!cast<Instruction>(NAME # _REAL) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME # _REAL) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1, mayLoad = 1 in {
- def "" : Pseudo<(outs listty:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _REAL) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4)>;
- }
- }
- multiclass sve_mem_cld_si<bits<4> dtype, string asm, RegisterOperand listty,
- ZPRRegOp zprty>
- : sve_mem_cld_si_base<dtype, 0, asm, listty, zprty>;
- class sve_mem_cldnt_si_base<bits<2> msz, string asm, RegisterOperand VecList>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4),
- asm, "\t$Zt, $Pg/z, [$Rn, $imm4, mul vl]",
- "",
- []>, Sched<[]> {
- bits<5> Zt;
- bits<3> Pg;
- bits<5> Rn;
- bits<4> imm4;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = msz;
- let Inst{22-20} = 0b000;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_cldnt_si<bits<2> msz, string asm, RegisterOperand listty,
- ZPRRegOp zprty> {
- def NAME : sve_mem_cldnt_si_base<msz, asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $imm4, mul vl]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_cldnt_ss_base<bits<2> msz, string asm, RegisterOperand VecList,
- RegisterOperand gprty>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg/z, [$Rn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Rn;
- bits<5> Zt;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = msz;
- let Inst{22-21} = 0b00;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b110;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_cldnt_ss<bits<2> msz, string asm, RegisterOperand listty,
- ZPRRegOp zprty, RegisterOperand gprty> {
- def NAME : sve_mem_cldnt_ss_base<msz, asm, listty, gprty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Rm]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), 0>;
- }
- class sve_mem_ldqr_si<bits<2> sz, string asm, RegisterOperand VecList>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, simm4s16:$imm4),
- asm, "\t$Zt, $Pg/z, [$Rn, $imm4]", "", []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Rn;
- bits<3> Pg;
- bits<4> imm4;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = sz;
- let Inst{22-20} = 0;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_ldqr_si<bits<2> sz, string asm, RegisterOperand listty,
- ZPRRegOp zprty> {
- def NAME : sve_mem_ldqr_si<sz, asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $imm4]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s16:$imm4), 0>;
- }
- class sve_mem_ldqr_ss<bits<2> sz, string asm, RegisterOperand VecList,
- RegisterOperand gprty>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg/z, [$Rn, $Rm]", "", []>, Sched<[]> {
- bits<5> Zt;
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Rm;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = sz;
- let Inst{22-21} = 0;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_ldqr_ss<bits<2> sz, string asm, RegisterOperand listty,
- ZPRRegOp zprty, RegisterOperand gprty> {
- def NAME : sve_mem_ldqr_ss<sz, asm, listty, gprty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Rm]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), 0>;
- }
- class sve_mem_ld_dup<bits<2> dtypeh, bits<2> dtypel, string asm,
- RegisterOperand VecList, Operand immtype>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, immtype:$imm6),
- asm, "\t$Zt, $Pg/z, [$Rn, $imm6]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zt;
- bits<6> imm6;
- let Inst{31-25} = 0b1000010;
- let Inst{24-23} = dtypeh;
- let Inst{22} = 1;
- let Inst{21-16} = imm6;
- let Inst{15} = 0b1;
- let Inst{14-13} = dtypel;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_ld_dup<bits<2> dtypeh, bits<2> dtypel, string asm,
- RegisterOperand zlistty, ZPRRegOp zprty, Operand immtype> {
- def NAME : sve_mem_ld_dup<dtypeh, dtypel, asm, zlistty, immtype>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $imm6]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, immtype:$imm6), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) zlistty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_cld_ss_base<bits<4> dtype, bit ff, dag iops, string asm,
- RegisterOperand VecList>
- : I<(outs VecList:$Zt), iops,
- asm, "\t$Zt, $Pg/z, [$Rn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<5> Zt;
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Rn;
- let Inst{31-25} = 0b1010010;
- let Inst{24-21} = dtype;
- let Inst{20-16} = Rm;
- let Inst{15-14} = 0b01;
- let Inst{13} = ff;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- let Uses = !if(ff, [FFR], []);
- let Defs = !if(ff, [FFR], []);
- }
- multiclass sve_mem_cld_ss<bits<4> dtype, string asm, RegisterOperand listty,
- ZPRRegOp zprty, RegisterOperand gprty> {
- def "" : sve_mem_cld_ss_base<dtype, 0, (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Rm]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), 0>;
- }
- multiclass sve_mem_cldff_ss<bits<4> dtype, string asm, RegisterOperand listty,
- ZPRRegOp zprty, RegisterOperand gprty> {
- def _REAL : sve_mem_cld_ss_base<dtype, 1, (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Rm]",
- (!cast<Instruction>(NAME # _REAL) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME # _REAL) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, XZR), 1>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME # _REAL) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, XZR), 0>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def "" : Pseudo<(outs listty:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _REAL) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm)>;
- }
- }
- multiclass sve_mem_cldnf_si<bits<4> dtype, string asm, RegisterOperand listty,
- ZPRRegOp zprty>
- : sve_mem_cld_si_base<dtype, 1, asm, listty, zprty>;
- class sve_mem_eld_si<bits<2> sz, bits<3> nregs, RegisterOperand VecList,
- string asm, Operand immtype>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, immtype:$imm4),
- asm, "\t$Zt, $Pg/z, [$Rn, $imm4, mul vl]",
- "",
- []>, Sched<[]> {
- bits<5> Zt;
- bits<3> Pg;
- bits<5> Rn;
- bits<4> imm4;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = sz;
- let Inst{22-21} = nregs{1-0};
- let Inst{20} = nregs{2};
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_eld_si<bits<2> sz, bits<3> nregs, RegisterOperand VecList,
- string asm, Operand immtype> {
- def NAME : sve_mem_eld_si<sz, nregs, VecList, asm, immtype>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) VecList:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_eld_ss<bits<2> sz, bits<3> nregs, RegisterOperand VecList,
- string asm, RegisterOperand gprty>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg/z, [$Rn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Rn;
- bits<5> Zt;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = sz;
- let Inst{22-21} = nregs{1-0};
- let Inst{20-16} = Rm;
- let Inst{15} = 0b1;
- let Inst{14} = nregs{2};
- let Inst{13} = 0b0;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- //===----------------------------------------------------------------------===//
- // SVE Memory - 32-bit Gather and Unsized Contiguous Group
- //===----------------------------------------------------------------------===//
- // bit xs is '1' if offsets are signed
- // bit scaled is '1' if the offsets are scaled
- class sve_mem_32b_gld_sv<bits<4> opc, bit xs, bit scaled, string asm,
- RegisterOperand zprext>
- : I<(outs Z_s:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm),
- asm, "\t$Zt, $Pg/z, [$Rn, $Zm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zm;
- bits<5> Zt;
- let Inst{31-25} = 0b1000010;
- let Inst{24-23} = opc{3-2};
- let Inst{22} = xs;
- let Inst{21} = scaled;
- let Inst{20-16} = Zm;
- let Inst{15} = 0b0;
- let Inst{14-13} = opc{1-0};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- let Defs = !if(!eq(opc{0}, 1), [FFR], []);
- let Uses = !if(!eq(opc{0}, 1), [FFR], []);
- }
- multiclass sve_mem_32b_gld_sv_32_scaled<bits<4> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt> {
- def _UXTW_SCALED_REAL : sve_mem_32b_gld_sv<opc, 0, 1, asm, uxtw_opnd>;
- def _SXTW_SCALED_REAL : sve_mem_32b_gld_sv<opc, 1, 1, asm, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW_SCALED_REAL) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW_SCALED_REAL) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def _UXTW_SCALED : Pseudo<(outs Z_s:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _UXTW_SCALED_REAL) Z_s:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm)>;
- def _SXTW_SCALED : Pseudo<(outs Z_s:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _SXTW_SCALED_REAL) Z_s:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm)>;
- }
- def : Pat<(nxv4i32 (uxtw_op (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$indices), vt)),
- (!cast<Instruction>(NAME # _UXTW_SCALED) PPR:$gp, GPR64sp:$base, ZPR:$indices)>;
- def : Pat<(nxv4i32 (sxtw_op (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$indices), vt)),
- (!cast<Instruction>(NAME # _SXTW_SCALED) PPR:$gp, GPR64sp:$base, ZPR:$indices)>;
- }
- multiclass sve_mem_32b_gld_vs_32_unscaled<bits<4> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt> {
- def _UXTW_REAL : sve_mem_32b_gld_sv<opc, 0, 0, asm, uxtw_opnd>;
- def _SXTW_REAL : sve_mem_32b_gld_sv<opc, 1, 0, asm, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW_REAL) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW_REAL) ZPR32:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def _UXTW : Pseudo<(outs Z_s:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _UXTW_REAL) Z_s:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm)>;
- def _SXTW : Pseudo<(outs Z_s:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _SXTW_REAL) Z_s:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm)>;
- }
- def : Pat<(nxv4i32 (uxtw_op (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$offsets), vt)),
- (!cast<Instruction>(NAME # _UXTW) PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- def : Pat<(nxv4i32 (sxtw_op (nxv4i1 PPR:$gp), GPR64sp:$base, (nxv4i32 ZPR:$offsets), vt)),
- (!cast<Instruction>(NAME # _SXTW) PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- class sve_mem_32b_gld_vi<bits<4> opc, string asm, Operand imm_ty>
- : I<(outs Z_s:$Zt), (ins PPR3bAny:$Pg, ZPR32:$Zn, imm_ty:$imm5),
- asm, "\t$Zt, $Pg/z, [$Zn, $imm5]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zn;
- bits<5> Zt;
- bits<5> imm5;
- let Inst{31-25} = 0b1000010;
- let Inst{24-23} = opc{3-2};
- let Inst{22-21} = 0b01;
- let Inst{20-16} = imm5;
- let Inst{15} = 0b1;
- let Inst{14-13} = opc{1-0};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- let Defs = !if(!eq(opc{0}, 1), [FFR], []);
- let Uses = !if(!eq(opc{0}, 1), [FFR], []);
- }
- multiclass sve_mem_32b_gld_vi_32_ptrs<bits<4> opc, string asm, Operand imm_ty,
- SDPatternOperator op, ValueType vt> {
- def _IMM_REAL : sve_mem_32b_gld_vi<opc, asm, imm_ty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _IMM_REAL) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn, $imm5]",
- (!cast<Instruction>(NAME # _IMM_REAL) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, imm_ty:$imm5), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _IMM_REAL) Z_s:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, 0), 1>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def _IMM : Pseudo<(outs Z_s:$Zt), (ins PPR3bAny:$Pg, ZPR32:$Zn, imm_ty:$imm5), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _IMM_REAL) Z_s:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, imm_ty:$imm5)>;
- }
- def : Pat<(nxv4i32 (op (nxv4i1 PPR:$gp), (nxv4i32 ZPR:$ptrs), imm_ty:$index, vt)),
- (!cast<Instruction>(NAME # _IMM) PPR:$gp, ZPR:$ptrs, imm_ty:$index)>;
- }
- class sve_mem_prfm_si<bits<2> msz, string asm>
- : I<(outs), (ins sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, simm6s1:$imm6),
- asm, "\t$prfop, $Pg, [$Rn, $imm6, mul vl]",
- "",
- []>, Sched<[]> {
- bits<5> Rn;
- bits<3> Pg;
- bits<6> imm6;
- bits<4> prfop;
- let Inst{31-22} = 0b1000010111;
- let Inst{21-16} = imm6;
- let Inst{15} = 0b0;
- let Inst{14-13} = msz;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4} = 0b0;
- let Inst{3-0} = prfop;
- let hasSideEffects = 1;
- }
- multiclass sve_mem_prfm_si<bits<2> msz, string asm> {
- def NAME : sve_mem_prfm_si<msz, asm>;
- def : InstAlias<asm # "\t$prfop, $Pg, [$Rn]",
- (!cast<Instruction>(NAME) sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_prfm_ss<bits<3> opc, string asm, RegisterOperand gprty>
- : I<(outs), (ins sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$prfop, $Pg, [$Rn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<5> Rm;
- bits<5> Rn;
- bits<3> Pg;
- bits<4> prfop;
- let Inst{31-25} = 0b1000010;
- let Inst{24-23} = opc{2-1};
- let Inst{22-21} = 0b00;
- let Inst{20-16} = Rm;
- let Inst{15} = 0b1;
- let Inst{14} = opc{0};
- let Inst{13} = 0b0;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4} = 0b0;
- let Inst{3-0} = prfop;
- let hasSideEffects = 1;
- }
- class sve_mem_32b_prfm_sv<bits<2> msz, bit xs, string asm,
- RegisterOperand zprext>
- : I<(outs), (ins sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm),
- asm, "\t$prfop, $Pg, [$Rn, $Zm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zm;
- bits<4> prfop;
- let Inst{31-23} = 0b100001000;
- let Inst{22} = xs;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15} = 0b0;
- let Inst{14-13} = msz;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4} = 0b0;
- let Inst{3-0} = prfop;
- let hasSideEffects = 1;
- }
- multiclass sve_mem_32b_prfm_sv_scaled<bits<2> msz, string asm,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- SDPatternOperator op_sxtw,
- SDPatternOperator op_uxtw> {
- def _UXTW_SCALED : sve_mem_32b_prfm_sv<msz, 0, asm, uxtw_opnd>;
- def _SXTW_SCALED : sve_mem_32b_prfm_sv<msz, 1, asm, sxtw_opnd>;
- def : Pat<(op_uxtw (nxv4i1 PPR3bAny:$Pg), (i64 GPR64sp:$Rn), (nxv4i32 uxtw_opnd:$Zm), (i32 sve_prfop:$prfop)),
- (!cast<Instruction>(NAME # _UXTW_SCALED) sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm)>;
- def : Pat<(op_sxtw (nxv4i1 PPR3bAny:$Pg), (i64 GPR64sp:$Rn), (nxv4i32 sxtw_opnd:$Zm), (i32 sve_prfop:$prfop)),
- (!cast<Instruction>(NAME # _SXTW_SCALED) sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm)>;
- }
- class sve_mem_32b_prfm_vi<bits<2> msz, string asm, Operand imm_ty>
- : I<(outs), (ins sve_prfop:$prfop, PPR3bAny:$Pg, ZPR32:$Zn, imm_ty:$imm5),
- asm, "\t$prfop, $Pg, [$Zn, $imm5]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zn;
- bits<5> imm5;
- bits<4> prfop;
- let Inst{31-25} = 0b1000010;
- let Inst{24-23} = msz;
- let Inst{22-21} = 0b00;
- let Inst{20-16} = imm5;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = 0b0;
- let Inst{3-0} = prfop;
- }
- multiclass sve_mem_32b_prfm_vi<bits<2> msz, string asm, Operand imm_ty, SDPatternOperator op> {
- def NAME : sve_mem_32b_prfm_vi<msz, asm, imm_ty>;
- def : InstAlias<asm # "\t$prfop, $Pg, [$Zn]",
- (!cast<Instruction>(NAME) sve_prfop:$prfop, PPR3bAny:$Pg, ZPR32:$Zn, 0), 1>;
- def : Pat<(op (nxv4i1 PPR_3b:$Pg), (nxv4i32 ZPR32:$Zn), (i64 imm_ty:$imm), (i32 sve_prfop:$prfop)),
- (!cast<Instruction>(NAME) sve_prfop:$prfop, PPR_3b:$Pg, ZPR32:$Zn, imm_ty:$imm)>;
- }
- class sve_mem_z_fill<string asm>
- : I<(outs ZPRAny:$Zt), (ins GPR64sp:$Rn, simm9:$imm9),
- asm, "\t$Zt, [$Rn, $imm9, mul vl]",
- "",
- []>, Sched<[]> {
- bits<5> Rn;
- bits<5> Zt;
- bits<9> imm9;
- let Inst{31-22} = 0b1000010110;
- let Inst{21-16} = imm9{8-3};
- let Inst{15-13} = 0b010;
- let Inst{12-10} = imm9{2-0};
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_z_fill<string asm> {
- def NAME : sve_mem_z_fill<asm>;
- def : InstAlias<asm # "\t$Zt, [$Rn]",
- (!cast<Instruction>(NAME) ZPRAny:$Zt, GPR64sp:$Rn, 0), 1>;
- }
- class sve_mem_p_fill<string asm>
- : I<(outs PPRAny:$Pt), (ins GPR64sp:$Rn, simm9:$imm9),
- asm, "\t$Pt, [$Rn, $imm9, mul vl]",
- "",
- []>, Sched<[]> {
- bits<4> Pt;
- bits<5> Rn;
- bits<9> imm9;
- let Inst{31-22} = 0b1000010110;
- let Inst{21-16} = imm9{8-3};
- let Inst{15-13} = 0b000;
- let Inst{12-10} = imm9{2-0};
- let Inst{9-5} = Rn;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pt;
- let mayLoad = 1;
- }
- multiclass sve_mem_p_fill<string asm> {
- def NAME : sve_mem_p_fill<asm>;
- def : InstAlias<asm # "\t$Pt, [$Rn]",
- (!cast<Instruction>(NAME) PPRAny:$Pt, GPR64sp:$Rn, 0), 1>;
- }
- class sve2_mem_gldnt_vs_base<bits<5> opc, dag iops, string asm,
- RegisterOperand VecList>
- : I<(outs VecList:$Zt), iops,
- asm, "\t$Zt, $Pg/z, [$Zn, $Rm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rm;
- bits<5> Zn;
- bits<5> Zt;
- let Inst{31} = 0b1;
- let Inst{30} = opc{4};
- let Inst{29-25} = 0b00010;
- let Inst{24-23} = opc{3-2};
- let Inst{22-21} = 0b00;
- let Inst{20-16} = Rm;
- let Inst{15} = 0b1;
- let Inst{14-13} = opc{1-0};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve2_mem_gldnt_vs_32_ptrs<bits<5> opc, string asm,
- SDPatternOperator op,
- ValueType vt> {
- def _REAL : sve2_mem_gldnt_vs_base<opc, (ins PPR3bAny:$Pg, ZPR32:$Zn, GPR64:$Rm),
- asm, Z_s>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn, $Rm]",
- (!cast<Instruction>(NAME # _REAL) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, GPR64:$Rm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) ZPR32:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, XZR), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) Z_s:$Zt, PPR3bAny:$Pg, ZPR32:$Zn, XZR), 1>;
- def : Pat <(nxv4i32 (op (nxv4i1 PPR3bAny:$Pg), (nxv4i32 ZPR32:$Zd), (i64 GPR64:$Rm), vt)),
- (!cast<Instruction>(NAME # _REAL) PPR3bAny:$Pg, ZPR32:$Zd, GPR64:$Rm)>;
- }
- multiclass sve2_mem_gldnt_vs_64_ptrs<bits<5> opc, string asm,
- SDPatternOperator op,
- ValueType vt> {
- def _REAL : sve2_mem_gldnt_vs_base<opc, (ins PPR3bAny:$Pg, ZPR64:$Zn, GPR64:$Rm),
- asm, Z_d>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn, $Rm]",
- (!cast<Instruction>(NAME # _REAL) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, GPR64:$Rm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, XZR), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _REAL) Z_d:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, XZR), 1>;
- def : Pat <(nxv2i64 (op (nxv2i1 PPR3bAny:$Pg), (nxv2i64 ZPR64:$Zd), (i64 GPR64:$Rm), vt)),
- (!cast<Instruction>(NAME # _REAL) PPR3bAny:$Pg, ZPR64:$Zd, GPR64:$Rm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Memory - 64-bit Gather Group
- //===----------------------------------------------------------------------===//
- // bit xs is '1' if offsets are signed
- // bit scaled is '1' if the offsets are scaled
- // bit lsl is '0' if the offsets are extended (uxtw/sxtw), '1' if shifted (lsl)
- class sve_mem_64b_gld_sv<bits<4> opc, bit xs, bit scaled, bit lsl, string asm,
- RegisterOperand zprext>
- : I<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm),
- asm, "\t$Zt, $Pg/z, [$Rn, $Zm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zm;
- bits<5> Zt;
- let Inst{31-25} = 0b1100010;
- let Inst{24-23} = opc{3-2};
- let Inst{22} = xs;
- let Inst{21} = scaled;
- let Inst{20-16} = Zm;
- let Inst{15} = lsl;
- let Inst{14-13} = opc{1-0};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- let Defs = !if(!eq(opc{0}, 1), [FFR], []);
- let Uses = !if(!eq(opc{0}, 1), [FFR], []);
- }
- multiclass sve_mem_64b_gld_sv_32_scaled<bits<4> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt> {
- def _UXTW_SCALED_REAL : sve_mem_64b_gld_sv<opc, 0, 1, 0, asm, uxtw_opnd>;
- def _SXTW_SCALED_REAL : sve_mem_64b_gld_sv<opc, 1, 1, 0, asm, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW_SCALED_REAL) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW_SCALED_REAL) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def _UXTW_SCALED : Pseudo<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _UXTW_SCALED_REAL) Z_d:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm)>;
- def _SXTW_SCALED : Pseudo<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _SXTW_SCALED_REAL) Z_d:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm)>;
- }
- def : Pat<(nxv2i64 (uxtw_op (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$indices), vt)),
- (!cast<Instruction>(NAME # _UXTW_SCALED) PPR:$gp, GPR64sp:$base, ZPR:$indices)>;
- def : Pat<(nxv2i64 (sxtw_op (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$indices), vt)),
- (!cast<Instruction>(NAME # _SXTW_SCALED) PPR:$gp, GPR64sp:$base, ZPR:$indices)>;
- }
- multiclass sve_mem_64b_gld_vs_32_unscaled<bits<4> opc, string asm,
- SDPatternOperator sxtw_op,
- SDPatternOperator uxtw_op,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- ValueType vt> {
- def _UXTW_REAL : sve_mem_64b_gld_sv<opc, 0, 0, 0, asm, uxtw_opnd>;
- def _SXTW_REAL : sve_mem_64b_gld_sv<opc, 1, 0, 0, asm, sxtw_opnd>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _UXTW_REAL) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SXTW_REAL) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), 0>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def _UXTW : Pseudo<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _UXTW_REAL) Z_d:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm)>;
- def _SXTW : Pseudo<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _SXTW_REAL) Z_d:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm)>;
- }
- def : Pat<(nxv2i64 (uxtw_op (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt)),
- (!cast<Instruction>(NAME # _UXTW) PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- def : Pat<(nxv2i64 (sxtw_op (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt)),
- (!cast<Instruction>(NAME # _SXTW) PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- multiclass sve_mem_64b_gld_sv2_64_scaled<bits<4> opc, string asm,
- SDPatternOperator op,
- RegisterOperand zprext, ValueType vt> {
- def _SCALED_REAL : sve_mem_64b_gld_sv<opc, 1, 1, 1, asm, zprext>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SCALED_REAL) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm), 0>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def _SCALED : Pseudo<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _SCALED_REAL) Z_d:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm)>;
- }
- def : Pat<(nxv2i64 (op (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$indices), vt)),
- (!cast<Instruction>(NAME # _SCALED) PPR:$gp, GPR64sp:$base, ZPR:$indices)>;
- }
- multiclass sve_mem_64b_gld_vs2_64_unscaled<bits<4> opc, string asm,
- SDPatternOperator op, ValueType vt> {
- def _REAL : sve_mem_64b_gld_sv<opc, 1, 0, 1, asm, ZPR64ExtLSL8>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _REAL) ZPR64:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, ZPR64ExtLSL8:$Zm), 0>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def "" : Pseudo<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, ZPR64ExtLSL8:$Zm), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _REAL) Z_d:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, ZPR64ExtLSL8:$Zm)>;
- }
- def : Pat<(nxv2i64 (op (nxv2i1 PPR:$gp), GPR64sp:$base, (nxv2i64 ZPR:$offsets), vt)),
- (!cast<Instruction>(NAME) PPR:$gp, GPR64sp:$base, ZPR:$offsets)>;
- }
- class sve_mem_64b_gld_vi<bits<4> opc, string asm, Operand imm_ty>
- : I<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, ZPR64:$Zn, imm_ty:$imm5),
- asm, "\t$Zt, $Pg/z, [$Zn, $imm5]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zn;
- bits<5> Zt;
- bits<5> imm5;
- let Inst{31-25} = 0b1100010;
- let Inst{24-23} = opc{3-2};
- let Inst{22-21} = 0b01;
- let Inst{20-16} = imm5;
- let Inst{15} = 0b1;
- let Inst{14-13} = opc{1-0};
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- let Defs = !if(!eq(opc{0}, 1), [FFR], []);
- let Uses = !if(!eq(opc{0}, 1), [FFR], []);
- }
- multiclass sve_mem_64b_gld_vi_64_ptrs<bits<4> opc, string asm, Operand imm_ty,
- SDPatternOperator op, ValueType vt> {
- def _IMM_REAL : sve_mem_64b_gld_vi<opc, asm, imm_ty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _IMM_REAL) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn, $imm5]",
- (!cast<Instruction>(NAME # _IMM_REAL) ZPR64:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, imm_ty:$imm5), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME # _IMM_REAL) Z_d:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, 0), 1>;
- // We need a layer of indirection because early machine code passes balk at
- // physical register (i.e. FFR) uses that have no previous definition.
- let hasSideEffects = 1, hasNoSchedulingInfo = 1 in {
- def _IMM : Pseudo<(outs Z_d:$Zt), (ins PPR3bAny:$Pg, ZPR64:$Zn, imm_ty:$imm5), []>,
- PseudoInstExpansion<(!cast<Instruction>(NAME # _IMM_REAL) Z_d:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, imm_ty:$imm5)>;
- }
- def : Pat<(nxv2i64 (op (nxv2i1 PPR:$gp), (nxv2i64 ZPR:$ptrs), imm_ty:$index, vt)),
- (!cast<Instruction>(NAME # _IMM) PPR:$gp, ZPR:$ptrs, imm_ty:$index)>;
- }
- // bit lsl is '0' if the offsets are extended (uxtw/sxtw), '1' if shifted (lsl)
- class sve_mem_64b_prfm_sv<bits<2> msz, bit xs, bit lsl, string asm,
- RegisterOperand zprext>
- : I<(outs), (ins sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm),
- asm, "\t$prfop, $Pg, [$Rn, $Zm]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Zm;
- bits<4> prfop;
- let Inst{31-23} = 0b110001000;
- let Inst{22} = xs;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15} = lsl;
- let Inst{14-13} = msz;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4} = 0b0;
- let Inst{3-0} = prfop;
- let hasSideEffects = 1;
- }
- multiclass sve_mem_64b_prfm_sv_ext_scaled<bits<2> msz, string asm,
- RegisterOperand sxtw_opnd,
- RegisterOperand uxtw_opnd,
- SDPatternOperator op_sxtw,
- SDPatternOperator op_uxtw> {
- def _UXTW_SCALED : sve_mem_64b_prfm_sv<msz, 0, 0, asm, uxtw_opnd>;
- def _SXTW_SCALED : sve_mem_64b_prfm_sv<msz, 1, 0, asm, sxtw_opnd>;
- def : Pat<(op_uxtw (nxv2i1 PPR3bAny:$Pg), (i64 GPR64sp:$Rn), (nxv2i64 uxtw_opnd:$Zm), (i32 sve_prfop:$prfop)),
- (!cast<Instruction>(NAME # _UXTW_SCALED) sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, uxtw_opnd:$Zm)>;
- def : Pat<(op_sxtw (nxv2i1 PPR3bAny:$Pg), (i64 GPR64sp:$Rn), (nxv2i64 sxtw_opnd:$Zm), (i32 sve_prfop:$prfop)),
- (!cast<Instruction>(NAME # _SXTW_SCALED) sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, sxtw_opnd:$Zm)>;
- }
- multiclass sve_mem_64b_prfm_sv_lsl_scaled<bits<2> msz, string asm,
- RegisterOperand zprext, SDPatternOperator frag> {
- def NAME : sve_mem_64b_prfm_sv<msz, 1, 1, asm, zprext>;
- def : Pat<(frag (nxv2i1 PPR3bAny:$Pg), (i64 GPR64sp:$Rn), (nxv2i64 zprext:$Zm), (i32 sve_prfop:$prfop)),
- (!cast<Instruction>(NAME) sve_prfop:$prfop, PPR3bAny:$Pg, GPR64sp:$Rn, zprext:$Zm)>;
- }
- class sve_mem_64b_prfm_vi<bits<2> msz, string asm, Operand imm_ty>
- : I<(outs), (ins sve_prfop:$prfop, PPR3bAny:$Pg, ZPR64:$Zn, imm_ty:$imm5),
- asm, "\t$prfop, $Pg, [$Zn, $imm5]",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zn;
- bits<5> imm5;
- bits<4> prfop;
- let Inst{31-25} = 0b1100010;
- let Inst{24-23} = msz;
- let Inst{22-21} = 0b00;
- let Inst{20-16} = imm5;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = 0b0;
- let Inst{3-0} = prfop;
- let hasSideEffects = 1;
- }
- multiclass sve_mem_64b_prfm_vi<bits<2> msz, string asm, Operand imm_ty, SDPatternOperator op> {
- def NAME : sve_mem_64b_prfm_vi<msz, asm, imm_ty>;
- def : InstAlias<asm # "\t$prfop, $Pg, [$Zn]",
- (!cast<Instruction>(NAME) sve_prfop:$prfop, PPR3bAny:$Pg, ZPR64:$Zn, 0), 1>;
- def : Pat<(op (nxv2i1 PPR_3b:$Pg), (nxv2i64 ZPR32:$Zn), (i64 imm_ty:$imm), (i32 sve_prfop:$prfop)),
- (!cast<Instruction>(NAME) sve_prfop:$prfop, PPR_3b:$Pg, ZPR32:$Zn, imm_ty:$imm)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Compute Vector Address Group
- //===----------------------------------------------------------------------===//
- class sve_int_bin_cons_misc_0_a<bits<2> opc, bits<2> msz, string asm,
- ZPRRegOp zprty, RegisterOperand zprext>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprext:$Zm),
- asm, "\t$Zd, [$Zn, $Zm]",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-12} = 0b1010;
- let Inst{11-10} = msz;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_bin_cons_misc_0_a_uxtw<bits<2> opc, string asm> {
- def _0 : sve_int_bin_cons_misc_0_a<opc, 0b00, asm, ZPR64, ZPR64ExtUXTW8>;
- def _1 : sve_int_bin_cons_misc_0_a<opc, 0b01, asm, ZPR64, ZPR64ExtUXTW16>;
- def _2 : sve_int_bin_cons_misc_0_a<opc, 0b10, asm, ZPR64, ZPR64ExtUXTW32>;
- def _3 : sve_int_bin_cons_misc_0_a<opc, 0b11, asm, ZPR64, ZPR64ExtUXTW64>;
- }
- multiclass sve_int_bin_cons_misc_0_a_sxtw<bits<2> opc, string asm> {
- def _0 : sve_int_bin_cons_misc_0_a<opc, 0b00, asm, ZPR64, ZPR64ExtSXTW8>;
- def _1 : sve_int_bin_cons_misc_0_a<opc, 0b01, asm, ZPR64, ZPR64ExtSXTW16>;
- def _2 : sve_int_bin_cons_misc_0_a<opc, 0b10, asm, ZPR64, ZPR64ExtSXTW32>;
- def _3 : sve_int_bin_cons_misc_0_a<opc, 0b11, asm, ZPR64, ZPR64ExtSXTW64>;
- }
- multiclass sve_int_bin_cons_misc_0_a_32_lsl<bits<2> opc, string asm> {
- def _0 : sve_int_bin_cons_misc_0_a<opc, 0b00, asm, ZPR32, ZPR32ExtLSL8>;
- def _1 : sve_int_bin_cons_misc_0_a<opc, 0b01, asm, ZPR32, ZPR32ExtLSL16>;
- def _2 : sve_int_bin_cons_misc_0_a<opc, 0b10, asm, ZPR32, ZPR32ExtLSL32>;
- def _3 : sve_int_bin_cons_misc_0_a<opc, 0b11, asm, ZPR32, ZPR32ExtLSL64>;
- }
- multiclass sve_int_bin_cons_misc_0_a_64_lsl<bits<2> opc, string asm> {
- def _0 : sve_int_bin_cons_misc_0_a<opc, 0b00, asm, ZPR64, ZPR64ExtLSL8>;
- def _1 : sve_int_bin_cons_misc_0_a<opc, 0b01, asm, ZPR64, ZPR64ExtLSL16>;
- def _2 : sve_int_bin_cons_misc_0_a<opc, 0b10, asm, ZPR64, ZPR64ExtLSL32>;
- def _3 : sve_int_bin_cons_misc_0_a<opc, 0b11, asm, ZPR64, ZPR64ExtLSL64>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Misc - Unpredicated Group
- //===----------------------------------------------------------------------===//
- class sve_int_bin_cons_misc_0_b<bits<2> sz, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b101100;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_bin_cons_misc_0_b<string asm, SDPatternOperator op> {
- def _H : sve_int_bin_cons_misc_0_b<0b01, asm, ZPR16>;
- def _S : sve_int_bin_cons_misc_0_b<0b10, asm, ZPR32>;
- def _D : sve_int_bin_cons_misc_0_b<0b11, asm, ZPR64>;
- def : SVE_2_Op_Pat<nxv8f16, op, nxv8f16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4f32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2f64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_bin_cons_misc_0_c<bits<8> opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn),
- asm, "\t$Zd, $Zn",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = opc{7-6};
- let Inst{21} = 0b1;
- let Inst{20-16} = opc{5-1};
- let Inst{15-11} = 0b10111;
- let Inst{10} = opc{0};
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let hasSideEffects = 0;
- }
- multiclass sve_int_bin_cons_misc_0_c_fexpa<string asm, SDPatternOperator op> {
- def _H : sve_int_bin_cons_misc_0_c<0b01000000, asm, ZPR16>;
- def _S : sve_int_bin_cons_misc_0_c<0b10000000, asm, ZPR32>;
- def _D : sve_int_bin_cons_misc_0_c<0b11000000, asm, ZPR64>;
- def : SVE_1_Op_Pat<nxv8f16, op, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv4f32, op, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv2f64, op, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Reduction Group
- //===----------------------------------------------------------------------===//
- class sve_int_reduce<bits<2> sz8_32, bits<2> fmt, bits<3> opc, string asm,
- ZPRRegOp zprty, FPRasZPROperand dstOpType>
- : I<(outs dstOpType:$Vd), (ins PPR3bAny:$Pg, zprty:$Zn),
- asm, "\t$Vd, $Pg, $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Vd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_32;
- let Inst{21} = 0b0;
- let Inst{20-19} = fmt;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Vd;
- }
- multiclass sve_int_reduce_0_saddv<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_reduce<0b00, 0b00, opc, asm, ZPR8, FPR64asZPR>;
- def _H : sve_int_reduce<0b01, 0b00, opc, asm, ZPR16, FPR64asZPR>;
- def _S : sve_int_reduce<0b10, 0b00, opc, asm, ZPR32, FPR64asZPR>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- }
- multiclass sve_int_reduce_0_uaddv<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_reduce<0b00, 0b00, opc, asm, ZPR8, FPR64asZPR>;
- def _H : sve_int_reduce<0b01, 0b00, opc, asm, ZPR16, FPR64asZPR>;
- def _S : sve_int_reduce<0b10, 0b00, opc, asm, ZPR32, FPR64asZPR>;
- def _D : sve_int_reduce<0b11, 0b00, opc, asm, ZPR64, FPR64asZPR>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_reduce_1<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_reduce<0b00, 0b01, opc, asm, ZPR8, FPR8asZPR>;
- def _H : sve_int_reduce<0b01, 0b01, opc, asm, ZPR16, FPR16asZPR>;
- def _S : sve_int_reduce<0b10, 0b01, opc, asm, ZPR32, FPR32asZPR>;
- def _D : sve_int_reduce<0b11, 0b01, opc, asm, ZPR64, FPR64asZPR>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- multiclass sve_int_reduce_2<bits<3> opc, string asm,
- SDPatternOperator op> {
- def _B : sve_int_reduce<0b00, 0b11, opc, asm, ZPR8, FPR8asZPR>;
- def _H : sve_int_reduce<0b01, 0b11, opc, asm, ZPR16, FPR16asZPR>;
- def _S : sve_int_reduce<0b10, 0b11, opc, asm, ZPR32, FPR32asZPR>;
- def _D : sve_int_reduce<0b11, 0b11, opc, asm, ZPR64, FPR64asZPR>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, !cast<Instruction>(NAME # _H)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- class sve_int_movprfx_pred<bits<2> sz8_32, bits<3> opc, string asm,
- ZPRRegOp zprty, string pg_suffix, dag iops>
- : I<(outs zprty:$Zd), iops,
- asm, "\t$Zd, $Pg"#pg_suffix#", $Zn",
- "",
- []>, Sched<[]> {
- bits<3> Pg;
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz8_32;
- let Inst{21-19} = 0b010;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_int_movprfx_pred_merge<bits<3> opc, string asm> {
- let Constraints = "$Zd = $_Zd" in {
- def _B : sve_int_movprfx_pred<0b00, opc, asm, ZPR8, "/m",
- (ins ZPR8:$_Zd, PPR3bAny:$Pg, ZPR8:$Zn)>;
- def _H : sve_int_movprfx_pred<0b01, opc, asm, ZPR16, "/m",
- (ins ZPR16:$_Zd, PPR3bAny:$Pg, ZPR16:$Zn)>;
- def _S : sve_int_movprfx_pred<0b10, opc, asm, ZPR32, "/m",
- (ins ZPR32:$_Zd, PPR3bAny:$Pg, ZPR32:$Zn)>;
- def _D : sve_int_movprfx_pred<0b11, opc, asm, ZPR64, "/m",
- (ins ZPR64:$_Zd, PPR3bAny:$Pg, ZPR64:$Zn)>;
- }
- }
- multiclass sve_int_movprfx_pred_zero<bits<3> opc, string asm> {
- def _B : sve_int_movprfx_pred<0b00, opc, asm, ZPR8, "/z",
- (ins PPR3bAny:$Pg, ZPR8:$Zn)>;
- def _H : sve_int_movprfx_pred<0b01, opc, asm, ZPR16, "/z",
- (ins PPR3bAny:$Pg, ZPR16:$Zn)>;
- def _S : sve_int_movprfx_pred<0b10, opc, asm, ZPR32, "/z",
- (ins PPR3bAny:$Pg, ZPR32:$Zn)>;
- def _D : sve_int_movprfx_pred<0b11, opc, asm, ZPR64, "/z",
- (ins PPR3bAny:$Pg, ZPR64:$Zn)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Propagate Break Group
- //===----------------------------------------------------------------------===//
- class sve_int_brkp<bits<2> opc, string asm>
- : I<(outs PPR8:$Pd), (ins PPRAny:$Pg, PPR8:$Pn, PPR8:$Pm),
- asm, "\t$Pd, $Pg/z, $Pn, $Pm",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<4> Pg;
- bits<4> Pm;
- bits<4> Pn;
- let Inst{31-24} = 0b00100101;
- let Inst{23} = 0b0;
- let Inst{22} = opc{1};
- let Inst{21-20} = 0b00;
- let Inst{19-16} = Pm;
- let Inst{15-14} = 0b11;
- let Inst{13-10} = Pg;
- let Inst{9} = 0b0;
- let Inst{8-5} = Pn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- let Defs = !if(!eq (opc{1}, 1), [NZCV], []);
- }
- multiclass sve_int_brkp<bits<2> opc, string asm, SDPatternOperator op> {
- def NAME : sve_int_brkp<opc, asm>;
- def : SVE_3_Op_Pat<nxv16i1, op, nxv16i1, nxv16i1, nxv16i1, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Partition Break Group
- //===----------------------------------------------------------------------===//
- class sve_int_brkn<bit S, string asm>
- : I<(outs PPR8:$Pdm), (ins PPRAny:$Pg, PPR8:$Pn, PPR8:$_Pdm),
- asm, "\t$Pdm, $Pg/z, $Pn, $_Pdm",
- "",
- []>, Sched<[]> {
- bits<4> Pdm;
- bits<4> Pg;
- bits<4> Pn;
- let Inst{31-23} = 0b001001010;
- let Inst{22} = S;
- let Inst{21-14} = 0b01100001;
- let Inst{13-10} = Pg;
- let Inst{9} = 0b0;
- let Inst{8-5} = Pn;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pdm;
- let Constraints = "$Pdm = $_Pdm";
- let Defs = !if(S, [NZCV], []);
- let ElementSize = ElementSizeB;
- }
- multiclass sve_int_brkn<bits<1> opc, string asm, SDPatternOperator op> {
- def NAME : sve_int_brkn<opc, asm>;
- def : SVE_3_Op_Pat<nxv16i1, op, nxv16i1, nxv16i1, nxv16i1, !cast<Instruction>(NAME)>;
- }
- class sve_int_break<bits<3> opc, string asm, string suffix, dag iops>
- : I<(outs PPR8:$Pd), iops,
- asm, "\t$Pd, $Pg"#suffix#", $Pn",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<4> Pg;
- bits<4> Pn;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = opc{2-1};
- let Inst{21-14} = 0b01000001;
- let Inst{13-10} = Pg;
- let Inst{9} = 0b0;
- let Inst{8-5} = Pn;
- let Inst{4} = opc{0};
- let Inst{3-0} = Pd;
- let Constraints = !if(!eq (opc{0}, 1), "$Pd = $_Pd", "");
- let Defs = !if(!eq (opc{1}, 1), [NZCV], []);
- }
- multiclass sve_int_break_m<bits<3> opc, string asm, SDPatternOperator op> {
- def NAME : sve_int_break<opc, asm, "/m", (ins PPR8:$_Pd, PPRAny:$Pg, PPR8:$Pn)>;
- def : SVE_3_Op_Pat<nxv16i1, op, nxv16i1, nxv16i1, nxv16i1, !cast<Instruction>(NAME)>;
- }
- multiclass sve_int_break_z<bits<3> opc, string asm, SDPatternOperator op> {
- def NAME : sve_int_break<opc, asm, "/z", (ins PPRAny:$Pg, PPR8:$Pn)>;
- def : SVE_2_Op_Pat<nxv16i1, op, nxv16i1, nxv16i1, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 String Processing Group
- //===----------------------------------------------------------------------===//
- class sve2_char_match<bit sz, bit opc, string asm,
- PPRRegOp pprty, ZPRRegOp zprty>
- : I<(outs pprty:$Pd), (ins PPR3bAny:$Pg, zprty:$Zn, zprty:$Zm),
- asm, "\t$Pd, $Pg/z, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<4> Pd;
- bits<3> Pg;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-23} = 0b010001010;
- let Inst{22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4} = opc;
- let Inst{3-0} = Pd;
- let Defs = [NZCV];
- let ElementSize = pprty.ElementSize;
- let isPTestLike = 1;
- }
- multiclass sve2_char_match<bit opc, string asm, SDPatternOperator op> {
- def _B : sve2_char_match<0b0, opc, asm, PPR8, ZPR8>;
- def _H : sve2_char_match<0b1, opc, asm, PPR16, ZPR16>;
- def : SVE_3_Op_Pat<nxv16i1, op, nxv16i1, nxv16i8, nxv16i8, !cast<Instruction>(NAME # _B)>;
- def : SVE_3_Op_Pat<nxv8i1, op, nxv8i1, nxv8i16, nxv8i16, !cast<Instruction>(NAME # _H)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Histogram Computation - Segment Group
- //===----------------------------------------------------------------------===//
- class sve2_hist_gen_segment<string asm, SDPatternOperator op>
- : I<(outs ZPR8:$Zd), (ins ZPR8:$Zn, ZPR8:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- [(set nxv16i8:$Zd, (op nxv16i8:$Zn, nxv16i8:$Zm))]>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-21} = 0b01000101001;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b101000;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Histogram Computation - Vector Group
- //===----------------------------------------------------------------------===//
- class sve2_hist_gen_vector<bit sz, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins PPR3bAny:$Pg, zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Pg/z, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<3> Pg;
- bits<5> Zm;
- let Inst{31-23} = 0b010001011;
- let Inst{22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b110;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_hist_gen_vector<string asm, SDPatternOperator op> {
- def _S : sve2_hist_gen_vector<0b0, asm, ZPR32>;
- def _D : sve2_hist_gen_vector<0b1, asm, ZPR64>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Instruction>(NAME # _D)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Crypto Extensions Group
- //===----------------------------------------------------------------------===//
- class sve2_crypto_cons_bin_op<bit opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, zprty:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-21} = 0b01000101001;
- let Inst{20-16} = Zm;
- let Inst{15-11} = 0b11110;
- let Inst{10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2_crypto_cons_bin_op<bit opc, string asm, ZPRRegOp zprty,
- SDPatternOperator op, ValueType vt> {
- def NAME : sve2_crypto_cons_bin_op<opc, asm, zprty>;
- def : SVE_2_Op_Pat<vt, op, vt, vt, !cast<Instruction>(NAME)>;
- }
- class sve2_crypto_des_bin_op<bits<2> opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn, zprty:$Zm),
- asm, "\t$Zdn, $_Zdn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zm;
- let Inst{31-17} = 0b010001010010001;
- let Inst{16} = opc{1};
- let Inst{15-11} = 0b11100;
- let Inst{10} = opc{0};
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- }
- multiclass sve2_crypto_des_bin_op<bits<2> opc, string asm, ZPRRegOp zprty,
- SDPatternOperator op, ValueType vt> {
- def NAME : sve2_crypto_des_bin_op<opc, asm, zprty>;
- def : SVE_2_Op_Pat<vt, op, vt, vt, !cast<Instruction>(NAME)>;
- }
- class sve2_crypto_unary_op<bit opc, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zdn), (ins zprty:$_Zdn),
- asm, "\t$Zdn, $_Zdn",
- "",
- []>, Sched<[]> {
- bits<5> Zdn;
- let Inst{31-11} = 0b010001010010000011100;
- let Inst{10} = opc;
- let Inst{9-5} = 0b00000;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- }
- multiclass sve2_crypto_unary_op<bit opc, string asm, SDPatternOperator op> {
- def NAME : sve2_crypto_unary_op<opc, asm, ZPR8>;
- def : SVE_1_Op_Pat<nxv16i8, op, nxv16i8, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE BFloat16 Group
- //===----------------------------------------------------------------------===//
- class sve_float_dot<bit bf, string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR16:$Zm),
- asm, "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-23} = 0b011001000;
- let Inst{22} = bf;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b100000;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- }
- multiclass sve_float_dot<bit bf, string asm, ValueType InVT, SDPatternOperator op> {
- def NAME : sve_float_dot<bf, asm>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4f32, InVT, InVT, !cast<Instruction>(NAME)>;
- }
- class sve_float_dot_indexed<bit bf, string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR3b16:$Zm, VectorIndexS32b:$iop),
- asm, "\t$Zda, $Zn, $Zm$iop", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<3> Zm;
- bits<2> iop;
- let Inst{31-23} = 0b011001000;
- let Inst{22} = bf;
- let Inst{21} = 0b1;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- let Inst{15-10} = 0b010000;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- }
- multiclass sve_float_dot_indexed<bit bf, string asm, ValueType InVT, SDPatternOperator op> {
- def NAME : sve_float_dot_indexed<bf, asm>;
- def : SVE_4_Op_Imm_Pat<nxv4f32, op, nxv4f32, InVT, InVT, i32, VectorIndexS32b_timm, !cast<Instruction>(NAME)>;
- }
- class sve_bfloat_matmul<string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR16:$Zm),
- asm, "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zm;
- bits<5> Zda;
- bits<5> Zn;
- let Inst{31-21} = 0b01100100011;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b111001;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeH;
- }
- multiclass sve_bfloat_matmul<string asm, SDPatternOperator op> {
- def NAME : sve_bfloat_matmul<asm>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4f32, nxv8bf16, nxv8bf16 ,!cast<Instruction>(NAME)>;
- }
- class sve_bfloat_convert<bit N, string asm>
- : I<(outs ZPR16:$Zd), (ins ZPR16:$_Zd, PPR3bAny:$Pg, ZPR32:$Zn),
- asm, "\t$Zd, $Pg/m, $Zn", "", []>, Sched<[]> {
- bits<5> Zd;
- bits<3> Pg;
- bits<5> Zn;
- let Inst{31-25} = 0b0110010;
- let Inst{24} = N;
- let Inst{23-13} = 0b10001010101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveOther;
- let hasSideEffects = 1;
- let ElementSize = ElementSizeS;
- }
- multiclass sve_bfloat_convert<bit N, string asm, SDPatternOperator op> {
- def NAME : sve_bfloat_convert<N, asm>;
- def : SVE_3_Op_Pat<nxv8bf16, op, nxv8bf16, nxv8i1, nxv4f32, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Matrix Multiply Group
- //===----------------------------------------------------------------------===//
- class sve_int_matmul<bits<2> uns, string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR8:$Zn, ZPR8:$Zm), asm,
- "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000101;
- let Inst{23-22} = uns;
- let Inst{21} = 0;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b100110;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ZPR32.ElementSize;
- }
- multiclass sve_int_matmul<bits<2> uns, string asm, SDPatternOperator op> {
- def NAME : sve_int_matmul<uns, asm>;
- def : SVE_3_Op_Pat<nxv4i32, op , nxv4i32, nxv16i8, nxv16i8, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Dot Product Mixed Sign Group
- //===----------------------------------------------------------------------===//
- class sve_int_dot_mixed<string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR8:$Zn, ZPR8:$Zm), asm,
- "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-21} = 0b01000100100;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b011110;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ZPR32.ElementSize;
- }
- multiclass sve_int_dot_mixed<string asm, SDPatternOperator op> {
- def NAME : sve_int_dot_mixed<asm>;
- def : SVE_3_Op_Pat<nxv4i32, op , nxv4i32, nxv16i8, nxv16i8, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Integer Dot Product Mixed Sign - Indexed Group
- //===----------------------------------------------------------------------===//
- class sve_int_dot_mixed_indexed<bit U, string asm>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR8:$Zn, ZPR3b8:$Zm, VectorIndexS32b:$idx),
- asm, "\t$Zda, $Zn, $Zm$idx", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<3> Zm;
- bits<2> idx;
- let Inst{31-21} = 0b01000100101;
- let Inst{20-19} = idx;
- let Inst{18-16} = Zm;
- let Inst{15-11} = 0b00011;
- let Inst{10} = U;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ZPR32.ElementSize;
- }
- multiclass sve_int_dot_mixed_indexed<bit U, string asm, SDPatternOperator op> {
- def NAME : sve_int_dot_mixed_indexed<U, asm>;
- def : SVE_4_Op_Imm_Pat<nxv4i32, op, nxv4i32, nxv16i8, nxv16i8, i32, VectorIndexS32b_timm, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Floating Point Matrix Multiply Accumulate Group
- //===----------------------------------------------------------------------===//
- class sve_fp_matrix_mla<bit sz, string asm, ZPRRegOp zprty>
- : I<(outs zprty:$Zda), (ins zprty:$_Zda, zprty:$Zn, zprty:$Zm),
- asm, "\t$Zda, $Zn, $Zm", "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-23} = 0b011001001;
- let Inst{22} = sz;
- let Inst{21} = 1;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b111001;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zprty.ElementSize;
- }
- multiclass sve_fp_matrix_mla<bit sz, string asm, ZPRRegOp zprty, SDPatternOperator op, ValueType vt> {
- def NAME : sve_fp_matrix_mla<sz, asm, zprty>;
- def : SVE_3_Op_Pat<vt, op , vt, vt, vt, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Memory - Contiguous Load And Replicate 256-bit Group
- //===----------------------------------------------------------------------===//
- class sve_mem_ldor_si<bits<2> sz, string asm, RegisterOperand VecList>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, simm4s32:$imm4),
- asm, "\t$Zt, $Pg/z, [$Rn, $imm4]", "", []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Rn;
- bits<3> Pg;
- bits<4> imm4;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = sz;
- let Inst{22-20} = 0b010;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_ldor_si<bits<2> sz, string asm, RegisterOperand listty,
- ZPRRegOp zprty, ValueType Ty, ValueType PredTy, SDNode Ld1ro> {
- def NAME : sve_mem_ldor_si<sz, asm, listty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) listty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $imm4]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s32:$imm4), 0>;
- // Base addressing mode
- def : Pat<(Ty (Ld1ro (PredTy PPR3bAny:$Pg), GPR64sp:$base)),
- (!cast<Instruction>(NAME) PPR3bAny:$Pg, GPR64sp:$base, (i64 0))>;
- let AddedComplexity = 2 in {
- // Reg + Imm addressing mode
- def : Pat<(Ty (Ld1ro (PredTy PPR3bAny:$Pg), (add GPR64:$base, (i64 simm4s32:$imm)))),
- (!cast<Instruction>(NAME) $Pg, $base, simm4s32:$imm)>;
- }
- }
- class sve_mem_ldor_ss<bits<2> sz, string asm, RegisterOperand VecList,
- RegisterOperand gprty>
- : I<(outs VecList:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm),
- asm, "\t$Zt, $Pg/z, [$Rn, $Rm]", "", []>, Sched<[]> {
- bits<5> Zt;
- bits<3> Pg;
- bits<5> Rn;
- bits<5> Rm;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = sz;
- let Inst{22-21} = 0b01;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_ldor_ss<bits<2> sz, string asm, RegisterOperand listty,
- ZPRRegOp zprty, RegisterOperand gprty, ValueType Ty,
- ValueType PredTy, SDNode Ld1ro, ComplexPattern AddrCP> {
- def NAME : sve_mem_ldor_ss<sz, asm, listty, gprty>;
- def : InstAlias<asm # "\t$Zt, $Pg/z, [$Rn, $Rm]",
- (!cast<Instruction>(NAME) zprty:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprty:$Rm), 0>;
- def : Pat<(Ty (Ld1ro (PredTy PPR3bAny:$gp), (AddrCP GPR64sp:$base, gprty:$offset))),
- (!cast<Instruction>(NAME) PPR3bAny:$gp, GPR64sp:$base, gprty:$offset)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Interleave 128-bit Elements Group
- //===----------------------------------------------------------------------===//
- class sve_int_perm_bin_perm_128_zz<bits<2> opc, bit P, string asm>
- : I<(outs ZPR128:$Zd), (ins ZPR128:$Zn, ZPR128:$Zm),
- asm, "\t$Zd, $Zn, $Zm",
- "",
- []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zm;
- bits<5> Zn;
- let Inst{31-21} = 0b00000101101;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b000;
- let Inst{12-11} = opc;
- let Inst{10} = P;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_int_perm_bin_perm_128_zz<bits<2> opc, bit P, string asm, SDPatternOperator op> {
- def NAME : sve_int_perm_bin_perm_128_zz<opc, P, asm>;
- def : SVE_2_Op_Pat<nxv16i8, op, nxv16i8, nxv16i8, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv8i16, op, nxv8i16, nxv8i16, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv8f16, op, nxv8f16, nxv8f16, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv4i32, op, nxv4i32, nxv4i32, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv4f32, op, nxv4f32, nxv4f32, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv2i64, op, nxv2i64, nxv2i64, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv2f64, op, nxv2f64, nxv2f64, !cast<Instruction>(NAME)>;
- def : SVE_2_Op_Pat<nxv8bf16, op, nxv8bf16, nxv8bf16, !cast<Instruction>(NAME)>;
- }
- /// Addressing modes
- def am_sve_indexed_s4 :ComplexPattern<iPTR, 2, "SelectAddrModeIndexedSVE<-8,7>", [], [SDNPWantRoot]>;
- def am_sve_indexed_s6 :ComplexPattern<iPTR, 2, "SelectAddrModeIndexedSVE<-32,31>", [], [SDNPWantRoot]>;
- def am_sve_regreg_lsl0 : ComplexPattern<iPTR, 2, "SelectSVERegRegAddrMode<0>", []>;
- def am_sve_regreg_lsl1 : ComplexPattern<iPTR, 2, "SelectSVERegRegAddrMode<1>", []>;
- def am_sve_regreg_lsl2 : ComplexPattern<iPTR, 2, "SelectSVERegRegAddrMode<2>", []>;
- def am_sve_regreg_lsl3 : ComplexPattern<iPTR, 2, "SelectSVERegRegAddrMode<3>", []>;
- def am_sve_regreg_lsl4 : ComplexPattern<iPTR, 2, "SelectSVERegRegAddrMode<4>", []>;
- // Predicated pseudo floating point two operand instructions.
- multiclass sve_fp_bin_pred_hfd<SDPatternOperator op> {
- def _UNDEF_H : PredTwoOpPseudo<NAME # _H, ZPR16, FalseLanesUndef>;
- def _UNDEF_S : PredTwoOpPseudo<NAME # _S, ZPR32, FalseLanesUndef>;
- def _UNDEF_D : PredTwoOpPseudo<NAME # _D, ZPR64, FalseLanesUndef>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8i1, nxv8f16, nxv8f16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- def : SVE_3_Op_Pat<nxv4f16, op, nxv4i1, nxv4f16, nxv4f16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- def : SVE_3_Op_Pat<nxv2f16, op, nxv2i1, nxv2f16, nxv2f16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4i1, nxv4f32, nxv4f32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- def : SVE_3_Op_Pat<nxv2f32, op, nxv2i1, nxv2f32, nxv2f32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2i1, nxv2f64, nxv2f64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- // Predicated pseudo integer two operand instructions.
- multiclass sve_int_bin_pred_bhsd<SDPatternOperator op> {
- def _UNDEF_B : PredTwoOpPseudo<NAME # _B, ZPR8, FalseLanesUndef>;
- def _UNDEF_H : PredTwoOpPseudo<NAME # _H, ZPR16, FalseLanesUndef>;
- def _UNDEF_S : PredTwoOpPseudo<NAME # _S, ZPR32, FalseLanesUndef>;
- def _UNDEF_D : PredTwoOpPseudo<NAME # _D, ZPR64, FalseLanesUndef>;
- def : SVE_3_Op_Pat<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Pseudo>(NAME # _UNDEF_B)>;
- def : SVE_3_Op_Pat<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- // As sve_int_bin_pred but when only i32 and i64 vector types are required.
- multiclass sve_int_bin_pred_sd<SDPatternOperator op> {
- def _UNDEF_S : PredTwoOpPseudo<NAME # _S, ZPR32, FalseLanesUndef>;
- def _UNDEF_D : PredTwoOpPseudo<NAME # _D, ZPR64, FalseLanesUndef>;
- def : SVE_3_Op_Pat<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- def : SVE_3_Op_Pat<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- // Predicated pseudo integer two operand instructions. Second operand is an
- // immediate specified by imm_[bhsd].
- multiclass sve_int_shift_pred_bhsd<SDPatternOperator op,
- ComplexPattern imm_b, ComplexPattern imm_h,
- ComplexPattern imm_s, ComplexPattern imm_d> {
- def _UNDEF_B : PredTwoOpImmPseudo<NAME # _B, ZPR8, Operand<i32>, FalseLanesUndef>;
- def _UNDEF_H : PredTwoOpImmPseudo<NAME # _H, ZPR16, Operand<i32>, FalseLanesUndef>;
- def _UNDEF_S : PredTwoOpImmPseudo<NAME # _S, ZPR32, Operand<i32>, FalseLanesUndef>;
- def _UNDEF_D : PredTwoOpImmPseudo<NAME # _D, ZPR64, Operand<i32>, FalseLanesUndef>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv16i8, op, nxv16i1, i32, imm_b, !cast<Instruction>(NAME # _UNDEF_B)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv8i16, op, nxv8i1, i32, imm_h, !cast<Instruction>(NAME # _UNDEF_H)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv4i32, op, nxv4i1, i32, imm_s, !cast<Instruction>(NAME # _UNDEF_S)>;
- def : SVE_Shift_DupImm_Pred_Pat<nxv2i64, op, nxv2i1, i64, imm_d, !cast<Instruction>(NAME # _UNDEF_D)>;
- }
- multiclass sve_int_bin_pred_all_active_bhsd<SDPatternOperator op> {
- def _UNDEF_B : PredTwoOpPseudo<NAME # _B, ZPR8, FalseLanesUndef>;
- def _UNDEF_H : PredTwoOpPseudo<NAME # _H, ZPR16, FalseLanesUndef>;
- def _UNDEF_S : PredTwoOpPseudo<NAME # _S, ZPR32, FalseLanesUndef>;
- def _UNDEF_D : PredTwoOpPseudo<NAME # _D, ZPR64, FalseLanesUndef>;
- def : SVE_2_Op_Pred_All_Active_Pt<nxv16i8, op, nxv16i1, nxv16i8, nxv16i8, !cast<Pseudo>(NAME # _UNDEF_B)>;
- def : SVE_2_Op_Pred_All_Active_Pt<nxv8i16, op, nxv8i1, nxv8i16, nxv8i16, !cast<Pseudo>(NAME # _UNDEF_H)>;
- def : SVE_2_Op_Pred_All_Active_Pt<nxv4i32, op, nxv4i1, nxv4i32, nxv4i32, !cast<Pseudo>(NAME # _UNDEF_S)>;
- def : SVE_2_Op_Pred_All_Active_Pt<nxv2i64, op, nxv2i1, nxv2i64, nxv2i64, !cast<Pseudo>(NAME # _UNDEF_D)>;
- }
- //===----------------------------------------------------------------------===//
- // SME2 or SVE2.1 Instructions
- //===----------------------------------------------------------------------===//
- class sve2p1_fclamp<string asm, bits<2> sz, ZPRRegOp zpr_ty>
- : I<(outs zpr_ty:$Zd), (ins zpr_ty:$_Zd, zpr_ty:$Zn, zpr_ty:$Zm),
- asm, "\t$Zd, $Zn, $Zm", "", []>,
- Sched<[]> {
- bits<5> Zm;
- bits<5> Zn;
- bits<5> Zd;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Zm;
- let Inst{15-10} = 0b001001;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = zpr_ty.ElementSize;
- }
- multiclass sve2p1_fclamp<string asm, SDPatternOperator op> {
- def _H : sve2p1_fclamp<asm, 0b01, ZPR16>;
- def _S : sve2p1_fclamp<asm, 0b10, ZPR32>;
- def _D : sve2p1_fclamp<asm, 0b11, ZPR64>;
- def : SVE_3_Op_Pat<nxv8f16, op, nxv8f16, nxv8f16, nxv8f16, !cast<Instruction>(NAME # _H)>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4f32, nxv4f32, nxv4f32, !cast<Instruction>(NAME # _S)>;
- def : SVE_3_Op_Pat<nxv2f64, op, nxv2f64, nxv2f64, nxv2f64, !cast<Instruction>(NAME # _D)>;
- }
- // SVE two-way dot product
- class sve2p1_two_way_dot_vv<string mnemonic, bit u>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR16:$Zm),
- mnemonic, "\t$Zda, $Zn, $Zm",
- "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-21} = 0b01000100000;
- let Inst{20-16} = Zm;
- let Inst{15-11} = 0b11001;
- let Inst{10} = u;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- }
- // SVE two-way dot product (indexed)
- class sve2p1_two_way_dot_vvi<string mnemonic, bit u>
- : I<(outs ZPR32:$Zda), (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR3b16:$Zm, VectorIndexS32b:$i2),
- mnemonic, "\t$Zda, $Zn, $Zm$i2",
- "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- bits<3> Zm;
- bits<2> i2;
- let Inst{31-21} = 0b01000100100;
- let Inst{20-19} = i2;
- let Inst{18-16} = Zm;
- let Inst{15-11} = 0b11001;
- let Inst{10} = u;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- }
- class sve2p1_ptrue_pn<string mnemonic, bits<2> sz, PNRP8to15RegOp pnrty>
- : I<(outs pnrty:$PNd), (ins ), mnemonic, "\t$PNd",
- "", []>, Sched<[]> {
- bits<3> PNd;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz;
- let Inst{21-3} = 0b1000000111100000010;
- let Inst{2-0} = PNd;
- }
- multiclass sve2p1_ptrue_pn<string mnemonic> {
- def _B : sve2p1_ptrue_pn<mnemonic, 0b00, PNR8_p8to15>;
- def _H : sve2p1_ptrue_pn<mnemonic, 0b01, PNR16_p8to15>;
- def _S : sve2p1_ptrue_pn<mnemonic, 0b10, PNR32_p8to15>;
- def _D : sve2p1_ptrue_pn<mnemonic, 0b11, PNR64_p8to15>;
- }
- // SVE extract mask predicate from predicate-as-counter
- class sve2p1_pred_as_ctr_to_mask_base<string mnemonic, bits<2> sz, bits<3> opc,
- RegisterOperand pprty, Operand idxty>
- : I<(outs pprty:$Pd), (ins PNRAny_p8to15:$PNn, idxty:$index),
- mnemonic, "\t$Pd, $PNn$index",
- "", []>, Sched<[]> {
- bits<4> Pd;
- bits<3> PNn;
- bits<2> imm2;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz;
- let Inst{21-11} = 0b10000001110;
- let Inst{10-8} = opc;
- let Inst{7-5} = PNn;
- let Inst{4} = 0b1;
- let Inst{3-0} = Pd;
- }
- class sve2p1_pred_as_ctr_to_mask<string mnemonic, bits<2> sz, PPRRegOp pprty>
- : sve2p1_pred_as_ctr_to_mask_base<mnemonic, sz, {0, ?, ?}, pprty, VectorIndexS> {
- bits<2> index;
- let Inst{9-8} = index;
- }
- multiclass sve2p1_pred_as_ctr_to_mask<string mnemonic> {
- def _B : sve2p1_pred_as_ctr_to_mask<mnemonic, 0b00, PPR8>;
- def _H : sve2p1_pred_as_ctr_to_mask<mnemonic, 0b01, PPR16>;
- def _S : sve2p1_pred_as_ctr_to_mask<mnemonic, 0b10, PPR32>;
- def _D : sve2p1_pred_as_ctr_to_mask<mnemonic, 0b11, PPR64>;
- }
- class sve2p1_pred_as_ctr_to_mask_pair<string mnemonic, bits<2> sz, RegisterOperand pprty>
- : sve2p1_pred_as_ctr_to_mask_base<mnemonic, sz, {1, 0, ?}, pprty, VectorIndexD> {
- bit index;
- let Inst{8} = index;
- }
- multiclass sve2p1_pred_as_ctr_to_mask_pair<string mnemonic> {
- def _B : sve2p1_pred_as_ctr_to_mask_pair<mnemonic, 0b00, PP_b>;
- def _H : sve2p1_pred_as_ctr_to_mask_pair<mnemonic, 0b01, PP_h>;
- def _S : sve2p1_pred_as_ctr_to_mask_pair<mnemonic, 0b10, PP_s>;
- def _D : sve2p1_pred_as_ctr_to_mask_pair<mnemonic, 0b11, PP_d>;
- }
- // SME2 multi-vec extract narrow
- class sve2p1_multi_vec_extract_narrow<string mnemonic, bits<2> opc, bits<3> tsz>
- : I<(outs ZPR16:$Zd), (ins ZZ_s_mul_r:$Zn),
- mnemonic, "\t$Zd, $Zn",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<4> Zn;
- let Inst{31-23} = 0b010001010;
- let Inst{22} = tsz{2};
- let Inst{21} = 0b1;
- let Inst{20-19} = tsz{1-0};
- let Inst{18-13} = 0b001010;
- let Inst{12-11} = opc;
- let Inst{10} = 0b0;
- let Inst{9-6} = Zn;
- let Inst{5} = 0b0;
- let Inst{4-0} = Zd;
- }
- multiclass sve2p1_multi_vec_extract_narrow<string mnemonic, bits<2> opc, SDPatternOperator intrinsic> {
- def NAME : sve2p1_multi_vec_extract_narrow<mnemonic, opc, 0b010>;
- def : SVE2p1_Cvt_VG2_Pat<NAME, intrinsic, nxv8i16, nxv4i32>;
- }
- // SVE2 multi-vec shift narrow
- class sve2p1_multi_vec_shift_narrow<string mnemonic, bits<3> opc, bits<2> tsz>
- : I<(outs ZPR16:$Zd), (ins ZZ_s_mul_r:$Zn, vecshiftR16:$imm4),
- mnemonic, "\t$Zd, $Zn, $imm4",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<4> Zn;
- bits<4> imm4;
- let Inst{31-23} = 0b010001011;
- let Inst{22} = tsz{1};
- let Inst{21} = 0b1;
- let Inst{20} = tsz{0};
- let Inst{19-16} = imm4;
- let Inst{15-14} = 0b00;
- let Inst{13-11} = opc;
- let Inst{10} = 0b0;
- let Inst{9-6} = Zn;
- let Inst{5} = 0b0;
- let Inst{4-0} = Zd;
- }
- multiclass sve2p1_multi_vec_shift_narrow<string mnemonic, bits<3> opc> {
- def : sve2p1_multi_vec_shift_narrow<mnemonic, opc, 0b01>;
- }
- // SME2 multi-vec contiguous load (scalar plus scalar, two registers)
- class sve2p1_mem_cld_ss_2z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty, RegisterOperand gpr_ty>
- : I<(outs vector_ty:$Zt),
- (ins PNRAny_p8to15:$PNg, GPR64sp:$Rn, gpr_ty:$Rm),
- mnemonic, "\t$Zt, $PNg/z, [$Rn, $Rm]",
- "", []>, Sched<[]> {
- bits<4> Zt;
- bits<5> Rm;
- bits<5> Rn;
- bits<3> PNg;
- let Inst{31-21} = 0b10100000000;
- let Inst{20-16} = Rm;
- let Inst{15} = 0b0;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-1} = Zt;
- let Inst{0} = n;
- let mayLoad = 1;
- }
- // SME2 multi-vec contiguous load (scalar plus immediate, two registers)
- class sve2p1_mem_cld_si_2z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty>
- : I<(outs vector_ty:$Zt),
- (ins PNRAny_p8to15:$PNg, GPR64sp:$Rn, simm4s2:$imm4),
- mnemonic, "\t$Zt, $PNg/z, [$Rn, $imm4, mul vl]",
- "", []>, Sched<[]> {
- bits<4> Zt;
- bits<5> Rn;
- bits<3> PNg;
- bits<4> imm4;
- let Inst{31-20} = 0b101000000100;
- let Inst{19-16} = imm4;
- let Inst{15} = 0b0;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-1} = Zt;
- let Inst{0} = n;
- let mayLoad = 1;
- }
- multiclass sve2p1_mem_cld_si_2z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty> {
- def NAME : sve2p1_mem_cld_si_2z<mnemonic, msz, n, vector_ty>;
- def : InstAlias<mnemonic # " $Zt, $PNg/z, [$Rn]",
- (!cast<Instruction>(NAME) vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn, 0), 1>;
- }
- // SME2 multi-vec contiguous load (scalar plus scalar, four registers)
- class sve2p1_mem_cld_ss_4z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty, RegisterOperand gpr_ty>
- : I<(outs vector_ty:$Zt),
- (ins PNRAny_p8to15:$PNg, GPR64sp:$Rn, gpr_ty:$Rm),
- mnemonic, "\t$Zt, $PNg/z, [$Rn, $Rm]",
- "", []>, Sched<[]> {
- bits<3> Zt;
- bits<5> Rm;
- bits<5> Rn;
- bits<3> PNg;
- let Inst{31-21} = 0b10100000000;
- let Inst{20-16} = Rm;
- let Inst{15} = 0b1;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-2} = Zt;
- let Inst{1} = 0b0;
- let Inst{0} = n;
- let mayLoad = 1;
- }
- // SME2 multi-vec contiguous load (scalar plus immediate, four registers)
- class sve2p1_mem_cld_si_4z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty>
- : I<(outs vector_ty:$Zt),
- (ins PNRAny_p8to15:$PNg, GPR64sp:$Rn, simm4s4:$imm4),
- mnemonic, "\t$Zt, $PNg/z, [$Rn, $imm4, mul vl]",
- "", []>, Sched<[]> {
- bits<3> Zt;
- bits<5> Rn;
- bits<3> PNg;
- bits<4> imm4;
- let Inst{31-20} = 0b101000000100;
- let Inst{19-16} = imm4;
- let Inst{15} = 0b1;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-2} = Zt;
- let Inst{1} = 0b0;
- let Inst{0} = n;
- let mayLoad = 1;
- }
- multiclass sve2p1_mem_cld_si_4z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty> {
- def NAME : sve2p1_mem_cld_si_4z<mnemonic, msz, n, vector_ty>;
- def : InstAlias<mnemonic # " $Zt, $PNg/z, [$Rn]",
- (!cast<Instruction>(NAME) vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn, 0), 1>;
- }
- // SME2 multi-vec contiguous store (scalar plus scalar, two registers)
- class sve2p1_mem_cst_ss_2z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty, RegisterOperand gpr_ty>
- : I<(outs ),
- (ins vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn, gpr_ty:$Rm),
- mnemonic, "\t$Zt, $PNg, [$Rn, $Rm]",
- "", []>, Sched<[]> {
- bits<4> Zt;
- bits<5> Rm;
- bits<5> Rn;
- bits<3> PNg;
- let Inst{31-21} = 0b10100000001;
- let Inst{20-16} = Rm;
- let Inst{15} = 0b0;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-1} = Zt;
- let Inst{0} = n;
- let mayStore = 1;
- }
- // SME2 multi-vec contiguous store (scalar plus immediate, two registers)
- class sve2p1_mem_cst_si_2z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty>
- : I<(outs ),
- (ins vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn, simm4s2:$imm4),
- mnemonic, "\t$Zt, $PNg, [$Rn, $imm4, mul vl]",
- "", []>, Sched<[]> {
- bits<4> Zt;
- bits<5> Rn;
- bits<3> PNg;
- bits<4> imm4;
- let Inst{31-20} = 0b101000000110;
- let Inst{19-16} = imm4;
- let Inst{15} = 0b0;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-1} = Zt;
- let Inst{0} = n;
- let mayStore = 1;
- }
- multiclass sve2p1_mem_cst_si_2z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty> {
- def NAME : sve2p1_mem_cst_si_2z<mnemonic, msz, n, vector_ty>;
- def : InstAlias<mnemonic # " $Zt, $PNg, [$Rn]",
- (!cast<Instruction>(NAME) vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn, 0), 1>;
- }
- // SME2 multi-vec contiguous store (scalar plus scalar, four registers)
- class sve2p1_mem_cst_ss_4z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty, RegisterOperand gpr_ty>
- : I<(outs ),
- (ins vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn, gpr_ty:$Rm),
- mnemonic, "\t$Zt, $PNg, [$Rn, $Rm]",
- "", []>, Sched<[]> {
- bits<3> Zt;
- bits<5> Rm;
- bits<5> Rn;
- bits<3> PNg;
- let Inst{31-21} = 0b10100000001;
- let Inst{20-16} = Rm;
- let Inst{15} = 0b1;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-2} = Zt;
- let Inst{1} = 0b0;
- let Inst{0} = n;
- let mayStore = 1;
- }
- // SME2 multi-vec contiguous store (scalar plus immediate, four registers)
- class sve2p1_mem_cst_si_4z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty>
- : I<(outs ),
- (ins vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn, simm4s4:$imm4),
- mnemonic, "\t$Zt, $PNg, [$Rn, $imm4, mul vl]",
- "", []>, Sched<[]> {
- bits<3> Zt;
- bits<5> Rn;
- bits<3> PNg;
- bits<4> imm4;
- let Inst{31-20} = 0b101000000110;
- let Inst{19-16} = imm4;
- let Inst{15} = 0b1;
- let Inst{14-13} = msz;
- let Inst{12-10} = PNg;
- let Inst{9-5} = Rn;
- let Inst{4-2} = Zt;
- let Inst{1} = 0b0;
- let Inst{0} = n;
- let mayStore = 1;
- }
- multiclass sve2p1_mem_cst_si_4z<string mnemonic, bits<2> msz, bit n,
- RegisterOperand vector_ty> {
- def NAME : sve2p1_mem_cst_si_4z<mnemonic, msz, n, vector_ty>;
- def : InstAlias<mnemonic # " $Zt, $PNg, [$Rn]",
- (!cast<Instruction>(NAME) vector_ty:$Zt, PNRAny_p8to15:$PNg, GPR64sp:$Rn,0), 1>;
- }
- // SVE predicate count (predicate-as-counter)
- class sve2p1_pcount_pn<string mnemonic, bits<3> opc, bits<2> sz, PNRRegOp pnrty>
- : I<(outs GPR64:$Rd),
- (ins pnrty:$PNn, sve_vec_len_specifier_enum:$vl),
- mnemonic, "\t$Rd, $PNn, $vl",
- "", []>, Sched<[]> {
- bits<5> Rd;
- bits<4> PNn;
- bits<1> vl;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b100;
- let Inst{18-16} = opc;
- let Inst{15-11} = 0b10000;
- let Inst{10} = vl;
- let Inst{9} = 0b1;
- let Inst{8-5} = PNn;
- let Inst{4-0} = Rd;
- }
- multiclass sve2p1_pcount_pn<string mnemonic, bits<3> opc> {
- def _B : sve2p1_pcount_pn<mnemonic, opc, 0b00, PNR8>;
- def _H : sve2p1_pcount_pn<mnemonic, opc, 0b01, PNR16>;
- def _S : sve2p1_pcount_pn<mnemonic, opc, 0b10, PNR32>;
- def _D : sve2p1_pcount_pn<mnemonic, opc, 0b11, PNR64>;
- }
- // SVE integer compare scalar count and limit (predicate-as-counter)
- class sve2p1_int_while_rr_pn<string mnemonic, bits<2> sz, bits<3> opc,
- PNRP8to15RegOp pnrty>
- : I<(outs pnrty:$PNd), (ins GPR64:$Rn, GPR64:$Rm, sve_vec_len_specifier_enum:$vl),
- mnemonic, "\t$PNd, $Rn, $Rm, $vl",
- "", []>, Sched<[]> {
- bits<3> PNd;
- bits<5> Rn;
- bits<1> vl;
- bits<5> Rm;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-14} = 0b01;
- let Inst{13} = vl;
- let Inst{12} = 0b0;
- let Inst{11-10} = opc{2-1};
- let Inst{9-5} = Rn;
- let Inst{4} = 0b1;
- let Inst{3} = opc{0};
- let Inst{2-0} = PNd;
- let Defs = [NZCV];
- }
- multiclass sve2p1_int_while_rr_pn<string mnemonic, bits<3> opc> {
- def _B : sve2p1_int_while_rr_pn<mnemonic, 0b00, opc, PNR8_p8to15>;
- def _H : sve2p1_int_while_rr_pn<mnemonic, 0b01, opc, PNR16_p8to15>;
- def _S : sve2p1_int_while_rr_pn<mnemonic, 0b10, opc, PNR32_p8to15>;
- def _D : sve2p1_int_while_rr_pn<mnemonic, 0b11, opc, PNR64_p8to15>;
- }
- // SVE integer compare scalar count and limit (predicate pair)
- class sve2p1_int_while_rr_pair<string mnemonic, bits<2> sz, bits<3> opc,
- RegisterOperand ppr_ty>
- : I<(outs ppr_ty:$Pd), (ins GPR64:$Rn, GPR64:$Rm),
- mnemonic, "\t$Pd, $Rn, $Rm",
- "", []>, Sched<[]> {
- bits<3> Pd;
- bits<5> Rn;
- bits<5> Rm;
- let Inst{31-24} = 0b00100101;
- let Inst{23-22} = sz;
- let Inst{21} = 0b1;
- let Inst{20-16} = Rm;
- let Inst{15-12} = 0b0101;
- let Inst{11-10} = opc{2-1};
- let Inst{9-5} = Rn;
- let Inst{4} = 0b1;
- let Inst{3-1} = Pd;
- let Inst{0} = opc{0};
- let Defs = [NZCV];
- }
- multiclass sve2p1_int_while_rr_pair<string mnemonic, bits<3> opc> {
- def _B : sve2p1_int_while_rr_pair<mnemonic, 0b00, opc, PP_b_mul_r>;
- def _H : sve2p1_int_while_rr_pair<mnemonic, 0b01, opc, PP_h_mul_r>;
- def _S : sve2p1_int_while_rr_pair<mnemonic, 0b10, opc, PP_s_mul_r>;
- def _D : sve2p1_int_while_rr_pair<mnemonic, 0b11, opc, PP_d_mul_r>;
- }
- class sve_mem_128b_gld_64_unscaled<string mnemonic>
- : I<(outs Z_q:$Zt), (ins PPR3bAny:$Pg, ZPR64:$Zn, GPR64:$Rm),
- mnemonic, "\t$Zt, $Pg/z, [$Zn, $Rm]",
- "", []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Zn;
- bits<3> Pg;
- bits<5> Rm;
- let Inst{31-21} = 0b11000100000;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_128b_gld_64_unscaled<string mnemonic> {
- def NAME : sve_mem_128b_gld_64_unscaled<mnemonic>;
- def : InstAlias<mnemonic # " $Zt, $Pg/z, [$Zn]",
- (!cast<Instruction>(NAME) Z_q:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, XZR), 1>;
- }
- class sve_mem_sst_128b_64_unscaled<string mnemonic>
- : I<(outs ), (ins Z_q:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, GPR64:$Rm),
- mnemonic, "\t$Zt, $Pg, [$Zn, $Rm]",
- "", []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Zn;
- bits<3> Pg;
- bits<5> Rm;
- let Inst{31-21} = 0b11100100001;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zt;
- let mayStore = 1;
- }
- multiclass sve_mem_sst_128b_64_unscaled<string mnemonic> {
- def NAME : sve_mem_sst_128b_64_unscaled<mnemonic>;
- def : InstAlias<mnemonic # " $Zt, $Pg, [$Zn]",
- (!cast<Instruction>(NAME) Z_q:$Zt, PPR3bAny:$Pg, ZPR64:$Zn, XZR), 1>;
- }
- // SVE contiguous load (quadwords, scalar plus immediate)
- class sve_mem_128b_cld_si<bits<2> dtype, string mnemonic>
- : I<(outs Z_q:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4),
- mnemonic, "\t$Zt, $Pg/z, [$Rn, $imm4, mul vl]",
- "", []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Rn;
- bits<3> Pg;
- bits<4> imm4;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = dtype;
- let Inst{22-20} = 0b001;
- let Inst{19-16} = imm4;
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_128b_cld_si<bits<2> dtype, string mnemonic> {
- def NAME : sve_mem_128b_cld_si<dtype, mnemonic>;
- def : InstAlias<mnemonic # " $Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) Z_q:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 1>;
- def : InstAlias<mnemonic # " $Zt, $Pg/z, [$Rn]",
- (!cast<Instruction>(NAME) ZPR128:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, 0), 0>;
- def : InstAlias<mnemonic # " $Zt, $Pg/z, [$Rn, $imm4, mul vl]",
- (!cast<Instruction>(NAME) ZPR128:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, simm4s1:$imm4), 0>;
- }
- // SVE contiguous load (quadwords, scalar plus scalar)
- class sve_mem_128b_cld_ss<bits<2> dtype, string mnemonic, RegisterOperand gprsh_ty>
- : I<(outs Z_q:$Zt), (ins PPR3bAny:$Pg, GPR64sp:$Rn, gprsh_ty:$Rm),
- mnemonic, "\t$Zt, $Pg/z, [$Rn, $Rm]", "",
- []>, Sched<[]> {
- bits<5> Zt;
- bits<5> Rn;
- bits<3> Pg;
- bits<5> Rm;
- let Inst{31-25} = 0b1010010;
- let Inst{24-23} = dtype;
- let Inst{22-21} = 0b00;
- let Inst{20-16} = Rm;
- let Inst{15-13} = 0b100;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Rn;
- let Inst{4-0} = Zt;
- let mayLoad = 1;
- }
- multiclass sve_mem_128b_cld_ss<bits<2> dtype, string mnemonic, RegisterOperand gprsh_ty> {
- def NAME : sve_mem_128b_cld_ss<dtype, mnemonic, gprsh_ty>;
- def : InstAlias<mnemonic # " $Zt, $Pg/z, [$Rn, $Rm]",
- (!cast<Instruction>(NAME) ZPR128:$Zt, PPR3bAny:$Pg, GPR64sp:$Rn, gprsh_ty:$Rm), 0>;
- }
- // SVE floating-point recursive reduction (quadwords)
- class sve2p1_fp_reduction_q<bits<2> sz, bits<3> opc, string mnemonic,
- RegisterOperand zpr_ty, string vec_sfx>
- : I<(outs V128:$Vd), (ins PPR3bAny:$Pg, zpr_ty:$Zn),
- mnemonic, "\t$Vd." # vec_sfx # ", $Pg, $Zn",
- "", []>, Sched<[]> {
- bits<5> Vd;
- bits<5> Zn;
- bits<3> Pg;
- let Inst{31-24} = 0b01100100;
- let Inst{23-22} = sz;
- let Inst{21-19} = 0b010;
- let Inst{18-16} = opc;
- let Inst{15-13} = 0b101;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Vd;
- }
- multiclass sve2p1_fp_reduction_q<bits<3> opc, string mnemonic> {
- def _H : sve2p1_fp_reduction_q<0b01, opc, mnemonic, ZPR16, "8h">;
- def _S : sve2p1_fp_reduction_q<0b10, opc, mnemonic, ZPR32, "4s">;
- def _D : sve2p1_fp_reduction_q<0b11, opc, mnemonic, ZPR64, "2d">;
- }
- // SVE Permute Vector - Quadwords (DUPQ)
- class sve2p1_dupq<bits<5> ind_tsz, string mnemonic, ZPRRegOp zprty, Operand itype>
- : I<(outs zprty:$Zd), (ins zprty:$Zn, itype:$index),
- mnemonic, "\t$Zd, $Zn$index",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- let Inst{31-21} = 0b00000101001;
- let Inst{20-16} = ind_tsz;
- let Inst{15-10} = 0b001001;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2p1_dupq<string mnemonic> {
- def _B : sve2p1_dupq<{?, ?, ?, ?, 1}, mnemonic, ZPR8, VectorIndexB32b> {
- bits<4> index;
- let Inst{20-17} = index;
- }
- def _H : sve2p1_dupq<{?, ?, ?, 1, 0}, mnemonic, ZPR16, VectorIndexH32b> {
- bits<3> index;
- let Inst{20-18} = index;
- }
- def _S : sve2p1_dupq<{?, ?, 1, 0, 0}, mnemonic, ZPR32, VectorIndexS32b> {
- bits<2> index;
- let Inst{20-19} = index;
- }
- def _D : sve2p1_dupq<{?, 1, 0, 0, 0}, mnemonic, ZPR64, VectorIndexD32b> {
- bits<1> index;
- let Inst{20} = index;
- }
- }
- // SVE Permute Vector - Quadwords (EXTQ)
- class sve2p1_extq<string mnemonic>
- : I<(outs ZPR8:$Zdn), (ins ZPR8:$_Zdn, ZPR8:$Zm, imm0_15:$imm4),
- mnemonic, "\t$Zdn, $_Zdn, $Zm, $imm4",
- "", []>, Sched<[]> {
- bits<5> Zdn;
- bits<5> Zm;
- bits<4> imm4;
- let Inst{31-20} = 0b000001010110;
- let Inst{19-16} = imm4;
- let Inst{15-10} = 0b001001;
- let Inst{9-5} = Zm;
- let Inst{4-0} = Zdn;
- let Constraints = "$Zdn = $_Zdn";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ZPR8.ElementSize;
- }
- // SVE move predicate from vector
- class sve2p1_vector_to_pred<bits<4> opc, string mnemonic,
- PPRRegOp ppr_ty, Operand itype>
- : I<(outs ppr_ty:$Pd), (ins ZPRAny:$Zn, itype:$index),
- mnemonic, "\t$Pd, $Zn$index",
- "", []>, Sched<[]> {
- bits<4> Pd;
- bits<5> Zn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = opc{3-2};
- let Inst{21-19} = 0b101;
- let Inst{18-17} = opc{1-0};
- let Inst{16-10} = 0b0001110;
- let Inst{9-5} = Zn;
- let Inst{4} = 0b0;
- let Inst{3-0} = Pd;
- }
- multiclass sve2p1_vector_to_pred<string mnemonic> {
- def _B : sve2p1_vector_to_pred<{0, 0, 0, 1}, mnemonic, PPR8, VectorIndex0>;
- def _H : sve2p1_vector_to_pred<{0, 0, 1, ?}, mnemonic, PPR16, VectorIndexD32b> {
- bits<1> index;
- let Inst{17} = index;
- }
- def _S : sve2p1_vector_to_pred<{0, 1, ?, ?}, mnemonic, PPR32, VectorIndexS32b> {
- bits<2> index;
- let Inst{18-17} = index;
- }
- def _D : sve2p1_vector_to_pred<{1, ?, ?, ?}, mnemonic, PPR64, VectorIndexH32b> {
- bits<3> index;
- let Inst{22} = index{2};
- let Inst{18-17} = index{1-0};
- }
- def : InstAlias<mnemonic # "\t$Pd, $Zn",
- (!cast<Instruction>(NAME # _B) PPR8:$Pd, ZPRAny:$Zn, 0), 1>;
- }
- // SVE move predicate into vector
- class sve2p1_pred_to_vector<bits<4> opc, string mnemonic,
- PPRRegOp ppr_ty, Operand itype>
- : I<(outs ZPRAny:$Zd), (ins ZPRAny:$_Zd, itype:$index, ppr_ty:$Pn),
- mnemonic, "\t$Zd$index, $Pn",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<4> Pn;
- let Inst{31-24} = 0b00000101;
- let Inst{23-22} = opc{3-2};
- let Inst{21-19} = 0b101;
- let Inst{18-17} = opc{1-0};
- let Inst{16-9} = 0b10011100;
- let Inst{8-5} = Pn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2p1_pred_to_vector<string mnemonic> {
- def _B : sve2p1_pred_to_vector<{0, 0, 0, 1}, mnemonic, PPR8, VectorIndex0>;
- def _H : sve2p1_pred_to_vector<{0, 0, 1, ?}, mnemonic, PPR16, VectorIndexD32b> {
- bits<1> index;
- let Inst{17} = index;
- }
- def _S : sve2p1_pred_to_vector<{0, 1, ?, ?}, mnemonic, PPR32, VectorIndexS32b> {
- bits<2> index;
- let Inst{18-17} = index;
- }
- def _D : sve2p1_pred_to_vector<{1, ?, ?, ?}, mnemonic, PPR64, VectorIndexH32b> {
- bits<3> index;
- let Inst{22} = index{2};
- let Inst{18-17} = index{1-0};
- }
- def : InstAlias<mnemonic # "\t$Zd, $Pn",
- (!cast<Instruction>(NAME # _B) ZPRAny:$Zd, 0, PPR8:$Pn), 1>;
- }
- // SVE bitwise logical/add/min/max reductions (quadwords)
- class sve2p1_int_reduce_q<bits<2> sz, bits<4> opc, string mnemonic,
- RegisterOperand zpr_ty, string vec_sfx>
- : I<(outs V128:$Vd), (ins PPR3bAny:$Pg, zpr_ty:$Zn),
- mnemonic, "\t$Vd." # vec_sfx # ", $Pg, $Zn",
- "", []>, Sched<[]> {
- bits<5> Vd;
- bits<5> Zn;
- bits<3> Pg;
- let Inst{31-24} = 0b00000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-19} = opc{3-2};
- let Inst{18} = 0b1;
- let Inst{17-16} = opc{1-0};
- let Inst{15-13} = 0b001;
- let Inst{12-10} = Pg;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Vd;
- }
- multiclass sve2p1_int_reduce_q<bits<4> opc, string mnemonic> {
- def _B : sve2p1_int_reduce_q<0b00, opc, mnemonic, ZPR8, "16b">;
- def _H : sve2p1_int_reduce_q<0b01, opc, mnemonic, ZPR16, "8h">;
- def _S : sve2p1_int_reduce_q<0b10, opc, mnemonic, ZPR32, "4s">;
- def _D : sve2p1_int_reduce_q<0b11, opc, mnemonic, ZPR64, "2d">;
- }
- // SVE permute vector elements (quadwords)
- class sve2p1_permute_vec_elems_q<bits<2> sz, bits<3> opc, string mnemonic,
- ZPRRegOp zpr_ty, RegisterOperand src1_ty>
- : I<(outs zpr_ty:$Zd), (ins src1_ty:$Zn, zpr_ty:$Zm),
- mnemonic, "\t$Zd, $Zn, $Zm",
- "", []>, Sched<[]> {
- bits<5> Zd;
- bits<5> Zn;
- bits<5> Zm;
- let Inst{31-24} = 0b01000100;
- let Inst{23-22} = sz;
- let Inst{21} = 0b0;
- let Inst{20-16} = Zm;
- let Inst{15-13} = 0b111;
- let Inst{12-10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve2p1_permute_vec_elems_q<bits<3> opc, string mnemonic> {
- def _B : sve2p1_permute_vec_elems_q<0b00, opc, mnemonic, ZPR8, ZPR8>;
- def _H : sve2p1_permute_vec_elems_q<0b01, opc, mnemonic, ZPR16, ZPR16>;
- def _S : sve2p1_permute_vec_elems_q<0b10, opc, mnemonic, ZPR32, ZPR32>;
- def _D : sve2p1_permute_vec_elems_q<0b11, opc, mnemonic, ZPR64, ZPR64>;
- }
- multiclass sve2p1_tblq<string mnemonic> {
- def _B : sve2p1_permute_vec_elems_q<0b00, 0b110, mnemonic, ZPR8, Z_b>;
- def _H : sve2p1_permute_vec_elems_q<0b01, 0b110, mnemonic, ZPR16, Z_h>;
- def _S : sve2p1_permute_vec_elems_q<0b10, 0b110, mnemonic, ZPR32, Z_s>;
- def _D : sve2p1_permute_vec_elems_q<0b11, 0b110, mnemonic, ZPR64, Z_d>;
- }
|