tile-desc_32.c 294 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499105001050110502105031050410505105061050710508105091051010511105121051310514105151051610517105181051910520105211052210523105241052510526105271052810529105301053110532105331053410535105361053710538105391054010541105421054310544105451054610547105481054910550105511055210553105541055510556105571055810559105601056110562105631056410565105661056710568105691057010571105721057310574105751057610577105781057910580105811058210583105841058510586105871058810589105901059110592105931059410595105961059710598105991060010601106021060310604106051060610607106081060910610106111061210613106141061510616106171061810619106201062110622106231062410625106261062710628106291063010631106321063310634106351063610637106381063910640106411064210643106441064510646106471064810649106501065110652106531065410655106561065710658106591066010661106621066310664106651066610667106681066910670106711067210673106741067510676106771067810679106801068110682106831068410685106861068710688106891069010691106921069310694106951069610697106981069910700107011070210703107041070510706107071070810709107101071110712107131071410715107161071710718107191072010721107221072310724107251072610727107281072910730107311073210733107341073510736107371073810739107401074110742107431074410745107461074710748107491075010751107521075310754107551075610757107581075910760107611076210763107641076510766107671076810769107701077110772107731077410775107761077710778107791078010781107821078310784107851078610787107881078910790107911079210793107941079510796107971079810799108001080110802108031080410805108061080710808108091081010811108121081310814108151081610817108181081910820108211082210823108241082510826108271082810829108301083110832108331083410835108361083710838108391084010841108421084310844108451084610847108481084910850108511085210853108541085510856108571085810859108601086110862108631086410865108661086710868108691087010871108721087310874108751087610877108781087910880108811088210883108841088510886108871088810889108901089110892108931089410895108961089710898108991090010901109021090310904109051090610907109081090910910109111091210913109141091510916109171091810919109201092110922109231092410925109261092710928109291093010931109321093310934109351093610937109381093910940109411094210943109441094510946109471094810949109501095110952109531095410955109561095710958109591096010961109621096310964109651096610967109681096910970109711097210973109741097510976109771097810979109801098110982109831098410985109861098710988109891099010991109921099310994109951099610997109981099911000110011100211003110041100511006110071100811009110101101111012110131101411015110161101711018110191102011021110221102311024110251102611027110281102911030110311103211033110341103511036110371103811039110401104111042110431104411045110461104711048110491105011051110521105311054110551105611057110581105911060110611106211063110641106511066110671106811069110701107111072110731107411075110761107711078110791108011081110821108311084110851108611087110881108911090110911109211093110941109511096110971109811099111001110111102111031110411105111061110711108111091111011111111121111311114111151111611117111181111911120111211112211123111241112511126111271112811129111301113111132111331113411135111361113711138111391114011141111421114311144111451114611147111481114911150111511115211153111541115511156111571115811159111601116111162111631116411165111661116711168111691117011171111721117311174111751117611177111781117911180111811118211183111841118511186111871118811189111901119111192111931119411195111961119711198111991120011201112021120311204112051120611207112081120911210112111121211213112141121511216112171121811219112201122111222112231122411225112261122711228112291123011231112321123311234112351123611237112381123911240112411124211243112441124511246112471124811249112501125111252112531125411255112561125711258112591126011261112621126311264112651126611267112681126911270112711127211273112741127511276112771127811279112801128111282112831128411285112861128711288112891129011291112921129311294112951129611297112981129911300113011130211303113041130511306113071130811309113101131111312113131131411315113161131711318113191132011321113221132311324113251132611327113281132911330113311133211333113341133511336113371133811339113401134111342113431134411345113461134711348113491135011351113521135311354113551135611357113581135911360113611136211363113641136511366113671136811369113701137111372113731137411375113761137711378113791138011381113821138311384113851138611387113881138911390113911139211393113941139511396113971139811399114001140111402114031140411405114061140711408114091141011411114121141311414114151141611417114181141911420114211142211423114241142511426114271142811429114301143111432114331143411435114361143711438114391144011441114421144311444114451144611447114481144911450114511145211453114541145511456114571145811459114601146111462114631146411465114661146711468114691147011471114721147311474114751147611477114781147911480114811148211483114841148511486114871148811489114901149111492114931149411495114961149711498114991150011501115021150311504115051150611507115081150911510115111151211513115141151511516115171151811519115201152111522115231152411525115261152711528115291153011531115321153311534115351153611537115381153911540115411154211543115441154511546115471154811549115501155111552115531155411555115561155711558115591156011561115621156311564115651156611567115681156911570115711157211573115741157511576115771157811579115801158111582115831158411585115861158711588115891159011591115921159311594115951159611597115981159911600116011160211603116041160511606116071160811609116101161111612116131161411615116161161711618116191162011621116221162311624116251162611627116281162911630116311163211633116341163511636116371163811639116401164111642116431164411645116461164711648116491165011651116521165311654116551165611657116581165911660116611166211663116641166511666116671166811669116701167111672116731167411675116761167711678116791168011681116821168311684116851168611687116881168911690116911169211693116941169511696116971169811699117001170111702117031170411705117061170711708117091171011711117121171311714117151171611717117181171911720117211172211723117241172511726117271172811729117301173111732117331173411735117361173711738117391174011741117421174311744117451174611747117481174911750117511175211753117541175511756117571175811759117601176111762117631176411765117661176711768117691177011771117721177311774117751177611777117781177911780117811178211783117841178511786117871178811789117901179111792117931179411795117961179711798117991180011801118021180311804118051180611807118081180911810118111181211813118141181511816118171181811819118201182111822118231182411825118261182711828118291183011831118321183311834118351183611837118381183911840118411184211843118441184511846118471184811849118501185111852118531185411855118561185711858118591186011861118621186311864118651186611867118681186911870118711187211873118741187511876118771187811879118801188111882118831188411885118861188711888118891189011891118921189311894118951189611897118981189911900119011190211903119041190511906119071190811909119101191111912119131191411915119161191711918119191192011921119221192311924119251192611927119281192911930119311193211933119341193511936119371193811939119401194111942119431194411945119461194711948119491195011951119521195311954119551195611957119581195911960119611196211963119641196511966119671196811969119701197111972119731197411975119761197711978119791198011981119821198311984119851198611987119881198911990119911199211993119941199511996119971199811999120001200112002120031200412005120061200712008120091201012011120121201312014120151201612017120181201912020120211202212023120241202512026120271202812029120301203112032120331203412035120361203712038120391204012041120421204312044120451204612047120481204912050120511205212053120541205512056120571205812059120601206112062120631206412065120661206712068120691207012071120721207312074120751207612077120781207912080120811208212083120841208512086120871208812089120901209112092120931209412095120961209712098120991210012101121021210312104121051210612107121081210912110121111211212113121141211512116121171211812119121201212112122121231212412125121261212712128121291213012131121321213312134121351213612137121381213912140121411214212143121441214512146121471214812149121501215112152121531215412155121561215712158121591216012161121621216312164121651216612167121681216912170121711217212173121741217512176121771217812179121801218112182121831218412185121861218712188121891219012191121921219312194121951219612197121981219912200122011220212203122041220512206122071220812209122101221112212122131221412215122161221712218122191222012221122221222312224122251222612227122281222912230122311223212233122341223512236122371223812239122401224112242122431224412245122461224712248122491225012251122521225312254122551225612257122581225912260122611226212263122641226512266122671226812269122701227112272122731227412275122761227712278122791228012281122821228312284122851228612287122881228912290122911229212293122941229512296122971229812299123001230112302123031230412305123061230712308123091231012311123121231312314123151231612317123181231912320123211232212323123241232512326123271232812329123301233112332123331233412335123361233712338123391234012341123421234312344123451234612347123481234912350123511235212353123541235512356123571235812359123601236112362123631236412365123661236712368123691237012371123721237312374123751237612377123781237912380123811238212383123841238512386123871238812389123901239112392123931239412395123961239712398123991240012401124021240312404124051240612407124081240912410124111241212413124141241512416124171241812419124201242112422124231242412425124261242712428124291243012431124321243312434124351243612437124381243912440124411244212443124441244512446124471244812449124501245112452124531245412455124561245712458124591246012461124621246312464124651246612467124681246912470124711247212473124741247512476124771247812479124801248112482124831248412485124861248712488124891249012491124921249312494124951249612497124981249912500125011250212503125041250512506125071250812509125101251112512125131251412515125161251712518125191252012521125221252312524125251252612527125281252912530125311253212533125341253512536125371253812539125401254112542125431254412545125461254712548125491255012551125521255312554125551255612557125581255912560125611256212563125641256512566125671256812569125701257112572125731257412575125761257712578125791258012581125821258312584125851258612587125881258912590125911259212593125941259512596125971259812599126001260112602126031260412605126061260712608126091261012611126121261312614126151261612617126181261912620126211262212623126241262512626126271262812629126301263112632126331263412635126361263712638126391264012641126421264312644126451264612647126481264912650126511265212653126541265512656126571265812659126601266112662126631266412665126661266712668126691267012671126721267312674126751267612677126781267912680126811268212683126841268512686126871268812689126901269112692126931269412695126961269712698126991270012701127021270312704127051270612707127081270912710127111271212713127141271512716127171271812719127201272112722127231272412725127261272712728127291273012731127321273312734127351273612737127381273912740127411274212743127441274512746127471274812749127501275112752127531275412755127561275712758127591276012761127621276312764127651276612767127681276912770127711277212773127741277512776127771277812779127801278112782127831278412785127861278712788127891279012791127921279312794127951279612797127981279912800128011280212803128041280512806128071280812809128101281112812128131281412815128161281712818128191282012821128221282312824128251282612827128281282912830128311283212833128341283512836128371283812839128401284112842128431284412845128461284712848128491285012851128521285312854128551285612857128581285912860128611286212863128641286512866128671286812869128701287112872128731287412875128761287712878128791288012881128821288312884128851288612887128881288912890128911289212893128941289512896128971289812899129001290112902129031290412905129061290712908129091291012911129121291312914129151291612917129181291912920129211292212923129241292512926129271292812929129301293112932129331293412935129361293712938129391294012941129421294312944129451294612947129481294912950129511295212953129541295512956129571295812959129601296112962129631296412965129661296712968129691297012971129721297312974129751297612977129781297912980129811298212983129841298512986129871298812989129901299112992129931299412995129961299712998129991300013001130021300313004130051300613007130081300913010130111301213013130141301513016130171301813019130201302113022130231302413025130261302713028130291303013031130321303313034130351303613037130381303913040130411304213043130441304513046130471304813049130501305113052130531305413055130561305713058130591306013061130621306313064130651306613067130681306913070130711307213073130741307513076130771307813079130801308113082130831308413085130861308713088130891309013091130921309313094130951309613097130981309913100131011310213103131041310513106131071310813109131101311113112131131311413115131161311713118131191312013121131221312313124131251312613127131281312913130131311313213133131341313513136131371313813139131401314113142131431314413145131461314713148131491315013151131521315313154131551315613157131581315913160131611316213163131641316513166131671316813169131701317113172131731317413175131761317713178131791318013181131821318313184131851318613187131881318913190131911319213193131941319513196131971319813199132001320113202132031320413205132061320713208132091321013211132121321313214132151321613217132181321913220132211322213223132241322513226132271322813229132301323113232132331323413235132361323713238132391324013241132421324313244132451324613247132481324913250132511325213253132541325513256132571325813259132601326113262132631326413265132661326713268132691327013271132721327313274132751327613277132781327913280132811328213283132841328513286132871328813289132901329113292132931329413295132961329713298132991330013301133021330313304133051330613307133081330913310133111331213313133141331513316133171331813319133201332113322133231332413325133261332713328133291333013331133321333313334133351333613337133381333913340133411334213343133441334513346133471334813349133501335113352133531335413355133561335713358133591336013361133621336313364133651336613367133681336913370133711337213373133741337513376133771337813379133801338113382133831338413385133861338713388133891339013391133921339313394133951339613397133981339913400134011340213403134041340513406134071340813409134101341113412134131341413415134161341713418134191342013421134221342313424134251342613427134281342913430134311343213433134341343513436134371343813439134401344113442134431344413445134461344713448134491345013451134521345313454134551345613457134581345913460134611346213463134641346513466134671346813469134701347113472134731347413475134761347713478134791348013481134821348313484134851348613487134881348913490134911349213493134941349513496134971349813499135001350113502135031350413505135061350713508135091351013511135121351313514135151351613517135181351913520135211352213523135241352513526135271352813529135301353113532135331353413535135361353713538135391354013541135421354313544135451354613547135481354913550135511355213553135541355513556135571355813559135601356113562135631356413565135661356713568135691357013571135721357313574135751357613577135781357913580135811358213583135841358513586135871358813589135901359113592135931359413595135961359713598135991360013601136021360313604136051360613607136081360913610136111361213613136141361513616136171361813619136201362113622136231362413625136261362713628136291363013631136321363313634136351363613637136381363913640136411364213643136441364513646136471364813649136501365113652136531365413655136561365713658136591366013661136621366313664136651366613667136681366913670136711367213673136741367513676136771367813679136801368113682136831368413685136861368713688136891369013691136921369313694136951369613697136981369913700137011370213703137041370513706137071370813709137101371113712137131371413715137161371713718137191372013721137221372313724137251372613727137281372913730137311373213733137341373513736137371373813739137401374113742137431374413745137461374713748137491375013751137521375313754137551375613757137581375913760137611376213763137641376513766137671376813769137701377113772137731377413775137761377713778137791378013781137821378313784137851378613787137881378913790137911379213793137941379513796137971379813799138001380113802138031380413805138061380713808138091381013811138121381313814138151381613817138181381913820138211382213823138241382513826
  1. /* Define to include "bfd.h" and get actual BFD relocations below. */
  2. /* #define WANT_BFD_RELOCS */
  3. #ifdef WANT_BFD_RELOCS
  4. #include "bfd.h"
  5. #define MAYBE_BFD_RELOC(X) (X)
  6. #else
  7. #define MAYBE_BFD_RELOC(X) -1
  8. #endif
  9. /* Special registers. */
  10. #define TREG_LR 55
  11. #define TREG_SN 56
  12. #define TREG_ZERO 63
  13. /* FIXME: Rename this. */
  14. #include <asm/opcode-tile.h>
  15. const struct tile_opcode tile_opcodes[394] =
  16. {
  17. { "bpt", TILE_OPC_BPT, 0x2 /* pipes */, 0 /* num_operands */,
  18. TREG_ZERO, /* implicitly_written_register */
  19. 0, /* can_bundle */
  20. {
  21. /* operands */
  22. { 0, },
  23. { },
  24. { 0, },
  25. { 0, },
  26. { 0, }
  27. },
  28. {
  29. /* fixed_bit_masks */
  30. 0ULL,
  31. 0xfbffffff80000000ULL,
  32. 0ULL,
  33. 0ULL,
  34. 0ULL
  35. },
  36. {
  37. /* fixed_bit_values */
  38. -1ULL,
  39. 0x400b3cae00000000ULL,
  40. -1ULL,
  41. -1ULL,
  42. -1ULL
  43. }
  44. },
  45. { "info", TILE_OPC_INFO, 0xf /* pipes */, 1 /* num_operands */,
  46. TREG_ZERO, /* implicitly_written_register */
  47. 1, /* can_bundle */
  48. {
  49. /* operands */
  50. { 0 },
  51. { 1 },
  52. { 2 },
  53. { 3 },
  54. { 0, }
  55. },
  56. {
  57. /* fixed_bit_masks */
  58. 0x800000007ff00fffULL,
  59. 0xfff807ff80000000ULL,
  60. 0x8000000078000fffULL,
  61. 0xf80007ff80000000ULL,
  62. 0ULL
  63. },
  64. {
  65. /* fixed_bit_values */
  66. 0x0000000050100fffULL,
  67. 0x302007ff80000000ULL,
  68. 0x8000000050000fffULL,
  69. 0xc00007ff80000000ULL,
  70. -1ULL
  71. }
  72. },
  73. { "infol", TILE_OPC_INFOL, 0x3 /* pipes */, 1 /* num_operands */,
  74. TREG_ZERO, /* implicitly_written_register */
  75. 1, /* can_bundle */
  76. {
  77. /* operands */
  78. { 4 },
  79. { 5 },
  80. { 0, },
  81. { 0, },
  82. { 0, }
  83. },
  84. {
  85. /* fixed_bit_masks */
  86. 0x8000000070000fffULL,
  87. 0xf80007ff80000000ULL,
  88. 0ULL,
  89. 0ULL,
  90. 0ULL
  91. },
  92. {
  93. /* fixed_bit_values */
  94. 0x0000000030000fffULL,
  95. 0x200007ff80000000ULL,
  96. -1ULL,
  97. -1ULL,
  98. -1ULL
  99. }
  100. },
  101. { "j", TILE_OPC_J, 0x2 /* pipes */, 1 /* num_operands */,
  102. TREG_ZERO, /* implicitly_written_register */
  103. 1, /* can_bundle */
  104. {
  105. /* operands */
  106. { 0, },
  107. { 6 },
  108. { 0, },
  109. { 0, },
  110. { 0, }
  111. },
  112. {
  113. /* fixed_bit_masks */
  114. 0ULL,
  115. 0xf000000000000000ULL,
  116. 0ULL,
  117. 0ULL,
  118. 0ULL
  119. },
  120. {
  121. /* fixed_bit_values */
  122. -1ULL,
  123. 0x5000000000000000ULL,
  124. -1ULL,
  125. -1ULL,
  126. -1ULL
  127. }
  128. },
  129. { "jal", TILE_OPC_JAL, 0x2 /* pipes */, 1 /* num_operands */,
  130. TREG_LR, /* implicitly_written_register */
  131. 1, /* can_bundle */
  132. {
  133. /* operands */
  134. { 0, },
  135. { 6 },
  136. { 0, },
  137. { 0, },
  138. { 0, }
  139. },
  140. {
  141. /* fixed_bit_masks */
  142. 0ULL,
  143. 0xf000000000000000ULL,
  144. 0ULL,
  145. 0ULL,
  146. 0ULL
  147. },
  148. {
  149. /* fixed_bit_values */
  150. -1ULL,
  151. 0x6000000000000000ULL,
  152. -1ULL,
  153. -1ULL,
  154. -1ULL
  155. }
  156. },
  157. { "move", TILE_OPC_MOVE, 0xf /* pipes */, 2 /* num_operands */,
  158. TREG_ZERO, /* implicitly_written_register */
  159. 1, /* can_bundle */
  160. {
  161. /* operands */
  162. { 7, 8 },
  163. { 9, 10 },
  164. { 11, 12 },
  165. { 13, 14 },
  166. { 0, }
  167. },
  168. {
  169. /* fixed_bit_masks */
  170. 0x800000007ffff000ULL,
  171. 0xfffff80000000000ULL,
  172. 0x80000000780ff000ULL,
  173. 0xf807f80000000000ULL,
  174. 0ULL
  175. },
  176. {
  177. /* fixed_bit_values */
  178. 0x0000000000cff000ULL,
  179. 0x0833f80000000000ULL,
  180. 0x80000000180bf000ULL,
  181. 0x9805f80000000000ULL,
  182. -1ULL
  183. }
  184. },
  185. { "move.sn", TILE_OPC_MOVE_SN, 0x3 /* pipes */, 2 /* num_operands */,
  186. TREG_SN, /* implicitly_written_register */
  187. 1, /* can_bundle */
  188. {
  189. /* operands */
  190. { 7, 8 },
  191. { 9, 10 },
  192. { 0, },
  193. { 0, },
  194. { 0, }
  195. },
  196. {
  197. /* fixed_bit_masks */
  198. 0x800000007ffff000ULL,
  199. 0xfffff80000000000ULL,
  200. 0ULL,
  201. 0ULL,
  202. 0ULL
  203. },
  204. {
  205. /* fixed_bit_values */
  206. 0x0000000008cff000ULL,
  207. 0x0c33f80000000000ULL,
  208. -1ULL,
  209. -1ULL,
  210. -1ULL
  211. }
  212. },
  213. { "movei", TILE_OPC_MOVEI, 0xf /* pipes */, 2 /* num_operands */,
  214. TREG_ZERO, /* implicitly_written_register */
  215. 1, /* can_bundle */
  216. {
  217. /* operands */
  218. { 7, 0 },
  219. { 9, 1 },
  220. { 11, 2 },
  221. { 13, 3 },
  222. { 0, }
  223. },
  224. {
  225. /* fixed_bit_masks */
  226. 0x800000007ff00fc0ULL,
  227. 0xfff807e000000000ULL,
  228. 0x8000000078000fc0ULL,
  229. 0xf80007e000000000ULL,
  230. 0ULL
  231. },
  232. {
  233. /* fixed_bit_values */
  234. 0x0000000040800fc0ULL,
  235. 0x305807e000000000ULL,
  236. 0x8000000058000fc0ULL,
  237. 0xc80007e000000000ULL,
  238. -1ULL
  239. }
  240. },
  241. { "movei.sn", TILE_OPC_MOVEI_SN, 0x3 /* pipes */, 2 /* num_operands */,
  242. TREG_SN, /* implicitly_written_register */
  243. 1, /* can_bundle */
  244. {
  245. /* operands */
  246. { 7, 0 },
  247. { 9, 1 },
  248. { 0, },
  249. { 0, },
  250. { 0, }
  251. },
  252. {
  253. /* fixed_bit_masks */
  254. 0x800000007ff00fc0ULL,
  255. 0xfff807e000000000ULL,
  256. 0ULL,
  257. 0ULL,
  258. 0ULL
  259. },
  260. {
  261. /* fixed_bit_values */
  262. 0x0000000048800fc0ULL,
  263. 0x345807e000000000ULL,
  264. -1ULL,
  265. -1ULL,
  266. -1ULL
  267. }
  268. },
  269. { "moveli", TILE_OPC_MOVELI, 0x3 /* pipes */, 2 /* num_operands */,
  270. TREG_ZERO, /* implicitly_written_register */
  271. 1, /* can_bundle */
  272. {
  273. /* operands */
  274. { 7, 4 },
  275. { 9, 5 },
  276. { 0, },
  277. { 0, },
  278. { 0, }
  279. },
  280. {
  281. /* fixed_bit_masks */
  282. 0x8000000070000fc0ULL,
  283. 0xf80007e000000000ULL,
  284. 0ULL,
  285. 0ULL,
  286. 0ULL
  287. },
  288. {
  289. /* fixed_bit_values */
  290. 0x0000000020000fc0ULL,
  291. 0x180007e000000000ULL,
  292. -1ULL,
  293. -1ULL,
  294. -1ULL
  295. }
  296. },
  297. { "moveli.sn", TILE_OPC_MOVELI_SN, 0x3 /* pipes */, 2 /* num_operands */,
  298. TREG_SN, /* implicitly_written_register */
  299. 1, /* can_bundle */
  300. {
  301. /* operands */
  302. { 7, 4 },
  303. { 9, 5 },
  304. { 0, },
  305. { 0, },
  306. { 0, }
  307. },
  308. {
  309. /* fixed_bit_masks */
  310. 0x8000000070000fc0ULL,
  311. 0xf80007e000000000ULL,
  312. 0ULL,
  313. 0ULL,
  314. 0ULL
  315. },
  316. {
  317. /* fixed_bit_values */
  318. 0x0000000010000fc0ULL,
  319. 0x100007e000000000ULL,
  320. -1ULL,
  321. -1ULL,
  322. -1ULL
  323. }
  324. },
  325. { "movelis", TILE_OPC_MOVELIS, 0x3 /* pipes */, 2 /* num_operands */,
  326. TREG_SN, /* implicitly_written_register */
  327. 1, /* can_bundle */
  328. {
  329. /* operands */
  330. { 7, 4 },
  331. { 9, 5 },
  332. { 0, },
  333. { 0, },
  334. { 0, }
  335. },
  336. {
  337. /* fixed_bit_masks */
  338. 0x8000000070000fc0ULL,
  339. 0xf80007e000000000ULL,
  340. 0ULL,
  341. 0ULL,
  342. 0ULL
  343. },
  344. {
  345. /* fixed_bit_values */
  346. 0x0000000010000fc0ULL,
  347. 0x100007e000000000ULL,
  348. -1ULL,
  349. -1ULL,
  350. -1ULL
  351. }
  352. },
  353. { "prefetch", TILE_OPC_PREFETCH, 0x12 /* pipes */, 1 /* num_operands */,
  354. TREG_ZERO, /* implicitly_written_register */
  355. 1, /* can_bundle */
  356. {
  357. /* operands */
  358. { 0, },
  359. { 10 },
  360. { 0, },
  361. { 0, },
  362. { 15 }
  363. },
  364. {
  365. /* fixed_bit_masks */
  366. 0ULL,
  367. 0xfffff81f80000000ULL,
  368. 0ULL,
  369. 0ULL,
  370. 0x8700000003f00000ULL
  371. },
  372. {
  373. /* fixed_bit_values */
  374. -1ULL,
  375. 0x400b501f80000000ULL,
  376. -1ULL,
  377. -1ULL,
  378. 0x8000000003f00000ULL
  379. }
  380. },
  381. { "add", TILE_OPC_ADD, 0xf /* pipes */, 3 /* num_operands */,
  382. TREG_ZERO, /* implicitly_written_register */
  383. 1, /* can_bundle */
  384. {
  385. /* operands */
  386. { 7, 8, 16 },
  387. { 9, 10, 17 },
  388. { 11, 12, 18 },
  389. { 13, 14, 19 },
  390. { 0, }
  391. },
  392. {
  393. /* fixed_bit_masks */
  394. 0x800000007ffc0000ULL,
  395. 0xfffe000000000000ULL,
  396. 0x80000000780c0000ULL,
  397. 0xf806000000000000ULL,
  398. 0ULL
  399. },
  400. {
  401. /* fixed_bit_values */
  402. 0x00000000000c0000ULL,
  403. 0x0806000000000000ULL,
  404. 0x8000000008000000ULL,
  405. 0x8800000000000000ULL,
  406. -1ULL
  407. }
  408. },
  409. { "add.sn", TILE_OPC_ADD_SN, 0x3 /* pipes */, 3 /* num_operands */,
  410. TREG_SN, /* implicitly_written_register */
  411. 1, /* can_bundle */
  412. {
  413. /* operands */
  414. { 7, 8, 16 },
  415. { 9, 10, 17 },
  416. { 0, },
  417. { 0, },
  418. { 0, }
  419. },
  420. {
  421. /* fixed_bit_masks */
  422. 0x800000007ffc0000ULL,
  423. 0xfffe000000000000ULL,
  424. 0ULL,
  425. 0ULL,
  426. 0ULL
  427. },
  428. {
  429. /* fixed_bit_values */
  430. 0x00000000080c0000ULL,
  431. 0x0c06000000000000ULL,
  432. -1ULL,
  433. -1ULL,
  434. -1ULL
  435. }
  436. },
  437. { "addb", TILE_OPC_ADDB, 0x3 /* pipes */, 3 /* num_operands */,
  438. TREG_ZERO, /* implicitly_written_register */
  439. 1, /* can_bundle */
  440. {
  441. /* operands */
  442. { 7, 8, 16 },
  443. { 9, 10, 17 },
  444. { 0, },
  445. { 0, },
  446. { 0, }
  447. },
  448. {
  449. /* fixed_bit_masks */
  450. 0x800000007ffc0000ULL,
  451. 0xfffe000000000000ULL,
  452. 0ULL,
  453. 0ULL,
  454. 0ULL
  455. },
  456. {
  457. /* fixed_bit_values */
  458. 0x0000000000040000ULL,
  459. 0x0802000000000000ULL,
  460. -1ULL,
  461. -1ULL,
  462. -1ULL
  463. }
  464. },
  465. { "addb.sn", TILE_OPC_ADDB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  466. TREG_SN, /* implicitly_written_register */
  467. 1, /* can_bundle */
  468. {
  469. /* operands */
  470. { 7, 8, 16 },
  471. { 9, 10, 17 },
  472. { 0, },
  473. { 0, },
  474. { 0, }
  475. },
  476. {
  477. /* fixed_bit_masks */
  478. 0x800000007ffc0000ULL,
  479. 0xfffe000000000000ULL,
  480. 0ULL,
  481. 0ULL,
  482. 0ULL
  483. },
  484. {
  485. /* fixed_bit_values */
  486. 0x0000000008040000ULL,
  487. 0x0c02000000000000ULL,
  488. -1ULL,
  489. -1ULL,
  490. -1ULL
  491. }
  492. },
  493. { "addbs_u", TILE_OPC_ADDBS_U, 0x3 /* pipes */, 3 /* num_operands */,
  494. TREG_ZERO, /* implicitly_written_register */
  495. 1, /* can_bundle */
  496. {
  497. /* operands */
  498. { 7, 8, 16 },
  499. { 9, 10, 17 },
  500. { 0, },
  501. { 0, },
  502. { 0, }
  503. },
  504. {
  505. /* fixed_bit_masks */
  506. 0x800000007ffc0000ULL,
  507. 0xfffe000000000000ULL,
  508. 0ULL,
  509. 0ULL,
  510. 0ULL
  511. },
  512. {
  513. /* fixed_bit_values */
  514. 0x0000000001880000ULL,
  515. 0x0888000000000000ULL,
  516. -1ULL,
  517. -1ULL,
  518. -1ULL
  519. }
  520. },
  521. { "addbs_u.sn", TILE_OPC_ADDBS_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  522. TREG_SN, /* implicitly_written_register */
  523. 1, /* can_bundle */
  524. {
  525. /* operands */
  526. { 7, 8, 16 },
  527. { 9, 10, 17 },
  528. { 0, },
  529. { 0, },
  530. { 0, }
  531. },
  532. {
  533. /* fixed_bit_masks */
  534. 0x800000007ffc0000ULL,
  535. 0xfffe000000000000ULL,
  536. 0ULL,
  537. 0ULL,
  538. 0ULL
  539. },
  540. {
  541. /* fixed_bit_values */
  542. 0x0000000009880000ULL,
  543. 0x0c88000000000000ULL,
  544. -1ULL,
  545. -1ULL,
  546. -1ULL
  547. }
  548. },
  549. { "addh", TILE_OPC_ADDH, 0x3 /* pipes */, 3 /* num_operands */,
  550. TREG_ZERO, /* implicitly_written_register */
  551. 1, /* can_bundle */
  552. {
  553. /* operands */
  554. { 7, 8, 16 },
  555. { 9, 10, 17 },
  556. { 0, },
  557. { 0, },
  558. { 0, }
  559. },
  560. {
  561. /* fixed_bit_masks */
  562. 0x800000007ffc0000ULL,
  563. 0xfffe000000000000ULL,
  564. 0ULL,
  565. 0ULL,
  566. 0ULL
  567. },
  568. {
  569. /* fixed_bit_values */
  570. 0x0000000000080000ULL,
  571. 0x0804000000000000ULL,
  572. -1ULL,
  573. -1ULL,
  574. -1ULL
  575. }
  576. },
  577. { "addh.sn", TILE_OPC_ADDH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  578. TREG_SN, /* implicitly_written_register */
  579. 1, /* can_bundle */
  580. {
  581. /* operands */
  582. { 7, 8, 16 },
  583. { 9, 10, 17 },
  584. { 0, },
  585. { 0, },
  586. { 0, }
  587. },
  588. {
  589. /* fixed_bit_masks */
  590. 0x800000007ffc0000ULL,
  591. 0xfffe000000000000ULL,
  592. 0ULL,
  593. 0ULL,
  594. 0ULL
  595. },
  596. {
  597. /* fixed_bit_values */
  598. 0x0000000008080000ULL,
  599. 0x0c04000000000000ULL,
  600. -1ULL,
  601. -1ULL,
  602. -1ULL
  603. }
  604. },
  605. { "addhs", TILE_OPC_ADDHS, 0x3 /* pipes */, 3 /* num_operands */,
  606. TREG_ZERO, /* implicitly_written_register */
  607. 1, /* can_bundle */
  608. {
  609. /* operands */
  610. { 7, 8, 16 },
  611. { 9, 10, 17 },
  612. { 0, },
  613. { 0, },
  614. { 0, }
  615. },
  616. {
  617. /* fixed_bit_masks */
  618. 0x800000007ffc0000ULL,
  619. 0xfffe000000000000ULL,
  620. 0ULL,
  621. 0ULL,
  622. 0ULL
  623. },
  624. {
  625. /* fixed_bit_values */
  626. 0x00000000018c0000ULL,
  627. 0x088a000000000000ULL,
  628. -1ULL,
  629. -1ULL,
  630. -1ULL
  631. }
  632. },
  633. { "addhs.sn", TILE_OPC_ADDHS_SN, 0x3 /* pipes */, 3 /* num_operands */,
  634. TREG_SN, /* implicitly_written_register */
  635. 1, /* can_bundle */
  636. {
  637. /* operands */
  638. { 7, 8, 16 },
  639. { 9, 10, 17 },
  640. { 0, },
  641. { 0, },
  642. { 0, }
  643. },
  644. {
  645. /* fixed_bit_masks */
  646. 0x800000007ffc0000ULL,
  647. 0xfffe000000000000ULL,
  648. 0ULL,
  649. 0ULL,
  650. 0ULL
  651. },
  652. {
  653. /* fixed_bit_values */
  654. 0x00000000098c0000ULL,
  655. 0x0c8a000000000000ULL,
  656. -1ULL,
  657. -1ULL,
  658. -1ULL
  659. }
  660. },
  661. { "addi", TILE_OPC_ADDI, 0xf /* pipes */, 3 /* num_operands */,
  662. TREG_ZERO, /* implicitly_written_register */
  663. 1, /* can_bundle */
  664. {
  665. /* operands */
  666. { 7, 8, 0 },
  667. { 9, 10, 1 },
  668. { 11, 12, 2 },
  669. { 13, 14, 3 },
  670. { 0, }
  671. },
  672. {
  673. /* fixed_bit_masks */
  674. 0x800000007ff00000ULL,
  675. 0xfff8000000000000ULL,
  676. 0x8000000078000000ULL,
  677. 0xf800000000000000ULL,
  678. 0ULL
  679. },
  680. {
  681. /* fixed_bit_values */
  682. 0x0000000040300000ULL,
  683. 0x3018000000000000ULL,
  684. 0x8000000048000000ULL,
  685. 0xb800000000000000ULL,
  686. -1ULL
  687. }
  688. },
  689. { "addi.sn", TILE_OPC_ADDI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  690. TREG_SN, /* implicitly_written_register */
  691. 1, /* can_bundle */
  692. {
  693. /* operands */
  694. { 7, 8, 0 },
  695. { 9, 10, 1 },
  696. { 0, },
  697. { 0, },
  698. { 0, }
  699. },
  700. {
  701. /* fixed_bit_masks */
  702. 0x800000007ff00000ULL,
  703. 0xfff8000000000000ULL,
  704. 0ULL,
  705. 0ULL,
  706. 0ULL
  707. },
  708. {
  709. /* fixed_bit_values */
  710. 0x0000000048300000ULL,
  711. 0x3418000000000000ULL,
  712. -1ULL,
  713. -1ULL,
  714. -1ULL
  715. }
  716. },
  717. { "addib", TILE_OPC_ADDIB, 0x3 /* pipes */, 3 /* num_operands */,
  718. TREG_ZERO, /* implicitly_written_register */
  719. 1, /* can_bundle */
  720. {
  721. /* operands */
  722. { 7, 8, 0 },
  723. { 9, 10, 1 },
  724. { 0, },
  725. { 0, },
  726. { 0, }
  727. },
  728. {
  729. /* fixed_bit_masks */
  730. 0x800000007ff00000ULL,
  731. 0xfff8000000000000ULL,
  732. 0ULL,
  733. 0ULL,
  734. 0ULL
  735. },
  736. {
  737. /* fixed_bit_values */
  738. 0x0000000040100000ULL,
  739. 0x3008000000000000ULL,
  740. -1ULL,
  741. -1ULL,
  742. -1ULL
  743. }
  744. },
  745. { "addib.sn", TILE_OPC_ADDIB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  746. TREG_SN, /* implicitly_written_register */
  747. 1, /* can_bundle */
  748. {
  749. /* operands */
  750. { 7, 8, 0 },
  751. { 9, 10, 1 },
  752. { 0, },
  753. { 0, },
  754. { 0, }
  755. },
  756. {
  757. /* fixed_bit_masks */
  758. 0x800000007ff00000ULL,
  759. 0xfff8000000000000ULL,
  760. 0ULL,
  761. 0ULL,
  762. 0ULL
  763. },
  764. {
  765. /* fixed_bit_values */
  766. 0x0000000048100000ULL,
  767. 0x3408000000000000ULL,
  768. -1ULL,
  769. -1ULL,
  770. -1ULL
  771. }
  772. },
  773. { "addih", TILE_OPC_ADDIH, 0x3 /* pipes */, 3 /* num_operands */,
  774. TREG_ZERO, /* implicitly_written_register */
  775. 1, /* can_bundle */
  776. {
  777. /* operands */
  778. { 7, 8, 0 },
  779. { 9, 10, 1 },
  780. { 0, },
  781. { 0, },
  782. { 0, }
  783. },
  784. {
  785. /* fixed_bit_masks */
  786. 0x800000007ff00000ULL,
  787. 0xfff8000000000000ULL,
  788. 0ULL,
  789. 0ULL,
  790. 0ULL
  791. },
  792. {
  793. /* fixed_bit_values */
  794. 0x0000000040200000ULL,
  795. 0x3010000000000000ULL,
  796. -1ULL,
  797. -1ULL,
  798. -1ULL
  799. }
  800. },
  801. { "addih.sn", TILE_OPC_ADDIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  802. TREG_SN, /* implicitly_written_register */
  803. 1, /* can_bundle */
  804. {
  805. /* operands */
  806. { 7, 8, 0 },
  807. { 9, 10, 1 },
  808. { 0, },
  809. { 0, },
  810. { 0, }
  811. },
  812. {
  813. /* fixed_bit_masks */
  814. 0x800000007ff00000ULL,
  815. 0xfff8000000000000ULL,
  816. 0ULL,
  817. 0ULL,
  818. 0ULL
  819. },
  820. {
  821. /* fixed_bit_values */
  822. 0x0000000048200000ULL,
  823. 0x3410000000000000ULL,
  824. -1ULL,
  825. -1ULL,
  826. -1ULL
  827. }
  828. },
  829. { "addli", TILE_OPC_ADDLI, 0x3 /* pipes */, 3 /* num_operands */,
  830. TREG_ZERO, /* implicitly_written_register */
  831. 1, /* can_bundle */
  832. {
  833. /* operands */
  834. { 7, 8, 4 },
  835. { 9, 10, 5 },
  836. { 0, },
  837. { 0, },
  838. { 0, }
  839. },
  840. {
  841. /* fixed_bit_masks */
  842. 0x8000000070000000ULL,
  843. 0xf800000000000000ULL,
  844. 0ULL,
  845. 0ULL,
  846. 0ULL
  847. },
  848. {
  849. /* fixed_bit_values */
  850. 0x0000000020000000ULL,
  851. 0x1800000000000000ULL,
  852. -1ULL,
  853. -1ULL,
  854. -1ULL
  855. }
  856. },
  857. { "addli.sn", TILE_OPC_ADDLI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  858. TREG_SN, /* implicitly_written_register */
  859. 1, /* can_bundle */
  860. {
  861. /* operands */
  862. { 7, 8, 4 },
  863. { 9, 10, 5 },
  864. { 0, },
  865. { 0, },
  866. { 0, }
  867. },
  868. {
  869. /* fixed_bit_masks */
  870. 0x8000000070000000ULL,
  871. 0xf800000000000000ULL,
  872. 0ULL,
  873. 0ULL,
  874. 0ULL
  875. },
  876. {
  877. /* fixed_bit_values */
  878. 0x0000000010000000ULL,
  879. 0x1000000000000000ULL,
  880. -1ULL,
  881. -1ULL,
  882. -1ULL
  883. }
  884. },
  885. { "addlis", TILE_OPC_ADDLIS, 0x3 /* pipes */, 3 /* num_operands */,
  886. TREG_SN, /* implicitly_written_register */
  887. 1, /* can_bundle */
  888. {
  889. /* operands */
  890. { 7, 8, 4 },
  891. { 9, 10, 5 },
  892. { 0, },
  893. { 0, },
  894. { 0, }
  895. },
  896. {
  897. /* fixed_bit_masks */
  898. 0x8000000070000000ULL,
  899. 0xf800000000000000ULL,
  900. 0ULL,
  901. 0ULL,
  902. 0ULL
  903. },
  904. {
  905. /* fixed_bit_values */
  906. 0x0000000010000000ULL,
  907. 0x1000000000000000ULL,
  908. -1ULL,
  909. -1ULL,
  910. -1ULL
  911. }
  912. },
  913. { "adds", TILE_OPC_ADDS, 0x3 /* pipes */, 3 /* num_operands */,
  914. TREG_ZERO, /* implicitly_written_register */
  915. 1, /* can_bundle */
  916. {
  917. /* operands */
  918. { 7, 8, 16 },
  919. { 9, 10, 17 },
  920. { 0, },
  921. { 0, },
  922. { 0, }
  923. },
  924. {
  925. /* fixed_bit_masks */
  926. 0x800000007ffc0000ULL,
  927. 0xfffe000000000000ULL,
  928. 0ULL,
  929. 0ULL,
  930. 0ULL
  931. },
  932. {
  933. /* fixed_bit_values */
  934. 0x0000000001800000ULL,
  935. 0x0884000000000000ULL,
  936. -1ULL,
  937. -1ULL,
  938. -1ULL
  939. }
  940. },
  941. { "adds.sn", TILE_OPC_ADDS_SN, 0x3 /* pipes */, 3 /* num_operands */,
  942. TREG_SN, /* implicitly_written_register */
  943. 1, /* can_bundle */
  944. {
  945. /* operands */
  946. { 7, 8, 16 },
  947. { 9, 10, 17 },
  948. { 0, },
  949. { 0, },
  950. { 0, }
  951. },
  952. {
  953. /* fixed_bit_masks */
  954. 0x800000007ffc0000ULL,
  955. 0xfffe000000000000ULL,
  956. 0ULL,
  957. 0ULL,
  958. 0ULL
  959. },
  960. {
  961. /* fixed_bit_values */
  962. 0x0000000009800000ULL,
  963. 0x0c84000000000000ULL,
  964. -1ULL,
  965. -1ULL,
  966. -1ULL
  967. }
  968. },
  969. { "adiffb_u", TILE_OPC_ADIFFB_U, 0x1 /* pipes */, 3 /* num_operands */,
  970. TREG_ZERO, /* implicitly_written_register */
  971. 1, /* can_bundle */
  972. {
  973. /* operands */
  974. { 7, 8, 16 },
  975. { 0, },
  976. { 0, },
  977. { 0, },
  978. { 0, }
  979. },
  980. {
  981. /* fixed_bit_masks */
  982. 0x800000007ffc0000ULL,
  983. 0ULL,
  984. 0ULL,
  985. 0ULL,
  986. 0ULL
  987. },
  988. {
  989. /* fixed_bit_values */
  990. 0x0000000000100000ULL,
  991. -1ULL,
  992. -1ULL,
  993. -1ULL,
  994. -1ULL
  995. }
  996. },
  997. { "adiffb_u.sn", TILE_OPC_ADIFFB_U_SN, 0x1 /* pipes */, 3 /* num_operands */,
  998. TREG_SN, /* implicitly_written_register */
  999. 1, /* can_bundle */
  1000. {
  1001. /* operands */
  1002. { 7, 8, 16 },
  1003. { 0, },
  1004. { 0, },
  1005. { 0, },
  1006. { 0, }
  1007. },
  1008. {
  1009. /* fixed_bit_masks */
  1010. 0x800000007ffc0000ULL,
  1011. 0ULL,
  1012. 0ULL,
  1013. 0ULL,
  1014. 0ULL
  1015. },
  1016. {
  1017. /* fixed_bit_values */
  1018. 0x0000000008100000ULL,
  1019. -1ULL,
  1020. -1ULL,
  1021. -1ULL,
  1022. -1ULL
  1023. }
  1024. },
  1025. { "adiffh", TILE_OPC_ADIFFH, 0x1 /* pipes */, 3 /* num_operands */,
  1026. TREG_ZERO, /* implicitly_written_register */
  1027. 1, /* can_bundle */
  1028. {
  1029. /* operands */
  1030. { 7, 8, 16 },
  1031. { 0, },
  1032. { 0, },
  1033. { 0, },
  1034. { 0, }
  1035. },
  1036. {
  1037. /* fixed_bit_masks */
  1038. 0x800000007ffc0000ULL,
  1039. 0ULL,
  1040. 0ULL,
  1041. 0ULL,
  1042. 0ULL
  1043. },
  1044. {
  1045. /* fixed_bit_values */
  1046. 0x0000000000140000ULL,
  1047. -1ULL,
  1048. -1ULL,
  1049. -1ULL,
  1050. -1ULL
  1051. }
  1052. },
  1053. { "adiffh.sn", TILE_OPC_ADIFFH_SN, 0x1 /* pipes */, 3 /* num_operands */,
  1054. TREG_SN, /* implicitly_written_register */
  1055. 1, /* can_bundle */
  1056. {
  1057. /* operands */
  1058. { 7, 8, 16 },
  1059. { 0, },
  1060. { 0, },
  1061. { 0, },
  1062. { 0, }
  1063. },
  1064. {
  1065. /* fixed_bit_masks */
  1066. 0x800000007ffc0000ULL,
  1067. 0ULL,
  1068. 0ULL,
  1069. 0ULL,
  1070. 0ULL
  1071. },
  1072. {
  1073. /* fixed_bit_values */
  1074. 0x0000000008140000ULL,
  1075. -1ULL,
  1076. -1ULL,
  1077. -1ULL,
  1078. -1ULL
  1079. }
  1080. },
  1081. { "and", TILE_OPC_AND, 0xf /* pipes */, 3 /* num_operands */,
  1082. TREG_ZERO, /* implicitly_written_register */
  1083. 1, /* can_bundle */
  1084. {
  1085. /* operands */
  1086. { 7, 8, 16 },
  1087. { 9, 10, 17 },
  1088. { 11, 12, 18 },
  1089. { 13, 14, 19 },
  1090. { 0, }
  1091. },
  1092. {
  1093. /* fixed_bit_masks */
  1094. 0x800000007ffc0000ULL,
  1095. 0xfffe000000000000ULL,
  1096. 0x80000000780c0000ULL,
  1097. 0xf806000000000000ULL,
  1098. 0ULL
  1099. },
  1100. {
  1101. /* fixed_bit_values */
  1102. 0x0000000000180000ULL,
  1103. 0x0808000000000000ULL,
  1104. 0x8000000018000000ULL,
  1105. 0x9800000000000000ULL,
  1106. -1ULL
  1107. }
  1108. },
  1109. { "and.sn", TILE_OPC_AND_SN, 0x3 /* pipes */, 3 /* num_operands */,
  1110. TREG_SN, /* implicitly_written_register */
  1111. 1, /* can_bundle */
  1112. {
  1113. /* operands */
  1114. { 7, 8, 16 },
  1115. { 9, 10, 17 },
  1116. { 0, },
  1117. { 0, },
  1118. { 0, }
  1119. },
  1120. {
  1121. /* fixed_bit_masks */
  1122. 0x800000007ffc0000ULL,
  1123. 0xfffe000000000000ULL,
  1124. 0ULL,
  1125. 0ULL,
  1126. 0ULL
  1127. },
  1128. {
  1129. /* fixed_bit_values */
  1130. 0x0000000008180000ULL,
  1131. 0x0c08000000000000ULL,
  1132. -1ULL,
  1133. -1ULL,
  1134. -1ULL
  1135. }
  1136. },
  1137. { "andi", TILE_OPC_ANDI, 0xf /* pipes */, 3 /* num_operands */,
  1138. TREG_ZERO, /* implicitly_written_register */
  1139. 1, /* can_bundle */
  1140. {
  1141. /* operands */
  1142. { 7, 8, 0 },
  1143. { 9, 10, 1 },
  1144. { 11, 12, 2 },
  1145. { 13, 14, 3 },
  1146. { 0, }
  1147. },
  1148. {
  1149. /* fixed_bit_masks */
  1150. 0x800000007ff00000ULL,
  1151. 0xfff8000000000000ULL,
  1152. 0x8000000078000000ULL,
  1153. 0xf800000000000000ULL,
  1154. 0ULL
  1155. },
  1156. {
  1157. /* fixed_bit_values */
  1158. 0x0000000050100000ULL,
  1159. 0x3020000000000000ULL,
  1160. 0x8000000050000000ULL,
  1161. 0xc000000000000000ULL,
  1162. -1ULL
  1163. }
  1164. },
  1165. { "andi.sn", TILE_OPC_ANDI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  1166. TREG_SN, /* implicitly_written_register */
  1167. 1, /* can_bundle */
  1168. {
  1169. /* operands */
  1170. { 7, 8, 0 },
  1171. { 9, 10, 1 },
  1172. { 0, },
  1173. { 0, },
  1174. { 0, }
  1175. },
  1176. {
  1177. /* fixed_bit_masks */
  1178. 0x800000007ff00000ULL,
  1179. 0xfff8000000000000ULL,
  1180. 0ULL,
  1181. 0ULL,
  1182. 0ULL
  1183. },
  1184. {
  1185. /* fixed_bit_values */
  1186. 0x0000000058100000ULL,
  1187. 0x3420000000000000ULL,
  1188. -1ULL,
  1189. -1ULL,
  1190. -1ULL
  1191. }
  1192. },
  1193. { "auli", TILE_OPC_AULI, 0x3 /* pipes */, 3 /* num_operands */,
  1194. TREG_ZERO, /* implicitly_written_register */
  1195. 1, /* can_bundle */
  1196. {
  1197. /* operands */
  1198. { 7, 8, 4 },
  1199. { 9, 10, 5 },
  1200. { 0, },
  1201. { 0, },
  1202. { 0, }
  1203. },
  1204. {
  1205. /* fixed_bit_masks */
  1206. 0x8000000070000000ULL,
  1207. 0xf800000000000000ULL,
  1208. 0ULL,
  1209. 0ULL,
  1210. 0ULL
  1211. },
  1212. {
  1213. /* fixed_bit_values */
  1214. 0x0000000030000000ULL,
  1215. 0x2000000000000000ULL,
  1216. -1ULL,
  1217. -1ULL,
  1218. -1ULL
  1219. }
  1220. },
  1221. { "avgb_u", TILE_OPC_AVGB_U, 0x1 /* pipes */, 3 /* num_operands */,
  1222. TREG_ZERO, /* implicitly_written_register */
  1223. 1, /* can_bundle */
  1224. {
  1225. /* operands */
  1226. { 7, 8, 16 },
  1227. { 0, },
  1228. { 0, },
  1229. { 0, },
  1230. { 0, }
  1231. },
  1232. {
  1233. /* fixed_bit_masks */
  1234. 0x800000007ffc0000ULL,
  1235. 0ULL,
  1236. 0ULL,
  1237. 0ULL,
  1238. 0ULL
  1239. },
  1240. {
  1241. /* fixed_bit_values */
  1242. 0x00000000001c0000ULL,
  1243. -1ULL,
  1244. -1ULL,
  1245. -1ULL,
  1246. -1ULL
  1247. }
  1248. },
  1249. { "avgb_u.sn", TILE_OPC_AVGB_U_SN, 0x1 /* pipes */, 3 /* num_operands */,
  1250. TREG_SN, /* implicitly_written_register */
  1251. 1, /* can_bundle */
  1252. {
  1253. /* operands */
  1254. { 7, 8, 16 },
  1255. { 0, },
  1256. { 0, },
  1257. { 0, },
  1258. { 0, }
  1259. },
  1260. {
  1261. /* fixed_bit_masks */
  1262. 0x800000007ffc0000ULL,
  1263. 0ULL,
  1264. 0ULL,
  1265. 0ULL,
  1266. 0ULL
  1267. },
  1268. {
  1269. /* fixed_bit_values */
  1270. 0x00000000081c0000ULL,
  1271. -1ULL,
  1272. -1ULL,
  1273. -1ULL,
  1274. -1ULL
  1275. }
  1276. },
  1277. { "avgh", TILE_OPC_AVGH, 0x1 /* pipes */, 3 /* num_operands */,
  1278. TREG_ZERO, /* implicitly_written_register */
  1279. 1, /* can_bundle */
  1280. {
  1281. /* operands */
  1282. { 7, 8, 16 },
  1283. { 0, },
  1284. { 0, },
  1285. { 0, },
  1286. { 0, }
  1287. },
  1288. {
  1289. /* fixed_bit_masks */
  1290. 0x800000007ffc0000ULL,
  1291. 0ULL,
  1292. 0ULL,
  1293. 0ULL,
  1294. 0ULL
  1295. },
  1296. {
  1297. /* fixed_bit_values */
  1298. 0x0000000000200000ULL,
  1299. -1ULL,
  1300. -1ULL,
  1301. -1ULL,
  1302. -1ULL
  1303. }
  1304. },
  1305. { "avgh.sn", TILE_OPC_AVGH_SN, 0x1 /* pipes */, 3 /* num_operands */,
  1306. TREG_SN, /* implicitly_written_register */
  1307. 1, /* can_bundle */
  1308. {
  1309. /* operands */
  1310. { 7, 8, 16 },
  1311. { 0, },
  1312. { 0, },
  1313. { 0, },
  1314. { 0, }
  1315. },
  1316. {
  1317. /* fixed_bit_masks */
  1318. 0x800000007ffc0000ULL,
  1319. 0ULL,
  1320. 0ULL,
  1321. 0ULL,
  1322. 0ULL
  1323. },
  1324. {
  1325. /* fixed_bit_values */
  1326. 0x0000000008200000ULL,
  1327. -1ULL,
  1328. -1ULL,
  1329. -1ULL,
  1330. -1ULL
  1331. }
  1332. },
  1333. { "bbns", TILE_OPC_BBNS, 0x2 /* pipes */, 2 /* num_operands */,
  1334. TREG_ZERO, /* implicitly_written_register */
  1335. 1, /* can_bundle */
  1336. {
  1337. /* operands */
  1338. { 0, },
  1339. { 10, 20 },
  1340. { 0, },
  1341. { 0, },
  1342. { 0, }
  1343. },
  1344. {
  1345. /* fixed_bit_masks */
  1346. 0ULL,
  1347. 0xfc00000780000000ULL,
  1348. 0ULL,
  1349. 0ULL,
  1350. 0ULL
  1351. },
  1352. {
  1353. /* fixed_bit_values */
  1354. -1ULL,
  1355. 0x2800000700000000ULL,
  1356. -1ULL,
  1357. -1ULL,
  1358. -1ULL
  1359. }
  1360. },
  1361. { "bbns.sn", TILE_OPC_BBNS_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1362. TREG_SN, /* implicitly_written_register */
  1363. 1, /* can_bundle */
  1364. {
  1365. /* operands */
  1366. { 0, },
  1367. { 10, 20 },
  1368. { 0, },
  1369. { 0, },
  1370. { 0, }
  1371. },
  1372. {
  1373. /* fixed_bit_masks */
  1374. 0ULL,
  1375. 0xfc00000780000000ULL,
  1376. 0ULL,
  1377. 0ULL,
  1378. 0ULL
  1379. },
  1380. {
  1381. /* fixed_bit_values */
  1382. -1ULL,
  1383. 0x2c00000700000000ULL,
  1384. -1ULL,
  1385. -1ULL,
  1386. -1ULL
  1387. }
  1388. },
  1389. { "bbnst", TILE_OPC_BBNST, 0x2 /* pipes */, 2 /* num_operands */,
  1390. TREG_ZERO, /* implicitly_written_register */
  1391. 1, /* can_bundle */
  1392. {
  1393. /* operands */
  1394. { 0, },
  1395. { 10, 20 },
  1396. { 0, },
  1397. { 0, },
  1398. { 0, }
  1399. },
  1400. {
  1401. /* fixed_bit_masks */
  1402. 0ULL,
  1403. 0xfc00000780000000ULL,
  1404. 0ULL,
  1405. 0ULL,
  1406. 0ULL
  1407. },
  1408. {
  1409. /* fixed_bit_values */
  1410. -1ULL,
  1411. 0x2800000780000000ULL,
  1412. -1ULL,
  1413. -1ULL,
  1414. -1ULL
  1415. }
  1416. },
  1417. { "bbnst.sn", TILE_OPC_BBNST_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1418. TREG_SN, /* implicitly_written_register */
  1419. 1, /* can_bundle */
  1420. {
  1421. /* operands */
  1422. { 0, },
  1423. { 10, 20 },
  1424. { 0, },
  1425. { 0, },
  1426. { 0, }
  1427. },
  1428. {
  1429. /* fixed_bit_masks */
  1430. 0ULL,
  1431. 0xfc00000780000000ULL,
  1432. 0ULL,
  1433. 0ULL,
  1434. 0ULL
  1435. },
  1436. {
  1437. /* fixed_bit_values */
  1438. -1ULL,
  1439. 0x2c00000780000000ULL,
  1440. -1ULL,
  1441. -1ULL,
  1442. -1ULL
  1443. }
  1444. },
  1445. { "bbs", TILE_OPC_BBS, 0x2 /* pipes */, 2 /* num_operands */,
  1446. TREG_ZERO, /* implicitly_written_register */
  1447. 1, /* can_bundle */
  1448. {
  1449. /* operands */
  1450. { 0, },
  1451. { 10, 20 },
  1452. { 0, },
  1453. { 0, },
  1454. { 0, }
  1455. },
  1456. {
  1457. /* fixed_bit_masks */
  1458. 0ULL,
  1459. 0xfc00000780000000ULL,
  1460. 0ULL,
  1461. 0ULL,
  1462. 0ULL
  1463. },
  1464. {
  1465. /* fixed_bit_values */
  1466. -1ULL,
  1467. 0x2800000600000000ULL,
  1468. -1ULL,
  1469. -1ULL,
  1470. -1ULL
  1471. }
  1472. },
  1473. { "bbs.sn", TILE_OPC_BBS_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1474. TREG_SN, /* implicitly_written_register */
  1475. 1, /* can_bundle */
  1476. {
  1477. /* operands */
  1478. { 0, },
  1479. { 10, 20 },
  1480. { 0, },
  1481. { 0, },
  1482. { 0, }
  1483. },
  1484. {
  1485. /* fixed_bit_masks */
  1486. 0ULL,
  1487. 0xfc00000780000000ULL,
  1488. 0ULL,
  1489. 0ULL,
  1490. 0ULL
  1491. },
  1492. {
  1493. /* fixed_bit_values */
  1494. -1ULL,
  1495. 0x2c00000600000000ULL,
  1496. -1ULL,
  1497. -1ULL,
  1498. -1ULL
  1499. }
  1500. },
  1501. { "bbst", TILE_OPC_BBST, 0x2 /* pipes */, 2 /* num_operands */,
  1502. TREG_ZERO, /* implicitly_written_register */
  1503. 1, /* can_bundle */
  1504. {
  1505. /* operands */
  1506. { 0, },
  1507. { 10, 20 },
  1508. { 0, },
  1509. { 0, },
  1510. { 0, }
  1511. },
  1512. {
  1513. /* fixed_bit_masks */
  1514. 0ULL,
  1515. 0xfc00000780000000ULL,
  1516. 0ULL,
  1517. 0ULL,
  1518. 0ULL
  1519. },
  1520. {
  1521. /* fixed_bit_values */
  1522. -1ULL,
  1523. 0x2800000680000000ULL,
  1524. -1ULL,
  1525. -1ULL,
  1526. -1ULL
  1527. }
  1528. },
  1529. { "bbst.sn", TILE_OPC_BBST_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1530. TREG_SN, /* implicitly_written_register */
  1531. 1, /* can_bundle */
  1532. {
  1533. /* operands */
  1534. { 0, },
  1535. { 10, 20 },
  1536. { 0, },
  1537. { 0, },
  1538. { 0, }
  1539. },
  1540. {
  1541. /* fixed_bit_masks */
  1542. 0ULL,
  1543. 0xfc00000780000000ULL,
  1544. 0ULL,
  1545. 0ULL,
  1546. 0ULL
  1547. },
  1548. {
  1549. /* fixed_bit_values */
  1550. -1ULL,
  1551. 0x2c00000680000000ULL,
  1552. -1ULL,
  1553. -1ULL,
  1554. -1ULL
  1555. }
  1556. },
  1557. { "bgez", TILE_OPC_BGEZ, 0x2 /* pipes */, 2 /* num_operands */,
  1558. TREG_ZERO, /* implicitly_written_register */
  1559. 1, /* can_bundle */
  1560. {
  1561. /* operands */
  1562. { 0, },
  1563. { 10, 20 },
  1564. { 0, },
  1565. { 0, },
  1566. { 0, }
  1567. },
  1568. {
  1569. /* fixed_bit_masks */
  1570. 0ULL,
  1571. 0xfc00000780000000ULL,
  1572. 0ULL,
  1573. 0ULL,
  1574. 0ULL
  1575. },
  1576. {
  1577. /* fixed_bit_values */
  1578. -1ULL,
  1579. 0x2800000300000000ULL,
  1580. -1ULL,
  1581. -1ULL,
  1582. -1ULL
  1583. }
  1584. },
  1585. { "bgez.sn", TILE_OPC_BGEZ_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1586. TREG_SN, /* implicitly_written_register */
  1587. 1, /* can_bundle */
  1588. {
  1589. /* operands */
  1590. { 0, },
  1591. { 10, 20 },
  1592. { 0, },
  1593. { 0, },
  1594. { 0, }
  1595. },
  1596. {
  1597. /* fixed_bit_masks */
  1598. 0ULL,
  1599. 0xfc00000780000000ULL,
  1600. 0ULL,
  1601. 0ULL,
  1602. 0ULL
  1603. },
  1604. {
  1605. /* fixed_bit_values */
  1606. -1ULL,
  1607. 0x2c00000300000000ULL,
  1608. -1ULL,
  1609. -1ULL,
  1610. -1ULL
  1611. }
  1612. },
  1613. { "bgezt", TILE_OPC_BGEZT, 0x2 /* pipes */, 2 /* num_operands */,
  1614. TREG_ZERO, /* implicitly_written_register */
  1615. 1, /* can_bundle */
  1616. {
  1617. /* operands */
  1618. { 0, },
  1619. { 10, 20 },
  1620. { 0, },
  1621. { 0, },
  1622. { 0, }
  1623. },
  1624. {
  1625. /* fixed_bit_masks */
  1626. 0ULL,
  1627. 0xfc00000780000000ULL,
  1628. 0ULL,
  1629. 0ULL,
  1630. 0ULL
  1631. },
  1632. {
  1633. /* fixed_bit_values */
  1634. -1ULL,
  1635. 0x2800000380000000ULL,
  1636. -1ULL,
  1637. -1ULL,
  1638. -1ULL
  1639. }
  1640. },
  1641. { "bgezt.sn", TILE_OPC_BGEZT_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1642. TREG_SN, /* implicitly_written_register */
  1643. 1, /* can_bundle */
  1644. {
  1645. /* operands */
  1646. { 0, },
  1647. { 10, 20 },
  1648. { 0, },
  1649. { 0, },
  1650. { 0, }
  1651. },
  1652. {
  1653. /* fixed_bit_masks */
  1654. 0ULL,
  1655. 0xfc00000780000000ULL,
  1656. 0ULL,
  1657. 0ULL,
  1658. 0ULL
  1659. },
  1660. {
  1661. /* fixed_bit_values */
  1662. -1ULL,
  1663. 0x2c00000380000000ULL,
  1664. -1ULL,
  1665. -1ULL,
  1666. -1ULL
  1667. }
  1668. },
  1669. { "bgz", TILE_OPC_BGZ, 0x2 /* pipes */, 2 /* num_operands */,
  1670. TREG_ZERO, /* implicitly_written_register */
  1671. 1, /* can_bundle */
  1672. {
  1673. /* operands */
  1674. { 0, },
  1675. { 10, 20 },
  1676. { 0, },
  1677. { 0, },
  1678. { 0, }
  1679. },
  1680. {
  1681. /* fixed_bit_masks */
  1682. 0ULL,
  1683. 0xfc00000780000000ULL,
  1684. 0ULL,
  1685. 0ULL,
  1686. 0ULL
  1687. },
  1688. {
  1689. /* fixed_bit_values */
  1690. -1ULL,
  1691. 0x2800000200000000ULL,
  1692. -1ULL,
  1693. -1ULL,
  1694. -1ULL
  1695. }
  1696. },
  1697. { "bgz.sn", TILE_OPC_BGZ_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1698. TREG_SN, /* implicitly_written_register */
  1699. 1, /* can_bundle */
  1700. {
  1701. /* operands */
  1702. { 0, },
  1703. { 10, 20 },
  1704. { 0, },
  1705. { 0, },
  1706. { 0, }
  1707. },
  1708. {
  1709. /* fixed_bit_masks */
  1710. 0ULL,
  1711. 0xfc00000780000000ULL,
  1712. 0ULL,
  1713. 0ULL,
  1714. 0ULL
  1715. },
  1716. {
  1717. /* fixed_bit_values */
  1718. -1ULL,
  1719. 0x2c00000200000000ULL,
  1720. -1ULL,
  1721. -1ULL,
  1722. -1ULL
  1723. }
  1724. },
  1725. { "bgzt", TILE_OPC_BGZT, 0x2 /* pipes */, 2 /* num_operands */,
  1726. TREG_ZERO, /* implicitly_written_register */
  1727. 1, /* can_bundle */
  1728. {
  1729. /* operands */
  1730. { 0, },
  1731. { 10, 20 },
  1732. { 0, },
  1733. { 0, },
  1734. { 0, }
  1735. },
  1736. {
  1737. /* fixed_bit_masks */
  1738. 0ULL,
  1739. 0xfc00000780000000ULL,
  1740. 0ULL,
  1741. 0ULL,
  1742. 0ULL
  1743. },
  1744. {
  1745. /* fixed_bit_values */
  1746. -1ULL,
  1747. 0x2800000280000000ULL,
  1748. -1ULL,
  1749. -1ULL,
  1750. -1ULL
  1751. }
  1752. },
  1753. { "bgzt.sn", TILE_OPC_BGZT_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1754. TREG_SN, /* implicitly_written_register */
  1755. 1, /* can_bundle */
  1756. {
  1757. /* operands */
  1758. { 0, },
  1759. { 10, 20 },
  1760. { 0, },
  1761. { 0, },
  1762. { 0, }
  1763. },
  1764. {
  1765. /* fixed_bit_masks */
  1766. 0ULL,
  1767. 0xfc00000780000000ULL,
  1768. 0ULL,
  1769. 0ULL,
  1770. 0ULL
  1771. },
  1772. {
  1773. /* fixed_bit_values */
  1774. -1ULL,
  1775. 0x2c00000280000000ULL,
  1776. -1ULL,
  1777. -1ULL,
  1778. -1ULL
  1779. }
  1780. },
  1781. { "bitx", TILE_OPC_BITX, 0x5 /* pipes */, 2 /* num_operands */,
  1782. TREG_ZERO, /* implicitly_written_register */
  1783. 1, /* can_bundle */
  1784. {
  1785. /* operands */
  1786. { 7, 8 },
  1787. { 0, },
  1788. { 11, 12 },
  1789. { 0, },
  1790. { 0, }
  1791. },
  1792. {
  1793. /* fixed_bit_masks */
  1794. 0x800000007ffff000ULL,
  1795. 0ULL,
  1796. 0x80000000780ff000ULL,
  1797. 0ULL,
  1798. 0ULL
  1799. },
  1800. {
  1801. /* fixed_bit_values */
  1802. 0x0000000070161000ULL,
  1803. -1ULL,
  1804. 0x80000000680a1000ULL,
  1805. -1ULL,
  1806. -1ULL
  1807. }
  1808. },
  1809. { "bitx.sn", TILE_OPC_BITX_SN, 0x1 /* pipes */, 2 /* num_operands */,
  1810. TREG_SN, /* implicitly_written_register */
  1811. 1, /* can_bundle */
  1812. {
  1813. /* operands */
  1814. { 7, 8 },
  1815. { 0, },
  1816. { 0, },
  1817. { 0, },
  1818. { 0, }
  1819. },
  1820. {
  1821. /* fixed_bit_masks */
  1822. 0x800000007ffff000ULL,
  1823. 0ULL,
  1824. 0ULL,
  1825. 0ULL,
  1826. 0ULL
  1827. },
  1828. {
  1829. /* fixed_bit_values */
  1830. 0x0000000078161000ULL,
  1831. -1ULL,
  1832. -1ULL,
  1833. -1ULL,
  1834. -1ULL
  1835. }
  1836. },
  1837. { "blez", TILE_OPC_BLEZ, 0x2 /* pipes */, 2 /* num_operands */,
  1838. TREG_ZERO, /* implicitly_written_register */
  1839. 1, /* can_bundle */
  1840. {
  1841. /* operands */
  1842. { 0, },
  1843. { 10, 20 },
  1844. { 0, },
  1845. { 0, },
  1846. { 0, }
  1847. },
  1848. {
  1849. /* fixed_bit_masks */
  1850. 0ULL,
  1851. 0xfc00000780000000ULL,
  1852. 0ULL,
  1853. 0ULL,
  1854. 0ULL
  1855. },
  1856. {
  1857. /* fixed_bit_values */
  1858. -1ULL,
  1859. 0x2800000500000000ULL,
  1860. -1ULL,
  1861. -1ULL,
  1862. -1ULL
  1863. }
  1864. },
  1865. { "blez.sn", TILE_OPC_BLEZ_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1866. TREG_SN, /* implicitly_written_register */
  1867. 1, /* can_bundle */
  1868. {
  1869. /* operands */
  1870. { 0, },
  1871. { 10, 20 },
  1872. { 0, },
  1873. { 0, },
  1874. { 0, }
  1875. },
  1876. {
  1877. /* fixed_bit_masks */
  1878. 0ULL,
  1879. 0xfc00000780000000ULL,
  1880. 0ULL,
  1881. 0ULL,
  1882. 0ULL
  1883. },
  1884. {
  1885. /* fixed_bit_values */
  1886. -1ULL,
  1887. 0x2c00000500000000ULL,
  1888. -1ULL,
  1889. -1ULL,
  1890. -1ULL
  1891. }
  1892. },
  1893. { "blezt", TILE_OPC_BLEZT, 0x2 /* pipes */, 2 /* num_operands */,
  1894. TREG_ZERO, /* implicitly_written_register */
  1895. 1, /* can_bundle */
  1896. {
  1897. /* operands */
  1898. { 0, },
  1899. { 10, 20 },
  1900. { 0, },
  1901. { 0, },
  1902. { 0, }
  1903. },
  1904. {
  1905. /* fixed_bit_masks */
  1906. 0ULL,
  1907. 0xfc00000780000000ULL,
  1908. 0ULL,
  1909. 0ULL,
  1910. 0ULL
  1911. },
  1912. {
  1913. /* fixed_bit_values */
  1914. -1ULL,
  1915. 0x2800000580000000ULL,
  1916. -1ULL,
  1917. -1ULL,
  1918. -1ULL
  1919. }
  1920. },
  1921. { "blezt.sn", TILE_OPC_BLEZT_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1922. TREG_SN, /* implicitly_written_register */
  1923. 1, /* can_bundle */
  1924. {
  1925. /* operands */
  1926. { 0, },
  1927. { 10, 20 },
  1928. { 0, },
  1929. { 0, },
  1930. { 0, }
  1931. },
  1932. {
  1933. /* fixed_bit_masks */
  1934. 0ULL,
  1935. 0xfc00000780000000ULL,
  1936. 0ULL,
  1937. 0ULL,
  1938. 0ULL
  1939. },
  1940. {
  1941. /* fixed_bit_values */
  1942. -1ULL,
  1943. 0x2c00000580000000ULL,
  1944. -1ULL,
  1945. -1ULL,
  1946. -1ULL
  1947. }
  1948. },
  1949. { "blz", TILE_OPC_BLZ, 0x2 /* pipes */, 2 /* num_operands */,
  1950. TREG_ZERO, /* implicitly_written_register */
  1951. 1, /* can_bundle */
  1952. {
  1953. /* operands */
  1954. { 0, },
  1955. { 10, 20 },
  1956. { 0, },
  1957. { 0, },
  1958. { 0, }
  1959. },
  1960. {
  1961. /* fixed_bit_masks */
  1962. 0ULL,
  1963. 0xfc00000780000000ULL,
  1964. 0ULL,
  1965. 0ULL,
  1966. 0ULL
  1967. },
  1968. {
  1969. /* fixed_bit_values */
  1970. -1ULL,
  1971. 0x2800000400000000ULL,
  1972. -1ULL,
  1973. -1ULL,
  1974. -1ULL
  1975. }
  1976. },
  1977. { "blz.sn", TILE_OPC_BLZ_SN, 0x2 /* pipes */, 2 /* num_operands */,
  1978. TREG_SN, /* implicitly_written_register */
  1979. 1, /* can_bundle */
  1980. {
  1981. /* operands */
  1982. { 0, },
  1983. { 10, 20 },
  1984. { 0, },
  1985. { 0, },
  1986. { 0, }
  1987. },
  1988. {
  1989. /* fixed_bit_masks */
  1990. 0ULL,
  1991. 0xfc00000780000000ULL,
  1992. 0ULL,
  1993. 0ULL,
  1994. 0ULL
  1995. },
  1996. {
  1997. /* fixed_bit_values */
  1998. -1ULL,
  1999. 0x2c00000400000000ULL,
  2000. -1ULL,
  2001. -1ULL,
  2002. -1ULL
  2003. }
  2004. },
  2005. { "blzt", TILE_OPC_BLZT, 0x2 /* pipes */, 2 /* num_operands */,
  2006. TREG_ZERO, /* implicitly_written_register */
  2007. 1, /* can_bundle */
  2008. {
  2009. /* operands */
  2010. { 0, },
  2011. { 10, 20 },
  2012. { 0, },
  2013. { 0, },
  2014. { 0, }
  2015. },
  2016. {
  2017. /* fixed_bit_masks */
  2018. 0ULL,
  2019. 0xfc00000780000000ULL,
  2020. 0ULL,
  2021. 0ULL,
  2022. 0ULL
  2023. },
  2024. {
  2025. /* fixed_bit_values */
  2026. -1ULL,
  2027. 0x2800000480000000ULL,
  2028. -1ULL,
  2029. -1ULL,
  2030. -1ULL
  2031. }
  2032. },
  2033. { "blzt.sn", TILE_OPC_BLZT_SN, 0x2 /* pipes */, 2 /* num_operands */,
  2034. TREG_SN, /* implicitly_written_register */
  2035. 1, /* can_bundle */
  2036. {
  2037. /* operands */
  2038. { 0, },
  2039. { 10, 20 },
  2040. { 0, },
  2041. { 0, },
  2042. { 0, }
  2043. },
  2044. {
  2045. /* fixed_bit_masks */
  2046. 0ULL,
  2047. 0xfc00000780000000ULL,
  2048. 0ULL,
  2049. 0ULL,
  2050. 0ULL
  2051. },
  2052. {
  2053. /* fixed_bit_values */
  2054. -1ULL,
  2055. 0x2c00000480000000ULL,
  2056. -1ULL,
  2057. -1ULL,
  2058. -1ULL
  2059. }
  2060. },
  2061. { "bnz", TILE_OPC_BNZ, 0x2 /* pipes */, 2 /* num_operands */,
  2062. TREG_ZERO, /* implicitly_written_register */
  2063. 1, /* can_bundle */
  2064. {
  2065. /* operands */
  2066. { 0, },
  2067. { 10, 20 },
  2068. { 0, },
  2069. { 0, },
  2070. { 0, }
  2071. },
  2072. {
  2073. /* fixed_bit_masks */
  2074. 0ULL,
  2075. 0xfc00000780000000ULL,
  2076. 0ULL,
  2077. 0ULL,
  2078. 0ULL
  2079. },
  2080. {
  2081. /* fixed_bit_values */
  2082. -1ULL,
  2083. 0x2800000100000000ULL,
  2084. -1ULL,
  2085. -1ULL,
  2086. -1ULL
  2087. }
  2088. },
  2089. { "bnz.sn", TILE_OPC_BNZ_SN, 0x2 /* pipes */, 2 /* num_operands */,
  2090. TREG_SN, /* implicitly_written_register */
  2091. 1, /* can_bundle */
  2092. {
  2093. /* operands */
  2094. { 0, },
  2095. { 10, 20 },
  2096. { 0, },
  2097. { 0, },
  2098. { 0, }
  2099. },
  2100. {
  2101. /* fixed_bit_masks */
  2102. 0ULL,
  2103. 0xfc00000780000000ULL,
  2104. 0ULL,
  2105. 0ULL,
  2106. 0ULL
  2107. },
  2108. {
  2109. /* fixed_bit_values */
  2110. -1ULL,
  2111. 0x2c00000100000000ULL,
  2112. -1ULL,
  2113. -1ULL,
  2114. -1ULL
  2115. }
  2116. },
  2117. { "bnzt", TILE_OPC_BNZT, 0x2 /* pipes */, 2 /* num_operands */,
  2118. TREG_ZERO, /* implicitly_written_register */
  2119. 1, /* can_bundle */
  2120. {
  2121. /* operands */
  2122. { 0, },
  2123. { 10, 20 },
  2124. { 0, },
  2125. { 0, },
  2126. { 0, }
  2127. },
  2128. {
  2129. /* fixed_bit_masks */
  2130. 0ULL,
  2131. 0xfc00000780000000ULL,
  2132. 0ULL,
  2133. 0ULL,
  2134. 0ULL
  2135. },
  2136. {
  2137. /* fixed_bit_values */
  2138. -1ULL,
  2139. 0x2800000180000000ULL,
  2140. -1ULL,
  2141. -1ULL,
  2142. -1ULL
  2143. }
  2144. },
  2145. { "bnzt.sn", TILE_OPC_BNZT_SN, 0x2 /* pipes */, 2 /* num_operands */,
  2146. TREG_SN, /* implicitly_written_register */
  2147. 1, /* can_bundle */
  2148. {
  2149. /* operands */
  2150. { 0, },
  2151. { 10, 20 },
  2152. { 0, },
  2153. { 0, },
  2154. { 0, }
  2155. },
  2156. {
  2157. /* fixed_bit_masks */
  2158. 0ULL,
  2159. 0xfc00000780000000ULL,
  2160. 0ULL,
  2161. 0ULL,
  2162. 0ULL
  2163. },
  2164. {
  2165. /* fixed_bit_values */
  2166. -1ULL,
  2167. 0x2c00000180000000ULL,
  2168. -1ULL,
  2169. -1ULL,
  2170. -1ULL
  2171. }
  2172. },
  2173. { "bytex", TILE_OPC_BYTEX, 0x5 /* pipes */, 2 /* num_operands */,
  2174. TREG_ZERO, /* implicitly_written_register */
  2175. 1, /* can_bundle */
  2176. {
  2177. /* operands */
  2178. { 7, 8 },
  2179. { 0, },
  2180. { 11, 12 },
  2181. { 0, },
  2182. { 0, }
  2183. },
  2184. {
  2185. /* fixed_bit_masks */
  2186. 0x800000007ffff000ULL,
  2187. 0ULL,
  2188. 0x80000000780ff000ULL,
  2189. 0ULL,
  2190. 0ULL
  2191. },
  2192. {
  2193. /* fixed_bit_values */
  2194. 0x0000000070162000ULL,
  2195. -1ULL,
  2196. 0x80000000680a2000ULL,
  2197. -1ULL,
  2198. -1ULL
  2199. }
  2200. },
  2201. { "bytex.sn", TILE_OPC_BYTEX_SN, 0x1 /* pipes */, 2 /* num_operands */,
  2202. TREG_SN, /* implicitly_written_register */
  2203. 1, /* can_bundle */
  2204. {
  2205. /* operands */
  2206. { 7, 8 },
  2207. { 0, },
  2208. { 0, },
  2209. { 0, },
  2210. { 0, }
  2211. },
  2212. {
  2213. /* fixed_bit_masks */
  2214. 0x800000007ffff000ULL,
  2215. 0ULL,
  2216. 0ULL,
  2217. 0ULL,
  2218. 0ULL
  2219. },
  2220. {
  2221. /* fixed_bit_values */
  2222. 0x0000000078162000ULL,
  2223. -1ULL,
  2224. -1ULL,
  2225. -1ULL,
  2226. -1ULL
  2227. }
  2228. },
  2229. { "bz", TILE_OPC_BZ, 0x2 /* pipes */, 2 /* num_operands */,
  2230. TREG_ZERO, /* implicitly_written_register */
  2231. 1, /* can_bundle */
  2232. {
  2233. /* operands */
  2234. { 0, },
  2235. { 10, 20 },
  2236. { 0, },
  2237. { 0, },
  2238. { 0, }
  2239. },
  2240. {
  2241. /* fixed_bit_masks */
  2242. 0ULL,
  2243. 0xfc00000780000000ULL,
  2244. 0ULL,
  2245. 0ULL,
  2246. 0ULL
  2247. },
  2248. {
  2249. /* fixed_bit_values */
  2250. -1ULL,
  2251. 0x2800000000000000ULL,
  2252. -1ULL,
  2253. -1ULL,
  2254. -1ULL
  2255. }
  2256. },
  2257. { "bz.sn", TILE_OPC_BZ_SN, 0x2 /* pipes */, 2 /* num_operands */,
  2258. TREG_SN, /* implicitly_written_register */
  2259. 1, /* can_bundle */
  2260. {
  2261. /* operands */
  2262. { 0, },
  2263. { 10, 20 },
  2264. { 0, },
  2265. { 0, },
  2266. { 0, }
  2267. },
  2268. {
  2269. /* fixed_bit_masks */
  2270. 0ULL,
  2271. 0xfc00000780000000ULL,
  2272. 0ULL,
  2273. 0ULL,
  2274. 0ULL
  2275. },
  2276. {
  2277. /* fixed_bit_values */
  2278. -1ULL,
  2279. 0x2c00000000000000ULL,
  2280. -1ULL,
  2281. -1ULL,
  2282. -1ULL
  2283. }
  2284. },
  2285. { "bzt", TILE_OPC_BZT, 0x2 /* pipes */, 2 /* num_operands */,
  2286. TREG_ZERO, /* implicitly_written_register */
  2287. 1, /* can_bundle */
  2288. {
  2289. /* operands */
  2290. { 0, },
  2291. { 10, 20 },
  2292. { 0, },
  2293. { 0, },
  2294. { 0, }
  2295. },
  2296. {
  2297. /* fixed_bit_masks */
  2298. 0ULL,
  2299. 0xfc00000780000000ULL,
  2300. 0ULL,
  2301. 0ULL,
  2302. 0ULL
  2303. },
  2304. {
  2305. /* fixed_bit_values */
  2306. -1ULL,
  2307. 0x2800000080000000ULL,
  2308. -1ULL,
  2309. -1ULL,
  2310. -1ULL
  2311. }
  2312. },
  2313. { "bzt.sn", TILE_OPC_BZT_SN, 0x2 /* pipes */, 2 /* num_operands */,
  2314. TREG_SN, /* implicitly_written_register */
  2315. 1, /* can_bundle */
  2316. {
  2317. /* operands */
  2318. { 0, },
  2319. { 10, 20 },
  2320. { 0, },
  2321. { 0, },
  2322. { 0, }
  2323. },
  2324. {
  2325. /* fixed_bit_masks */
  2326. 0ULL,
  2327. 0xfc00000780000000ULL,
  2328. 0ULL,
  2329. 0ULL,
  2330. 0ULL
  2331. },
  2332. {
  2333. /* fixed_bit_values */
  2334. -1ULL,
  2335. 0x2c00000080000000ULL,
  2336. -1ULL,
  2337. -1ULL,
  2338. -1ULL
  2339. }
  2340. },
  2341. { "clz", TILE_OPC_CLZ, 0x5 /* pipes */, 2 /* num_operands */,
  2342. TREG_ZERO, /* implicitly_written_register */
  2343. 1, /* can_bundle */
  2344. {
  2345. /* operands */
  2346. { 7, 8 },
  2347. { 0, },
  2348. { 11, 12 },
  2349. { 0, },
  2350. { 0, }
  2351. },
  2352. {
  2353. /* fixed_bit_masks */
  2354. 0x800000007ffff000ULL,
  2355. 0ULL,
  2356. 0x80000000780ff000ULL,
  2357. 0ULL,
  2358. 0ULL
  2359. },
  2360. {
  2361. /* fixed_bit_values */
  2362. 0x0000000070163000ULL,
  2363. -1ULL,
  2364. 0x80000000680a3000ULL,
  2365. -1ULL,
  2366. -1ULL
  2367. }
  2368. },
  2369. { "clz.sn", TILE_OPC_CLZ_SN, 0x1 /* pipes */, 2 /* num_operands */,
  2370. TREG_SN, /* implicitly_written_register */
  2371. 1, /* can_bundle */
  2372. {
  2373. /* operands */
  2374. { 7, 8 },
  2375. { 0, },
  2376. { 0, },
  2377. { 0, },
  2378. { 0, }
  2379. },
  2380. {
  2381. /* fixed_bit_masks */
  2382. 0x800000007ffff000ULL,
  2383. 0ULL,
  2384. 0ULL,
  2385. 0ULL,
  2386. 0ULL
  2387. },
  2388. {
  2389. /* fixed_bit_values */
  2390. 0x0000000078163000ULL,
  2391. -1ULL,
  2392. -1ULL,
  2393. -1ULL,
  2394. -1ULL
  2395. }
  2396. },
  2397. { "crc32_32", TILE_OPC_CRC32_32, 0x1 /* pipes */, 3 /* num_operands */,
  2398. TREG_ZERO, /* implicitly_written_register */
  2399. 1, /* can_bundle */
  2400. {
  2401. /* operands */
  2402. { 7, 8, 16 },
  2403. { 0, },
  2404. { 0, },
  2405. { 0, },
  2406. { 0, }
  2407. },
  2408. {
  2409. /* fixed_bit_masks */
  2410. 0x800000007ffc0000ULL,
  2411. 0ULL,
  2412. 0ULL,
  2413. 0ULL,
  2414. 0ULL
  2415. },
  2416. {
  2417. /* fixed_bit_values */
  2418. 0x0000000000240000ULL,
  2419. -1ULL,
  2420. -1ULL,
  2421. -1ULL,
  2422. -1ULL
  2423. }
  2424. },
  2425. { "crc32_32.sn", TILE_OPC_CRC32_32_SN, 0x1 /* pipes */, 3 /* num_operands */,
  2426. TREG_SN, /* implicitly_written_register */
  2427. 1, /* can_bundle */
  2428. {
  2429. /* operands */
  2430. { 7, 8, 16 },
  2431. { 0, },
  2432. { 0, },
  2433. { 0, },
  2434. { 0, }
  2435. },
  2436. {
  2437. /* fixed_bit_masks */
  2438. 0x800000007ffc0000ULL,
  2439. 0ULL,
  2440. 0ULL,
  2441. 0ULL,
  2442. 0ULL
  2443. },
  2444. {
  2445. /* fixed_bit_values */
  2446. 0x0000000008240000ULL,
  2447. -1ULL,
  2448. -1ULL,
  2449. -1ULL,
  2450. -1ULL
  2451. }
  2452. },
  2453. { "crc32_8", TILE_OPC_CRC32_8, 0x1 /* pipes */, 3 /* num_operands */,
  2454. TREG_ZERO, /* implicitly_written_register */
  2455. 1, /* can_bundle */
  2456. {
  2457. /* operands */
  2458. { 7, 8, 16 },
  2459. { 0, },
  2460. { 0, },
  2461. { 0, },
  2462. { 0, }
  2463. },
  2464. {
  2465. /* fixed_bit_masks */
  2466. 0x800000007ffc0000ULL,
  2467. 0ULL,
  2468. 0ULL,
  2469. 0ULL,
  2470. 0ULL
  2471. },
  2472. {
  2473. /* fixed_bit_values */
  2474. 0x0000000000280000ULL,
  2475. -1ULL,
  2476. -1ULL,
  2477. -1ULL,
  2478. -1ULL
  2479. }
  2480. },
  2481. { "crc32_8.sn", TILE_OPC_CRC32_8_SN, 0x1 /* pipes */, 3 /* num_operands */,
  2482. TREG_SN, /* implicitly_written_register */
  2483. 1, /* can_bundle */
  2484. {
  2485. /* operands */
  2486. { 7, 8, 16 },
  2487. { 0, },
  2488. { 0, },
  2489. { 0, },
  2490. { 0, }
  2491. },
  2492. {
  2493. /* fixed_bit_masks */
  2494. 0x800000007ffc0000ULL,
  2495. 0ULL,
  2496. 0ULL,
  2497. 0ULL,
  2498. 0ULL
  2499. },
  2500. {
  2501. /* fixed_bit_values */
  2502. 0x0000000008280000ULL,
  2503. -1ULL,
  2504. -1ULL,
  2505. -1ULL,
  2506. -1ULL
  2507. }
  2508. },
  2509. { "ctz", TILE_OPC_CTZ, 0x5 /* pipes */, 2 /* num_operands */,
  2510. TREG_ZERO, /* implicitly_written_register */
  2511. 1, /* can_bundle */
  2512. {
  2513. /* operands */
  2514. { 7, 8 },
  2515. { 0, },
  2516. { 11, 12 },
  2517. { 0, },
  2518. { 0, }
  2519. },
  2520. {
  2521. /* fixed_bit_masks */
  2522. 0x800000007ffff000ULL,
  2523. 0ULL,
  2524. 0x80000000780ff000ULL,
  2525. 0ULL,
  2526. 0ULL
  2527. },
  2528. {
  2529. /* fixed_bit_values */
  2530. 0x0000000070164000ULL,
  2531. -1ULL,
  2532. 0x80000000680a4000ULL,
  2533. -1ULL,
  2534. -1ULL
  2535. }
  2536. },
  2537. { "ctz.sn", TILE_OPC_CTZ_SN, 0x1 /* pipes */, 2 /* num_operands */,
  2538. TREG_SN, /* implicitly_written_register */
  2539. 1, /* can_bundle */
  2540. {
  2541. /* operands */
  2542. { 7, 8 },
  2543. { 0, },
  2544. { 0, },
  2545. { 0, },
  2546. { 0, }
  2547. },
  2548. {
  2549. /* fixed_bit_masks */
  2550. 0x800000007ffff000ULL,
  2551. 0ULL,
  2552. 0ULL,
  2553. 0ULL,
  2554. 0ULL
  2555. },
  2556. {
  2557. /* fixed_bit_values */
  2558. 0x0000000078164000ULL,
  2559. -1ULL,
  2560. -1ULL,
  2561. -1ULL,
  2562. -1ULL
  2563. }
  2564. },
  2565. { "drain", TILE_OPC_DRAIN, 0x2 /* pipes */, 0 /* num_operands */,
  2566. TREG_ZERO, /* implicitly_written_register */
  2567. 0, /* can_bundle */
  2568. {
  2569. /* operands */
  2570. { 0, },
  2571. { },
  2572. { 0, },
  2573. { 0, },
  2574. { 0, }
  2575. },
  2576. {
  2577. /* fixed_bit_masks */
  2578. 0ULL,
  2579. 0xfbfff80000000000ULL,
  2580. 0ULL,
  2581. 0ULL,
  2582. 0ULL
  2583. },
  2584. {
  2585. /* fixed_bit_values */
  2586. -1ULL,
  2587. 0x400b080000000000ULL,
  2588. -1ULL,
  2589. -1ULL,
  2590. -1ULL
  2591. }
  2592. },
  2593. { "dtlbpr", TILE_OPC_DTLBPR, 0x2 /* pipes */, 1 /* num_operands */,
  2594. TREG_ZERO, /* implicitly_written_register */
  2595. 1, /* can_bundle */
  2596. {
  2597. /* operands */
  2598. { 0, },
  2599. { 10 },
  2600. { 0, },
  2601. { 0, },
  2602. { 0, }
  2603. },
  2604. {
  2605. /* fixed_bit_masks */
  2606. 0ULL,
  2607. 0xfbfff80000000000ULL,
  2608. 0ULL,
  2609. 0ULL,
  2610. 0ULL
  2611. },
  2612. {
  2613. /* fixed_bit_values */
  2614. -1ULL,
  2615. 0x400b100000000000ULL,
  2616. -1ULL,
  2617. -1ULL,
  2618. -1ULL
  2619. }
  2620. },
  2621. { "dword_align", TILE_OPC_DWORD_ALIGN, 0x1 /* pipes */, 3 /* num_operands */,
  2622. TREG_ZERO, /* implicitly_written_register */
  2623. 1, /* can_bundle */
  2624. {
  2625. /* operands */
  2626. { 21, 8, 16 },
  2627. { 0, },
  2628. { 0, },
  2629. { 0, },
  2630. { 0, }
  2631. },
  2632. {
  2633. /* fixed_bit_masks */
  2634. 0x800000007ffc0000ULL,
  2635. 0ULL,
  2636. 0ULL,
  2637. 0ULL,
  2638. 0ULL
  2639. },
  2640. {
  2641. /* fixed_bit_values */
  2642. 0x00000000017c0000ULL,
  2643. -1ULL,
  2644. -1ULL,
  2645. -1ULL,
  2646. -1ULL
  2647. }
  2648. },
  2649. { "dword_align.sn", TILE_OPC_DWORD_ALIGN_SN, 0x1 /* pipes */, 3 /* num_operands */,
  2650. TREG_SN, /* implicitly_written_register */
  2651. 1, /* can_bundle */
  2652. {
  2653. /* operands */
  2654. { 21, 8, 16 },
  2655. { 0, },
  2656. { 0, },
  2657. { 0, },
  2658. { 0, }
  2659. },
  2660. {
  2661. /* fixed_bit_masks */
  2662. 0x800000007ffc0000ULL,
  2663. 0ULL,
  2664. 0ULL,
  2665. 0ULL,
  2666. 0ULL
  2667. },
  2668. {
  2669. /* fixed_bit_values */
  2670. 0x00000000097c0000ULL,
  2671. -1ULL,
  2672. -1ULL,
  2673. -1ULL,
  2674. -1ULL
  2675. }
  2676. },
  2677. { "finv", TILE_OPC_FINV, 0x2 /* pipes */, 1 /* num_operands */,
  2678. TREG_ZERO, /* implicitly_written_register */
  2679. 1, /* can_bundle */
  2680. {
  2681. /* operands */
  2682. { 0, },
  2683. { 10 },
  2684. { 0, },
  2685. { 0, },
  2686. { 0, }
  2687. },
  2688. {
  2689. /* fixed_bit_masks */
  2690. 0ULL,
  2691. 0xfbfff80000000000ULL,
  2692. 0ULL,
  2693. 0ULL,
  2694. 0ULL
  2695. },
  2696. {
  2697. /* fixed_bit_values */
  2698. -1ULL,
  2699. 0x400b180000000000ULL,
  2700. -1ULL,
  2701. -1ULL,
  2702. -1ULL
  2703. }
  2704. },
  2705. { "flush", TILE_OPC_FLUSH, 0x2 /* pipes */, 1 /* num_operands */,
  2706. TREG_ZERO, /* implicitly_written_register */
  2707. 1, /* can_bundle */
  2708. {
  2709. /* operands */
  2710. { 0, },
  2711. { 10 },
  2712. { 0, },
  2713. { 0, },
  2714. { 0, }
  2715. },
  2716. {
  2717. /* fixed_bit_masks */
  2718. 0ULL,
  2719. 0xfbfff80000000000ULL,
  2720. 0ULL,
  2721. 0ULL,
  2722. 0ULL
  2723. },
  2724. {
  2725. /* fixed_bit_values */
  2726. -1ULL,
  2727. 0x400b200000000000ULL,
  2728. -1ULL,
  2729. -1ULL,
  2730. -1ULL
  2731. }
  2732. },
  2733. { "fnop", TILE_OPC_FNOP, 0xf /* pipes */, 0 /* num_operands */,
  2734. TREG_ZERO, /* implicitly_written_register */
  2735. 1, /* can_bundle */
  2736. {
  2737. /* operands */
  2738. { },
  2739. { },
  2740. { },
  2741. { },
  2742. { 0, }
  2743. },
  2744. {
  2745. /* fixed_bit_masks */
  2746. 0x8000000077fff000ULL,
  2747. 0xfbfff80000000000ULL,
  2748. 0x80000000780ff000ULL,
  2749. 0xf807f80000000000ULL,
  2750. 0ULL
  2751. },
  2752. {
  2753. /* fixed_bit_values */
  2754. 0x0000000070165000ULL,
  2755. 0x400b280000000000ULL,
  2756. 0x80000000680a5000ULL,
  2757. 0xd805080000000000ULL,
  2758. -1ULL
  2759. }
  2760. },
  2761. { "icoh", TILE_OPC_ICOH, 0x2 /* pipes */, 1 /* num_operands */,
  2762. TREG_ZERO, /* implicitly_written_register */
  2763. 1, /* can_bundle */
  2764. {
  2765. /* operands */
  2766. { 0, },
  2767. { 10 },
  2768. { 0, },
  2769. { 0, },
  2770. { 0, }
  2771. },
  2772. {
  2773. /* fixed_bit_masks */
  2774. 0ULL,
  2775. 0xfbfff80000000000ULL,
  2776. 0ULL,
  2777. 0ULL,
  2778. 0ULL
  2779. },
  2780. {
  2781. /* fixed_bit_values */
  2782. -1ULL,
  2783. 0x400b300000000000ULL,
  2784. -1ULL,
  2785. -1ULL,
  2786. -1ULL
  2787. }
  2788. },
  2789. { "ill", TILE_OPC_ILL, 0xa /* pipes */, 0 /* num_operands */,
  2790. TREG_ZERO, /* implicitly_written_register */
  2791. 1, /* can_bundle */
  2792. {
  2793. /* operands */
  2794. { 0, },
  2795. { },
  2796. { 0, },
  2797. { },
  2798. { 0, }
  2799. },
  2800. {
  2801. /* fixed_bit_masks */
  2802. 0ULL,
  2803. 0xfbfff80000000000ULL,
  2804. 0ULL,
  2805. 0xf807f80000000000ULL,
  2806. 0ULL
  2807. },
  2808. {
  2809. /* fixed_bit_values */
  2810. -1ULL,
  2811. 0x400b380000000000ULL,
  2812. -1ULL,
  2813. 0xd805100000000000ULL,
  2814. -1ULL
  2815. }
  2816. },
  2817. { "inthb", TILE_OPC_INTHB, 0x3 /* pipes */, 3 /* num_operands */,
  2818. TREG_ZERO, /* implicitly_written_register */
  2819. 1, /* can_bundle */
  2820. {
  2821. /* operands */
  2822. { 7, 8, 16 },
  2823. { 9, 10, 17 },
  2824. { 0, },
  2825. { 0, },
  2826. { 0, }
  2827. },
  2828. {
  2829. /* fixed_bit_masks */
  2830. 0x800000007ffc0000ULL,
  2831. 0xfffe000000000000ULL,
  2832. 0ULL,
  2833. 0ULL,
  2834. 0ULL
  2835. },
  2836. {
  2837. /* fixed_bit_values */
  2838. 0x00000000002c0000ULL,
  2839. 0x080a000000000000ULL,
  2840. -1ULL,
  2841. -1ULL,
  2842. -1ULL
  2843. }
  2844. },
  2845. { "inthb.sn", TILE_OPC_INTHB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  2846. TREG_SN, /* implicitly_written_register */
  2847. 1, /* can_bundle */
  2848. {
  2849. /* operands */
  2850. { 7, 8, 16 },
  2851. { 9, 10, 17 },
  2852. { 0, },
  2853. { 0, },
  2854. { 0, }
  2855. },
  2856. {
  2857. /* fixed_bit_masks */
  2858. 0x800000007ffc0000ULL,
  2859. 0xfffe000000000000ULL,
  2860. 0ULL,
  2861. 0ULL,
  2862. 0ULL
  2863. },
  2864. {
  2865. /* fixed_bit_values */
  2866. 0x00000000082c0000ULL,
  2867. 0x0c0a000000000000ULL,
  2868. -1ULL,
  2869. -1ULL,
  2870. -1ULL
  2871. }
  2872. },
  2873. { "inthh", TILE_OPC_INTHH, 0x3 /* pipes */, 3 /* num_operands */,
  2874. TREG_ZERO, /* implicitly_written_register */
  2875. 1, /* can_bundle */
  2876. {
  2877. /* operands */
  2878. { 7, 8, 16 },
  2879. { 9, 10, 17 },
  2880. { 0, },
  2881. { 0, },
  2882. { 0, }
  2883. },
  2884. {
  2885. /* fixed_bit_masks */
  2886. 0x800000007ffc0000ULL,
  2887. 0xfffe000000000000ULL,
  2888. 0ULL,
  2889. 0ULL,
  2890. 0ULL
  2891. },
  2892. {
  2893. /* fixed_bit_values */
  2894. 0x0000000000300000ULL,
  2895. 0x080c000000000000ULL,
  2896. -1ULL,
  2897. -1ULL,
  2898. -1ULL
  2899. }
  2900. },
  2901. { "inthh.sn", TILE_OPC_INTHH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  2902. TREG_SN, /* implicitly_written_register */
  2903. 1, /* can_bundle */
  2904. {
  2905. /* operands */
  2906. { 7, 8, 16 },
  2907. { 9, 10, 17 },
  2908. { 0, },
  2909. { 0, },
  2910. { 0, }
  2911. },
  2912. {
  2913. /* fixed_bit_masks */
  2914. 0x800000007ffc0000ULL,
  2915. 0xfffe000000000000ULL,
  2916. 0ULL,
  2917. 0ULL,
  2918. 0ULL
  2919. },
  2920. {
  2921. /* fixed_bit_values */
  2922. 0x0000000008300000ULL,
  2923. 0x0c0c000000000000ULL,
  2924. -1ULL,
  2925. -1ULL,
  2926. -1ULL
  2927. }
  2928. },
  2929. { "intlb", TILE_OPC_INTLB, 0x3 /* pipes */, 3 /* num_operands */,
  2930. TREG_ZERO, /* implicitly_written_register */
  2931. 1, /* can_bundle */
  2932. {
  2933. /* operands */
  2934. { 7, 8, 16 },
  2935. { 9, 10, 17 },
  2936. { 0, },
  2937. { 0, },
  2938. { 0, }
  2939. },
  2940. {
  2941. /* fixed_bit_masks */
  2942. 0x800000007ffc0000ULL,
  2943. 0xfffe000000000000ULL,
  2944. 0ULL,
  2945. 0ULL,
  2946. 0ULL
  2947. },
  2948. {
  2949. /* fixed_bit_values */
  2950. 0x0000000000340000ULL,
  2951. 0x080e000000000000ULL,
  2952. -1ULL,
  2953. -1ULL,
  2954. -1ULL
  2955. }
  2956. },
  2957. { "intlb.sn", TILE_OPC_INTLB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  2958. TREG_SN, /* implicitly_written_register */
  2959. 1, /* can_bundle */
  2960. {
  2961. /* operands */
  2962. { 7, 8, 16 },
  2963. { 9, 10, 17 },
  2964. { 0, },
  2965. { 0, },
  2966. { 0, }
  2967. },
  2968. {
  2969. /* fixed_bit_masks */
  2970. 0x800000007ffc0000ULL,
  2971. 0xfffe000000000000ULL,
  2972. 0ULL,
  2973. 0ULL,
  2974. 0ULL
  2975. },
  2976. {
  2977. /* fixed_bit_values */
  2978. 0x0000000008340000ULL,
  2979. 0x0c0e000000000000ULL,
  2980. -1ULL,
  2981. -1ULL,
  2982. -1ULL
  2983. }
  2984. },
  2985. { "intlh", TILE_OPC_INTLH, 0x3 /* pipes */, 3 /* num_operands */,
  2986. TREG_ZERO, /* implicitly_written_register */
  2987. 1, /* can_bundle */
  2988. {
  2989. /* operands */
  2990. { 7, 8, 16 },
  2991. { 9, 10, 17 },
  2992. { 0, },
  2993. { 0, },
  2994. { 0, }
  2995. },
  2996. {
  2997. /* fixed_bit_masks */
  2998. 0x800000007ffc0000ULL,
  2999. 0xfffe000000000000ULL,
  3000. 0ULL,
  3001. 0ULL,
  3002. 0ULL
  3003. },
  3004. {
  3005. /* fixed_bit_values */
  3006. 0x0000000000380000ULL,
  3007. 0x0810000000000000ULL,
  3008. -1ULL,
  3009. -1ULL,
  3010. -1ULL
  3011. }
  3012. },
  3013. { "intlh.sn", TILE_OPC_INTLH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  3014. TREG_SN, /* implicitly_written_register */
  3015. 1, /* can_bundle */
  3016. {
  3017. /* operands */
  3018. { 7, 8, 16 },
  3019. { 9, 10, 17 },
  3020. { 0, },
  3021. { 0, },
  3022. { 0, }
  3023. },
  3024. {
  3025. /* fixed_bit_masks */
  3026. 0x800000007ffc0000ULL,
  3027. 0xfffe000000000000ULL,
  3028. 0ULL,
  3029. 0ULL,
  3030. 0ULL
  3031. },
  3032. {
  3033. /* fixed_bit_values */
  3034. 0x0000000008380000ULL,
  3035. 0x0c10000000000000ULL,
  3036. -1ULL,
  3037. -1ULL,
  3038. -1ULL
  3039. }
  3040. },
  3041. { "inv", TILE_OPC_INV, 0x2 /* pipes */, 1 /* num_operands */,
  3042. TREG_ZERO, /* implicitly_written_register */
  3043. 1, /* can_bundle */
  3044. {
  3045. /* operands */
  3046. { 0, },
  3047. { 10 },
  3048. { 0, },
  3049. { 0, },
  3050. { 0, }
  3051. },
  3052. {
  3053. /* fixed_bit_masks */
  3054. 0ULL,
  3055. 0xfbfff80000000000ULL,
  3056. 0ULL,
  3057. 0ULL,
  3058. 0ULL
  3059. },
  3060. {
  3061. /* fixed_bit_values */
  3062. -1ULL,
  3063. 0x400b400000000000ULL,
  3064. -1ULL,
  3065. -1ULL,
  3066. -1ULL
  3067. }
  3068. },
  3069. { "iret", TILE_OPC_IRET, 0x2 /* pipes */, 0 /* num_operands */,
  3070. TREG_ZERO, /* implicitly_written_register */
  3071. 1, /* can_bundle */
  3072. {
  3073. /* operands */
  3074. { 0, },
  3075. { },
  3076. { 0, },
  3077. { 0, },
  3078. { 0, }
  3079. },
  3080. {
  3081. /* fixed_bit_masks */
  3082. 0ULL,
  3083. 0xfbfff80000000000ULL,
  3084. 0ULL,
  3085. 0ULL,
  3086. 0ULL
  3087. },
  3088. {
  3089. /* fixed_bit_values */
  3090. -1ULL,
  3091. 0x400b480000000000ULL,
  3092. -1ULL,
  3093. -1ULL,
  3094. -1ULL
  3095. }
  3096. },
  3097. { "jalb", TILE_OPC_JALB, 0x2 /* pipes */, 1 /* num_operands */,
  3098. TREG_LR, /* implicitly_written_register */
  3099. 1, /* can_bundle */
  3100. {
  3101. /* operands */
  3102. { 0, },
  3103. { 22 },
  3104. { 0, },
  3105. { 0, },
  3106. { 0, }
  3107. },
  3108. {
  3109. /* fixed_bit_masks */
  3110. 0ULL,
  3111. 0xf800000000000000ULL,
  3112. 0ULL,
  3113. 0ULL,
  3114. 0ULL
  3115. },
  3116. {
  3117. /* fixed_bit_values */
  3118. -1ULL,
  3119. 0x6800000000000000ULL,
  3120. -1ULL,
  3121. -1ULL,
  3122. -1ULL
  3123. }
  3124. },
  3125. { "jalf", TILE_OPC_JALF, 0x2 /* pipes */, 1 /* num_operands */,
  3126. TREG_LR, /* implicitly_written_register */
  3127. 1, /* can_bundle */
  3128. {
  3129. /* operands */
  3130. { 0, },
  3131. { 22 },
  3132. { 0, },
  3133. { 0, },
  3134. { 0, }
  3135. },
  3136. {
  3137. /* fixed_bit_masks */
  3138. 0ULL,
  3139. 0xf800000000000000ULL,
  3140. 0ULL,
  3141. 0ULL,
  3142. 0ULL
  3143. },
  3144. {
  3145. /* fixed_bit_values */
  3146. -1ULL,
  3147. 0x6000000000000000ULL,
  3148. -1ULL,
  3149. -1ULL,
  3150. -1ULL
  3151. }
  3152. },
  3153. { "jalr", TILE_OPC_JALR, 0x2 /* pipes */, 1 /* num_operands */,
  3154. TREG_LR, /* implicitly_written_register */
  3155. 1, /* can_bundle */
  3156. {
  3157. /* operands */
  3158. { 0, },
  3159. { 10 },
  3160. { 0, },
  3161. { 0, },
  3162. { 0, }
  3163. },
  3164. {
  3165. /* fixed_bit_masks */
  3166. 0ULL,
  3167. 0xfbfe000000000000ULL,
  3168. 0ULL,
  3169. 0ULL,
  3170. 0ULL
  3171. },
  3172. {
  3173. /* fixed_bit_values */
  3174. -1ULL,
  3175. 0x0814000000000000ULL,
  3176. -1ULL,
  3177. -1ULL,
  3178. -1ULL
  3179. }
  3180. },
  3181. { "jalrp", TILE_OPC_JALRP, 0x2 /* pipes */, 1 /* num_operands */,
  3182. TREG_LR, /* implicitly_written_register */
  3183. 1, /* can_bundle */
  3184. {
  3185. /* operands */
  3186. { 0, },
  3187. { 10 },
  3188. { 0, },
  3189. { 0, },
  3190. { 0, }
  3191. },
  3192. {
  3193. /* fixed_bit_masks */
  3194. 0ULL,
  3195. 0xfbfe000000000000ULL,
  3196. 0ULL,
  3197. 0ULL,
  3198. 0ULL
  3199. },
  3200. {
  3201. /* fixed_bit_values */
  3202. -1ULL,
  3203. 0x0812000000000000ULL,
  3204. -1ULL,
  3205. -1ULL,
  3206. -1ULL
  3207. }
  3208. },
  3209. { "jb", TILE_OPC_JB, 0x2 /* pipes */, 1 /* num_operands */,
  3210. TREG_ZERO, /* implicitly_written_register */
  3211. 1, /* can_bundle */
  3212. {
  3213. /* operands */
  3214. { 0, },
  3215. { 22 },
  3216. { 0, },
  3217. { 0, },
  3218. { 0, }
  3219. },
  3220. {
  3221. /* fixed_bit_masks */
  3222. 0ULL,
  3223. 0xf800000000000000ULL,
  3224. 0ULL,
  3225. 0ULL,
  3226. 0ULL
  3227. },
  3228. {
  3229. /* fixed_bit_values */
  3230. -1ULL,
  3231. 0x5800000000000000ULL,
  3232. -1ULL,
  3233. -1ULL,
  3234. -1ULL
  3235. }
  3236. },
  3237. { "jf", TILE_OPC_JF, 0x2 /* pipes */, 1 /* num_operands */,
  3238. TREG_ZERO, /* implicitly_written_register */
  3239. 1, /* can_bundle */
  3240. {
  3241. /* operands */
  3242. { 0, },
  3243. { 22 },
  3244. { 0, },
  3245. { 0, },
  3246. { 0, }
  3247. },
  3248. {
  3249. /* fixed_bit_masks */
  3250. 0ULL,
  3251. 0xf800000000000000ULL,
  3252. 0ULL,
  3253. 0ULL,
  3254. 0ULL
  3255. },
  3256. {
  3257. /* fixed_bit_values */
  3258. -1ULL,
  3259. 0x5000000000000000ULL,
  3260. -1ULL,
  3261. -1ULL,
  3262. -1ULL
  3263. }
  3264. },
  3265. { "jr", TILE_OPC_JR, 0x2 /* pipes */, 1 /* num_operands */,
  3266. TREG_ZERO, /* implicitly_written_register */
  3267. 1, /* can_bundle */
  3268. {
  3269. /* operands */
  3270. { 0, },
  3271. { 10 },
  3272. { 0, },
  3273. { 0, },
  3274. { 0, }
  3275. },
  3276. {
  3277. /* fixed_bit_masks */
  3278. 0ULL,
  3279. 0xfbfe000000000000ULL,
  3280. 0ULL,
  3281. 0ULL,
  3282. 0ULL
  3283. },
  3284. {
  3285. /* fixed_bit_values */
  3286. -1ULL,
  3287. 0x0818000000000000ULL,
  3288. -1ULL,
  3289. -1ULL,
  3290. -1ULL
  3291. }
  3292. },
  3293. { "jrp", TILE_OPC_JRP, 0x2 /* pipes */, 1 /* num_operands */,
  3294. TREG_ZERO, /* implicitly_written_register */
  3295. 1, /* can_bundle */
  3296. {
  3297. /* operands */
  3298. { 0, },
  3299. { 10 },
  3300. { 0, },
  3301. { 0, },
  3302. { 0, }
  3303. },
  3304. {
  3305. /* fixed_bit_masks */
  3306. 0ULL,
  3307. 0xfbfe000000000000ULL,
  3308. 0ULL,
  3309. 0ULL,
  3310. 0ULL
  3311. },
  3312. {
  3313. /* fixed_bit_values */
  3314. -1ULL,
  3315. 0x0816000000000000ULL,
  3316. -1ULL,
  3317. -1ULL,
  3318. -1ULL
  3319. }
  3320. },
  3321. { "lb", TILE_OPC_LB, 0x12 /* pipes */, 2 /* num_operands */,
  3322. TREG_ZERO, /* implicitly_written_register */
  3323. 1, /* can_bundle */
  3324. {
  3325. /* operands */
  3326. { 0, },
  3327. { 9, 10 },
  3328. { 0, },
  3329. { 0, },
  3330. { 23, 15 }
  3331. },
  3332. {
  3333. /* fixed_bit_masks */
  3334. 0ULL,
  3335. 0xfffff80000000000ULL,
  3336. 0ULL,
  3337. 0ULL,
  3338. 0x8700000000000000ULL
  3339. },
  3340. {
  3341. /* fixed_bit_values */
  3342. -1ULL,
  3343. 0x400b500000000000ULL,
  3344. -1ULL,
  3345. -1ULL,
  3346. 0x8000000000000000ULL
  3347. }
  3348. },
  3349. { "lb.sn", TILE_OPC_LB_SN, 0x2 /* pipes */, 2 /* num_operands */,
  3350. TREG_SN, /* implicitly_written_register */
  3351. 1, /* can_bundle */
  3352. {
  3353. /* operands */
  3354. { 0, },
  3355. { 9, 10 },
  3356. { 0, },
  3357. { 0, },
  3358. { 0, }
  3359. },
  3360. {
  3361. /* fixed_bit_masks */
  3362. 0ULL,
  3363. 0xfffff80000000000ULL,
  3364. 0ULL,
  3365. 0ULL,
  3366. 0ULL
  3367. },
  3368. {
  3369. /* fixed_bit_values */
  3370. -1ULL,
  3371. 0x440b500000000000ULL,
  3372. -1ULL,
  3373. -1ULL,
  3374. -1ULL
  3375. }
  3376. },
  3377. { "lb_u", TILE_OPC_LB_U, 0x12 /* pipes */, 2 /* num_operands */,
  3378. TREG_ZERO, /* implicitly_written_register */
  3379. 1, /* can_bundle */
  3380. {
  3381. /* operands */
  3382. { 0, },
  3383. { 9, 10 },
  3384. { 0, },
  3385. { 0, },
  3386. { 23, 15 }
  3387. },
  3388. {
  3389. /* fixed_bit_masks */
  3390. 0ULL,
  3391. 0xfffff80000000000ULL,
  3392. 0ULL,
  3393. 0ULL,
  3394. 0x8700000000000000ULL
  3395. },
  3396. {
  3397. /* fixed_bit_values */
  3398. -1ULL,
  3399. 0x400b580000000000ULL,
  3400. -1ULL,
  3401. -1ULL,
  3402. 0x8100000000000000ULL
  3403. }
  3404. },
  3405. { "lb_u.sn", TILE_OPC_LB_U_SN, 0x2 /* pipes */, 2 /* num_operands */,
  3406. TREG_SN, /* implicitly_written_register */
  3407. 1, /* can_bundle */
  3408. {
  3409. /* operands */
  3410. { 0, },
  3411. { 9, 10 },
  3412. { 0, },
  3413. { 0, },
  3414. { 0, }
  3415. },
  3416. {
  3417. /* fixed_bit_masks */
  3418. 0ULL,
  3419. 0xfffff80000000000ULL,
  3420. 0ULL,
  3421. 0ULL,
  3422. 0ULL
  3423. },
  3424. {
  3425. /* fixed_bit_values */
  3426. -1ULL,
  3427. 0x440b580000000000ULL,
  3428. -1ULL,
  3429. -1ULL,
  3430. -1ULL
  3431. }
  3432. },
  3433. { "lbadd", TILE_OPC_LBADD, 0x2 /* pipes */, 3 /* num_operands */,
  3434. TREG_ZERO, /* implicitly_written_register */
  3435. 1, /* can_bundle */
  3436. {
  3437. /* operands */
  3438. { 0, },
  3439. { 9, 24, 1 },
  3440. { 0, },
  3441. { 0, },
  3442. { 0, }
  3443. },
  3444. {
  3445. /* fixed_bit_masks */
  3446. 0ULL,
  3447. 0xfff8000000000000ULL,
  3448. 0ULL,
  3449. 0ULL,
  3450. 0ULL
  3451. },
  3452. {
  3453. /* fixed_bit_values */
  3454. -1ULL,
  3455. 0x30b0000000000000ULL,
  3456. -1ULL,
  3457. -1ULL,
  3458. -1ULL
  3459. }
  3460. },
  3461. { "lbadd.sn", TILE_OPC_LBADD_SN, 0x2 /* pipes */, 3 /* num_operands */,
  3462. TREG_SN, /* implicitly_written_register */
  3463. 1, /* can_bundle */
  3464. {
  3465. /* operands */
  3466. { 0, },
  3467. { 9, 24, 1 },
  3468. { 0, },
  3469. { 0, },
  3470. { 0, }
  3471. },
  3472. {
  3473. /* fixed_bit_masks */
  3474. 0ULL,
  3475. 0xfff8000000000000ULL,
  3476. 0ULL,
  3477. 0ULL,
  3478. 0ULL
  3479. },
  3480. {
  3481. /* fixed_bit_values */
  3482. -1ULL,
  3483. 0x34b0000000000000ULL,
  3484. -1ULL,
  3485. -1ULL,
  3486. -1ULL
  3487. }
  3488. },
  3489. { "lbadd_u", TILE_OPC_LBADD_U, 0x2 /* pipes */, 3 /* num_operands */,
  3490. TREG_ZERO, /* implicitly_written_register */
  3491. 1, /* can_bundle */
  3492. {
  3493. /* operands */
  3494. { 0, },
  3495. { 9, 24, 1 },
  3496. { 0, },
  3497. { 0, },
  3498. { 0, }
  3499. },
  3500. {
  3501. /* fixed_bit_masks */
  3502. 0ULL,
  3503. 0xfff8000000000000ULL,
  3504. 0ULL,
  3505. 0ULL,
  3506. 0ULL
  3507. },
  3508. {
  3509. /* fixed_bit_values */
  3510. -1ULL,
  3511. 0x30b8000000000000ULL,
  3512. -1ULL,
  3513. -1ULL,
  3514. -1ULL
  3515. }
  3516. },
  3517. { "lbadd_u.sn", TILE_OPC_LBADD_U_SN, 0x2 /* pipes */, 3 /* num_operands */,
  3518. TREG_SN, /* implicitly_written_register */
  3519. 1, /* can_bundle */
  3520. {
  3521. /* operands */
  3522. { 0, },
  3523. { 9, 24, 1 },
  3524. { 0, },
  3525. { 0, },
  3526. { 0, }
  3527. },
  3528. {
  3529. /* fixed_bit_masks */
  3530. 0ULL,
  3531. 0xfff8000000000000ULL,
  3532. 0ULL,
  3533. 0ULL,
  3534. 0ULL
  3535. },
  3536. {
  3537. /* fixed_bit_values */
  3538. -1ULL,
  3539. 0x34b8000000000000ULL,
  3540. -1ULL,
  3541. -1ULL,
  3542. -1ULL
  3543. }
  3544. },
  3545. { "lh", TILE_OPC_LH, 0x12 /* pipes */, 2 /* num_operands */,
  3546. TREG_ZERO, /* implicitly_written_register */
  3547. 1, /* can_bundle */
  3548. {
  3549. /* operands */
  3550. { 0, },
  3551. { 9, 10 },
  3552. { 0, },
  3553. { 0, },
  3554. { 23, 15 }
  3555. },
  3556. {
  3557. /* fixed_bit_masks */
  3558. 0ULL,
  3559. 0xfffff80000000000ULL,
  3560. 0ULL,
  3561. 0ULL,
  3562. 0x8700000000000000ULL
  3563. },
  3564. {
  3565. /* fixed_bit_values */
  3566. -1ULL,
  3567. 0x400b600000000000ULL,
  3568. -1ULL,
  3569. -1ULL,
  3570. 0x8200000000000000ULL
  3571. }
  3572. },
  3573. { "lh.sn", TILE_OPC_LH_SN, 0x2 /* pipes */, 2 /* num_operands */,
  3574. TREG_SN, /* implicitly_written_register */
  3575. 1, /* can_bundle */
  3576. {
  3577. /* operands */
  3578. { 0, },
  3579. { 9, 10 },
  3580. { 0, },
  3581. { 0, },
  3582. { 0, }
  3583. },
  3584. {
  3585. /* fixed_bit_masks */
  3586. 0ULL,
  3587. 0xfffff80000000000ULL,
  3588. 0ULL,
  3589. 0ULL,
  3590. 0ULL
  3591. },
  3592. {
  3593. /* fixed_bit_values */
  3594. -1ULL,
  3595. 0x440b600000000000ULL,
  3596. -1ULL,
  3597. -1ULL,
  3598. -1ULL
  3599. }
  3600. },
  3601. { "lh_u", TILE_OPC_LH_U, 0x12 /* pipes */, 2 /* num_operands */,
  3602. TREG_ZERO, /* implicitly_written_register */
  3603. 1, /* can_bundle */
  3604. {
  3605. /* operands */
  3606. { 0, },
  3607. { 9, 10 },
  3608. { 0, },
  3609. { 0, },
  3610. { 23, 15 }
  3611. },
  3612. {
  3613. /* fixed_bit_masks */
  3614. 0ULL,
  3615. 0xfffff80000000000ULL,
  3616. 0ULL,
  3617. 0ULL,
  3618. 0x8700000000000000ULL
  3619. },
  3620. {
  3621. /* fixed_bit_values */
  3622. -1ULL,
  3623. 0x400b680000000000ULL,
  3624. -1ULL,
  3625. -1ULL,
  3626. 0x8300000000000000ULL
  3627. }
  3628. },
  3629. { "lh_u.sn", TILE_OPC_LH_U_SN, 0x2 /* pipes */, 2 /* num_operands */,
  3630. TREG_SN, /* implicitly_written_register */
  3631. 1, /* can_bundle */
  3632. {
  3633. /* operands */
  3634. { 0, },
  3635. { 9, 10 },
  3636. { 0, },
  3637. { 0, },
  3638. { 0, }
  3639. },
  3640. {
  3641. /* fixed_bit_masks */
  3642. 0ULL,
  3643. 0xfffff80000000000ULL,
  3644. 0ULL,
  3645. 0ULL,
  3646. 0ULL
  3647. },
  3648. {
  3649. /* fixed_bit_values */
  3650. -1ULL,
  3651. 0x440b680000000000ULL,
  3652. -1ULL,
  3653. -1ULL,
  3654. -1ULL
  3655. }
  3656. },
  3657. { "lhadd", TILE_OPC_LHADD, 0x2 /* pipes */, 3 /* num_operands */,
  3658. TREG_ZERO, /* implicitly_written_register */
  3659. 1, /* can_bundle */
  3660. {
  3661. /* operands */
  3662. { 0, },
  3663. { 9, 24, 1 },
  3664. { 0, },
  3665. { 0, },
  3666. { 0, }
  3667. },
  3668. {
  3669. /* fixed_bit_masks */
  3670. 0ULL,
  3671. 0xfff8000000000000ULL,
  3672. 0ULL,
  3673. 0ULL,
  3674. 0ULL
  3675. },
  3676. {
  3677. /* fixed_bit_values */
  3678. -1ULL,
  3679. 0x30c0000000000000ULL,
  3680. -1ULL,
  3681. -1ULL,
  3682. -1ULL
  3683. }
  3684. },
  3685. { "lhadd.sn", TILE_OPC_LHADD_SN, 0x2 /* pipes */, 3 /* num_operands */,
  3686. TREG_SN, /* implicitly_written_register */
  3687. 1, /* can_bundle */
  3688. {
  3689. /* operands */
  3690. { 0, },
  3691. { 9, 24, 1 },
  3692. { 0, },
  3693. { 0, },
  3694. { 0, }
  3695. },
  3696. {
  3697. /* fixed_bit_masks */
  3698. 0ULL,
  3699. 0xfff8000000000000ULL,
  3700. 0ULL,
  3701. 0ULL,
  3702. 0ULL
  3703. },
  3704. {
  3705. /* fixed_bit_values */
  3706. -1ULL,
  3707. 0x34c0000000000000ULL,
  3708. -1ULL,
  3709. -1ULL,
  3710. -1ULL
  3711. }
  3712. },
  3713. { "lhadd_u", TILE_OPC_LHADD_U, 0x2 /* pipes */, 3 /* num_operands */,
  3714. TREG_ZERO, /* implicitly_written_register */
  3715. 1, /* can_bundle */
  3716. {
  3717. /* operands */
  3718. { 0, },
  3719. { 9, 24, 1 },
  3720. { 0, },
  3721. { 0, },
  3722. { 0, }
  3723. },
  3724. {
  3725. /* fixed_bit_masks */
  3726. 0ULL,
  3727. 0xfff8000000000000ULL,
  3728. 0ULL,
  3729. 0ULL,
  3730. 0ULL
  3731. },
  3732. {
  3733. /* fixed_bit_values */
  3734. -1ULL,
  3735. 0x30c8000000000000ULL,
  3736. -1ULL,
  3737. -1ULL,
  3738. -1ULL
  3739. }
  3740. },
  3741. { "lhadd_u.sn", TILE_OPC_LHADD_U_SN, 0x2 /* pipes */, 3 /* num_operands */,
  3742. TREG_SN, /* implicitly_written_register */
  3743. 1, /* can_bundle */
  3744. {
  3745. /* operands */
  3746. { 0, },
  3747. { 9, 24, 1 },
  3748. { 0, },
  3749. { 0, },
  3750. { 0, }
  3751. },
  3752. {
  3753. /* fixed_bit_masks */
  3754. 0ULL,
  3755. 0xfff8000000000000ULL,
  3756. 0ULL,
  3757. 0ULL,
  3758. 0ULL
  3759. },
  3760. {
  3761. /* fixed_bit_values */
  3762. -1ULL,
  3763. 0x34c8000000000000ULL,
  3764. -1ULL,
  3765. -1ULL,
  3766. -1ULL
  3767. }
  3768. },
  3769. { "lnk", TILE_OPC_LNK, 0x2 /* pipes */, 1 /* num_operands */,
  3770. TREG_ZERO, /* implicitly_written_register */
  3771. 1, /* can_bundle */
  3772. {
  3773. /* operands */
  3774. { 0, },
  3775. { 9 },
  3776. { 0, },
  3777. { 0, },
  3778. { 0, }
  3779. },
  3780. {
  3781. /* fixed_bit_masks */
  3782. 0ULL,
  3783. 0xfffe000000000000ULL,
  3784. 0ULL,
  3785. 0ULL,
  3786. 0ULL
  3787. },
  3788. {
  3789. /* fixed_bit_values */
  3790. -1ULL,
  3791. 0x081a000000000000ULL,
  3792. -1ULL,
  3793. -1ULL,
  3794. -1ULL
  3795. }
  3796. },
  3797. { "lnk.sn", TILE_OPC_LNK_SN, 0x2 /* pipes */, 1 /* num_operands */,
  3798. TREG_SN, /* implicitly_written_register */
  3799. 1, /* can_bundle */
  3800. {
  3801. /* operands */
  3802. { 0, },
  3803. { 9 },
  3804. { 0, },
  3805. { 0, },
  3806. { 0, }
  3807. },
  3808. {
  3809. /* fixed_bit_masks */
  3810. 0ULL,
  3811. 0xfffe000000000000ULL,
  3812. 0ULL,
  3813. 0ULL,
  3814. 0ULL
  3815. },
  3816. {
  3817. /* fixed_bit_values */
  3818. -1ULL,
  3819. 0x0c1a000000000000ULL,
  3820. -1ULL,
  3821. -1ULL,
  3822. -1ULL
  3823. }
  3824. },
  3825. { "lw", TILE_OPC_LW, 0x12 /* pipes */, 2 /* num_operands */,
  3826. TREG_ZERO, /* implicitly_written_register */
  3827. 1, /* can_bundle */
  3828. {
  3829. /* operands */
  3830. { 0, },
  3831. { 9, 10 },
  3832. { 0, },
  3833. { 0, },
  3834. { 23, 15 }
  3835. },
  3836. {
  3837. /* fixed_bit_masks */
  3838. 0ULL,
  3839. 0xfffff80000000000ULL,
  3840. 0ULL,
  3841. 0ULL,
  3842. 0x8700000000000000ULL
  3843. },
  3844. {
  3845. /* fixed_bit_values */
  3846. -1ULL,
  3847. 0x400b700000000000ULL,
  3848. -1ULL,
  3849. -1ULL,
  3850. 0x8400000000000000ULL
  3851. }
  3852. },
  3853. { "lw.sn", TILE_OPC_LW_SN, 0x2 /* pipes */, 2 /* num_operands */,
  3854. TREG_SN, /* implicitly_written_register */
  3855. 1, /* can_bundle */
  3856. {
  3857. /* operands */
  3858. { 0, },
  3859. { 9, 10 },
  3860. { 0, },
  3861. { 0, },
  3862. { 0, }
  3863. },
  3864. {
  3865. /* fixed_bit_masks */
  3866. 0ULL,
  3867. 0xfffff80000000000ULL,
  3868. 0ULL,
  3869. 0ULL,
  3870. 0ULL
  3871. },
  3872. {
  3873. /* fixed_bit_values */
  3874. -1ULL,
  3875. 0x440b700000000000ULL,
  3876. -1ULL,
  3877. -1ULL,
  3878. -1ULL
  3879. }
  3880. },
  3881. { "lw_na", TILE_OPC_LW_NA, 0x2 /* pipes */, 2 /* num_operands */,
  3882. TREG_ZERO, /* implicitly_written_register */
  3883. 1, /* can_bundle */
  3884. {
  3885. /* operands */
  3886. { 0, },
  3887. { 9, 10 },
  3888. { 0, },
  3889. { 0, },
  3890. { 0, }
  3891. },
  3892. {
  3893. /* fixed_bit_masks */
  3894. 0ULL,
  3895. 0xfffff80000000000ULL,
  3896. 0ULL,
  3897. 0ULL,
  3898. 0ULL
  3899. },
  3900. {
  3901. /* fixed_bit_values */
  3902. -1ULL,
  3903. 0x400bc00000000000ULL,
  3904. -1ULL,
  3905. -1ULL,
  3906. -1ULL
  3907. }
  3908. },
  3909. { "lw_na.sn", TILE_OPC_LW_NA_SN, 0x2 /* pipes */, 2 /* num_operands */,
  3910. TREG_SN, /* implicitly_written_register */
  3911. 1, /* can_bundle */
  3912. {
  3913. /* operands */
  3914. { 0, },
  3915. { 9, 10 },
  3916. { 0, },
  3917. { 0, },
  3918. { 0, }
  3919. },
  3920. {
  3921. /* fixed_bit_masks */
  3922. 0ULL,
  3923. 0xfffff80000000000ULL,
  3924. 0ULL,
  3925. 0ULL,
  3926. 0ULL
  3927. },
  3928. {
  3929. /* fixed_bit_values */
  3930. -1ULL,
  3931. 0x440bc00000000000ULL,
  3932. -1ULL,
  3933. -1ULL,
  3934. -1ULL
  3935. }
  3936. },
  3937. { "lwadd", TILE_OPC_LWADD, 0x2 /* pipes */, 3 /* num_operands */,
  3938. TREG_ZERO, /* implicitly_written_register */
  3939. 1, /* can_bundle */
  3940. {
  3941. /* operands */
  3942. { 0, },
  3943. { 9, 24, 1 },
  3944. { 0, },
  3945. { 0, },
  3946. { 0, }
  3947. },
  3948. {
  3949. /* fixed_bit_masks */
  3950. 0ULL,
  3951. 0xfff8000000000000ULL,
  3952. 0ULL,
  3953. 0ULL,
  3954. 0ULL
  3955. },
  3956. {
  3957. /* fixed_bit_values */
  3958. -1ULL,
  3959. 0x30d0000000000000ULL,
  3960. -1ULL,
  3961. -1ULL,
  3962. -1ULL
  3963. }
  3964. },
  3965. { "lwadd.sn", TILE_OPC_LWADD_SN, 0x2 /* pipes */, 3 /* num_operands */,
  3966. TREG_SN, /* implicitly_written_register */
  3967. 1, /* can_bundle */
  3968. {
  3969. /* operands */
  3970. { 0, },
  3971. { 9, 24, 1 },
  3972. { 0, },
  3973. { 0, },
  3974. { 0, }
  3975. },
  3976. {
  3977. /* fixed_bit_masks */
  3978. 0ULL,
  3979. 0xfff8000000000000ULL,
  3980. 0ULL,
  3981. 0ULL,
  3982. 0ULL
  3983. },
  3984. {
  3985. /* fixed_bit_values */
  3986. -1ULL,
  3987. 0x34d0000000000000ULL,
  3988. -1ULL,
  3989. -1ULL,
  3990. -1ULL
  3991. }
  3992. },
  3993. { "lwadd_na", TILE_OPC_LWADD_NA, 0x2 /* pipes */, 3 /* num_operands */,
  3994. TREG_ZERO, /* implicitly_written_register */
  3995. 1, /* can_bundle */
  3996. {
  3997. /* operands */
  3998. { 0, },
  3999. { 9, 24, 1 },
  4000. { 0, },
  4001. { 0, },
  4002. { 0, }
  4003. },
  4004. {
  4005. /* fixed_bit_masks */
  4006. 0ULL,
  4007. 0xfff8000000000000ULL,
  4008. 0ULL,
  4009. 0ULL,
  4010. 0ULL
  4011. },
  4012. {
  4013. /* fixed_bit_values */
  4014. -1ULL,
  4015. 0x30d8000000000000ULL,
  4016. -1ULL,
  4017. -1ULL,
  4018. -1ULL
  4019. }
  4020. },
  4021. { "lwadd_na.sn", TILE_OPC_LWADD_NA_SN, 0x2 /* pipes */, 3 /* num_operands */,
  4022. TREG_SN, /* implicitly_written_register */
  4023. 1, /* can_bundle */
  4024. {
  4025. /* operands */
  4026. { 0, },
  4027. { 9, 24, 1 },
  4028. { 0, },
  4029. { 0, },
  4030. { 0, }
  4031. },
  4032. {
  4033. /* fixed_bit_masks */
  4034. 0ULL,
  4035. 0xfff8000000000000ULL,
  4036. 0ULL,
  4037. 0ULL,
  4038. 0ULL
  4039. },
  4040. {
  4041. /* fixed_bit_values */
  4042. -1ULL,
  4043. 0x34d8000000000000ULL,
  4044. -1ULL,
  4045. -1ULL,
  4046. -1ULL
  4047. }
  4048. },
  4049. { "maxb_u", TILE_OPC_MAXB_U, 0x3 /* pipes */, 3 /* num_operands */,
  4050. TREG_ZERO, /* implicitly_written_register */
  4051. 1, /* can_bundle */
  4052. {
  4053. /* operands */
  4054. { 7, 8, 16 },
  4055. { 9, 10, 17 },
  4056. { 0, },
  4057. { 0, },
  4058. { 0, }
  4059. },
  4060. {
  4061. /* fixed_bit_masks */
  4062. 0x800000007ffc0000ULL,
  4063. 0xfffe000000000000ULL,
  4064. 0ULL,
  4065. 0ULL,
  4066. 0ULL
  4067. },
  4068. {
  4069. /* fixed_bit_values */
  4070. 0x00000000003c0000ULL,
  4071. 0x081c000000000000ULL,
  4072. -1ULL,
  4073. -1ULL,
  4074. -1ULL
  4075. }
  4076. },
  4077. { "maxb_u.sn", TILE_OPC_MAXB_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4078. TREG_SN, /* implicitly_written_register */
  4079. 1, /* can_bundle */
  4080. {
  4081. /* operands */
  4082. { 7, 8, 16 },
  4083. { 9, 10, 17 },
  4084. { 0, },
  4085. { 0, },
  4086. { 0, }
  4087. },
  4088. {
  4089. /* fixed_bit_masks */
  4090. 0x800000007ffc0000ULL,
  4091. 0xfffe000000000000ULL,
  4092. 0ULL,
  4093. 0ULL,
  4094. 0ULL
  4095. },
  4096. {
  4097. /* fixed_bit_values */
  4098. 0x00000000083c0000ULL,
  4099. 0x0c1c000000000000ULL,
  4100. -1ULL,
  4101. -1ULL,
  4102. -1ULL
  4103. }
  4104. },
  4105. { "maxh", TILE_OPC_MAXH, 0x3 /* pipes */, 3 /* num_operands */,
  4106. TREG_ZERO, /* implicitly_written_register */
  4107. 1, /* can_bundle */
  4108. {
  4109. /* operands */
  4110. { 7, 8, 16 },
  4111. { 9, 10, 17 },
  4112. { 0, },
  4113. { 0, },
  4114. { 0, }
  4115. },
  4116. {
  4117. /* fixed_bit_masks */
  4118. 0x800000007ffc0000ULL,
  4119. 0xfffe000000000000ULL,
  4120. 0ULL,
  4121. 0ULL,
  4122. 0ULL
  4123. },
  4124. {
  4125. /* fixed_bit_values */
  4126. 0x0000000000400000ULL,
  4127. 0x081e000000000000ULL,
  4128. -1ULL,
  4129. -1ULL,
  4130. -1ULL
  4131. }
  4132. },
  4133. { "maxh.sn", TILE_OPC_MAXH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4134. TREG_SN, /* implicitly_written_register */
  4135. 1, /* can_bundle */
  4136. {
  4137. /* operands */
  4138. { 7, 8, 16 },
  4139. { 9, 10, 17 },
  4140. { 0, },
  4141. { 0, },
  4142. { 0, }
  4143. },
  4144. {
  4145. /* fixed_bit_masks */
  4146. 0x800000007ffc0000ULL,
  4147. 0xfffe000000000000ULL,
  4148. 0ULL,
  4149. 0ULL,
  4150. 0ULL
  4151. },
  4152. {
  4153. /* fixed_bit_values */
  4154. 0x0000000008400000ULL,
  4155. 0x0c1e000000000000ULL,
  4156. -1ULL,
  4157. -1ULL,
  4158. -1ULL
  4159. }
  4160. },
  4161. { "maxib_u", TILE_OPC_MAXIB_U, 0x3 /* pipes */, 3 /* num_operands */,
  4162. TREG_ZERO, /* implicitly_written_register */
  4163. 1, /* can_bundle */
  4164. {
  4165. /* operands */
  4166. { 7, 8, 0 },
  4167. { 9, 10, 1 },
  4168. { 0, },
  4169. { 0, },
  4170. { 0, }
  4171. },
  4172. {
  4173. /* fixed_bit_masks */
  4174. 0x800000007ff00000ULL,
  4175. 0xfff8000000000000ULL,
  4176. 0ULL,
  4177. 0ULL,
  4178. 0ULL
  4179. },
  4180. {
  4181. /* fixed_bit_values */
  4182. 0x0000000040400000ULL,
  4183. 0x3028000000000000ULL,
  4184. -1ULL,
  4185. -1ULL,
  4186. -1ULL
  4187. }
  4188. },
  4189. { "maxib_u.sn", TILE_OPC_MAXIB_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4190. TREG_SN, /* implicitly_written_register */
  4191. 1, /* can_bundle */
  4192. {
  4193. /* operands */
  4194. { 7, 8, 0 },
  4195. { 9, 10, 1 },
  4196. { 0, },
  4197. { 0, },
  4198. { 0, }
  4199. },
  4200. {
  4201. /* fixed_bit_masks */
  4202. 0x800000007ff00000ULL,
  4203. 0xfff8000000000000ULL,
  4204. 0ULL,
  4205. 0ULL,
  4206. 0ULL
  4207. },
  4208. {
  4209. /* fixed_bit_values */
  4210. 0x0000000048400000ULL,
  4211. 0x3428000000000000ULL,
  4212. -1ULL,
  4213. -1ULL,
  4214. -1ULL
  4215. }
  4216. },
  4217. { "maxih", TILE_OPC_MAXIH, 0x3 /* pipes */, 3 /* num_operands */,
  4218. TREG_ZERO, /* implicitly_written_register */
  4219. 1, /* can_bundle */
  4220. {
  4221. /* operands */
  4222. { 7, 8, 0 },
  4223. { 9, 10, 1 },
  4224. { 0, },
  4225. { 0, },
  4226. { 0, }
  4227. },
  4228. {
  4229. /* fixed_bit_masks */
  4230. 0x800000007ff00000ULL,
  4231. 0xfff8000000000000ULL,
  4232. 0ULL,
  4233. 0ULL,
  4234. 0ULL
  4235. },
  4236. {
  4237. /* fixed_bit_values */
  4238. 0x0000000040500000ULL,
  4239. 0x3030000000000000ULL,
  4240. -1ULL,
  4241. -1ULL,
  4242. -1ULL
  4243. }
  4244. },
  4245. { "maxih.sn", TILE_OPC_MAXIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4246. TREG_SN, /* implicitly_written_register */
  4247. 1, /* can_bundle */
  4248. {
  4249. /* operands */
  4250. { 7, 8, 0 },
  4251. { 9, 10, 1 },
  4252. { 0, },
  4253. { 0, },
  4254. { 0, }
  4255. },
  4256. {
  4257. /* fixed_bit_masks */
  4258. 0x800000007ff00000ULL,
  4259. 0xfff8000000000000ULL,
  4260. 0ULL,
  4261. 0ULL,
  4262. 0ULL
  4263. },
  4264. {
  4265. /* fixed_bit_values */
  4266. 0x0000000048500000ULL,
  4267. 0x3430000000000000ULL,
  4268. -1ULL,
  4269. -1ULL,
  4270. -1ULL
  4271. }
  4272. },
  4273. { "mf", TILE_OPC_MF, 0x2 /* pipes */, 0 /* num_operands */,
  4274. TREG_ZERO, /* implicitly_written_register */
  4275. 1, /* can_bundle */
  4276. {
  4277. /* operands */
  4278. { 0, },
  4279. { },
  4280. { 0, },
  4281. { 0, },
  4282. { 0, }
  4283. },
  4284. {
  4285. /* fixed_bit_masks */
  4286. 0ULL,
  4287. 0xfbfff80000000000ULL,
  4288. 0ULL,
  4289. 0ULL,
  4290. 0ULL
  4291. },
  4292. {
  4293. /* fixed_bit_values */
  4294. -1ULL,
  4295. 0x400b780000000000ULL,
  4296. -1ULL,
  4297. -1ULL,
  4298. -1ULL
  4299. }
  4300. },
  4301. { "mfspr", TILE_OPC_MFSPR, 0x2 /* pipes */, 2 /* num_operands */,
  4302. TREG_ZERO, /* implicitly_written_register */
  4303. 1, /* can_bundle */
  4304. {
  4305. /* operands */
  4306. { 0, },
  4307. { 9, 25 },
  4308. { 0, },
  4309. { 0, },
  4310. { 0, }
  4311. },
  4312. {
  4313. /* fixed_bit_masks */
  4314. 0ULL,
  4315. 0xfbf8000000000000ULL,
  4316. 0ULL,
  4317. 0ULL,
  4318. 0ULL
  4319. },
  4320. {
  4321. /* fixed_bit_values */
  4322. -1ULL,
  4323. 0x3038000000000000ULL,
  4324. -1ULL,
  4325. -1ULL,
  4326. -1ULL
  4327. }
  4328. },
  4329. { "minb_u", TILE_OPC_MINB_U, 0x3 /* pipes */, 3 /* num_operands */,
  4330. TREG_ZERO, /* implicitly_written_register */
  4331. 1, /* can_bundle */
  4332. {
  4333. /* operands */
  4334. { 7, 8, 16 },
  4335. { 9, 10, 17 },
  4336. { 0, },
  4337. { 0, },
  4338. { 0, }
  4339. },
  4340. {
  4341. /* fixed_bit_masks */
  4342. 0x800000007ffc0000ULL,
  4343. 0xfffe000000000000ULL,
  4344. 0ULL,
  4345. 0ULL,
  4346. 0ULL
  4347. },
  4348. {
  4349. /* fixed_bit_values */
  4350. 0x0000000000440000ULL,
  4351. 0x0820000000000000ULL,
  4352. -1ULL,
  4353. -1ULL,
  4354. -1ULL
  4355. }
  4356. },
  4357. { "minb_u.sn", TILE_OPC_MINB_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4358. TREG_SN, /* implicitly_written_register */
  4359. 1, /* can_bundle */
  4360. {
  4361. /* operands */
  4362. { 7, 8, 16 },
  4363. { 9, 10, 17 },
  4364. { 0, },
  4365. { 0, },
  4366. { 0, }
  4367. },
  4368. {
  4369. /* fixed_bit_masks */
  4370. 0x800000007ffc0000ULL,
  4371. 0xfffe000000000000ULL,
  4372. 0ULL,
  4373. 0ULL,
  4374. 0ULL
  4375. },
  4376. {
  4377. /* fixed_bit_values */
  4378. 0x0000000008440000ULL,
  4379. 0x0c20000000000000ULL,
  4380. -1ULL,
  4381. -1ULL,
  4382. -1ULL
  4383. }
  4384. },
  4385. { "minh", TILE_OPC_MINH, 0x3 /* pipes */, 3 /* num_operands */,
  4386. TREG_ZERO, /* implicitly_written_register */
  4387. 1, /* can_bundle */
  4388. {
  4389. /* operands */
  4390. { 7, 8, 16 },
  4391. { 9, 10, 17 },
  4392. { 0, },
  4393. { 0, },
  4394. { 0, }
  4395. },
  4396. {
  4397. /* fixed_bit_masks */
  4398. 0x800000007ffc0000ULL,
  4399. 0xfffe000000000000ULL,
  4400. 0ULL,
  4401. 0ULL,
  4402. 0ULL
  4403. },
  4404. {
  4405. /* fixed_bit_values */
  4406. 0x0000000000480000ULL,
  4407. 0x0822000000000000ULL,
  4408. -1ULL,
  4409. -1ULL,
  4410. -1ULL
  4411. }
  4412. },
  4413. { "minh.sn", TILE_OPC_MINH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4414. TREG_SN, /* implicitly_written_register */
  4415. 1, /* can_bundle */
  4416. {
  4417. /* operands */
  4418. { 7, 8, 16 },
  4419. { 9, 10, 17 },
  4420. { 0, },
  4421. { 0, },
  4422. { 0, }
  4423. },
  4424. {
  4425. /* fixed_bit_masks */
  4426. 0x800000007ffc0000ULL,
  4427. 0xfffe000000000000ULL,
  4428. 0ULL,
  4429. 0ULL,
  4430. 0ULL
  4431. },
  4432. {
  4433. /* fixed_bit_values */
  4434. 0x0000000008480000ULL,
  4435. 0x0c22000000000000ULL,
  4436. -1ULL,
  4437. -1ULL,
  4438. -1ULL
  4439. }
  4440. },
  4441. { "minib_u", TILE_OPC_MINIB_U, 0x3 /* pipes */, 3 /* num_operands */,
  4442. TREG_ZERO, /* implicitly_written_register */
  4443. 1, /* can_bundle */
  4444. {
  4445. /* operands */
  4446. { 7, 8, 0 },
  4447. { 9, 10, 1 },
  4448. { 0, },
  4449. { 0, },
  4450. { 0, }
  4451. },
  4452. {
  4453. /* fixed_bit_masks */
  4454. 0x800000007ff00000ULL,
  4455. 0xfff8000000000000ULL,
  4456. 0ULL,
  4457. 0ULL,
  4458. 0ULL
  4459. },
  4460. {
  4461. /* fixed_bit_values */
  4462. 0x0000000040600000ULL,
  4463. 0x3040000000000000ULL,
  4464. -1ULL,
  4465. -1ULL,
  4466. -1ULL
  4467. }
  4468. },
  4469. { "minib_u.sn", TILE_OPC_MINIB_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4470. TREG_SN, /* implicitly_written_register */
  4471. 1, /* can_bundle */
  4472. {
  4473. /* operands */
  4474. { 7, 8, 0 },
  4475. { 9, 10, 1 },
  4476. { 0, },
  4477. { 0, },
  4478. { 0, }
  4479. },
  4480. {
  4481. /* fixed_bit_masks */
  4482. 0x800000007ff00000ULL,
  4483. 0xfff8000000000000ULL,
  4484. 0ULL,
  4485. 0ULL,
  4486. 0ULL
  4487. },
  4488. {
  4489. /* fixed_bit_values */
  4490. 0x0000000048600000ULL,
  4491. 0x3440000000000000ULL,
  4492. -1ULL,
  4493. -1ULL,
  4494. -1ULL
  4495. }
  4496. },
  4497. { "minih", TILE_OPC_MINIH, 0x3 /* pipes */, 3 /* num_operands */,
  4498. TREG_ZERO, /* implicitly_written_register */
  4499. 1, /* can_bundle */
  4500. {
  4501. /* operands */
  4502. { 7, 8, 0 },
  4503. { 9, 10, 1 },
  4504. { 0, },
  4505. { 0, },
  4506. { 0, }
  4507. },
  4508. {
  4509. /* fixed_bit_masks */
  4510. 0x800000007ff00000ULL,
  4511. 0xfff8000000000000ULL,
  4512. 0ULL,
  4513. 0ULL,
  4514. 0ULL
  4515. },
  4516. {
  4517. /* fixed_bit_values */
  4518. 0x0000000040700000ULL,
  4519. 0x3048000000000000ULL,
  4520. -1ULL,
  4521. -1ULL,
  4522. -1ULL
  4523. }
  4524. },
  4525. { "minih.sn", TILE_OPC_MINIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4526. TREG_SN, /* implicitly_written_register */
  4527. 1, /* can_bundle */
  4528. {
  4529. /* operands */
  4530. { 7, 8, 0 },
  4531. { 9, 10, 1 },
  4532. { 0, },
  4533. { 0, },
  4534. { 0, }
  4535. },
  4536. {
  4537. /* fixed_bit_masks */
  4538. 0x800000007ff00000ULL,
  4539. 0xfff8000000000000ULL,
  4540. 0ULL,
  4541. 0ULL,
  4542. 0ULL
  4543. },
  4544. {
  4545. /* fixed_bit_values */
  4546. 0x0000000048700000ULL,
  4547. 0x3448000000000000ULL,
  4548. -1ULL,
  4549. -1ULL,
  4550. -1ULL
  4551. }
  4552. },
  4553. { "mm", TILE_OPC_MM, 0x3 /* pipes */, 5 /* num_operands */,
  4554. TREG_ZERO, /* implicitly_written_register */
  4555. 1, /* can_bundle */
  4556. {
  4557. /* operands */
  4558. { 7, 8, 16, 26, 27 },
  4559. { 9, 10, 17, 28, 29 },
  4560. { 0, },
  4561. { 0, },
  4562. { 0, }
  4563. },
  4564. {
  4565. /* fixed_bit_masks */
  4566. 0x8000000070000000ULL,
  4567. 0xf800000000000000ULL,
  4568. 0ULL,
  4569. 0ULL,
  4570. 0ULL
  4571. },
  4572. {
  4573. /* fixed_bit_values */
  4574. 0x0000000060000000ULL,
  4575. 0x3800000000000000ULL,
  4576. -1ULL,
  4577. -1ULL,
  4578. -1ULL
  4579. }
  4580. },
  4581. { "mnz", TILE_OPC_MNZ, 0xf /* pipes */, 3 /* num_operands */,
  4582. TREG_ZERO, /* implicitly_written_register */
  4583. 1, /* can_bundle */
  4584. {
  4585. /* operands */
  4586. { 7, 8, 16 },
  4587. { 9, 10, 17 },
  4588. { 11, 12, 18 },
  4589. { 13, 14, 19 },
  4590. { 0, }
  4591. },
  4592. {
  4593. /* fixed_bit_masks */
  4594. 0x800000007ffc0000ULL,
  4595. 0xfffe000000000000ULL,
  4596. 0x80000000780c0000ULL,
  4597. 0xf806000000000000ULL,
  4598. 0ULL
  4599. },
  4600. {
  4601. /* fixed_bit_values */
  4602. 0x0000000000540000ULL,
  4603. 0x0828000000000000ULL,
  4604. 0x8000000010000000ULL,
  4605. 0x9002000000000000ULL,
  4606. -1ULL
  4607. }
  4608. },
  4609. { "mnz.sn", TILE_OPC_MNZ_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4610. TREG_SN, /* implicitly_written_register */
  4611. 1, /* can_bundle */
  4612. {
  4613. /* operands */
  4614. { 7, 8, 16 },
  4615. { 9, 10, 17 },
  4616. { 0, },
  4617. { 0, },
  4618. { 0, }
  4619. },
  4620. {
  4621. /* fixed_bit_masks */
  4622. 0x800000007ffc0000ULL,
  4623. 0xfffe000000000000ULL,
  4624. 0ULL,
  4625. 0ULL,
  4626. 0ULL
  4627. },
  4628. {
  4629. /* fixed_bit_values */
  4630. 0x0000000008540000ULL,
  4631. 0x0c28000000000000ULL,
  4632. -1ULL,
  4633. -1ULL,
  4634. -1ULL
  4635. }
  4636. },
  4637. { "mnzb", TILE_OPC_MNZB, 0x3 /* pipes */, 3 /* num_operands */,
  4638. TREG_ZERO, /* implicitly_written_register */
  4639. 1, /* can_bundle */
  4640. {
  4641. /* operands */
  4642. { 7, 8, 16 },
  4643. { 9, 10, 17 },
  4644. { 0, },
  4645. { 0, },
  4646. { 0, }
  4647. },
  4648. {
  4649. /* fixed_bit_masks */
  4650. 0x800000007ffc0000ULL,
  4651. 0xfffe000000000000ULL,
  4652. 0ULL,
  4653. 0ULL,
  4654. 0ULL
  4655. },
  4656. {
  4657. /* fixed_bit_values */
  4658. 0x00000000004c0000ULL,
  4659. 0x0824000000000000ULL,
  4660. -1ULL,
  4661. -1ULL,
  4662. -1ULL
  4663. }
  4664. },
  4665. { "mnzb.sn", TILE_OPC_MNZB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4666. TREG_SN, /* implicitly_written_register */
  4667. 1, /* can_bundle */
  4668. {
  4669. /* operands */
  4670. { 7, 8, 16 },
  4671. { 9, 10, 17 },
  4672. { 0, },
  4673. { 0, },
  4674. { 0, }
  4675. },
  4676. {
  4677. /* fixed_bit_masks */
  4678. 0x800000007ffc0000ULL,
  4679. 0xfffe000000000000ULL,
  4680. 0ULL,
  4681. 0ULL,
  4682. 0ULL
  4683. },
  4684. {
  4685. /* fixed_bit_values */
  4686. 0x00000000084c0000ULL,
  4687. 0x0c24000000000000ULL,
  4688. -1ULL,
  4689. -1ULL,
  4690. -1ULL
  4691. }
  4692. },
  4693. { "mnzh", TILE_OPC_MNZH, 0x3 /* pipes */, 3 /* num_operands */,
  4694. TREG_ZERO, /* implicitly_written_register */
  4695. 1, /* can_bundle */
  4696. {
  4697. /* operands */
  4698. { 7, 8, 16 },
  4699. { 9, 10, 17 },
  4700. { 0, },
  4701. { 0, },
  4702. { 0, }
  4703. },
  4704. {
  4705. /* fixed_bit_masks */
  4706. 0x800000007ffc0000ULL,
  4707. 0xfffe000000000000ULL,
  4708. 0ULL,
  4709. 0ULL,
  4710. 0ULL
  4711. },
  4712. {
  4713. /* fixed_bit_values */
  4714. 0x0000000000500000ULL,
  4715. 0x0826000000000000ULL,
  4716. -1ULL,
  4717. -1ULL,
  4718. -1ULL
  4719. }
  4720. },
  4721. { "mnzh.sn", TILE_OPC_MNZH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  4722. TREG_SN, /* implicitly_written_register */
  4723. 1, /* can_bundle */
  4724. {
  4725. /* operands */
  4726. { 7, 8, 16 },
  4727. { 9, 10, 17 },
  4728. { 0, },
  4729. { 0, },
  4730. { 0, }
  4731. },
  4732. {
  4733. /* fixed_bit_masks */
  4734. 0x800000007ffc0000ULL,
  4735. 0xfffe000000000000ULL,
  4736. 0ULL,
  4737. 0ULL,
  4738. 0ULL
  4739. },
  4740. {
  4741. /* fixed_bit_values */
  4742. 0x0000000008500000ULL,
  4743. 0x0c26000000000000ULL,
  4744. -1ULL,
  4745. -1ULL,
  4746. -1ULL
  4747. }
  4748. },
  4749. { "mtspr", TILE_OPC_MTSPR, 0x2 /* pipes */, 2 /* num_operands */,
  4750. TREG_ZERO, /* implicitly_written_register */
  4751. 1, /* can_bundle */
  4752. {
  4753. /* operands */
  4754. { 0, },
  4755. { 30, 10 },
  4756. { 0, },
  4757. { 0, },
  4758. { 0, }
  4759. },
  4760. {
  4761. /* fixed_bit_masks */
  4762. 0ULL,
  4763. 0xfbf8000000000000ULL,
  4764. 0ULL,
  4765. 0ULL,
  4766. 0ULL
  4767. },
  4768. {
  4769. /* fixed_bit_values */
  4770. -1ULL,
  4771. 0x3050000000000000ULL,
  4772. -1ULL,
  4773. -1ULL,
  4774. -1ULL
  4775. }
  4776. },
  4777. { "mulhh_ss", TILE_OPC_MULHH_SS, 0x5 /* pipes */, 3 /* num_operands */,
  4778. TREG_ZERO, /* implicitly_written_register */
  4779. 1, /* can_bundle */
  4780. {
  4781. /* operands */
  4782. { 7, 8, 16 },
  4783. { 0, },
  4784. { 11, 12, 18 },
  4785. { 0, },
  4786. { 0, }
  4787. },
  4788. {
  4789. /* fixed_bit_masks */
  4790. 0x800000007ffc0000ULL,
  4791. 0ULL,
  4792. 0x80000000780c0000ULL,
  4793. 0ULL,
  4794. 0ULL
  4795. },
  4796. {
  4797. /* fixed_bit_values */
  4798. 0x0000000000680000ULL,
  4799. -1ULL,
  4800. 0x8000000038000000ULL,
  4801. -1ULL,
  4802. -1ULL
  4803. }
  4804. },
  4805. { "mulhh_ss.sn", TILE_OPC_MULHH_SS_SN, 0x1 /* pipes */, 3 /* num_operands */,
  4806. TREG_SN, /* implicitly_written_register */
  4807. 1, /* can_bundle */
  4808. {
  4809. /* operands */
  4810. { 7, 8, 16 },
  4811. { 0, },
  4812. { 0, },
  4813. { 0, },
  4814. { 0, }
  4815. },
  4816. {
  4817. /* fixed_bit_masks */
  4818. 0x800000007ffc0000ULL,
  4819. 0ULL,
  4820. 0ULL,
  4821. 0ULL,
  4822. 0ULL
  4823. },
  4824. {
  4825. /* fixed_bit_values */
  4826. 0x0000000008680000ULL,
  4827. -1ULL,
  4828. -1ULL,
  4829. -1ULL,
  4830. -1ULL
  4831. }
  4832. },
  4833. { "mulhh_su", TILE_OPC_MULHH_SU, 0x1 /* pipes */, 3 /* num_operands */,
  4834. TREG_ZERO, /* implicitly_written_register */
  4835. 1, /* can_bundle */
  4836. {
  4837. /* operands */
  4838. { 7, 8, 16 },
  4839. { 0, },
  4840. { 0, },
  4841. { 0, },
  4842. { 0, }
  4843. },
  4844. {
  4845. /* fixed_bit_masks */
  4846. 0x800000007ffc0000ULL,
  4847. 0ULL,
  4848. 0ULL,
  4849. 0ULL,
  4850. 0ULL
  4851. },
  4852. {
  4853. /* fixed_bit_values */
  4854. 0x00000000006c0000ULL,
  4855. -1ULL,
  4856. -1ULL,
  4857. -1ULL,
  4858. -1ULL
  4859. }
  4860. },
  4861. { "mulhh_su.sn", TILE_OPC_MULHH_SU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  4862. TREG_SN, /* implicitly_written_register */
  4863. 1, /* can_bundle */
  4864. {
  4865. /* operands */
  4866. { 7, 8, 16 },
  4867. { 0, },
  4868. { 0, },
  4869. { 0, },
  4870. { 0, }
  4871. },
  4872. {
  4873. /* fixed_bit_masks */
  4874. 0x800000007ffc0000ULL,
  4875. 0ULL,
  4876. 0ULL,
  4877. 0ULL,
  4878. 0ULL
  4879. },
  4880. {
  4881. /* fixed_bit_values */
  4882. 0x00000000086c0000ULL,
  4883. -1ULL,
  4884. -1ULL,
  4885. -1ULL,
  4886. -1ULL
  4887. }
  4888. },
  4889. { "mulhh_uu", TILE_OPC_MULHH_UU, 0x5 /* pipes */, 3 /* num_operands */,
  4890. TREG_ZERO, /* implicitly_written_register */
  4891. 1, /* can_bundle */
  4892. {
  4893. /* operands */
  4894. { 7, 8, 16 },
  4895. { 0, },
  4896. { 11, 12, 18 },
  4897. { 0, },
  4898. { 0, }
  4899. },
  4900. {
  4901. /* fixed_bit_masks */
  4902. 0x800000007ffc0000ULL,
  4903. 0ULL,
  4904. 0x80000000780c0000ULL,
  4905. 0ULL,
  4906. 0ULL
  4907. },
  4908. {
  4909. /* fixed_bit_values */
  4910. 0x0000000000700000ULL,
  4911. -1ULL,
  4912. 0x8000000038040000ULL,
  4913. -1ULL,
  4914. -1ULL
  4915. }
  4916. },
  4917. { "mulhh_uu.sn", TILE_OPC_MULHH_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  4918. TREG_SN, /* implicitly_written_register */
  4919. 1, /* can_bundle */
  4920. {
  4921. /* operands */
  4922. { 7, 8, 16 },
  4923. { 0, },
  4924. { 0, },
  4925. { 0, },
  4926. { 0, }
  4927. },
  4928. {
  4929. /* fixed_bit_masks */
  4930. 0x800000007ffc0000ULL,
  4931. 0ULL,
  4932. 0ULL,
  4933. 0ULL,
  4934. 0ULL
  4935. },
  4936. {
  4937. /* fixed_bit_values */
  4938. 0x0000000008700000ULL,
  4939. -1ULL,
  4940. -1ULL,
  4941. -1ULL,
  4942. -1ULL
  4943. }
  4944. },
  4945. { "mulhha_ss", TILE_OPC_MULHHA_SS, 0x5 /* pipes */, 3 /* num_operands */,
  4946. TREG_ZERO, /* implicitly_written_register */
  4947. 1, /* can_bundle */
  4948. {
  4949. /* operands */
  4950. { 21, 8, 16 },
  4951. { 0, },
  4952. { 31, 12, 18 },
  4953. { 0, },
  4954. { 0, }
  4955. },
  4956. {
  4957. /* fixed_bit_masks */
  4958. 0x800000007ffc0000ULL,
  4959. 0ULL,
  4960. 0x80000000780c0000ULL,
  4961. 0ULL,
  4962. 0ULL
  4963. },
  4964. {
  4965. /* fixed_bit_values */
  4966. 0x0000000000580000ULL,
  4967. -1ULL,
  4968. 0x8000000040000000ULL,
  4969. -1ULL,
  4970. -1ULL
  4971. }
  4972. },
  4973. { "mulhha_ss.sn", TILE_OPC_MULHHA_SS_SN, 0x1 /* pipes */, 3 /* num_operands */,
  4974. TREG_SN, /* implicitly_written_register */
  4975. 1, /* can_bundle */
  4976. {
  4977. /* operands */
  4978. { 21, 8, 16 },
  4979. { 0, },
  4980. { 0, },
  4981. { 0, },
  4982. { 0, }
  4983. },
  4984. {
  4985. /* fixed_bit_masks */
  4986. 0x800000007ffc0000ULL,
  4987. 0ULL,
  4988. 0ULL,
  4989. 0ULL,
  4990. 0ULL
  4991. },
  4992. {
  4993. /* fixed_bit_values */
  4994. 0x0000000008580000ULL,
  4995. -1ULL,
  4996. -1ULL,
  4997. -1ULL,
  4998. -1ULL
  4999. }
  5000. },
  5001. { "mulhha_su", TILE_OPC_MULHHA_SU, 0x1 /* pipes */, 3 /* num_operands */,
  5002. TREG_ZERO, /* implicitly_written_register */
  5003. 1, /* can_bundle */
  5004. {
  5005. /* operands */
  5006. { 21, 8, 16 },
  5007. { 0, },
  5008. { 0, },
  5009. { 0, },
  5010. { 0, }
  5011. },
  5012. {
  5013. /* fixed_bit_masks */
  5014. 0x800000007ffc0000ULL,
  5015. 0ULL,
  5016. 0ULL,
  5017. 0ULL,
  5018. 0ULL
  5019. },
  5020. {
  5021. /* fixed_bit_values */
  5022. 0x00000000005c0000ULL,
  5023. -1ULL,
  5024. -1ULL,
  5025. -1ULL,
  5026. -1ULL
  5027. }
  5028. },
  5029. { "mulhha_su.sn", TILE_OPC_MULHHA_SU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5030. TREG_SN, /* implicitly_written_register */
  5031. 1, /* can_bundle */
  5032. {
  5033. /* operands */
  5034. { 21, 8, 16 },
  5035. { 0, },
  5036. { 0, },
  5037. { 0, },
  5038. { 0, }
  5039. },
  5040. {
  5041. /* fixed_bit_masks */
  5042. 0x800000007ffc0000ULL,
  5043. 0ULL,
  5044. 0ULL,
  5045. 0ULL,
  5046. 0ULL
  5047. },
  5048. {
  5049. /* fixed_bit_values */
  5050. 0x00000000085c0000ULL,
  5051. -1ULL,
  5052. -1ULL,
  5053. -1ULL,
  5054. -1ULL
  5055. }
  5056. },
  5057. { "mulhha_uu", TILE_OPC_MULHHA_UU, 0x5 /* pipes */, 3 /* num_operands */,
  5058. TREG_ZERO, /* implicitly_written_register */
  5059. 1, /* can_bundle */
  5060. {
  5061. /* operands */
  5062. { 21, 8, 16 },
  5063. { 0, },
  5064. { 31, 12, 18 },
  5065. { 0, },
  5066. { 0, }
  5067. },
  5068. {
  5069. /* fixed_bit_masks */
  5070. 0x800000007ffc0000ULL,
  5071. 0ULL,
  5072. 0x80000000780c0000ULL,
  5073. 0ULL,
  5074. 0ULL
  5075. },
  5076. {
  5077. /* fixed_bit_values */
  5078. 0x0000000000600000ULL,
  5079. -1ULL,
  5080. 0x8000000040040000ULL,
  5081. -1ULL,
  5082. -1ULL
  5083. }
  5084. },
  5085. { "mulhha_uu.sn", TILE_OPC_MULHHA_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5086. TREG_SN, /* implicitly_written_register */
  5087. 1, /* can_bundle */
  5088. {
  5089. /* operands */
  5090. { 21, 8, 16 },
  5091. { 0, },
  5092. { 0, },
  5093. { 0, },
  5094. { 0, }
  5095. },
  5096. {
  5097. /* fixed_bit_masks */
  5098. 0x800000007ffc0000ULL,
  5099. 0ULL,
  5100. 0ULL,
  5101. 0ULL,
  5102. 0ULL
  5103. },
  5104. {
  5105. /* fixed_bit_values */
  5106. 0x0000000008600000ULL,
  5107. -1ULL,
  5108. -1ULL,
  5109. -1ULL,
  5110. -1ULL
  5111. }
  5112. },
  5113. { "mulhhsa_uu", TILE_OPC_MULHHSA_UU, 0x1 /* pipes */, 3 /* num_operands */,
  5114. TREG_ZERO, /* implicitly_written_register */
  5115. 1, /* can_bundle */
  5116. {
  5117. /* operands */
  5118. { 21, 8, 16 },
  5119. { 0, },
  5120. { 0, },
  5121. { 0, },
  5122. { 0, }
  5123. },
  5124. {
  5125. /* fixed_bit_masks */
  5126. 0x800000007ffc0000ULL,
  5127. 0ULL,
  5128. 0ULL,
  5129. 0ULL,
  5130. 0ULL
  5131. },
  5132. {
  5133. /* fixed_bit_values */
  5134. 0x0000000000640000ULL,
  5135. -1ULL,
  5136. -1ULL,
  5137. -1ULL,
  5138. -1ULL
  5139. }
  5140. },
  5141. { "mulhhsa_uu.sn", TILE_OPC_MULHHSA_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5142. TREG_SN, /* implicitly_written_register */
  5143. 1, /* can_bundle */
  5144. {
  5145. /* operands */
  5146. { 21, 8, 16 },
  5147. { 0, },
  5148. { 0, },
  5149. { 0, },
  5150. { 0, }
  5151. },
  5152. {
  5153. /* fixed_bit_masks */
  5154. 0x800000007ffc0000ULL,
  5155. 0ULL,
  5156. 0ULL,
  5157. 0ULL,
  5158. 0ULL
  5159. },
  5160. {
  5161. /* fixed_bit_values */
  5162. 0x0000000008640000ULL,
  5163. -1ULL,
  5164. -1ULL,
  5165. -1ULL,
  5166. -1ULL
  5167. }
  5168. },
  5169. { "mulhl_ss", TILE_OPC_MULHL_SS, 0x1 /* pipes */, 3 /* num_operands */,
  5170. TREG_ZERO, /* implicitly_written_register */
  5171. 1, /* can_bundle */
  5172. {
  5173. /* operands */
  5174. { 7, 8, 16 },
  5175. { 0, },
  5176. { 0, },
  5177. { 0, },
  5178. { 0, }
  5179. },
  5180. {
  5181. /* fixed_bit_masks */
  5182. 0x800000007ffc0000ULL,
  5183. 0ULL,
  5184. 0ULL,
  5185. 0ULL,
  5186. 0ULL
  5187. },
  5188. {
  5189. /* fixed_bit_values */
  5190. 0x0000000000880000ULL,
  5191. -1ULL,
  5192. -1ULL,
  5193. -1ULL,
  5194. -1ULL
  5195. }
  5196. },
  5197. { "mulhl_ss.sn", TILE_OPC_MULHL_SS_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5198. TREG_SN, /* implicitly_written_register */
  5199. 1, /* can_bundle */
  5200. {
  5201. /* operands */
  5202. { 7, 8, 16 },
  5203. { 0, },
  5204. { 0, },
  5205. { 0, },
  5206. { 0, }
  5207. },
  5208. {
  5209. /* fixed_bit_masks */
  5210. 0x800000007ffc0000ULL,
  5211. 0ULL,
  5212. 0ULL,
  5213. 0ULL,
  5214. 0ULL
  5215. },
  5216. {
  5217. /* fixed_bit_values */
  5218. 0x0000000008880000ULL,
  5219. -1ULL,
  5220. -1ULL,
  5221. -1ULL,
  5222. -1ULL
  5223. }
  5224. },
  5225. { "mulhl_su", TILE_OPC_MULHL_SU, 0x1 /* pipes */, 3 /* num_operands */,
  5226. TREG_ZERO, /* implicitly_written_register */
  5227. 1, /* can_bundle */
  5228. {
  5229. /* operands */
  5230. { 7, 8, 16 },
  5231. { 0, },
  5232. { 0, },
  5233. { 0, },
  5234. { 0, }
  5235. },
  5236. {
  5237. /* fixed_bit_masks */
  5238. 0x800000007ffc0000ULL,
  5239. 0ULL,
  5240. 0ULL,
  5241. 0ULL,
  5242. 0ULL
  5243. },
  5244. {
  5245. /* fixed_bit_values */
  5246. 0x00000000008c0000ULL,
  5247. -1ULL,
  5248. -1ULL,
  5249. -1ULL,
  5250. -1ULL
  5251. }
  5252. },
  5253. { "mulhl_su.sn", TILE_OPC_MULHL_SU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5254. TREG_SN, /* implicitly_written_register */
  5255. 1, /* can_bundle */
  5256. {
  5257. /* operands */
  5258. { 7, 8, 16 },
  5259. { 0, },
  5260. { 0, },
  5261. { 0, },
  5262. { 0, }
  5263. },
  5264. {
  5265. /* fixed_bit_masks */
  5266. 0x800000007ffc0000ULL,
  5267. 0ULL,
  5268. 0ULL,
  5269. 0ULL,
  5270. 0ULL
  5271. },
  5272. {
  5273. /* fixed_bit_values */
  5274. 0x00000000088c0000ULL,
  5275. -1ULL,
  5276. -1ULL,
  5277. -1ULL,
  5278. -1ULL
  5279. }
  5280. },
  5281. { "mulhl_us", TILE_OPC_MULHL_US, 0x1 /* pipes */, 3 /* num_operands */,
  5282. TREG_ZERO, /* implicitly_written_register */
  5283. 1, /* can_bundle */
  5284. {
  5285. /* operands */
  5286. { 7, 8, 16 },
  5287. { 0, },
  5288. { 0, },
  5289. { 0, },
  5290. { 0, }
  5291. },
  5292. {
  5293. /* fixed_bit_masks */
  5294. 0x800000007ffc0000ULL,
  5295. 0ULL,
  5296. 0ULL,
  5297. 0ULL,
  5298. 0ULL
  5299. },
  5300. {
  5301. /* fixed_bit_values */
  5302. 0x0000000000900000ULL,
  5303. -1ULL,
  5304. -1ULL,
  5305. -1ULL,
  5306. -1ULL
  5307. }
  5308. },
  5309. { "mulhl_us.sn", TILE_OPC_MULHL_US_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5310. TREG_SN, /* implicitly_written_register */
  5311. 1, /* can_bundle */
  5312. {
  5313. /* operands */
  5314. { 7, 8, 16 },
  5315. { 0, },
  5316. { 0, },
  5317. { 0, },
  5318. { 0, }
  5319. },
  5320. {
  5321. /* fixed_bit_masks */
  5322. 0x800000007ffc0000ULL,
  5323. 0ULL,
  5324. 0ULL,
  5325. 0ULL,
  5326. 0ULL
  5327. },
  5328. {
  5329. /* fixed_bit_values */
  5330. 0x0000000008900000ULL,
  5331. -1ULL,
  5332. -1ULL,
  5333. -1ULL,
  5334. -1ULL
  5335. }
  5336. },
  5337. { "mulhl_uu", TILE_OPC_MULHL_UU, 0x1 /* pipes */, 3 /* num_operands */,
  5338. TREG_ZERO, /* implicitly_written_register */
  5339. 1, /* can_bundle */
  5340. {
  5341. /* operands */
  5342. { 7, 8, 16 },
  5343. { 0, },
  5344. { 0, },
  5345. { 0, },
  5346. { 0, }
  5347. },
  5348. {
  5349. /* fixed_bit_masks */
  5350. 0x800000007ffc0000ULL,
  5351. 0ULL,
  5352. 0ULL,
  5353. 0ULL,
  5354. 0ULL
  5355. },
  5356. {
  5357. /* fixed_bit_values */
  5358. 0x0000000000940000ULL,
  5359. -1ULL,
  5360. -1ULL,
  5361. -1ULL,
  5362. -1ULL
  5363. }
  5364. },
  5365. { "mulhl_uu.sn", TILE_OPC_MULHL_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5366. TREG_SN, /* implicitly_written_register */
  5367. 1, /* can_bundle */
  5368. {
  5369. /* operands */
  5370. { 7, 8, 16 },
  5371. { 0, },
  5372. { 0, },
  5373. { 0, },
  5374. { 0, }
  5375. },
  5376. {
  5377. /* fixed_bit_masks */
  5378. 0x800000007ffc0000ULL,
  5379. 0ULL,
  5380. 0ULL,
  5381. 0ULL,
  5382. 0ULL
  5383. },
  5384. {
  5385. /* fixed_bit_values */
  5386. 0x0000000008940000ULL,
  5387. -1ULL,
  5388. -1ULL,
  5389. -1ULL,
  5390. -1ULL
  5391. }
  5392. },
  5393. { "mulhla_ss", TILE_OPC_MULHLA_SS, 0x1 /* pipes */, 3 /* num_operands */,
  5394. TREG_ZERO, /* implicitly_written_register */
  5395. 1, /* can_bundle */
  5396. {
  5397. /* operands */
  5398. { 21, 8, 16 },
  5399. { 0, },
  5400. { 0, },
  5401. { 0, },
  5402. { 0, }
  5403. },
  5404. {
  5405. /* fixed_bit_masks */
  5406. 0x800000007ffc0000ULL,
  5407. 0ULL,
  5408. 0ULL,
  5409. 0ULL,
  5410. 0ULL
  5411. },
  5412. {
  5413. /* fixed_bit_values */
  5414. 0x0000000000740000ULL,
  5415. -1ULL,
  5416. -1ULL,
  5417. -1ULL,
  5418. -1ULL
  5419. }
  5420. },
  5421. { "mulhla_ss.sn", TILE_OPC_MULHLA_SS_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5422. TREG_SN, /* implicitly_written_register */
  5423. 1, /* can_bundle */
  5424. {
  5425. /* operands */
  5426. { 21, 8, 16 },
  5427. { 0, },
  5428. { 0, },
  5429. { 0, },
  5430. { 0, }
  5431. },
  5432. {
  5433. /* fixed_bit_masks */
  5434. 0x800000007ffc0000ULL,
  5435. 0ULL,
  5436. 0ULL,
  5437. 0ULL,
  5438. 0ULL
  5439. },
  5440. {
  5441. /* fixed_bit_values */
  5442. 0x0000000008740000ULL,
  5443. -1ULL,
  5444. -1ULL,
  5445. -1ULL,
  5446. -1ULL
  5447. }
  5448. },
  5449. { "mulhla_su", TILE_OPC_MULHLA_SU, 0x1 /* pipes */, 3 /* num_operands */,
  5450. TREG_ZERO, /* implicitly_written_register */
  5451. 1, /* can_bundle */
  5452. {
  5453. /* operands */
  5454. { 21, 8, 16 },
  5455. { 0, },
  5456. { 0, },
  5457. { 0, },
  5458. { 0, }
  5459. },
  5460. {
  5461. /* fixed_bit_masks */
  5462. 0x800000007ffc0000ULL,
  5463. 0ULL,
  5464. 0ULL,
  5465. 0ULL,
  5466. 0ULL
  5467. },
  5468. {
  5469. /* fixed_bit_values */
  5470. 0x0000000000780000ULL,
  5471. -1ULL,
  5472. -1ULL,
  5473. -1ULL,
  5474. -1ULL
  5475. }
  5476. },
  5477. { "mulhla_su.sn", TILE_OPC_MULHLA_SU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5478. TREG_SN, /* implicitly_written_register */
  5479. 1, /* can_bundle */
  5480. {
  5481. /* operands */
  5482. { 21, 8, 16 },
  5483. { 0, },
  5484. { 0, },
  5485. { 0, },
  5486. { 0, }
  5487. },
  5488. {
  5489. /* fixed_bit_masks */
  5490. 0x800000007ffc0000ULL,
  5491. 0ULL,
  5492. 0ULL,
  5493. 0ULL,
  5494. 0ULL
  5495. },
  5496. {
  5497. /* fixed_bit_values */
  5498. 0x0000000008780000ULL,
  5499. -1ULL,
  5500. -1ULL,
  5501. -1ULL,
  5502. -1ULL
  5503. }
  5504. },
  5505. { "mulhla_us", TILE_OPC_MULHLA_US, 0x1 /* pipes */, 3 /* num_operands */,
  5506. TREG_ZERO, /* implicitly_written_register */
  5507. 1, /* can_bundle */
  5508. {
  5509. /* operands */
  5510. { 21, 8, 16 },
  5511. { 0, },
  5512. { 0, },
  5513. { 0, },
  5514. { 0, }
  5515. },
  5516. {
  5517. /* fixed_bit_masks */
  5518. 0x800000007ffc0000ULL,
  5519. 0ULL,
  5520. 0ULL,
  5521. 0ULL,
  5522. 0ULL
  5523. },
  5524. {
  5525. /* fixed_bit_values */
  5526. 0x00000000007c0000ULL,
  5527. -1ULL,
  5528. -1ULL,
  5529. -1ULL,
  5530. -1ULL
  5531. }
  5532. },
  5533. { "mulhla_us.sn", TILE_OPC_MULHLA_US_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5534. TREG_SN, /* implicitly_written_register */
  5535. 1, /* can_bundle */
  5536. {
  5537. /* operands */
  5538. { 21, 8, 16 },
  5539. { 0, },
  5540. { 0, },
  5541. { 0, },
  5542. { 0, }
  5543. },
  5544. {
  5545. /* fixed_bit_masks */
  5546. 0x800000007ffc0000ULL,
  5547. 0ULL,
  5548. 0ULL,
  5549. 0ULL,
  5550. 0ULL
  5551. },
  5552. {
  5553. /* fixed_bit_values */
  5554. 0x00000000087c0000ULL,
  5555. -1ULL,
  5556. -1ULL,
  5557. -1ULL,
  5558. -1ULL
  5559. }
  5560. },
  5561. { "mulhla_uu", TILE_OPC_MULHLA_UU, 0x1 /* pipes */, 3 /* num_operands */,
  5562. TREG_ZERO, /* implicitly_written_register */
  5563. 1, /* can_bundle */
  5564. {
  5565. /* operands */
  5566. { 21, 8, 16 },
  5567. { 0, },
  5568. { 0, },
  5569. { 0, },
  5570. { 0, }
  5571. },
  5572. {
  5573. /* fixed_bit_masks */
  5574. 0x800000007ffc0000ULL,
  5575. 0ULL,
  5576. 0ULL,
  5577. 0ULL,
  5578. 0ULL
  5579. },
  5580. {
  5581. /* fixed_bit_values */
  5582. 0x0000000000800000ULL,
  5583. -1ULL,
  5584. -1ULL,
  5585. -1ULL,
  5586. -1ULL
  5587. }
  5588. },
  5589. { "mulhla_uu.sn", TILE_OPC_MULHLA_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5590. TREG_SN, /* implicitly_written_register */
  5591. 1, /* can_bundle */
  5592. {
  5593. /* operands */
  5594. { 21, 8, 16 },
  5595. { 0, },
  5596. { 0, },
  5597. { 0, },
  5598. { 0, }
  5599. },
  5600. {
  5601. /* fixed_bit_masks */
  5602. 0x800000007ffc0000ULL,
  5603. 0ULL,
  5604. 0ULL,
  5605. 0ULL,
  5606. 0ULL
  5607. },
  5608. {
  5609. /* fixed_bit_values */
  5610. 0x0000000008800000ULL,
  5611. -1ULL,
  5612. -1ULL,
  5613. -1ULL,
  5614. -1ULL
  5615. }
  5616. },
  5617. { "mulhlsa_uu", TILE_OPC_MULHLSA_UU, 0x5 /* pipes */, 3 /* num_operands */,
  5618. TREG_ZERO, /* implicitly_written_register */
  5619. 1, /* can_bundle */
  5620. {
  5621. /* operands */
  5622. { 21, 8, 16 },
  5623. { 0, },
  5624. { 31, 12, 18 },
  5625. { 0, },
  5626. { 0, }
  5627. },
  5628. {
  5629. /* fixed_bit_masks */
  5630. 0x800000007ffc0000ULL,
  5631. 0ULL,
  5632. 0x80000000780c0000ULL,
  5633. 0ULL,
  5634. 0ULL
  5635. },
  5636. {
  5637. /* fixed_bit_values */
  5638. 0x0000000000840000ULL,
  5639. -1ULL,
  5640. 0x8000000030000000ULL,
  5641. -1ULL,
  5642. -1ULL
  5643. }
  5644. },
  5645. { "mulhlsa_uu.sn", TILE_OPC_MULHLSA_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5646. TREG_SN, /* implicitly_written_register */
  5647. 1, /* can_bundle */
  5648. {
  5649. /* operands */
  5650. { 21, 8, 16 },
  5651. { 0, },
  5652. { 0, },
  5653. { 0, },
  5654. { 0, }
  5655. },
  5656. {
  5657. /* fixed_bit_masks */
  5658. 0x800000007ffc0000ULL,
  5659. 0ULL,
  5660. 0ULL,
  5661. 0ULL,
  5662. 0ULL
  5663. },
  5664. {
  5665. /* fixed_bit_values */
  5666. 0x0000000008840000ULL,
  5667. -1ULL,
  5668. -1ULL,
  5669. -1ULL,
  5670. -1ULL
  5671. }
  5672. },
  5673. { "mulll_ss", TILE_OPC_MULLL_SS, 0x5 /* pipes */, 3 /* num_operands */,
  5674. TREG_ZERO, /* implicitly_written_register */
  5675. 1, /* can_bundle */
  5676. {
  5677. /* operands */
  5678. { 7, 8, 16 },
  5679. { 0, },
  5680. { 11, 12, 18 },
  5681. { 0, },
  5682. { 0, }
  5683. },
  5684. {
  5685. /* fixed_bit_masks */
  5686. 0x800000007ffc0000ULL,
  5687. 0ULL,
  5688. 0x80000000780c0000ULL,
  5689. 0ULL,
  5690. 0ULL
  5691. },
  5692. {
  5693. /* fixed_bit_values */
  5694. 0x0000000000a80000ULL,
  5695. -1ULL,
  5696. 0x8000000038080000ULL,
  5697. -1ULL,
  5698. -1ULL
  5699. }
  5700. },
  5701. { "mulll_ss.sn", TILE_OPC_MULLL_SS_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5702. TREG_SN, /* implicitly_written_register */
  5703. 1, /* can_bundle */
  5704. {
  5705. /* operands */
  5706. { 7, 8, 16 },
  5707. { 0, },
  5708. { 0, },
  5709. { 0, },
  5710. { 0, }
  5711. },
  5712. {
  5713. /* fixed_bit_masks */
  5714. 0x800000007ffc0000ULL,
  5715. 0ULL,
  5716. 0ULL,
  5717. 0ULL,
  5718. 0ULL
  5719. },
  5720. {
  5721. /* fixed_bit_values */
  5722. 0x0000000008a80000ULL,
  5723. -1ULL,
  5724. -1ULL,
  5725. -1ULL,
  5726. -1ULL
  5727. }
  5728. },
  5729. { "mulll_su", TILE_OPC_MULLL_SU, 0x1 /* pipes */, 3 /* num_operands */,
  5730. TREG_ZERO, /* implicitly_written_register */
  5731. 1, /* can_bundle */
  5732. {
  5733. /* operands */
  5734. { 7, 8, 16 },
  5735. { 0, },
  5736. { 0, },
  5737. { 0, },
  5738. { 0, }
  5739. },
  5740. {
  5741. /* fixed_bit_masks */
  5742. 0x800000007ffc0000ULL,
  5743. 0ULL,
  5744. 0ULL,
  5745. 0ULL,
  5746. 0ULL
  5747. },
  5748. {
  5749. /* fixed_bit_values */
  5750. 0x0000000000ac0000ULL,
  5751. -1ULL,
  5752. -1ULL,
  5753. -1ULL,
  5754. -1ULL
  5755. }
  5756. },
  5757. { "mulll_su.sn", TILE_OPC_MULLL_SU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5758. TREG_SN, /* implicitly_written_register */
  5759. 1, /* can_bundle */
  5760. {
  5761. /* operands */
  5762. { 7, 8, 16 },
  5763. { 0, },
  5764. { 0, },
  5765. { 0, },
  5766. { 0, }
  5767. },
  5768. {
  5769. /* fixed_bit_masks */
  5770. 0x800000007ffc0000ULL,
  5771. 0ULL,
  5772. 0ULL,
  5773. 0ULL,
  5774. 0ULL
  5775. },
  5776. {
  5777. /* fixed_bit_values */
  5778. 0x0000000008ac0000ULL,
  5779. -1ULL,
  5780. -1ULL,
  5781. -1ULL,
  5782. -1ULL
  5783. }
  5784. },
  5785. { "mulll_uu", TILE_OPC_MULLL_UU, 0x5 /* pipes */, 3 /* num_operands */,
  5786. TREG_ZERO, /* implicitly_written_register */
  5787. 1, /* can_bundle */
  5788. {
  5789. /* operands */
  5790. { 7, 8, 16 },
  5791. { 0, },
  5792. { 11, 12, 18 },
  5793. { 0, },
  5794. { 0, }
  5795. },
  5796. {
  5797. /* fixed_bit_masks */
  5798. 0x800000007ffc0000ULL,
  5799. 0ULL,
  5800. 0x80000000780c0000ULL,
  5801. 0ULL,
  5802. 0ULL
  5803. },
  5804. {
  5805. /* fixed_bit_values */
  5806. 0x0000000000b00000ULL,
  5807. -1ULL,
  5808. 0x80000000380c0000ULL,
  5809. -1ULL,
  5810. -1ULL
  5811. }
  5812. },
  5813. { "mulll_uu.sn", TILE_OPC_MULLL_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5814. TREG_SN, /* implicitly_written_register */
  5815. 1, /* can_bundle */
  5816. {
  5817. /* operands */
  5818. { 7, 8, 16 },
  5819. { 0, },
  5820. { 0, },
  5821. { 0, },
  5822. { 0, }
  5823. },
  5824. {
  5825. /* fixed_bit_masks */
  5826. 0x800000007ffc0000ULL,
  5827. 0ULL,
  5828. 0ULL,
  5829. 0ULL,
  5830. 0ULL
  5831. },
  5832. {
  5833. /* fixed_bit_values */
  5834. 0x0000000008b00000ULL,
  5835. -1ULL,
  5836. -1ULL,
  5837. -1ULL,
  5838. -1ULL
  5839. }
  5840. },
  5841. { "mullla_ss", TILE_OPC_MULLLA_SS, 0x5 /* pipes */, 3 /* num_operands */,
  5842. TREG_ZERO, /* implicitly_written_register */
  5843. 1, /* can_bundle */
  5844. {
  5845. /* operands */
  5846. { 21, 8, 16 },
  5847. { 0, },
  5848. { 31, 12, 18 },
  5849. { 0, },
  5850. { 0, }
  5851. },
  5852. {
  5853. /* fixed_bit_masks */
  5854. 0x800000007ffc0000ULL,
  5855. 0ULL,
  5856. 0x80000000780c0000ULL,
  5857. 0ULL,
  5858. 0ULL
  5859. },
  5860. {
  5861. /* fixed_bit_values */
  5862. 0x0000000000980000ULL,
  5863. -1ULL,
  5864. 0x8000000040080000ULL,
  5865. -1ULL,
  5866. -1ULL
  5867. }
  5868. },
  5869. { "mullla_ss.sn", TILE_OPC_MULLLA_SS_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5870. TREG_SN, /* implicitly_written_register */
  5871. 1, /* can_bundle */
  5872. {
  5873. /* operands */
  5874. { 21, 8, 16 },
  5875. { 0, },
  5876. { 0, },
  5877. { 0, },
  5878. { 0, }
  5879. },
  5880. {
  5881. /* fixed_bit_masks */
  5882. 0x800000007ffc0000ULL,
  5883. 0ULL,
  5884. 0ULL,
  5885. 0ULL,
  5886. 0ULL
  5887. },
  5888. {
  5889. /* fixed_bit_values */
  5890. 0x0000000008980000ULL,
  5891. -1ULL,
  5892. -1ULL,
  5893. -1ULL,
  5894. -1ULL
  5895. }
  5896. },
  5897. { "mullla_su", TILE_OPC_MULLLA_SU, 0x1 /* pipes */, 3 /* num_operands */,
  5898. TREG_ZERO, /* implicitly_written_register */
  5899. 1, /* can_bundle */
  5900. {
  5901. /* operands */
  5902. { 21, 8, 16 },
  5903. { 0, },
  5904. { 0, },
  5905. { 0, },
  5906. { 0, }
  5907. },
  5908. {
  5909. /* fixed_bit_masks */
  5910. 0x800000007ffc0000ULL,
  5911. 0ULL,
  5912. 0ULL,
  5913. 0ULL,
  5914. 0ULL
  5915. },
  5916. {
  5917. /* fixed_bit_values */
  5918. 0x00000000009c0000ULL,
  5919. -1ULL,
  5920. -1ULL,
  5921. -1ULL,
  5922. -1ULL
  5923. }
  5924. },
  5925. { "mullla_su.sn", TILE_OPC_MULLLA_SU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5926. TREG_SN, /* implicitly_written_register */
  5927. 1, /* can_bundle */
  5928. {
  5929. /* operands */
  5930. { 21, 8, 16 },
  5931. { 0, },
  5932. { 0, },
  5933. { 0, },
  5934. { 0, }
  5935. },
  5936. {
  5937. /* fixed_bit_masks */
  5938. 0x800000007ffc0000ULL,
  5939. 0ULL,
  5940. 0ULL,
  5941. 0ULL,
  5942. 0ULL
  5943. },
  5944. {
  5945. /* fixed_bit_values */
  5946. 0x00000000089c0000ULL,
  5947. -1ULL,
  5948. -1ULL,
  5949. -1ULL,
  5950. -1ULL
  5951. }
  5952. },
  5953. { "mullla_uu", TILE_OPC_MULLLA_UU, 0x5 /* pipes */, 3 /* num_operands */,
  5954. TREG_ZERO, /* implicitly_written_register */
  5955. 1, /* can_bundle */
  5956. {
  5957. /* operands */
  5958. { 21, 8, 16 },
  5959. { 0, },
  5960. { 31, 12, 18 },
  5961. { 0, },
  5962. { 0, }
  5963. },
  5964. {
  5965. /* fixed_bit_masks */
  5966. 0x800000007ffc0000ULL,
  5967. 0ULL,
  5968. 0x80000000780c0000ULL,
  5969. 0ULL,
  5970. 0ULL
  5971. },
  5972. {
  5973. /* fixed_bit_values */
  5974. 0x0000000000a00000ULL,
  5975. -1ULL,
  5976. 0x80000000400c0000ULL,
  5977. -1ULL,
  5978. -1ULL
  5979. }
  5980. },
  5981. { "mullla_uu.sn", TILE_OPC_MULLLA_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  5982. TREG_SN, /* implicitly_written_register */
  5983. 1, /* can_bundle */
  5984. {
  5985. /* operands */
  5986. { 21, 8, 16 },
  5987. { 0, },
  5988. { 0, },
  5989. { 0, },
  5990. { 0, }
  5991. },
  5992. {
  5993. /* fixed_bit_masks */
  5994. 0x800000007ffc0000ULL,
  5995. 0ULL,
  5996. 0ULL,
  5997. 0ULL,
  5998. 0ULL
  5999. },
  6000. {
  6001. /* fixed_bit_values */
  6002. 0x0000000008a00000ULL,
  6003. -1ULL,
  6004. -1ULL,
  6005. -1ULL,
  6006. -1ULL
  6007. }
  6008. },
  6009. { "mulllsa_uu", TILE_OPC_MULLLSA_UU, 0x1 /* pipes */, 3 /* num_operands */,
  6010. TREG_ZERO, /* implicitly_written_register */
  6011. 1, /* can_bundle */
  6012. {
  6013. /* operands */
  6014. { 21, 8, 16 },
  6015. { 0, },
  6016. { 0, },
  6017. { 0, },
  6018. { 0, }
  6019. },
  6020. {
  6021. /* fixed_bit_masks */
  6022. 0x800000007ffc0000ULL,
  6023. 0ULL,
  6024. 0ULL,
  6025. 0ULL,
  6026. 0ULL
  6027. },
  6028. {
  6029. /* fixed_bit_values */
  6030. 0x0000000000a40000ULL,
  6031. -1ULL,
  6032. -1ULL,
  6033. -1ULL,
  6034. -1ULL
  6035. }
  6036. },
  6037. { "mulllsa_uu.sn", TILE_OPC_MULLLSA_UU_SN, 0x1 /* pipes */, 3 /* num_operands */,
  6038. TREG_SN, /* implicitly_written_register */
  6039. 1, /* can_bundle */
  6040. {
  6041. /* operands */
  6042. { 21, 8, 16 },
  6043. { 0, },
  6044. { 0, },
  6045. { 0, },
  6046. { 0, }
  6047. },
  6048. {
  6049. /* fixed_bit_masks */
  6050. 0x800000007ffc0000ULL,
  6051. 0ULL,
  6052. 0ULL,
  6053. 0ULL,
  6054. 0ULL
  6055. },
  6056. {
  6057. /* fixed_bit_values */
  6058. 0x0000000008a40000ULL,
  6059. -1ULL,
  6060. -1ULL,
  6061. -1ULL,
  6062. -1ULL
  6063. }
  6064. },
  6065. { "mvnz", TILE_OPC_MVNZ, 0x5 /* pipes */, 3 /* num_operands */,
  6066. TREG_ZERO, /* implicitly_written_register */
  6067. 1, /* can_bundle */
  6068. {
  6069. /* operands */
  6070. { 21, 8, 16 },
  6071. { 0, },
  6072. { 31, 12, 18 },
  6073. { 0, },
  6074. { 0, }
  6075. },
  6076. {
  6077. /* fixed_bit_masks */
  6078. 0x800000007ffc0000ULL,
  6079. 0ULL,
  6080. 0x80000000780c0000ULL,
  6081. 0ULL,
  6082. 0ULL
  6083. },
  6084. {
  6085. /* fixed_bit_values */
  6086. 0x0000000000b40000ULL,
  6087. -1ULL,
  6088. 0x8000000010040000ULL,
  6089. -1ULL,
  6090. -1ULL
  6091. }
  6092. },
  6093. { "mvnz.sn", TILE_OPC_MVNZ_SN, 0x1 /* pipes */, 3 /* num_operands */,
  6094. TREG_SN, /* implicitly_written_register */
  6095. 1, /* can_bundle */
  6096. {
  6097. /* operands */
  6098. { 21, 8, 16 },
  6099. { 0, },
  6100. { 0, },
  6101. { 0, },
  6102. { 0, }
  6103. },
  6104. {
  6105. /* fixed_bit_masks */
  6106. 0x800000007ffc0000ULL,
  6107. 0ULL,
  6108. 0ULL,
  6109. 0ULL,
  6110. 0ULL
  6111. },
  6112. {
  6113. /* fixed_bit_values */
  6114. 0x0000000008b40000ULL,
  6115. -1ULL,
  6116. -1ULL,
  6117. -1ULL,
  6118. -1ULL
  6119. }
  6120. },
  6121. { "mvz", TILE_OPC_MVZ, 0x5 /* pipes */, 3 /* num_operands */,
  6122. TREG_ZERO, /* implicitly_written_register */
  6123. 1, /* can_bundle */
  6124. {
  6125. /* operands */
  6126. { 21, 8, 16 },
  6127. { 0, },
  6128. { 31, 12, 18 },
  6129. { 0, },
  6130. { 0, }
  6131. },
  6132. {
  6133. /* fixed_bit_masks */
  6134. 0x800000007ffc0000ULL,
  6135. 0ULL,
  6136. 0x80000000780c0000ULL,
  6137. 0ULL,
  6138. 0ULL
  6139. },
  6140. {
  6141. /* fixed_bit_values */
  6142. 0x0000000000b80000ULL,
  6143. -1ULL,
  6144. 0x8000000010080000ULL,
  6145. -1ULL,
  6146. -1ULL
  6147. }
  6148. },
  6149. { "mvz.sn", TILE_OPC_MVZ_SN, 0x1 /* pipes */, 3 /* num_operands */,
  6150. TREG_SN, /* implicitly_written_register */
  6151. 1, /* can_bundle */
  6152. {
  6153. /* operands */
  6154. { 21, 8, 16 },
  6155. { 0, },
  6156. { 0, },
  6157. { 0, },
  6158. { 0, }
  6159. },
  6160. {
  6161. /* fixed_bit_masks */
  6162. 0x800000007ffc0000ULL,
  6163. 0ULL,
  6164. 0ULL,
  6165. 0ULL,
  6166. 0ULL
  6167. },
  6168. {
  6169. /* fixed_bit_values */
  6170. 0x0000000008b80000ULL,
  6171. -1ULL,
  6172. -1ULL,
  6173. -1ULL,
  6174. -1ULL
  6175. }
  6176. },
  6177. { "mz", TILE_OPC_MZ, 0xf /* pipes */, 3 /* num_operands */,
  6178. TREG_ZERO, /* implicitly_written_register */
  6179. 1, /* can_bundle */
  6180. {
  6181. /* operands */
  6182. { 7, 8, 16 },
  6183. { 9, 10, 17 },
  6184. { 11, 12, 18 },
  6185. { 13, 14, 19 },
  6186. { 0, }
  6187. },
  6188. {
  6189. /* fixed_bit_masks */
  6190. 0x800000007ffc0000ULL,
  6191. 0xfffe000000000000ULL,
  6192. 0x80000000780c0000ULL,
  6193. 0xf806000000000000ULL,
  6194. 0ULL
  6195. },
  6196. {
  6197. /* fixed_bit_values */
  6198. 0x0000000000c40000ULL,
  6199. 0x082e000000000000ULL,
  6200. 0x80000000100c0000ULL,
  6201. 0x9004000000000000ULL,
  6202. -1ULL
  6203. }
  6204. },
  6205. { "mz.sn", TILE_OPC_MZ_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6206. TREG_SN, /* implicitly_written_register */
  6207. 1, /* can_bundle */
  6208. {
  6209. /* operands */
  6210. { 7, 8, 16 },
  6211. { 9, 10, 17 },
  6212. { 0, },
  6213. { 0, },
  6214. { 0, }
  6215. },
  6216. {
  6217. /* fixed_bit_masks */
  6218. 0x800000007ffc0000ULL,
  6219. 0xfffe000000000000ULL,
  6220. 0ULL,
  6221. 0ULL,
  6222. 0ULL
  6223. },
  6224. {
  6225. /* fixed_bit_values */
  6226. 0x0000000008c40000ULL,
  6227. 0x0c2e000000000000ULL,
  6228. -1ULL,
  6229. -1ULL,
  6230. -1ULL
  6231. }
  6232. },
  6233. { "mzb", TILE_OPC_MZB, 0x3 /* pipes */, 3 /* num_operands */,
  6234. TREG_ZERO, /* implicitly_written_register */
  6235. 1, /* can_bundle */
  6236. {
  6237. /* operands */
  6238. { 7, 8, 16 },
  6239. { 9, 10, 17 },
  6240. { 0, },
  6241. { 0, },
  6242. { 0, }
  6243. },
  6244. {
  6245. /* fixed_bit_masks */
  6246. 0x800000007ffc0000ULL,
  6247. 0xfffe000000000000ULL,
  6248. 0ULL,
  6249. 0ULL,
  6250. 0ULL
  6251. },
  6252. {
  6253. /* fixed_bit_values */
  6254. 0x0000000000bc0000ULL,
  6255. 0x082a000000000000ULL,
  6256. -1ULL,
  6257. -1ULL,
  6258. -1ULL
  6259. }
  6260. },
  6261. { "mzb.sn", TILE_OPC_MZB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6262. TREG_SN, /* implicitly_written_register */
  6263. 1, /* can_bundle */
  6264. {
  6265. /* operands */
  6266. { 7, 8, 16 },
  6267. { 9, 10, 17 },
  6268. { 0, },
  6269. { 0, },
  6270. { 0, }
  6271. },
  6272. {
  6273. /* fixed_bit_masks */
  6274. 0x800000007ffc0000ULL,
  6275. 0xfffe000000000000ULL,
  6276. 0ULL,
  6277. 0ULL,
  6278. 0ULL
  6279. },
  6280. {
  6281. /* fixed_bit_values */
  6282. 0x0000000008bc0000ULL,
  6283. 0x0c2a000000000000ULL,
  6284. -1ULL,
  6285. -1ULL,
  6286. -1ULL
  6287. }
  6288. },
  6289. { "mzh", TILE_OPC_MZH, 0x3 /* pipes */, 3 /* num_operands */,
  6290. TREG_ZERO, /* implicitly_written_register */
  6291. 1, /* can_bundle */
  6292. {
  6293. /* operands */
  6294. { 7, 8, 16 },
  6295. { 9, 10, 17 },
  6296. { 0, },
  6297. { 0, },
  6298. { 0, }
  6299. },
  6300. {
  6301. /* fixed_bit_masks */
  6302. 0x800000007ffc0000ULL,
  6303. 0xfffe000000000000ULL,
  6304. 0ULL,
  6305. 0ULL,
  6306. 0ULL
  6307. },
  6308. {
  6309. /* fixed_bit_values */
  6310. 0x0000000000c00000ULL,
  6311. 0x082c000000000000ULL,
  6312. -1ULL,
  6313. -1ULL,
  6314. -1ULL
  6315. }
  6316. },
  6317. { "mzh.sn", TILE_OPC_MZH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6318. TREG_SN, /* implicitly_written_register */
  6319. 1, /* can_bundle */
  6320. {
  6321. /* operands */
  6322. { 7, 8, 16 },
  6323. { 9, 10, 17 },
  6324. { 0, },
  6325. { 0, },
  6326. { 0, }
  6327. },
  6328. {
  6329. /* fixed_bit_masks */
  6330. 0x800000007ffc0000ULL,
  6331. 0xfffe000000000000ULL,
  6332. 0ULL,
  6333. 0ULL,
  6334. 0ULL
  6335. },
  6336. {
  6337. /* fixed_bit_values */
  6338. 0x0000000008c00000ULL,
  6339. 0x0c2c000000000000ULL,
  6340. -1ULL,
  6341. -1ULL,
  6342. -1ULL
  6343. }
  6344. },
  6345. { "nap", TILE_OPC_NAP, 0x2 /* pipes */, 0 /* num_operands */,
  6346. TREG_ZERO, /* implicitly_written_register */
  6347. 0, /* can_bundle */
  6348. {
  6349. /* operands */
  6350. { 0, },
  6351. { },
  6352. { 0, },
  6353. { 0, },
  6354. { 0, }
  6355. },
  6356. {
  6357. /* fixed_bit_masks */
  6358. 0ULL,
  6359. 0xfbfff80000000000ULL,
  6360. 0ULL,
  6361. 0ULL,
  6362. 0ULL
  6363. },
  6364. {
  6365. /* fixed_bit_values */
  6366. -1ULL,
  6367. 0x400b800000000000ULL,
  6368. -1ULL,
  6369. -1ULL,
  6370. -1ULL
  6371. }
  6372. },
  6373. { "nop", TILE_OPC_NOP, 0xf /* pipes */, 0 /* num_operands */,
  6374. TREG_ZERO, /* implicitly_written_register */
  6375. 1, /* can_bundle */
  6376. {
  6377. /* operands */
  6378. { },
  6379. { },
  6380. { },
  6381. { },
  6382. { 0, }
  6383. },
  6384. {
  6385. /* fixed_bit_masks */
  6386. 0x8000000077fff000ULL,
  6387. 0xfbfff80000000000ULL,
  6388. 0x80000000780ff000ULL,
  6389. 0xf807f80000000000ULL,
  6390. 0ULL
  6391. },
  6392. {
  6393. /* fixed_bit_values */
  6394. 0x0000000070166000ULL,
  6395. 0x400b880000000000ULL,
  6396. 0x80000000680a6000ULL,
  6397. 0xd805180000000000ULL,
  6398. -1ULL
  6399. }
  6400. },
  6401. { "nor", TILE_OPC_NOR, 0xf /* pipes */, 3 /* num_operands */,
  6402. TREG_ZERO, /* implicitly_written_register */
  6403. 1, /* can_bundle */
  6404. {
  6405. /* operands */
  6406. { 7, 8, 16 },
  6407. { 9, 10, 17 },
  6408. { 11, 12, 18 },
  6409. { 13, 14, 19 },
  6410. { 0, }
  6411. },
  6412. {
  6413. /* fixed_bit_masks */
  6414. 0x800000007ffc0000ULL,
  6415. 0xfffe000000000000ULL,
  6416. 0x80000000780c0000ULL,
  6417. 0xf806000000000000ULL,
  6418. 0ULL
  6419. },
  6420. {
  6421. /* fixed_bit_values */
  6422. 0x0000000000c80000ULL,
  6423. 0x0830000000000000ULL,
  6424. 0x8000000018040000ULL,
  6425. 0x9802000000000000ULL,
  6426. -1ULL
  6427. }
  6428. },
  6429. { "nor.sn", TILE_OPC_NOR_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6430. TREG_SN, /* implicitly_written_register */
  6431. 1, /* can_bundle */
  6432. {
  6433. /* operands */
  6434. { 7, 8, 16 },
  6435. { 9, 10, 17 },
  6436. { 0, },
  6437. { 0, },
  6438. { 0, }
  6439. },
  6440. {
  6441. /* fixed_bit_masks */
  6442. 0x800000007ffc0000ULL,
  6443. 0xfffe000000000000ULL,
  6444. 0ULL,
  6445. 0ULL,
  6446. 0ULL
  6447. },
  6448. {
  6449. /* fixed_bit_values */
  6450. 0x0000000008c80000ULL,
  6451. 0x0c30000000000000ULL,
  6452. -1ULL,
  6453. -1ULL,
  6454. -1ULL
  6455. }
  6456. },
  6457. { "or", TILE_OPC_OR, 0xf /* pipes */, 3 /* num_operands */,
  6458. TREG_ZERO, /* implicitly_written_register */
  6459. 1, /* can_bundle */
  6460. {
  6461. /* operands */
  6462. { 7, 8, 16 },
  6463. { 9, 10, 17 },
  6464. { 11, 12, 18 },
  6465. { 13, 14, 19 },
  6466. { 0, }
  6467. },
  6468. {
  6469. /* fixed_bit_masks */
  6470. 0x800000007ffc0000ULL,
  6471. 0xfffe000000000000ULL,
  6472. 0x80000000780c0000ULL,
  6473. 0xf806000000000000ULL,
  6474. 0ULL
  6475. },
  6476. {
  6477. /* fixed_bit_values */
  6478. 0x0000000000cc0000ULL,
  6479. 0x0832000000000000ULL,
  6480. 0x8000000018080000ULL,
  6481. 0x9804000000000000ULL,
  6482. -1ULL
  6483. }
  6484. },
  6485. { "or.sn", TILE_OPC_OR_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6486. TREG_SN, /* implicitly_written_register */
  6487. 1, /* can_bundle */
  6488. {
  6489. /* operands */
  6490. { 7, 8, 16 },
  6491. { 9, 10, 17 },
  6492. { 0, },
  6493. { 0, },
  6494. { 0, }
  6495. },
  6496. {
  6497. /* fixed_bit_masks */
  6498. 0x800000007ffc0000ULL,
  6499. 0xfffe000000000000ULL,
  6500. 0ULL,
  6501. 0ULL,
  6502. 0ULL
  6503. },
  6504. {
  6505. /* fixed_bit_values */
  6506. 0x0000000008cc0000ULL,
  6507. 0x0c32000000000000ULL,
  6508. -1ULL,
  6509. -1ULL,
  6510. -1ULL
  6511. }
  6512. },
  6513. { "ori", TILE_OPC_ORI, 0xf /* pipes */, 3 /* num_operands */,
  6514. TREG_ZERO, /* implicitly_written_register */
  6515. 1, /* can_bundle */
  6516. {
  6517. /* operands */
  6518. { 7, 8, 0 },
  6519. { 9, 10, 1 },
  6520. { 11, 12, 2 },
  6521. { 13, 14, 3 },
  6522. { 0, }
  6523. },
  6524. {
  6525. /* fixed_bit_masks */
  6526. 0x800000007ff00000ULL,
  6527. 0xfff8000000000000ULL,
  6528. 0x8000000078000000ULL,
  6529. 0xf800000000000000ULL,
  6530. 0ULL
  6531. },
  6532. {
  6533. /* fixed_bit_values */
  6534. 0x0000000040800000ULL,
  6535. 0x3058000000000000ULL,
  6536. 0x8000000058000000ULL,
  6537. 0xc800000000000000ULL,
  6538. -1ULL
  6539. }
  6540. },
  6541. { "ori.sn", TILE_OPC_ORI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6542. TREG_SN, /* implicitly_written_register */
  6543. 1, /* can_bundle */
  6544. {
  6545. /* operands */
  6546. { 7, 8, 0 },
  6547. { 9, 10, 1 },
  6548. { 0, },
  6549. { 0, },
  6550. { 0, }
  6551. },
  6552. {
  6553. /* fixed_bit_masks */
  6554. 0x800000007ff00000ULL,
  6555. 0xfff8000000000000ULL,
  6556. 0ULL,
  6557. 0ULL,
  6558. 0ULL
  6559. },
  6560. {
  6561. /* fixed_bit_values */
  6562. 0x0000000048800000ULL,
  6563. 0x3458000000000000ULL,
  6564. -1ULL,
  6565. -1ULL,
  6566. -1ULL
  6567. }
  6568. },
  6569. { "packbs_u", TILE_OPC_PACKBS_U, 0x3 /* pipes */, 3 /* num_operands */,
  6570. TREG_ZERO, /* implicitly_written_register */
  6571. 1, /* can_bundle */
  6572. {
  6573. /* operands */
  6574. { 7, 8, 16 },
  6575. { 9, 10, 17 },
  6576. { 0, },
  6577. { 0, },
  6578. { 0, }
  6579. },
  6580. {
  6581. /* fixed_bit_masks */
  6582. 0x800000007ffc0000ULL,
  6583. 0xfffe000000000000ULL,
  6584. 0ULL,
  6585. 0ULL,
  6586. 0ULL
  6587. },
  6588. {
  6589. /* fixed_bit_values */
  6590. 0x00000000019c0000ULL,
  6591. 0x0892000000000000ULL,
  6592. -1ULL,
  6593. -1ULL,
  6594. -1ULL
  6595. }
  6596. },
  6597. { "packbs_u.sn", TILE_OPC_PACKBS_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6598. TREG_SN, /* implicitly_written_register */
  6599. 1, /* can_bundle */
  6600. {
  6601. /* operands */
  6602. { 7, 8, 16 },
  6603. { 9, 10, 17 },
  6604. { 0, },
  6605. { 0, },
  6606. { 0, }
  6607. },
  6608. {
  6609. /* fixed_bit_masks */
  6610. 0x800000007ffc0000ULL,
  6611. 0xfffe000000000000ULL,
  6612. 0ULL,
  6613. 0ULL,
  6614. 0ULL
  6615. },
  6616. {
  6617. /* fixed_bit_values */
  6618. 0x00000000099c0000ULL,
  6619. 0x0c92000000000000ULL,
  6620. -1ULL,
  6621. -1ULL,
  6622. -1ULL
  6623. }
  6624. },
  6625. { "packhb", TILE_OPC_PACKHB, 0x3 /* pipes */, 3 /* num_operands */,
  6626. TREG_ZERO, /* implicitly_written_register */
  6627. 1, /* can_bundle */
  6628. {
  6629. /* operands */
  6630. { 7, 8, 16 },
  6631. { 9, 10, 17 },
  6632. { 0, },
  6633. { 0, },
  6634. { 0, }
  6635. },
  6636. {
  6637. /* fixed_bit_masks */
  6638. 0x800000007ffc0000ULL,
  6639. 0xfffe000000000000ULL,
  6640. 0ULL,
  6641. 0ULL,
  6642. 0ULL
  6643. },
  6644. {
  6645. /* fixed_bit_values */
  6646. 0x0000000000d00000ULL,
  6647. 0x0834000000000000ULL,
  6648. -1ULL,
  6649. -1ULL,
  6650. -1ULL
  6651. }
  6652. },
  6653. { "packhb.sn", TILE_OPC_PACKHB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6654. TREG_SN, /* implicitly_written_register */
  6655. 1, /* can_bundle */
  6656. {
  6657. /* operands */
  6658. { 7, 8, 16 },
  6659. { 9, 10, 17 },
  6660. { 0, },
  6661. { 0, },
  6662. { 0, }
  6663. },
  6664. {
  6665. /* fixed_bit_masks */
  6666. 0x800000007ffc0000ULL,
  6667. 0xfffe000000000000ULL,
  6668. 0ULL,
  6669. 0ULL,
  6670. 0ULL
  6671. },
  6672. {
  6673. /* fixed_bit_values */
  6674. 0x0000000008d00000ULL,
  6675. 0x0c34000000000000ULL,
  6676. -1ULL,
  6677. -1ULL,
  6678. -1ULL
  6679. }
  6680. },
  6681. { "packhs", TILE_OPC_PACKHS, 0x3 /* pipes */, 3 /* num_operands */,
  6682. TREG_ZERO, /* implicitly_written_register */
  6683. 1, /* can_bundle */
  6684. {
  6685. /* operands */
  6686. { 7, 8, 16 },
  6687. { 9, 10, 17 },
  6688. { 0, },
  6689. { 0, },
  6690. { 0, }
  6691. },
  6692. {
  6693. /* fixed_bit_masks */
  6694. 0x800000007ffc0000ULL,
  6695. 0xfffe000000000000ULL,
  6696. 0ULL,
  6697. 0ULL,
  6698. 0ULL
  6699. },
  6700. {
  6701. /* fixed_bit_values */
  6702. 0x0000000001980000ULL,
  6703. 0x0890000000000000ULL,
  6704. -1ULL,
  6705. -1ULL,
  6706. -1ULL
  6707. }
  6708. },
  6709. { "packhs.sn", TILE_OPC_PACKHS_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6710. TREG_SN, /* implicitly_written_register */
  6711. 1, /* can_bundle */
  6712. {
  6713. /* operands */
  6714. { 7, 8, 16 },
  6715. { 9, 10, 17 },
  6716. { 0, },
  6717. { 0, },
  6718. { 0, }
  6719. },
  6720. {
  6721. /* fixed_bit_masks */
  6722. 0x800000007ffc0000ULL,
  6723. 0xfffe000000000000ULL,
  6724. 0ULL,
  6725. 0ULL,
  6726. 0ULL
  6727. },
  6728. {
  6729. /* fixed_bit_values */
  6730. 0x0000000009980000ULL,
  6731. 0x0c90000000000000ULL,
  6732. -1ULL,
  6733. -1ULL,
  6734. -1ULL
  6735. }
  6736. },
  6737. { "packlb", TILE_OPC_PACKLB, 0x3 /* pipes */, 3 /* num_operands */,
  6738. TREG_ZERO, /* implicitly_written_register */
  6739. 1, /* can_bundle */
  6740. {
  6741. /* operands */
  6742. { 7, 8, 16 },
  6743. { 9, 10, 17 },
  6744. { 0, },
  6745. { 0, },
  6746. { 0, }
  6747. },
  6748. {
  6749. /* fixed_bit_masks */
  6750. 0x800000007ffc0000ULL,
  6751. 0xfffe000000000000ULL,
  6752. 0ULL,
  6753. 0ULL,
  6754. 0ULL
  6755. },
  6756. {
  6757. /* fixed_bit_values */
  6758. 0x0000000000d40000ULL,
  6759. 0x0836000000000000ULL,
  6760. -1ULL,
  6761. -1ULL,
  6762. -1ULL
  6763. }
  6764. },
  6765. { "packlb.sn", TILE_OPC_PACKLB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6766. TREG_SN, /* implicitly_written_register */
  6767. 1, /* can_bundle */
  6768. {
  6769. /* operands */
  6770. { 7, 8, 16 },
  6771. { 9, 10, 17 },
  6772. { 0, },
  6773. { 0, },
  6774. { 0, }
  6775. },
  6776. {
  6777. /* fixed_bit_masks */
  6778. 0x800000007ffc0000ULL,
  6779. 0xfffe000000000000ULL,
  6780. 0ULL,
  6781. 0ULL,
  6782. 0ULL
  6783. },
  6784. {
  6785. /* fixed_bit_values */
  6786. 0x0000000008d40000ULL,
  6787. 0x0c36000000000000ULL,
  6788. -1ULL,
  6789. -1ULL,
  6790. -1ULL
  6791. }
  6792. },
  6793. { "pcnt", TILE_OPC_PCNT, 0x5 /* pipes */, 2 /* num_operands */,
  6794. TREG_ZERO, /* implicitly_written_register */
  6795. 1, /* can_bundle */
  6796. {
  6797. /* operands */
  6798. { 7, 8 },
  6799. { 0, },
  6800. { 11, 12 },
  6801. { 0, },
  6802. { 0, }
  6803. },
  6804. {
  6805. /* fixed_bit_masks */
  6806. 0x800000007ffff000ULL,
  6807. 0ULL,
  6808. 0x80000000780ff000ULL,
  6809. 0ULL,
  6810. 0ULL
  6811. },
  6812. {
  6813. /* fixed_bit_values */
  6814. 0x0000000070167000ULL,
  6815. -1ULL,
  6816. 0x80000000680a7000ULL,
  6817. -1ULL,
  6818. -1ULL
  6819. }
  6820. },
  6821. { "pcnt.sn", TILE_OPC_PCNT_SN, 0x1 /* pipes */, 2 /* num_operands */,
  6822. TREG_SN, /* implicitly_written_register */
  6823. 1, /* can_bundle */
  6824. {
  6825. /* operands */
  6826. { 7, 8 },
  6827. { 0, },
  6828. { 0, },
  6829. { 0, },
  6830. { 0, }
  6831. },
  6832. {
  6833. /* fixed_bit_masks */
  6834. 0x800000007ffff000ULL,
  6835. 0ULL,
  6836. 0ULL,
  6837. 0ULL,
  6838. 0ULL
  6839. },
  6840. {
  6841. /* fixed_bit_values */
  6842. 0x0000000078167000ULL,
  6843. -1ULL,
  6844. -1ULL,
  6845. -1ULL,
  6846. -1ULL
  6847. }
  6848. },
  6849. { "rl", TILE_OPC_RL, 0xf /* pipes */, 3 /* num_operands */,
  6850. TREG_ZERO, /* implicitly_written_register */
  6851. 1, /* can_bundle */
  6852. {
  6853. /* operands */
  6854. { 7, 8, 16 },
  6855. { 9, 10, 17 },
  6856. { 11, 12, 18 },
  6857. { 13, 14, 19 },
  6858. { 0, }
  6859. },
  6860. {
  6861. /* fixed_bit_masks */
  6862. 0x800000007ffc0000ULL,
  6863. 0xfffe000000000000ULL,
  6864. 0x80000000780c0000ULL,
  6865. 0xf806000000000000ULL,
  6866. 0ULL
  6867. },
  6868. {
  6869. /* fixed_bit_values */
  6870. 0x0000000000d80000ULL,
  6871. 0x0838000000000000ULL,
  6872. 0x8000000020000000ULL,
  6873. 0xa000000000000000ULL,
  6874. -1ULL
  6875. }
  6876. },
  6877. { "rl.sn", TILE_OPC_RL_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6878. TREG_SN, /* implicitly_written_register */
  6879. 1, /* can_bundle */
  6880. {
  6881. /* operands */
  6882. { 7, 8, 16 },
  6883. { 9, 10, 17 },
  6884. { 0, },
  6885. { 0, },
  6886. { 0, }
  6887. },
  6888. {
  6889. /* fixed_bit_masks */
  6890. 0x800000007ffc0000ULL,
  6891. 0xfffe000000000000ULL,
  6892. 0ULL,
  6893. 0ULL,
  6894. 0ULL
  6895. },
  6896. {
  6897. /* fixed_bit_values */
  6898. 0x0000000008d80000ULL,
  6899. 0x0c38000000000000ULL,
  6900. -1ULL,
  6901. -1ULL,
  6902. -1ULL
  6903. }
  6904. },
  6905. { "rli", TILE_OPC_RLI, 0xf /* pipes */, 3 /* num_operands */,
  6906. TREG_ZERO, /* implicitly_written_register */
  6907. 1, /* can_bundle */
  6908. {
  6909. /* operands */
  6910. { 7, 8, 32 },
  6911. { 9, 10, 33 },
  6912. { 11, 12, 34 },
  6913. { 13, 14, 35 },
  6914. { 0, }
  6915. },
  6916. {
  6917. /* fixed_bit_masks */
  6918. 0x800000007ffe0000ULL,
  6919. 0xffff000000000000ULL,
  6920. 0x80000000780e0000ULL,
  6921. 0xf807000000000000ULL,
  6922. 0ULL
  6923. },
  6924. {
  6925. /* fixed_bit_values */
  6926. 0x0000000070020000ULL,
  6927. 0x4001000000000000ULL,
  6928. 0x8000000068020000ULL,
  6929. 0xd801000000000000ULL,
  6930. -1ULL
  6931. }
  6932. },
  6933. { "rli.sn", TILE_OPC_RLI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6934. TREG_SN, /* implicitly_written_register */
  6935. 1, /* can_bundle */
  6936. {
  6937. /* operands */
  6938. { 7, 8, 32 },
  6939. { 9, 10, 33 },
  6940. { 0, },
  6941. { 0, },
  6942. { 0, }
  6943. },
  6944. {
  6945. /* fixed_bit_masks */
  6946. 0x800000007ffe0000ULL,
  6947. 0xffff000000000000ULL,
  6948. 0ULL,
  6949. 0ULL,
  6950. 0ULL
  6951. },
  6952. {
  6953. /* fixed_bit_values */
  6954. 0x0000000078020000ULL,
  6955. 0x4401000000000000ULL,
  6956. -1ULL,
  6957. -1ULL,
  6958. -1ULL
  6959. }
  6960. },
  6961. { "s1a", TILE_OPC_S1A, 0xf /* pipes */, 3 /* num_operands */,
  6962. TREG_ZERO, /* implicitly_written_register */
  6963. 1, /* can_bundle */
  6964. {
  6965. /* operands */
  6966. { 7, 8, 16 },
  6967. { 9, 10, 17 },
  6968. { 11, 12, 18 },
  6969. { 13, 14, 19 },
  6970. { 0, }
  6971. },
  6972. {
  6973. /* fixed_bit_masks */
  6974. 0x800000007ffc0000ULL,
  6975. 0xfffe000000000000ULL,
  6976. 0x80000000780c0000ULL,
  6977. 0xf806000000000000ULL,
  6978. 0ULL
  6979. },
  6980. {
  6981. /* fixed_bit_values */
  6982. 0x0000000000dc0000ULL,
  6983. 0x083a000000000000ULL,
  6984. 0x8000000008040000ULL,
  6985. 0x8802000000000000ULL,
  6986. -1ULL
  6987. }
  6988. },
  6989. { "s1a.sn", TILE_OPC_S1A_SN, 0x3 /* pipes */, 3 /* num_operands */,
  6990. TREG_SN, /* implicitly_written_register */
  6991. 1, /* can_bundle */
  6992. {
  6993. /* operands */
  6994. { 7, 8, 16 },
  6995. { 9, 10, 17 },
  6996. { 0, },
  6997. { 0, },
  6998. { 0, }
  6999. },
  7000. {
  7001. /* fixed_bit_masks */
  7002. 0x800000007ffc0000ULL,
  7003. 0xfffe000000000000ULL,
  7004. 0ULL,
  7005. 0ULL,
  7006. 0ULL
  7007. },
  7008. {
  7009. /* fixed_bit_values */
  7010. 0x0000000008dc0000ULL,
  7011. 0x0c3a000000000000ULL,
  7012. -1ULL,
  7013. -1ULL,
  7014. -1ULL
  7015. }
  7016. },
  7017. { "s2a", TILE_OPC_S2A, 0xf /* pipes */, 3 /* num_operands */,
  7018. TREG_ZERO, /* implicitly_written_register */
  7019. 1, /* can_bundle */
  7020. {
  7021. /* operands */
  7022. { 7, 8, 16 },
  7023. { 9, 10, 17 },
  7024. { 11, 12, 18 },
  7025. { 13, 14, 19 },
  7026. { 0, }
  7027. },
  7028. {
  7029. /* fixed_bit_masks */
  7030. 0x800000007ffc0000ULL,
  7031. 0xfffe000000000000ULL,
  7032. 0x80000000780c0000ULL,
  7033. 0xf806000000000000ULL,
  7034. 0ULL
  7035. },
  7036. {
  7037. /* fixed_bit_values */
  7038. 0x0000000000e00000ULL,
  7039. 0x083c000000000000ULL,
  7040. 0x8000000008080000ULL,
  7041. 0x8804000000000000ULL,
  7042. -1ULL
  7043. }
  7044. },
  7045. { "s2a.sn", TILE_OPC_S2A_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7046. TREG_SN, /* implicitly_written_register */
  7047. 1, /* can_bundle */
  7048. {
  7049. /* operands */
  7050. { 7, 8, 16 },
  7051. { 9, 10, 17 },
  7052. { 0, },
  7053. { 0, },
  7054. { 0, }
  7055. },
  7056. {
  7057. /* fixed_bit_masks */
  7058. 0x800000007ffc0000ULL,
  7059. 0xfffe000000000000ULL,
  7060. 0ULL,
  7061. 0ULL,
  7062. 0ULL
  7063. },
  7064. {
  7065. /* fixed_bit_values */
  7066. 0x0000000008e00000ULL,
  7067. 0x0c3c000000000000ULL,
  7068. -1ULL,
  7069. -1ULL,
  7070. -1ULL
  7071. }
  7072. },
  7073. { "s3a", TILE_OPC_S3A, 0xf /* pipes */, 3 /* num_operands */,
  7074. TREG_ZERO, /* implicitly_written_register */
  7075. 1, /* can_bundle */
  7076. {
  7077. /* operands */
  7078. { 7, 8, 16 },
  7079. { 9, 10, 17 },
  7080. { 11, 12, 18 },
  7081. { 13, 14, 19 },
  7082. { 0, }
  7083. },
  7084. {
  7085. /* fixed_bit_masks */
  7086. 0x800000007ffc0000ULL,
  7087. 0xfffe000000000000ULL,
  7088. 0x80000000780c0000ULL,
  7089. 0xf806000000000000ULL,
  7090. 0ULL
  7091. },
  7092. {
  7093. /* fixed_bit_values */
  7094. 0x0000000000e40000ULL,
  7095. 0x083e000000000000ULL,
  7096. 0x8000000030040000ULL,
  7097. 0xb002000000000000ULL,
  7098. -1ULL
  7099. }
  7100. },
  7101. { "s3a.sn", TILE_OPC_S3A_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7102. TREG_SN, /* implicitly_written_register */
  7103. 1, /* can_bundle */
  7104. {
  7105. /* operands */
  7106. { 7, 8, 16 },
  7107. { 9, 10, 17 },
  7108. { 0, },
  7109. { 0, },
  7110. { 0, }
  7111. },
  7112. {
  7113. /* fixed_bit_masks */
  7114. 0x800000007ffc0000ULL,
  7115. 0xfffe000000000000ULL,
  7116. 0ULL,
  7117. 0ULL,
  7118. 0ULL
  7119. },
  7120. {
  7121. /* fixed_bit_values */
  7122. 0x0000000008e40000ULL,
  7123. 0x0c3e000000000000ULL,
  7124. -1ULL,
  7125. -1ULL,
  7126. -1ULL
  7127. }
  7128. },
  7129. { "sadab_u", TILE_OPC_SADAB_U, 0x1 /* pipes */, 3 /* num_operands */,
  7130. TREG_ZERO, /* implicitly_written_register */
  7131. 1, /* can_bundle */
  7132. {
  7133. /* operands */
  7134. { 21, 8, 16 },
  7135. { 0, },
  7136. { 0, },
  7137. { 0, },
  7138. { 0, }
  7139. },
  7140. {
  7141. /* fixed_bit_masks */
  7142. 0x800000007ffc0000ULL,
  7143. 0ULL,
  7144. 0ULL,
  7145. 0ULL,
  7146. 0ULL
  7147. },
  7148. {
  7149. /* fixed_bit_values */
  7150. 0x0000000000e80000ULL,
  7151. -1ULL,
  7152. -1ULL,
  7153. -1ULL,
  7154. -1ULL
  7155. }
  7156. },
  7157. { "sadab_u.sn", TILE_OPC_SADAB_U_SN, 0x1 /* pipes */, 3 /* num_operands */,
  7158. TREG_SN, /* implicitly_written_register */
  7159. 1, /* can_bundle */
  7160. {
  7161. /* operands */
  7162. { 21, 8, 16 },
  7163. { 0, },
  7164. { 0, },
  7165. { 0, },
  7166. { 0, }
  7167. },
  7168. {
  7169. /* fixed_bit_masks */
  7170. 0x800000007ffc0000ULL,
  7171. 0ULL,
  7172. 0ULL,
  7173. 0ULL,
  7174. 0ULL
  7175. },
  7176. {
  7177. /* fixed_bit_values */
  7178. 0x0000000008e80000ULL,
  7179. -1ULL,
  7180. -1ULL,
  7181. -1ULL,
  7182. -1ULL
  7183. }
  7184. },
  7185. { "sadah", TILE_OPC_SADAH, 0x1 /* pipes */, 3 /* num_operands */,
  7186. TREG_ZERO, /* implicitly_written_register */
  7187. 1, /* can_bundle */
  7188. {
  7189. /* operands */
  7190. { 21, 8, 16 },
  7191. { 0, },
  7192. { 0, },
  7193. { 0, },
  7194. { 0, }
  7195. },
  7196. {
  7197. /* fixed_bit_masks */
  7198. 0x800000007ffc0000ULL,
  7199. 0ULL,
  7200. 0ULL,
  7201. 0ULL,
  7202. 0ULL
  7203. },
  7204. {
  7205. /* fixed_bit_values */
  7206. 0x0000000000ec0000ULL,
  7207. -1ULL,
  7208. -1ULL,
  7209. -1ULL,
  7210. -1ULL
  7211. }
  7212. },
  7213. { "sadah.sn", TILE_OPC_SADAH_SN, 0x1 /* pipes */, 3 /* num_operands */,
  7214. TREG_SN, /* implicitly_written_register */
  7215. 1, /* can_bundle */
  7216. {
  7217. /* operands */
  7218. { 21, 8, 16 },
  7219. { 0, },
  7220. { 0, },
  7221. { 0, },
  7222. { 0, }
  7223. },
  7224. {
  7225. /* fixed_bit_masks */
  7226. 0x800000007ffc0000ULL,
  7227. 0ULL,
  7228. 0ULL,
  7229. 0ULL,
  7230. 0ULL
  7231. },
  7232. {
  7233. /* fixed_bit_values */
  7234. 0x0000000008ec0000ULL,
  7235. -1ULL,
  7236. -1ULL,
  7237. -1ULL,
  7238. -1ULL
  7239. }
  7240. },
  7241. { "sadah_u", TILE_OPC_SADAH_U, 0x1 /* pipes */, 3 /* num_operands */,
  7242. TREG_ZERO, /* implicitly_written_register */
  7243. 1, /* can_bundle */
  7244. {
  7245. /* operands */
  7246. { 21, 8, 16 },
  7247. { 0, },
  7248. { 0, },
  7249. { 0, },
  7250. { 0, }
  7251. },
  7252. {
  7253. /* fixed_bit_masks */
  7254. 0x800000007ffc0000ULL,
  7255. 0ULL,
  7256. 0ULL,
  7257. 0ULL,
  7258. 0ULL
  7259. },
  7260. {
  7261. /* fixed_bit_values */
  7262. 0x0000000000f00000ULL,
  7263. -1ULL,
  7264. -1ULL,
  7265. -1ULL,
  7266. -1ULL
  7267. }
  7268. },
  7269. { "sadah_u.sn", TILE_OPC_SADAH_U_SN, 0x1 /* pipes */, 3 /* num_operands */,
  7270. TREG_SN, /* implicitly_written_register */
  7271. 1, /* can_bundle */
  7272. {
  7273. /* operands */
  7274. { 21, 8, 16 },
  7275. { 0, },
  7276. { 0, },
  7277. { 0, },
  7278. { 0, }
  7279. },
  7280. {
  7281. /* fixed_bit_masks */
  7282. 0x800000007ffc0000ULL,
  7283. 0ULL,
  7284. 0ULL,
  7285. 0ULL,
  7286. 0ULL
  7287. },
  7288. {
  7289. /* fixed_bit_values */
  7290. 0x0000000008f00000ULL,
  7291. -1ULL,
  7292. -1ULL,
  7293. -1ULL,
  7294. -1ULL
  7295. }
  7296. },
  7297. { "sadb_u", TILE_OPC_SADB_U, 0x1 /* pipes */, 3 /* num_operands */,
  7298. TREG_ZERO, /* implicitly_written_register */
  7299. 1, /* can_bundle */
  7300. {
  7301. /* operands */
  7302. { 7, 8, 16 },
  7303. { 0, },
  7304. { 0, },
  7305. { 0, },
  7306. { 0, }
  7307. },
  7308. {
  7309. /* fixed_bit_masks */
  7310. 0x800000007ffc0000ULL,
  7311. 0ULL,
  7312. 0ULL,
  7313. 0ULL,
  7314. 0ULL
  7315. },
  7316. {
  7317. /* fixed_bit_values */
  7318. 0x0000000000f40000ULL,
  7319. -1ULL,
  7320. -1ULL,
  7321. -1ULL,
  7322. -1ULL
  7323. }
  7324. },
  7325. { "sadb_u.sn", TILE_OPC_SADB_U_SN, 0x1 /* pipes */, 3 /* num_operands */,
  7326. TREG_SN, /* implicitly_written_register */
  7327. 1, /* can_bundle */
  7328. {
  7329. /* operands */
  7330. { 7, 8, 16 },
  7331. { 0, },
  7332. { 0, },
  7333. { 0, },
  7334. { 0, }
  7335. },
  7336. {
  7337. /* fixed_bit_masks */
  7338. 0x800000007ffc0000ULL,
  7339. 0ULL,
  7340. 0ULL,
  7341. 0ULL,
  7342. 0ULL
  7343. },
  7344. {
  7345. /* fixed_bit_values */
  7346. 0x0000000008f40000ULL,
  7347. -1ULL,
  7348. -1ULL,
  7349. -1ULL,
  7350. -1ULL
  7351. }
  7352. },
  7353. { "sadh", TILE_OPC_SADH, 0x1 /* pipes */, 3 /* num_operands */,
  7354. TREG_ZERO, /* implicitly_written_register */
  7355. 1, /* can_bundle */
  7356. {
  7357. /* operands */
  7358. { 7, 8, 16 },
  7359. { 0, },
  7360. { 0, },
  7361. { 0, },
  7362. { 0, }
  7363. },
  7364. {
  7365. /* fixed_bit_masks */
  7366. 0x800000007ffc0000ULL,
  7367. 0ULL,
  7368. 0ULL,
  7369. 0ULL,
  7370. 0ULL
  7371. },
  7372. {
  7373. /* fixed_bit_values */
  7374. 0x0000000000f80000ULL,
  7375. -1ULL,
  7376. -1ULL,
  7377. -1ULL,
  7378. -1ULL
  7379. }
  7380. },
  7381. { "sadh.sn", TILE_OPC_SADH_SN, 0x1 /* pipes */, 3 /* num_operands */,
  7382. TREG_SN, /* implicitly_written_register */
  7383. 1, /* can_bundle */
  7384. {
  7385. /* operands */
  7386. { 7, 8, 16 },
  7387. { 0, },
  7388. { 0, },
  7389. { 0, },
  7390. { 0, }
  7391. },
  7392. {
  7393. /* fixed_bit_masks */
  7394. 0x800000007ffc0000ULL,
  7395. 0ULL,
  7396. 0ULL,
  7397. 0ULL,
  7398. 0ULL
  7399. },
  7400. {
  7401. /* fixed_bit_values */
  7402. 0x0000000008f80000ULL,
  7403. -1ULL,
  7404. -1ULL,
  7405. -1ULL,
  7406. -1ULL
  7407. }
  7408. },
  7409. { "sadh_u", TILE_OPC_SADH_U, 0x1 /* pipes */, 3 /* num_operands */,
  7410. TREG_ZERO, /* implicitly_written_register */
  7411. 1, /* can_bundle */
  7412. {
  7413. /* operands */
  7414. { 7, 8, 16 },
  7415. { 0, },
  7416. { 0, },
  7417. { 0, },
  7418. { 0, }
  7419. },
  7420. {
  7421. /* fixed_bit_masks */
  7422. 0x800000007ffc0000ULL,
  7423. 0ULL,
  7424. 0ULL,
  7425. 0ULL,
  7426. 0ULL
  7427. },
  7428. {
  7429. /* fixed_bit_values */
  7430. 0x0000000000fc0000ULL,
  7431. -1ULL,
  7432. -1ULL,
  7433. -1ULL,
  7434. -1ULL
  7435. }
  7436. },
  7437. { "sadh_u.sn", TILE_OPC_SADH_U_SN, 0x1 /* pipes */, 3 /* num_operands */,
  7438. TREG_SN, /* implicitly_written_register */
  7439. 1, /* can_bundle */
  7440. {
  7441. /* operands */
  7442. { 7, 8, 16 },
  7443. { 0, },
  7444. { 0, },
  7445. { 0, },
  7446. { 0, }
  7447. },
  7448. {
  7449. /* fixed_bit_masks */
  7450. 0x800000007ffc0000ULL,
  7451. 0ULL,
  7452. 0ULL,
  7453. 0ULL,
  7454. 0ULL
  7455. },
  7456. {
  7457. /* fixed_bit_values */
  7458. 0x0000000008fc0000ULL,
  7459. -1ULL,
  7460. -1ULL,
  7461. -1ULL,
  7462. -1ULL
  7463. }
  7464. },
  7465. { "sb", TILE_OPC_SB, 0x12 /* pipes */, 2 /* num_operands */,
  7466. TREG_ZERO, /* implicitly_written_register */
  7467. 1, /* can_bundle */
  7468. {
  7469. /* operands */
  7470. { 0, },
  7471. { 10, 17 },
  7472. { 0, },
  7473. { 0, },
  7474. { 15, 36 }
  7475. },
  7476. {
  7477. /* fixed_bit_masks */
  7478. 0ULL,
  7479. 0xfbfe000000000000ULL,
  7480. 0ULL,
  7481. 0ULL,
  7482. 0x8700000000000000ULL
  7483. },
  7484. {
  7485. /* fixed_bit_values */
  7486. -1ULL,
  7487. 0x0840000000000000ULL,
  7488. -1ULL,
  7489. -1ULL,
  7490. 0x8500000000000000ULL
  7491. }
  7492. },
  7493. { "sbadd", TILE_OPC_SBADD, 0x2 /* pipes */, 3 /* num_operands */,
  7494. TREG_ZERO, /* implicitly_written_register */
  7495. 1, /* can_bundle */
  7496. {
  7497. /* operands */
  7498. { 0, },
  7499. { 24, 17, 37 },
  7500. { 0, },
  7501. { 0, },
  7502. { 0, }
  7503. },
  7504. {
  7505. /* fixed_bit_masks */
  7506. 0ULL,
  7507. 0xfbf8000000000000ULL,
  7508. 0ULL,
  7509. 0ULL,
  7510. 0ULL
  7511. },
  7512. {
  7513. /* fixed_bit_values */
  7514. -1ULL,
  7515. 0x30e0000000000000ULL,
  7516. -1ULL,
  7517. -1ULL,
  7518. -1ULL
  7519. }
  7520. },
  7521. { "seq", TILE_OPC_SEQ, 0xf /* pipes */, 3 /* num_operands */,
  7522. TREG_ZERO, /* implicitly_written_register */
  7523. 1, /* can_bundle */
  7524. {
  7525. /* operands */
  7526. { 7, 8, 16 },
  7527. { 9, 10, 17 },
  7528. { 11, 12, 18 },
  7529. { 13, 14, 19 },
  7530. { 0, }
  7531. },
  7532. {
  7533. /* fixed_bit_masks */
  7534. 0x800000007ffc0000ULL,
  7535. 0xfffe000000000000ULL,
  7536. 0x80000000780c0000ULL,
  7537. 0xf806000000000000ULL,
  7538. 0ULL
  7539. },
  7540. {
  7541. /* fixed_bit_values */
  7542. 0x0000000001080000ULL,
  7543. 0x0846000000000000ULL,
  7544. 0x8000000030080000ULL,
  7545. 0xb004000000000000ULL,
  7546. -1ULL
  7547. }
  7548. },
  7549. { "seq.sn", TILE_OPC_SEQ_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7550. TREG_SN, /* implicitly_written_register */
  7551. 1, /* can_bundle */
  7552. {
  7553. /* operands */
  7554. { 7, 8, 16 },
  7555. { 9, 10, 17 },
  7556. { 0, },
  7557. { 0, },
  7558. { 0, }
  7559. },
  7560. {
  7561. /* fixed_bit_masks */
  7562. 0x800000007ffc0000ULL,
  7563. 0xfffe000000000000ULL,
  7564. 0ULL,
  7565. 0ULL,
  7566. 0ULL
  7567. },
  7568. {
  7569. /* fixed_bit_values */
  7570. 0x0000000009080000ULL,
  7571. 0x0c46000000000000ULL,
  7572. -1ULL,
  7573. -1ULL,
  7574. -1ULL
  7575. }
  7576. },
  7577. { "seqb", TILE_OPC_SEQB, 0x3 /* pipes */, 3 /* num_operands */,
  7578. TREG_ZERO, /* implicitly_written_register */
  7579. 1, /* can_bundle */
  7580. {
  7581. /* operands */
  7582. { 7, 8, 16 },
  7583. { 9, 10, 17 },
  7584. { 0, },
  7585. { 0, },
  7586. { 0, }
  7587. },
  7588. {
  7589. /* fixed_bit_masks */
  7590. 0x800000007ffc0000ULL,
  7591. 0xfffe000000000000ULL,
  7592. 0ULL,
  7593. 0ULL,
  7594. 0ULL
  7595. },
  7596. {
  7597. /* fixed_bit_values */
  7598. 0x0000000001000000ULL,
  7599. 0x0842000000000000ULL,
  7600. -1ULL,
  7601. -1ULL,
  7602. -1ULL
  7603. }
  7604. },
  7605. { "seqb.sn", TILE_OPC_SEQB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7606. TREG_SN, /* implicitly_written_register */
  7607. 1, /* can_bundle */
  7608. {
  7609. /* operands */
  7610. { 7, 8, 16 },
  7611. { 9, 10, 17 },
  7612. { 0, },
  7613. { 0, },
  7614. { 0, }
  7615. },
  7616. {
  7617. /* fixed_bit_masks */
  7618. 0x800000007ffc0000ULL,
  7619. 0xfffe000000000000ULL,
  7620. 0ULL,
  7621. 0ULL,
  7622. 0ULL
  7623. },
  7624. {
  7625. /* fixed_bit_values */
  7626. 0x0000000009000000ULL,
  7627. 0x0c42000000000000ULL,
  7628. -1ULL,
  7629. -1ULL,
  7630. -1ULL
  7631. }
  7632. },
  7633. { "seqh", TILE_OPC_SEQH, 0x3 /* pipes */, 3 /* num_operands */,
  7634. TREG_ZERO, /* implicitly_written_register */
  7635. 1, /* can_bundle */
  7636. {
  7637. /* operands */
  7638. { 7, 8, 16 },
  7639. { 9, 10, 17 },
  7640. { 0, },
  7641. { 0, },
  7642. { 0, }
  7643. },
  7644. {
  7645. /* fixed_bit_masks */
  7646. 0x800000007ffc0000ULL,
  7647. 0xfffe000000000000ULL,
  7648. 0ULL,
  7649. 0ULL,
  7650. 0ULL
  7651. },
  7652. {
  7653. /* fixed_bit_values */
  7654. 0x0000000001040000ULL,
  7655. 0x0844000000000000ULL,
  7656. -1ULL,
  7657. -1ULL,
  7658. -1ULL
  7659. }
  7660. },
  7661. { "seqh.sn", TILE_OPC_SEQH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7662. TREG_SN, /* implicitly_written_register */
  7663. 1, /* can_bundle */
  7664. {
  7665. /* operands */
  7666. { 7, 8, 16 },
  7667. { 9, 10, 17 },
  7668. { 0, },
  7669. { 0, },
  7670. { 0, }
  7671. },
  7672. {
  7673. /* fixed_bit_masks */
  7674. 0x800000007ffc0000ULL,
  7675. 0xfffe000000000000ULL,
  7676. 0ULL,
  7677. 0ULL,
  7678. 0ULL
  7679. },
  7680. {
  7681. /* fixed_bit_values */
  7682. 0x0000000009040000ULL,
  7683. 0x0c44000000000000ULL,
  7684. -1ULL,
  7685. -1ULL,
  7686. -1ULL
  7687. }
  7688. },
  7689. { "seqi", TILE_OPC_SEQI, 0xf /* pipes */, 3 /* num_operands */,
  7690. TREG_ZERO, /* implicitly_written_register */
  7691. 1, /* can_bundle */
  7692. {
  7693. /* operands */
  7694. { 7, 8, 0 },
  7695. { 9, 10, 1 },
  7696. { 11, 12, 2 },
  7697. { 13, 14, 3 },
  7698. { 0, }
  7699. },
  7700. {
  7701. /* fixed_bit_masks */
  7702. 0x800000007ff00000ULL,
  7703. 0xfff8000000000000ULL,
  7704. 0x8000000078000000ULL,
  7705. 0xf800000000000000ULL,
  7706. 0ULL
  7707. },
  7708. {
  7709. /* fixed_bit_values */
  7710. 0x0000000040b00000ULL,
  7711. 0x3070000000000000ULL,
  7712. 0x8000000060000000ULL,
  7713. 0xd000000000000000ULL,
  7714. -1ULL
  7715. }
  7716. },
  7717. { "seqi.sn", TILE_OPC_SEQI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7718. TREG_SN, /* implicitly_written_register */
  7719. 1, /* can_bundle */
  7720. {
  7721. /* operands */
  7722. { 7, 8, 0 },
  7723. { 9, 10, 1 },
  7724. { 0, },
  7725. { 0, },
  7726. { 0, }
  7727. },
  7728. {
  7729. /* fixed_bit_masks */
  7730. 0x800000007ff00000ULL,
  7731. 0xfff8000000000000ULL,
  7732. 0ULL,
  7733. 0ULL,
  7734. 0ULL
  7735. },
  7736. {
  7737. /* fixed_bit_values */
  7738. 0x0000000048b00000ULL,
  7739. 0x3470000000000000ULL,
  7740. -1ULL,
  7741. -1ULL,
  7742. -1ULL
  7743. }
  7744. },
  7745. { "seqib", TILE_OPC_SEQIB, 0x3 /* pipes */, 3 /* num_operands */,
  7746. TREG_ZERO, /* implicitly_written_register */
  7747. 1, /* can_bundle */
  7748. {
  7749. /* operands */
  7750. { 7, 8, 0 },
  7751. { 9, 10, 1 },
  7752. { 0, },
  7753. { 0, },
  7754. { 0, }
  7755. },
  7756. {
  7757. /* fixed_bit_masks */
  7758. 0x800000007ff00000ULL,
  7759. 0xfff8000000000000ULL,
  7760. 0ULL,
  7761. 0ULL,
  7762. 0ULL
  7763. },
  7764. {
  7765. /* fixed_bit_values */
  7766. 0x0000000040900000ULL,
  7767. 0x3060000000000000ULL,
  7768. -1ULL,
  7769. -1ULL,
  7770. -1ULL
  7771. }
  7772. },
  7773. { "seqib.sn", TILE_OPC_SEQIB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7774. TREG_SN, /* implicitly_written_register */
  7775. 1, /* can_bundle */
  7776. {
  7777. /* operands */
  7778. { 7, 8, 0 },
  7779. { 9, 10, 1 },
  7780. { 0, },
  7781. { 0, },
  7782. { 0, }
  7783. },
  7784. {
  7785. /* fixed_bit_masks */
  7786. 0x800000007ff00000ULL,
  7787. 0xfff8000000000000ULL,
  7788. 0ULL,
  7789. 0ULL,
  7790. 0ULL
  7791. },
  7792. {
  7793. /* fixed_bit_values */
  7794. 0x0000000048900000ULL,
  7795. 0x3460000000000000ULL,
  7796. -1ULL,
  7797. -1ULL,
  7798. -1ULL
  7799. }
  7800. },
  7801. { "seqih", TILE_OPC_SEQIH, 0x3 /* pipes */, 3 /* num_operands */,
  7802. TREG_ZERO, /* implicitly_written_register */
  7803. 1, /* can_bundle */
  7804. {
  7805. /* operands */
  7806. { 7, 8, 0 },
  7807. { 9, 10, 1 },
  7808. { 0, },
  7809. { 0, },
  7810. { 0, }
  7811. },
  7812. {
  7813. /* fixed_bit_masks */
  7814. 0x800000007ff00000ULL,
  7815. 0xfff8000000000000ULL,
  7816. 0ULL,
  7817. 0ULL,
  7818. 0ULL
  7819. },
  7820. {
  7821. /* fixed_bit_values */
  7822. 0x0000000040a00000ULL,
  7823. 0x3068000000000000ULL,
  7824. -1ULL,
  7825. -1ULL,
  7826. -1ULL
  7827. }
  7828. },
  7829. { "seqih.sn", TILE_OPC_SEQIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7830. TREG_SN, /* implicitly_written_register */
  7831. 1, /* can_bundle */
  7832. {
  7833. /* operands */
  7834. { 7, 8, 0 },
  7835. { 9, 10, 1 },
  7836. { 0, },
  7837. { 0, },
  7838. { 0, }
  7839. },
  7840. {
  7841. /* fixed_bit_masks */
  7842. 0x800000007ff00000ULL,
  7843. 0xfff8000000000000ULL,
  7844. 0ULL,
  7845. 0ULL,
  7846. 0ULL
  7847. },
  7848. {
  7849. /* fixed_bit_values */
  7850. 0x0000000048a00000ULL,
  7851. 0x3468000000000000ULL,
  7852. -1ULL,
  7853. -1ULL,
  7854. -1ULL
  7855. }
  7856. },
  7857. { "sh", TILE_OPC_SH, 0x12 /* pipes */, 2 /* num_operands */,
  7858. TREG_ZERO, /* implicitly_written_register */
  7859. 1, /* can_bundle */
  7860. {
  7861. /* operands */
  7862. { 0, },
  7863. { 10, 17 },
  7864. { 0, },
  7865. { 0, },
  7866. { 15, 36 }
  7867. },
  7868. {
  7869. /* fixed_bit_masks */
  7870. 0ULL,
  7871. 0xfbfe000000000000ULL,
  7872. 0ULL,
  7873. 0ULL,
  7874. 0x8700000000000000ULL
  7875. },
  7876. {
  7877. /* fixed_bit_values */
  7878. -1ULL,
  7879. 0x0854000000000000ULL,
  7880. -1ULL,
  7881. -1ULL,
  7882. 0x8600000000000000ULL
  7883. }
  7884. },
  7885. { "shadd", TILE_OPC_SHADD, 0x2 /* pipes */, 3 /* num_operands */,
  7886. TREG_ZERO, /* implicitly_written_register */
  7887. 1, /* can_bundle */
  7888. {
  7889. /* operands */
  7890. { 0, },
  7891. { 24, 17, 37 },
  7892. { 0, },
  7893. { 0, },
  7894. { 0, }
  7895. },
  7896. {
  7897. /* fixed_bit_masks */
  7898. 0ULL,
  7899. 0xfbf8000000000000ULL,
  7900. 0ULL,
  7901. 0ULL,
  7902. 0ULL
  7903. },
  7904. {
  7905. /* fixed_bit_values */
  7906. -1ULL,
  7907. 0x30e8000000000000ULL,
  7908. -1ULL,
  7909. -1ULL,
  7910. -1ULL
  7911. }
  7912. },
  7913. { "shl", TILE_OPC_SHL, 0xf /* pipes */, 3 /* num_operands */,
  7914. TREG_ZERO, /* implicitly_written_register */
  7915. 1, /* can_bundle */
  7916. {
  7917. /* operands */
  7918. { 7, 8, 16 },
  7919. { 9, 10, 17 },
  7920. { 11, 12, 18 },
  7921. { 13, 14, 19 },
  7922. { 0, }
  7923. },
  7924. {
  7925. /* fixed_bit_masks */
  7926. 0x800000007ffc0000ULL,
  7927. 0xfffe000000000000ULL,
  7928. 0x80000000780c0000ULL,
  7929. 0xf806000000000000ULL,
  7930. 0ULL
  7931. },
  7932. {
  7933. /* fixed_bit_values */
  7934. 0x0000000001140000ULL,
  7935. 0x084c000000000000ULL,
  7936. 0x8000000020040000ULL,
  7937. 0xa002000000000000ULL,
  7938. -1ULL
  7939. }
  7940. },
  7941. { "shl.sn", TILE_OPC_SHL_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7942. TREG_SN, /* implicitly_written_register */
  7943. 1, /* can_bundle */
  7944. {
  7945. /* operands */
  7946. { 7, 8, 16 },
  7947. { 9, 10, 17 },
  7948. { 0, },
  7949. { 0, },
  7950. { 0, }
  7951. },
  7952. {
  7953. /* fixed_bit_masks */
  7954. 0x800000007ffc0000ULL,
  7955. 0xfffe000000000000ULL,
  7956. 0ULL,
  7957. 0ULL,
  7958. 0ULL
  7959. },
  7960. {
  7961. /* fixed_bit_values */
  7962. 0x0000000009140000ULL,
  7963. 0x0c4c000000000000ULL,
  7964. -1ULL,
  7965. -1ULL,
  7966. -1ULL
  7967. }
  7968. },
  7969. { "shlb", TILE_OPC_SHLB, 0x3 /* pipes */, 3 /* num_operands */,
  7970. TREG_ZERO, /* implicitly_written_register */
  7971. 1, /* can_bundle */
  7972. {
  7973. /* operands */
  7974. { 7, 8, 16 },
  7975. { 9, 10, 17 },
  7976. { 0, },
  7977. { 0, },
  7978. { 0, }
  7979. },
  7980. {
  7981. /* fixed_bit_masks */
  7982. 0x800000007ffc0000ULL,
  7983. 0xfffe000000000000ULL,
  7984. 0ULL,
  7985. 0ULL,
  7986. 0ULL
  7987. },
  7988. {
  7989. /* fixed_bit_values */
  7990. 0x00000000010c0000ULL,
  7991. 0x0848000000000000ULL,
  7992. -1ULL,
  7993. -1ULL,
  7994. -1ULL
  7995. }
  7996. },
  7997. { "shlb.sn", TILE_OPC_SHLB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  7998. TREG_SN, /* implicitly_written_register */
  7999. 1, /* can_bundle */
  8000. {
  8001. /* operands */
  8002. { 7, 8, 16 },
  8003. { 9, 10, 17 },
  8004. { 0, },
  8005. { 0, },
  8006. { 0, }
  8007. },
  8008. {
  8009. /* fixed_bit_masks */
  8010. 0x800000007ffc0000ULL,
  8011. 0xfffe000000000000ULL,
  8012. 0ULL,
  8013. 0ULL,
  8014. 0ULL
  8015. },
  8016. {
  8017. /* fixed_bit_values */
  8018. 0x00000000090c0000ULL,
  8019. 0x0c48000000000000ULL,
  8020. -1ULL,
  8021. -1ULL,
  8022. -1ULL
  8023. }
  8024. },
  8025. { "shlh", TILE_OPC_SHLH, 0x3 /* pipes */, 3 /* num_operands */,
  8026. TREG_ZERO, /* implicitly_written_register */
  8027. 1, /* can_bundle */
  8028. {
  8029. /* operands */
  8030. { 7, 8, 16 },
  8031. { 9, 10, 17 },
  8032. { 0, },
  8033. { 0, },
  8034. { 0, }
  8035. },
  8036. {
  8037. /* fixed_bit_masks */
  8038. 0x800000007ffc0000ULL,
  8039. 0xfffe000000000000ULL,
  8040. 0ULL,
  8041. 0ULL,
  8042. 0ULL
  8043. },
  8044. {
  8045. /* fixed_bit_values */
  8046. 0x0000000001100000ULL,
  8047. 0x084a000000000000ULL,
  8048. -1ULL,
  8049. -1ULL,
  8050. -1ULL
  8051. }
  8052. },
  8053. { "shlh.sn", TILE_OPC_SHLH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8054. TREG_SN, /* implicitly_written_register */
  8055. 1, /* can_bundle */
  8056. {
  8057. /* operands */
  8058. { 7, 8, 16 },
  8059. { 9, 10, 17 },
  8060. { 0, },
  8061. { 0, },
  8062. { 0, }
  8063. },
  8064. {
  8065. /* fixed_bit_masks */
  8066. 0x800000007ffc0000ULL,
  8067. 0xfffe000000000000ULL,
  8068. 0ULL,
  8069. 0ULL,
  8070. 0ULL
  8071. },
  8072. {
  8073. /* fixed_bit_values */
  8074. 0x0000000009100000ULL,
  8075. 0x0c4a000000000000ULL,
  8076. -1ULL,
  8077. -1ULL,
  8078. -1ULL
  8079. }
  8080. },
  8081. { "shli", TILE_OPC_SHLI, 0xf /* pipes */, 3 /* num_operands */,
  8082. TREG_ZERO, /* implicitly_written_register */
  8083. 1, /* can_bundle */
  8084. {
  8085. /* operands */
  8086. { 7, 8, 32 },
  8087. { 9, 10, 33 },
  8088. { 11, 12, 34 },
  8089. { 13, 14, 35 },
  8090. { 0, }
  8091. },
  8092. {
  8093. /* fixed_bit_masks */
  8094. 0x800000007ffe0000ULL,
  8095. 0xffff000000000000ULL,
  8096. 0x80000000780e0000ULL,
  8097. 0xf807000000000000ULL,
  8098. 0ULL
  8099. },
  8100. {
  8101. /* fixed_bit_values */
  8102. 0x0000000070080000ULL,
  8103. 0x4004000000000000ULL,
  8104. 0x8000000068040000ULL,
  8105. 0xd802000000000000ULL,
  8106. -1ULL
  8107. }
  8108. },
  8109. { "shli.sn", TILE_OPC_SHLI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8110. TREG_SN, /* implicitly_written_register */
  8111. 1, /* can_bundle */
  8112. {
  8113. /* operands */
  8114. { 7, 8, 32 },
  8115. { 9, 10, 33 },
  8116. { 0, },
  8117. { 0, },
  8118. { 0, }
  8119. },
  8120. {
  8121. /* fixed_bit_masks */
  8122. 0x800000007ffe0000ULL,
  8123. 0xffff000000000000ULL,
  8124. 0ULL,
  8125. 0ULL,
  8126. 0ULL
  8127. },
  8128. {
  8129. /* fixed_bit_values */
  8130. 0x0000000078080000ULL,
  8131. 0x4404000000000000ULL,
  8132. -1ULL,
  8133. -1ULL,
  8134. -1ULL
  8135. }
  8136. },
  8137. { "shlib", TILE_OPC_SHLIB, 0x3 /* pipes */, 3 /* num_operands */,
  8138. TREG_ZERO, /* implicitly_written_register */
  8139. 1, /* can_bundle */
  8140. {
  8141. /* operands */
  8142. { 7, 8, 32 },
  8143. { 9, 10, 33 },
  8144. { 0, },
  8145. { 0, },
  8146. { 0, }
  8147. },
  8148. {
  8149. /* fixed_bit_masks */
  8150. 0x800000007ffe0000ULL,
  8151. 0xffff000000000000ULL,
  8152. 0ULL,
  8153. 0ULL,
  8154. 0ULL
  8155. },
  8156. {
  8157. /* fixed_bit_values */
  8158. 0x0000000070040000ULL,
  8159. 0x4002000000000000ULL,
  8160. -1ULL,
  8161. -1ULL,
  8162. -1ULL
  8163. }
  8164. },
  8165. { "shlib.sn", TILE_OPC_SHLIB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8166. TREG_SN, /* implicitly_written_register */
  8167. 1, /* can_bundle */
  8168. {
  8169. /* operands */
  8170. { 7, 8, 32 },
  8171. { 9, 10, 33 },
  8172. { 0, },
  8173. { 0, },
  8174. { 0, }
  8175. },
  8176. {
  8177. /* fixed_bit_masks */
  8178. 0x800000007ffe0000ULL,
  8179. 0xffff000000000000ULL,
  8180. 0ULL,
  8181. 0ULL,
  8182. 0ULL
  8183. },
  8184. {
  8185. /* fixed_bit_values */
  8186. 0x0000000078040000ULL,
  8187. 0x4402000000000000ULL,
  8188. -1ULL,
  8189. -1ULL,
  8190. -1ULL
  8191. }
  8192. },
  8193. { "shlih", TILE_OPC_SHLIH, 0x3 /* pipes */, 3 /* num_operands */,
  8194. TREG_ZERO, /* implicitly_written_register */
  8195. 1, /* can_bundle */
  8196. {
  8197. /* operands */
  8198. { 7, 8, 32 },
  8199. { 9, 10, 33 },
  8200. { 0, },
  8201. { 0, },
  8202. { 0, }
  8203. },
  8204. {
  8205. /* fixed_bit_masks */
  8206. 0x800000007ffe0000ULL,
  8207. 0xffff000000000000ULL,
  8208. 0ULL,
  8209. 0ULL,
  8210. 0ULL
  8211. },
  8212. {
  8213. /* fixed_bit_values */
  8214. 0x0000000070060000ULL,
  8215. 0x4003000000000000ULL,
  8216. -1ULL,
  8217. -1ULL,
  8218. -1ULL
  8219. }
  8220. },
  8221. { "shlih.sn", TILE_OPC_SHLIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8222. TREG_SN, /* implicitly_written_register */
  8223. 1, /* can_bundle */
  8224. {
  8225. /* operands */
  8226. { 7, 8, 32 },
  8227. { 9, 10, 33 },
  8228. { 0, },
  8229. { 0, },
  8230. { 0, }
  8231. },
  8232. {
  8233. /* fixed_bit_masks */
  8234. 0x800000007ffe0000ULL,
  8235. 0xffff000000000000ULL,
  8236. 0ULL,
  8237. 0ULL,
  8238. 0ULL
  8239. },
  8240. {
  8241. /* fixed_bit_values */
  8242. 0x0000000078060000ULL,
  8243. 0x4403000000000000ULL,
  8244. -1ULL,
  8245. -1ULL,
  8246. -1ULL
  8247. }
  8248. },
  8249. { "shr", TILE_OPC_SHR, 0xf /* pipes */, 3 /* num_operands */,
  8250. TREG_ZERO, /* implicitly_written_register */
  8251. 1, /* can_bundle */
  8252. {
  8253. /* operands */
  8254. { 7, 8, 16 },
  8255. { 9, 10, 17 },
  8256. { 11, 12, 18 },
  8257. { 13, 14, 19 },
  8258. { 0, }
  8259. },
  8260. {
  8261. /* fixed_bit_masks */
  8262. 0x800000007ffc0000ULL,
  8263. 0xfffe000000000000ULL,
  8264. 0x80000000780c0000ULL,
  8265. 0xf806000000000000ULL,
  8266. 0ULL
  8267. },
  8268. {
  8269. /* fixed_bit_values */
  8270. 0x0000000001200000ULL,
  8271. 0x0852000000000000ULL,
  8272. 0x8000000020080000ULL,
  8273. 0xa004000000000000ULL,
  8274. -1ULL
  8275. }
  8276. },
  8277. { "shr.sn", TILE_OPC_SHR_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8278. TREG_SN, /* implicitly_written_register */
  8279. 1, /* can_bundle */
  8280. {
  8281. /* operands */
  8282. { 7, 8, 16 },
  8283. { 9, 10, 17 },
  8284. { 0, },
  8285. { 0, },
  8286. { 0, }
  8287. },
  8288. {
  8289. /* fixed_bit_masks */
  8290. 0x800000007ffc0000ULL,
  8291. 0xfffe000000000000ULL,
  8292. 0ULL,
  8293. 0ULL,
  8294. 0ULL
  8295. },
  8296. {
  8297. /* fixed_bit_values */
  8298. 0x0000000009200000ULL,
  8299. 0x0c52000000000000ULL,
  8300. -1ULL,
  8301. -1ULL,
  8302. -1ULL
  8303. }
  8304. },
  8305. { "shrb", TILE_OPC_SHRB, 0x3 /* pipes */, 3 /* num_operands */,
  8306. TREG_ZERO, /* implicitly_written_register */
  8307. 1, /* can_bundle */
  8308. {
  8309. /* operands */
  8310. { 7, 8, 16 },
  8311. { 9, 10, 17 },
  8312. { 0, },
  8313. { 0, },
  8314. { 0, }
  8315. },
  8316. {
  8317. /* fixed_bit_masks */
  8318. 0x800000007ffc0000ULL,
  8319. 0xfffe000000000000ULL,
  8320. 0ULL,
  8321. 0ULL,
  8322. 0ULL
  8323. },
  8324. {
  8325. /* fixed_bit_values */
  8326. 0x0000000001180000ULL,
  8327. 0x084e000000000000ULL,
  8328. -1ULL,
  8329. -1ULL,
  8330. -1ULL
  8331. }
  8332. },
  8333. { "shrb.sn", TILE_OPC_SHRB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8334. TREG_SN, /* implicitly_written_register */
  8335. 1, /* can_bundle */
  8336. {
  8337. /* operands */
  8338. { 7, 8, 16 },
  8339. { 9, 10, 17 },
  8340. { 0, },
  8341. { 0, },
  8342. { 0, }
  8343. },
  8344. {
  8345. /* fixed_bit_masks */
  8346. 0x800000007ffc0000ULL,
  8347. 0xfffe000000000000ULL,
  8348. 0ULL,
  8349. 0ULL,
  8350. 0ULL
  8351. },
  8352. {
  8353. /* fixed_bit_values */
  8354. 0x0000000009180000ULL,
  8355. 0x0c4e000000000000ULL,
  8356. -1ULL,
  8357. -1ULL,
  8358. -1ULL
  8359. }
  8360. },
  8361. { "shrh", TILE_OPC_SHRH, 0x3 /* pipes */, 3 /* num_operands */,
  8362. TREG_ZERO, /* implicitly_written_register */
  8363. 1, /* can_bundle */
  8364. {
  8365. /* operands */
  8366. { 7, 8, 16 },
  8367. { 9, 10, 17 },
  8368. { 0, },
  8369. { 0, },
  8370. { 0, }
  8371. },
  8372. {
  8373. /* fixed_bit_masks */
  8374. 0x800000007ffc0000ULL,
  8375. 0xfffe000000000000ULL,
  8376. 0ULL,
  8377. 0ULL,
  8378. 0ULL
  8379. },
  8380. {
  8381. /* fixed_bit_values */
  8382. 0x00000000011c0000ULL,
  8383. 0x0850000000000000ULL,
  8384. -1ULL,
  8385. -1ULL,
  8386. -1ULL
  8387. }
  8388. },
  8389. { "shrh.sn", TILE_OPC_SHRH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8390. TREG_SN, /* implicitly_written_register */
  8391. 1, /* can_bundle */
  8392. {
  8393. /* operands */
  8394. { 7, 8, 16 },
  8395. { 9, 10, 17 },
  8396. { 0, },
  8397. { 0, },
  8398. { 0, }
  8399. },
  8400. {
  8401. /* fixed_bit_masks */
  8402. 0x800000007ffc0000ULL,
  8403. 0xfffe000000000000ULL,
  8404. 0ULL,
  8405. 0ULL,
  8406. 0ULL
  8407. },
  8408. {
  8409. /* fixed_bit_values */
  8410. 0x00000000091c0000ULL,
  8411. 0x0c50000000000000ULL,
  8412. -1ULL,
  8413. -1ULL,
  8414. -1ULL
  8415. }
  8416. },
  8417. { "shri", TILE_OPC_SHRI, 0xf /* pipes */, 3 /* num_operands */,
  8418. TREG_ZERO, /* implicitly_written_register */
  8419. 1, /* can_bundle */
  8420. {
  8421. /* operands */
  8422. { 7, 8, 32 },
  8423. { 9, 10, 33 },
  8424. { 11, 12, 34 },
  8425. { 13, 14, 35 },
  8426. { 0, }
  8427. },
  8428. {
  8429. /* fixed_bit_masks */
  8430. 0x800000007ffe0000ULL,
  8431. 0xffff000000000000ULL,
  8432. 0x80000000780e0000ULL,
  8433. 0xf807000000000000ULL,
  8434. 0ULL
  8435. },
  8436. {
  8437. /* fixed_bit_values */
  8438. 0x00000000700e0000ULL,
  8439. 0x4007000000000000ULL,
  8440. 0x8000000068060000ULL,
  8441. 0xd803000000000000ULL,
  8442. -1ULL
  8443. }
  8444. },
  8445. { "shri.sn", TILE_OPC_SHRI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8446. TREG_SN, /* implicitly_written_register */
  8447. 1, /* can_bundle */
  8448. {
  8449. /* operands */
  8450. { 7, 8, 32 },
  8451. { 9, 10, 33 },
  8452. { 0, },
  8453. { 0, },
  8454. { 0, }
  8455. },
  8456. {
  8457. /* fixed_bit_masks */
  8458. 0x800000007ffe0000ULL,
  8459. 0xffff000000000000ULL,
  8460. 0ULL,
  8461. 0ULL,
  8462. 0ULL
  8463. },
  8464. {
  8465. /* fixed_bit_values */
  8466. 0x00000000780e0000ULL,
  8467. 0x4407000000000000ULL,
  8468. -1ULL,
  8469. -1ULL,
  8470. -1ULL
  8471. }
  8472. },
  8473. { "shrib", TILE_OPC_SHRIB, 0x3 /* pipes */, 3 /* num_operands */,
  8474. TREG_ZERO, /* implicitly_written_register */
  8475. 1, /* can_bundle */
  8476. {
  8477. /* operands */
  8478. { 7, 8, 32 },
  8479. { 9, 10, 33 },
  8480. { 0, },
  8481. { 0, },
  8482. { 0, }
  8483. },
  8484. {
  8485. /* fixed_bit_masks */
  8486. 0x800000007ffe0000ULL,
  8487. 0xffff000000000000ULL,
  8488. 0ULL,
  8489. 0ULL,
  8490. 0ULL
  8491. },
  8492. {
  8493. /* fixed_bit_values */
  8494. 0x00000000700a0000ULL,
  8495. 0x4005000000000000ULL,
  8496. -1ULL,
  8497. -1ULL,
  8498. -1ULL
  8499. }
  8500. },
  8501. { "shrib.sn", TILE_OPC_SHRIB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8502. TREG_SN, /* implicitly_written_register */
  8503. 1, /* can_bundle */
  8504. {
  8505. /* operands */
  8506. { 7, 8, 32 },
  8507. { 9, 10, 33 },
  8508. { 0, },
  8509. { 0, },
  8510. { 0, }
  8511. },
  8512. {
  8513. /* fixed_bit_masks */
  8514. 0x800000007ffe0000ULL,
  8515. 0xffff000000000000ULL,
  8516. 0ULL,
  8517. 0ULL,
  8518. 0ULL
  8519. },
  8520. {
  8521. /* fixed_bit_values */
  8522. 0x00000000780a0000ULL,
  8523. 0x4405000000000000ULL,
  8524. -1ULL,
  8525. -1ULL,
  8526. -1ULL
  8527. }
  8528. },
  8529. { "shrih", TILE_OPC_SHRIH, 0x3 /* pipes */, 3 /* num_operands */,
  8530. TREG_ZERO, /* implicitly_written_register */
  8531. 1, /* can_bundle */
  8532. {
  8533. /* operands */
  8534. { 7, 8, 32 },
  8535. { 9, 10, 33 },
  8536. { 0, },
  8537. { 0, },
  8538. { 0, }
  8539. },
  8540. {
  8541. /* fixed_bit_masks */
  8542. 0x800000007ffe0000ULL,
  8543. 0xffff000000000000ULL,
  8544. 0ULL,
  8545. 0ULL,
  8546. 0ULL
  8547. },
  8548. {
  8549. /* fixed_bit_values */
  8550. 0x00000000700c0000ULL,
  8551. 0x4006000000000000ULL,
  8552. -1ULL,
  8553. -1ULL,
  8554. -1ULL
  8555. }
  8556. },
  8557. { "shrih.sn", TILE_OPC_SHRIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8558. TREG_SN, /* implicitly_written_register */
  8559. 1, /* can_bundle */
  8560. {
  8561. /* operands */
  8562. { 7, 8, 32 },
  8563. { 9, 10, 33 },
  8564. { 0, },
  8565. { 0, },
  8566. { 0, }
  8567. },
  8568. {
  8569. /* fixed_bit_masks */
  8570. 0x800000007ffe0000ULL,
  8571. 0xffff000000000000ULL,
  8572. 0ULL,
  8573. 0ULL,
  8574. 0ULL
  8575. },
  8576. {
  8577. /* fixed_bit_values */
  8578. 0x00000000780c0000ULL,
  8579. 0x4406000000000000ULL,
  8580. -1ULL,
  8581. -1ULL,
  8582. -1ULL
  8583. }
  8584. },
  8585. { "slt", TILE_OPC_SLT, 0xf /* pipes */, 3 /* num_operands */,
  8586. TREG_ZERO, /* implicitly_written_register */
  8587. 1, /* can_bundle */
  8588. {
  8589. /* operands */
  8590. { 7, 8, 16 },
  8591. { 9, 10, 17 },
  8592. { 11, 12, 18 },
  8593. { 13, 14, 19 },
  8594. { 0, }
  8595. },
  8596. {
  8597. /* fixed_bit_masks */
  8598. 0x800000007ffc0000ULL,
  8599. 0xfffe000000000000ULL,
  8600. 0x80000000780c0000ULL,
  8601. 0xf806000000000000ULL,
  8602. 0ULL
  8603. },
  8604. {
  8605. /* fixed_bit_values */
  8606. 0x00000000014c0000ULL,
  8607. 0x086a000000000000ULL,
  8608. 0x8000000028080000ULL,
  8609. 0xa804000000000000ULL,
  8610. -1ULL
  8611. }
  8612. },
  8613. { "slt.sn", TILE_OPC_SLT_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8614. TREG_SN, /* implicitly_written_register */
  8615. 1, /* can_bundle */
  8616. {
  8617. /* operands */
  8618. { 7, 8, 16 },
  8619. { 9, 10, 17 },
  8620. { 0, },
  8621. { 0, },
  8622. { 0, }
  8623. },
  8624. {
  8625. /* fixed_bit_masks */
  8626. 0x800000007ffc0000ULL,
  8627. 0xfffe000000000000ULL,
  8628. 0ULL,
  8629. 0ULL,
  8630. 0ULL
  8631. },
  8632. {
  8633. /* fixed_bit_values */
  8634. 0x00000000094c0000ULL,
  8635. 0x0c6a000000000000ULL,
  8636. -1ULL,
  8637. -1ULL,
  8638. -1ULL
  8639. }
  8640. },
  8641. { "slt_u", TILE_OPC_SLT_U, 0xf /* pipes */, 3 /* num_operands */,
  8642. TREG_ZERO, /* implicitly_written_register */
  8643. 1, /* can_bundle */
  8644. {
  8645. /* operands */
  8646. { 7, 8, 16 },
  8647. { 9, 10, 17 },
  8648. { 11, 12, 18 },
  8649. { 13, 14, 19 },
  8650. { 0, }
  8651. },
  8652. {
  8653. /* fixed_bit_masks */
  8654. 0x800000007ffc0000ULL,
  8655. 0xfffe000000000000ULL,
  8656. 0x80000000780c0000ULL,
  8657. 0xf806000000000000ULL,
  8658. 0ULL
  8659. },
  8660. {
  8661. /* fixed_bit_values */
  8662. 0x0000000001500000ULL,
  8663. 0x086c000000000000ULL,
  8664. 0x80000000280c0000ULL,
  8665. 0xa806000000000000ULL,
  8666. -1ULL
  8667. }
  8668. },
  8669. { "slt_u.sn", TILE_OPC_SLT_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8670. TREG_SN, /* implicitly_written_register */
  8671. 1, /* can_bundle */
  8672. {
  8673. /* operands */
  8674. { 7, 8, 16 },
  8675. { 9, 10, 17 },
  8676. { 0, },
  8677. { 0, },
  8678. { 0, }
  8679. },
  8680. {
  8681. /* fixed_bit_masks */
  8682. 0x800000007ffc0000ULL,
  8683. 0xfffe000000000000ULL,
  8684. 0ULL,
  8685. 0ULL,
  8686. 0ULL
  8687. },
  8688. {
  8689. /* fixed_bit_values */
  8690. 0x0000000009500000ULL,
  8691. 0x0c6c000000000000ULL,
  8692. -1ULL,
  8693. -1ULL,
  8694. -1ULL
  8695. }
  8696. },
  8697. { "sltb", TILE_OPC_SLTB, 0x3 /* pipes */, 3 /* num_operands */,
  8698. TREG_ZERO, /* implicitly_written_register */
  8699. 1, /* can_bundle */
  8700. {
  8701. /* operands */
  8702. { 7, 8, 16 },
  8703. { 9, 10, 17 },
  8704. { 0, },
  8705. { 0, },
  8706. { 0, }
  8707. },
  8708. {
  8709. /* fixed_bit_masks */
  8710. 0x800000007ffc0000ULL,
  8711. 0xfffe000000000000ULL,
  8712. 0ULL,
  8713. 0ULL,
  8714. 0ULL
  8715. },
  8716. {
  8717. /* fixed_bit_values */
  8718. 0x0000000001240000ULL,
  8719. 0x0856000000000000ULL,
  8720. -1ULL,
  8721. -1ULL,
  8722. -1ULL
  8723. }
  8724. },
  8725. { "sltb.sn", TILE_OPC_SLTB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8726. TREG_SN, /* implicitly_written_register */
  8727. 1, /* can_bundle */
  8728. {
  8729. /* operands */
  8730. { 7, 8, 16 },
  8731. { 9, 10, 17 },
  8732. { 0, },
  8733. { 0, },
  8734. { 0, }
  8735. },
  8736. {
  8737. /* fixed_bit_masks */
  8738. 0x800000007ffc0000ULL,
  8739. 0xfffe000000000000ULL,
  8740. 0ULL,
  8741. 0ULL,
  8742. 0ULL
  8743. },
  8744. {
  8745. /* fixed_bit_values */
  8746. 0x0000000009240000ULL,
  8747. 0x0c56000000000000ULL,
  8748. -1ULL,
  8749. -1ULL,
  8750. -1ULL
  8751. }
  8752. },
  8753. { "sltb_u", TILE_OPC_SLTB_U, 0x3 /* pipes */, 3 /* num_operands */,
  8754. TREG_ZERO, /* implicitly_written_register */
  8755. 1, /* can_bundle */
  8756. {
  8757. /* operands */
  8758. { 7, 8, 16 },
  8759. { 9, 10, 17 },
  8760. { 0, },
  8761. { 0, },
  8762. { 0, }
  8763. },
  8764. {
  8765. /* fixed_bit_masks */
  8766. 0x800000007ffc0000ULL,
  8767. 0xfffe000000000000ULL,
  8768. 0ULL,
  8769. 0ULL,
  8770. 0ULL
  8771. },
  8772. {
  8773. /* fixed_bit_values */
  8774. 0x0000000001280000ULL,
  8775. 0x0858000000000000ULL,
  8776. -1ULL,
  8777. -1ULL,
  8778. -1ULL
  8779. }
  8780. },
  8781. { "sltb_u.sn", TILE_OPC_SLTB_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8782. TREG_SN, /* implicitly_written_register */
  8783. 1, /* can_bundle */
  8784. {
  8785. /* operands */
  8786. { 7, 8, 16 },
  8787. { 9, 10, 17 },
  8788. { 0, },
  8789. { 0, },
  8790. { 0, }
  8791. },
  8792. {
  8793. /* fixed_bit_masks */
  8794. 0x800000007ffc0000ULL,
  8795. 0xfffe000000000000ULL,
  8796. 0ULL,
  8797. 0ULL,
  8798. 0ULL
  8799. },
  8800. {
  8801. /* fixed_bit_values */
  8802. 0x0000000009280000ULL,
  8803. 0x0c58000000000000ULL,
  8804. -1ULL,
  8805. -1ULL,
  8806. -1ULL
  8807. }
  8808. },
  8809. { "slte", TILE_OPC_SLTE, 0xf /* pipes */, 3 /* num_operands */,
  8810. TREG_ZERO, /* implicitly_written_register */
  8811. 1, /* can_bundle */
  8812. {
  8813. /* operands */
  8814. { 7, 8, 16 },
  8815. { 9, 10, 17 },
  8816. { 11, 12, 18 },
  8817. { 13, 14, 19 },
  8818. { 0, }
  8819. },
  8820. {
  8821. /* fixed_bit_masks */
  8822. 0x800000007ffc0000ULL,
  8823. 0xfffe000000000000ULL,
  8824. 0x80000000780c0000ULL,
  8825. 0xf806000000000000ULL,
  8826. 0ULL
  8827. },
  8828. {
  8829. /* fixed_bit_values */
  8830. 0x00000000013c0000ULL,
  8831. 0x0862000000000000ULL,
  8832. 0x8000000028000000ULL,
  8833. 0xa800000000000000ULL,
  8834. -1ULL
  8835. }
  8836. },
  8837. { "slte.sn", TILE_OPC_SLTE_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8838. TREG_SN, /* implicitly_written_register */
  8839. 1, /* can_bundle */
  8840. {
  8841. /* operands */
  8842. { 7, 8, 16 },
  8843. { 9, 10, 17 },
  8844. { 0, },
  8845. { 0, },
  8846. { 0, }
  8847. },
  8848. {
  8849. /* fixed_bit_masks */
  8850. 0x800000007ffc0000ULL,
  8851. 0xfffe000000000000ULL,
  8852. 0ULL,
  8853. 0ULL,
  8854. 0ULL
  8855. },
  8856. {
  8857. /* fixed_bit_values */
  8858. 0x00000000093c0000ULL,
  8859. 0x0c62000000000000ULL,
  8860. -1ULL,
  8861. -1ULL,
  8862. -1ULL
  8863. }
  8864. },
  8865. { "slte_u", TILE_OPC_SLTE_U, 0xf /* pipes */, 3 /* num_operands */,
  8866. TREG_ZERO, /* implicitly_written_register */
  8867. 1, /* can_bundle */
  8868. {
  8869. /* operands */
  8870. { 7, 8, 16 },
  8871. { 9, 10, 17 },
  8872. { 11, 12, 18 },
  8873. { 13, 14, 19 },
  8874. { 0, }
  8875. },
  8876. {
  8877. /* fixed_bit_masks */
  8878. 0x800000007ffc0000ULL,
  8879. 0xfffe000000000000ULL,
  8880. 0x80000000780c0000ULL,
  8881. 0xf806000000000000ULL,
  8882. 0ULL
  8883. },
  8884. {
  8885. /* fixed_bit_values */
  8886. 0x0000000001400000ULL,
  8887. 0x0864000000000000ULL,
  8888. 0x8000000028040000ULL,
  8889. 0xa802000000000000ULL,
  8890. -1ULL
  8891. }
  8892. },
  8893. { "slte_u.sn", TILE_OPC_SLTE_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8894. TREG_SN, /* implicitly_written_register */
  8895. 1, /* can_bundle */
  8896. {
  8897. /* operands */
  8898. { 7, 8, 16 },
  8899. { 9, 10, 17 },
  8900. { 0, },
  8901. { 0, },
  8902. { 0, }
  8903. },
  8904. {
  8905. /* fixed_bit_masks */
  8906. 0x800000007ffc0000ULL,
  8907. 0xfffe000000000000ULL,
  8908. 0ULL,
  8909. 0ULL,
  8910. 0ULL
  8911. },
  8912. {
  8913. /* fixed_bit_values */
  8914. 0x0000000009400000ULL,
  8915. 0x0c64000000000000ULL,
  8916. -1ULL,
  8917. -1ULL,
  8918. -1ULL
  8919. }
  8920. },
  8921. { "slteb", TILE_OPC_SLTEB, 0x3 /* pipes */, 3 /* num_operands */,
  8922. TREG_ZERO, /* implicitly_written_register */
  8923. 1, /* can_bundle */
  8924. {
  8925. /* operands */
  8926. { 7, 8, 16 },
  8927. { 9, 10, 17 },
  8928. { 0, },
  8929. { 0, },
  8930. { 0, }
  8931. },
  8932. {
  8933. /* fixed_bit_masks */
  8934. 0x800000007ffc0000ULL,
  8935. 0xfffe000000000000ULL,
  8936. 0ULL,
  8937. 0ULL,
  8938. 0ULL
  8939. },
  8940. {
  8941. /* fixed_bit_values */
  8942. 0x00000000012c0000ULL,
  8943. 0x085a000000000000ULL,
  8944. -1ULL,
  8945. -1ULL,
  8946. -1ULL
  8947. }
  8948. },
  8949. { "slteb.sn", TILE_OPC_SLTEB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  8950. TREG_SN, /* implicitly_written_register */
  8951. 1, /* can_bundle */
  8952. {
  8953. /* operands */
  8954. { 7, 8, 16 },
  8955. { 9, 10, 17 },
  8956. { 0, },
  8957. { 0, },
  8958. { 0, }
  8959. },
  8960. {
  8961. /* fixed_bit_masks */
  8962. 0x800000007ffc0000ULL,
  8963. 0xfffe000000000000ULL,
  8964. 0ULL,
  8965. 0ULL,
  8966. 0ULL
  8967. },
  8968. {
  8969. /* fixed_bit_values */
  8970. 0x00000000092c0000ULL,
  8971. 0x0c5a000000000000ULL,
  8972. -1ULL,
  8973. -1ULL,
  8974. -1ULL
  8975. }
  8976. },
  8977. { "slteb_u", TILE_OPC_SLTEB_U, 0x3 /* pipes */, 3 /* num_operands */,
  8978. TREG_ZERO, /* implicitly_written_register */
  8979. 1, /* can_bundle */
  8980. {
  8981. /* operands */
  8982. { 7, 8, 16 },
  8983. { 9, 10, 17 },
  8984. { 0, },
  8985. { 0, },
  8986. { 0, }
  8987. },
  8988. {
  8989. /* fixed_bit_masks */
  8990. 0x800000007ffc0000ULL,
  8991. 0xfffe000000000000ULL,
  8992. 0ULL,
  8993. 0ULL,
  8994. 0ULL
  8995. },
  8996. {
  8997. /* fixed_bit_values */
  8998. 0x0000000001300000ULL,
  8999. 0x085c000000000000ULL,
  9000. -1ULL,
  9001. -1ULL,
  9002. -1ULL
  9003. }
  9004. },
  9005. { "slteb_u.sn", TILE_OPC_SLTEB_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9006. TREG_SN, /* implicitly_written_register */
  9007. 1, /* can_bundle */
  9008. {
  9009. /* operands */
  9010. { 7, 8, 16 },
  9011. { 9, 10, 17 },
  9012. { 0, },
  9013. { 0, },
  9014. { 0, }
  9015. },
  9016. {
  9017. /* fixed_bit_masks */
  9018. 0x800000007ffc0000ULL,
  9019. 0xfffe000000000000ULL,
  9020. 0ULL,
  9021. 0ULL,
  9022. 0ULL
  9023. },
  9024. {
  9025. /* fixed_bit_values */
  9026. 0x0000000009300000ULL,
  9027. 0x0c5c000000000000ULL,
  9028. -1ULL,
  9029. -1ULL,
  9030. -1ULL
  9031. }
  9032. },
  9033. { "slteh", TILE_OPC_SLTEH, 0x3 /* pipes */, 3 /* num_operands */,
  9034. TREG_ZERO, /* implicitly_written_register */
  9035. 1, /* can_bundle */
  9036. {
  9037. /* operands */
  9038. { 7, 8, 16 },
  9039. { 9, 10, 17 },
  9040. { 0, },
  9041. { 0, },
  9042. { 0, }
  9043. },
  9044. {
  9045. /* fixed_bit_masks */
  9046. 0x800000007ffc0000ULL,
  9047. 0xfffe000000000000ULL,
  9048. 0ULL,
  9049. 0ULL,
  9050. 0ULL
  9051. },
  9052. {
  9053. /* fixed_bit_values */
  9054. 0x0000000001340000ULL,
  9055. 0x085e000000000000ULL,
  9056. -1ULL,
  9057. -1ULL,
  9058. -1ULL
  9059. }
  9060. },
  9061. { "slteh.sn", TILE_OPC_SLTEH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9062. TREG_SN, /* implicitly_written_register */
  9063. 1, /* can_bundle */
  9064. {
  9065. /* operands */
  9066. { 7, 8, 16 },
  9067. { 9, 10, 17 },
  9068. { 0, },
  9069. { 0, },
  9070. { 0, }
  9071. },
  9072. {
  9073. /* fixed_bit_masks */
  9074. 0x800000007ffc0000ULL,
  9075. 0xfffe000000000000ULL,
  9076. 0ULL,
  9077. 0ULL,
  9078. 0ULL
  9079. },
  9080. {
  9081. /* fixed_bit_values */
  9082. 0x0000000009340000ULL,
  9083. 0x0c5e000000000000ULL,
  9084. -1ULL,
  9085. -1ULL,
  9086. -1ULL
  9087. }
  9088. },
  9089. { "slteh_u", TILE_OPC_SLTEH_U, 0x3 /* pipes */, 3 /* num_operands */,
  9090. TREG_ZERO, /* implicitly_written_register */
  9091. 1, /* can_bundle */
  9092. {
  9093. /* operands */
  9094. { 7, 8, 16 },
  9095. { 9, 10, 17 },
  9096. { 0, },
  9097. { 0, },
  9098. { 0, }
  9099. },
  9100. {
  9101. /* fixed_bit_masks */
  9102. 0x800000007ffc0000ULL,
  9103. 0xfffe000000000000ULL,
  9104. 0ULL,
  9105. 0ULL,
  9106. 0ULL
  9107. },
  9108. {
  9109. /* fixed_bit_values */
  9110. 0x0000000001380000ULL,
  9111. 0x0860000000000000ULL,
  9112. -1ULL,
  9113. -1ULL,
  9114. -1ULL
  9115. }
  9116. },
  9117. { "slteh_u.sn", TILE_OPC_SLTEH_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9118. TREG_SN, /* implicitly_written_register */
  9119. 1, /* can_bundle */
  9120. {
  9121. /* operands */
  9122. { 7, 8, 16 },
  9123. { 9, 10, 17 },
  9124. { 0, },
  9125. { 0, },
  9126. { 0, }
  9127. },
  9128. {
  9129. /* fixed_bit_masks */
  9130. 0x800000007ffc0000ULL,
  9131. 0xfffe000000000000ULL,
  9132. 0ULL,
  9133. 0ULL,
  9134. 0ULL
  9135. },
  9136. {
  9137. /* fixed_bit_values */
  9138. 0x0000000009380000ULL,
  9139. 0x0c60000000000000ULL,
  9140. -1ULL,
  9141. -1ULL,
  9142. -1ULL
  9143. }
  9144. },
  9145. { "slth", TILE_OPC_SLTH, 0x3 /* pipes */, 3 /* num_operands */,
  9146. TREG_ZERO, /* implicitly_written_register */
  9147. 1, /* can_bundle */
  9148. {
  9149. /* operands */
  9150. { 7, 8, 16 },
  9151. { 9, 10, 17 },
  9152. { 0, },
  9153. { 0, },
  9154. { 0, }
  9155. },
  9156. {
  9157. /* fixed_bit_masks */
  9158. 0x800000007ffc0000ULL,
  9159. 0xfffe000000000000ULL,
  9160. 0ULL,
  9161. 0ULL,
  9162. 0ULL
  9163. },
  9164. {
  9165. /* fixed_bit_values */
  9166. 0x0000000001440000ULL,
  9167. 0x0866000000000000ULL,
  9168. -1ULL,
  9169. -1ULL,
  9170. -1ULL
  9171. }
  9172. },
  9173. { "slth.sn", TILE_OPC_SLTH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9174. TREG_SN, /* implicitly_written_register */
  9175. 1, /* can_bundle */
  9176. {
  9177. /* operands */
  9178. { 7, 8, 16 },
  9179. { 9, 10, 17 },
  9180. { 0, },
  9181. { 0, },
  9182. { 0, }
  9183. },
  9184. {
  9185. /* fixed_bit_masks */
  9186. 0x800000007ffc0000ULL,
  9187. 0xfffe000000000000ULL,
  9188. 0ULL,
  9189. 0ULL,
  9190. 0ULL
  9191. },
  9192. {
  9193. /* fixed_bit_values */
  9194. 0x0000000009440000ULL,
  9195. 0x0c66000000000000ULL,
  9196. -1ULL,
  9197. -1ULL,
  9198. -1ULL
  9199. }
  9200. },
  9201. { "slth_u", TILE_OPC_SLTH_U, 0x3 /* pipes */, 3 /* num_operands */,
  9202. TREG_ZERO, /* implicitly_written_register */
  9203. 1, /* can_bundle */
  9204. {
  9205. /* operands */
  9206. { 7, 8, 16 },
  9207. { 9, 10, 17 },
  9208. { 0, },
  9209. { 0, },
  9210. { 0, }
  9211. },
  9212. {
  9213. /* fixed_bit_masks */
  9214. 0x800000007ffc0000ULL,
  9215. 0xfffe000000000000ULL,
  9216. 0ULL,
  9217. 0ULL,
  9218. 0ULL
  9219. },
  9220. {
  9221. /* fixed_bit_values */
  9222. 0x0000000001480000ULL,
  9223. 0x0868000000000000ULL,
  9224. -1ULL,
  9225. -1ULL,
  9226. -1ULL
  9227. }
  9228. },
  9229. { "slth_u.sn", TILE_OPC_SLTH_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9230. TREG_SN, /* implicitly_written_register */
  9231. 1, /* can_bundle */
  9232. {
  9233. /* operands */
  9234. { 7, 8, 16 },
  9235. { 9, 10, 17 },
  9236. { 0, },
  9237. { 0, },
  9238. { 0, }
  9239. },
  9240. {
  9241. /* fixed_bit_masks */
  9242. 0x800000007ffc0000ULL,
  9243. 0xfffe000000000000ULL,
  9244. 0ULL,
  9245. 0ULL,
  9246. 0ULL
  9247. },
  9248. {
  9249. /* fixed_bit_values */
  9250. 0x0000000009480000ULL,
  9251. 0x0c68000000000000ULL,
  9252. -1ULL,
  9253. -1ULL,
  9254. -1ULL
  9255. }
  9256. },
  9257. { "slti", TILE_OPC_SLTI, 0xf /* pipes */, 3 /* num_operands */,
  9258. TREG_ZERO, /* implicitly_written_register */
  9259. 1, /* can_bundle */
  9260. {
  9261. /* operands */
  9262. { 7, 8, 0 },
  9263. { 9, 10, 1 },
  9264. { 11, 12, 2 },
  9265. { 13, 14, 3 },
  9266. { 0, }
  9267. },
  9268. {
  9269. /* fixed_bit_masks */
  9270. 0x800000007ff00000ULL,
  9271. 0xfff8000000000000ULL,
  9272. 0x8000000078000000ULL,
  9273. 0xf800000000000000ULL,
  9274. 0ULL
  9275. },
  9276. {
  9277. /* fixed_bit_values */
  9278. 0x0000000041000000ULL,
  9279. 0x3098000000000000ULL,
  9280. 0x8000000070000000ULL,
  9281. 0xe000000000000000ULL,
  9282. -1ULL
  9283. }
  9284. },
  9285. { "slti.sn", TILE_OPC_SLTI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9286. TREG_SN, /* implicitly_written_register */
  9287. 1, /* can_bundle */
  9288. {
  9289. /* operands */
  9290. { 7, 8, 0 },
  9291. { 9, 10, 1 },
  9292. { 0, },
  9293. { 0, },
  9294. { 0, }
  9295. },
  9296. {
  9297. /* fixed_bit_masks */
  9298. 0x800000007ff00000ULL,
  9299. 0xfff8000000000000ULL,
  9300. 0ULL,
  9301. 0ULL,
  9302. 0ULL
  9303. },
  9304. {
  9305. /* fixed_bit_values */
  9306. 0x0000000049000000ULL,
  9307. 0x3498000000000000ULL,
  9308. -1ULL,
  9309. -1ULL,
  9310. -1ULL
  9311. }
  9312. },
  9313. { "slti_u", TILE_OPC_SLTI_U, 0xf /* pipes */, 3 /* num_operands */,
  9314. TREG_ZERO, /* implicitly_written_register */
  9315. 1, /* can_bundle */
  9316. {
  9317. /* operands */
  9318. { 7, 8, 0 },
  9319. { 9, 10, 1 },
  9320. { 11, 12, 2 },
  9321. { 13, 14, 3 },
  9322. { 0, }
  9323. },
  9324. {
  9325. /* fixed_bit_masks */
  9326. 0x800000007ff00000ULL,
  9327. 0xfff8000000000000ULL,
  9328. 0x8000000078000000ULL,
  9329. 0xf800000000000000ULL,
  9330. 0ULL
  9331. },
  9332. {
  9333. /* fixed_bit_values */
  9334. 0x0000000041100000ULL,
  9335. 0x30a0000000000000ULL,
  9336. 0x8000000078000000ULL,
  9337. 0xe800000000000000ULL,
  9338. -1ULL
  9339. }
  9340. },
  9341. { "slti_u.sn", TILE_OPC_SLTI_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9342. TREG_SN, /* implicitly_written_register */
  9343. 1, /* can_bundle */
  9344. {
  9345. /* operands */
  9346. { 7, 8, 0 },
  9347. { 9, 10, 1 },
  9348. { 0, },
  9349. { 0, },
  9350. { 0, }
  9351. },
  9352. {
  9353. /* fixed_bit_masks */
  9354. 0x800000007ff00000ULL,
  9355. 0xfff8000000000000ULL,
  9356. 0ULL,
  9357. 0ULL,
  9358. 0ULL
  9359. },
  9360. {
  9361. /* fixed_bit_values */
  9362. 0x0000000049100000ULL,
  9363. 0x34a0000000000000ULL,
  9364. -1ULL,
  9365. -1ULL,
  9366. -1ULL
  9367. }
  9368. },
  9369. { "sltib", TILE_OPC_SLTIB, 0x3 /* pipes */, 3 /* num_operands */,
  9370. TREG_ZERO, /* implicitly_written_register */
  9371. 1, /* can_bundle */
  9372. {
  9373. /* operands */
  9374. { 7, 8, 0 },
  9375. { 9, 10, 1 },
  9376. { 0, },
  9377. { 0, },
  9378. { 0, }
  9379. },
  9380. {
  9381. /* fixed_bit_masks */
  9382. 0x800000007ff00000ULL,
  9383. 0xfff8000000000000ULL,
  9384. 0ULL,
  9385. 0ULL,
  9386. 0ULL
  9387. },
  9388. {
  9389. /* fixed_bit_values */
  9390. 0x0000000040c00000ULL,
  9391. 0x3078000000000000ULL,
  9392. -1ULL,
  9393. -1ULL,
  9394. -1ULL
  9395. }
  9396. },
  9397. { "sltib.sn", TILE_OPC_SLTIB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9398. TREG_SN, /* implicitly_written_register */
  9399. 1, /* can_bundle */
  9400. {
  9401. /* operands */
  9402. { 7, 8, 0 },
  9403. { 9, 10, 1 },
  9404. { 0, },
  9405. { 0, },
  9406. { 0, }
  9407. },
  9408. {
  9409. /* fixed_bit_masks */
  9410. 0x800000007ff00000ULL,
  9411. 0xfff8000000000000ULL,
  9412. 0ULL,
  9413. 0ULL,
  9414. 0ULL
  9415. },
  9416. {
  9417. /* fixed_bit_values */
  9418. 0x0000000048c00000ULL,
  9419. 0x3478000000000000ULL,
  9420. -1ULL,
  9421. -1ULL,
  9422. -1ULL
  9423. }
  9424. },
  9425. { "sltib_u", TILE_OPC_SLTIB_U, 0x3 /* pipes */, 3 /* num_operands */,
  9426. TREG_ZERO, /* implicitly_written_register */
  9427. 1, /* can_bundle */
  9428. {
  9429. /* operands */
  9430. { 7, 8, 0 },
  9431. { 9, 10, 1 },
  9432. { 0, },
  9433. { 0, },
  9434. { 0, }
  9435. },
  9436. {
  9437. /* fixed_bit_masks */
  9438. 0x800000007ff00000ULL,
  9439. 0xfff8000000000000ULL,
  9440. 0ULL,
  9441. 0ULL,
  9442. 0ULL
  9443. },
  9444. {
  9445. /* fixed_bit_values */
  9446. 0x0000000040d00000ULL,
  9447. 0x3080000000000000ULL,
  9448. -1ULL,
  9449. -1ULL,
  9450. -1ULL
  9451. }
  9452. },
  9453. { "sltib_u.sn", TILE_OPC_SLTIB_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9454. TREG_SN, /* implicitly_written_register */
  9455. 1, /* can_bundle */
  9456. {
  9457. /* operands */
  9458. { 7, 8, 0 },
  9459. { 9, 10, 1 },
  9460. { 0, },
  9461. { 0, },
  9462. { 0, }
  9463. },
  9464. {
  9465. /* fixed_bit_masks */
  9466. 0x800000007ff00000ULL,
  9467. 0xfff8000000000000ULL,
  9468. 0ULL,
  9469. 0ULL,
  9470. 0ULL
  9471. },
  9472. {
  9473. /* fixed_bit_values */
  9474. 0x0000000048d00000ULL,
  9475. 0x3480000000000000ULL,
  9476. -1ULL,
  9477. -1ULL,
  9478. -1ULL
  9479. }
  9480. },
  9481. { "sltih", TILE_OPC_SLTIH, 0x3 /* pipes */, 3 /* num_operands */,
  9482. TREG_ZERO, /* implicitly_written_register */
  9483. 1, /* can_bundle */
  9484. {
  9485. /* operands */
  9486. { 7, 8, 0 },
  9487. { 9, 10, 1 },
  9488. { 0, },
  9489. { 0, },
  9490. { 0, }
  9491. },
  9492. {
  9493. /* fixed_bit_masks */
  9494. 0x800000007ff00000ULL,
  9495. 0xfff8000000000000ULL,
  9496. 0ULL,
  9497. 0ULL,
  9498. 0ULL
  9499. },
  9500. {
  9501. /* fixed_bit_values */
  9502. 0x0000000040e00000ULL,
  9503. 0x3088000000000000ULL,
  9504. -1ULL,
  9505. -1ULL,
  9506. -1ULL
  9507. }
  9508. },
  9509. { "sltih.sn", TILE_OPC_SLTIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9510. TREG_SN, /* implicitly_written_register */
  9511. 1, /* can_bundle */
  9512. {
  9513. /* operands */
  9514. { 7, 8, 0 },
  9515. { 9, 10, 1 },
  9516. { 0, },
  9517. { 0, },
  9518. { 0, }
  9519. },
  9520. {
  9521. /* fixed_bit_masks */
  9522. 0x800000007ff00000ULL,
  9523. 0xfff8000000000000ULL,
  9524. 0ULL,
  9525. 0ULL,
  9526. 0ULL
  9527. },
  9528. {
  9529. /* fixed_bit_values */
  9530. 0x0000000048e00000ULL,
  9531. 0x3488000000000000ULL,
  9532. -1ULL,
  9533. -1ULL,
  9534. -1ULL
  9535. }
  9536. },
  9537. { "sltih_u", TILE_OPC_SLTIH_U, 0x3 /* pipes */, 3 /* num_operands */,
  9538. TREG_ZERO, /* implicitly_written_register */
  9539. 1, /* can_bundle */
  9540. {
  9541. /* operands */
  9542. { 7, 8, 0 },
  9543. { 9, 10, 1 },
  9544. { 0, },
  9545. { 0, },
  9546. { 0, }
  9547. },
  9548. {
  9549. /* fixed_bit_masks */
  9550. 0x800000007ff00000ULL,
  9551. 0xfff8000000000000ULL,
  9552. 0ULL,
  9553. 0ULL,
  9554. 0ULL
  9555. },
  9556. {
  9557. /* fixed_bit_values */
  9558. 0x0000000040f00000ULL,
  9559. 0x3090000000000000ULL,
  9560. -1ULL,
  9561. -1ULL,
  9562. -1ULL
  9563. }
  9564. },
  9565. { "sltih_u.sn", TILE_OPC_SLTIH_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9566. TREG_SN, /* implicitly_written_register */
  9567. 1, /* can_bundle */
  9568. {
  9569. /* operands */
  9570. { 7, 8, 0 },
  9571. { 9, 10, 1 },
  9572. { 0, },
  9573. { 0, },
  9574. { 0, }
  9575. },
  9576. {
  9577. /* fixed_bit_masks */
  9578. 0x800000007ff00000ULL,
  9579. 0xfff8000000000000ULL,
  9580. 0ULL,
  9581. 0ULL,
  9582. 0ULL
  9583. },
  9584. {
  9585. /* fixed_bit_values */
  9586. 0x0000000048f00000ULL,
  9587. 0x3490000000000000ULL,
  9588. -1ULL,
  9589. -1ULL,
  9590. -1ULL
  9591. }
  9592. },
  9593. { "sne", TILE_OPC_SNE, 0xf /* pipes */, 3 /* num_operands */,
  9594. TREG_ZERO, /* implicitly_written_register */
  9595. 1, /* can_bundle */
  9596. {
  9597. /* operands */
  9598. { 7, 8, 16 },
  9599. { 9, 10, 17 },
  9600. { 11, 12, 18 },
  9601. { 13, 14, 19 },
  9602. { 0, }
  9603. },
  9604. {
  9605. /* fixed_bit_masks */
  9606. 0x800000007ffc0000ULL,
  9607. 0xfffe000000000000ULL,
  9608. 0x80000000780c0000ULL,
  9609. 0xf806000000000000ULL,
  9610. 0ULL
  9611. },
  9612. {
  9613. /* fixed_bit_values */
  9614. 0x00000000015c0000ULL,
  9615. 0x0872000000000000ULL,
  9616. 0x80000000300c0000ULL,
  9617. 0xb006000000000000ULL,
  9618. -1ULL
  9619. }
  9620. },
  9621. { "sne.sn", TILE_OPC_SNE_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9622. TREG_SN, /* implicitly_written_register */
  9623. 1, /* can_bundle */
  9624. {
  9625. /* operands */
  9626. { 7, 8, 16 },
  9627. { 9, 10, 17 },
  9628. { 0, },
  9629. { 0, },
  9630. { 0, }
  9631. },
  9632. {
  9633. /* fixed_bit_masks */
  9634. 0x800000007ffc0000ULL,
  9635. 0xfffe000000000000ULL,
  9636. 0ULL,
  9637. 0ULL,
  9638. 0ULL
  9639. },
  9640. {
  9641. /* fixed_bit_values */
  9642. 0x00000000095c0000ULL,
  9643. 0x0c72000000000000ULL,
  9644. -1ULL,
  9645. -1ULL,
  9646. -1ULL
  9647. }
  9648. },
  9649. { "sneb", TILE_OPC_SNEB, 0x3 /* pipes */, 3 /* num_operands */,
  9650. TREG_ZERO, /* implicitly_written_register */
  9651. 1, /* can_bundle */
  9652. {
  9653. /* operands */
  9654. { 7, 8, 16 },
  9655. { 9, 10, 17 },
  9656. { 0, },
  9657. { 0, },
  9658. { 0, }
  9659. },
  9660. {
  9661. /* fixed_bit_masks */
  9662. 0x800000007ffc0000ULL,
  9663. 0xfffe000000000000ULL,
  9664. 0ULL,
  9665. 0ULL,
  9666. 0ULL
  9667. },
  9668. {
  9669. /* fixed_bit_values */
  9670. 0x0000000001540000ULL,
  9671. 0x086e000000000000ULL,
  9672. -1ULL,
  9673. -1ULL,
  9674. -1ULL
  9675. }
  9676. },
  9677. { "sneb.sn", TILE_OPC_SNEB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9678. TREG_SN, /* implicitly_written_register */
  9679. 1, /* can_bundle */
  9680. {
  9681. /* operands */
  9682. { 7, 8, 16 },
  9683. { 9, 10, 17 },
  9684. { 0, },
  9685. { 0, },
  9686. { 0, }
  9687. },
  9688. {
  9689. /* fixed_bit_masks */
  9690. 0x800000007ffc0000ULL,
  9691. 0xfffe000000000000ULL,
  9692. 0ULL,
  9693. 0ULL,
  9694. 0ULL
  9695. },
  9696. {
  9697. /* fixed_bit_values */
  9698. 0x0000000009540000ULL,
  9699. 0x0c6e000000000000ULL,
  9700. -1ULL,
  9701. -1ULL,
  9702. -1ULL
  9703. }
  9704. },
  9705. { "sneh", TILE_OPC_SNEH, 0x3 /* pipes */, 3 /* num_operands */,
  9706. TREG_ZERO, /* implicitly_written_register */
  9707. 1, /* can_bundle */
  9708. {
  9709. /* operands */
  9710. { 7, 8, 16 },
  9711. { 9, 10, 17 },
  9712. { 0, },
  9713. { 0, },
  9714. { 0, }
  9715. },
  9716. {
  9717. /* fixed_bit_masks */
  9718. 0x800000007ffc0000ULL,
  9719. 0xfffe000000000000ULL,
  9720. 0ULL,
  9721. 0ULL,
  9722. 0ULL
  9723. },
  9724. {
  9725. /* fixed_bit_values */
  9726. 0x0000000001580000ULL,
  9727. 0x0870000000000000ULL,
  9728. -1ULL,
  9729. -1ULL,
  9730. -1ULL
  9731. }
  9732. },
  9733. { "sneh.sn", TILE_OPC_SNEH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9734. TREG_SN, /* implicitly_written_register */
  9735. 1, /* can_bundle */
  9736. {
  9737. /* operands */
  9738. { 7, 8, 16 },
  9739. { 9, 10, 17 },
  9740. { 0, },
  9741. { 0, },
  9742. { 0, }
  9743. },
  9744. {
  9745. /* fixed_bit_masks */
  9746. 0x800000007ffc0000ULL,
  9747. 0xfffe000000000000ULL,
  9748. 0ULL,
  9749. 0ULL,
  9750. 0ULL
  9751. },
  9752. {
  9753. /* fixed_bit_values */
  9754. 0x0000000009580000ULL,
  9755. 0x0c70000000000000ULL,
  9756. -1ULL,
  9757. -1ULL,
  9758. -1ULL
  9759. }
  9760. },
  9761. { "sra", TILE_OPC_SRA, 0xf /* pipes */, 3 /* num_operands */,
  9762. TREG_ZERO, /* implicitly_written_register */
  9763. 1, /* can_bundle */
  9764. {
  9765. /* operands */
  9766. { 7, 8, 16 },
  9767. { 9, 10, 17 },
  9768. { 11, 12, 18 },
  9769. { 13, 14, 19 },
  9770. { 0, }
  9771. },
  9772. {
  9773. /* fixed_bit_masks */
  9774. 0x800000007ffc0000ULL,
  9775. 0xfffe000000000000ULL,
  9776. 0x80000000780c0000ULL,
  9777. 0xf806000000000000ULL,
  9778. 0ULL
  9779. },
  9780. {
  9781. /* fixed_bit_values */
  9782. 0x0000000001680000ULL,
  9783. 0x0878000000000000ULL,
  9784. 0x80000000200c0000ULL,
  9785. 0xa006000000000000ULL,
  9786. -1ULL
  9787. }
  9788. },
  9789. { "sra.sn", TILE_OPC_SRA_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9790. TREG_SN, /* implicitly_written_register */
  9791. 1, /* can_bundle */
  9792. {
  9793. /* operands */
  9794. { 7, 8, 16 },
  9795. { 9, 10, 17 },
  9796. { 0, },
  9797. { 0, },
  9798. { 0, }
  9799. },
  9800. {
  9801. /* fixed_bit_masks */
  9802. 0x800000007ffc0000ULL,
  9803. 0xfffe000000000000ULL,
  9804. 0ULL,
  9805. 0ULL,
  9806. 0ULL
  9807. },
  9808. {
  9809. /* fixed_bit_values */
  9810. 0x0000000009680000ULL,
  9811. 0x0c78000000000000ULL,
  9812. -1ULL,
  9813. -1ULL,
  9814. -1ULL
  9815. }
  9816. },
  9817. { "srab", TILE_OPC_SRAB, 0x3 /* pipes */, 3 /* num_operands */,
  9818. TREG_ZERO, /* implicitly_written_register */
  9819. 1, /* can_bundle */
  9820. {
  9821. /* operands */
  9822. { 7, 8, 16 },
  9823. { 9, 10, 17 },
  9824. { 0, },
  9825. { 0, },
  9826. { 0, }
  9827. },
  9828. {
  9829. /* fixed_bit_masks */
  9830. 0x800000007ffc0000ULL,
  9831. 0xfffe000000000000ULL,
  9832. 0ULL,
  9833. 0ULL,
  9834. 0ULL
  9835. },
  9836. {
  9837. /* fixed_bit_values */
  9838. 0x0000000001600000ULL,
  9839. 0x0874000000000000ULL,
  9840. -1ULL,
  9841. -1ULL,
  9842. -1ULL
  9843. }
  9844. },
  9845. { "srab.sn", TILE_OPC_SRAB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9846. TREG_SN, /* implicitly_written_register */
  9847. 1, /* can_bundle */
  9848. {
  9849. /* operands */
  9850. { 7, 8, 16 },
  9851. { 9, 10, 17 },
  9852. { 0, },
  9853. { 0, },
  9854. { 0, }
  9855. },
  9856. {
  9857. /* fixed_bit_masks */
  9858. 0x800000007ffc0000ULL,
  9859. 0xfffe000000000000ULL,
  9860. 0ULL,
  9861. 0ULL,
  9862. 0ULL
  9863. },
  9864. {
  9865. /* fixed_bit_values */
  9866. 0x0000000009600000ULL,
  9867. 0x0c74000000000000ULL,
  9868. -1ULL,
  9869. -1ULL,
  9870. -1ULL
  9871. }
  9872. },
  9873. { "srah", TILE_OPC_SRAH, 0x3 /* pipes */, 3 /* num_operands */,
  9874. TREG_ZERO, /* implicitly_written_register */
  9875. 1, /* can_bundle */
  9876. {
  9877. /* operands */
  9878. { 7, 8, 16 },
  9879. { 9, 10, 17 },
  9880. { 0, },
  9881. { 0, },
  9882. { 0, }
  9883. },
  9884. {
  9885. /* fixed_bit_masks */
  9886. 0x800000007ffc0000ULL,
  9887. 0xfffe000000000000ULL,
  9888. 0ULL,
  9889. 0ULL,
  9890. 0ULL
  9891. },
  9892. {
  9893. /* fixed_bit_values */
  9894. 0x0000000001640000ULL,
  9895. 0x0876000000000000ULL,
  9896. -1ULL,
  9897. -1ULL,
  9898. -1ULL
  9899. }
  9900. },
  9901. { "srah.sn", TILE_OPC_SRAH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9902. TREG_SN, /* implicitly_written_register */
  9903. 1, /* can_bundle */
  9904. {
  9905. /* operands */
  9906. { 7, 8, 16 },
  9907. { 9, 10, 17 },
  9908. { 0, },
  9909. { 0, },
  9910. { 0, }
  9911. },
  9912. {
  9913. /* fixed_bit_masks */
  9914. 0x800000007ffc0000ULL,
  9915. 0xfffe000000000000ULL,
  9916. 0ULL,
  9917. 0ULL,
  9918. 0ULL
  9919. },
  9920. {
  9921. /* fixed_bit_values */
  9922. 0x0000000009640000ULL,
  9923. 0x0c76000000000000ULL,
  9924. -1ULL,
  9925. -1ULL,
  9926. -1ULL
  9927. }
  9928. },
  9929. { "srai", TILE_OPC_SRAI, 0xf /* pipes */, 3 /* num_operands */,
  9930. TREG_ZERO, /* implicitly_written_register */
  9931. 1, /* can_bundle */
  9932. {
  9933. /* operands */
  9934. { 7, 8, 32 },
  9935. { 9, 10, 33 },
  9936. { 11, 12, 34 },
  9937. { 13, 14, 35 },
  9938. { 0, }
  9939. },
  9940. {
  9941. /* fixed_bit_masks */
  9942. 0x800000007ffe0000ULL,
  9943. 0xffff000000000000ULL,
  9944. 0x80000000780e0000ULL,
  9945. 0xf807000000000000ULL,
  9946. 0ULL
  9947. },
  9948. {
  9949. /* fixed_bit_values */
  9950. 0x0000000070140000ULL,
  9951. 0x400a000000000000ULL,
  9952. 0x8000000068080000ULL,
  9953. 0xd804000000000000ULL,
  9954. -1ULL
  9955. }
  9956. },
  9957. { "srai.sn", TILE_OPC_SRAI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  9958. TREG_SN, /* implicitly_written_register */
  9959. 1, /* can_bundle */
  9960. {
  9961. /* operands */
  9962. { 7, 8, 32 },
  9963. { 9, 10, 33 },
  9964. { 0, },
  9965. { 0, },
  9966. { 0, }
  9967. },
  9968. {
  9969. /* fixed_bit_masks */
  9970. 0x800000007ffe0000ULL,
  9971. 0xffff000000000000ULL,
  9972. 0ULL,
  9973. 0ULL,
  9974. 0ULL
  9975. },
  9976. {
  9977. /* fixed_bit_values */
  9978. 0x0000000078140000ULL,
  9979. 0x440a000000000000ULL,
  9980. -1ULL,
  9981. -1ULL,
  9982. -1ULL
  9983. }
  9984. },
  9985. { "sraib", TILE_OPC_SRAIB, 0x3 /* pipes */, 3 /* num_operands */,
  9986. TREG_ZERO, /* implicitly_written_register */
  9987. 1, /* can_bundle */
  9988. {
  9989. /* operands */
  9990. { 7, 8, 32 },
  9991. { 9, 10, 33 },
  9992. { 0, },
  9993. { 0, },
  9994. { 0, }
  9995. },
  9996. {
  9997. /* fixed_bit_masks */
  9998. 0x800000007ffe0000ULL,
  9999. 0xffff000000000000ULL,
  10000. 0ULL,
  10001. 0ULL,
  10002. 0ULL
  10003. },
  10004. {
  10005. /* fixed_bit_values */
  10006. 0x0000000070100000ULL,
  10007. 0x4008000000000000ULL,
  10008. -1ULL,
  10009. -1ULL,
  10010. -1ULL
  10011. }
  10012. },
  10013. { "sraib.sn", TILE_OPC_SRAIB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10014. TREG_SN, /* implicitly_written_register */
  10015. 1, /* can_bundle */
  10016. {
  10017. /* operands */
  10018. { 7, 8, 32 },
  10019. { 9, 10, 33 },
  10020. { 0, },
  10021. { 0, },
  10022. { 0, }
  10023. },
  10024. {
  10025. /* fixed_bit_masks */
  10026. 0x800000007ffe0000ULL,
  10027. 0xffff000000000000ULL,
  10028. 0ULL,
  10029. 0ULL,
  10030. 0ULL
  10031. },
  10032. {
  10033. /* fixed_bit_values */
  10034. 0x0000000078100000ULL,
  10035. 0x4408000000000000ULL,
  10036. -1ULL,
  10037. -1ULL,
  10038. -1ULL
  10039. }
  10040. },
  10041. { "sraih", TILE_OPC_SRAIH, 0x3 /* pipes */, 3 /* num_operands */,
  10042. TREG_ZERO, /* implicitly_written_register */
  10043. 1, /* can_bundle */
  10044. {
  10045. /* operands */
  10046. { 7, 8, 32 },
  10047. { 9, 10, 33 },
  10048. { 0, },
  10049. { 0, },
  10050. { 0, }
  10051. },
  10052. {
  10053. /* fixed_bit_masks */
  10054. 0x800000007ffe0000ULL,
  10055. 0xffff000000000000ULL,
  10056. 0ULL,
  10057. 0ULL,
  10058. 0ULL
  10059. },
  10060. {
  10061. /* fixed_bit_values */
  10062. 0x0000000070120000ULL,
  10063. 0x4009000000000000ULL,
  10064. -1ULL,
  10065. -1ULL,
  10066. -1ULL
  10067. }
  10068. },
  10069. { "sraih.sn", TILE_OPC_SRAIH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10070. TREG_SN, /* implicitly_written_register */
  10071. 1, /* can_bundle */
  10072. {
  10073. /* operands */
  10074. { 7, 8, 32 },
  10075. { 9, 10, 33 },
  10076. { 0, },
  10077. { 0, },
  10078. { 0, }
  10079. },
  10080. {
  10081. /* fixed_bit_masks */
  10082. 0x800000007ffe0000ULL,
  10083. 0xffff000000000000ULL,
  10084. 0ULL,
  10085. 0ULL,
  10086. 0ULL
  10087. },
  10088. {
  10089. /* fixed_bit_values */
  10090. 0x0000000078120000ULL,
  10091. 0x4409000000000000ULL,
  10092. -1ULL,
  10093. -1ULL,
  10094. -1ULL
  10095. }
  10096. },
  10097. { "sub", TILE_OPC_SUB, 0xf /* pipes */, 3 /* num_operands */,
  10098. TREG_ZERO, /* implicitly_written_register */
  10099. 1, /* can_bundle */
  10100. {
  10101. /* operands */
  10102. { 7, 8, 16 },
  10103. { 9, 10, 17 },
  10104. { 11, 12, 18 },
  10105. { 13, 14, 19 },
  10106. { 0, }
  10107. },
  10108. {
  10109. /* fixed_bit_masks */
  10110. 0x800000007ffc0000ULL,
  10111. 0xfffe000000000000ULL,
  10112. 0x80000000780c0000ULL,
  10113. 0xf806000000000000ULL,
  10114. 0ULL
  10115. },
  10116. {
  10117. /* fixed_bit_values */
  10118. 0x0000000001740000ULL,
  10119. 0x087e000000000000ULL,
  10120. 0x80000000080c0000ULL,
  10121. 0x8806000000000000ULL,
  10122. -1ULL
  10123. }
  10124. },
  10125. { "sub.sn", TILE_OPC_SUB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10126. TREG_SN, /* implicitly_written_register */
  10127. 1, /* can_bundle */
  10128. {
  10129. /* operands */
  10130. { 7, 8, 16 },
  10131. { 9, 10, 17 },
  10132. { 0, },
  10133. { 0, },
  10134. { 0, }
  10135. },
  10136. {
  10137. /* fixed_bit_masks */
  10138. 0x800000007ffc0000ULL,
  10139. 0xfffe000000000000ULL,
  10140. 0ULL,
  10141. 0ULL,
  10142. 0ULL
  10143. },
  10144. {
  10145. /* fixed_bit_values */
  10146. 0x0000000009740000ULL,
  10147. 0x0c7e000000000000ULL,
  10148. -1ULL,
  10149. -1ULL,
  10150. -1ULL
  10151. }
  10152. },
  10153. { "subb", TILE_OPC_SUBB, 0x3 /* pipes */, 3 /* num_operands */,
  10154. TREG_ZERO, /* implicitly_written_register */
  10155. 1, /* can_bundle */
  10156. {
  10157. /* operands */
  10158. { 7, 8, 16 },
  10159. { 9, 10, 17 },
  10160. { 0, },
  10161. { 0, },
  10162. { 0, }
  10163. },
  10164. {
  10165. /* fixed_bit_masks */
  10166. 0x800000007ffc0000ULL,
  10167. 0xfffe000000000000ULL,
  10168. 0ULL,
  10169. 0ULL,
  10170. 0ULL
  10171. },
  10172. {
  10173. /* fixed_bit_values */
  10174. 0x00000000016c0000ULL,
  10175. 0x087a000000000000ULL,
  10176. -1ULL,
  10177. -1ULL,
  10178. -1ULL
  10179. }
  10180. },
  10181. { "subb.sn", TILE_OPC_SUBB_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10182. TREG_SN, /* implicitly_written_register */
  10183. 1, /* can_bundle */
  10184. {
  10185. /* operands */
  10186. { 7, 8, 16 },
  10187. { 9, 10, 17 },
  10188. { 0, },
  10189. { 0, },
  10190. { 0, }
  10191. },
  10192. {
  10193. /* fixed_bit_masks */
  10194. 0x800000007ffc0000ULL,
  10195. 0xfffe000000000000ULL,
  10196. 0ULL,
  10197. 0ULL,
  10198. 0ULL
  10199. },
  10200. {
  10201. /* fixed_bit_values */
  10202. 0x00000000096c0000ULL,
  10203. 0x0c7a000000000000ULL,
  10204. -1ULL,
  10205. -1ULL,
  10206. -1ULL
  10207. }
  10208. },
  10209. { "subbs_u", TILE_OPC_SUBBS_U, 0x3 /* pipes */, 3 /* num_operands */,
  10210. TREG_ZERO, /* implicitly_written_register */
  10211. 1, /* can_bundle */
  10212. {
  10213. /* operands */
  10214. { 7, 8, 16 },
  10215. { 9, 10, 17 },
  10216. { 0, },
  10217. { 0, },
  10218. { 0, }
  10219. },
  10220. {
  10221. /* fixed_bit_masks */
  10222. 0x800000007ffc0000ULL,
  10223. 0xfffe000000000000ULL,
  10224. 0ULL,
  10225. 0ULL,
  10226. 0ULL
  10227. },
  10228. {
  10229. /* fixed_bit_values */
  10230. 0x0000000001900000ULL,
  10231. 0x088c000000000000ULL,
  10232. -1ULL,
  10233. -1ULL,
  10234. -1ULL
  10235. }
  10236. },
  10237. { "subbs_u.sn", TILE_OPC_SUBBS_U_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10238. TREG_SN, /* implicitly_written_register */
  10239. 1, /* can_bundle */
  10240. {
  10241. /* operands */
  10242. { 7, 8, 16 },
  10243. { 9, 10, 17 },
  10244. { 0, },
  10245. { 0, },
  10246. { 0, }
  10247. },
  10248. {
  10249. /* fixed_bit_masks */
  10250. 0x800000007ffc0000ULL,
  10251. 0xfffe000000000000ULL,
  10252. 0ULL,
  10253. 0ULL,
  10254. 0ULL
  10255. },
  10256. {
  10257. /* fixed_bit_values */
  10258. 0x0000000009900000ULL,
  10259. 0x0c8c000000000000ULL,
  10260. -1ULL,
  10261. -1ULL,
  10262. -1ULL
  10263. }
  10264. },
  10265. { "subh", TILE_OPC_SUBH, 0x3 /* pipes */, 3 /* num_operands */,
  10266. TREG_ZERO, /* implicitly_written_register */
  10267. 1, /* can_bundle */
  10268. {
  10269. /* operands */
  10270. { 7, 8, 16 },
  10271. { 9, 10, 17 },
  10272. { 0, },
  10273. { 0, },
  10274. { 0, }
  10275. },
  10276. {
  10277. /* fixed_bit_masks */
  10278. 0x800000007ffc0000ULL,
  10279. 0xfffe000000000000ULL,
  10280. 0ULL,
  10281. 0ULL,
  10282. 0ULL
  10283. },
  10284. {
  10285. /* fixed_bit_values */
  10286. 0x0000000001700000ULL,
  10287. 0x087c000000000000ULL,
  10288. -1ULL,
  10289. -1ULL,
  10290. -1ULL
  10291. }
  10292. },
  10293. { "subh.sn", TILE_OPC_SUBH_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10294. TREG_SN, /* implicitly_written_register */
  10295. 1, /* can_bundle */
  10296. {
  10297. /* operands */
  10298. { 7, 8, 16 },
  10299. { 9, 10, 17 },
  10300. { 0, },
  10301. { 0, },
  10302. { 0, }
  10303. },
  10304. {
  10305. /* fixed_bit_masks */
  10306. 0x800000007ffc0000ULL,
  10307. 0xfffe000000000000ULL,
  10308. 0ULL,
  10309. 0ULL,
  10310. 0ULL
  10311. },
  10312. {
  10313. /* fixed_bit_values */
  10314. 0x0000000009700000ULL,
  10315. 0x0c7c000000000000ULL,
  10316. -1ULL,
  10317. -1ULL,
  10318. -1ULL
  10319. }
  10320. },
  10321. { "subhs", TILE_OPC_SUBHS, 0x3 /* pipes */, 3 /* num_operands */,
  10322. TREG_ZERO, /* implicitly_written_register */
  10323. 1, /* can_bundle */
  10324. {
  10325. /* operands */
  10326. { 7, 8, 16 },
  10327. { 9, 10, 17 },
  10328. { 0, },
  10329. { 0, },
  10330. { 0, }
  10331. },
  10332. {
  10333. /* fixed_bit_masks */
  10334. 0x800000007ffc0000ULL,
  10335. 0xfffe000000000000ULL,
  10336. 0ULL,
  10337. 0ULL,
  10338. 0ULL
  10339. },
  10340. {
  10341. /* fixed_bit_values */
  10342. 0x0000000001940000ULL,
  10343. 0x088e000000000000ULL,
  10344. -1ULL,
  10345. -1ULL,
  10346. -1ULL
  10347. }
  10348. },
  10349. { "subhs.sn", TILE_OPC_SUBHS_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10350. TREG_SN, /* implicitly_written_register */
  10351. 1, /* can_bundle */
  10352. {
  10353. /* operands */
  10354. { 7, 8, 16 },
  10355. { 9, 10, 17 },
  10356. { 0, },
  10357. { 0, },
  10358. { 0, }
  10359. },
  10360. {
  10361. /* fixed_bit_masks */
  10362. 0x800000007ffc0000ULL,
  10363. 0xfffe000000000000ULL,
  10364. 0ULL,
  10365. 0ULL,
  10366. 0ULL
  10367. },
  10368. {
  10369. /* fixed_bit_values */
  10370. 0x0000000009940000ULL,
  10371. 0x0c8e000000000000ULL,
  10372. -1ULL,
  10373. -1ULL,
  10374. -1ULL
  10375. }
  10376. },
  10377. { "subs", TILE_OPC_SUBS, 0x3 /* pipes */, 3 /* num_operands */,
  10378. TREG_ZERO, /* implicitly_written_register */
  10379. 1, /* can_bundle */
  10380. {
  10381. /* operands */
  10382. { 7, 8, 16 },
  10383. { 9, 10, 17 },
  10384. { 0, },
  10385. { 0, },
  10386. { 0, }
  10387. },
  10388. {
  10389. /* fixed_bit_masks */
  10390. 0x800000007ffc0000ULL,
  10391. 0xfffe000000000000ULL,
  10392. 0ULL,
  10393. 0ULL,
  10394. 0ULL
  10395. },
  10396. {
  10397. /* fixed_bit_values */
  10398. 0x0000000001840000ULL,
  10399. 0x0886000000000000ULL,
  10400. -1ULL,
  10401. -1ULL,
  10402. -1ULL
  10403. }
  10404. },
  10405. { "subs.sn", TILE_OPC_SUBS_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10406. TREG_SN, /* implicitly_written_register */
  10407. 1, /* can_bundle */
  10408. {
  10409. /* operands */
  10410. { 7, 8, 16 },
  10411. { 9, 10, 17 },
  10412. { 0, },
  10413. { 0, },
  10414. { 0, }
  10415. },
  10416. {
  10417. /* fixed_bit_masks */
  10418. 0x800000007ffc0000ULL,
  10419. 0xfffe000000000000ULL,
  10420. 0ULL,
  10421. 0ULL,
  10422. 0ULL
  10423. },
  10424. {
  10425. /* fixed_bit_values */
  10426. 0x0000000009840000ULL,
  10427. 0x0c86000000000000ULL,
  10428. -1ULL,
  10429. -1ULL,
  10430. -1ULL
  10431. }
  10432. },
  10433. { "sw", TILE_OPC_SW, 0x12 /* pipes */, 2 /* num_operands */,
  10434. TREG_ZERO, /* implicitly_written_register */
  10435. 1, /* can_bundle */
  10436. {
  10437. /* operands */
  10438. { 0, },
  10439. { 10, 17 },
  10440. { 0, },
  10441. { 0, },
  10442. { 15, 36 }
  10443. },
  10444. {
  10445. /* fixed_bit_masks */
  10446. 0ULL,
  10447. 0xfbfe000000000000ULL,
  10448. 0ULL,
  10449. 0ULL,
  10450. 0x8700000000000000ULL
  10451. },
  10452. {
  10453. /* fixed_bit_values */
  10454. -1ULL,
  10455. 0x0880000000000000ULL,
  10456. -1ULL,
  10457. -1ULL,
  10458. 0x8700000000000000ULL
  10459. }
  10460. },
  10461. { "swadd", TILE_OPC_SWADD, 0x2 /* pipes */, 3 /* num_operands */,
  10462. TREG_ZERO, /* implicitly_written_register */
  10463. 1, /* can_bundle */
  10464. {
  10465. /* operands */
  10466. { 0, },
  10467. { 24, 17, 37 },
  10468. { 0, },
  10469. { 0, },
  10470. { 0, }
  10471. },
  10472. {
  10473. /* fixed_bit_masks */
  10474. 0ULL,
  10475. 0xfbf8000000000000ULL,
  10476. 0ULL,
  10477. 0ULL,
  10478. 0ULL
  10479. },
  10480. {
  10481. /* fixed_bit_values */
  10482. -1ULL,
  10483. 0x30f0000000000000ULL,
  10484. -1ULL,
  10485. -1ULL,
  10486. -1ULL
  10487. }
  10488. },
  10489. { "swint0", TILE_OPC_SWINT0, 0x2 /* pipes */, 0 /* num_operands */,
  10490. TREG_ZERO, /* implicitly_written_register */
  10491. 0, /* can_bundle */
  10492. {
  10493. /* operands */
  10494. { 0, },
  10495. { },
  10496. { 0, },
  10497. { 0, },
  10498. { 0, }
  10499. },
  10500. {
  10501. /* fixed_bit_masks */
  10502. 0ULL,
  10503. 0xfbfff80000000000ULL,
  10504. 0ULL,
  10505. 0ULL,
  10506. 0ULL
  10507. },
  10508. {
  10509. /* fixed_bit_values */
  10510. -1ULL,
  10511. 0x400b900000000000ULL,
  10512. -1ULL,
  10513. -1ULL,
  10514. -1ULL
  10515. }
  10516. },
  10517. { "swint1", TILE_OPC_SWINT1, 0x2 /* pipes */, 0 /* num_operands */,
  10518. TREG_ZERO, /* implicitly_written_register */
  10519. 0, /* can_bundle */
  10520. {
  10521. /* operands */
  10522. { 0, },
  10523. { },
  10524. { 0, },
  10525. { 0, },
  10526. { 0, }
  10527. },
  10528. {
  10529. /* fixed_bit_masks */
  10530. 0ULL,
  10531. 0xfbfff80000000000ULL,
  10532. 0ULL,
  10533. 0ULL,
  10534. 0ULL
  10535. },
  10536. {
  10537. /* fixed_bit_values */
  10538. -1ULL,
  10539. 0x400b980000000000ULL,
  10540. -1ULL,
  10541. -1ULL,
  10542. -1ULL
  10543. }
  10544. },
  10545. { "swint2", TILE_OPC_SWINT2, 0x2 /* pipes */, 0 /* num_operands */,
  10546. TREG_ZERO, /* implicitly_written_register */
  10547. 0, /* can_bundle */
  10548. {
  10549. /* operands */
  10550. { 0, },
  10551. { },
  10552. { 0, },
  10553. { 0, },
  10554. { 0, }
  10555. },
  10556. {
  10557. /* fixed_bit_masks */
  10558. 0ULL,
  10559. 0xfbfff80000000000ULL,
  10560. 0ULL,
  10561. 0ULL,
  10562. 0ULL
  10563. },
  10564. {
  10565. /* fixed_bit_values */
  10566. -1ULL,
  10567. 0x400ba00000000000ULL,
  10568. -1ULL,
  10569. -1ULL,
  10570. -1ULL
  10571. }
  10572. },
  10573. { "swint3", TILE_OPC_SWINT3, 0x2 /* pipes */, 0 /* num_operands */,
  10574. TREG_ZERO, /* implicitly_written_register */
  10575. 0, /* can_bundle */
  10576. {
  10577. /* operands */
  10578. { 0, },
  10579. { },
  10580. { 0, },
  10581. { 0, },
  10582. { 0, }
  10583. },
  10584. {
  10585. /* fixed_bit_masks */
  10586. 0ULL,
  10587. 0xfbfff80000000000ULL,
  10588. 0ULL,
  10589. 0ULL,
  10590. 0ULL
  10591. },
  10592. {
  10593. /* fixed_bit_values */
  10594. -1ULL,
  10595. 0x400ba80000000000ULL,
  10596. -1ULL,
  10597. -1ULL,
  10598. -1ULL
  10599. }
  10600. },
  10601. { "tblidxb0", TILE_OPC_TBLIDXB0, 0x5 /* pipes */, 2 /* num_operands */,
  10602. TREG_ZERO, /* implicitly_written_register */
  10603. 1, /* can_bundle */
  10604. {
  10605. /* operands */
  10606. { 21, 8 },
  10607. { 0, },
  10608. { 31, 12 },
  10609. { 0, },
  10610. { 0, }
  10611. },
  10612. {
  10613. /* fixed_bit_masks */
  10614. 0x800000007ffff000ULL,
  10615. 0ULL,
  10616. 0x80000000780ff000ULL,
  10617. 0ULL,
  10618. 0ULL
  10619. },
  10620. {
  10621. /* fixed_bit_values */
  10622. 0x0000000070168000ULL,
  10623. -1ULL,
  10624. 0x80000000680a8000ULL,
  10625. -1ULL,
  10626. -1ULL
  10627. }
  10628. },
  10629. { "tblidxb0.sn", TILE_OPC_TBLIDXB0_SN, 0x1 /* pipes */, 2 /* num_operands */,
  10630. TREG_SN, /* implicitly_written_register */
  10631. 1, /* can_bundle */
  10632. {
  10633. /* operands */
  10634. { 21, 8 },
  10635. { 0, },
  10636. { 0, },
  10637. { 0, },
  10638. { 0, }
  10639. },
  10640. {
  10641. /* fixed_bit_masks */
  10642. 0x800000007ffff000ULL,
  10643. 0ULL,
  10644. 0ULL,
  10645. 0ULL,
  10646. 0ULL
  10647. },
  10648. {
  10649. /* fixed_bit_values */
  10650. 0x0000000078168000ULL,
  10651. -1ULL,
  10652. -1ULL,
  10653. -1ULL,
  10654. -1ULL
  10655. }
  10656. },
  10657. { "tblidxb1", TILE_OPC_TBLIDXB1, 0x5 /* pipes */, 2 /* num_operands */,
  10658. TREG_ZERO, /* implicitly_written_register */
  10659. 1, /* can_bundle */
  10660. {
  10661. /* operands */
  10662. { 21, 8 },
  10663. { 0, },
  10664. { 31, 12 },
  10665. { 0, },
  10666. { 0, }
  10667. },
  10668. {
  10669. /* fixed_bit_masks */
  10670. 0x800000007ffff000ULL,
  10671. 0ULL,
  10672. 0x80000000780ff000ULL,
  10673. 0ULL,
  10674. 0ULL
  10675. },
  10676. {
  10677. /* fixed_bit_values */
  10678. 0x0000000070169000ULL,
  10679. -1ULL,
  10680. 0x80000000680a9000ULL,
  10681. -1ULL,
  10682. -1ULL
  10683. }
  10684. },
  10685. { "tblidxb1.sn", TILE_OPC_TBLIDXB1_SN, 0x1 /* pipes */, 2 /* num_operands */,
  10686. TREG_SN, /* implicitly_written_register */
  10687. 1, /* can_bundle */
  10688. {
  10689. /* operands */
  10690. { 21, 8 },
  10691. { 0, },
  10692. { 0, },
  10693. { 0, },
  10694. { 0, }
  10695. },
  10696. {
  10697. /* fixed_bit_masks */
  10698. 0x800000007ffff000ULL,
  10699. 0ULL,
  10700. 0ULL,
  10701. 0ULL,
  10702. 0ULL
  10703. },
  10704. {
  10705. /* fixed_bit_values */
  10706. 0x0000000078169000ULL,
  10707. -1ULL,
  10708. -1ULL,
  10709. -1ULL,
  10710. -1ULL
  10711. }
  10712. },
  10713. { "tblidxb2", TILE_OPC_TBLIDXB2, 0x5 /* pipes */, 2 /* num_operands */,
  10714. TREG_ZERO, /* implicitly_written_register */
  10715. 1, /* can_bundle */
  10716. {
  10717. /* operands */
  10718. { 21, 8 },
  10719. { 0, },
  10720. { 31, 12 },
  10721. { 0, },
  10722. { 0, }
  10723. },
  10724. {
  10725. /* fixed_bit_masks */
  10726. 0x800000007ffff000ULL,
  10727. 0ULL,
  10728. 0x80000000780ff000ULL,
  10729. 0ULL,
  10730. 0ULL
  10731. },
  10732. {
  10733. /* fixed_bit_values */
  10734. 0x000000007016a000ULL,
  10735. -1ULL,
  10736. 0x80000000680aa000ULL,
  10737. -1ULL,
  10738. -1ULL
  10739. }
  10740. },
  10741. { "tblidxb2.sn", TILE_OPC_TBLIDXB2_SN, 0x1 /* pipes */, 2 /* num_operands */,
  10742. TREG_SN, /* implicitly_written_register */
  10743. 1, /* can_bundle */
  10744. {
  10745. /* operands */
  10746. { 21, 8 },
  10747. { 0, },
  10748. { 0, },
  10749. { 0, },
  10750. { 0, }
  10751. },
  10752. {
  10753. /* fixed_bit_masks */
  10754. 0x800000007ffff000ULL,
  10755. 0ULL,
  10756. 0ULL,
  10757. 0ULL,
  10758. 0ULL
  10759. },
  10760. {
  10761. /* fixed_bit_values */
  10762. 0x000000007816a000ULL,
  10763. -1ULL,
  10764. -1ULL,
  10765. -1ULL,
  10766. -1ULL
  10767. }
  10768. },
  10769. { "tblidxb3", TILE_OPC_TBLIDXB3, 0x5 /* pipes */, 2 /* num_operands */,
  10770. TREG_ZERO, /* implicitly_written_register */
  10771. 1, /* can_bundle */
  10772. {
  10773. /* operands */
  10774. { 21, 8 },
  10775. { 0, },
  10776. { 31, 12 },
  10777. { 0, },
  10778. { 0, }
  10779. },
  10780. {
  10781. /* fixed_bit_masks */
  10782. 0x800000007ffff000ULL,
  10783. 0ULL,
  10784. 0x80000000780ff000ULL,
  10785. 0ULL,
  10786. 0ULL
  10787. },
  10788. {
  10789. /* fixed_bit_values */
  10790. 0x000000007016b000ULL,
  10791. -1ULL,
  10792. 0x80000000680ab000ULL,
  10793. -1ULL,
  10794. -1ULL
  10795. }
  10796. },
  10797. { "tblidxb3.sn", TILE_OPC_TBLIDXB3_SN, 0x1 /* pipes */, 2 /* num_operands */,
  10798. TREG_SN, /* implicitly_written_register */
  10799. 1, /* can_bundle */
  10800. {
  10801. /* operands */
  10802. { 21, 8 },
  10803. { 0, },
  10804. { 0, },
  10805. { 0, },
  10806. { 0, }
  10807. },
  10808. {
  10809. /* fixed_bit_masks */
  10810. 0x800000007ffff000ULL,
  10811. 0ULL,
  10812. 0ULL,
  10813. 0ULL,
  10814. 0ULL
  10815. },
  10816. {
  10817. /* fixed_bit_values */
  10818. 0x000000007816b000ULL,
  10819. -1ULL,
  10820. -1ULL,
  10821. -1ULL,
  10822. -1ULL
  10823. }
  10824. },
  10825. { "tns", TILE_OPC_TNS, 0x2 /* pipes */, 2 /* num_operands */,
  10826. TREG_ZERO, /* implicitly_written_register */
  10827. 1, /* can_bundle */
  10828. {
  10829. /* operands */
  10830. { 0, },
  10831. { 9, 10 },
  10832. { 0, },
  10833. { 0, },
  10834. { 0, }
  10835. },
  10836. {
  10837. /* fixed_bit_masks */
  10838. 0ULL,
  10839. 0xfffff80000000000ULL,
  10840. 0ULL,
  10841. 0ULL,
  10842. 0ULL
  10843. },
  10844. {
  10845. /* fixed_bit_values */
  10846. -1ULL,
  10847. 0x400bb00000000000ULL,
  10848. -1ULL,
  10849. -1ULL,
  10850. -1ULL
  10851. }
  10852. },
  10853. { "tns.sn", TILE_OPC_TNS_SN, 0x2 /* pipes */, 2 /* num_operands */,
  10854. TREG_SN, /* implicitly_written_register */
  10855. 1, /* can_bundle */
  10856. {
  10857. /* operands */
  10858. { 0, },
  10859. { 9, 10 },
  10860. { 0, },
  10861. { 0, },
  10862. { 0, }
  10863. },
  10864. {
  10865. /* fixed_bit_masks */
  10866. 0ULL,
  10867. 0xfffff80000000000ULL,
  10868. 0ULL,
  10869. 0ULL,
  10870. 0ULL
  10871. },
  10872. {
  10873. /* fixed_bit_values */
  10874. -1ULL,
  10875. 0x440bb00000000000ULL,
  10876. -1ULL,
  10877. -1ULL,
  10878. -1ULL
  10879. }
  10880. },
  10881. { "wh64", TILE_OPC_WH64, 0x2 /* pipes */, 1 /* num_operands */,
  10882. TREG_ZERO, /* implicitly_written_register */
  10883. 1, /* can_bundle */
  10884. {
  10885. /* operands */
  10886. { 0, },
  10887. { 10 },
  10888. { 0, },
  10889. { 0, },
  10890. { 0, }
  10891. },
  10892. {
  10893. /* fixed_bit_masks */
  10894. 0ULL,
  10895. 0xfbfff80000000000ULL,
  10896. 0ULL,
  10897. 0ULL,
  10898. 0ULL
  10899. },
  10900. {
  10901. /* fixed_bit_values */
  10902. -1ULL,
  10903. 0x400bb80000000000ULL,
  10904. -1ULL,
  10905. -1ULL,
  10906. -1ULL
  10907. }
  10908. },
  10909. { "xor", TILE_OPC_XOR, 0xf /* pipes */, 3 /* num_operands */,
  10910. TREG_ZERO, /* implicitly_written_register */
  10911. 1, /* can_bundle */
  10912. {
  10913. /* operands */
  10914. { 7, 8, 16 },
  10915. { 9, 10, 17 },
  10916. { 11, 12, 18 },
  10917. { 13, 14, 19 },
  10918. { 0, }
  10919. },
  10920. {
  10921. /* fixed_bit_masks */
  10922. 0x800000007ffc0000ULL,
  10923. 0xfffe000000000000ULL,
  10924. 0x80000000780c0000ULL,
  10925. 0xf806000000000000ULL,
  10926. 0ULL
  10927. },
  10928. {
  10929. /* fixed_bit_values */
  10930. 0x0000000001780000ULL,
  10931. 0x0882000000000000ULL,
  10932. 0x80000000180c0000ULL,
  10933. 0x9806000000000000ULL,
  10934. -1ULL
  10935. }
  10936. },
  10937. { "xor.sn", TILE_OPC_XOR_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10938. TREG_SN, /* implicitly_written_register */
  10939. 1, /* can_bundle */
  10940. {
  10941. /* operands */
  10942. { 7, 8, 16 },
  10943. { 9, 10, 17 },
  10944. { 0, },
  10945. { 0, },
  10946. { 0, }
  10947. },
  10948. {
  10949. /* fixed_bit_masks */
  10950. 0x800000007ffc0000ULL,
  10951. 0xfffe000000000000ULL,
  10952. 0ULL,
  10953. 0ULL,
  10954. 0ULL
  10955. },
  10956. {
  10957. /* fixed_bit_values */
  10958. 0x0000000009780000ULL,
  10959. 0x0c82000000000000ULL,
  10960. -1ULL,
  10961. -1ULL,
  10962. -1ULL
  10963. }
  10964. },
  10965. { "xori", TILE_OPC_XORI, 0x3 /* pipes */, 3 /* num_operands */,
  10966. TREG_ZERO, /* implicitly_written_register */
  10967. 1, /* can_bundle */
  10968. {
  10969. /* operands */
  10970. { 7, 8, 0 },
  10971. { 9, 10, 1 },
  10972. { 0, },
  10973. { 0, },
  10974. { 0, }
  10975. },
  10976. {
  10977. /* fixed_bit_masks */
  10978. 0x800000007ff00000ULL,
  10979. 0xfff8000000000000ULL,
  10980. 0ULL,
  10981. 0ULL,
  10982. 0ULL
  10983. },
  10984. {
  10985. /* fixed_bit_values */
  10986. 0x0000000050200000ULL,
  10987. 0x30a8000000000000ULL,
  10988. -1ULL,
  10989. -1ULL,
  10990. -1ULL
  10991. }
  10992. },
  10993. { "xori.sn", TILE_OPC_XORI_SN, 0x3 /* pipes */, 3 /* num_operands */,
  10994. TREG_SN, /* implicitly_written_register */
  10995. 1, /* can_bundle */
  10996. {
  10997. /* operands */
  10998. { 7, 8, 0 },
  10999. { 9, 10, 1 },
  11000. { 0, },
  11001. { 0, },
  11002. { 0, }
  11003. },
  11004. {
  11005. /* fixed_bit_masks */
  11006. 0x800000007ff00000ULL,
  11007. 0xfff8000000000000ULL,
  11008. 0ULL,
  11009. 0ULL,
  11010. 0ULL
  11011. },
  11012. {
  11013. /* fixed_bit_values */
  11014. 0x0000000058200000ULL,
  11015. 0x34a8000000000000ULL,
  11016. -1ULL,
  11017. -1ULL,
  11018. -1ULL
  11019. }
  11020. },
  11021. { 0, TILE_OPC_NONE, 0, 0, 0, TREG_ZERO, { { 0, } }, { 0, }, { 0, }
  11022. }
  11023. };
  11024. #define BITFIELD(start, size) ((start) | (((1 << (size)) - 1) << 6))
  11025. #define CHILD(array_index) (TILE_OPC_NONE + (array_index))
  11026. static const unsigned short decode_X0_fsm[1153] =
  11027. {
  11028. BITFIELD(22, 9) /* index 0 */,
  11029. CHILD(513), CHILD(530), CHILD(547), CHILD(564), CHILD(596), CHILD(613),
  11030. CHILD(630), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11031. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11032. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11033. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11034. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11035. TILE_OPC_NONE, CHILD(663), CHILD(680), CHILD(697), CHILD(714), CHILD(746),
  11036. CHILD(763), CHILD(780), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11037. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11038. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11039. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11040. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11041. TILE_OPC_NONE, TILE_OPC_NONE, CHILD(813), CHILD(813), CHILD(813),
  11042. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11043. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11044. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11045. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11046. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11047. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11048. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11049. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11050. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11051. CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
  11052. CHILD(813), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11053. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11054. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11055. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11056. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11057. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11058. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11059. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11060. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11061. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
  11062. CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(843),
  11063. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11064. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11065. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11066. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11067. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11068. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11069. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11070. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11071. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11072. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11073. CHILD(843), CHILD(843), CHILD(843), CHILD(873), CHILD(878), CHILD(883),
  11074. CHILD(903), CHILD(908), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11075. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11076. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11077. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11078. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11079. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, CHILD(913),
  11080. CHILD(918), CHILD(923), CHILD(943), CHILD(948), TILE_OPC_NONE,
  11081. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11082. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11083. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11084. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11085. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11086. TILE_OPC_NONE, CHILD(953), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11087. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11088. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11089. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11090. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11091. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11092. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, CHILD(988), TILE_OPC_NONE,
  11093. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11094. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11095. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11096. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11097. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11098. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11099. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11100. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11101. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11102. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11103. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11104. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11105. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11106. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11107. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11108. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11109. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11110. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11111. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, CHILD(993),
  11112. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11113. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11114. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11115. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11116. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11117. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11118. TILE_OPC_NONE, CHILD(1076), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11119. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11120. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11121. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11122. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11123. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11124. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11125. BITFIELD(18, 4) /* index 513 */,
  11126. TILE_OPC_NONE, TILE_OPC_ADDB, TILE_OPC_ADDH, TILE_OPC_ADD,
  11127. TILE_OPC_ADIFFB_U, TILE_OPC_ADIFFH, TILE_OPC_AND, TILE_OPC_AVGB_U,
  11128. TILE_OPC_AVGH, TILE_OPC_CRC32_32, TILE_OPC_CRC32_8, TILE_OPC_INTHB,
  11129. TILE_OPC_INTHH, TILE_OPC_INTLB, TILE_OPC_INTLH, TILE_OPC_MAXB_U,
  11130. BITFIELD(18, 4) /* index 530 */,
  11131. TILE_OPC_MAXH, TILE_OPC_MINB_U, TILE_OPC_MINH, TILE_OPC_MNZB, TILE_OPC_MNZH,
  11132. TILE_OPC_MNZ, TILE_OPC_MULHHA_SS, TILE_OPC_MULHHA_SU, TILE_OPC_MULHHA_UU,
  11133. TILE_OPC_MULHHSA_UU, TILE_OPC_MULHH_SS, TILE_OPC_MULHH_SU,
  11134. TILE_OPC_MULHH_UU, TILE_OPC_MULHLA_SS, TILE_OPC_MULHLA_SU,
  11135. TILE_OPC_MULHLA_US,
  11136. BITFIELD(18, 4) /* index 547 */,
  11137. TILE_OPC_MULHLA_UU, TILE_OPC_MULHLSA_UU, TILE_OPC_MULHL_SS,
  11138. TILE_OPC_MULHL_SU, TILE_OPC_MULHL_US, TILE_OPC_MULHL_UU, TILE_OPC_MULLLA_SS,
  11139. TILE_OPC_MULLLA_SU, TILE_OPC_MULLLA_UU, TILE_OPC_MULLLSA_UU,
  11140. TILE_OPC_MULLL_SS, TILE_OPC_MULLL_SU, TILE_OPC_MULLL_UU, TILE_OPC_MVNZ,
  11141. TILE_OPC_MVZ, TILE_OPC_MZB,
  11142. BITFIELD(18, 4) /* index 564 */,
  11143. TILE_OPC_MZH, TILE_OPC_MZ, TILE_OPC_NOR, CHILD(581), TILE_OPC_PACKHB,
  11144. TILE_OPC_PACKLB, TILE_OPC_RL, TILE_OPC_S1A, TILE_OPC_S2A, TILE_OPC_S3A,
  11145. TILE_OPC_SADAB_U, TILE_OPC_SADAH, TILE_OPC_SADAH_U, TILE_OPC_SADB_U,
  11146. TILE_OPC_SADH, TILE_OPC_SADH_U,
  11147. BITFIELD(12, 2) /* index 581 */,
  11148. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(586),
  11149. BITFIELD(14, 2) /* index 586 */,
  11150. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(591),
  11151. BITFIELD(16, 2) /* index 591 */,
  11152. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_MOVE,
  11153. BITFIELD(18, 4) /* index 596 */,
  11154. TILE_OPC_SEQB, TILE_OPC_SEQH, TILE_OPC_SEQ, TILE_OPC_SHLB, TILE_OPC_SHLH,
  11155. TILE_OPC_SHL, TILE_OPC_SHRB, TILE_OPC_SHRH, TILE_OPC_SHR, TILE_OPC_SLTB,
  11156. TILE_OPC_SLTB_U, TILE_OPC_SLTEB, TILE_OPC_SLTEB_U, TILE_OPC_SLTEH,
  11157. TILE_OPC_SLTEH_U, TILE_OPC_SLTE,
  11158. BITFIELD(18, 4) /* index 613 */,
  11159. TILE_OPC_SLTE_U, TILE_OPC_SLTH, TILE_OPC_SLTH_U, TILE_OPC_SLT,
  11160. TILE_OPC_SLT_U, TILE_OPC_SNEB, TILE_OPC_SNEH, TILE_OPC_SNE, TILE_OPC_SRAB,
  11161. TILE_OPC_SRAH, TILE_OPC_SRA, TILE_OPC_SUBB, TILE_OPC_SUBH, TILE_OPC_SUB,
  11162. TILE_OPC_XOR, TILE_OPC_DWORD_ALIGN,
  11163. BITFIELD(18, 3) /* index 630 */,
  11164. CHILD(639), CHILD(642), CHILD(645), CHILD(648), CHILD(651), CHILD(654),
  11165. CHILD(657), CHILD(660),
  11166. BITFIELD(21, 1) /* index 639 */,
  11167. TILE_OPC_ADDS, TILE_OPC_NONE,
  11168. BITFIELD(21, 1) /* index 642 */,
  11169. TILE_OPC_SUBS, TILE_OPC_NONE,
  11170. BITFIELD(21, 1) /* index 645 */,
  11171. TILE_OPC_ADDBS_U, TILE_OPC_NONE,
  11172. BITFIELD(21, 1) /* index 648 */,
  11173. TILE_OPC_ADDHS, TILE_OPC_NONE,
  11174. BITFIELD(21, 1) /* index 651 */,
  11175. TILE_OPC_SUBBS_U, TILE_OPC_NONE,
  11176. BITFIELD(21, 1) /* index 654 */,
  11177. TILE_OPC_SUBHS, TILE_OPC_NONE,
  11178. BITFIELD(21, 1) /* index 657 */,
  11179. TILE_OPC_PACKHS, TILE_OPC_NONE,
  11180. BITFIELD(21, 1) /* index 660 */,
  11181. TILE_OPC_PACKBS_U, TILE_OPC_NONE,
  11182. BITFIELD(18, 4) /* index 663 */,
  11183. TILE_OPC_NONE, TILE_OPC_ADDB_SN, TILE_OPC_ADDH_SN, TILE_OPC_ADD_SN,
  11184. TILE_OPC_ADIFFB_U_SN, TILE_OPC_ADIFFH_SN, TILE_OPC_AND_SN,
  11185. TILE_OPC_AVGB_U_SN, TILE_OPC_AVGH_SN, TILE_OPC_CRC32_32_SN,
  11186. TILE_OPC_CRC32_8_SN, TILE_OPC_INTHB_SN, TILE_OPC_INTHH_SN,
  11187. TILE_OPC_INTLB_SN, TILE_OPC_INTLH_SN, TILE_OPC_MAXB_U_SN,
  11188. BITFIELD(18, 4) /* index 680 */,
  11189. TILE_OPC_MAXH_SN, TILE_OPC_MINB_U_SN, TILE_OPC_MINH_SN, TILE_OPC_MNZB_SN,
  11190. TILE_OPC_MNZH_SN, TILE_OPC_MNZ_SN, TILE_OPC_MULHHA_SS_SN,
  11191. TILE_OPC_MULHHA_SU_SN, TILE_OPC_MULHHA_UU_SN, TILE_OPC_MULHHSA_UU_SN,
  11192. TILE_OPC_MULHH_SS_SN, TILE_OPC_MULHH_SU_SN, TILE_OPC_MULHH_UU_SN,
  11193. TILE_OPC_MULHLA_SS_SN, TILE_OPC_MULHLA_SU_SN, TILE_OPC_MULHLA_US_SN,
  11194. BITFIELD(18, 4) /* index 697 */,
  11195. TILE_OPC_MULHLA_UU_SN, TILE_OPC_MULHLSA_UU_SN, TILE_OPC_MULHL_SS_SN,
  11196. TILE_OPC_MULHL_SU_SN, TILE_OPC_MULHL_US_SN, TILE_OPC_MULHL_UU_SN,
  11197. TILE_OPC_MULLLA_SS_SN, TILE_OPC_MULLLA_SU_SN, TILE_OPC_MULLLA_UU_SN,
  11198. TILE_OPC_MULLLSA_UU_SN, TILE_OPC_MULLL_SS_SN, TILE_OPC_MULLL_SU_SN,
  11199. TILE_OPC_MULLL_UU_SN, TILE_OPC_MVNZ_SN, TILE_OPC_MVZ_SN, TILE_OPC_MZB_SN,
  11200. BITFIELD(18, 4) /* index 714 */,
  11201. TILE_OPC_MZH_SN, TILE_OPC_MZ_SN, TILE_OPC_NOR_SN, CHILD(731),
  11202. TILE_OPC_PACKHB_SN, TILE_OPC_PACKLB_SN, TILE_OPC_RL_SN, TILE_OPC_S1A_SN,
  11203. TILE_OPC_S2A_SN, TILE_OPC_S3A_SN, TILE_OPC_SADAB_U_SN, TILE_OPC_SADAH_SN,
  11204. TILE_OPC_SADAH_U_SN, TILE_OPC_SADB_U_SN, TILE_OPC_SADH_SN,
  11205. TILE_OPC_SADH_U_SN,
  11206. BITFIELD(12, 2) /* index 731 */,
  11207. TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_OR_SN, CHILD(736),
  11208. BITFIELD(14, 2) /* index 736 */,
  11209. TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_OR_SN, CHILD(741),
  11210. BITFIELD(16, 2) /* index 741 */,
  11211. TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_MOVE_SN,
  11212. BITFIELD(18, 4) /* index 746 */,
  11213. TILE_OPC_SEQB_SN, TILE_OPC_SEQH_SN, TILE_OPC_SEQ_SN, TILE_OPC_SHLB_SN,
  11214. TILE_OPC_SHLH_SN, TILE_OPC_SHL_SN, TILE_OPC_SHRB_SN, TILE_OPC_SHRH_SN,
  11215. TILE_OPC_SHR_SN, TILE_OPC_SLTB_SN, TILE_OPC_SLTB_U_SN, TILE_OPC_SLTEB_SN,
  11216. TILE_OPC_SLTEB_U_SN, TILE_OPC_SLTEH_SN, TILE_OPC_SLTEH_U_SN,
  11217. TILE_OPC_SLTE_SN,
  11218. BITFIELD(18, 4) /* index 763 */,
  11219. TILE_OPC_SLTE_U_SN, TILE_OPC_SLTH_SN, TILE_OPC_SLTH_U_SN, TILE_OPC_SLT_SN,
  11220. TILE_OPC_SLT_U_SN, TILE_OPC_SNEB_SN, TILE_OPC_SNEH_SN, TILE_OPC_SNE_SN,
  11221. TILE_OPC_SRAB_SN, TILE_OPC_SRAH_SN, TILE_OPC_SRA_SN, TILE_OPC_SUBB_SN,
  11222. TILE_OPC_SUBH_SN, TILE_OPC_SUB_SN, TILE_OPC_XOR_SN, TILE_OPC_DWORD_ALIGN_SN,
  11223. BITFIELD(18, 3) /* index 780 */,
  11224. CHILD(789), CHILD(792), CHILD(795), CHILD(798), CHILD(801), CHILD(804),
  11225. CHILD(807), CHILD(810),
  11226. BITFIELD(21, 1) /* index 789 */,
  11227. TILE_OPC_ADDS_SN, TILE_OPC_NONE,
  11228. BITFIELD(21, 1) /* index 792 */,
  11229. TILE_OPC_SUBS_SN, TILE_OPC_NONE,
  11230. BITFIELD(21, 1) /* index 795 */,
  11231. TILE_OPC_ADDBS_U_SN, TILE_OPC_NONE,
  11232. BITFIELD(21, 1) /* index 798 */,
  11233. TILE_OPC_ADDHS_SN, TILE_OPC_NONE,
  11234. BITFIELD(21, 1) /* index 801 */,
  11235. TILE_OPC_SUBBS_U_SN, TILE_OPC_NONE,
  11236. BITFIELD(21, 1) /* index 804 */,
  11237. TILE_OPC_SUBHS_SN, TILE_OPC_NONE,
  11238. BITFIELD(21, 1) /* index 807 */,
  11239. TILE_OPC_PACKHS_SN, TILE_OPC_NONE,
  11240. BITFIELD(21, 1) /* index 810 */,
  11241. TILE_OPC_PACKBS_U_SN, TILE_OPC_NONE,
  11242. BITFIELD(6, 2) /* index 813 */,
  11243. TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, CHILD(818),
  11244. BITFIELD(8, 2) /* index 818 */,
  11245. TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, CHILD(823),
  11246. BITFIELD(10, 2) /* index 823 */,
  11247. TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_MOVELI_SN,
  11248. BITFIELD(6, 2) /* index 828 */,
  11249. TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_ADDLI, CHILD(833),
  11250. BITFIELD(8, 2) /* index 833 */,
  11251. TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_ADDLI, CHILD(838),
  11252. BITFIELD(10, 2) /* index 838 */,
  11253. TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_MOVELI,
  11254. BITFIELD(0, 2) /* index 843 */,
  11255. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(848),
  11256. BITFIELD(2, 2) /* index 848 */,
  11257. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(853),
  11258. BITFIELD(4, 2) /* index 853 */,
  11259. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(858),
  11260. BITFIELD(6, 2) /* index 858 */,
  11261. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(863),
  11262. BITFIELD(8, 2) /* index 863 */,
  11263. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(868),
  11264. BITFIELD(10, 2) /* index 868 */,
  11265. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_INFOL,
  11266. BITFIELD(20, 2) /* index 873 */,
  11267. TILE_OPC_NONE, TILE_OPC_ADDIB, TILE_OPC_ADDIH, TILE_OPC_ADDI,
  11268. BITFIELD(20, 2) /* index 878 */,
  11269. TILE_OPC_MAXIB_U, TILE_OPC_MAXIH, TILE_OPC_MINIB_U, TILE_OPC_MINIH,
  11270. BITFIELD(20, 2) /* index 883 */,
  11271. CHILD(888), TILE_OPC_SEQIB, TILE_OPC_SEQIH, TILE_OPC_SEQI,
  11272. BITFIELD(6, 2) /* index 888 */,
  11273. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(893),
  11274. BITFIELD(8, 2) /* index 893 */,
  11275. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(898),
  11276. BITFIELD(10, 2) /* index 898 */,
  11277. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_MOVEI,
  11278. BITFIELD(20, 2) /* index 903 */,
  11279. TILE_OPC_SLTIB, TILE_OPC_SLTIB_U, TILE_OPC_SLTIH, TILE_OPC_SLTIH_U,
  11280. BITFIELD(20, 2) /* index 908 */,
  11281. TILE_OPC_SLTI, TILE_OPC_SLTI_U, TILE_OPC_NONE, TILE_OPC_NONE,
  11282. BITFIELD(20, 2) /* index 913 */,
  11283. TILE_OPC_NONE, TILE_OPC_ADDIB_SN, TILE_OPC_ADDIH_SN, TILE_OPC_ADDI_SN,
  11284. BITFIELD(20, 2) /* index 918 */,
  11285. TILE_OPC_MAXIB_U_SN, TILE_OPC_MAXIH_SN, TILE_OPC_MINIB_U_SN,
  11286. TILE_OPC_MINIH_SN,
  11287. BITFIELD(20, 2) /* index 923 */,
  11288. CHILD(928), TILE_OPC_SEQIB_SN, TILE_OPC_SEQIH_SN, TILE_OPC_SEQI_SN,
  11289. BITFIELD(6, 2) /* index 928 */,
  11290. TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, CHILD(933),
  11291. BITFIELD(8, 2) /* index 933 */,
  11292. TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, CHILD(938),
  11293. BITFIELD(10, 2) /* index 938 */,
  11294. TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_MOVEI_SN,
  11295. BITFIELD(20, 2) /* index 943 */,
  11296. TILE_OPC_SLTIB_SN, TILE_OPC_SLTIB_U_SN, TILE_OPC_SLTIH_SN,
  11297. TILE_OPC_SLTIH_U_SN,
  11298. BITFIELD(20, 2) /* index 948 */,
  11299. TILE_OPC_SLTI_SN, TILE_OPC_SLTI_U_SN, TILE_OPC_NONE, TILE_OPC_NONE,
  11300. BITFIELD(20, 2) /* index 953 */,
  11301. TILE_OPC_NONE, CHILD(958), TILE_OPC_XORI, TILE_OPC_NONE,
  11302. BITFIELD(0, 2) /* index 958 */,
  11303. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(963),
  11304. BITFIELD(2, 2) /* index 963 */,
  11305. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(968),
  11306. BITFIELD(4, 2) /* index 968 */,
  11307. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(973),
  11308. BITFIELD(6, 2) /* index 973 */,
  11309. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(978),
  11310. BITFIELD(8, 2) /* index 978 */,
  11311. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(983),
  11312. BITFIELD(10, 2) /* index 983 */,
  11313. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_INFO,
  11314. BITFIELD(20, 2) /* index 988 */,
  11315. TILE_OPC_NONE, TILE_OPC_ANDI_SN, TILE_OPC_XORI_SN, TILE_OPC_NONE,
  11316. BITFIELD(17, 5) /* index 993 */,
  11317. TILE_OPC_NONE, TILE_OPC_RLI, TILE_OPC_SHLIB, TILE_OPC_SHLIH, TILE_OPC_SHLI,
  11318. TILE_OPC_SHRIB, TILE_OPC_SHRIH, TILE_OPC_SHRI, TILE_OPC_SRAIB,
  11319. TILE_OPC_SRAIH, TILE_OPC_SRAI, CHILD(1026), TILE_OPC_NONE, TILE_OPC_NONE,
  11320. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11321. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11322. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11323. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11324. BITFIELD(12, 4) /* index 1026 */,
  11325. TILE_OPC_NONE, CHILD(1043), CHILD(1046), CHILD(1049), CHILD(1052),
  11326. CHILD(1055), CHILD(1058), CHILD(1061), CHILD(1064), CHILD(1067),
  11327. CHILD(1070), CHILD(1073), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11328. TILE_OPC_NONE,
  11329. BITFIELD(16, 1) /* index 1043 */,
  11330. TILE_OPC_BITX, TILE_OPC_NONE,
  11331. BITFIELD(16, 1) /* index 1046 */,
  11332. TILE_OPC_BYTEX, TILE_OPC_NONE,
  11333. BITFIELD(16, 1) /* index 1049 */,
  11334. TILE_OPC_CLZ, TILE_OPC_NONE,
  11335. BITFIELD(16, 1) /* index 1052 */,
  11336. TILE_OPC_CTZ, TILE_OPC_NONE,
  11337. BITFIELD(16, 1) /* index 1055 */,
  11338. TILE_OPC_FNOP, TILE_OPC_NONE,
  11339. BITFIELD(16, 1) /* index 1058 */,
  11340. TILE_OPC_NOP, TILE_OPC_NONE,
  11341. BITFIELD(16, 1) /* index 1061 */,
  11342. TILE_OPC_PCNT, TILE_OPC_NONE,
  11343. BITFIELD(16, 1) /* index 1064 */,
  11344. TILE_OPC_TBLIDXB0, TILE_OPC_NONE,
  11345. BITFIELD(16, 1) /* index 1067 */,
  11346. TILE_OPC_TBLIDXB1, TILE_OPC_NONE,
  11347. BITFIELD(16, 1) /* index 1070 */,
  11348. TILE_OPC_TBLIDXB2, TILE_OPC_NONE,
  11349. BITFIELD(16, 1) /* index 1073 */,
  11350. TILE_OPC_TBLIDXB3, TILE_OPC_NONE,
  11351. BITFIELD(17, 5) /* index 1076 */,
  11352. TILE_OPC_NONE, TILE_OPC_RLI_SN, TILE_OPC_SHLIB_SN, TILE_OPC_SHLIH_SN,
  11353. TILE_OPC_SHLI_SN, TILE_OPC_SHRIB_SN, TILE_OPC_SHRIH_SN, TILE_OPC_SHRI_SN,
  11354. TILE_OPC_SRAIB_SN, TILE_OPC_SRAIH_SN, TILE_OPC_SRAI_SN, CHILD(1109),
  11355. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11356. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11357. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11358. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11359. BITFIELD(12, 4) /* index 1109 */,
  11360. TILE_OPC_NONE, CHILD(1126), CHILD(1129), CHILD(1132), CHILD(1135),
  11361. CHILD(1055), CHILD(1058), CHILD(1138), CHILD(1141), CHILD(1144),
  11362. CHILD(1147), CHILD(1150), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11363. TILE_OPC_NONE,
  11364. BITFIELD(16, 1) /* index 1126 */,
  11365. TILE_OPC_BITX_SN, TILE_OPC_NONE,
  11366. BITFIELD(16, 1) /* index 1129 */,
  11367. TILE_OPC_BYTEX_SN, TILE_OPC_NONE,
  11368. BITFIELD(16, 1) /* index 1132 */,
  11369. TILE_OPC_CLZ_SN, TILE_OPC_NONE,
  11370. BITFIELD(16, 1) /* index 1135 */,
  11371. TILE_OPC_CTZ_SN, TILE_OPC_NONE,
  11372. BITFIELD(16, 1) /* index 1138 */,
  11373. TILE_OPC_PCNT_SN, TILE_OPC_NONE,
  11374. BITFIELD(16, 1) /* index 1141 */,
  11375. TILE_OPC_TBLIDXB0_SN, TILE_OPC_NONE,
  11376. BITFIELD(16, 1) /* index 1144 */,
  11377. TILE_OPC_TBLIDXB1_SN, TILE_OPC_NONE,
  11378. BITFIELD(16, 1) /* index 1147 */,
  11379. TILE_OPC_TBLIDXB2_SN, TILE_OPC_NONE,
  11380. BITFIELD(16, 1) /* index 1150 */,
  11381. TILE_OPC_TBLIDXB3_SN, TILE_OPC_NONE,
  11382. };
  11383. static const unsigned short decode_X1_fsm[1509] =
  11384. {
  11385. BITFIELD(54, 9) /* index 0 */,
  11386. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11387. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11388. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11389. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11390. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11391. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11392. TILE_OPC_NONE, TILE_OPC_NONE, CHILD(513), CHILD(561), CHILD(594),
  11393. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11394. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11395. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, CHILD(641), CHILD(689),
  11396. CHILD(722), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11397. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11398. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, CHILD(766),
  11399. CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
  11400. CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
  11401. CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
  11402. CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
  11403. CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
  11404. CHILD(766), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
  11405. CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
  11406. CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
  11407. CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
  11408. CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
  11409. CHILD(781), CHILD(781), CHILD(781), CHILD(796), CHILD(796), CHILD(796),
  11410. CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
  11411. CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
  11412. CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
  11413. CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
  11414. CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(826),
  11415. CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826),
  11416. CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826),
  11417. CHILD(826), CHILD(826), CHILD(826), CHILD(843), CHILD(843), CHILD(843),
  11418. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11419. CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
  11420. CHILD(843), CHILD(860), CHILD(899), CHILD(923), CHILD(932), TILE_OPC_NONE,
  11421. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11422. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11423. TILE_OPC_NONE, CHILD(941), CHILD(950), CHILD(974), CHILD(983),
  11424. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11425. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11426. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11427. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11428. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11429. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11430. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11431. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM,
  11432. TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, TILE_OPC_MM, CHILD(992),
  11433. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11434. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11435. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11436. CHILD(1303), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11437. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11438. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11439. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11440. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11441. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11442. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11443. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11444. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11445. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_J, TILE_OPC_J,
  11446. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11447. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11448. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11449. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11450. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11451. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11452. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11453. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11454. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11455. TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J, TILE_OPC_J,
  11456. TILE_OPC_J, TILE_OPC_J, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11457. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11458. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11459. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11460. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11461. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11462. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11463. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11464. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11465. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11466. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11467. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11468. TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL, TILE_OPC_JAL,
  11469. TILE_OPC_JAL, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11470. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11471. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11472. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11473. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11474. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11475. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11476. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11477. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11478. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11479. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11480. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11481. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11482. BITFIELD(49, 5) /* index 513 */,
  11483. TILE_OPC_NONE, TILE_OPC_ADDB, TILE_OPC_ADDH, TILE_OPC_ADD, TILE_OPC_AND,
  11484. TILE_OPC_INTHB, TILE_OPC_INTHH, TILE_OPC_INTLB, TILE_OPC_INTLH,
  11485. TILE_OPC_JALRP, TILE_OPC_JALR, TILE_OPC_JRP, TILE_OPC_JR, TILE_OPC_LNK,
  11486. TILE_OPC_MAXB_U, TILE_OPC_MAXH, TILE_OPC_MINB_U, TILE_OPC_MINH,
  11487. TILE_OPC_MNZB, TILE_OPC_MNZH, TILE_OPC_MNZ, TILE_OPC_MZB, TILE_OPC_MZH,
  11488. TILE_OPC_MZ, TILE_OPC_NOR, CHILD(546), TILE_OPC_PACKHB, TILE_OPC_PACKLB,
  11489. TILE_OPC_RL, TILE_OPC_S1A, TILE_OPC_S2A, TILE_OPC_S3A,
  11490. BITFIELD(43, 2) /* index 546 */,
  11491. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(551),
  11492. BITFIELD(45, 2) /* index 551 */,
  11493. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(556),
  11494. BITFIELD(47, 2) /* index 556 */,
  11495. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_MOVE,
  11496. BITFIELD(49, 5) /* index 561 */,
  11497. TILE_OPC_SB, TILE_OPC_SEQB, TILE_OPC_SEQH, TILE_OPC_SEQ, TILE_OPC_SHLB,
  11498. TILE_OPC_SHLH, TILE_OPC_SHL, TILE_OPC_SHRB, TILE_OPC_SHRH, TILE_OPC_SHR,
  11499. TILE_OPC_SH, TILE_OPC_SLTB, TILE_OPC_SLTB_U, TILE_OPC_SLTEB,
  11500. TILE_OPC_SLTEB_U, TILE_OPC_SLTEH, TILE_OPC_SLTEH_U, TILE_OPC_SLTE,
  11501. TILE_OPC_SLTE_U, TILE_OPC_SLTH, TILE_OPC_SLTH_U, TILE_OPC_SLT,
  11502. TILE_OPC_SLT_U, TILE_OPC_SNEB, TILE_OPC_SNEH, TILE_OPC_SNE, TILE_OPC_SRAB,
  11503. TILE_OPC_SRAH, TILE_OPC_SRA, TILE_OPC_SUBB, TILE_OPC_SUBH, TILE_OPC_SUB,
  11504. BITFIELD(49, 4) /* index 594 */,
  11505. CHILD(611), CHILD(614), CHILD(617), CHILD(620), CHILD(623), CHILD(626),
  11506. CHILD(629), CHILD(632), CHILD(635), CHILD(638), TILE_OPC_NONE,
  11507. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11508. BITFIELD(53, 1) /* index 611 */,
  11509. TILE_OPC_SW, TILE_OPC_NONE,
  11510. BITFIELD(53, 1) /* index 614 */,
  11511. TILE_OPC_XOR, TILE_OPC_NONE,
  11512. BITFIELD(53, 1) /* index 617 */,
  11513. TILE_OPC_ADDS, TILE_OPC_NONE,
  11514. BITFIELD(53, 1) /* index 620 */,
  11515. TILE_OPC_SUBS, TILE_OPC_NONE,
  11516. BITFIELD(53, 1) /* index 623 */,
  11517. TILE_OPC_ADDBS_U, TILE_OPC_NONE,
  11518. BITFIELD(53, 1) /* index 626 */,
  11519. TILE_OPC_ADDHS, TILE_OPC_NONE,
  11520. BITFIELD(53, 1) /* index 629 */,
  11521. TILE_OPC_SUBBS_U, TILE_OPC_NONE,
  11522. BITFIELD(53, 1) /* index 632 */,
  11523. TILE_OPC_SUBHS, TILE_OPC_NONE,
  11524. BITFIELD(53, 1) /* index 635 */,
  11525. TILE_OPC_PACKHS, TILE_OPC_NONE,
  11526. BITFIELD(53, 1) /* index 638 */,
  11527. TILE_OPC_PACKBS_U, TILE_OPC_NONE,
  11528. BITFIELD(49, 5) /* index 641 */,
  11529. TILE_OPC_NONE, TILE_OPC_ADDB_SN, TILE_OPC_ADDH_SN, TILE_OPC_ADD_SN,
  11530. TILE_OPC_AND_SN, TILE_OPC_INTHB_SN, TILE_OPC_INTHH_SN, TILE_OPC_INTLB_SN,
  11531. TILE_OPC_INTLH_SN, TILE_OPC_JALRP, TILE_OPC_JALR, TILE_OPC_JRP, TILE_OPC_JR,
  11532. TILE_OPC_LNK_SN, TILE_OPC_MAXB_U_SN, TILE_OPC_MAXH_SN, TILE_OPC_MINB_U_SN,
  11533. TILE_OPC_MINH_SN, TILE_OPC_MNZB_SN, TILE_OPC_MNZH_SN, TILE_OPC_MNZ_SN,
  11534. TILE_OPC_MZB_SN, TILE_OPC_MZH_SN, TILE_OPC_MZ_SN, TILE_OPC_NOR_SN,
  11535. CHILD(674), TILE_OPC_PACKHB_SN, TILE_OPC_PACKLB_SN, TILE_OPC_RL_SN,
  11536. TILE_OPC_S1A_SN, TILE_OPC_S2A_SN, TILE_OPC_S3A_SN,
  11537. BITFIELD(43, 2) /* index 674 */,
  11538. TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_OR_SN, CHILD(679),
  11539. BITFIELD(45, 2) /* index 679 */,
  11540. TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_OR_SN, CHILD(684),
  11541. BITFIELD(47, 2) /* index 684 */,
  11542. TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_OR_SN, TILE_OPC_MOVE_SN,
  11543. BITFIELD(49, 5) /* index 689 */,
  11544. TILE_OPC_SB, TILE_OPC_SEQB_SN, TILE_OPC_SEQH_SN, TILE_OPC_SEQ_SN,
  11545. TILE_OPC_SHLB_SN, TILE_OPC_SHLH_SN, TILE_OPC_SHL_SN, TILE_OPC_SHRB_SN,
  11546. TILE_OPC_SHRH_SN, TILE_OPC_SHR_SN, TILE_OPC_SH, TILE_OPC_SLTB_SN,
  11547. TILE_OPC_SLTB_U_SN, TILE_OPC_SLTEB_SN, TILE_OPC_SLTEB_U_SN,
  11548. TILE_OPC_SLTEH_SN, TILE_OPC_SLTEH_U_SN, TILE_OPC_SLTE_SN,
  11549. TILE_OPC_SLTE_U_SN, TILE_OPC_SLTH_SN, TILE_OPC_SLTH_U_SN, TILE_OPC_SLT_SN,
  11550. TILE_OPC_SLT_U_SN, TILE_OPC_SNEB_SN, TILE_OPC_SNEH_SN, TILE_OPC_SNE_SN,
  11551. TILE_OPC_SRAB_SN, TILE_OPC_SRAH_SN, TILE_OPC_SRA_SN, TILE_OPC_SUBB_SN,
  11552. TILE_OPC_SUBH_SN, TILE_OPC_SUB_SN,
  11553. BITFIELD(49, 4) /* index 722 */,
  11554. CHILD(611), CHILD(739), CHILD(742), CHILD(745), CHILD(748), CHILD(751),
  11555. CHILD(754), CHILD(757), CHILD(760), CHILD(763), TILE_OPC_NONE,
  11556. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11557. BITFIELD(53, 1) /* index 739 */,
  11558. TILE_OPC_XOR_SN, TILE_OPC_NONE,
  11559. BITFIELD(53, 1) /* index 742 */,
  11560. TILE_OPC_ADDS_SN, TILE_OPC_NONE,
  11561. BITFIELD(53, 1) /* index 745 */,
  11562. TILE_OPC_SUBS_SN, TILE_OPC_NONE,
  11563. BITFIELD(53, 1) /* index 748 */,
  11564. TILE_OPC_ADDBS_U_SN, TILE_OPC_NONE,
  11565. BITFIELD(53, 1) /* index 751 */,
  11566. TILE_OPC_ADDHS_SN, TILE_OPC_NONE,
  11567. BITFIELD(53, 1) /* index 754 */,
  11568. TILE_OPC_SUBBS_U_SN, TILE_OPC_NONE,
  11569. BITFIELD(53, 1) /* index 757 */,
  11570. TILE_OPC_SUBHS_SN, TILE_OPC_NONE,
  11571. BITFIELD(53, 1) /* index 760 */,
  11572. TILE_OPC_PACKHS_SN, TILE_OPC_NONE,
  11573. BITFIELD(53, 1) /* index 763 */,
  11574. TILE_OPC_PACKBS_U_SN, TILE_OPC_NONE,
  11575. BITFIELD(37, 2) /* index 766 */,
  11576. TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, CHILD(771),
  11577. BITFIELD(39, 2) /* index 771 */,
  11578. TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, CHILD(776),
  11579. BITFIELD(41, 2) /* index 776 */,
  11580. TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_ADDLI_SN, TILE_OPC_MOVELI_SN,
  11581. BITFIELD(37, 2) /* index 781 */,
  11582. TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_ADDLI, CHILD(786),
  11583. BITFIELD(39, 2) /* index 786 */,
  11584. TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_ADDLI, CHILD(791),
  11585. BITFIELD(41, 2) /* index 791 */,
  11586. TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_ADDLI, TILE_OPC_MOVELI,
  11587. BITFIELD(31, 2) /* index 796 */,
  11588. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(801),
  11589. BITFIELD(33, 2) /* index 801 */,
  11590. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(806),
  11591. BITFIELD(35, 2) /* index 806 */,
  11592. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(811),
  11593. BITFIELD(37, 2) /* index 811 */,
  11594. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(816),
  11595. BITFIELD(39, 2) /* index 816 */,
  11596. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, CHILD(821),
  11597. BITFIELD(41, 2) /* index 821 */,
  11598. TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_AULI, TILE_OPC_INFOL,
  11599. BITFIELD(31, 4) /* index 826 */,
  11600. TILE_OPC_BZ, TILE_OPC_BZT, TILE_OPC_BNZ, TILE_OPC_BNZT, TILE_OPC_BGZ,
  11601. TILE_OPC_BGZT, TILE_OPC_BGEZ, TILE_OPC_BGEZT, TILE_OPC_BLZ, TILE_OPC_BLZT,
  11602. TILE_OPC_BLEZ, TILE_OPC_BLEZT, TILE_OPC_BBS, TILE_OPC_BBST, TILE_OPC_BBNS,
  11603. TILE_OPC_BBNST,
  11604. BITFIELD(31, 4) /* index 843 */,
  11605. TILE_OPC_BZ_SN, TILE_OPC_BZT_SN, TILE_OPC_BNZ_SN, TILE_OPC_BNZT_SN,
  11606. TILE_OPC_BGZ_SN, TILE_OPC_BGZT_SN, TILE_OPC_BGEZ_SN, TILE_OPC_BGEZT_SN,
  11607. TILE_OPC_BLZ_SN, TILE_OPC_BLZT_SN, TILE_OPC_BLEZ_SN, TILE_OPC_BLEZT_SN,
  11608. TILE_OPC_BBS_SN, TILE_OPC_BBST_SN, TILE_OPC_BBNS_SN, TILE_OPC_BBNST_SN,
  11609. BITFIELD(51, 3) /* index 860 */,
  11610. TILE_OPC_NONE, TILE_OPC_ADDIB, TILE_OPC_ADDIH, TILE_OPC_ADDI, CHILD(869),
  11611. TILE_OPC_MAXIB_U, TILE_OPC_MAXIH, TILE_OPC_MFSPR,
  11612. BITFIELD(31, 2) /* index 869 */,
  11613. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(874),
  11614. BITFIELD(33, 2) /* index 874 */,
  11615. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(879),
  11616. BITFIELD(35, 2) /* index 879 */,
  11617. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(884),
  11618. BITFIELD(37, 2) /* index 884 */,
  11619. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(889),
  11620. BITFIELD(39, 2) /* index 889 */,
  11621. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(894),
  11622. BITFIELD(41, 2) /* index 894 */,
  11623. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_INFO,
  11624. BITFIELD(51, 3) /* index 899 */,
  11625. TILE_OPC_MINIB_U, TILE_OPC_MINIH, TILE_OPC_MTSPR, CHILD(908),
  11626. TILE_OPC_SEQIB, TILE_OPC_SEQIH, TILE_OPC_SEQI, TILE_OPC_SLTIB,
  11627. BITFIELD(37, 2) /* index 908 */,
  11628. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(913),
  11629. BITFIELD(39, 2) /* index 913 */,
  11630. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(918),
  11631. BITFIELD(41, 2) /* index 918 */,
  11632. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_MOVEI,
  11633. BITFIELD(51, 3) /* index 923 */,
  11634. TILE_OPC_SLTIB_U, TILE_OPC_SLTIH, TILE_OPC_SLTIH_U, TILE_OPC_SLTI,
  11635. TILE_OPC_SLTI_U, TILE_OPC_XORI, TILE_OPC_LBADD, TILE_OPC_LBADD_U,
  11636. BITFIELD(51, 3) /* index 932 */,
  11637. TILE_OPC_LHADD, TILE_OPC_LHADD_U, TILE_OPC_LWADD, TILE_OPC_LWADD_NA,
  11638. TILE_OPC_SBADD, TILE_OPC_SHADD, TILE_OPC_SWADD, TILE_OPC_NONE,
  11639. BITFIELD(51, 3) /* index 941 */,
  11640. TILE_OPC_NONE, TILE_OPC_ADDIB_SN, TILE_OPC_ADDIH_SN, TILE_OPC_ADDI_SN,
  11641. TILE_OPC_ANDI_SN, TILE_OPC_MAXIB_U_SN, TILE_OPC_MAXIH_SN, TILE_OPC_MFSPR,
  11642. BITFIELD(51, 3) /* index 950 */,
  11643. TILE_OPC_MINIB_U_SN, TILE_OPC_MINIH_SN, TILE_OPC_MTSPR, CHILD(959),
  11644. TILE_OPC_SEQIB_SN, TILE_OPC_SEQIH_SN, TILE_OPC_SEQI_SN, TILE_OPC_SLTIB_SN,
  11645. BITFIELD(37, 2) /* index 959 */,
  11646. TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, CHILD(964),
  11647. BITFIELD(39, 2) /* index 964 */,
  11648. TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, CHILD(969),
  11649. BITFIELD(41, 2) /* index 969 */,
  11650. TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_ORI_SN, TILE_OPC_MOVEI_SN,
  11651. BITFIELD(51, 3) /* index 974 */,
  11652. TILE_OPC_SLTIB_U_SN, TILE_OPC_SLTIH_SN, TILE_OPC_SLTIH_U_SN,
  11653. TILE_OPC_SLTI_SN, TILE_OPC_SLTI_U_SN, TILE_OPC_XORI_SN, TILE_OPC_LBADD_SN,
  11654. TILE_OPC_LBADD_U_SN,
  11655. BITFIELD(51, 3) /* index 983 */,
  11656. TILE_OPC_LHADD_SN, TILE_OPC_LHADD_U_SN, TILE_OPC_LWADD_SN,
  11657. TILE_OPC_LWADD_NA_SN, TILE_OPC_SBADD, TILE_OPC_SHADD, TILE_OPC_SWADD,
  11658. TILE_OPC_NONE,
  11659. BITFIELD(46, 7) /* index 992 */,
  11660. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, CHILD(1121),
  11661. CHILD(1121), CHILD(1121), CHILD(1121), CHILD(1124), CHILD(1124),
  11662. CHILD(1124), CHILD(1124), CHILD(1127), CHILD(1127), CHILD(1127),
  11663. CHILD(1127), CHILD(1130), CHILD(1130), CHILD(1130), CHILD(1130),
  11664. CHILD(1133), CHILD(1133), CHILD(1133), CHILD(1133), CHILD(1136),
  11665. CHILD(1136), CHILD(1136), CHILD(1136), CHILD(1139), CHILD(1139),
  11666. CHILD(1139), CHILD(1139), CHILD(1142), CHILD(1142), CHILD(1142),
  11667. CHILD(1142), CHILD(1145), CHILD(1145), CHILD(1145), CHILD(1145),
  11668. CHILD(1148), CHILD(1148), CHILD(1148), CHILD(1148), CHILD(1151),
  11669. CHILD(1211), CHILD(1259), CHILD(1292), TILE_OPC_NONE, TILE_OPC_NONE,
  11670. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11671. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11672. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11673. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11674. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11675. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11676. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11677. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11678. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11679. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11680. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11681. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11682. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11683. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11684. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11685. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11686. BITFIELD(53, 1) /* index 1121 */,
  11687. TILE_OPC_RLI, TILE_OPC_NONE,
  11688. BITFIELD(53, 1) /* index 1124 */,
  11689. TILE_OPC_SHLIB, TILE_OPC_NONE,
  11690. BITFIELD(53, 1) /* index 1127 */,
  11691. TILE_OPC_SHLIH, TILE_OPC_NONE,
  11692. BITFIELD(53, 1) /* index 1130 */,
  11693. TILE_OPC_SHLI, TILE_OPC_NONE,
  11694. BITFIELD(53, 1) /* index 1133 */,
  11695. TILE_OPC_SHRIB, TILE_OPC_NONE,
  11696. BITFIELD(53, 1) /* index 1136 */,
  11697. TILE_OPC_SHRIH, TILE_OPC_NONE,
  11698. BITFIELD(53, 1) /* index 1139 */,
  11699. TILE_OPC_SHRI, TILE_OPC_NONE,
  11700. BITFIELD(53, 1) /* index 1142 */,
  11701. TILE_OPC_SRAIB, TILE_OPC_NONE,
  11702. BITFIELD(53, 1) /* index 1145 */,
  11703. TILE_OPC_SRAIH, TILE_OPC_NONE,
  11704. BITFIELD(53, 1) /* index 1148 */,
  11705. TILE_OPC_SRAI, TILE_OPC_NONE,
  11706. BITFIELD(43, 3) /* index 1151 */,
  11707. TILE_OPC_NONE, CHILD(1160), CHILD(1163), CHILD(1166), CHILD(1169),
  11708. CHILD(1172), CHILD(1175), CHILD(1178),
  11709. BITFIELD(53, 1) /* index 1160 */,
  11710. TILE_OPC_DRAIN, TILE_OPC_NONE,
  11711. BITFIELD(53, 1) /* index 1163 */,
  11712. TILE_OPC_DTLBPR, TILE_OPC_NONE,
  11713. BITFIELD(53, 1) /* index 1166 */,
  11714. TILE_OPC_FINV, TILE_OPC_NONE,
  11715. BITFIELD(53, 1) /* index 1169 */,
  11716. TILE_OPC_FLUSH, TILE_OPC_NONE,
  11717. BITFIELD(53, 1) /* index 1172 */,
  11718. TILE_OPC_FNOP, TILE_OPC_NONE,
  11719. BITFIELD(53, 1) /* index 1175 */,
  11720. TILE_OPC_ICOH, TILE_OPC_NONE,
  11721. BITFIELD(53, 1) /* index 1178 */,
  11722. CHILD(1181), TILE_OPC_NONE,
  11723. BITFIELD(31, 2) /* index 1181 */,
  11724. CHILD(1186), TILE_OPC_ILL, TILE_OPC_ILL, TILE_OPC_ILL,
  11725. BITFIELD(33, 2) /* index 1186 */,
  11726. TILE_OPC_ILL, TILE_OPC_ILL, TILE_OPC_ILL, CHILD(1191),
  11727. BITFIELD(35, 2) /* index 1191 */,
  11728. TILE_OPC_ILL, CHILD(1196), TILE_OPC_ILL, TILE_OPC_ILL,
  11729. BITFIELD(37, 2) /* index 1196 */,
  11730. TILE_OPC_ILL, CHILD(1201), TILE_OPC_ILL, TILE_OPC_ILL,
  11731. BITFIELD(39, 2) /* index 1201 */,
  11732. TILE_OPC_ILL, CHILD(1206), TILE_OPC_ILL, TILE_OPC_ILL,
  11733. BITFIELD(41, 2) /* index 1206 */,
  11734. TILE_OPC_ILL, TILE_OPC_ILL, TILE_OPC_BPT, TILE_OPC_ILL,
  11735. BITFIELD(43, 3) /* index 1211 */,
  11736. CHILD(1220), CHILD(1223), CHILD(1226), CHILD(1244), CHILD(1247),
  11737. CHILD(1250), CHILD(1253), CHILD(1256),
  11738. BITFIELD(53, 1) /* index 1220 */,
  11739. TILE_OPC_INV, TILE_OPC_NONE,
  11740. BITFIELD(53, 1) /* index 1223 */,
  11741. TILE_OPC_IRET, TILE_OPC_NONE,
  11742. BITFIELD(53, 1) /* index 1226 */,
  11743. CHILD(1229), TILE_OPC_NONE,
  11744. BITFIELD(31, 2) /* index 1229 */,
  11745. TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_LB, CHILD(1234),
  11746. BITFIELD(33, 2) /* index 1234 */,
  11747. TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_LB, CHILD(1239),
  11748. BITFIELD(35, 2) /* index 1239 */,
  11749. TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_PREFETCH,
  11750. BITFIELD(53, 1) /* index 1244 */,
  11751. TILE_OPC_LB_U, TILE_OPC_NONE,
  11752. BITFIELD(53, 1) /* index 1247 */,
  11753. TILE_OPC_LH, TILE_OPC_NONE,
  11754. BITFIELD(53, 1) /* index 1250 */,
  11755. TILE_OPC_LH_U, TILE_OPC_NONE,
  11756. BITFIELD(53, 1) /* index 1253 */,
  11757. TILE_OPC_LW, TILE_OPC_NONE,
  11758. BITFIELD(53, 1) /* index 1256 */,
  11759. TILE_OPC_MF, TILE_OPC_NONE,
  11760. BITFIELD(43, 3) /* index 1259 */,
  11761. CHILD(1268), CHILD(1271), CHILD(1274), CHILD(1277), CHILD(1280),
  11762. CHILD(1283), CHILD(1286), CHILD(1289),
  11763. BITFIELD(53, 1) /* index 1268 */,
  11764. TILE_OPC_NAP, TILE_OPC_NONE,
  11765. BITFIELD(53, 1) /* index 1271 */,
  11766. TILE_OPC_NOP, TILE_OPC_NONE,
  11767. BITFIELD(53, 1) /* index 1274 */,
  11768. TILE_OPC_SWINT0, TILE_OPC_NONE,
  11769. BITFIELD(53, 1) /* index 1277 */,
  11770. TILE_OPC_SWINT1, TILE_OPC_NONE,
  11771. BITFIELD(53, 1) /* index 1280 */,
  11772. TILE_OPC_SWINT2, TILE_OPC_NONE,
  11773. BITFIELD(53, 1) /* index 1283 */,
  11774. TILE_OPC_SWINT3, TILE_OPC_NONE,
  11775. BITFIELD(53, 1) /* index 1286 */,
  11776. TILE_OPC_TNS, TILE_OPC_NONE,
  11777. BITFIELD(53, 1) /* index 1289 */,
  11778. TILE_OPC_WH64, TILE_OPC_NONE,
  11779. BITFIELD(43, 2) /* index 1292 */,
  11780. CHILD(1297), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11781. BITFIELD(45, 1) /* index 1297 */,
  11782. CHILD(1300), TILE_OPC_NONE,
  11783. BITFIELD(53, 1) /* index 1300 */,
  11784. TILE_OPC_LW_NA, TILE_OPC_NONE,
  11785. BITFIELD(46, 7) /* index 1303 */,
  11786. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, CHILD(1432),
  11787. CHILD(1432), CHILD(1432), CHILD(1432), CHILD(1435), CHILD(1435),
  11788. CHILD(1435), CHILD(1435), CHILD(1438), CHILD(1438), CHILD(1438),
  11789. CHILD(1438), CHILD(1441), CHILD(1441), CHILD(1441), CHILD(1441),
  11790. CHILD(1444), CHILD(1444), CHILD(1444), CHILD(1444), CHILD(1447),
  11791. CHILD(1447), CHILD(1447), CHILD(1447), CHILD(1450), CHILD(1450),
  11792. CHILD(1450), CHILD(1450), CHILD(1453), CHILD(1453), CHILD(1453),
  11793. CHILD(1453), CHILD(1456), CHILD(1456), CHILD(1456), CHILD(1456),
  11794. CHILD(1459), CHILD(1459), CHILD(1459), CHILD(1459), CHILD(1151),
  11795. CHILD(1462), CHILD(1486), CHILD(1498), TILE_OPC_NONE, TILE_OPC_NONE,
  11796. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11797. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11798. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11799. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11800. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11801. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11802. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11803. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11804. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11805. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11806. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11807. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11808. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11809. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11810. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11811. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11812. BITFIELD(53, 1) /* index 1432 */,
  11813. TILE_OPC_RLI_SN, TILE_OPC_NONE,
  11814. BITFIELD(53, 1) /* index 1435 */,
  11815. TILE_OPC_SHLIB_SN, TILE_OPC_NONE,
  11816. BITFIELD(53, 1) /* index 1438 */,
  11817. TILE_OPC_SHLIH_SN, TILE_OPC_NONE,
  11818. BITFIELD(53, 1) /* index 1441 */,
  11819. TILE_OPC_SHLI_SN, TILE_OPC_NONE,
  11820. BITFIELD(53, 1) /* index 1444 */,
  11821. TILE_OPC_SHRIB_SN, TILE_OPC_NONE,
  11822. BITFIELD(53, 1) /* index 1447 */,
  11823. TILE_OPC_SHRIH_SN, TILE_OPC_NONE,
  11824. BITFIELD(53, 1) /* index 1450 */,
  11825. TILE_OPC_SHRI_SN, TILE_OPC_NONE,
  11826. BITFIELD(53, 1) /* index 1453 */,
  11827. TILE_OPC_SRAIB_SN, TILE_OPC_NONE,
  11828. BITFIELD(53, 1) /* index 1456 */,
  11829. TILE_OPC_SRAIH_SN, TILE_OPC_NONE,
  11830. BITFIELD(53, 1) /* index 1459 */,
  11831. TILE_OPC_SRAI_SN, TILE_OPC_NONE,
  11832. BITFIELD(43, 3) /* index 1462 */,
  11833. CHILD(1220), CHILD(1223), CHILD(1471), CHILD(1474), CHILD(1477),
  11834. CHILD(1480), CHILD(1483), CHILD(1256),
  11835. BITFIELD(53, 1) /* index 1471 */,
  11836. TILE_OPC_LB_SN, TILE_OPC_NONE,
  11837. BITFIELD(53, 1) /* index 1474 */,
  11838. TILE_OPC_LB_U_SN, TILE_OPC_NONE,
  11839. BITFIELD(53, 1) /* index 1477 */,
  11840. TILE_OPC_LH_SN, TILE_OPC_NONE,
  11841. BITFIELD(53, 1) /* index 1480 */,
  11842. TILE_OPC_LH_U_SN, TILE_OPC_NONE,
  11843. BITFIELD(53, 1) /* index 1483 */,
  11844. TILE_OPC_LW_SN, TILE_OPC_NONE,
  11845. BITFIELD(43, 3) /* index 1486 */,
  11846. CHILD(1268), CHILD(1271), CHILD(1274), CHILD(1277), CHILD(1280),
  11847. CHILD(1283), CHILD(1495), CHILD(1289),
  11848. BITFIELD(53, 1) /* index 1495 */,
  11849. TILE_OPC_TNS_SN, TILE_OPC_NONE,
  11850. BITFIELD(43, 2) /* index 1498 */,
  11851. CHILD(1503), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11852. BITFIELD(45, 1) /* index 1503 */,
  11853. CHILD(1506), TILE_OPC_NONE,
  11854. BITFIELD(53, 1) /* index 1506 */,
  11855. TILE_OPC_LW_NA_SN, TILE_OPC_NONE,
  11856. };
  11857. static const unsigned short decode_Y0_fsm[168] =
  11858. {
  11859. BITFIELD(27, 4) /* index 0 */,
  11860. TILE_OPC_NONE, CHILD(17), CHILD(22), CHILD(27), CHILD(47), CHILD(52),
  11861. CHILD(57), CHILD(62), CHILD(67), TILE_OPC_ADDI, CHILD(72), CHILD(102),
  11862. TILE_OPC_SEQI, CHILD(117), TILE_OPC_SLTI, TILE_OPC_SLTI_U,
  11863. BITFIELD(18, 2) /* index 17 */,
  11864. TILE_OPC_ADD, TILE_OPC_S1A, TILE_OPC_S2A, TILE_OPC_SUB,
  11865. BITFIELD(18, 2) /* index 22 */,
  11866. TILE_OPC_MNZ, TILE_OPC_MVNZ, TILE_OPC_MVZ, TILE_OPC_MZ,
  11867. BITFIELD(18, 2) /* index 27 */,
  11868. TILE_OPC_AND, TILE_OPC_NOR, CHILD(32), TILE_OPC_XOR,
  11869. BITFIELD(12, 2) /* index 32 */,
  11870. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(37),
  11871. BITFIELD(14, 2) /* index 37 */,
  11872. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(42),
  11873. BITFIELD(16, 2) /* index 42 */,
  11874. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_MOVE,
  11875. BITFIELD(18, 2) /* index 47 */,
  11876. TILE_OPC_RL, TILE_OPC_SHL, TILE_OPC_SHR, TILE_OPC_SRA,
  11877. BITFIELD(18, 2) /* index 52 */,
  11878. TILE_OPC_SLTE, TILE_OPC_SLTE_U, TILE_OPC_SLT, TILE_OPC_SLT_U,
  11879. BITFIELD(18, 2) /* index 57 */,
  11880. TILE_OPC_MULHLSA_UU, TILE_OPC_S3A, TILE_OPC_SEQ, TILE_OPC_SNE,
  11881. BITFIELD(18, 2) /* index 62 */,
  11882. TILE_OPC_MULHH_SS, TILE_OPC_MULHH_UU, TILE_OPC_MULLL_SS, TILE_OPC_MULLL_UU,
  11883. BITFIELD(18, 2) /* index 67 */,
  11884. TILE_OPC_MULHHA_SS, TILE_OPC_MULHHA_UU, TILE_OPC_MULLLA_SS,
  11885. TILE_OPC_MULLLA_UU,
  11886. BITFIELD(0, 2) /* index 72 */,
  11887. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(77),
  11888. BITFIELD(2, 2) /* index 77 */,
  11889. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(82),
  11890. BITFIELD(4, 2) /* index 82 */,
  11891. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(87),
  11892. BITFIELD(6, 2) /* index 87 */,
  11893. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(92),
  11894. BITFIELD(8, 2) /* index 92 */,
  11895. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(97),
  11896. BITFIELD(10, 2) /* index 97 */,
  11897. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_INFO,
  11898. BITFIELD(6, 2) /* index 102 */,
  11899. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(107),
  11900. BITFIELD(8, 2) /* index 107 */,
  11901. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(112),
  11902. BITFIELD(10, 2) /* index 112 */,
  11903. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_MOVEI,
  11904. BITFIELD(15, 5) /* index 117 */,
  11905. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_RLI,
  11906. TILE_OPC_RLI, TILE_OPC_RLI, TILE_OPC_RLI, TILE_OPC_SHLI, TILE_OPC_SHLI,
  11907. TILE_OPC_SHLI, TILE_OPC_SHLI, TILE_OPC_SHRI, TILE_OPC_SHRI, TILE_OPC_SHRI,
  11908. TILE_OPC_SHRI, TILE_OPC_SRAI, TILE_OPC_SRAI, TILE_OPC_SRAI, TILE_OPC_SRAI,
  11909. CHILD(150), CHILD(159), TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11910. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11911. TILE_OPC_NONE, TILE_OPC_NONE,
  11912. BITFIELD(12, 3) /* index 150 */,
  11913. TILE_OPC_NONE, TILE_OPC_BITX, TILE_OPC_BYTEX, TILE_OPC_CLZ, TILE_OPC_CTZ,
  11914. TILE_OPC_FNOP, TILE_OPC_NOP, TILE_OPC_PCNT,
  11915. BITFIELD(12, 3) /* index 159 */,
  11916. TILE_OPC_TBLIDXB0, TILE_OPC_TBLIDXB1, TILE_OPC_TBLIDXB2, TILE_OPC_TBLIDXB3,
  11917. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11918. };
  11919. static const unsigned short decode_Y1_fsm[140] =
  11920. {
  11921. BITFIELD(59, 4) /* index 0 */,
  11922. TILE_OPC_NONE, CHILD(17), CHILD(22), CHILD(27), CHILD(47), CHILD(52),
  11923. CHILD(57), TILE_OPC_ADDI, CHILD(62), CHILD(92), TILE_OPC_SEQI, CHILD(107),
  11924. TILE_OPC_SLTI, TILE_OPC_SLTI_U, TILE_OPC_NONE, TILE_OPC_NONE,
  11925. BITFIELD(49, 2) /* index 17 */,
  11926. TILE_OPC_ADD, TILE_OPC_S1A, TILE_OPC_S2A, TILE_OPC_SUB,
  11927. BITFIELD(49, 2) /* index 22 */,
  11928. TILE_OPC_NONE, TILE_OPC_MNZ, TILE_OPC_MZ, TILE_OPC_NONE,
  11929. BITFIELD(49, 2) /* index 27 */,
  11930. TILE_OPC_AND, TILE_OPC_NOR, CHILD(32), TILE_OPC_XOR,
  11931. BITFIELD(43, 2) /* index 32 */,
  11932. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(37),
  11933. BITFIELD(45, 2) /* index 37 */,
  11934. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, CHILD(42),
  11935. BITFIELD(47, 2) /* index 42 */,
  11936. TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_OR, TILE_OPC_MOVE,
  11937. BITFIELD(49, 2) /* index 47 */,
  11938. TILE_OPC_RL, TILE_OPC_SHL, TILE_OPC_SHR, TILE_OPC_SRA,
  11939. BITFIELD(49, 2) /* index 52 */,
  11940. TILE_OPC_SLTE, TILE_OPC_SLTE_U, TILE_OPC_SLT, TILE_OPC_SLT_U,
  11941. BITFIELD(49, 2) /* index 57 */,
  11942. TILE_OPC_NONE, TILE_OPC_S3A, TILE_OPC_SEQ, TILE_OPC_SNE,
  11943. BITFIELD(31, 2) /* index 62 */,
  11944. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(67),
  11945. BITFIELD(33, 2) /* index 67 */,
  11946. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(72),
  11947. BITFIELD(35, 2) /* index 72 */,
  11948. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(77),
  11949. BITFIELD(37, 2) /* index 77 */,
  11950. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(82),
  11951. BITFIELD(39, 2) /* index 82 */,
  11952. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, CHILD(87),
  11953. BITFIELD(41, 2) /* index 87 */,
  11954. TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_ANDI, TILE_OPC_INFO,
  11955. BITFIELD(37, 2) /* index 92 */,
  11956. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(97),
  11957. BITFIELD(39, 2) /* index 97 */,
  11958. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, CHILD(102),
  11959. BITFIELD(41, 2) /* index 102 */,
  11960. TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_ORI, TILE_OPC_MOVEI,
  11961. BITFIELD(48, 3) /* index 107 */,
  11962. TILE_OPC_NONE, TILE_OPC_RLI, TILE_OPC_SHLI, TILE_OPC_SHRI, TILE_OPC_SRAI,
  11963. CHILD(116), TILE_OPC_NONE, TILE_OPC_NONE,
  11964. BITFIELD(43, 3) /* index 116 */,
  11965. TILE_OPC_NONE, CHILD(125), CHILD(130), CHILD(135), TILE_OPC_NONE,
  11966. TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11967. BITFIELD(46, 2) /* index 125 */,
  11968. TILE_OPC_FNOP, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11969. BITFIELD(46, 2) /* index 130 */,
  11970. TILE_OPC_ILL, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11971. BITFIELD(46, 2) /* index 135 */,
  11972. TILE_OPC_NOP, TILE_OPC_NONE, TILE_OPC_NONE, TILE_OPC_NONE,
  11973. };
  11974. static const unsigned short decode_Y2_fsm[24] =
  11975. {
  11976. BITFIELD(56, 3) /* index 0 */,
  11977. CHILD(9), TILE_OPC_LB_U, TILE_OPC_LH, TILE_OPC_LH_U, TILE_OPC_LW,
  11978. TILE_OPC_SB, TILE_OPC_SH, TILE_OPC_SW,
  11979. BITFIELD(20, 2) /* index 9 */,
  11980. TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_LB, CHILD(14),
  11981. BITFIELD(22, 2) /* index 14 */,
  11982. TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_LB, CHILD(19),
  11983. BITFIELD(24, 2) /* index 19 */,
  11984. TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_LB, TILE_OPC_PREFETCH,
  11985. };
  11986. #undef BITFIELD
  11987. #undef CHILD
  11988. const unsigned short * const
  11989. tile_bundle_decoder_fsms[TILE_NUM_PIPELINE_ENCODINGS] =
  11990. {
  11991. decode_X0_fsm,
  11992. decode_X1_fsm,
  11993. decode_Y0_fsm,
  11994. decode_Y1_fsm,
  11995. decode_Y2_fsm
  11996. };
  11997. const struct tile_sn_opcode tile_sn_opcodes[23] =
  11998. {
  11999. { "bz", TILE_SN_OPC_BZ,
  12000. 1 /* num_operands */,
  12001. /* operands */
  12002. { 38 },
  12003. /* fixed_bit_mask */
  12004. 0xfc00,
  12005. /* fixed_bit_value */
  12006. 0xe000
  12007. },
  12008. { "bnz", TILE_SN_OPC_BNZ,
  12009. 1 /* num_operands */,
  12010. /* operands */
  12011. { 38 },
  12012. /* fixed_bit_mask */
  12013. 0xfc00,
  12014. /* fixed_bit_value */
  12015. 0xe400
  12016. },
  12017. { "jrr", TILE_SN_OPC_JRR,
  12018. 1 /* num_operands */,
  12019. /* operands */
  12020. { 39 },
  12021. /* fixed_bit_mask */
  12022. 0xff00,
  12023. /* fixed_bit_value */
  12024. 0x0600
  12025. },
  12026. { "fnop", TILE_SN_OPC_FNOP,
  12027. 0 /* num_operands */,
  12028. /* operands */
  12029. { 0, },
  12030. /* fixed_bit_mask */
  12031. 0xffff,
  12032. /* fixed_bit_value */
  12033. 0x0003
  12034. },
  12035. { "blz", TILE_SN_OPC_BLZ,
  12036. 1 /* num_operands */,
  12037. /* operands */
  12038. { 38 },
  12039. /* fixed_bit_mask */
  12040. 0xfc00,
  12041. /* fixed_bit_value */
  12042. 0xf000
  12043. },
  12044. { "nop", TILE_SN_OPC_NOP,
  12045. 0 /* num_operands */,
  12046. /* operands */
  12047. { 0, },
  12048. /* fixed_bit_mask */
  12049. 0xffff,
  12050. /* fixed_bit_value */
  12051. 0x0002
  12052. },
  12053. { "movei", TILE_SN_OPC_MOVEI,
  12054. 1 /* num_operands */,
  12055. /* operands */
  12056. { 40 },
  12057. /* fixed_bit_mask */
  12058. 0xff00,
  12059. /* fixed_bit_value */
  12060. 0x0400
  12061. },
  12062. { "move", TILE_SN_OPC_MOVE,
  12063. 2 /* num_operands */,
  12064. /* operands */
  12065. { 41, 42 },
  12066. /* fixed_bit_mask */
  12067. 0xfff0,
  12068. /* fixed_bit_value */
  12069. 0x0080
  12070. },
  12071. { "bgez", TILE_SN_OPC_BGEZ,
  12072. 1 /* num_operands */,
  12073. /* operands */
  12074. { 38 },
  12075. /* fixed_bit_mask */
  12076. 0xfc00,
  12077. /* fixed_bit_value */
  12078. 0xf400
  12079. },
  12080. { "jr", TILE_SN_OPC_JR,
  12081. 1 /* num_operands */,
  12082. /* operands */
  12083. { 42 },
  12084. /* fixed_bit_mask */
  12085. 0xfff0,
  12086. /* fixed_bit_value */
  12087. 0x0040
  12088. },
  12089. { "blez", TILE_SN_OPC_BLEZ,
  12090. 1 /* num_operands */,
  12091. /* operands */
  12092. { 38 },
  12093. /* fixed_bit_mask */
  12094. 0xfc00,
  12095. /* fixed_bit_value */
  12096. 0xec00
  12097. },
  12098. { "bbns", TILE_SN_OPC_BBNS,
  12099. 1 /* num_operands */,
  12100. /* operands */
  12101. { 38 },
  12102. /* fixed_bit_mask */
  12103. 0xfc00,
  12104. /* fixed_bit_value */
  12105. 0xfc00
  12106. },
  12107. { "jalrr", TILE_SN_OPC_JALRR,
  12108. 1 /* num_operands */,
  12109. /* operands */
  12110. { 39 },
  12111. /* fixed_bit_mask */
  12112. 0xff00,
  12113. /* fixed_bit_value */
  12114. 0x0700
  12115. },
  12116. { "bpt", TILE_SN_OPC_BPT,
  12117. 0 /* num_operands */,
  12118. /* operands */
  12119. { 0, },
  12120. /* fixed_bit_mask */
  12121. 0xffff,
  12122. /* fixed_bit_value */
  12123. 0x0001
  12124. },
  12125. { "jalr", TILE_SN_OPC_JALR,
  12126. 1 /* num_operands */,
  12127. /* operands */
  12128. { 42 },
  12129. /* fixed_bit_mask */
  12130. 0xfff0,
  12131. /* fixed_bit_value */
  12132. 0x0050
  12133. },
  12134. { "shr1", TILE_SN_OPC_SHR1,
  12135. 2 /* num_operands */,
  12136. /* operands */
  12137. { 41, 42 },
  12138. /* fixed_bit_mask */
  12139. 0xfff0,
  12140. /* fixed_bit_value */
  12141. 0x0090
  12142. },
  12143. { "bgz", TILE_SN_OPC_BGZ,
  12144. 1 /* num_operands */,
  12145. /* operands */
  12146. { 38 },
  12147. /* fixed_bit_mask */
  12148. 0xfc00,
  12149. /* fixed_bit_value */
  12150. 0xe800
  12151. },
  12152. { "bbs", TILE_SN_OPC_BBS,
  12153. 1 /* num_operands */,
  12154. /* operands */
  12155. { 38 },
  12156. /* fixed_bit_mask */
  12157. 0xfc00,
  12158. /* fixed_bit_value */
  12159. 0xf800
  12160. },
  12161. { "shl8ii", TILE_SN_OPC_SHL8II,
  12162. 1 /* num_operands */,
  12163. /* operands */
  12164. { 39 },
  12165. /* fixed_bit_mask */
  12166. 0xff00,
  12167. /* fixed_bit_value */
  12168. 0x0300
  12169. },
  12170. { "addi", TILE_SN_OPC_ADDI,
  12171. 1 /* num_operands */,
  12172. /* operands */
  12173. { 40 },
  12174. /* fixed_bit_mask */
  12175. 0xff00,
  12176. /* fixed_bit_value */
  12177. 0x0500
  12178. },
  12179. { "halt", TILE_SN_OPC_HALT,
  12180. 0 /* num_operands */,
  12181. /* operands */
  12182. { 0, },
  12183. /* fixed_bit_mask */
  12184. 0xffff,
  12185. /* fixed_bit_value */
  12186. 0x0000
  12187. },
  12188. { "route", TILE_SN_OPC_ROUTE, 0, { 0, }, 0, 0,
  12189. },
  12190. { 0, TILE_SN_OPC_NONE, 0, { 0, }, 0, 0,
  12191. }
  12192. };
  12193. const unsigned char tile_sn_route_encode[6 * 6 * 6] =
  12194. {
  12195. 0xdf,
  12196. 0xde,
  12197. 0xdd,
  12198. 0xdc,
  12199. 0xdb,
  12200. 0xda,
  12201. 0xb9,
  12202. 0xb8,
  12203. 0xa1,
  12204. 0xa0,
  12205. 0x11,
  12206. 0x10,
  12207. 0x9f,
  12208. 0x9e,
  12209. 0x9d,
  12210. 0x9c,
  12211. 0x9b,
  12212. 0x9a,
  12213. 0x79,
  12214. 0x78,
  12215. 0x61,
  12216. 0x60,
  12217. 0xb,
  12218. 0xa,
  12219. 0x5f,
  12220. 0x5e,
  12221. 0x5d,
  12222. 0x5c,
  12223. 0x5b,
  12224. 0x5a,
  12225. 0x1f,
  12226. 0x1e,
  12227. 0x1d,
  12228. 0x1c,
  12229. 0x1b,
  12230. 0x1a,
  12231. 0xd7,
  12232. 0xd6,
  12233. 0xd5,
  12234. 0xd4,
  12235. 0xd3,
  12236. 0xd2,
  12237. 0xa7,
  12238. 0xa6,
  12239. 0xb1,
  12240. 0xb0,
  12241. 0x13,
  12242. 0x12,
  12243. 0x97,
  12244. 0x96,
  12245. 0x95,
  12246. 0x94,
  12247. 0x93,
  12248. 0x92,
  12249. 0x67,
  12250. 0x66,
  12251. 0x71,
  12252. 0x70,
  12253. 0x9,
  12254. 0x8,
  12255. 0x57,
  12256. 0x56,
  12257. 0x55,
  12258. 0x54,
  12259. 0x53,
  12260. 0x52,
  12261. 0x17,
  12262. 0x16,
  12263. 0x15,
  12264. 0x14,
  12265. 0x19,
  12266. 0x18,
  12267. 0xcf,
  12268. 0xce,
  12269. 0xcd,
  12270. 0xcc,
  12271. 0xcb,
  12272. 0xca,
  12273. 0xaf,
  12274. 0xae,
  12275. 0xad,
  12276. 0xac,
  12277. 0xab,
  12278. 0xaa,
  12279. 0x8f,
  12280. 0x8e,
  12281. 0x8d,
  12282. 0x8c,
  12283. 0x8b,
  12284. 0x8a,
  12285. 0x6f,
  12286. 0x6e,
  12287. 0x6d,
  12288. 0x6c,
  12289. 0x6b,
  12290. 0x6a,
  12291. 0x4f,
  12292. 0x4e,
  12293. 0x4d,
  12294. 0x4c,
  12295. 0x4b,
  12296. 0x4a,
  12297. 0x2f,
  12298. 0x2e,
  12299. 0x2d,
  12300. 0x2c,
  12301. 0x2b,
  12302. 0x2a,
  12303. 0xc9,
  12304. 0xc8,
  12305. 0xc5,
  12306. 0xc4,
  12307. 0xc3,
  12308. 0xc2,
  12309. 0xa9,
  12310. 0xa8,
  12311. 0xa5,
  12312. 0xa4,
  12313. 0xa3,
  12314. 0xa2,
  12315. 0x89,
  12316. 0x88,
  12317. 0x85,
  12318. 0x84,
  12319. 0x83,
  12320. 0x82,
  12321. 0x69,
  12322. 0x68,
  12323. 0x65,
  12324. 0x64,
  12325. 0x63,
  12326. 0x62,
  12327. 0x47,
  12328. 0x46,
  12329. 0x45,
  12330. 0x44,
  12331. 0x43,
  12332. 0x42,
  12333. 0x27,
  12334. 0x26,
  12335. 0x25,
  12336. 0x24,
  12337. 0x23,
  12338. 0x22,
  12339. 0xd9,
  12340. 0xd8,
  12341. 0xc1,
  12342. 0xc0,
  12343. 0x3b,
  12344. 0x3a,
  12345. 0xbf,
  12346. 0xbe,
  12347. 0xbd,
  12348. 0xbc,
  12349. 0xbb,
  12350. 0xba,
  12351. 0x99,
  12352. 0x98,
  12353. 0x81,
  12354. 0x80,
  12355. 0x31,
  12356. 0x30,
  12357. 0x7f,
  12358. 0x7e,
  12359. 0x7d,
  12360. 0x7c,
  12361. 0x7b,
  12362. 0x7a,
  12363. 0x59,
  12364. 0x58,
  12365. 0x3d,
  12366. 0x3c,
  12367. 0x49,
  12368. 0x48,
  12369. 0xf,
  12370. 0xe,
  12371. 0xd,
  12372. 0xc,
  12373. 0x29,
  12374. 0x28,
  12375. 0xc7,
  12376. 0xc6,
  12377. 0xd1,
  12378. 0xd0,
  12379. 0x39,
  12380. 0x38,
  12381. 0xb7,
  12382. 0xb6,
  12383. 0xb5,
  12384. 0xb4,
  12385. 0xb3,
  12386. 0xb2,
  12387. 0x87,
  12388. 0x86,
  12389. 0x91,
  12390. 0x90,
  12391. 0x33,
  12392. 0x32,
  12393. 0x77,
  12394. 0x76,
  12395. 0x75,
  12396. 0x74,
  12397. 0x73,
  12398. 0x72,
  12399. 0x3f,
  12400. 0x3e,
  12401. 0x51,
  12402. 0x50,
  12403. 0x41,
  12404. 0x40,
  12405. 0x37,
  12406. 0x36,
  12407. 0x35,
  12408. 0x34,
  12409. 0x21,
  12410. 0x20
  12411. };
  12412. const signed char tile_sn_route_decode[256][3] =
  12413. {
  12414. { -1, -1, -1 },
  12415. { -1, -1, -1 },
  12416. { -1, -1, -1 },
  12417. { -1, -1, -1 },
  12418. { -1, -1, -1 },
  12419. { -1, -1, -1 },
  12420. { -1, -1, -1 },
  12421. { -1, -1, -1 },
  12422. { 5, 3, 1 },
  12423. { 4, 3, 1 },
  12424. { 5, 3, 0 },
  12425. { 4, 3, 0 },
  12426. { 3, 5, 4 },
  12427. { 2, 5, 4 },
  12428. { 1, 5, 4 },
  12429. { 0, 5, 4 },
  12430. { 5, 1, 0 },
  12431. { 4, 1, 0 },
  12432. { 5, 1, 1 },
  12433. { 4, 1, 1 },
  12434. { 3, 5, 1 },
  12435. { 2, 5, 1 },
  12436. { 1, 5, 1 },
  12437. { 0, 5, 1 },
  12438. { 5, 5, 1 },
  12439. { 4, 5, 1 },
  12440. { 5, 5, 0 },
  12441. { 4, 5, 0 },
  12442. { 3, 5, 0 },
  12443. { 2, 5, 0 },
  12444. { 1, 5, 0 },
  12445. { 0, 5, 0 },
  12446. { 5, 5, 5 },
  12447. { 4, 5, 5 },
  12448. { 5, 5, 3 },
  12449. { 4, 5, 3 },
  12450. { 3, 5, 3 },
  12451. { 2, 5, 3 },
  12452. { 1, 5, 3 },
  12453. { 0, 5, 3 },
  12454. { 5, 5, 4 },
  12455. { 4, 5, 4 },
  12456. { 5, 5, 2 },
  12457. { 4, 5, 2 },
  12458. { 3, 5, 2 },
  12459. { 2, 5, 2 },
  12460. { 1, 5, 2 },
  12461. { 0, 5, 2 },
  12462. { 5, 2, 4 },
  12463. { 4, 2, 4 },
  12464. { 5, 2, 5 },
  12465. { 4, 2, 5 },
  12466. { 3, 5, 5 },
  12467. { 2, 5, 5 },
  12468. { 1, 5, 5 },
  12469. { 0, 5, 5 },
  12470. { 5, 0, 5 },
  12471. { 4, 0, 5 },
  12472. { 5, 0, 4 },
  12473. { 4, 0, 4 },
  12474. { 3, 4, 4 },
  12475. { 2, 4, 4 },
  12476. { 1, 4, 5 },
  12477. { 0, 4, 5 },
  12478. { 5, 4, 5 },
  12479. { 4, 4, 5 },
  12480. { 5, 4, 3 },
  12481. { 4, 4, 3 },
  12482. { 3, 4, 3 },
  12483. { 2, 4, 3 },
  12484. { 1, 4, 3 },
  12485. { 0, 4, 3 },
  12486. { 5, 4, 4 },
  12487. { 4, 4, 4 },
  12488. { 5, 4, 2 },
  12489. { 4, 4, 2 },
  12490. { 3, 4, 2 },
  12491. { 2, 4, 2 },
  12492. { 1, 4, 2 },
  12493. { 0, 4, 2 },
  12494. { 3, 4, 5 },
  12495. { 2, 4, 5 },
  12496. { 5, 4, 1 },
  12497. { 4, 4, 1 },
  12498. { 3, 4, 1 },
  12499. { 2, 4, 1 },
  12500. { 1, 4, 1 },
  12501. { 0, 4, 1 },
  12502. { 1, 4, 4 },
  12503. { 0, 4, 4 },
  12504. { 5, 4, 0 },
  12505. { 4, 4, 0 },
  12506. { 3, 4, 0 },
  12507. { 2, 4, 0 },
  12508. { 1, 4, 0 },
  12509. { 0, 4, 0 },
  12510. { 3, 3, 0 },
  12511. { 2, 3, 0 },
  12512. { 5, 3, 3 },
  12513. { 4, 3, 3 },
  12514. { 3, 3, 3 },
  12515. { 2, 3, 3 },
  12516. { 1, 3, 1 },
  12517. { 0, 3, 1 },
  12518. { 1, 3, 3 },
  12519. { 0, 3, 3 },
  12520. { 5, 3, 2 },
  12521. { 4, 3, 2 },
  12522. { 3, 3, 2 },
  12523. { 2, 3, 2 },
  12524. { 1, 3, 2 },
  12525. { 0, 3, 2 },
  12526. { 3, 3, 1 },
  12527. { 2, 3, 1 },
  12528. { 5, 3, 5 },
  12529. { 4, 3, 5 },
  12530. { 3, 3, 5 },
  12531. { 2, 3, 5 },
  12532. { 1, 3, 5 },
  12533. { 0, 3, 5 },
  12534. { 1, 3, 0 },
  12535. { 0, 3, 0 },
  12536. { 5, 3, 4 },
  12537. { 4, 3, 4 },
  12538. { 3, 3, 4 },
  12539. { 2, 3, 4 },
  12540. { 1, 3, 4 },
  12541. { 0, 3, 4 },
  12542. { 3, 2, 4 },
  12543. { 2, 2, 4 },
  12544. { 5, 2, 3 },
  12545. { 4, 2, 3 },
  12546. { 3, 2, 3 },
  12547. { 2, 2, 3 },
  12548. { 1, 2, 5 },
  12549. { 0, 2, 5 },
  12550. { 1, 2, 3 },
  12551. { 0, 2, 3 },
  12552. { 5, 2, 2 },
  12553. { 4, 2, 2 },
  12554. { 3, 2, 2 },
  12555. { 2, 2, 2 },
  12556. { 1, 2, 2 },
  12557. { 0, 2, 2 },
  12558. { 3, 2, 5 },
  12559. { 2, 2, 5 },
  12560. { 5, 2, 1 },
  12561. { 4, 2, 1 },
  12562. { 3, 2, 1 },
  12563. { 2, 2, 1 },
  12564. { 1, 2, 1 },
  12565. { 0, 2, 1 },
  12566. { 1, 2, 4 },
  12567. { 0, 2, 4 },
  12568. { 5, 2, 0 },
  12569. { 4, 2, 0 },
  12570. { 3, 2, 0 },
  12571. { 2, 2, 0 },
  12572. { 1, 2, 0 },
  12573. { 0, 2, 0 },
  12574. { 3, 1, 0 },
  12575. { 2, 1, 0 },
  12576. { 5, 1, 3 },
  12577. { 4, 1, 3 },
  12578. { 3, 1, 3 },
  12579. { 2, 1, 3 },
  12580. { 1, 1, 1 },
  12581. { 0, 1, 1 },
  12582. { 1, 1, 3 },
  12583. { 0, 1, 3 },
  12584. { 5, 1, 2 },
  12585. { 4, 1, 2 },
  12586. { 3, 1, 2 },
  12587. { 2, 1, 2 },
  12588. { 1, 1, 2 },
  12589. { 0, 1, 2 },
  12590. { 3, 1, 1 },
  12591. { 2, 1, 1 },
  12592. { 5, 1, 5 },
  12593. { 4, 1, 5 },
  12594. { 3, 1, 5 },
  12595. { 2, 1, 5 },
  12596. { 1, 1, 5 },
  12597. { 0, 1, 5 },
  12598. { 1, 1, 0 },
  12599. { 0, 1, 0 },
  12600. { 5, 1, 4 },
  12601. { 4, 1, 4 },
  12602. { 3, 1, 4 },
  12603. { 2, 1, 4 },
  12604. { 1, 1, 4 },
  12605. { 0, 1, 4 },
  12606. { 3, 0, 4 },
  12607. { 2, 0, 4 },
  12608. { 5, 0, 3 },
  12609. { 4, 0, 3 },
  12610. { 3, 0, 3 },
  12611. { 2, 0, 3 },
  12612. { 1, 0, 5 },
  12613. { 0, 0, 5 },
  12614. { 1, 0, 3 },
  12615. { 0, 0, 3 },
  12616. { 5, 0, 2 },
  12617. { 4, 0, 2 },
  12618. { 3, 0, 2 },
  12619. { 2, 0, 2 },
  12620. { 1, 0, 2 },
  12621. { 0, 0, 2 },
  12622. { 3, 0, 5 },
  12623. { 2, 0, 5 },
  12624. { 5, 0, 1 },
  12625. { 4, 0, 1 },
  12626. { 3, 0, 1 },
  12627. { 2, 0, 1 },
  12628. { 1, 0, 1 },
  12629. { 0, 0, 1 },
  12630. { 1, 0, 4 },
  12631. { 0, 0, 4 },
  12632. { 5, 0, 0 },
  12633. { 4, 0, 0 },
  12634. { 3, 0, 0 },
  12635. { 2, 0, 0 },
  12636. { 1, 0, 0 },
  12637. { 0, 0, 0 },
  12638. { -1, -1, -1 },
  12639. { -1, -1, -1 },
  12640. { -1, -1, -1 },
  12641. { -1, -1, -1 },
  12642. { -1, -1, -1 },
  12643. { -1, -1, -1 },
  12644. { -1, -1, -1 },
  12645. { -1, -1, -1 },
  12646. { -1, -1, -1 },
  12647. { -1, -1, -1 },
  12648. { -1, -1, -1 },
  12649. { -1, -1, -1 },
  12650. { -1, -1, -1 },
  12651. { -1, -1, -1 },
  12652. { -1, -1, -1 },
  12653. { -1, -1, -1 },
  12654. { -1, -1, -1 },
  12655. { -1, -1, -1 },
  12656. { -1, -1, -1 },
  12657. { -1, -1, -1 },
  12658. { -1, -1, -1 },
  12659. { -1, -1, -1 },
  12660. { -1, -1, -1 },
  12661. { -1, -1, -1 },
  12662. { -1, -1, -1 },
  12663. { -1, -1, -1 },
  12664. { -1, -1, -1 },
  12665. { -1, -1, -1 },
  12666. { -1, -1, -1 },
  12667. { -1, -1, -1 },
  12668. { -1, -1, -1 },
  12669. { -1, -1, -1 }
  12670. };
  12671. const char tile_sn_direction_names[6][5] =
  12672. {
  12673. "w",
  12674. "c",
  12675. "acc",
  12676. "n",
  12677. "e",
  12678. "s"
  12679. };
  12680. const signed char tile_sn_dest_map[6][6] = {
  12681. { -1, 3, 4, 5, 1, 2 } /* val -> w */,
  12682. { -1, 3, 4, 5, 0, 2 } /* val -> c */,
  12683. { -1, 3, 4, 5, 0, 1 } /* val -> acc */,
  12684. { -1, 4, 5, 0, 1, 2 } /* val -> n */,
  12685. { -1, 3, 5, 0, 1, 2 } /* val -> e */,
  12686. { -1, 3, 4, 0, 1, 2 } /* val -> s */
  12687. };
  12688. const struct tile_operand tile_operands[43] =
  12689. {
  12690. {
  12691. TILE_OP_TYPE_IMMEDIATE, /* type */
  12692. MAYBE_BFD_RELOC(BFD_RELOC_TILE_IMM8_X0), /* default_reloc */
  12693. 8, /* num_bits */
  12694. 1, /* is_signed */
  12695. 0, /* is_src_reg */
  12696. 0, /* is_dest_reg */
  12697. 0, /* is_pc_relative */
  12698. 0, /* rightshift */
  12699. create_Imm8_X0, /* insert */
  12700. get_Imm8_X0 /* extract */
  12701. },
  12702. {
  12703. TILE_OP_TYPE_IMMEDIATE, /* type */
  12704. MAYBE_BFD_RELOC(BFD_RELOC_TILE_IMM8_X1), /* default_reloc */
  12705. 8, /* num_bits */
  12706. 1, /* is_signed */
  12707. 0, /* is_src_reg */
  12708. 0, /* is_dest_reg */
  12709. 0, /* is_pc_relative */
  12710. 0, /* rightshift */
  12711. create_Imm8_X1, /* insert */
  12712. get_Imm8_X1 /* extract */
  12713. },
  12714. {
  12715. TILE_OP_TYPE_IMMEDIATE, /* type */
  12716. MAYBE_BFD_RELOC(BFD_RELOC_TILE_IMM8_Y0), /* default_reloc */
  12717. 8, /* num_bits */
  12718. 1, /* is_signed */
  12719. 0, /* is_src_reg */
  12720. 0, /* is_dest_reg */
  12721. 0, /* is_pc_relative */
  12722. 0, /* rightshift */
  12723. create_Imm8_Y0, /* insert */
  12724. get_Imm8_Y0 /* extract */
  12725. },
  12726. {
  12727. TILE_OP_TYPE_IMMEDIATE, /* type */
  12728. MAYBE_BFD_RELOC(BFD_RELOC_TILE_IMM8_Y1), /* default_reloc */
  12729. 8, /* num_bits */
  12730. 1, /* is_signed */
  12731. 0, /* is_src_reg */
  12732. 0, /* is_dest_reg */
  12733. 0, /* is_pc_relative */
  12734. 0, /* rightshift */
  12735. create_Imm8_Y1, /* insert */
  12736. get_Imm8_Y1 /* extract */
  12737. },
  12738. {
  12739. TILE_OP_TYPE_IMMEDIATE, /* type */
  12740. MAYBE_BFD_RELOC(BFD_RELOC_TILE_IMM16_X0), /* default_reloc */
  12741. 16, /* num_bits */
  12742. 1, /* is_signed */
  12743. 0, /* is_src_reg */
  12744. 0, /* is_dest_reg */
  12745. 0, /* is_pc_relative */
  12746. 0, /* rightshift */
  12747. create_Imm16_X0, /* insert */
  12748. get_Imm16_X0 /* extract */
  12749. },
  12750. {
  12751. TILE_OP_TYPE_IMMEDIATE, /* type */
  12752. MAYBE_BFD_RELOC(BFD_RELOC_TILE_IMM16_X1), /* default_reloc */
  12753. 16, /* num_bits */
  12754. 1, /* is_signed */
  12755. 0, /* is_src_reg */
  12756. 0, /* is_dest_reg */
  12757. 0, /* is_pc_relative */
  12758. 0, /* rightshift */
  12759. create_Imm16_X1, /* insert */
  12760. get_Imm16_X1 /* extract */
  12761. },
  12762. {
  12763. TILE_OP_TYPE_ADDRESS, /* type */
  12764. MAYBE_BFD_RELOC(BFD_RELOC_TILE_JOFFLONG_X1), /* default_reloc */
  12765. 29, /* num_bits */
  12766. 1, /* is_signed */
  12767. 0, /* is_src_reg */
  12768. 0, /* is_dest_reg */
  12769. 1, /* is_pc_relative */
  12770. TILE_LOG2_BUNDLE_ALIGNMENT_IN_BYTES, /* rightshift */
  12771. create_JOffLong_X1, /* insert */
  12772. get_JOffLong_X1 /* extract */
  12773. },
  12774. {
  12775. TILE_OP_TYPE_REGISTER, /* type */
  12776. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12777. 6, /* num_bits */
  12778. 0, /* is_signed */
  12779. 0, /* is_src_reg */
  12780. 1, /* is_dest_reg */
  12781. 0, /* is_pc_relative */
  12782. 0, /* rightshift */
  12783. create_Dest_X0, /* insert */
  12784. get_Dest_X0 /* extract */
  12785. },
  12786. {
  12787. TILE_OP_TYPE_REGISTER, /* type */
  12788. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12789. 6, /* num_bits */
  12790. 0, /* is_signed */
  12791. 1, /* is_src_reg */
  12792. 0, /* is_dest_reg */
  12793. 0, /* is_pc_relative */
  12794. 0, /* rightshift */
  12795. create_SrcA_X0, /* insert */
  12796. get_SrcA_X0 /* extract */
  12797. },
  12798. {
  12799. TILE_OP_TYPE_REGISTER, /* type */
  12800. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12801. 6, /* num_bits */
  12802. 0, /* is_signed */
  12803. 0, /* is_src_reg */
  12804. 1, /* is_dest_reg */
  12805. 0, /* is_pc_relative */
  12806. 0, /* rightshift */
  12807. create_Dest_X1, /* insert */
  12808. get_Dest_X1 /* extract */
  12809. },
  12810. {
  12811. TILE_OP_TYPE_REGISTER, /* type */
  12812. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12813. 6, /* num_bits */
  12814. 0, /* is_signed */
  12815. 1, /* is_src_reg */
  12816. 0, /* is_dest_reg */
  12817. 0, /* is_pc_relative */
  12818. 0, /* rightshift */
  12819. create_SrcA_X1, /* insert */
  12820. get_SrcA_X1 /* extract */
  12821. },
  12822. {
  12823. TILE_OP_TYPE_REGISTER, /* type */
  12824. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12825. 6, /* num_bits */
  12826. 0, /* is_signed */
  12827. 0, /* is_src_reg */
  12828. 1, /* is_dest_reg */
  12829. 0, /* is_pc_relative */
  12830. 0, /* rightshift */
  12831. create_Dest_Y0, /* insert */
  12832. get_Dest_Y0 /* extract */
  12833. },
  12834. {
  12835. TILE_OP_TYPE_REGISTER, /* type */
  12836. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12837. 6, /* num_bits */
  12838. 0, /* is_signed */
  12839. 1, /* is_src_reg */
  12840. 0, /* is_dest_reg */
  12841. 0, /* is_pc_relative */
  12842. 0, /* rightshift */
  12843. create_SrcA_Y0, /* insert */
  12844. get_SrcA_Y0 /* extract */
  12845. },
  12846. {
  12847. TILE_OP_TYPE_REGISTER, /* type */
  12848. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12849. 6, /* num_bits */
  12850. 0, /* is_signed */
  12851. 0, /* is_src_reg */
  12852. 1, /* is_dest_reg */
  12853. 0, /* is_pc_relative */
  12854. 0, /* rightshift */
  12855. create_Dest_Y1, /* insert */
  12856. get_Dest_Y1 /* extract */
  12857. },
  12858. {
  12859. TILE_OP_TYPE_REGISTER, /* type */
  12860. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12861. 6, /* num_bits */
  12862. 0, /* is_signed */
  12863. 1, /* is_src_reg */
  12864. 0, /* is_dest_reg */
  12865. 0, /* is_pc_relative */
  12866. 0, /* rightshift */
  12867. create_SrcA_Y1, /* insert */
  12868. get_SrcA_Y1 /* extract */
  12869. },
  12870. {
  12871. TILE_OP_TYPE_REGISTER, /* type */
  12872. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12873. 6, /* num_bits */
  12874. 0, /* is_signed */
  12875. 1, /* is_src_reg */
  12876. 0, /* is_dest_reg */
  12877. 0, /* is_pc_relative */
  12878. 0, /* rightshift */
  12879. create_SrcA_Y2, /* insert */
  12880. get_SrcA_Y2 /* extract */
  12881. },
  12882. {
  12883. TILE_OP_TYPE_REGISTER, /* type */
  12884. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12885. 6, /* num_bits */
  12886. 0, /* is_signed */
  12887. 1, /* is_src_reg */
  12888. 0, /* is_dest_reg */
  12889. 0, /* is_pc_relative */
  12890. 0, /* rightshift */
  12891. create_SrcB_X0, /* insert */
  12892. get_SrcB_X0 /* extract */
  12893. },
  12894. {
  12895. TILE_OP_TYPE_REGISTER, /* type */
  12896. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12897. 6, /* num_bits */
  12898. 0, /* is_signed */
  12899. 1, /* is_src_reg */
  12900. 0, /* is_dest_reg */
  12901. 0, /* is_pc_relative */
  12902. 0, /* rightshift */
  12903. create_SrcB_X1, /* insert */
  12904. get_SrcB_X1 /* extract */
  12905. },
  12906. {
  12907. TILE_OP_TYPE_REGISTER, /* type */
  12908. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12909. 6, /* num_bits */
  12910. 0, /* is_signed */
  12911. 1, /* is_src_reg */
  12912. 0, /* is_dest_reg */
  12913. 0, /* is_pc_relative */
  12914. 0, /* rightshift */
  12915. create_SrcB_Y0, /* insert */
  12916. get_SrcB_Y0 /* extract */
  12917. },
  12918. {
  12919. TILE_OP_TYPE_REGISTER, /* type */
  12920. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12921. 6, /* num_bits */
  12922. 0, /* is_signed */
  12923. 1, /* is_src_reg */
  12924. 0, /* is_dest_reg */
  12925. 0, /* is_pc_relative */
  12926. 0, /* rightshift */
  12927. create_SrcB_Y1, /* insert */
  12928. get_SrcB_Y1 /* extract */
  12929. },
  12930. {
  12931. TILE_OP_TYPE_ADDRESS, /* type */
  12932. MAYBE_BFD_RELOC(BFD_RELOC_TILE_BROFF_X1), /* default_reloc */
  12933. 17, /* num_bits */
  12934. 1, /* is_signed */
  12935. 0, /* is_src_reg */
  12936. 0, /* is_dest_reg */
  12937. 1, /* is_pc_relative */
  12938. TILE_LOG2_BUNDLE_ALIGNMENT_IN_BYTES, /* rightshift */
  12939. create_BrOff_X1, /* insert */
  12940. get_BrOff_X1 /* extract */
  12941. },
  12942. {
  12943. TILE_OP_TYPE_REGISTER, /* type */
  12944. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12945. 6, /* num_bits */
  12946. 0, /* is_signed */
  12947. 1, /* is_src_reg */
  12948. 1, /* is_dest_reg */
  12949. 0, /* is_pc_relative */
  12950. 0, /* rightshift */
  12951. create_Dest_X0, /* insert */
  12952. get_Dest_X0 /* extract */
  12953. },
  12954. {
  12955. TILE_OP_TYPE_ADDRESS, /* type */
  12956. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12957. 28, /* num_bits */
  12958. 1, /* is_signed */
  12959. 0, /* is_src_reg */
  12960. 0, /* is_dest_reg */
  12961. 1, /* is_pc_relative */
  12962. TILE_LOG2_BUNDLE_ALIGNMENT_IN_BYTES, /* rightshift */
  12963. create_JOff_X1, /* insert */
  12964. get_JOff_X1 /* extract */
  12965. },
  12966. {
  12967. TILE_OP_TYPE_REGISTER, /* type */
  12968. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12969. 6, /* num_bits */
  12970. 0, /* is_signed */
  12971. 0, /* is_src_reg */
  12972. 1, /* is_dest_reg */
  12973. 0, /* is_pc_relative */
  12974. 0, /* rightshift */
  12975. create_SrcBDest_Y2, /* insert */
  12976. get_SrcBDest_Y2 /* extract */
  12977. },
  12978. {
  12979. TILE_OP_TYPE_REGISTER, /* type */
  12980. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  12981. 6, /* num_bits */
  12982. 0, /* is_signed */
  12983. 1, /* is_src_reg */
  12984. 1, /* is_dest_reg */
  12985. 0, /* is_pc_relative */
  12986. 0, /* rightshift */
  12987. create_SrcA_X1, /* insert */
  12988. get_SrcA_X1 /* extract */
  12989. },
  12990. {
  12991. TILE_OP_TYPE_SPR, /* type */
  12992. MAYBE_BFD_RELOC(BFD_RELOC_TILE_MF_IMM15_X1), /* default_reloc */
  12993. 15, /* num_bits */
  12994. 0, /* is_signed */
  12995. 0, /* is_src_reg */
  12996. 0, /* is_dest_reg */
  12997. 0, /* is_pc_relative */
  12998. 0, /* rightshift */
  12999. create_MF_Imm15_X1, /* insert */
  13000. get_MF_Imm15_X1 /* extract */
  13001. },
  13002. {
  13003. TILE_OP_TYPE_IMMEDIATE, /* type */
  13004. MAYBE_BFD_RELOC(BFD_RELOC_TILE_MMSTART_X0), /* default_reloc */
  13005. 5, /* num_bits */
  13006. 0, /* is_signed */
  13007. 0, /* is_src_reg */
  13008. 0, /* is_dest_reg */
  13009. 0, /* is_pc_relative */
  13010. 0, /* rightshift */
  13011. create_MMStart_X0, /* insert */
  13012. get_MMStart_X0 /* extract */
  13013. },
  13014. {
  13015. TILE_OP_TYPE_IMMEDIATE, /* type */
  13016. MAYBE_BFD_RELOC(BFD_RELOC_TILE_MMEND_X0), /* default_reloc */
  13017. 5, /* num_bits */
  13018. 0, /* is_signed */
  13019. 0, /* is_src_reg */
  13020. 0, /* is_dest_reg */
  13021. 0, /* is_pc_relative */
  13022. 0, /* rightshift */
  13023. create_MMEnd_X0, /* insert */
  13024. get_MMEnd_X0 /* extract */
  13025. },
  13026. {
  13027. TILE_OP_TYPE_IMMEDIATE, /* type */
  13028. MAYBE_BFD_RELOC(BFD_RELOC_TILE_MMSTART_X1), /* default_reloc */
  13029. 5, /* num_bits */
  13030. 0, /* is_signed */
  13031. 0, /* is_src_reg */
  13032. 0, /* is_dest_reg */
  13033. 0, /* is_pc_relative */
  13034. 0, /* rightshift */
  13035. create_MMStart_X1, /* insert */
  13036. get_MMStart_X1 /* extract */
  13037. },
  13038. {
  13039. TILE_OP_TYPE_IMMEDIATE, /* type */
  13040. MAYBE_BFD_RELOC(BFD_RELOC_TILE_MMEND_X1), /* default_reloc */
  13041. 5, /* num_bits */
  13042. 0, /* is_signed */
  13043. 0, /* is_src_reg */
  13044. 0, /* is_dest_reg */
  13045. 0, /* is_pc_relative */
  13046. 0, /* rightshift */
  13047. create_MMEnd_X1, /* insert */
  13048. get_MMEnd_X1 /* extract */
  13049. },
  13050. {
  13051. TILE_OP_TYPE_SPR, /* type */
  13052. MAYBE_BFD_RELOC(BFD_RELOC_TILE_MT_IMM15_X1), /* default_reloc */
  13053. 15, /* num_bits */
  13054. 0, /* is_signed */
  13055. 0, /* is_src_reg */
  13056. 0, /* is_dest_reg */
  13057. 0, /* is_pc_relative */
  13058. 0, /* rightshift */
  13059. create_MT_Imm15_X1, /* insert */
  13060. get_MT_Imm15_X1 /* extract */
  13061. },
  13062. {
  13063. TILE_OP_TYPE_REGISTER, /* type */
  13064. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  13065. 6, /* num_bits */
  13066. 0, /* is_signed */
  13067. 1, /* is_src_reg */
  13068. 1, /* is_dest_reg */
  13069. 0, /* is_pc_relative */
  13070. 0, /* rightshift */
  13071. create_Dest_Y0, /* insert */
  13072. get_Dest_Y0 /* extract */
  13073. },
  13074. {
  13075. TILE_OP_TYPE_IMMEDIATE, /* type */
  13076. MAYBE_BFD_RELOC(BFD_RELOC_TILE_SHAMT_X0), /* default_reloc */
  13077. 5, /* num_bits */
  13078. 0, /* is_signed */
  13079. 0, /* is_src_reg */
  13080. 0, /* is_dest_reg */
  13081. 0, /* is_pc_relative */
  13082. 0, /* rightshift */
  13083. create_ShAmt_X0, /* insert */
  13084. get_ShAmt_X0 /* extract */
  13085. },
  13086. {
  13087. TILE_OP_TYPE_IMMEDIATE, /* type */
  13088. MAYBE_BFD_RELOC(BFD_RELOC_TILE_SHAMT_X1), /* default_reloc */
  13089. 5, /* num_bits */
  13090. 0, /* is_signed */
  13091. 0, /* is_src_reg */
  13092. 0, /* is_dest_reg */
  13093. 0, /* is_pc_relative */
  13094. 0, /* rightshift */
  13095. create_ShAmt_X1, /* insert */
  13096. get_ShAmt_X1 /* extract */
  13097. },
  13098. {
  13099. TILE_OP_TYPE_IMMEDIATE, /* type */
  13100. MAYBE_BFD_RELOC(BFD_RELOC_TILE_SHAMT_Y0), /* default_reloc */
  13101. 5, /* num_bits */
  13102. 0, /* is_signed */
  13103. 0, /* is_src_reg */
  13104. 0, /* is_dest_reg */
  13105. 0, /* is_pc_relative */
  13106. 0, /* rightshift */
  13107. create_ShAmt_Y0, /* insert */
  13108. get_ShAmt_Y0 /* extract */
  13109. },
  13110. {
  13111. TILE_OP_TYPE_IMMEDIATE, /* type */
  13112. MAYBE_BFD_RELOC(BFD_RELOC_TILE_SHAMT_Y1), /* default_reloc */
  13113. 5, /* num_bits */
  13114. 0, /* is_signed */
  13115. 0, /* is_src_reg */
  13116. 0, /* is_dest_reg */
  13117. 0, /* is_pc_relative */
  13118. 0, /* rightshift */
  13119. create_ShAmt_Y1, /* insert */
  13120. get_ShAmt_Y1 /* extract */
  13121. },
  13122. {
  13123. TILE_OP_TYPE_REGISTER, /* type */
  13124. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  13125. 6, /* num_bits */
  13126. 0, /* is_signed */
  13127. 1, /* is_src_reg */
  13128. 0, /* is_dest_reg */
  13129. 0, /* is_pc_relative */
  13130. 0, /* rightshift */
  13131. create_SrcBDest_Y2, /* insert */
  13132. get_SrcBDest_Y2 /* extract */
  13133. },
  13134. {
  13135. TILE_OP_TYPE_IMMEDIATE, /* type */
  13136. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  13137. 8, /* num_bits */
  13138. 1, /* is_signed */
  13139. 0, /* is_src_reg */
  13140. 0, /* is_dest_reg */
  13141. 0, /* is_pc_relative */
  13142. 0, /* rightshift */
  13143. create_Dest_Imm8_X1, /* insert */
  13144. get_Dest_Imm8_X1 /* extract */
  13145. },
  13146. {
  13147. TILE_OP_TYPE_ADDRESS, /* type */
  13148. MAYBE_BFD_RELOC(BFD_RELOC_TILE_SN_BROFF), /* default_reloc */
  13149. 10, /* num_bits */
  13150. 1, /* is_signed */
  13151. 0, /* is_src_reg */
  13152. 0, /* is_dest_reg */
  13153. 1, /* is_pc_relative */
  13154. TILE_LOG2_SN_INSTRUCTION_SIZE_IN_BYTES, /* rightshift */
  13155. create_BrOff_SN, /* insert */
  13156. get_BrOff_SN /* extract */
  13157. },
  13158. {
  13159. TILE_OP_TYPE_IMMEDIATE, /* type */
  13160. MAYBE_BFD_RELOC(BFD_RELOC_TILE_SN_UIMM8), /* default_reloc */
  13161. 8, /* num_bits */
  13162. 0, /* is_signed */
  13163. 0, /* is_src_reg */
  13164. 0, /* is_dest_reg */
  13165. 0, /* is_pc_relative */
  13166. 0, /* rightshift */
  13167. create_Imm8_SN, /* insert */
  13168. get_Imm8_SN /* extract */
  13169. },
  13170. {
  13171. TILE_OP_TYPE_IMMEDIATE, /* type */
  13172. MAYBE_BFD_RELOC(BFD_RELOC_TILE_SN_IMM8), /* default_reloc */
  13173. 8, /* num_bits */
  13174. 1, /* is_signed */
  13175. 0, /* is_src_reg */
  13176. 0, /* is_dest_reg */
  13177. 0, /* is_pc_relative */
  13178. 0, /* rightshift */
  13179. create_Imm8_SN, /* insert */
  13180. get_Imm8_SN /* extract */
  13181. },
  13182. {
  13183. TILE_OP_TYPE_REGISTER, /* type */
  13184. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  13185. 2, /* num_bits */
  13186. 0, /* is_signed */
  13187. 0, /* is_src_reg */
  13188. 1, /* is_dest_reg */
  13189. 0, /* is_pc_relative */
  13190. 0, /* rightshift */
  13191. create_Dest_SN, /* insert */
  13192. get_Dest_SN /* extract */
  13193. },
  13194. {
  13195. TILE_OP_TYPE_REGISTER, /* type */
  13196. MAYBE_BFD_RELOC(BFD_RELOC_NONE), /* default_reloc */
  13197. 2, /* num_bits */
  13198. 0, /* is_signed */
  13199. 1, /* is_src_reg */
  13200. 0, /* is_dest_reg */
  13201. 0, /* is_pc_relative */
  13202. 0, /* rightshift */
  13203. create_Src_SN, /* insert */
  13204. get_Src_SN /* extract */
  13205. }
  13206. };
  13207. const struct tile_spr tile_sprs[] = {
  13208. { 0, "MPL_ITLB_MISS_SET_0" },
  13209. { 1, "MPL_ITLB_MISS_SET_1" },
  13210. { 2, "MPL_ITLB_MISS_SET_2" },
  13211. { 3, "MPL_ITLB_MISS_SET_3" },
  13212. { 4, "MPL_ITLB_MISS" },
  13213. { 256, "ITLB_CURRENT_0" },
  13214. { 257, "ITLB_CURRENT_1" },
  13215. { 258, "ITLB_CURRENT_2" },
  13216. { 259, "ITLB_CURRENT_3" },
  13217. { 260, "ITLB_INDEX" },
  13218. { 261, "ITLB_MATCH_0" },
  13219. { 262, "ITLB_PR" },
  13220. { 263, "NUMBER_ITLB" },
  13221. { 264, "REPLACEMENT_ITLB" },
  13222. { 265, "WIRED_ITLB" },
  13223. { 266, "ITLB_PERF" },
  13224. { 512, "MPL_MEM_ERROR_SET_0" },
  13225. { 513, "MPL_MEM_ERROR_SET_1" },
  13226. { 514, "MPL_MEM_ERROR_SET_2" },
  13227. { 515, "MPL_MEM_ERROR_SET_3" },
  13228. { 516, "MPL_MEM_ERROR" },
  13229. { 517, "L1_I_ERROR" },
  13230. { 518, "MEM_ERROR_CBOX_ADDR" },
  13231. { 519, "MEM_ERROR_CBOX_STATUS" },
  13232. { 520, "MEM_ERROR_ENABLE" },
  13233. { 521, "MEM_ERROR_MBOX_ADDR" },
  13234. { 522, "MEM_ERROR_MBOX_STATUS" },
  13235. { 523, "SNIC_ERROR_LOG_STATUS" },
  13236. { 524, "SNIC_ERROR_LOG_VA" },
  13237. { 525, "XDN_DEMUX_ERROR" },
  13238. { 1024, "MPL_ILL_SET_0" },
  13239. { 1025, "MPL_ILL_SET_1" },
  13240. { 1026, "MPL_ILL_SET_2" },
  13241. { 1027, "MPL_ILL_SET_3" },
  13242. { 1028, "MPL_ILL" },
  13243. { 1536, "MPL_GPV_SET_0" },
  13244. { 1537, "MPL_GPV_SET_1" },
  13245. { 1538, "MPL_GPV_SET_2" },
  13246. { 1539, "MPL_GPV_SET_3" },
  13247. { 1540, "MPL_GPV" },
  13248. { 1541, "GPV_REASON" },
  13249. { 2048, "MPL_SN_ACCESS_SET_0" },
  13250. { 2049, "MPL_SN_ACCESS_SET_1" },
  13251. { 2050, "MPL_SN_ACCESS_SET_2" },
  13252. { 2051, "MPL_SN_ACCESS_SET_3" },
  13253. { 2052, "MPL_SN_ACCESS" },
  13254. { 2053, "SNCTL" },
  13255. { 2054, "SNFIFO_DATA" },
  13256. { 2055, "SNFIFO_SEL" },
  13257. { 2056, "SNIC_INVADDR" },
  13258. { 2057, "SNISTATE" },
  13259. { 2058, "SNOSTATE" },
  13260. { 2059, "SNPC" },
  13261. { 2060, "SNSTATIC" },
  13262. { 2304, "SN_DATA_AVAIL" },
  13263. { 2560, "MPL_IDN_ACCESS_SET_0" },
  13264. { 2561, "MPL_IDN_ACCESS_SET_1" },
  13265. { 2562, "MPL_IDN_ACCESS_SET_2" },
  13266. { 2563, "MPL_IDN_ACCESS_SET_3" },
  13267. { 2564, "MPL_IDN_ACCESS" },
  13268. { 2565, "IDN_DEMUX_CA_COUNT" },
  13269. { 2566, "IDN_DEMUX_COUNT_0" },
  13270. { 2567, "IDN_DEMUX_COUNT_1" },
  13271. { 2568, "IDN_DEMUX_CTL" },
  13272. { 2569, "IDN_DEMUX_CURR_TAG" },
  13273. { 2570, "IDN_DEMUX_QUEUE_SEL" },
  13274. { 2571, "IDN_DEMUX_STATUS" },
  13275. { 2572, "IDN_DEMUX_WRITE_FIFO" },
  13276. { 2573, "IDN_DEMUX_WRITE_QUEUE" },
  13277. { 2574, "IDN_PENDING" },
  13278. { 2575, "IDN_SP_FIFO_DATA" },
  13279. { 2576, "IDN_SP_FIFO_SEL" },
  13280. { 2577, "IDN_SP_FREEZE" },
  13281. { 2578, "IDN_SP_STATE" },
  13282. { 2579, "IDN_TAG_0" },
  13283. { 2580, "IDN_TAG_1" },
  13284. { 2581, "IDN_TAG_VALID" },
  13285. { 2582, "IDN_TILE_COORD" },
  13286. { 2816, "IDN_CA_DATA" },
  13287. { 2817, "IDN_CA_REM" },
  13288. { 2818, "IDN_CA_TAG" },
  13289. { 2819, "IDN_DATA_AVAIL" },
  13290. { 3072, "MPL_UDN_ACCESS_SET_0" },
  13291. { 3073, "MPL_UDN_ACCESS_SET_1" },
  13292. { 3074, "MPL_UDN_ACCESS_SET_2" },
  13293. { 3075, "MPL_UDN_ACCESS_SET_3" },
  13294. { 3076, "MPL_UDN_ACCESS" },
  13295. { 3077, "UDN_DEMUX_CA_COUNT" },
  13296. { 3078, "UDN_DEMUX_COUNT_0" },
  13297. { 3079, "UDN_DEMUX_COUNT_1" },
  13298. { 3080, "UDN_DEMUX_COUNT_2" },
  13299. { 3081, "UDN_DEMUX_COUNT_3" },
  13300. { 3082, "UDN_DEMUX_CTL" },
  13301. { 3083, "UDN_DEMUX_CURR_TAG" },
  13302. { 3084, "UDN_DEMUX_QUEUE_SEL" },
  13303. { 3085, "UDN_DEMUX_STATUS" },
  13304. { 3086, "UDN_DEMUX_WRITE_FIFO" },
  13305. { 3087, "UDN_DEMUX_WRITE_QUEUE" },
  13306. { 3088, "UDN_PENDING" },
  13307. { 3089, "UDN_SP_FIFO_DATA" },
  13308. { 3090, "UDN_SP_FIFO_SEL" },
  13309. { 3091, "UDN_SP_FREEZE" },
  13310. { 3092, "UDN_SP_STATE" },
  13311. { 3093, "UDN_TAG_0" },
  13312. { 3094, "UDN_TAG_1" },
  13313. { 3095, "UDN_TAG_2" },
  13314. { 3096, "UDN_TAG_3" },
  13315. { 3097, "UDN_TAG_VALID" },
  13316. { 3098, "UDN_TILE_COORD" },
  13317. { 3328, "UDN_CA_DATA" },
  13318. { 3329, "UDN_CA_REM" },
  13319. { 3330, "UDN_CA_TAG" },
  13320. { 3331, "UDN_DATA_AVAIL" },
  13321. { 3584, "MPL_IDN_REFILL_SET_0" },
  13322. { 3585, "MPL_IDN_REFILL_SET_1" },
  13323. { 3586, "MPL_IDN_REFILL_SET_2" },
  13324. { 3587, "MPL_IDN_REFILL_SET_3" },
  13325. { 3588, "MPL_IDN_REFILL" },
  13326. { 3589, "IDN_REFILL_EN" },
  13327. { 4096, "MPL_UDN_REFILL_SET_0" },
  13328. { 4097, "MPL_UDN_REFILL_SET_1" },
  13329. { 4098, "MPL_UDN_REFILL_SET_2" },
  13330. { 4099, "MPL_UDN_REFILL_SET_3" },
  13331. { 4100, "MPL_UDN_REFILL" },
  13332. { 4101, "UDN_REFILL_EN" },
  13333. { 4608, "MPL_IDN_COMPLETE_SET_0" },
  13334. { 4609, "MPL_IDN_COMPLETE_SET_1" },
  13335. { 4610, "MPL_IDN_COMPLETE_SET_2" },
  13336. { 4611, "MPL_IDN_COMPLETE_SET_3" },
  13337. { 4612, "MPL_IDN_COMPLETE" },
  13338. { 4613, "IDN_REMAINING" },
  13339. { 5120, "MPL_UDN_COMPLETE_SET_0" },
  13340. { 5121, "MPL_UDN_COMPLETE_SET_1" },
  13341. { 5122, "MPL_UDN_COMPLETE_SET_2" },
  13342. { 5123, "MPL_UDN_COMPLETE_SET_3" },
  13343. { 5124, "MPL_UDN_COMPLETE" },
  13344. { 5125, "UDN_REMAINING" },
  13345. { 5632, "MPL_SWINT_3_SET_0" },
  13346. { 5633, "MPL_SWINT_3_SET_1" },
  13347. { 5634, "MPL_SWINT_3_SET_2" },
  13348. { 5635, "MPL_SWINT_3_SET_3" },
  13349. { 5636, "MPL_SWINT_3" },
  13350. { 6144, "MPL_SWINT_2_SET_0" },
  13351. { 6145, "MPL_SWINT_2_SET_1" },
  13352. { 6146, "MPL_SWINT_2_SET_2" },
  13353. { 6147, "MPL_SWINT_2_SET_3" },
  13354. { 6148, "MPL_SWINT_2" },
  13355. { 6656, "MPL_SWINT_1_SET_0" },
  13356. { 6657, "MPL_SWINT_1_SET_1" },
  13357. { 6658, "MPL_SWINT_1_SET_2" },
  13358. { 6659, "MPL_SWINT_1_SET_3" },
  13359. { 6660, "MPL_SWINT_1" },
  13360. { 7168, "MPL_SWINT_0_SET_0" },
  13361. { 7169, "MPL_SWINT_0_SET_1" },
  13362. { 7170, "MPL_SWINT_0_SET_2" },
  13363. { 7171, "MPL_SWINT_0_SET_3" },
  13364. { 7172, "MPL_SWINT_0" },
  13365. { 7680, "MPL_UNALIGN_DATA_SET_0" },
  13366. { 7681, "MPL_UNALIGN_DATA_SET_1" },
  13367. { 7682, "MPL_UNALIGN_DATA_SET_2" },
  13368. { 7683, "MPL_UNALIGN_DATA_SET_3" },
  13369. { 7684, "MPL_UNALIGN_DATA" },
  13370. { 8192, "MPL_DTLB_MISS_SET_0" },
  13371. { 8193, "MPL_DTLB_MISS_SET_1" },
  13372. { 8194, "MPL_DTLB_MISS_SET_2" },
  13373. { 8195, "MPL_DTLB_MISS_SET_3" },
  13374. { 8196, "MPL_DTLB_MISS" },
  13375. { 8448, "AER_0" },
  13376. { 8449, "AER_1" },
  13377. { 8450, "DTLB_BAD_ADDR" },
  13378. { 8451, "DTLB_BAD_ADDR_REASON" },
  13379. { 8452, "DTLB_CURRENT_0" },
  13380. { 8453, "DTLB_CURRENT_1" },
  13381. { 8454, "DTLB_CURRENT_2" },
  13382. { 8455, "DTLB_CURRENT_3" },
  13383. { 8456, "DTLB_INDEX" },
  13384. { 8457, "DTLB_MATCH_0" },
  13385. { 8458, "NUMBER_DTLB" },
  13386. { 8459, "PHYSICAL_MEMORY_MODE" },
  13387. { 8460, "REPLACEMENT_DTLB" },
  13388. { 8461, "WIRED_DTLB" },
  13389. { 8462, "CACHE_RED_WAY_OVERRIDDEN" },
  13390. { 8463, "DTLB_PERF" },
  13391. { 8704, "MPL_DTLB_ACCESS_SET_0" },
  13392. { 8705, "MPL_DTLB_ACCESS_SET_1" },
  13393. { 8706, "MPL_DTLB_ACCESS_SET_2" },
  13394. { 8707, "MPL_DTLB_ACCESS_SET_3" },
  13395. { 8708, "MPL_DTLB_ACCESS" },
  13396. { 9216, "MPL_DMATLB_MISS_SET_0" },
  13397. { 9217, "MPL_DMATLB_MISS_SET_1" },
  13398. { 9218, "MPL_DMATLB_MISS_SET_2" },
  13399. { 9219, "MPL_DMATLB_MISS_SET_3" },
  13400. { 9220, "MPL_DMATLB_MISS" },
  13401. { 9472, "DMA_BAD_ADDR" },
  13402. { 9473, "DMA_STATUS" },
  13403. { 9728, "MPL_DMATLB_ACCESS_SET_0" },
  13404. { 9729, "MPL_DMATLB_ACCESS_SET_1" },
  13405. { 9730, "MPL_DMATLB_ACCESS_SET_2" },
  13406. { 9731, "MPL_DMATLB_ACCESS_SET_3" },
  13407. { 9732, "MPL_DMATLB_ACCESS" },
  13408. { 10240, "MPL_SNITLB_MISS_SET_0" },
  13409. { 10241, "MPL_SNITLB_MISS_SET_1" },
  13410. { 10242, "MPL_SNITLB_MISS_SET_2" },
  13411. { 10243, "MPL_SNITLB_MISS_SET_3" },
  13412. { 10244, "MPL_SNITLB_MISS" },
  13413. { 10245, "NUMBER_SNITLB" },
  13414. { 10246, "REPLACEMENT_SNITLB" },
  13415. { 10247, "SNITLB_CURRENT_0" },
  13416. { 10248, "SNITLB_CURRENT_1" },
  13417. { 10249, "SNITLB_CURRENT_2" },
  13418. { 10250, "SNITLB_CURRENT_3" },
  13419. { 10251, "SNITLB_INDEX" },
  13420. { 10252, "SNITLB_MATCH_0" },
  13421. { 10253, "SNITLB_PR" },
  13422. { 10254, "WIRED_SNITLB" },
  13423. { 10255, "SNITLB_STATUS" },
  13424. { 10752, "MPL_SN_NOTIFY_SET_0" },
  13425. { 10753, "MPL_SN_NOTIFY_SET_1" },
  13426. { 10754, "MPL_SN_NOTIFY_SET_2" },
  13427. { 10755, "MPL_SN_NOTIFY_SET_3" },
  13428. { 10756, "MPL_SN_NOTIFY" },
  13429. { 10757, "SN_NOTIFY_STATUS" },
  13430. { 11264, "MPL_SN_FIREWALL_SET_0" },
  13431. { 11265, "MPL_SN_FIREWALL_SET_1" },
  13432. { 11266, "MPL_SN_FIREWALL_SET_2" },
  13433. { 11267, "MPL_SN_FIREWALL_SET_3" },
  13434. { 11268, "MPL_SN_FIREWALL" },
  13435. { 11269, "SN_DIRECTION_PROTECT" },
  13436. { 11776, "MPL_IDN_FIREWALL_SET_0" },
  13437. { 11777, "MPL_IDN_FIREWALL_SET_1" },
  13438. { 11778, "MPL_IDN_FIREWALL_SET_2" },
  13439. { 11779, "MPL_IDN_FIREWALL_SET_3" },
  13440. { 11780, "MPL_IDN_FIREWALL" },
  13441. { 11781, "IDN_DIRECTION_PROTECT" },
  13442. { 12288, "MPL_UDN_FIREWALL_SET_0" },
  13443. { 12289, "MPL_UDN_FIREWALL_SET_1" },
  13444. { 12290, "MPL_UDN_FIREWALL_SET_2" },
  13445. { 12291, "MPL_UDN_FIREWALL_SET_3" },
  13446. { 12292, "MPL_UDN_FIREWALL" },
  13447. { 12293, "UDN_DIRECTION_PROTECT" },
  13448. { 12800, "MPL_TILE_TIMER_SET_0" },
  13449. { 12801, "MPL_TILE_TIMER_SET_1" },
  13450. { 12802, "MPL_TILE_TIMER_SET_2" },
  13451. { 12803, "MPL_TILE_TIMER_SET_3" },
  13452. { 12804, "MPL_TILE_TIMER" },
  13453. { 12805, "TILE_TIMER_CONTROL" },
  13454. { 13312, "MPL_IDN_TIMER_SET_0" },
  13455. { 13313, "MPL_IDN_TIMER_SET_1" },
  13456. { 13314, "MPL_IDN_TIMER_SET_2" },
  13457. { 13315, "MPL_IDN_TIMER_SET_3" },
  13458. { 13316, "MPL_IDN_TIMER" },
  13459. { 13317, "IDN_DEADLOCK_COUNT" },
  13460. { 13318, "IDN_DEADLOCK_TIMEOUT" },
  13461. { 13824, "MPL_UDN_TIMER_SET_0" },
  13462. { 13825, "MPL_UDN_TIMER_SET_1" },
  13463. { 13826, "MPL_UDN_TIMER_SET_2" },
  13464. { 13827, "MPL_UDN_TIMER_SET_3" },
  13465. { 13828, "MPL_UDN_TIMER" },
  13466. { 13829, "UDN_DEADLOCK_COUNT" },
  13467. { 13830, "UDN_DEADLOCK_TIMEOUT" },
  13468. { 14336, "MPL_DMA_NOTIFY_SET_0" },
  13469. { 14337, "MPL_DMA_NOTIFY_SET_1" },
  13470. { 14338, "MPL_DMA_NOTIFY_SET_2" },
  13471. { 14339, "MPL_DMA_NOTIFY_SET_3" },
  13472. { 14340, "MPL_DMA_NOTIFY" },
  13473. { 14592, "DMA_BYTE" },
  13474. { 14593, "DMA_CHUNK_SIZE" },
  13475. { 14594, "DMA_CTR" },
  13476. { 14595, "DMA_DST_ADDR" },
  13477. { 14596, "DMA_DST_CHUNK_ADDR" },
  13478. { 14597, "DMA_SRC_ADDR" },
  13479. { 14598, "DMA_SRC_CHUNK_ADDR" },
  13480. { 14599, "DMA_STRIDE" },
  13481. { 14600, "DMA_USER_STATUS" },
  13482. { 14848, "MPL_IDN_CA_SET_0" },
  13483. { 14849, "MPL_IDN_CA_SET_1" },
  13484. { 14850, "MPL_IDN_CA_SET_2" },
  13485. { 14851, "MPL_IDN_CA_SET_3" },
  13486. { 14852, "MPL_IDN_CA" },
  13487. { 15360, "MPL_UDN_CA_SET_0" },
  13488. { 15361, "MPL_UDN_CA_SET_1" },
  13489. { 15362, "MPL_UDN_CA_SET_2" },
  13490. { 15363, "MPL_UDN_CA_SET_3" },
  13491. { 15364, "MPL_UDN_CA" },
  13492. { 15872, "MPL_IDN_AVAIL_SET_0" },
  13493. { 15873, "MPL_IDN_AVAIL_SET_1" },
  13494. { 15874, "MPL_IDN_AVAIL_SET_2" },
  13495. { 15875, "MPL_IDN_AVAIL_SET_3" },
  13496. { 15876, "MPL_IDN_AVAIL" },
  13497. { 15877, "IDN_AVAIL_EN" },
  13498. { 16384, "MPL_UDN_AVAIL_SET_0" },
  13499. { 16385, "MPL_UDN_AVAIL_SET_1" },
  13500. { 16386, "MPL_UDN_AVAIL_SET_2" },
  13501. { 16387, "MPL_UDN_AVAIL_SET_3" },
  13502. { 16388, "MPL_UDN_AVAIL" },
  13503. { 16389, "UDN_AVAIL_EN" },
  13504. { 16896, "MPL_PERF_COUNT_SET_0" },
  13505. { 16897, "MPL_PERF_COUNT_SET_1" },
  13506. { 16898, "MPL_PERF_COUNT_SET_2" },
  13507. { 16899, "MPL_PERF_COUNT_SET_3" },
  13508. { 16900, "MPL_PERF_COUNT" },
  13509. { 16901, "PERF_COUNT_0" },
  13510. { 16902, "PERF_COUNT_1" },
  13511. { 16903, "PERF_COUNT_CTL" },
  13512. { 16904, "PERF_COUNT_STS" },
  13513. { 16905, "WATCH_CTL" },
  13514. { 16906, "WATCH_MASK" },
  13515. { 16907, "WATCH_VAL" },
  13516. { 16912, "PERF_COUNT_DN_CTL" },
  13517. { 17408, "MPL_INTCTRL_3_SET_0" },
  13518. { 17409, "MPL_INTCTRL_3_SET_1" },
  13519. { 17410, "MPL_INTCTRL_3_SET_2" },
  13520. { 17411, "MPL_INTCTRL_3_SET_3" },
  13521. { 17412, "MPL_INTCTRL_3" },
  13522. { 17413, "EX_CONTEXT_3_0" },
  13523. { 17414, "EX_CONTEXT_3_1" },
  13524. { 17415, "INTERRUPT_MASK_3_0" },
  13525. { 17416, "INTERRUPT_MASK_3_1" },
  13526. { 17417, "INTERRUPT_MASK_RESET_3_0" },
  13527. { 17418, "INTERRUPT_MASK_RESET_3_1" },
  13528. { 17419, "INTERRUPT_MASK_SET_3_0" },
  13529. { 17420, "INTERRUPT_MASK_SET_3_1" },
  13530. { 17432, "INTCTRL_3_STATUS" },
  13531. { 17664, "SYSTEM_SAVE_3_0" },
  13532. { 17665, "SYSTEM_SAVE_3_1" },
  13533. { 17666, "SYSTEM_SAVE_3_2" },
  13534. { 17667, "SYSTEM_SAVE_3_3" },
  13535. { 17920, "MPL_INTCTRL_2_SET_0" },
  13536. { 17921, "MPL_INTCTRL_2_SET_1" },
  13537. { 17922, "MPL_INTCTRL_2_SET_2" },
  13538. { 17923, "MPL_INTCTRL_2_SET_3" },
  13539. { 17924, "MPL_INTCTRL_2" },
  13540. { 17925, "EX_CONTEXT_2_0" },
  13541. { 17926, "EX_CONTEXT_2_1" },
  13542. { 17927, "INTCTRL_2_STATUS" },
  13543. { 17928, "INTERRUPT_MASK_2_0" },
  13544. { 17929, "INTERRUPT_MASK_2_1" },
  13545. { 17930, "INTERRUPT_MASK_RESET_2_0" },
  13546. { 17931, "INTERRUPT_MASK_RESET_2_1" },
  13547. { 17932, "INTERRUPT_MASK_SET_2_0" },
  13548. { 17933, "INTERRUPT_MASK_SET_2_1" },
  13549. { 18176, "SYSTEM_SAVE_2_0" },
  13550. { 18177, "SYSTEM_SAVE_2_1" },
  13551. { 18178, "SYSTEM_SAVE_2_2" },
  13552. { 18179, "SYSTEM_SAVE_2_3" },
  13553. { 18432, "MPL_INTCTRL_1_SET_0" },
  13554. { 18433, "MPL_INTCTRL_1_SET_1" },
  13555. { 18434, "MPL_INTCTRL_1_SET_2" },
  13556. { 18435, "MPL_INTCTRL_1_SET_3" },
  13557. { 18436, "MPL_INTCTRL_1" },
  13558. { 18437, "EX_CONTEXT_1_0" },
  13559. { 18438, "EX_CONTEXT_1_1" },
  13560. { 18439, "INTCTRL_1_STATUS" },
  13561. { 18440, "INTCTRL_3_STATUS_REV0" },
  13562. { 18441, "INTERRUPT_MASK_1_0" },
  13563. { 18442, "INTERRUPT_MASK_1_1" },
  13564. { 18443, "INTERRUPT_MASK_RESET_1_0" },
  13565. { 18444, "INTERRUPT_MASK_RESET_1_1" },
  13566. { 18445, "INTERRUPT_MASK_SET_1_0" },
  13567. { 18446, "INTERRUPT_MASK_SET_1_1" },
  13568. { 18688, "SYSTEM_SAVE_1_0" },
  13569. { 18689, "SYSTEM_SAVE_1_1" },
  13570. { 18690, "SYSTEM_SAVE_1_2" },
  13571. { 18691, "SYSTEM_SAVE_1_3" },
  13572. { 18944, "MPL_INTCTRL_0_SET_0" },
  13573. { 18945, "MPL_INTCTRL_0_SET_1" },
  13574. { 18946, "MPL_INTCTRL_0_SET_2" },
  13575. { 18947, "MPL_INTCTRL_0_SET_3" },
  13576. { 18948, "MPL_INTCTRL_0" },
  13577. { 18949, "EX_CONTEXT_0_0" },
  13578. { 18950, "EX_CONTEXT_0_1" },
  13579. { 18951, "INTCTRL_0_STATUS" },
  13580. { 18952, "INTERRUPT_MASK_0_0" },
  13581. { 18953, "INTERRUPT_MASK_0_1" },
  13582. { 18954, "INTERRUPT_MASK_RESET_0_0" },
  13583. { 18955, "INTERRUPT_MASK_RESET_0_1" },
  13584. { 18956, "INTERRUPT_MASK_SET_0_0" },
  13585. { 18957, "INTERRUPT_MASK_SET_0_1" },
  13586. { 19200, "SYSTEM_SAVE_0_0" },
  13587. { 19201, "SYSTEM_SAVE_0_1" },
  13588. { 19202, "SYSTEM_SAVE_0_2" },
  13589. { 19203, "SYSTEM_SAVE_0_3" },
  13590. { 19456, "MPL_BOOT_ACCESS_SET_0" },
  13591. { 19457, "MPL_BOOT_ACCESS_SET_1" },
  13592. { 19458, "MPL_BOOT_ACCESS_SET_2" },
  13593. { 19459, "MPL_BOOT_ACCESS_SET_3" },
  13594. { 19460, "MPL_BOOT_ACCESS" },
  13595. { 19461, "CBOX_CACHEASRAM_CONFIG" },
  13596. { 19462, "CBOX_CACHE_CONFIG" },
  13597. { 19463, "CBOX_MMAP_0" },
  13598. { 19464, "CBOX_MMAP_1" },
  13599. { 19465, "CBOX_MMAP_2" },
  13600. { 19466, "CBOX_MMAP_3" },
  13601. { 19467, "CBOX_MSR" },
  13602. { 19468, "CBOX_SRC_ID" },
  13603. { 19469, "CYCLE_HIGH_MODIFY" },
  13604. { 19470, "CYCLE_LOW_MODIFY" },
  13605. { 19471, "DIAG_BCST_CTL" },
  13606. { 19472, "DIAG_BCST_MASK" },
  13607. { 19473, "DIAG_BCST_TRIGGER" },
  13608. { 19474, "DIAG_MUX_CTL" },
  13609. { 19475, "DIAG_TRACE_CTL" },
  13610. { 19476, "DIAG_TRACE_STS" },
  13611. { 19477, "IDN_DEMUX_BUF_THRESH" },
  13612. { 19478, "SBOX_CONFIG" },
  13613. { 19479, "TILE_COORD" },
  13614. { 19480, "UDN_DEMUX_BUF_THRESH" },
  13615. { 19481, "CBOX_HOME_MAP_ADDR" },
  13616. { 19482, "CBOX_HOME_MAP_DATA" },
  13617. { 19483, "CBOX_MSR1" },
  13618. { 19484, "BIG_ENDIAN_CONFIG" },
  13619. { 19485, "MEM_STRIPE_CONFIG" },
  13620. { 19486, "DIAG_TRACE_WAY" },
  13621. { 19487, "VDN_SNOOP_SHIM_CTL" },
  13622. { 19488, "PERF_COUNT_PLS" },
  13623. { 19489, "DIAG_TRACE_DATA" },
  13624. { 19712, "I_AER_0" },
  13625. { 19713, "I_AER_1" },
  13626. { 19714, "I_PHYSICAL_MEMORY_MODE" },
  13627. { 19968, "MPL_WORLD_ACCESS_SET_0" },
  13628. { 19969, "MPL_WORLD_ACCESS_SET_1" },
  13629. { 19970, "MPL_WORLD_ACCESS_SET_2" },
  13630. { 19971, "MPL_WORLD_ACCESS_SET_3" },
  13631. { 19972, "MPL_WORLD_ACCESS" },
  13632. { 19973, "SIM_SOCKET" },
  13633. { 19974, "CYCLE_HIGH" },
  13634. { 19975, "CYCLE_LOW" },
  13635. { 19976, "DONE" },
  13636. { 19977, "FAIL" },
  13637. { 19978, "INTERRUPT_CRITICAL_SECTION" },
  13638. { 19979, "PASS" },
  13639. { 19980, "SIM_CONTROL" },
  13640. { 19981, "EVENT_BEGIN" },
  13641. { 19982, "EVENT_END" },
  13642. { 19983, "TILE_WRITE_PENDING" },
  13643. { 19984, "TILE_RTF_HWM" },
  13644. { 20224, "PROC_STATUS" },
  13645. { 20225, "STATUS_SATURATE" },
  13646. { 20480, "MPL_I_ASID_SET_0" },
  13647. { 20481, "MPL_I_ASID_SET_1" },
  13648. { 20482, "MPL_I_ASID_SET_2" },
  13649. { 20483, "MPL_I_ASID_SET_3" },
  13650. { 20484, "MPL_I_ASID" },
  13651. { 20485, "I_ASID" },
  13652. { 20992, "MPL_D_ASID_SET_0" },
  13653. { 20993, "MPL_D_ASID_SET_1" },
  13654. { 20994, "MPL_D_ASID_SET_2" },
  13655. { 20995, "MPL_D_ASID_SET_3" },
  13656. { 20996, "MPL_D_ASID" },
  13657. { 20997, "D_ASID" },
  13658. { 21504, "MPL_DMA_ASID_SET_0" },
  13659. { 21505, "MPL_DMA_ASID_SET_1" },
  13660. { 21506, "MPL_DMA_ASID_SET_2" },
  13661. { 21507, "MPL_DMA_ASID_SET_3" },
  13662. { 21508, "MPL_DMA_ASID" },
  13663. { 21509, "DMA_ASID" },
  13664. { 22016, "MPL_SNI_ASID_SET_0" },
  13665. { 22017, "MPL_SNI_ASID_SET_1" },
  13666. { 22018, "MPL_SNI_ASID_SET_2" },
  13667. { 22019, "MPL_SNI_ASID_SET_3" },
  13668. { 22020, "MPL_SNI_ASID" },
  13669. { 22021, "SNI_ASID" },
  13670. { 22528, "MPL_DMA_CPL_SET_0" },
  13671. { 22529, "MPL_DMA_CPL_SET_1" },
  13672. { 22530, "MPL_DMA_CPL_SET_2" },
  13673. { 22531, "MPL_DMA_CPL_SET_3" },
  13674. { 22532, "MPL_DMA_CPL" },
  13675. { 23040, "MPL_SN_CPL_SET_0" },
  13676. { 23041, "MPL_SN_CPL_SET_1" },
  13677. { 23042, "MPL_SN_CPL_SET_2" },
  13678. { 23043, "MPL_SN_CPL_SET_3" },
  13679. { 23044, "MPL_SN_CPL" },
  13680. { 23552, "MPL_DOUBLE_FAULT_SET_0" },
  13681. { 23553, "MPL_DOUBLE_FAULT_SET_1" },
  13682. { 23554, "MPL_DOUBLE_FAULT_SET_2" },
  13683. { 23555, "MPL_DOUBLE_FAULT_SET_3" },
  13684. { 23556, "MPL_DOUBLE_FAULT" },
  13685. { 23557, "LAST_INTERRUPT_REASON" },
  13686. { 24064, "MPL_SN_STATIC_ACCESS_SET_0" },
  13687. { 24065, "MPL_SN_STATIC_ACCESS_SET_1" },
  13688. { 24066, "MPL_SN_STATIC_ACCESS_SET_2" },
  13689. { 24067, "MPL_SN_STATIC_ACCESS_SET_3" },
  13690. { 24068, "MPL_SN_STATIC_ACCESS" },
  13691. { 24069, "SN_STATIC_CTL" },
  13692. { 24070, "SN_STATIC_FIFO_DATA" },
  13693. { 24071, "SN_STATIC_FIFO_SEL" },
  13694. { 24073, "SN_STATIC_ISTATE" },
  13695. { 24074, "SN_STATIC_OSTATE" },
  13696. { 24076, "SN_STATIC_STATIC" },
  13697. { 24320, "SN_STATIC_DATA_AVAIL" },
  13698. { 24576, "MPL_AUX_PERF_COUNT_SET_0" },
  13699. { 24577, "MPL_AUX_PERF_COUNT_SET_1" },
  13700. { 24578, "MPL_AUX_PERF_COUNT_SET_2" },
  13701. { 24579, "MPL_AUX_PERF_COUNT_SET_3" },
  13702. { 24580, "MPL_AUX_PERF_COUNT" },
  13703. { 24581, "AUX_PERF_COUNT_0" },
  13704. { 24582, "AUX_PERF_COUNT_1" },
  13705. { 24583, "AUX_PERF_COUNT_CTL" },
  13706. { 24584, "AUX_PERF_COUNT_STS" },
  13707. };
  13708. const int tile_num_sprs = 499;
  13709. /* Canonical name of each register. */
  13710. const char *const tile_register_names[] =
  13711. {
  13712. "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
  13713. "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
  13714. "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
  13715. "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31",
  13716. "r32", "r33", "r34", "r35", "r36", "r37", "r38", "r39",
  13717. "r40", "r41", "r42", "r43", "r44", "r45", "r46", "r47",
  13718. "r48", "r49", "r50", "r51", "r52", "tp", "sp", "lr",
  13719. "sn", "idn0", "idn1", "udn0", "udn1", "udn2", "udn3", "zero"
  13720. };
  13721. /* Given a set of bundle bits and the lookup FSM for a specific pipe,
  13722. * returns which instruction the bundle contains in that pipe.
  13723. */
  13724. static const struct tile_opcode *
  13725. find_opcode(tile_bundle_bits bits, const unsigned short *table)
  13726. {
  13727. int index = 0;
  13728. while (1)
  13729. {
  13730. unsigned short bitspec = table[index];
  13731. unsigned int bitfield =
  13732. ((unsigned int)(bits >> (bitspec & 63))) & (bitspec >> 6);
  13733. unsigned short next = table[index + 1 + bitfield];
  13734. if (next <= TILE_OPC_NONE)
  13735. return &tile_opcodes[next];
  13736. index = next - TILE_OPC_NONE;
  13737. }
  13738. }
  13739. int
  13740. parse_insn_tile(tile_bundle_bits bits,
  13741. unsigned int pc,
  13742. struct tile_decoded_instruction
  13743. decoded[TILE_MAX_INSTRUCTIONS_PER_BUNDLE])
  13744. {
  13745. int num_instructions = 0;
  13746. int pipe;
  13747. int min_pipe, max_pipe;
  13748. if ((bits & TILE_BUNDLE_Y_ENCODING_MASK) == 0)
  13749. {
  13750. min_pipe = TILE_PIPELINE_X0;
  13751. max_pipe = TILE_PIPELINE_X1;
  13752. }
  13753. else
  13754. {
  13755. min_pipe = TILE_PIPELINE_Y0;
  13756. max_pipe = TILE_PIPELINE_Y2;
  13757. }
  13758. /* For each pipe, find an instruction that fits. */
  13759. for (pipe = min_pipe; pipe <= max_pipe; pipe++)
  13760. {
  13761. const struct tile_opcode *opc;
  13762. struct tile_decoded_instruction *d;
  13763. int i;
  13764. d = &decoded[num_instructions++];
  13765. opc = find_opcode (bits, tile_bundle_decoder_fsms[pipe]);
  13766. d->opcode = opc;
  13767. /* Decode each operand, sign extending, etc. as appropriate. */
  13768. for (i = 0; i < opc->num_operands; i++)
  13769. {
  13770. const struct tile_operand *op =
  13771. &tile_operands[opc->operands[pipe][i]];
  13772. int opval = op->extract (bits);
  13773. if (op->is_signed)
  13774. {
  13775. /* Sign-extend the operand. */
  13776. int shift = (int)((sizeof(int) * 8) - op->num_bits);
  13777. opval = (opval << shift) >> shift;
  13778. }
  13779. /* Adjust PC-relative scaled branch offsets. */
  13780. if (op->type == TILE_OP_TYPE_ADDRESS)
  13781. {
  13782. opval *= TILE_BUNDLE_SIZE_IN_BYTES;
  13783. opval += (int)pc;
  13784. }
  13785. /* Record the final value. */
  13786. d->operands[i] = op;
  13787. d->operand_values[i] = opval;
  13788. }
  13789. }
  13790. return num_instructions;
  13791. }