1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515 |
- //=-- 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 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 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 SVE8BitLslImm32 : ComplexPattern<i32, 2, "SelectSVE8BitLslImm", [imm]>;
- def SVE8BitLslImm64 : ComplexPattern<i64, 2, "SelectSVE8BitLslImm", [imm]>;
- class SVE8BitLslImm<ValueType ty> {
- ComplexPattern Pat = !cond(
- !eq(ty, i32): SVE8BitLslImm32,
- !eq(ty, i64): SVE8BitLslImm64);
- }
- 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 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 = [HasSVEorStreamingSVE] in {
- defm PTRUE : sve_int_ptrue<0b000, "ptrue", AArch64ptrue>;
- defm PTRUES : sve_int_ptrue<0b001, "ptrues", null_frag>;
- }
- //===----------------------------------------------------------------------===//
- // 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_Reverse_Pat<ValueType vt, SDPatternOperator op, ZPRRegOp zprty,
- ValueType it, ComplexPattern cpx, Instruction inst>
- : Pat<(vt (op (vt (AArch64dup (it (cpx i32:$imm, i32:$shift)))), (vt zprty:$Op1))),
- (inst $Op1, i32:$imm, i32:$shift)>;
- 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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (it immL))))),
- (inst $Pg, $Zs1, imm)>;
- //
- // 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 : Pat<(nxv16i1 (splat_vector (i32 0))), (!cast<Instruction>(NAME))>;
- def : Pat<(nxv8i1 (splat_vector (i32 0))), (!cast<Instruction>(NAME))>;
- def : Pat<(nxv4i1 (splat_vector (i32 0))), (!cast<Instruction>(NAME))>;
- def : Pat<(nxv2i1 (splat_vector (i32 0))), (!cast<Instruction>(NAME))>;
- }
- class sve_int_ptest<bits<6> opc, string asm>
- : I<(outs), (ins PPRAny:$Pg, PPR8:$Pn),
- asm, "\t$Pg, $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;
- }
- 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;
- }
- 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 = [HasSVEorStreamingSVE] 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 = [HasSVEorStreamingSVE, 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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (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 (AArch64dup (f64 (vector_extract (nxv2f64 ZPR:$vec), sve_elm_idx_extdup_d:$index)))),
- (!cast<Instruction>(NAME # _D) ZPR:$vec, sve_elm_idx_extdup_d:$index)>;
- }
- 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, 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-10} = 0b001011;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- let Constraints = "$Zd = $_Zd";
- }
- multiclass sve2_int_perm_tbx<string asm, SDPatternOperator op> {
- def _B : sve2_int_perm_tbx<0b00, asm, ZPR8>;
- def _H : sve2_int_perm_tbx<0b01, asm, ZPR16>;
- def _S : sve2_int_perm_tbx<0b10, asm, ZPR32>;
- def _D : sve2_int_perm_tbx<0b11, 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>
- : I<(outs pprty:$Pd), (ins pprty:$Pn),
- asm, "\t$Pd, $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 op> {
- def _B : sve_int_perm_reverse_p<0b00, asm, PPR8>;
- def _H : sve_int_perm_reverse_p<0b01, asm, PPR16>;
- def _S : sve_int_perm_reverse_p<0b10, asm, PPR32>;
- def _D : sve_int_perm_reverse_p<0b11, asm, PPR64>;
- def : SVE_1_Op_Pat<nxv16i1, op, nxv16i1, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Pat<nxv8i1, op, nxv8i1, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Pat<nxv4i1, op, nxv4i1, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Pat<nxv2i1, 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_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>;
- }
- // 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)>;
- }
- //===----------------------------------------------------------------------===//
- // 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>;
- def : Pat<(nxv2i64 (AArch64dup (i64 logical_imm64:$imm))),
- (!cast<Instruction>(NAME) logical_imm64:$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;
- }
- multiclass sve_fp_3op_p_zds_a<bits<2> opc, string asm, string Ps,
- SDPatternOperator op, string revname,
- bit isReverseInstr=0> {
- let DestructiveInstType = DestructiveTernaryCommWithRev in {
- 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, bit 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-11} = 0;
- let Inst{10} = opc;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeNone;
- }
- multiclass sve_fp_fma_by_indexed_elem<bit 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, 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-10} = 0b001000;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zd;
- }
- multiclass sve_fp_fmul_by_indexed_elem<string asm, SDPatternOperator op> {
- def _H : sve_fp_fmul_by_indexed_elem<{0, ?}, 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, 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, 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<2> 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-21} = 0b01100100101;
- 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<2> opc, string asm,
- SDPatternOperator op> {
- def NAME : sve2_fp_mla_long_by_indexed_elem<opc, asm>;
- def : SVE_4_Op_Imm_Pat<nxv4f32, op, nxv4f32, nxv8f16, nxv8f16, i32, VectorIndexH32b_timm, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE2 Floating Point Widening Multiply-Add Group
- //===----------------------------------------------------------------------===//
- class sve2_fp_mla_long<bits<2> 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-21} = 0b01100100101;
- 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<2> opc, string asm, SDPatternOperator op> {
- def NAME : sve2_fp_mla_long<opc, asm>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4f32, nxv8f16, nxv8f16, !cast<Instruction>(NAME)>;
- }
- //===----------------------------------------------------------------------===//
- // SVE Stack Allocation Group
- //===----------------------------------------------------------------------===//
- class sve_int_arith_vl<bit opc, string asm>
- : 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-11} = 0b01010;
- let Inst{10-5} = imm6;
- let Inst{4-0} = Rd;
- }
- class sve_int_read_vl_a<bit op, bits<5> opc2, string asm>
- : 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-11} = 0b01010;
- let Inst{10-5} = imm6;
- let Inst{4-0} = Rd;
- }
- //===----------------------------------------------------------------------===//
- // 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, SDPatternOperator op> {
- def _B : sve_int_bin_pred_arit_log<0b00, 0b11, opc, asm, ZPR8>;
- def _H : sve_int_bin_pred_arit_log<0b01, 0b11, opc, asm, ZPR16>;
- def _S : sve_int_bin_pred_arit_log<0b10, 0b11, opc, asm, ZPR32>;
- def _D : sve_int_bin_pred_arit_log<0b11, 0b11, opc, 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)>;
- }
- 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,
- SDPatternOperator outerop, SDPatternOperator mulop> {
- 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)>;
- def : Pat<(outerop nxv16i8:$Op1, (mulop nxv16i1:$pred, nxv16i8:$Op2, nxv16i8:$Op3)),
- (!cast<Instruction>(NAME # _B) $pred, $Op1, $Op2, $Op3)>;
- def : Pat<(outerop nxv8i16:$Op1, (mulop nxv8i1:$pred, nxv8i16:$Op2, nxv8i16:$Op3)),
- (!cast<Instruction>(NAME # _H) $pred, $Op1, $Op2, $Op3)>;
- def : Pat<(outerop nxv4i32:$Op1, (mulop nxv4i1:$pred, nxv4i32:$Op2, nxv4i32:$Op3)),
- (!cast<Instruction>(NAME # _S) $pred, $Op1, $Op2, $Op3)>;
- def : Pat<(outerop nxv2i64:$Op1, (mulop nxv2i1:$pred, nxv2i64:$Op2, nxv2i64:$Op3)),
- (!cast<Instruction>(NAME # _D) $pred, $Op1, $Op2, $Op3)>;
- }
- //===----------------------------------------------------------------------===//
- // 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> {
- 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)>;
- }
- 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)>;
- }
- multiclass sve_int_arith_imm0_subr<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_Reverse_Pat<nxv16i8, op, ZPR8, i32, SVEAddSubImm8Pat, !cast<Instruction>(NAME # _B)>;
- def : SVE_1_Op_Imm_OptLsl_Reverse_Pat<nxv8i16, op, ZPR16, i32, SVEAddSubImm16Pat, !cast<Instruction>(NAME # _H)>;
- def : SVE_1_Op_Imm_OptLsl_Reverse_Pat<nxv4i32, op, ZPR32, i32, SVEAddSubImm32Pat, !cast<Instruction>(NAME # _S)>;
- def : SVE_1_Op_Imm_OptLsl_Reverse_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>;
- def _H : sve_int_arith_imm<0b01, { 0b1010, opc }, asm, ZPR16, simm8>;
- def _S : sve_int_arith_imm<0b10, { 0b1010, opc }, asm, ZPR32, simm8>;
- def _D : sve_int_arith_imm<0b11, { 0b1010, opc }, asm, ZPR64, simm8>;
- 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>;
- def _H : sve_int_arith_imm<0b01, 0b110000, asm, ZPR16, simm8>;
- def _S : sve_int_arith_imm<0b10, 0b110000, asm, ZPR32, simm8>;
- def _D : sve_int_arith_imm<0b11, 0b110000, asm, ZPR64, simm8>;
- 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> {
- 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)>;
- }
- 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, ValueType intty,
- ValueType predty, ValueType scalarty, imm8_opt_lsl cpyimm> {
- 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<(intty
- (vselect predty:$Pg,
- (intty (AArch64dup (scalarty (SVE8BitLslImm<scalarty>.Pat i32:$imm, i32:$shift)))),
- intty:$Zd)),
- (!cast<Instruction>(NAME) zprty:$Zd, $Pg, i32:$imm, i32:$shift)>;
- }
- multiclass sve_int_dup_imm_pred_merge<string asm> {
- defm _B : sve_int_dup_imm_pred_merge_inst<0b00, asm, ZPR8, nxv16i8, nxv16i1,
- i32, cpy_imm8_opt_lsl_i8>;
- defm _H : sve_int_dup_imm_pred_merge_inst<0b01, asm, ZPR16, nxv8i16, nxv8i1,
- i32, cpy_imm8_opt_lsl_i16>;
- defm _S : sve_int_dup_imm_pred_merge_inst<0b10, asm, ZPR32, nxv4i32, nxv4i1,
- i32, cpy_imm8_opt_lsl_i32>;
- defm _D : sve_int_dup_imm_pred_merge_inst<0b11, asm, ZPR64, nxv2i64, nxv2i1,
- i64, cpy_imm8_opt_lsl_i64>;
- 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>;
- }
- multiclass sve_int_dup_imm_pred_zero_inst<
- bits<2> sz8_64, string asm, ZPRRegOp zprty, ValueType intty,
- ValueType predty, ValueType scalarty, imm8_opt_lsl cpyimm> {
- 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<(intty
- (vselect predty:$Pg,
- (intty (AArch64dup (scalarty (SVE8BitLslImm<scalarty>.Pat i32:$imm, i32:$shift)))),
- (intty (AArch64dup (scalarty 0))))),
- (!cast<Instruction>(NAME) $Pg, i32:$imm, i32:$shift)>;
- }
- multiclass sve_int_dup_imm_pred_zero<string asm> {
- defm _B : sve_int_dup_imm_pred_zero_inst<0b00, asm, ZPR8, nxv16i8, nxv16i1,
- i32, cpy_imm8_opt_lsl_i8>;
- defm _H : sve_int_dup_imm_pred_zero_inst<0b01, asm, ZPR16, nxv8i16, nxv8i1,
- i32, cpy_imm8_opt_lsl_i16>;
- defm _S : sve_int_dup_imm_pred_zero_inst<0b10, asm, ZPR32, nxv4i32, nxv4i1,
- i32, cpy_imm8_opt_lsl_i32>;
- defm _D : sve_int_dup_imm_pred_zero_inst<0b11, asm, ZPR64, nxv2i64, nxv2i1,
- i64, cpy_imm8_opt_lsl_i64>;
- }
- //===----------------------------------------------------------------------===//
- // 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)>;
- }
- 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 (AArch64dup (immtype:$imm))),
- cc)),
- (cmp $Pg, $Zs1, immtype:$imm)>;
- def : Pat<(predvt (AArch64setcc_z (predvt PPR_3b:$Pg),
- (intvt (AArch64dup (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;
- }
- 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 (AArch64dup(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 (AArch64dup(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 (AArch64dup(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 (AArch64dup(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 (AArch64dup(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 (AArch64dup(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 (AArch64dup(simm5_32b:$imm5)))),
- (!cast<Instruction>(NAME # "_S") simm5_32b:$imm5, (!cast<Instruction>("MOVi32imm") $imm))>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse i64:$imm)), (nxv2i64 (AArch64dup(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 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_B") (i32 0), GPR32:$Rm)>;
- def : Pat<(mulop (nxv8i1 (AArch64ptrue 31)), (nxv8i16 (step_vector_oneuse (i16 1))), (nxv8i16 (AArch64dup(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_H") (i32 0), GPR32:$Rm)>;
- def : Pat<(mulop (nxv4i1 (AArch64ptrue 31)), (nxv4i32 (step_vector_oneuse (i32 1))), (nxv4i32 (AArch64dup(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_S") (i32 0), GPR32:$Rm)>;
- def : Pat<(mulop (nxv2i1 (AArch64ptrue 31)), (nxv2i64 (step_vector_oneuse (i64 1))), (nxv2i64 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))), (nxv16i8 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))), (nxv8i16 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))), (nxv4i32 (AArch64dup(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 (AArch64dup(i64 GPR64:$Rm)))), (nxv2i64 (AArch64dup(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 (AArch64dup(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 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))),
- (!cast<Instruction>(NAME # "_S") GPR32:$Rm, simm5_32b:$imm5)>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse simm5_64b_tgt:$imm5)), (nxv2i64 (AArch64dup(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 (AArch64dup(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 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rn)))),
- (!cast<Instruction>(NAME # "_S") GPR32:$Rn, (!cast<Instruction>("MOVi32imm") $imm))>;
- def : Pat<(add (nxv2i64 (step_vector_oneuse i64:$imm)), (nxv2i64 (AArch64dup(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 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))), (nxv16i8 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))),(nxv8i16 (AArch64dup(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 (AArch64dup(i32 GPR32:$Rm)))),(nxv4i32 (AArch64dup(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 (AArch64dup(i64 GPR64:$Rm)))),(nxv2i64 (AArch64dup(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>;
- }
- 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;
- }
- 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_REAL : sve_mem_sst_sv2<msz, 1, asm, zprext>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _SCALED_REAL) 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_REAL) 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 _REAL : sve_mem_sst_sv2<msz, 0, asm, ZPR64ExtLSL8>;
- def : InstAlias<asm # "\t$Zt, $Pg, [$Rn, $Zm]",
- (!cast<Instruction>(NAME # _REAL) 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 # _REAL) 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>
- : I<(outs pprty:$Pd), (ins pprty:$Pn, pprty:$Pm),
- asm, "\t$Pd, $Pn, $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 op> {
- def _B : sve_int_perm_bin_perm_pp<opc, 0b00, asm, PPR8>;
- def _H : sve_int_perm_bin_perm_pp<opc, 0b01, asm, PPR16>;
- def _S : sve_int_perm_bin_perm_pp<opc, 0b10, asm, PPR32>;
- def _D : sve_int_perm_bin_perm_pp<opc, 0b11, 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)>;
- }
- 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<2> 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;
- 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 mayLoad = 1;
- }
- multiclass sve_mem_eld_si<bits<2> sz, bits<2> 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<2> 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;
- 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;
- }
- //===----------------------------------------------------------------------===//
- // 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;
- }
- 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], []);
- }
- 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 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_bfloat_dot_base<bits<2> opc, string asm, string ops, dag iops>
- : I<(outs ZPR32:$Zda), iops, asm, ops, "", []>, Sched<[]> {
- bits<5> Zda;
- bits<5> Zn;
- let Inst{31-21} = 0b01100100011;
- let Inst{15-14} = opc;
- let Inst{13-10} = 0b0000;
- let Inst{9-5} = Zn;
- let Inst{4-0} = Zda;
- let Constraints = "$Zda = $_Zda";
- let DestructiveInstType = DestructiveOther;
- let ElementSize = ElementSizeH;
- }
- class sve_bfloat_dot<string asm>
- : sve_bfloat_dot_base<0b10, asm, "\t$Zda, $Zn, $Zm",
- (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR16:$Zm)> {
- bits<5> Zm;
- let Inst{20-16} = Zm;
- }
- multiclass sve_bfloat_dot<string asm, SDPatternOperator op> {
- def NAME : sve_bfloat_dot<asm>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4f32, nxv8bf16, nxv8bf16 ,!cast<Instruction>(NAME)>;
- }
- class sve_bfloat_dot_indexed<string asm>
- : sve_bfloat_dot_base<0b01, asm, "\t$Zda, $Zn, $Zm$iop",
- (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR3b16:$Zm, VectorIndexS:$iop)> {
- bits<2> iop;
- bits<3> Zm;
- let Inst{20-19} = iop;
- let Inst{18-16} = Zm;
- }
- multiclass sve_bfloat_dot_indexed<string asm, SDPatternOperator op> {
- def NAME : sve_bfloat_dot_indexed<asm>;
- def : SVE_4_Op_Imm_Pat<nxv4f32, op, nxv4f32, nxv8bf16, nxv8bf16, i64, VectorIndexS_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_matmul_longvecl<bit BT, string asm>
- : sve_bfloat_matmul<asm> {
- let Inst{23} = 0b1;
- let Inst{14-13} = 0b00;
- let Inst{10} = BT;
- }
- multiclass sve_bfloat_matmul_longvecl<bit BT, string asm, SDPatternOperator op> {
- def NAME : sve_bfloat_matmul_longvecl<BT, asm>;
- def : SVE_3_Op_Pat<nxv4f32, op, nxv4f32, nxv8bf16, nxv8bf16 ,!cast<Instruction>(NAME)>;
- }
- class sve_bfloat_matmul_longvecl_idx<bit BT, string asm>
- : sve_bfloat_dot_base<0b01, asm, "\t$Zda, $Zn, $Zm$iop",
- (ins ZPR32:$_Zda, ZPR16:$Zn, ZPR3b16:$Zm, VectorIndexH:$iop)> {
- bits<3> iop;
- bits<3> Zm;
- let Inst{23} = 0b1;
- let Inst{20-19} = iop{2-1};
- let Inst{18-16} = Zm;
- let Inst{11} = iop{0};
- let Inst{10} = BT;
- }
- multiclass sve_bfloat_matmul_longvecl_idx<bit BT, string asm, SDPatternOperator op> {
- def NAME : sve_bfloat_matmul_longvecl_idx<BT, asm>;
- def : SVE_4_Op_Imm_Pat<nxv4f32, op, nxv4f32, nxv8bf16, nxv8bf16, i64, VectorIndexH_timm, !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>", []>;
- // 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)>;
- }
|