12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800 |
- /* DO NOT EDIT! -*- buffer-read-only: t -*-
- This file is automatically generated by z8kgen. */
- /* Copyright (C) 2007-2015 Free Software Foundation, Inc.
- This file is part of the GNU opcodes library.
- This library is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 3, or (at your option)
- any later version.
- It is distributed in the hope that it will be useful, but WITHOUT
- ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
- License for more details.
- You should have received a copy of the GNU General Public License
- along with this file; see the file COPYING. If not, write to the
- Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston,
- MA 02110-1301, USA. */
- #define ARG_MASK 0x0f
- #define ARG_SRC 0x01
- #define ARG_DST 0x02
- #define ARG_RS 0x01
- #define ARG_RD 0x02
- #define ARG_RA 0x03
- #define ARG_RB 0x04
- #define ARG_RR 0x05
- #define ARG_RX 0x06
- #define ARG_IMM4 0x01
- #define ARG_IMM8 0x02
- #define ARG_IMM16 0x03
- #define ARG_IMM32 0x04
- #define ARG_IMMN 0x05
- #define ARG_IMMNMINUS1 0x05
- #define ARG_IMM_1 0x06
- #define ARG_IMM_2 0x07
- #define ARG_DISP16 0x08
- #define ARG_NIM8 0x09
- #define ARG_IMM2 0x0a
- #define ARG_IMM1OR2 0x0b
- #define ARG_DISP12 0x0b
- #define ARG_NIM4 0x0c
- #define ARG_DISP8 0x0c
- #define ARG_IMM4M1 0x0d
- #define CLASS_X 0x10
- #define CLASS_BA 0x20
- #define CLASS_DA 0x30
- #define CLASS_BX 0x40
- #define CLASS_DISP 0x50
- #define CLASS_IMM 0x60
- #define CLASS_CC 0x70
- #define CLASS_CTRL 0x80
- #define CLASS_IGNORE 0x90
- #define CLASS_ADDRESS 0xd0
- #define CLASS_0CCC 0xe0
- #define CLASS_1CCC 0xf0
- #define CLASS_0DISP7 0x100
- #define CLASS_1DISP7 0x200
- #define CLASS_01II 0x300
- #define CLASS_00II 0x400
- #define CLASS_BIT 0x500
- #define CLASS_FLAGS 0x600
- #define CLASS_IR 0x700
- #define CLASS_IRO 0x800
- #define CLASS_DISP8 0x900
- #define CLASS_BIT_1OR2 0xa00
- #define CLASS_REG 0x7000
- #define CLASS_REG_BYTE 0x2000
- #define CLASS_REG_WORD 0x3000
- #define CLASS_REG_QUAD 0x4000
- #define CLASS_REG_LONG 0x5000
- #define CLASS_REGN0 0x8000
- #define CLASS_PR 0x10000
- #define CLASS_MASK 0x1fff0
- #define OPC_adc 0
- #define OPC_adcb 1
- #define OPC_add 2
- #define OPC_addb 3
- #define OPC_addl 4
- #define OPC_and 5
- #define OPC_andb 6
- #define OPC_bit 7
- #define OPC_bitb 8
- #define OPC_call 9
- #define OPC_calr 10
- #define OPC_clr 11
- #define OPC_clrb 12
- #define OPC_com 13
- #define OPC_comb 14
- #define OPC_comflg 15
- #define OPC_cp 16
- #define OPC_cpb 17
- #define OPC_cpd 18
- #define OPC_cpdb 19
- #define OPC_cpdr 20
- #define OPC_cpdrb 21
- #define OPC_cpi 22
- #define OPC_cpib 23
- #define OPC_cpir 24
- #define OPC_cpirb 25
- #define OPC_cpl 26
- #define OPC_cpsd 27
- #define OPC_cpsdb 28
- #define OPC_cpsdr 29
- #define OPC_cpsdrb 30
- #define OPC_cpsi 31
- #define OPC_cpsib 32
- #define OPC_cpsir 33
- #define OPC_cpsirb 34
- #define OPC_dab 35
- #define OPC_dbjnz 36
- #define OPC_dec 37
- #define OPC_decb 38
- #define OPC_di 39
- #define OPC_div 40
- #define OPC_divl 41
- #define OPC_djnz 42
- #define OPC_ei 43
- #define OPC_ex 44
- #define OPC_exb 45
- #define OPC_exts 46
- #define OPC_extsb 47
- #define OPC_extsl 48
- #define OPC_halt 49
- #define OPC_in 50
- #define OPC_inb 51
- #define OPC_inc 52
- #define OPC_incb 53
- #define OPC_ind 54
- #define OPC_indb 55
- #define OPC_indr 56
- #define OPC_indrb 57
- #define OPC_ini 58
- #define OPC_inib 59
- #define OPC_inir 60
- #define OPC_inirb 61
- #define OPC_iret 62
- #define OPC_jp 63
- #define OPC_jr 64
- #define OPC_ld 65
- #define OPC_lda 66
- #define OPC_ldar 67
- #define OPC_ldb 68
- #define OPC_ldctl 69
- #define OPC_ldir 70
- #define OPC_ldirb 71
- #define OPC_ldk 72
- #define OPC_ldl 73
- #define OPC_ldm 74
- #define OPC_ldps 75
- #define OPC_ldr 76
- #define OPC_ldrb 77
- #define OPC_ldrl 78
- #define OPC_mbit 79
- #define OPC_mreq 80
- #define OPC_mres 81
- #define OPC_mset 82
- #define OPC_mult 83
- #define OPC_multl 84
- #define OPC_neg 85
- #define OPC_negb 86
- #define OPC_nop 87
- #define OPC_or 88
- #define OPC_orb 89
- #define OPC_otdr 90
- #define OPC_otdrb 91
- #define OPC_otir 92
- #define OPC_otirb 93
- #define OPC_out 94
- #define OPC_outb 95
- #define OPC_outd 96
- #define OPC_outdb 97
- #define OPC_outi 98
- #define OPC_outib 99
- #define OPC_pop 100
- #define OPC_popl 101
- #define OPC_push 102
- #define OPC_pushl 103
- #define OPC_res 104
- #define OPC_resb 105
- #define OPC_resflg 106
- #define OPC_ret 107
- #define OPC_rl 108
- #define OPC_rlb 109
- #define OPC_rlc 110
- #define OPC_rlcb 111
- #define OPC_rldb 112
- #define OPC_rr 113
- #define OPC_rrb 114
- #define OPC_rrc 115
- #define OPC_rrcb 116
- #define OPC_rrdb 117
- #define OPC_sbc 118
- #define OPC_sbcb 119
- #define OPC_sda 120
- #define OPC_sdab 121
- #define OPC_sdal 122
- #define OPC_sdl 123
- #define OPC_sdlb 124
- #define OPC_sdll 125
- #define OPC_set 126
- #define OPC_setb 127
- #define OPC_setflg 128
- #define OPC_sin 129
- #define OPC_sinb 130
- #define OPC_sind 131
- #define OPC_sindb 132
- #define OPC_sindr 133
- #define OPC_sindrb 134
- #define OPC_sini 135
- #define OPC_sinib 136
- #define OPC_sinir 137
- #define OPC_sinirb 138
- #define OPC_sla 139
- #define OPC_slab 140
- #define OPC_slal 141
- #define OPC_sll 142
- #define OPC_sllb 143
- #define OPC_slll 144
- #define OPC_sotdr 145
- #define OPC_sotdrb 146
- #define OPC_sotir 147
- #define OPC_sotirb 148
- #define OPC_sout 149
- #define OPC_soutb 150
- #define OPC_soutd 151
- #define OPC_soutdb 152
- #define OPC_souti 153
- #define OPC_soutib 154
- #define OPC_sra 155
- #define OPC_srab 156
- #define OPC_sral 157
- #define OPC_srl 158
- #define OPC_srlb 159
- #define OPC_srll 160
- #define OPC_sub 161
- #define OPC_subb 162
- #define OPC_subl 163
- #define OPC_tcc 164
- #define OPC_tccb 165
- #define OPC_test 166
- #define OPC_testb 167
- #define OPC_testl 168
- #define OPC_trdb 169
- #define OPC_trdrb 170
- #define OPC_trib 171
- #define OPC_trirb 172
- #define OPC_trtdrb 173
- #define OPC_trtib 174
- #define OPC_trtirb 175
- #define OPC_trtrb 176
- #define OPC_tset 177
- #define OPC_tsetb 178
- #define OPC_xor 179
- #define OPC_xorb 180
- #define OPC_ldd 181
- #define OPC_lddb 182
- #define OPC_lddr 183
- #define OPC_lddrb 184
- #define OPC_ldi 185
- #define OPC_ldib 186
- #define OPC_sc 187
- #define OPC_bpt 188
- #define OPC_ext0e 188
- #define OPC_ext0f 188
- #define OPC_ext8e 188
- #define OPC_ext8f 188
- #define OPC_rsvd36 188
- #define OPC_rsvd38 188
- #define OPC_rsvd78 188
- #define OPC_rsvd7e 188
- #define OPC_rsvd9d 188
- #define OPC_rsvd9f 188
- #define OPC_rsvdb9 188
- #define OPC_rsvdbf 188
- #define OPC_ldctlb 189
- #define OPC_trtdb 190
- #define OPC_brk 191
- typedef struct {
- #ifdef NICENAMES
- const char *nicename;
- int type;
- int cycles;
- int flags;
- #endif
- const char *name;
- unsigned char opcode;
- void (*func) (void);
- unsigned int arg_info[4];
- unsigned int byte_info[10];
- int noperands;
- int length;
- int idx;
- } opcode_entry_type;
- #ifdef DEFINE_TABLE
- const opcode_entry_type z8k_table[] = {
- /* 1011 0101 ssss dddd *** adc rd,rs */
- {
- #ifdef NICENAMES
- "adc rd,rs",16,5,0x3c,
- #endif
- "adc",OPC_adc,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+5,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,0},
- /* 1011 0100 ssss dddd *** adcb rbd,rbs */
- {
- #ifdef NICENAMES
- "adcb rbd,rbs",8,5,0x3f,
- #endif
- "adcb",OPC_adcb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+4,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,1},
- /* 0000 0001 ssN0 dddd *** add rd,@rs */
- {
- #ifdef NICENAMES
- "add rd,@rs",16,7,0x3c,
- #endif
- "add",OPC_add,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+1,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,2},
- /* 0100 0001 0000 dddd address_src *** add rd,address_src */
- {
- #ifdef NICENAMES
- "add rd,address_src",16,9,0x3c,
- #endif
- "add",OPC_add,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,2},
- /* 0100 0001 ssN0 dddd address_src *** add rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "add rd,address_src(rs)",16,10,0x3c,
- #endif
- "add",OPC_add,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+1,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,2},
- /* 0000 0001 0000 dddd imm16 *** add rd,imm16 */
- {
- #ifdef NICENAMES
- "add rd,imm16",16,7,0x3c,
- #endif
- "add",OPC_add,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,2},
- /* 1000 0001 ssss dddd *** add rd,rs */
- {
- #ifdef NICENAMES
- "add rd,rs",16,4,0x3c,
- #endif
- "add",OPC_add,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+1,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,2},
- /* 0000 0000 ssN0 dddd *** addb rbd,@rs */
- {
- #ifdef NICENAMES
- "addb rbd,@rs",8,7,0x3f,
- #endif
- "addb",OPC_addb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,3},
- /* 0100 0000 0000 dddd address_src *** addb rbd,address_src */
- {
- #ifdef NICENAMES
- "addb rbd,address_src",8,9,0x3f,
- #endif
- "addb",OPC_addb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,3},
- /* 0100 0000 ssN0 dddd address_src *** addb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "addb rbd,address_src(rs)",8,10,0x3f,
- #endif
- "addb",OPC_addb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,3},
- /* 0000 0000 0000 dddd imm8 imm8 *** addb rbd,imm8 */
- {
- #ifdef NICENAMES
- "addb rbd,imm8",8,7,0x3f,
- #endif
- "addb",OPC_addb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,3},
- /* 1000 0000 ssss dddd *** addb rbd,rbs */
- {
- #ifdef NICENAMES
- "addb rbd,rbs",8,4,0x3f,
- #endif
- "addb",OPC_addb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,3},
- /* 0001 0110 ssN0 dddd *** addl rrd,@rs */
- {
- #ifdef NICENAMES
- "addl rrd,@rs",32,14,0x3c,
- #endif
- "addl",OPC_addl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+6,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,4},
- /* 0101 0110 0000 dddd address_src *** addl rrd,address_src */
- {
- #ifdef NICENAMES
- "addl rrd,address_src",32,15,0x3c,
- #endif
- "addl",OPC_addl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,4},
- /* 0101 0110 ssN0 dddd address_src *** addl rrd,address_src(rs) */
- {
- #ifdef NICENAMES
- "addl rrd,address_src(rs)",32,16,0x3c,
- #endif
- "addl",OPC_addl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+6,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,4},
- /* 0001 0110 0000 dddd imm32 *** addl rrd,imm32 */
- {
- #ifdef NICENAMES
- "addl rrd,imm32",32,14,0x3c,
- #endif
- "addl",OPC_addl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM32),},
- {CLASS_BIT+1,CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM32),0,0,0,0,},2,6,4},
- /* 1001 0110 ssss dddd *** addl rrd,rrs */
- {
- #ifdef NICENAMES
- "addl rrd,rrs",32,8,0x3c,
- #endif
- "addl",OPC_addl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+6,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,4},
- /* 0000 0111 ssN0 dddd *** and rd,@rs */
- {
- #ifdef NICENAMES
- "and rd,@rs",16,7,0x18,
- #endif
- "and",OPC_and,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+7,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,5},
- /* 0100 0111 0000 dddd address_src *** and rd,address_src */
- {
- #ifdef NICENAMES
- "and rd,address_src",16,9,0x18,
- #endif
- "and",OPC_and,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+7,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,5},
- /* 0100 0111 ssN0 dddd address_src *** and rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "and rd,address_src(rs)",16,10,0x18,
- #endif
- "and",OPC_and,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+7,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,5},
- /* 0000 0111 0000 dddd imm16 *** and rd,imm16 */
- {
- #ifdef NICENAMES
- "and rd,imm16",16,7,0x18,
- #endif
- "and",OPC_and,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+7,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,5},
- /* 1000 0111 ssss dddd *** and rd,rs */
- {
- #ifdef NICENAMES
- "and rd,rs",16,4,0x18,
- #endif
- "and",OPC_and,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+7,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,5},
- /* 0000 0110 ssN0 dddd *** andb rbd,@rs */
- {
- #ifdef NICENAMES
- "andb rbd,@rs",8,7,0x1c,
- #endif
- "andb",OPC_andb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+6,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,6},
- /* 0100 0110 0000 dddd address_src *** andb rbd,address_src */
- {
- #ifdef NICENAMES
- "andb rbd,address_src",8,9,0x1c,
- #endif
- "andb",OPC_andb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,6},
- /* 0100 0110 ssN0 dddd address_src *** andb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "andb rbd,address_src(rs)",8,10,0x1c,
- #endif
- "andb",OPC_andb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+6,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,6},
- /* 0000 0110 0000 dddd imm8 imm8 *** andb rbd,imm8 */
- {
- #ifdef NICENAMES
- "andb rbd,imm8",8,7,0x1c,
- #endif
- "andb",OPC_andb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,6},
- /* 1000 0110 ssss dddd *** andb rbd,rbs */
- {
- #ifdef NICENAMES
- "andb rbd,rbs",8,4,0x1c,
- #endif
- "andb",OPC_andb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+6,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,6},
- /* 0010 0111 ddN0 imm4 *** bit @rd,imm4 */
- {
- #ifdef NICENAMES
- "bit @rd,imm4",16,8,0x10,
- #endif
- "bit",OPC_bit,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+2,CLASS_BIT+7,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,7},
- /* 0110 0111 ddN0 imm4 address_dst *** bit address_dst(rd),imm4 */
- {
- #ifdef NICENAMES
- "bit address_dst(rd),imm4",16,11,0x10,
- #endif
- "bit",OPC_bit,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+7,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,7},
- /* 0110 0111 0000 imm4 address_dst *** bit address_dst,imm4 */
- {
- #ifdef NICENAMES
- "bit address_dst,imm4",16,10,0x10,
- #endif
- "bit",OPC_bit,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+7,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,7},
- /* 1010 0111 dddd imm4 *** bit rd,imm4 */
- {
- #ifdef NICENAMES
- "bit rd,imm4",16,4,0x10,
- #endif
- "bit",OPC_bit,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xa,CLASS_BIT+7,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,7},
- /* 0010 0111 0000 ssss 0000 dddd 0000 0000 *** bit rd,rs */
- {
- #ifdef NICENAMES
- "bit rd,rs",16,10,0x10,
- #endif
- "bit",OPC_bit,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+7,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,7},
- /* 0010 0110 ddN0 imm4 *** bitb @rd,imm4 */
- {
- #ifdef NICENAMES
- "bitb @rd,imm4",8,8,0x10,
- #endif
- "bitb",OPC_bitb,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+2,CLASS_BIT+6,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,8},
- /* 0110 0110 ddN0 imm4 address_dst *** bitb address_dst(rd),imm4 */
- {
- #ifdef NICENAMES
- "bitb address_dst(rd),imm4",8,11,0x10,
- #endif
- "bitb",OPC_bitb,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+6,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,8},
- /* 0110 0110 0000 imm4 address_dst *** bitb address_dst,imm4 */
- {
- #ifdef NICENAMES
- "bitb address_dst,imm4",8,10,0x10,
- #endif
- "bitb",OPC_bitb,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+6,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,8},
- /* 1010 0110 dddd imm4 *** bitb rbd,imm4 */
- {
- #ifdef NICENAMES
- "bitb rbd,imm4",8,4,0x10,
- #endif
- "bitb",OPC_bitb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xa,CLASS_BIT+6,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,8},
- /* 0010 0110 0000 ssss 0000 dddd 0000 0000 *** bitb rbd,rs */
- {
- #ifdef NICENAMES
- "bitb rbd,rs",8,10,0x10,
- #endif
- "bitb",OPC_bitb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,8},
- /* 0011 0110 0000 0000 *** bpt */
- {
- #ifdef NICENAMES
- "bpt",8,2,0x00,
- #endif
- "bpt",OPC_bpt,0,{0},
- {CLASS_BIT+3,CLASS_BIT+6,CLASS_BIT+0,CLASS_BIT+0,0,0,0,0,0,},0,2,9},
- /* 0000 1111 0000 1100 *** brk */
- {
- #ifdef NICENAMES
- "brk",8,10,0x00,
- #endif
- "brk",OPC_brk,0,{0},
- {CLASS_BIT+0,CLASS_BIT+0xf,CLASS_BIT+0,CLASS_BIT+0xc,0,0,0,0,0,},0,2,10},
- /* 0001 1111 ddN0 0000 *** call @rd */
- {
- #ifdef NICENAMES
- "call @rd",32,10,0x00,
- #endif
- "call",OPC_call,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+1,CLASS_BIT+0xf,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,0,0,0,0,},1,2,11},
- /* 0101 1111 0000 0000 address_dst *** call address_dst */
- {
- #ifdef NICENAMES
- "call address_dst",32,12,0x00,
- #endif
- "call",OPC_call,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+5,CLASS_BIT+0xf,CLASS_BIT+0,CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,11},
- /* 0101 1111 ddN0 0000 address_dst *** call address_dst(rd) */
- {
- #ifdef NICENAMES
- "call address_dst(rd)",32,13,0x00,
- #endif
- "call",OPC_call,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+5,CLASS_BIT+0xf,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,11},
- /* 1101 disp12 *** calr disp12 */
- {
- #ifdef NICENAMES
- "calr disp12",16,10,0x00,
- #endif
- "calr",OPC_calr,0,{CLASS_DISP,},
- {CLASS_BIT+0xd,CLASS_DISP+(ARG_DISP12),0,0,0,0,0,0,0,},1,2,12},
- /* 0000 1101 ddN0 1000 *** clr @rd */
- {
- #ifdef NICENAMES
- "clr @rd",16,8,0x00,
- #endif
- "clr",OPC_clr,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,0,0,0,0,},1,2,13},
- /* 0100 1101 0000 1000 address_dst *** clr address_dst */
- {
- #ifdef NICENAMES
- "clr address_dst",16,11,0x00,
- #endif
- "clr",OPC_clr,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+8,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,13},
- /* 0100 1101 ddN0 1000 address_dst *** clr address_dst(rd) */
- {
- #ifdef NICENAMES
- "clr address_dst(rd)",16,12,0x00,
- #endif
- "clr",OPC_clr,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+8,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,13},
- /* 1000 1101 dddd 1000 *** clr rd */
- {
- #ifdef NICENAMES
- "clr rd",16,7,0x00,
- #endif
- "clr",OPC_clr,0,{CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_REG+(ARG_RD),CLASS_BIT+8,0,0,0,0,0,},1,2,13},
- /* 0000 1100 ddN0 1000 *** clrb @rd */
- {
- #ifdef NICENAMES
- "clrb @rd",8,8,0x00,
- #endif
- "clrb",OPC_clrb,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,0,0,0,0,},1,2,14},
- /* 0100 1100 0000 1000 address_dst *** clrb address_dst */
- {
- #ifdef NICENAMES
- "clrb address_dst",8,11,0x00,
- #endif
- "clrb",OPC_clrb,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+8,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,14},
- /* 0100 1100 ddN0 1000 address_dst *** clrb address_dst(rd) */
- {
- #ifdef NICENAMES
- "clrb address_dst(rd)",8,12,0x00,
- #endif
- "clrb",OPC_clrb,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+8,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,14},
- /* 1000 1100 dddd 1000 *** clrb rbd */
- {
- #ifdef NICENAMES
- "clrb rbd",8,7,0x00,
- #endif
- "clrb",OPC_clrb,0,{CLASS_REG_BYTE+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_BIT+8,0,0,0,0,0,},1,2,14},
- /* 0000 1101 ddN0 0000 *** com @rd */
- {
- #ifdef NICENAMES
- "com @rd",16,12,0x18,
- #endif
- "com",OPC_com,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,0,0,0,0,},1,2,15},
- /* 0100 1101 0000 0000 address_dst *** com address_dst */
- {
- #ifdef NICENAMES
- "com address_dst",16,15,0x18,
- #endif
- "com",OPC_com,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,15},
- /* 0100 1101 ddN0 0000 address_dst *** com address_dst(rd) */
- {
- #ifdef NICENAMES
- "com address_dst(rd)",16,16,0x18,
- #endif
- "com",OPC_com,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,15},
- /* 1000 1101 dddd 0000 *** com rd */
- {
- #ifdef NICENAMES
- "com rd",16,7,0x18,
- #endif
- "com",OPC_com,0,{CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_REG+(ARG_RD),CLASS_BIT+0,0,0,0,0,0,},1,2,15},
- /* 0000 1100 ddN0 0000 *** comb @rd */
- {
- #ifdef NICENAMES
- "comb @rd",8,12,0x1c,
- #endif
- "comb",OPC_comb,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,0,0,0,0,},1,2,16},
- /* 0100 1100 0000 0000 address_dst *** comb address_dst */
- {
- #ifdef NICENAMES
- "comb address_dst",8,15,0x1c,
- #endif
- "comb",OPC_comb,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,16},
- /* 0100 1100 ddN0 0000 address_dst *** comb address_dst(rd) */
- {
- #ifdef NICENAMES
- "comb address_dst(rd)",8,16,0x1c,
- #endif
- "comb",OPC_comb,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,16},
- /* 1000 1100 dddd 0000 *** comb rbd */
- {
- #ifdef NICENAMES
- "comb rbd",8,7,0x1c,
- #endif
- "comb",OPC_comb,0,{CLASS_REG_BYTE+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_BIT+0,0,0,0,0,0,},1,2,16},
- /* 1000 1101 flags 0101 *** comflg flags */
- {
- #ifdef NICENAMES
- "comflg flags",16,7,0x3c,
- #endif
- "comflg",OPC_comflg,0,{CLASS_FLAGS,},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_FLAGS,CLASS_BIT+5,0,0,0,0,0,},1,2,17},
- /* 0000 1101 ddN0 0001 imm16 *** cp @rd,imm16 */
- {
- #ifdef NICENAMES
- "cp @rd,imm16",16,11,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_IR+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+1,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,18},
- /* 0100 1101 ddN0 0001 address_dst imm16 *** cp address_dst(rd),imm16 */
- {
- #ifdef NICENAMES
- "cp address_dst(rd),imm16",16,15,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_X+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+1,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM16),0,0,0,},2,6,18},
- /* 0100 1101 0000 0001 address_dst imm16 *** cp address_dst,imm16 */
- {
- #ifdef NICENAMES
- "cp address_dst,imm16",16,14,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_DA+(ARG_DST),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+1,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM16),0,0,0,},2,6,18},
- /* 0000 1011 ssN0 dddd *** cp rd,@rs */
- {
- #ifdef NICENAMES
- "cp rd,@rs",16,7,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,18},
- /* 0100 1011 0000 dddd address_src *** cp rd,address_src */
- {
- #ifdef NICENAMES
- "cp rd,address_src",16,9,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,18},
- /* 0100 1011 ssN0 dddd address_src *** cp rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "cp rd,address_src(rs)",16,10,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,18},
- /* 0000 1011 0000 dddd imm16 *** cp rd,imm16 */
- {
- #ifdef NICENAMES
- "cp rd,imm16",16,7,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,18},
- /* 1000 1011 ssss dddd *** cp rd,rs */
- {
- #ifdef NICENAMES
- "cp rd,rs",16,4,0x3c,
- #endif
- "cp",OPC_cp,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,18},
- /* 0000 1100 ddN0 0001 imm8 imm8 *** cpb @rd,imm8 */
- {
- #ifdef NICENAMES
- "cpb @rd,imm8",8,11,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_IR+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+1,CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,19},
- /* 0100 1100 ddN0 0001 address_dst imm8 imm8 *** cpb address_dst(rd),imm8 */
- {
- #ifdef NICENAMES
- "cpb address_dst(rd),imm8",8,15,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_X+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+1,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,},2,6,19},
- /* 0100 1100 0000 0001 address_dst imm8 imm8 *** cpb address_dst,imm8 */
- {
- #ifdef NICENAMES
- "cpb address_dst,imm8",8,14,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_DA+(ARG_DST),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+1,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,},2,6,19},
- /* 0000 1010 ssN0 dddd *** cpb rbd,@rs */
- {
- #ifdef NICENAMES
- "cpb rbd,@rs",8,7,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,19},
- /* 0100 1010 0000 dddd address_src *** cpb rbd,address_src */
- {
- #ifdef NICENAMES
- "cpb rbd,address_src",8,9,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,19},
- /* 0100 1010 ssN0 dddd address_src *** cpb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "cpb rbd,address_src(rs)",8,10,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,19},
- /* 0000 1010 0000 dddd imm8 imm8 *** cpb rbd,imm8 */
- {
- #ifdef NICENAMES
- "cpb rbd,imm8",8,7,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,19},
- /* 1000 1010 ssss dddd *** cpb rbd,rbs */
- {
- #ifdef NICENAMES
- "cpb rbd,rbs",8,4,0x3c,
- #endif
- "cpb",OPC_cpb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,19},
- /* 1011 1011 ssN0 1000 0000 rrrr dddd cccc *** cpd rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpd rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpd",OPC_cpd,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,20},
- /* 1011 1010 ssN0 1000 0000 rrrr dddd cccc *** cpdb rbd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpdb rbd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpdb",OPC_cpdb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,21},
- /* 1011 1011 ssN0 1100 0000 rrrr dddd cccc *** cpdr rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpdr rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpdr",OPC_cpdr,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xc,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,22},
- /* 1011 1010 ssN0 1100 0000 rrrr dddd cccc *** cpdrb rbd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpdrb rbd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpdrb",OPC_cpdrb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xc,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,23},
- /* 1011 1011 ssN0 0000 0000 rrrr dddd cccc *** cpi rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpi rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpi",OPC_cpi,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,24},
- /* 1011 1010 ssN0 0000 0000 rrrr dddd cccc *** cpib rbd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpib rbd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpib",OPC_cpib,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,25},
- /* 1011 1011 ssN0 0100 0000 rrrr dddd cccc *** cpir rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpir rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpir",OPC_cpir,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,26},
- /* 1011 1010 ssN0 0100 0000 rrrr dddd cccc *** cpirb rbd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpirb rbd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpirb",OPC_cpirb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REG+(ARG_RD),CLASS_CC,0,},4,4,27},
- /* 0001 0000 ssN0 dddd *** cpl rrd,@rs */
- {
- #ifdef NICENAMES
- "cpl rrd,@rs",32,14,0x3c,
- #endif
- "cpl",OPC_cpl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,28},
- /* 0101 0000 0000 dddd address_src *** cpl rrd,address_src */
- {
- #ifdef NICENAMES
- "cpl rrd,address_src",32,15,0x3c,
- #endif
- "cpl",OPC_cpl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,28},
- /* 0101 0000 ssN0 dddd address_src *** cpl rrd,address_src(rs) */
- {
- #ifdef NICENAMES
- "cpl rrd,address_src(rs)",32,16,0x3c,
- #endif
- "cpl",OPC_cpl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,28},
- /* 0001 0000 0000 dddd imm32 *** cpl rrd,imm32 */
- {
- #ifdef NICENAMES
- "cpl rrd,imm32",32,14,0x3c,
- #endif
- "cpl",OPC_cpl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM32),},
- {CLASS_BIT+1,CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM32),0,0,0,0,},2,6,28},
- /* 1001 0000 ssss dddd *** cpl rrd,rrs */
- {
- #ifdef NICENAMES
- "cpl rrd,rrs",32,8,0x3c,
- #endif
- "cpl",OPC_cpl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,28},
- /* 1011 1011 ssN0 1010 0000 rrrr ddN0 cccc *** cpsd @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsd @rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpsd",OPC_cpsd,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,29},
- /* 1011 1010 ssN0 1010 0000 rrrr ddN0 cccc *** cpsdb @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsdb @rd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpsdb",OPC_cpsdb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,30},
- /* 1011 1011 ssN0 1110 0000 rrrr ddN0 cccc *** cpsdr @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsdr @rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpsdr",OPC_cpsdr,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xe,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,31},
- /* 1011 1010 ssN0 1110 0000 rrrr ddN0 cccc *** cpsdrb @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsdrb @rd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpsdrb",OPC_cpsdrb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xe,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,32},
- /* 1011 1011 ssN0 0010 0000 rrrr ddN0 cccc *** cpsi @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsi @rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpsi",OPC_cpsi,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,33},
- /* 1011 1010 ssN0 0010 0000 rrrr ddN0 cccc *** cpsib @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsib @rd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpsib",OPC_cpsib,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,34},
- /* 1011 1011 ssN0 0110 0000 rrrr ddN0 cccc *** cpsir @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsir @rd,@rs,rr,cc",16,11,0x3c,
- #endif
- "cpsir",OPC_cpsir,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,35},
- /* 1011 1010 ssN0 0110 0000 rrrr ddN0 cccc *** cpsirb @rd,@rs,rr,cc */
- {
- #ifdef NICENAMES
- "cpsirb @rd,@rs,rr,cc",8,11,0x3c,
- #endif
- "cpsirb",OPC_cpsirb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),CLASS_CC,},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_CC,0,},4,4,36},
- /* 1011 0000 dddd 0000 *** dab rbd */
- {
- #ifdef NICENAMES
- "dab rbd",8,5,0x38,
- #endif
- "dab",OPC_dab,0,{CLASS_REG_BYTE+(ARG_RD),},
- {CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,0,0,0,0,0,},1,2,37},
- /* 1111 dddd 0disp7 *** dbjnz rbd,disp7 */
- {
- #ifdef NICENAMES
- "dbjnz rbd,disp7",16,11,0x00,
- #endif
- "dbjnz",OPC_dbjnz,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DISP,},
- {CLASS_BIT+0xf,CLASS_REG+(ARG_RD),CLASS_0DISP7,0,0,0,0,0,0,},2,2,38},
- /* 0010 1011 ddN0 imm4m1 *** dec @rd,imm4m1 */
- {
- #ifdef NICENAMES
- "dec @rd,imm4m1",16,11,0x1c,
- #endif
- "dec",OPC_dec,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+2,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,39},
- /* 0110 1011 ddN0 imm4m1 address_dst *** dec address_dst(rd),imm4m1 */
- {
- #ifdef NICENAMES
- "dec address_dst(rd),imm4m1",16,14,0x1c,
- #endif
- "dec",OPC_dec,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,39},
- /* 0110 1011 0000 imm4m1 address_dst *** dec address_dst,imm4m1 */
- {
- #ifdef NICENAMES
- "dec address_dst,imm4m1",16,13,0x1c,
- #endif
- "dec",OPC_dec,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,39},
- /* 1010 1011 dddd imm4m1 *** dec rd,imm4m1 */
- {
- #ifdef NICENAMES
- "dec rd,imm4m1",16,4,0x1c,
- #endif
- "dec",OPC_dec,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+0xa,CLASS_BIT+0xb,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,39},
- /* 0010 1010 ddN0 imm4m1 *** decb @rd,imm4m1 */
- {
- #ifdef NICENAMES
- "decb @rd,imm4m1",8,11,0x1c,
- #endif
- "decb",OPC_decb,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+2,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,40},
- /* 0110 1010 ddN0 imm4m1 address_dst *** decb address_dst(rd),imm4m1 */
- {
- #ifdef NICENAMES
- "decb address_dst(rd),imm4m1",8,14,0x1c,
- #endif
- "decb",OPC_decb,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,40},
- /* 0110 1010 0000 imm4m1 address_dst *** decb address_dst,imm4m1 */
- {
- #ifdef NICENAMES
- "decb address_dst,imm4m1",8,13,0x1c,
- #endif
- "decb",OPC_decb,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+0xa,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,40},
- /* 1010 1010 dddd imm4m1 *** decb rbd,imm4m1 */
- {
- #ifdef NICENAMES
- "decb rbd,imm4m1",8,4,0x1c,
- #endif
- "decb",OPC_decb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+0xa,CLASS_BIT+0xa,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,40},
- /* 0111 1100 0000 00ii *** di i2 */
- {
- #ifdef NICENAMES
- "di i2",16,7,0x00,
- #endif
- "di",OPC_di,0,{CLASS_IMM+(ARG_IMM2),},
- {CLASS_BIT+7,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_00II,0,0,0,0,0,},1,2,41},
- /* 0001 1011 ssN0 dddd *** div rrd,@rs */
- {
- #ifdef NICENAMES
- "div rrd,@rs",16,107,0x3c,
- #endif
- "div",OPC_div,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,42},
- /* 0101 1011 0000 dddd address_src *** div rrd,address_src */
- {
- #ifdef NICENAMES
- "div rrd,address_src",16,107,0x3c,
- #endif
- "div",OPC_div,0,{CLASS_REG_LONG+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,42},
- /* 0101 1011 ssN0 dddd address_src *** div rrd,address_src(rs) */
- {
- #ifdef NICENAMES
- "div rrd,address_src(rs)",16,107,0x3c,
- #endif
- "div",OPC_div,0,{CLASS_REG_LONG+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,42},
- /* 0001 1011 0000 dddd imm16 *** div rrd,imm16 */
- {
- #ifdef NICENAMES
- "div rrd,imm16",16,107,0x3c,
- #endif
- "div",OPC_div,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+1,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,42},
- /* 1001 1011 ssss dddd *** div rrd,rs */
- {
- #ifdef NICENAMES
- "div rrd,rs",16,107,0x3c,
- #endif
- "div",OPC_div,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,42},
- /* 0001 1010 ssN0 dddd *** divl rqd,@rs */
- {
- #ifdef NICENAMES
- "divl rqd,@rs",32,744,0x3c,
- #endif
- "divl",OPC_divl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,43},
- /* 0101 1010 0000 dddd address_src *** divl rqd,address_src */
- {
- #ifdef NICENAMES
- "divl rqd,address_src",32,745,0x3c,
- #endif
- "divl",OPC_divl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,43},
- /* 0101 1010 ssN0 dddd address_src *** divl rqd,address_src(rs) */
- {
- #ifdef NICENAMES
- "divl rqd,address_src(rs)",32,746,0x3c,
- #endif
- "divl",OPC_divl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,43},
- /* 0001 1010 0000 dddd imm32 *** divl rqd,imm32 */
- {
- #ifdef NICENAMES
- "divl rqd,imm32",32,744,0x3c,
- #endif
- "divl",OPC_divl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_IMM+(ARG_IMM32),},
- {CLASS_BIT+1,CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM32),0,0,0,0,},2,6,43},
- /* 1001 1010 ssss dddd *** divl rqd,rrs */
- {
- #ifdef NICENAMES
- "divl rqd,rrs",32,744,0x3c,
- #endif
- "divl",OPC_divl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,43},
- /* 1111 dddd 1disp7 *** djnz rd,disp7 */
- {
- #ifdef NICENAMES
- "djnz rd,disp7",16,11,0x00,
- #endif
- "djnz",OPC_djnz,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DISP,},
- {CLASS_BIT+0xf,CLASS_REG+(ARG_RD),CLASS_1DISP7,0,0,0,0,0,0,},2,2,44},
- /* 0111 1100 0000 01ii *** ei i2 */
- {
- #ifdef NICENAMES
- "ei i2",16,7,0x00,
- #endif
- "ei",OPC_ei,0,{CLASS_IMM+(ARG_IMM2),},
- {CLASS_BIT+7,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_01II,0,0,0,0,0,},1,2,45},
- /* 0010 1101 ssN0 dddd *** ex rd,@rs */
- {
- #ifdef NICENAMES
- "ex rd,@rs",16,12,0x00,
- #endif
- "ex",OPC_ex,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,46},
- /* 0110 1101 0000 dddd address_src *** ex rd,address_src */
- {
- #ifdef NICENAMES
- "ex rd,address_src",16,15,0x00,
- #endif
- "ex",OPC_ex,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+6,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,46},
- /* 0110 1101 ssN0 dddd address_src *** ex rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "ex rd,address_src(rs)",16,16,0x00,
- #endif
- "ex",OPC_ex,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,46},
- /* 1010 1101 ssss dddd *** ex rd,rs */
- {
- #ifdef NICENAMES
- "ex rd,rs",16,6,0x00,
- #endif
- "ex",OPC_ex,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xa,CLASS_BIT+0xd,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,46},
- /* 0010 1100 ssN0 dddd *** exb rbd,@rs */
- {
- #ifdef NICENAMES
- "exb rbd,@rs",8,12,0x00,
- #endif
- "exb",OPC_exb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,47},
- /* 0110 1100 0000 dddd address_src *** exb rbd,address_src */
- {
- #ifdef NICENAMES
- "exb rbd,address_src",8,15,0x00,
- #endif
- "exb",OPC_exb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+6,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,47},
- /* 0110 1100 ssN0 dddd address_src *** exb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "exb rbd,address_src(rs)",8,16,0x00,
- #endif
- "exb",OPC_exb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,47},
- /* 1010 1100 ssss dddd *** exb rbd,rbs */
- {
- #ifdef NICENAMES
- "exb rbd,rbs",8,6,0x00,
- #endif
- "exb",OPC_exb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+0xa,CLASS_BIT+0xc,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,47},
- /* 0000 1110 imm8 *** ext0e imm8 */
- {
- #ifdef NICENAMES
- "ext0e imm8",8,10,0x00,
- #endif
- "ext0e",OPC_ext0e,0,{CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+0xe,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},1,2,48},
- /* 0000 1111 imm8 *** ext0f imm8 */
- {
- #ifdef NICENAMES
- "ext0f imm8",8,10,0x00,
- #endif
- "ext0f",OPC_ext0f,0,{CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+0xf,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},1,2,49},
- /* 1000 1110 imm8 *** ext8e imm8 */
- {
- #ifdef NICENAMES
- "ext8e imm8",8,10,0x00,
- #endif
- "ext8e",OPC_ext8e,0,{CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+8,CLASS_BIT+0xe,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},1,2,50},
- /* 1000 1111 imm8 *** ext8f imm8 */
- {
- #ifdef NICENAMES
- "ext8f imm8",8,10,0x00,
- #endif
- "ext8f",OPC_ext8f,0,{CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+8,CLASS_BIT+0xf,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},1,2,51},
- /* 1011 0001 dddd 1010 *** exts rrd */
- {
- #ifdef NICENAMES
- "exts rrd",16,11,0x00,
- #endif
- "exts",OPC_exts,0,{CLASS_REG_LONG+(ARG_RD),},
- {CLASS_BIT+0xb,CLASS_BIT+1,CLASS_REG+(ARG_RD),CLASS_BIT+0xa,0,0,0,0,0,},1,2,52},
- /* 1011 0001 dddd 0000 *** extsb rd */
- {
- #ifdef NICENAMES
- "extsb rd",8,11,0x00,
- #endif
- "extsb",OPC_extsb,0,{CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+0xb,CLASS_BIT+1,CLASS_REG+(ARG_RD),CLASS_BIT+0,0,0,0,0,0,},1,2,53},
- /* 1011 0001 dddd 0111 *** extsl rqd */
- {
- #ifdef NICENAMES
- "extsl rqd",32,11,0x00,
- #endif
- "extsl",OPC_extsl,0,{CLASS_REG_QUAD+(ARG_RD),},
- {CLASS_BIT+0xb,CLASS_BIT+1,CLASS_REG+(ARG_RD),CLASS_BIT+7,0,0,0,0,0,},1,2,54},
- /* 0111 1010 0000 0000 *** halt */
- {
- #ifdef NICENAMES
- "halt",16,8,0x00,
- #endif
- "halt",OPC_halt,0,{0},
- {CLASS_BIT+7,CLASS_BIT+0xa,CLASS_BIT+0,CLASS_BIT+0,0,0,0,0,0,},0,2,55},
- /* 0011 1101 ssss dddd *** in rd,@ri */
- {
- #ifdef NICENAMES
- "in rd,@ri",16,10,0x00,
- #endif
- "in",OPC_in,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IRO+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xd,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,56},
- /* 0011 1011 dddd 0100 imm16 *** in rd,imm16 */
- {
- #ifdef NICENAMES
- "in rd,imm16",16,12,0x00,
- #endif
- "in",OPC_in,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RD),CLASS_BIT+4,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,56},
- /* 0011 1100 ssss dddd *** inb rbd,@ri */
- {
- #ifdef NICENAMES
- "inb rbd,@ri",8,12,0x00,
- #endif
- "inb",OPC_inb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IRO+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xc,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,57},
- /* 0011 1010 dddd 0100 imm16 *** inb rbd,imm16 */
- {
- #ifdef NICENAMES
- "inb rbd,imm16",8,10,0x00,
- #endif
- "inb",OPC_inb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RD),CLASS_BIT+4,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,57},
- /* 0010 1001 ddN0 imm4m1 *** inc @rd,imm4m1 */
- {
- #ifdef NICENAMES
- "inc @rd,imm4m1",16,11,0x1c,
- #endif
- "inc",OPC_inc,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+2,CLASS_BIT+9,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,58},
- /* 0110 1001 ddN0 imm4m1 address_dst *** inc address_dst(rd),imm4m1 */
- {
- #ifdef NICENAMES
- "inc address_dst(rd),imm4m1",16,14,0x1c,
- #endif
- "inc",OPC_inc,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+9,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,58},
- /* 0110 1001 0000 imm4m1 address_dst *** inc address_dst,imm4m1 */
- {
- #ifdef NICENAMES
- "inc address_dst,imm4m1",16,13,0x1c,
- #endif
- "inc",OPC_inc,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+9,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,58},
- /* 1010 1001 dddd imm4m1 *** inc rd,imm4m1 */
- {
- #ifdef NICENAMES
- "inc rd,imm4m1",16,4,0x1c,
- #endif
- "inc",OPC_inc,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+0xa,CLASS_BIT+9,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,58},
- /* 0010 1000 ddN0 imm4m1 *** incb @rd,imm4m1 */
- {
- #ifdef NICENAMES
- "incb @rd,imm4m1",8,11,0x1c,
- #endif
- "incb",OPC_incb,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+2,CLASS_BIT+8,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,59},
- /* 0110 1000 ddN0 imm4m1 address_dst *** incb address_dst(rd),imm4m1 */
- {
- #ifdef NICENAMES
- "incb address_dst(rd),imm4m1",8,14,0x1c,
- #endif
- "incb",OPC_incb,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+8,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,59},
- /* 0110 1000 0000 imm4m1 address_dst *** incb address_dst,imm4m1 */
- {
- #ifdef NICENAMES
- "incb address_dst,imm4m1",8,13,0x1c,
- #endif
- "incb",OPC_incb,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+6,CLASS_BIT+8,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,59},
- /* 1010 1000 dddd imm4m1 *** incb rbd,imm4m1 */
- {
- #ifdef NICENAMES
- "incb rbd,imm4m1",8,4,0x1c,
- #endif
- "incb",OPC_incb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4M1),},
- {CLASS_BIT+0xa,CLASS_BIT+8,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4M1),0,0,0,0,0,},2,2,59},
- /* 0011 1011 ssss 1000 0000 aaaa ddN0 1000 *** ind @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "ind @rd,@ri,ra",16,21,0x04,
- #endif
- "ind",OPC_ind,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,60},
- /* 0011 1010 ssss 1000 0000 aaaa ddN0 1000 *** indb @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "indb @rd,@ri,ra",8,21,0x04,
- #endif
- "indb",OPC_indb,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,61},
- /* 0011 1011 ssss 1000 0000 aaaa ddN0 0000 *** indr @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "indr @rd,@ri,ra",16,11,0x04,
- #endif
- "indr",OPC_indr,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,62},
- /* 0011 1010 ssss 1000 0000 aaaa ddN0 0000 *** indrb @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "indrb @rd,@ri,ra",8,11,0x04,
- #endif
- "indrb",OPC_indrb,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,63},
- /* 0011 1011 ssss 0000 0000 aaaa ddN0 1000 *** ini @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "ini @rd,@ri,ra",16,21,0x04,
- #endif
- "ini",OPC_ini,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,64},
- /* 0011 1010 ssss 0000 0000 aaaa ddN0 1000 *** inib @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "inib @rd,@ri,ra",8,21,0x04,
- #endif
- "inib",OPC_inib,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,65},
- /* 0011 1011 ssss 0000 0000 aaaa ddN0 0000 *** inir @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "inir @rd,@ri,ra",16,11,0x04,
- #endif
- "inir",OPC_inir,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,66},
- /* 0011 1010 ssss 0000 0000 aaaa ddN0 0000 *** inirb @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "inirb @rd,@ri,ra",8,11,0x04,
- #endif
- "inirb",OPC_inirb,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,67},
- /* 0111 1011 0000 0000 *** iret */
- {
- #ifdef NICENAMES
- "iret",16,13,0x3f,
- #endif
- "iret",OPC_iret,0,{0},
- {CLASS_BIT+7,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_BIT+0,0,0,0,0,0,},0,2,68},
- /* 0001 1110 ddN0 cccc *** jp cc,@rd */
- {
- #ifdef NICENAMES
- "jp cc,@rd",16,10,0x00,
- #endif
- "jp",OPC_jp,0,{CLASS_CC,CLASS_IR+(ARG_RD),},
- {CLASS_BIT+1,CLASS_BIT+0xe,CLASS_REGN0+(ARG_RD),CLASS_CC,0,0,0,0,0,},2,2,69},
- /* 0101 1110 0000 cccc address_dst *** jp cc,address_dst */
- {
- #ifdef NICENAMES
- "jp cc,address_dst",16,7,0x00,
- #endif
- "jp",OPC_jp,0,{CLASS_CC,CLASS_DA+(ARG_DST),},
- {CLASS_BIT+5,CLASS_BIT+0xe,CLASS_BIT+0,CLASS_CC,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,69},
- /* 0101 1110 ddN0 cccc address_dst *** jp cc,address_dst(rd) */
- {
- #ifdef NICENAMES
- "jp cc,address_dst(rd)",16,8,0x00,
- #endif
- "jp",OPC_jp,0,{CLASS_CC,CLASS_X+(ARG_RD),},
- {CLASS_BIT+5,CLASS_BIT+0xe,CLASS_REGN0+(ARG_RD),CLASS_CC,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,69},
- /* 1110 cccc disp8 *** jr cc,disp8 */
- {
- #ifdef NICENAMES
- "jr cc,disp8",16,6,0x00,
- #endif
- "jr",OPC_jr,0,{CLASS_CC,CLASS_DISP,},
- {CLASS_BIT+0xe,CLASS_CC,CLASS_DISP8,0,0,0,0,0,0,},2,2,70},
- /* 0000 1101 ddN0 0101 imm16 *** ld @rd,imm16 */
- {
- #ifdef NICENAMES
- "ld @rd,imm16",16,7,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_IR+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+5,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,71},
- /* 0010 1111 ddN0 ssss *** ld @rd,rs */
- {
- #ifdef NICENAMES
- "ld @rd,rs",16,8,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_IR+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+0xf,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),0,0,0,0,0,},2,2,71},
- /* 0100 1101 ddN0 0101 address_dst imm16 *** ld address_dst(rd),imm16 */
- {
- #ifdef NICENAMES
- "ld address_dst(rd),imm16",16,15,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_X+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+5,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM16),0,0,0,},2,6,71},
- /* 0110 1111 ddN0 ssss address_dst *** ld address_dst(rd),rs */
- {
- #ifdef NICENAMES
- "ld address_dst(rd),rs",16,12,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_X+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+0xf,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,71},
- /* 0100 1101 0000 0101 address_dst imm16 *** ld address_dst,imm16 */
- {
- #ifdef NICENAMES
- "ld address_dst,imm16",16,14,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_DA+(ARG_DST),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+5,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM16),0,0,0,},2,6,71},
- /* 0110 1111 0000 ssss address_dst *** ld address_dst,rs */
- {
- #ifdef NICENAMES
- "ld address_dst,rs",16,11,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_DA+(ARG_DST),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+0xf,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,71},
- /* 0011 0011 ddN0 ssss imm16 *** ld rd(imm16),rs */
- {
- #ifdef NICENAMES
- "ld rd(imm16),rs",16,14,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_BA+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,71},
- /* 0111 0011 ddN0 ssss 0000 xxxx 0000 0000 *** ld rd(rx),rs */
- {
- #ifdef NICENAMES
- "ld rd(rx),rs",16,14,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_BX+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RX),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,71},
- /* 0010 0001 ssN0 dddd *** ld rd,@rs */
- {
- #ifdef NICENAMES
- "ld rd,@rs",16,7,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+1,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,71},
- /* 0110 0001 0000 dddd address_src *** ld rd,address_src */
- {
- #ifdef NICENAMES
- "ld rd,address_src",16,9,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+6,CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,71},
- /* 0110 0001 ssN0 dddd address_src *** ld rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "ld rd,address_src(rs)",16,10,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+1,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,71},
- /* 0010 0001 0000 dddd imm16 *** ld rd,imm16 */
- {
- #ifdef NICENAMES
- "ld rd,imm16",16,7,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+2,CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,71},
- /* 1010 0001 ssss dddd *** ld rd,rs */
- {
- #ifdef NICENAMES
- "ld rd,rs",16,3,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xa,CLASS_BIT+1,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,71},
- /* 0011 0001 ssN0 dddd imm16 *** ld rd,rs(imm16) */
- {
- #ifdef NICENAMES
- "ld rd,rs(imm16)",16,14,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_REG_WORD+(ARG_RD),CLASS_BA+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+1,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,71},
- /* 0111 0001 ssN0 dddd 0000 xxxx 0000 0000 *** ld rd,rs(rx) */
- {
- #ifdef NICENAMES
- "ld rd,rs(rx)",16,14,0x00,
- #endif
- "ld",OPC_ld,0,{CLASS_REG_WORD+(ARG_RD),CLASS_BX+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+1,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_REG+(ARG_RX),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,71},
- /* 0111 0110 0000 dddd address_src *** lda prd,address_src */
- {
- #ifdef NICENAMES
- "lda prd,address_src",16,12,0x00,
- #endif
- "lda",OPC_lda,0,{CLASS_PR+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+7,CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,72},
- /* 0111 0110 ssN0 dddd address_src *** lda prd,address_src(rs) */
- {
- #ifdef NICENAMES
- "lda prd,address_src(rs)",16,13,0x00,
- #endif
- "lda",OPC_lda,0,{CLASS_PR+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+6,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,72},
- /* 0011 0100 ssN0 dddd imm16 *** lda prd,rs(imm16) */
- {
- #ifdef NICENAMES
- "lda prd,rs(imm16)",16,15,0x00,
- #endif
- "lda",OPC_lda,0,{CLASS_PR+(ARG_RD),CLASS_BA+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+4,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,72},
- /* 0111 0100 ssN0 dddd 0000 xxxx 0000 0000 *** lda prd,rs(rx) */
- {
- #ifdef NICENAMES
- "lda prd,rs(rx)",16,15,0x00,
- #endif
- "lda",OPC_lda,0,{CLASS_PR+(ARG_RD),CLASS_BX+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+4,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_REG+(ARG_RX),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,72},
- /* 0011 0100 0000 dddd disp16 *** ldar prd,disp16 */
- {
- #ifdef NICENAMES
- "ldar prd,disp16",16,15,0x00,
- #endif
- "ldar",OPC_ldar,0,{CLASS_PR+(ARG_RD),CLASS_DISP,},
- {CLASS_BIT+3,CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_DISP+(ARG_DISP16),0,0,0,0,},2,4,73},
- /* 0000 1100 ddN0 0101 imm8 imm8 *** ldb @rd,imm8 */
- {
- #ifdef NICENAMES
- "ldb @rd,imm8",8,7,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_IR+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+5,CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,74},
- /* 0010 1110 ddN0 ssss *** ldb @rd,rbs */
- {
- #ifdef NICENAMES
- "ldb @rd,rbs",8,8,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_IR+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+0xe,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),0,0,0,0,0,},2,2,74},
- /* 0100 1100 ddN0 0101 address_dst imm8 imm8 *** ldb address_dst(rd),imm8 */
- {
- #ifdef NICENAMES
- "ldb address_dst(rd),imm8",8,15,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_X+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+5,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,},2,6,74},
- /* 0110 1110 ddN0 ssss address_dst *** ldb address_dst(rd),rbs */
- {
- #ifdef NICENAMES
- "ldb address_dst(rd),rbs",8,12,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_X+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+0xe,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,74},
- /* 0100 1100 0000 0101 address_dst imm8 imm8 *** ldb address_dst,imm8 */
- {
- #ifdef NICENAMES
- "ldb address_dst,imm8",8,14,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_DA+(ARG_DST),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+5,CLASS_ADDRESS+(ARG_DST),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,},2,6,74},
- /* 0110 1110 0000 ssss address_dst *** ldb address_dst,rbs */
- {
- #ifdef NICENAMES
- "ldb address_dst,rbs",8,11,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_DA+(ARG_DST),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+0xe,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,74},
- /* 0010 0000 ssN0 dddd *** ldb rbd,@rs */
- {
- #ifdef NICENAMES
- "ldb rbd,@rs",8,7,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,74},
- /* 0110 0000 0000 dddd address_src *** ldb rbd,address_src */
- {
- #ifdef NICENAMES
- "ldb rbd,address_src",8,9,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+6,CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,74},
- /* 0110 0000 ssN0 dddd address_src *** ldb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "ldb rbd,address_src(rs)",8,10,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+6,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,74},
- /* 1100 dddd imm8 *** ldb rbd,imm8 */
- {
- #ifdef NICENAMES
- "ldb rbd,imm8",8,5,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},2,2,74},
- /* 0010 0000 0000 dddd imm8 imm8 *** ldb rbd,imm8 */
- {
- #ifdef NICENAMES
- "ldb rbd,imm8",8,7,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+2,CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,74},
- /* 1010 0000 ssss dddd *** ldb rbd,rbs */
- {
- #ifdef NICENAMES
- "ldb rbd,rbs",8,3,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,74},
- /* 0011 0000 ssN0 dddd imm16 *** ldb rbd,rs(imm16) */
- {
- #ifdef NICENAMES
- "ldb rbd,rs(imm16)",8,14,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_BA+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,74},
- /* 0111 0000 ssN0 dddd 0000 xxxx 0000 0000 *** ldb rbd,rs(rx) */
- {
- #ifdef NICENAMES
- "ldb rbd,rs(rx)",8,14,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_BX+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+0,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_REG+(ARG_RX),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,74},
- /* 0011 0010 ddN0 ssss imm16 *** ldb rd(imm16),rbs */
- {
- #ifdef NICENAMES
- "ldb rd(imm16),rbs",8,14,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_BA+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+2,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,74},
- /* 0111 0010 ddN0 ssss 0000 xxxx 0000 0000 *** ldb rd(rx),rbs */
- {
- #ifdef NICENAMES
- "ldb rd(rx),rbs",8,14,0x00,
- #endif
- "ldb",OPC_ldb,0,{CLASS_BX+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+2,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RX),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,74},
- /* 0111 1101 ssss 1ccc *** ldctl ctrl,rs */
- {
- #ifdef NICENAMES
- "ldctl ctrl,rs",32,7,0x00,
- #endif
- "ldctl",OPC_ldctl,0,{CLASS_CTRL,CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+0xd,CLASS_REG+(ARG_RS),CLASS_1CCC,0,0,0,0,0,},2,2,75},
- /* 0111 1101 dddd 0ccc *** ldctl rd,ctrl */
- {
- #ifdef NICENAMES
- "ldctl rd,ctrl",32,7,0x00,
- #endif
- "ldctl",OPC_ldctl,0,{CLASS_REG_WORD+(ARG_RD),CLASS_CTRL,},
- {CLASS_BIT+7,CLASS_BIT+0xd,CLASS_REG+(ARG_RD),CLASS_0CCC,0,0,0,0,0,},2,2,75},
- /* 1000 1100 ssss 1001 *** ldctlb ctrl,rbs */
- {
- #ifdef NICENAMES
- "ldctlb ctrl,rbs",32,7,0x3f,
- #endif
- "ldctlb",OPC_ldctlb,0,{CLASS_CTRL,CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+0xc,CLASS_REG+(ARG_RS),CLASS_BIT+9,0,0,0,0,0,},2,2,76},
- /* 1000 1100 dddd 0001 *** ldctlb rbd,ctrl */
- {
- #ifdef NICENAMES
- "ldctlb rbd,ctrl",32,7,0x00,
- #endif
- "ldctlb",OPC_ldctlb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_CTRL,},
- {CLASS_BIT+8,CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_BIT+1,0,0,0,0,0,},2,2,76},
- /* 1011 1011 ssN0 1001 0000 rrrr ddN0 1000 *** ldd @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "ldd @rd,@rs,rr",16,11,0x04,
- #endif
- "ldd",OPC_ldd,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,77},
- /* 1011 1010 ssN0 1001 0000 rrrr ddN0 1000 *** lddb @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "lddb @rd,@rs,rr",8,11,0x04,
- #endif
- "lddb",OPC_lddb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,78},
- /* 1011 1011 ssN0 1001 0000 rrrr ddN0 0000 *** lddr @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "lddr @rd,@rs,rr",16,11,0x04,
- #endif
- "lddr",OPC_lddr,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,79},
- /* 1011 1010 ssN0 1001 0000 rrrr ddN0 0000 *** lddrb @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "lddrb @rd,@rs,rr",8,11,0x04,
- #endif
- "lddrb",OPC_lddrb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,80},
- /* 1011 1011 ssN0 0001 0000 rrrr ddN0 1000 *** ldi @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "ldi @rd,@rs,rr",16,11,0x04,
- #endif
- "ldi",OPC_ldi,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,81},
- /* 1011 1010 ssN0 0001 0000 rrrr ddN0 1000 *** ldib @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "ldib @rd,@rs,rr",8,11,0x04,
- #endif
- "ldib",OPC_ldib,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,82},
- /* 1011 1011 ssN0 0001 0000 rrrr ddN0 0000 *** ldir @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "ldir @rd,@rs,rr",16,11,0x04,
- #endif
- "ldir",OPC_ldir,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,83},
- /* 1011 1010 ssN0 0001 0000 rrrr ddN0 0000 *** ldirb @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "ldirb @rd,@rs,rr",8,11,0x04,
- #endif
- "ldirb",OPC_ldirb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,84},
- /* 1011 1101 dddd imm4 *** ldk rd,imm4 */
- {
- #ifdef NICENAMES
- "ldk rd,imm4",16,5,0x00,
- #endif
- "ldk",OPC_ldk,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xb,CLASS_BIT+0xd,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,85},
- /* 0001 1101 ddN0 ssss *** ldl @rd,rrs */
- {
- #ifdef NICENAMES
- "ldl @rd,rrs",32,11,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_IR+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),0,0,0,0,0,},2,2,86},
- /* 0101 1101 ddN0 ssss address_dst *** ldl address_dst(rd),rrs */
- {
- #ifdef NICENAMES
- "ldl address_dst(rd),rrs",32,14,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_X+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,86},
- /* 0101 1101 0000 ssss address_dst *** ldl address_dst,rrs */
- {
- #ifdef NICENAMES
- "ldl address_dst,rrs",32,15,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_DA+(ARG_DST),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,86},
- /* 0011 0111 ddN0 ssss imm16 *** ldl rd(imm16),rrs */
- {
- #ifdef NICENAMES
- "ldl rd(imm16),rrs",32,17,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_BA+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+7,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,86},
- /* 0111 0111 ddN0 ssss 0000 xxxx 0000 0000 *** ldl rd(rx),rrs */
- {
- #ifdef NICENAMES
- "ldl rd(rx),rrs",32,17,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_BX+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+7,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RX),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,86},
- /* 0001 0100 ssN0 dddd *** ldl rrd,@rs */
- {
- #ifdef NICENAMES
- "ldl rrd,@rs",32,11,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+4,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,86},
- /* 0101 0100 0000 dddd address_src *** ldl rrd,address_src */
- {
- #ifdef NICENAMES
- "ldl rrd,address_src",32,12,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,86},
- /* 0101 0100 ssN0 dddd address_src *** ldl rrd,address_src(rs) */
- {
- #ifdef NICENAMES
- "ldl rrd,address_src(rs)",32,13,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+4,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,86},
- /* 0001 0100 0000 dddd imm32 *** ldl rrd,imm32 */
- {
- #ifdef NICENAMES
- "ldl rrd,imm32",32,11,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM32),},
- {CLASS_BIT+1,CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM32),0,0,0,0,},2,6,86},
- /* 1001 0100 ssss dddd *** ldl rrd,rrs */
- {
- #ifdef NICENAMES
- "ldl rrd,rrs",32,5,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+4,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,86},
- /* 0011 0101 ssN0 dddd imm16 *** ldl rrd,rs(imm16) */
- {
- #ifdef NICENAMES
- "ldl rrd,rs(imm16)",32,17,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_BA+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,86},
- /* 0111 0101 ssN0 dddd 0000 xxxx 0000 0000 *** ldl rrd,rs(rx) */
- {
- #ifdef NICENAMES
- "ldl rrd,rs(rx)",32,17,0x00,
- #endif
- "ldl",OPC_ldl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_BX+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_REG+(ARG_RX),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,86},
- /* 0001 1100 ddN0 1001 0000 ssss 0000 imm4m1 *** ldm @rd,rs,n */
- {
- #ifdef NICENAMES
- "ldm @rd,rs,n",16,11,0x00,
- #endif
- "ldm",OPC_ldm,0,{CLASS_IR+(ARG_RD),CLASS_REG_WORD+(ARG_RS),CLASS_IMM + (ARG_IMM4M1),},
- {CLASS_BIT+1,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),0,},3,4,87},
- /* 0101 1100 ddN0 1001 0000 ssss 0000 imm4m1 address_dst *** ldm address_dst(rd),rs,n */
- {
- #ifdef NICENAMES
- "ldm address_dst(rd),rs,n",16,15,0x00,
- #endif
- "ldm",OPC_ldm,0,{CLASS_X+(ARG_RD),CLASS_REG_WORD+(ARG_RS),CLASS_IMM + (ARG_IMM4M1),},
- {CLASS_BIT+5,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),},3,6,87},
- /* 0101 1100 0000 1001 0000 ssss 0000 imm4m1 address_dst *** ldm address_dst,rs,n */
- {
- #ifdef NICENAMES
- "ldm address_dst,rs,n",16,14,0x00,
- #endif
- "ldm",OPC_ldm,0,{CLASS_DA+(ARG_DST),CLASS_REG_WORD+(ARG_RS),CLASS_IMM + (ARG_IMM4M1),},
- {CLASS_BIT+5,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_DST),},3,6,87},
- /* 0001 1100 ssN0 0001 0000 dddd 0000 imm4m1 *** ldm rd,@rs,n */
- {
- #ifdef NICENAMES
- "ldm rd,@rs,n",16,11,0x00,
- #endif
- "ldm",OPC_ldm,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_IMM + (ARG_IMM4M1),},
- {CLASS_BIT+1,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),0,},3,4,87},
- /* 0101 1100 ssN0 0001 0000 dddd 0000 imm4m1 address_src *** ldm rd,address_src(rs),n */
- {
- #ifdef NICENAMES
- "ldm rd,address_src(rs),n",16,15,0x00,
- #endif
- "ldm",OPC_ldm,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),CLASS_IMM + (ARG_IMM4M1),},
- {CLASS_BIT+5,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_SRC),},3,6,87},
- /* 0101 1100 0000 0001 0000 dddd 0000 imm4m1 address_src *** ldm rd,address_src,n */
- {
- #ifdef NICENAMES
- "ldm rd,address_src,n",16,14,0x00,
- #endif
- "ldm",OPC_ldm,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),CLASS_IMM + (ARG_IMM4M1),},
- {CLASS_BIT+5,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_IMM+(ARG_IMM4M1),CLASS_ADDRESS+(ARG_SRC),},3,6,87},
- /* 0011 1001 ssN0 0000 *** ldps @rs */
- {
- #ifdef NICENAMES
- "ldps @rs",16,12,0x3f,
- #endif
- "ldps",OPC_ldps,0,{CLASS_IR+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+9,CLASS_REGN0+(ARG_RS),CLASS_BIT+0,0,0,0,0,0,},1,2,88},
- /* 0111 1001 0000 0000 address_src *** ldps address_src */
- {
- #ifdef NICENAMES
- "ldps address_src",16,16,0x3f,
- #endif
- "ldps",OPC_ldps,0,{CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+7,CLASS_BIT+9,CLASS_BIT+0,CLASS_BIT+0,CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},1,4,88},
- /* 0111 1001 ssN0 0000 address_src *** ldps address_src(rs) */
- {
- #ifdef NICENAMES
- "ldps address_src(rs)",16,17,0x3f,
- #endif
- "ldps",OPC_ldps,0,{CLASS_X+(ARG_RS),},
- {CLASS_BIT+7,CLASS_BIT+9,CLASS_REGN0+(ARG_RS),CLASS_BIT+0,CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},1,4,88},
- /* 0011 0011 0000 ssss disp16 *** ldr disp16,rs */
- {
- #ifdef NICENAMES
- "ldr disp16,rs",16,14,0x00,
- #endif
- "ldr",OPC_ldr,0,{CLASS_DISP,CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_DISP+(ARG_DISP16),0,0,0,0,},2,4,89},
- /* 0011 0001 0000 dddd disp16 *** ldr rd,disp16 */
- {
- #ifdef NICENAMES
- "ldr rd,disp16",16,14,0x00,
- #endif
- "ldr",OPC_ldr,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DISP,},
- {CLASS_BIT+3,CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_DISP+(ARG_DISP16),0,0,0,0,},2,4,89},
- /* 0011 0010 0000 ssss disp16 *** ldrb disp16,rbs */
- {
- #ifdef NICENAMES
- "ldrb disp16,rbs",8,14,0x00,
- #endif
- "ldrb",OPC_ldrb,0,{CLASS_DISP,CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_DISP+(ARG_DISP16),0,0,0,0,},2,4,90},
- /* 0011 0000 0000 dddd disp16 *** ldrb rbd,disp16 */
- {
- #ifdef NICENAMES
- "ldrb rbd,disp16",8,14,0x00,
- #endif
- "ldrb",OPC_ldrb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DISP,},
- {CLASS_BIT+3,CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_DISP+(ARG_DISP16),0,0,0,0,},2,4,90},
- /* 0011 0111 0000 ssss disp16 *** ldrl disp16,rrs */
- {
- #ifdef NICENAMES
- "ldrl disp16,rrs",32,17,0x00,
- #endif
- "ldrl",OPC_ldrl,0,{CLASS_DISP,CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+7,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_DISP+(ARG_DISP16),0,0,0,0,},2,4,91},
- /* 0011 0101 0000 dddd disp16 *** ldrl rrd,disp16 */
- {
- #ifdef NICENAMES
- "ldrl rrd,disp16",32,17,0x00,
- #endif
- "ldrl",OPC_ldrl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_DISP,},
- {CLASS_BIT+3,CLASS_BIT+5,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_DISP+(ARG_DISP16),0,0,0,0,},2,4,91},
- /* 0111 1011 0000 1010 *** mbit */
- {
- #ifdef NICENAMES
- "mbit",16,7,0x38,
- #endif
- "mbit",OPC_mbit,0,{0},
- {CLASS_BIT+7,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_BIT+0xa,0,0,0,0,0,},0,2,92},
- /* 0111 1011 dddd 1101 *** mreq rd */
- {
- #ifdef NICENAMES
- "mreq rd",16,12,0x18,
- #endif
- "mreq",OPC_mreq,0,{CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+7,CLASS_BIT+0xb,CLASS_REG+(ARG_RD),CLASS_BIT+0xd,0,0,0,0,0,},1,2,93},
- /* 0111 1011 0000 1001 *** mres */
- {
- #ifdef NICENAMES
- "mres",16,5,0x00,
- #endif
- "mres",OPC_mres,0,{0},
- {CLASS_BIT+7,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_BIT+9,0,0,0,0,0,},0,2,94},
- /* 0111 1011 0000 1000 *** mset */
- {
- #ifdef NICENAMES
- "mset",16,5,0x00,
- #endif
- "mset",OPC_mset,0,{0},
- {CLASS_BIT+7,CLASS_BIT+0xb,CLASS_BIT+0,CLASS_BIT+8,0,0,0,0,0,},0,2,95},
- /* 0001 1001 ssN0 dddd *** mult rrd,@rs */
- {
- #ifdef NICENAMES
- "mult rrd,@rs",16,70,0x3c,
- #endif
- "mult",OPC_mult,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+9,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,96},
- /* 0101 1001 0000 dddd address_src *** mult rrd,address_src */
- {
- #ifdef NICENAMES
- "mult rrd,address_src",16,70,0x3c,
- #endif
- "mult",OPC_mult,0,{CLASS_REG_LONG+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,96},
- /* 0101 1001 ssN0 dddd address_src *** mult rrd,address_src(rs) */
- {
- #ifdef NICENAMES
- "mult rrd,address_src(rs)",16,70,0x3c,
- #endif
- "mult",OPC_mult,0,{CLASS_REG_LONG+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+9,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,96},
- /* 0001 1001 0000 dddd imm16 *** mult rrd,imm16 */
- {
- #ifdef NICENAMES
- "mult rrd,imm16",16,70,0x3c,
- #endif
- "mult",OPC_mult,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+1,CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,96},
- /* 1001 1001 ssss dddd *** mult rrd,rs */
- {
- #ifdef NICENAMES
- "mult rrd,rs",16,70,0x3c,
- #endif
- "mult",OPC_mult,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+9,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,96},
- /* 0001 1000 ssN0 dddd *** multl rqd,@rs */
- {
- #ifdef NICENAMES
- "multl rqd,@rs",32,282,0x3c,
- #endif
- "multl",OPC_multl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+8,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,97},
- /* 0101 1000 0000 dddd address_src *** multl rqd,address_src */
- {
- #ifdef NICENAMES
- "multl rqd,address_src",32,282,0x3c,
- #endif
- "multl",OPC_multl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,97},
- /* 0101 1000 ssN0 dddd address_src *** multl rqd,address_src(rs) */
- {
- #ifdef NICENAMES
- "multl rqd,address_src(rs)",32,282,0x3c,
- #endif
- "multl",OPC_multl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+8,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,97},
- /* 0001 1000 0000 dddd imm32 *** multl rqd,imm32 */
- {
- #ifdef NICENAMES
- "multl rqd,imm32",32,282,0x3c,
- #endif
- "multl",OPC_multl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_IMM+(ARG_IMM32),},
- {CLASS_BIT+1,CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM32),0,0,0,0,},2,6,97},
- /* 1001 1000 ssss dddd *** multl rqd,rrs */
- {
- #ifdef NICENAMES
- "multl rqd,rrs",32,282,0x3c,
- #endif
- "multl",OPC_multl,0,{CLASS_REG_QUAD+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+8,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,97},
- /* 0000 1101 ddN0 0010 *** neg @rd */
- {
- #ifdef NICENAMES
- "neg @rd",16,12,0x3c,
- #endif
- "neg",OPC_neg,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+2,0,0,0,0,0,},1,2,98},
- /* 0100 1101 0000 0010 address_dst *** neg address_dst */
- {
- #ifdef NICENAMES
- "neg address_dst",16,15,0x3c,
- #endif
- "neg",OPC_neg,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+2,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,98},
- /* 0100 1101 ddN0 0010 address_dst *** neg address_dst(rd) */
- {
- #ifdef NICENAMES
- "neg address_dst(rd)",16,16,0x3c,
- #endif
- "neg",OPC_neg,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+2,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,98},
- /* 1000 1101 dddd 0010 *** neg rd */
- {
- #ifdef NICENAMES
- "neg rd",16,7,0x3c,
- #endif
- "neg",OPC_neg,0,{CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_REG+(ARG_RD),CLASS_BIT+2,0,0,0,0,0,},1,2,98},
- /* 0000 1100 ddN0 0010 *** negb @rd */
- {
- #ifdef NICENAMES
- "negb @rd",8,12,0x3c,
- #endif
- "negb",OPC_negb,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+2,0,0,0,0,0,},1,2,99},
- /* 0100 1100 0000 0010 address_dst *** negb address_dst */
- {
- #ifdef NICENAMES
- "negb address_dst",8,15,0x3c,
- #endif
- "negb",OPC_negb,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+2,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,99},
- /* 0100 1100 ddN0 0010 address_dst *** negb address_dst(rd) */
- {
- #ifdef NICENAMES
- "negb address_dst(rd)",8,16,0x3c,
- #endif
- "negb",OPC_negb,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+2,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,99},
- /* 1000 1100 dddd 0010 *** negb rbd */
- {
- #ifdef NICENAMES
- "negb rbd",8,7,0x3c,
- #endif
- "negb",OPC_negb,0,{CLASS_REG_BYTE+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_BIT+2,0,0,0,0,0,},1,2,99},
- /* 1000 1101 0000 0111 *** nop */
- {
- #ifdef NICENAMES
- "nop",16,7,0x00,
- #endif
- "nop",OPC_nop,0,{0},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+7,0,0,0,0,0,},0,2,100},
- /* 0000 0101 ssN0 dddd *** or rd,@rs */
- {
- #ifdef NICENAMES
- "or rd,@rs",16,7,0x38,
- #endif
- "or",OPC_or,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,101},
- /* 0100 0101 0000 dddd address_src *** or rd,address_src */
- {
- #ifdef NICENAMES
- "or rd,address_src",16,9,0x38,
- #endif
- "or",OPC_or,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+5,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,101},
- /* 0100 0101 ssN0 dddd address_src *** or rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "or rd,address_src(rs)",16,10,0x38,
- #endif
- "or",OPC_or,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,101},
- /* 0000 0101 0000 dddd imm16 *** or rd,imm16 */
- {
- #ifdef NICENAMES
- "or rd,imm16",16,7,0x38,
- #endif
- "or",OPC_or,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+5,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,101},
- /* 1000 0101 ssss dddd *** or rd,rs */
- {
- #ifdef NICENAMES
- "or rd,rs",16,4,0x38,
- #endif
- "or",OPC_or,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+5,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,101},
- /* 0000 0100 ssN0 dddd *** orb rbd,@rs */
- {
- #ifdef NICENAMES
- "orb rbd,@rs",8,7,0x3c,
- #endif
- "orb",OPC_orb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+4,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,102},
- /* 0100 0100 0000 dddd address_src *** orb rbd,address_src */
- {
- #ifdef NICENAMES
- "orb rbd,address_src",8,9,0x3c,
- #endif
- "orb",OPC_orb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,102},
- /* 0100 0100 ssN0 dddd address_src *** orb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "orb rbd,address_src(rs)",8,10,0x3c,
- #endif
- "orb",OPC_orb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+4,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,102},
- /* 0000 0100 0000 dddd imm8 imm8 *** orb rbd,imm8 */
- {
- #ifdef NICENAMES
- "orb rbd,imm8",8,7,0x3c,
- #endif
- "orb",OPC_orb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,102},
- /* 1000 0100 ssss dddd *** orb rbd,rbs */
- {
- #ifdef NICENAMES
- "orb rbd,rbs",8,4,0x3c,
- #endif
- "orb",OPC_orb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+4,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,102},
- /* 0011 1011 ssN0 1010 0000 aaaa dddd 0000 *** otdr @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "otdr @ro,@rs,ra",16,11,0x04,
- #endif
- "otdr",OPC_otdr,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,103},
- /* 0011 1010 ssN0 1010 0000 aaaa dddd 0000 *** otdrb @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "otdrb @ro,@rs,ra",8,11,0x04,
- #endif
- "otdrb",OPC_otdrb,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,104},
- /* 0011 1011 ssN0 0010 0000 aaaa dddd 0000 *** otir @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "otir @ro,@rs,ra",16,11,0x04,
- #endif
- "otir",OPC_otir,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,105},
- /* 0011 1010 ssN0 0010 0000 aaaa dddd 0000 *** otirb @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "otirb @ro,@rs,ra",8,11,0x04,
- #endif
- "otirb",OPC_otirb,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,106},
- /* 0011 1111 dddd ssss *** out @ro,rs */
- {
- #ifdef NICENAMES
- "out @ro,rs",16,10,0x00,
- #endif
- "out",OPC_out,0,{CLASS_IRO+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xf,CLASS_REG+(ARG_RD),CLASS_REG+(ARG_RS),0,0,0,0,0,},2,2,107},
- /* 0011 1011 ssss 0110 imm16 *** out imm16,rs */
- {
- #ifdef NICENAMES
- "out imm16,rs",16,12,0x00,
- #endif
- "out",OPC_out,0,{CLASS_IMM+(ARG_IMM16),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+6,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,107},
- /* 0011 1110 dddd ssss *** outb @ro,rbs */
- {
- #ifdef NICENAMES
- "outb @ro,rbs",8,10,0x00,
- #endif
- "outb",OPC_outb,0,{CLASS_IRO+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xe,CLASS_REG+(ARG_RD),CLASS_REG+(ARG_RS),0,0,0,0,0,},2,2,108},
- /* 0011 1010 ssss 0110 imm16 *** outb imm16,rbs */
- {
- #ifdef NICENAMES
- "outb imm16,rbs",8,12,0x00,
- #endif
- "outb",OPC_outb,0,{CLASS_IMM+(ARG_IMM16),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+6,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,108},
- /* 0011 1011 ssN0 1010 0000 aaaa dddd 1000 *** outd @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "outd @ro,@rs,ra",16,21,0x04,
- #endif
- "outd",OPC_outd,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,109},
- /* 0011 1010 ssN0 1010 0000 aaaa dddd 1000 *** outdb @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "outdb @ro,@rs,ra",8,21,0x04,
- #endif
- "outdb",OPC_outdb,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,110},
- /* 0011 1011 ssN0 0010 0000 aaaa dddd 1000 *** outi @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "outi @ro,@rs,ra",16,21,0x04,
- #endif
- "outi",OPC_outi,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,111},
- /* 0011 1010 ssN0 0010 0000 aaaa dddd 1000 *** outib @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "outib @ro,@rs,ra",8,21,0x04,
- #endif
- "outib",OPC_outib,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,112},
- /* 0001 0111 ssN0 ddN0 *** pop @rd,@rs */
- {
- #ifdef NICENAMES
- "pop @rd,@rs",16,12,0x00,
- #endif
- "pop",OPC_pop,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+7,CLASS_REGN0+(ARG_RS),CLASS_REGN0+(ARG_RD),0,0,0,0,0,},2,2,113},
- /* 0101 0111 ssN0 ddN0 address_dst *** pop address_dst(rd),@rs */
- {
- #ifdef NICENAMES
- "pop address_dst(rd),@rs",16,16,0x00,
- #endif
- "pop",OPC_pop,0,{CLASS_X+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+7,CLASS_REGN0+(ARG_RS),CLASS_REGN0+(ARG_RD),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,113},
- /* 0101 0111 ssN0 0000 address_dst *** pop address_dst,@rs */
- {
- #ifdef NICENAMES
- "pop address_dst,@rs",16,16,0x00,
- #endif
- "pop",OPC_pop,0,{CLASS_DA+(ARG_DST),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+7,CLASS_REGN0+(ARG_RS),CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,113},
- /* 1001 0111 ssN0 dddd *** pop rd,@rs */
- {
- #ifdef NICENAMES
- "pop rd,@rs",16,8,0x00,
- #endif
- "pop",OPC_pop,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+7,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,113},
- /* 0001 0101 ssN0 ddN0 *** popl @rd,@rs */
- {
- #ifdef NICENAMES
- "popl @rd,@rs",32,19,0x00,
- #endif
- "popl",OPC_popl,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_REGN0+(ARG_RD),0,0,0,0,0,},2,2,114},
- /* 0101 0101 ssN0 ddN0 address_dst *** popl address_dst(rd),@rs */
- {
- #ifdef NICENAMES
- "popl address_dst(rd),@rs",32,23,0x00,
- #endif
- "popl",OPC_popl,0,{CLASS_X+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_REGN0+(ARG_RD),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,114},
- /* 0101 0101 ssN0 0000 address_dst *** popl address_dst,@rs */
- {
- #ifdef NICENAMES
- "popl address_dst,@rs",32,23,0x00,
- #endif
- "popl",OPC_popl,0,{CLASS_DA+(ARG_DST),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_BIT+0,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,114},
- /* 1001 0101 ssN0 dddd *** popl rrd,@rs */
- {
- #ifdef NICENAMES
- "popl rrd,@rs",32,12,0x00,
- #endif
- "popl",OPC_popl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+5,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,114},
- /* 0001 0011 ddN0 ssN0 *** push @rd,@rs */
- {
- #ifdef NICENAMES
- "push @rd,@rs",16,13,0x00,
- #endif
- "push",OPC_push,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_REGN0+(ARG_RS),0,0,0,0,0,},2,2,115},
- /* 0101 0011 ddN0 0000 address_src *** push @rd,address_src */
- {
- #ifdef NICENAMES
- "push @rd,address_src",16,14,0x00,
- #endif
- "push",OPC_push,0,{CLASS_IR+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,115},
- /* 0101 0011 ddN0 ssN0 address_src *** push @rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "push @rd,address_src(rs)",16,14,0x00,
- #endif
- "push",OPC_push,0,{CLASS_IR+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_REGN0+(ARG_RS),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,115},
- /* 0000 1101 ddN0 1001 imm16 *** push @rd,imm16 */
- {
- #ifdef NICENAMES
- "push @rd,imm16",16,12,0x00,
- #endif
- "push",OPC_push,0,{CLASS_IR+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+9,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,115},
- /* 1001 0011 ddN0 ssss *** push @rd,rs */
- {
- #ifdef NICENAMES
- "push @rd,rs",16,9,0x00,
- #endif
- "push",OPC_push,0,{CLASS_IR+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),0,0,0,0,0,},2,2,115},
- /* 0001 0001 ddN0 ssN0 *** pushl @rd,@rs */
- {
- #ifdef NICENAMES
- "pushl @rd,@rs",32,20,0x00,
- #endif
- "pushl",OPC_pushl,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+1,CLASS_REGN0+(ARG_RD),CLASS_REGN0+(ARG_RS),0,0,0,0,0,},2,2,116},
- /* 0101 0001 ddN0 0000 address_src *** pushl @rd,address_src */
- {
- #ifdef NICENAMES
- "pushl @rd,address_src",32,21,0x00,
- #endif
- "pushl",OPC_pushl,0,{CLASS_IR+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+1,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,116},
- /* 0101 0001 ddN0 ssN0 address_src *** pushl @rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "pushl @rd,address_src(rs)",32,21,0x00,
- #endif
- "pushl",OPC_pushl,0,{CLASS_IR+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+1,CLASS_REGN0+(ARG_RD),CLASS_REGN0+(ARG_RS),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,116},
- /* 1001 0001 ddN0 ssss *** pushl @rd,rrs */
- {
- #ifdef NICENAMES
- "pushl @rd,rrs",32,12,0x00,
- #endif
- "pushl",OPC_pushl,0,{CLASS_IR+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+1,CLASS_REGN0+(ARG_RD),CLASS_REG+(ARG_RS),0,0,0,0,0,},2,2,116},
- /* 0010 0011 ddN0 imm4 *** res @rd,imm4 */
- {
- #ifdef NICENAMES
- "res @rd,imm4",16,11,0x00,
- #endif
- "res",OPC_res,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+2,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,117},
- /* 0110 0011 ddN0 imm4 address_dst *** res address_dst(rd),imm4 */
- {
- #ifdef NICENAMES
- "res address_dst(rd),imm4",16,14,0x00,
- #endif
- "res",OPC_res,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+3,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,117},
- /* 0110 0011 0000 imm4 address_dst *** res address_dst,imm4 */
- {
- #ifdef NICENAMES
- "res address_dst,imm4",16,13,0x00,
- #endif
- "res",OPC_res,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+3,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,117},
- /* 1010 0011 dddd imm4 *** res rd,imm4 */
- {
- #ifdef NICENAMES
- "res rd,imm4",16,4,0x00,
- #endif
- "res",OPC_res,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xa,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,117},
- /* 0010 0011 0000 ssss 0000 dddd 0000 0000 *** res rd,rs */
- {
- #ifdef NICENAMES
- "res rd,rs",16,10,0x00,
- #endif
- "res",OPC_res,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,117},
- /* 0010 0010 ddN0 imm4 *** resb @rd,imm4 */
- {
- #ifdef NICENAMES
- "resb @rd,imm4",8,11,0x00,
- #endif
- "resb",OPC_resb,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+2,CLASS_BIT+2,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,118},
- /* 0110 0010 ddN0 imm4 address_dst *** resb address_dst(rd),imm4 */
- {
- #ifdef NICENAMES
- "resb address_dst(rd),imm4",8,14,0x00,
- #endif
- "resb",OPC_resb,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+2,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,118},
- /* 0110 0010 0000 imm4 address_dst *** resb address_dst,imm4 */
- {
- #ifdef NICENAMES
- "resb address_dst,imm4",8,13,0x00,
- #endif
- "resb",OPC_resb,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+2,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,118},
- /* 1010 0010 dddd imm4 *** resb rbd,imm4 */
- {
- #ifdef NICENAMES
- "resb rbd,imm4",8,4,0x00,
- #endif
- "resb",OPC_resb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xa,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,118},
- /* 0010 0010 0000 ssss 0000 dddd 0000 0000 *** resb rbd,rs */
- {
- #ifdef NICENAMES
- "resb rbd,rs",8,10,0x00,
- #endif
- "resb",OPC_resb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,118},
- /* 1000 1101 flags 0011 *** resflg flags */
- {
- #ifdef NICENAMES
- "resflg flags",16,7,0x3c,
- #endif
- "resflg",OPC_resflg,0,{CLASS_FLAGS,},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_FLAGS,CLASS_BIT+3,0,0,0,0,0,},1,2,119},
- /* 1001 1110 0000 cccc *** ret cc */
- {
- #ifdef NICENAMES
- "ret cc",16,10,0x00,
- #endif
- "ret",OPC_ret,0,{CLASS_CC,},
- {CLASS_BIT+9,CLASS_BIT+0xe,CLASS_BIT+0,CLASS_CC,0,0,0,0,0,},1,2,120},
- /* 1011 0011 dddd 00I0 *** rl rd,imm1or2 */
- {
- #ifdef NICENAMES
- "rl rd,imm1or2",16,6,0x3c,
- #endif
- "rl",OPC_rl,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+0,0,0,0,0,0,},2,2,121},
- /* 1011 0010 dddd 00I0 *** rlb rbd,imm1or2 */
- {
- #ifdef NICENAMES
- "rlb rbd,imm1or2",8,6,0x3c,
- #endif
- "rlb",OPC_rlb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+0,0,0,0,0,0,},2,2,122},
- /* 1011 0011 dddd 10I0 *** rlc rd,imm1or2 */
- {
- #ifdef NICENAMES
- "rlc rd,imm1or2",16,6,0x3c,
- #endif
- "rlc",OPC_rlc,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+8,0,0,0,0,0,},2,2,123},
- /* 1011 0010 dddd 10I0 *** rlcb rbd,imm1or2 */
- {
- #ifdef NICENAMES
- "rlcb rbd,imm1or2",8,9,0x10,
- #endif
- "rlcb",OPC_rlcb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+8,0,0,0,0,0,},2,2,124},
- /* 1011 1110 aaaa bbbb *** rldb rbb,rba */
- {
- #ifdef NICENAMES
- "rldb rbb,rba",8,9,0x10,
- #endif
- "rldb",OPC_rldb,0,{CLASS_REG_BYTE+(ARG_RB),CLASS_REG_BYTE+(ARG_RA),},
- {CLASS_BIT+0xb,CLASS_BIT+0xe,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RB),0,0,0,0,0,},2,2,125},
- /* 1011 0011 dddd 01I0 *** rr rd,imm1or2 */
- {
- #ifdef NICENAMES
- "rr rd,imm1or2",16,6,0x3c,
- #endif
- "rr",OPC_rr,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+4,0,0,0,0,0,},2,2,126},
- /* 1011 0010 dddd 01I0 *** rrb rbd,imm1or2 */
- {
- #ifdef NICENAMES
- "rrb rbd,imm1or2",8,6,0x3c,
- #endif
- "rrb",OPC_rrb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+4,0,0,0,0,0,},2,2,127},
- /* 1011 0011 dddd 11I0 *** rrc rd,imm1or2 */
- {
- #ifdef NICENAMES
- "rrc rd,imm1or2",16,6,0x3c,
- #endif
- "rrc",OPC_rrc,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+0xc,0,0,0,0,0,},2,2,128},
- /* 1011 0010 dddd 11I0 *** rrcb rbd,imm1or2 */
- {
- #ifdef NICENAMES
- "rrcb rbd,imm1or2",8,9,0x10,
- #endif
- "rrcb",OPC_rrcb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM1OR2),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT_1OR2+0xc,0,0,0,0,0,},2,2,129},
- /* 1011 1100 aaaa bbbb *** rrdb rbb,rba */
- {
- #ifdef NICENAMES
- "rrdb rbb,rba",8,9,0x10,
- #endif
- "rrdb",OPC_rrdb,0,{CLASS_REG_BYTE+(ARG_RB),CLASS_REG_BYTE+(ARG_RA),},
- {CLASS_BIT+0xb,CLASS_BIT+0xc,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RB),0,0,0,0,0,},2,2,130},
- /* 0011 0110 imm8 *** rsvd36 */
- {
- #ifdef NICENAMES
- "rsvd36",8,10,0x00,
- #endif
- "rsvd36",OPC_rsvd36,0,{0},
- {CLASS_BIT+3,CLASS_BIT+6,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,131},
- /* 0011 1000 imm8 *** rsvd38 */
- {
- #ifdef NICENAMES
- "rsvd38",8,10,0x00,
- #endif
- "rsvd38",OPC_rsvd38,0,{0},
- {CLASS_BIT+3,CLASS_BIT+8,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,132},
- /* 0111 1000 imm8 *** rsvd78 */
- {
- #ifdef NICENAMES
- "rsvd78",8,10,0x00,
- #endif
- "rsvd78",OPC_rsvd78,0,{0},
- {CLASS_BIT+7,CLASS_BIT+8,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,133},
- /* 0111 1110 imm8 *** rsvd7e */
- {
- #ifdef NICENAMES
- "rsvd7e",8,10,0x00,
- #endif
- "rsvd7e",OPC_rsvd7e,0,{0},
- {CLASS_BIT+7,CLASS_BIT+0xe,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,134},
- /* 1001 1101 imm8 *** rsvd9d */
- {
- #ifdef NICENAMES
- "rsvd9d",8,10,0x00,
- #endif
- "rsvd9d",OPC_rsvd9d,0,{0},
- {CLASS_BIT+9,CLASS_BIT+0xd,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,135},
- /* 1001 1111 imm8 *** rsvd9f */
- {
- #ifdef NICENAMES
- "rsvd9f",8,10,0x00,
- #endif
- "rsvd9f",OPC_rsvd9f,0,{0},
- {CLASS_BIT+9,CLASS_BIT+0xf,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,136},
- /* 1011 1001 imm8 *** rsvdb9 */
- {
- #ifdef NICENAMES
- "rsvdb9",8,10,0x00,
- #endif
- "rsvdb9",OPC_rsvdb9,0,{0},
- {CLASS_BIT+0xb,CLASS_BIT+9,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,137},
- /* 1011 1111 imm8 *** rsvdbf */
- {
- #ifdef NICENAMES
- "rsvdbf",8,10,0x00,
- #endif
- "rsvdbf",OPC_rsvdbf,0,{0},
- {CLASS_BIT+0xb,CLASS_BIT+0xf,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},0,2,138},
- /* 1011 0111 ssss dddd *** sbc rd,rs */
- {
- #ifdef NICENAMES
- "sbc rd,rs",16,5,0x3c,
- #endif
- "sbc",OPC_sbc,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+7,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,139},
- /* 1011 0110 ssss dddd *** sbcb rbd,rbs */
- {
- #ifdef NICENAMES
- "sbcb rbd,rbs",8,5,0x3f,
- #endif
- "sbcb",OPC_sbcb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+6,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,140},
- /* 0111 1111 imm8 *** sc imm8 */
- {
- #ifdef NICENAMES
- "sc imm8",8,33,0x3f,
- #endif
- "sc",OPC_sc,0,{CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+7,CLASS_BIT+0xf,CLASS_IMM+(ARG_IMM8),0,0,0,0,0,0,},1,2,141},
- /* 1011 0011 dddd 1011 0000 ssss 0000 0000 *** sda rd,rs */
- {
- #ifdef NICENAMES
- "sda rd,rs",16,15,0x3c,
- #endif
- "sda",OPC_sda,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,142},
- /* 1011 0010 dddd 1011 0000 ssss 0000 0000 *** sdab rbd,rs */
- {
- #ifdef NICENAMES
- "sdab rbd,rs",8,15,0x3c,
- #endif
- "sdab",OPC_sdab,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,143},
- /* 1011 0011 dddd 1111 0000 ssss 0000 0000 *** sdal rrd,rs */
- {
- #ifdef NICENAMES
- "sdal rrd,rs",32,15,0x3c,
- #endif
- "sdal",OPC_sdal,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+0xf,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,144},
- /* 1011 0011 dddd 0011 0000 ssss 0000 0000 *** sdl rd,rs */
- {
- #ifdef NICENAMES
- "sdl rd,rs",16,15,0x38,
- #endif
- "sdl",OPC_sdl,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,145},
- /* 1011 0010 dddd 0011 0000 ssss 0000 0000 *** sdlb rbd,rs */
- {
- #ifdef NICENAMES
- "sdlb rbd,rs",8,15,0x38,
- #endif
- "sdlb",OPC_sdlb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,146},
- /* 1011 0011 dddd 0111 0000 ssss 0000 0000 *** sdll rrd,rs */
- {
- #ifdef NICENAMES
- "sdll rrd,rs",32,15,0x38,
- #endif
- "sdll",OPC_sdll,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+7,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,147},
- /* 0010 0101 ddN0 imm4 *** set @rd,imm4 */
- {
- #ifdef NICENAMES
- "set @rd,imm4",16,11,0x00,
- #endif
- "set",OPC_set,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+2,CLASS_BIT+5,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,148},
- /* 0110 0101 ddN0 imm4 address_dst *** set address_dst(rd),imm4 */
- {
- #ifdef NICENAMES
- "set address_dst(rd),imm4",16,14,0x00,
- #endif
- "set",OPC_set,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+5,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,148},
- /* 0110 0101 0000 imm4 address_dst *** set address_dst,imm4 */
- {
- #ifdef NICENAMES
- "set address_dst,imm4",16,13,0x00,
- #endif
- "set",OPC_set,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+5,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,148},
- /* 1010 0101 dddd imm4 *** set rd,imm4 */
- {
- #ifdef NICENAMES
- "set rd,imm4",16,4,0x00,
- #endif
- "set",OPC_set,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xa,CLASS_BIT+5,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,148},
- /* 0010 0101 0000 ssss 0000 dddd 0000 0000 *** set rd,rs */
- {
- #ifdef NICENAMES
- "set rd,rs",16,10,0x00,
- #endif
- "set",OPC_set,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+5,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,148},
- /* 0010 0100 ddN0 imm4 *** setb @rd,imm4 */
- {
- #ifdef NICENAMES
- "setb @rd,imm4",8,11,0x00,
- #endif
- "setb",OPC_setb,0,{CLASS_IR+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+2,CLASS_BIT+4,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,149},
- /* 0110 0100 ddN0 imm4 address_dst *** setb address_dst(rd),imm4 */
- {
- #ifdef NICENAMES
- "setb address_dst(rd),imm4",8,14,0x00,
- #endif
- "setb",OPC_setb,0,{CLASS_X+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+4,CLASS_REGN0+(ARG_RD),CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,149},
- /* 0110 0100 0000 imm4 address_dst *** setb address_dst,imm4 */
- {
- #ifdef NICENAMES
- "setb address_dst,imm4",8,13,0x00,
- #endif
- "setb",OPC_setb,0,{CLASS_DA+(ARG_DST),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+6,CLASS_BIT+4,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),CLASS_ADDRESS+(ARG_DST),0,0,0,0,},2,4,149},
- /* 1010 0100 dddd imm4 *** setb rbd,imm4 */
- {
- #ifdef NICENAMES
- "setb rbd,imm4",8,4,0x00,
- #endif
- "setb",OPC_setb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xa,CLASS_BIT+4,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM4),0,0,0,0,0,},2,2,149},
- /* 0010 0100 0000 ssss 0000 dddd 0000 0000 *** setb rbd,rs */
- {
- #ifdef NICENAMES
- "setb rbd,rs",8,10,0x00,
- #endif
- "setb",OPC_setb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+2,CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RS),CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_BIT+0,CLASS_BIT+0,0,},2,4,149},
- /* 1000 1101 flags 0001 *** setflg flags */
- {
- #ifdef NICENAMES
- "setflg flags",16,7,0x3c,
- #endif
- "setflg",OPC_setflg,0,{CLASS_FLAGS,},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_FLAGS,CLASS_BIT+1,0,0,0,0,0,},1,2,150},
- /* 0011 1011 dddd 0101 imm16 *** sin rd,imm16 */
- {
- #ifdef NICENAMES
- "sin rd,imm16",16,12,0x00,
- #endif
- "sin",OPC_sin,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RD),CLASS_BIT+5,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,151},
- /* 0011 1010 dddd 0101 imm16 *** sinb rbd,imm16 */
- {
- #ifdef NICENAMES
- "sinb rbd,imm16",8,10,0x00,
- #endif
- "sinb",OPC_sinb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RD),CLASS_BIT+5,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,152},
- /* 0011 1011 ssss 1001 0000 aaaa ddN0 1000 *** sind @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sind @rd,@ri,ra",16,21,0x04,
- #endif
- "sind",OPC_sind,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,153},
- /* 0011 1010 ssss 1001 0000 aaaa ddN0 1000 *** sindb @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sindb @rd,@ri,ra",8,21,0x04,
- #endif
- "sindb",OPC_sindb,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,154},
- /* 0011 1011 ssss 1001 0000 aaaa ddN0 0000 *** sindr @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sindr @rd,@ri,ra",16,11,0x04,
- #endif
- "sindr",OPC_sindr,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,155},
- /* 0011 1010 ssss 1001 0000 aaaa ddN0 0000 *** sindrb @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sindrb @rd,@ri,ra",8,11,0x04,
- #endif
- "sindrb",OPC_sindrb,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,156},
- /* 0011 1011 ssss 0001 0000 aaaa ddN0 1000 *** sini @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sini @rd,@ri,ra",16,21,0x04,
- #endif
- "sini",OPC_sini,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,157},
- /* 0011 1010 ssss 0001 0000 aaaa ddN0 1000 *** sinib @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sinib @rd,@ri,ra",8,21,0x04,
- #endif
- "sinib",OPC_sinib,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,},3,4,158},
- /* 0011 1011 ssss 0001 0000 aaaa ddN0 0000 *** sinir @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sinir @rd,@ri,ra",16,11,0x04,
- #endif
- "sinir",OPC_sinir,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,159},
- /* 0011 1010 ssss 0001 0000 aaaa ddN0 0000 *** sinirb @rd,@ri,ra */
- {
- #ifdef NICENAMES
- "sinirb @rd,@ri,ra",8,11,0x04,
- #endif
- "sinirb",OPC_sinirb,0,{CLASS_IR+(ARG_RD),CLASS_IRO+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+1,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REGN0+(ARG_RD),CLASS_BIT+0,0,},3,4,160},
- /* 1011 0011 dddd 1001 0000 0000 imm8 *** sla rd,imm8 */
- {
- #ifdef NICENAMES
- "sla rd,imm8",16,13,0x3c,
- #endif
- "sla",OPC_sla,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+9,CLASS_BIT+0,CLASS_BIT+0,CLASS_IMM+(ARG_IMM8),0,0,},2,4,161},
- /* 1011 0010 dddd 1001 iiii iiii 0000 imm4 *** slab rbd,imm4 */
- {
- #ifdef NICENAMES
- "slab rbd,imm4",8,13,0x3c,
- #endif
- "slab",OPC_slab,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT+9,CLASS_IGNORE,CLASS_IGNORE,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),0,},2,4,162},
- /* 1011 0011 dddd 1101 0000 0000 imm8 *** slal rrd,imm8 */
- {
- #ifdef NICENAMES
- "slal rrd,imm8",32,13,0x3c,
- #endif
- "slal",OPC_slal,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+0,CLASS_IMM+(ARG_IMM8),0,0,},2,4,163},
- /* 1011 0011 dddd 0001 0000 0000 imm8 *** sll rd,imm8 */
- {
- #ifdef NICENAMES
- "sll rd,imm8",16,13,0x38,
- #endif
- "sll",OPC_sll,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+1,CLASS_BIT+0,CLASS_BIT+0,CLASS_IMM+(ARG_IMM8),0,0,},2,4,164},
- /* 1011 0010 dddd 0001 iiii iiii 0000 imm4 *** sllb rbd,imm4 */
- {
- #ifdef NICENAMES
- "sllb rbd,imm4",8,13,0x38,
- #endif
- "sllb",OPC_sllb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT+1,CLASS_IGNORE,CLASS_IGNORE,CLASS_BIT+0,CLASS_IMM+(ARG_IMM4),0,},2,4,165},
- /* 1011 0011 dddd 0101 0000 0000 imm8 *** slll rrd,imm8 */
- {
- #ifdef NICENAMES
- "slll rrd,imm8",32,13,0x38,
- #endif
- "slll",OPC_slll,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+5,CLASS_BIT+0,CLASS_BIT+0,CLASS_IMM+(ARG_IMM8),0,0,},2,4,166},
- /* 0011 1011 ssN0 1011 0000 aaaa dddd 0000 *** sotdr @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "sotdr @ro,@rs,ra",16,11,0x04,
- #endif
- "sotdr",OPC_sotdr,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,167},
- /* 0011 1010 ssN0 1011 0000 aaaa dddd 0000 *** sotdrb @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "sotdrb @ro,@rs,ra",8,11,0x04,
- #endif
- "sotdrb",OPC_sotdrb,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,168},
- /* 0011 1011 ssN0 0011 0000 aaaa dddd 0000 *** sotir @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "sotir @ro,@rs,ra",16,11,0x04,
- #endif
- "sotir",OPC_sotir,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,169},
- /* 0011 1010 ssN0 0011 0000 aaaa dddd 0000 *** sotirb @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "sotirb @ro,@rs,ra",8,11,0x04,
- #endif
- "sotirb",OPC_sotirb,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+0,0,},3,4,170},
- /* 0011 1011 ssss 0110 imm16 *** sout imm16,rs */
- {
- #ifdef NICENAMES
- "sout imm16,rs",16,12,0x00,
- #endif
- "sout",OPC_sout,0,{CLASS_IMM+(ARG_IMM16),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REG+(ARG_RS),CLASS_BIT+6,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,171},
- /* 0011 1010 ssss 0110 imm16 *** soutb imm16,rbs */
- {
- #ifdef NICENAMES
- "soutb imm16,rbs",8,12,0x00,
- #endif
- "soutb",OPC_soutb,0,{CLASS_IMM+(ARG_IMM16),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REG+(ARG_RS),CLASS_BIT+6,CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,172},
- /* 0011 1011 ssN0 1011 0000 aaaa dddd 1000 *** soutd @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "soutd @ro,@rs,ra",16,21,0x04,
- #endif
- "soutd",OPC_soutd,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,173},
- /* 0011 1010 ssN0 1011 0000 aaaa dddd 1000 *** soutdb @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "soutdb @ro,@rs,ra",8,21,0x04,
- #endif
- "soutdb",OPC_soutdb,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+0xb,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,174},
- /* 0011 1011 ssN0 0011 0000 aaaa dddd 1000 *** souti @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "souti @ro,@rs,ra",16,21,0x04,
- #endif
- "souti",OPC_souti,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xb,CLASS_REGN0+(ARG_RS),CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,175},
- /* 0011 1010 ssN0 0011 0000 aaaa dddd 1000 *** soutib @ro,@rs,ra */
- {
- #ifdef NICENAMES
- "soutib @ro,@rs,ra",8,21,0x04,
- #endif
- "soutib",OPC_soutib,0,{CLASS_IRO+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RA),},
- {CLASS_BIT+3,CLASS_BIT+0xa,CLASS_REGN0+(ARG_RS),CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RA),CLASS_REG+(ARG_RD),CLASS_BIT+8,0,},3,4,176},
- /* 1011 0011 dddd 1001 1111 1111 nim8 *** sra rd,imm8 */
- {
- #ifdef NICENAMES
- "sra rd,imm8",16,13,0x3c,
- #endif
- "sra",OPC_sra,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+9,CLASS_BIT+0xf,CLASS_BIT+0xf,CLASS_IMM+(ARG_NIM8),0,0,},2,4,177},
- /* 1011 0010 dddd 1001 iiii iiii 1111 nim4 *** srab rbd,imm4 */
- {
- #ifdef NICENAMES
- "srab rbd,imm4",8,13,0x3c,
- #endif
- "srab",OPC_srab,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT+9,CLASS_IGNORE,CLASS_IGNORE,CLASS_BIT+0xf,CLASS_IMM+(ARG_NIM4),0,},2,4,178},
- /* 1011 0011 dddd 1101 1111 1111 nim8 *** sral rrd,imm8 */
- {
- #ifdef NICENAMES
- "sral rrd,imm8",32,13,0x3c,
- #endif
- "sral",OPC_sral,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+0xd,CLASS_BIT+0xf,CLASS_BIT+0xf,CLASS_IMM+(ARG_NIM8),0,0,},2,4,179},
- /* 1011 0011 dddd 0001 1111 1111 nim8 *** srl rd,imm8 */
- {
- #ifdef NICENAMES
- "srl rd,imm8",16,13,0x3c,
- #endif
- "srl",OPC_srl,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+1,CLASS_BIT+0xf,CLASS_BIT+0xf,CLASS_IMM+(ARG_NIM8),0,0,},2,4,180},
- /* 1011 0010 dddd 0001 iiii iiii 1111 nim4 *** srlb rbd,imm4 */
- {
- #ifdef NICENAMES
- "srlb rbd,imm4",8,13,0x3c,
- #endif
- "srlb",OPC_srlb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM +(ARG_IMM4),},
- {CLASS_BIT+0xb,CLASS_BIT+2,CLASS_REG+(ARG_RD),CLASS_BIT+1,CLASS_IGNORE,CLASS_IGNORE,CLASS_BIT+0xf,CLASS_IMM+(ARG_NIM4),0,},2,4,181},
- /* 1011 0011 dddd 0101 1111 1111 nim8 *** srll rrd,imm8 */
- {
- #ifdef NICENAMES
- "srll rrd,imm8",32,13,0x3c,
- #endif
- "srll",OPC_srll,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0xb,CLASS_BIT+3,CLASS_REG+(ARG_RD),CLASS_BIT+5,CLASS_BIT+0xf,CLASS_BIT+0xf,CLASS_IMM+(ARG_NIM8),0,0,},2,4,182},
- /* 0000 0011 ssN0 dddd *** sub rd,@rs */
- {
- #ifdef NICENAMES
- "sub rd,@rs",16,7,0x3c,
- #endif
- "sub",OPC_sub,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+3,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,183},
- /* 0100 0011 0000 dddd address_src *** sub rd,address_src */
- {
- #ifdef NICENAMES
- "sub rd,address_src",16,9,0x3c,
- #endif
- "sub",OPC_sub,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,183},
- /* 0100 0011 ssN0 dddd address_src *** sub rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "sub rd,address_src(rs)",16,10,0x3c,
- #endif
- "sub",OPC_sub,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+3,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,183},
- /* 0000 0011 0000 dddd imm16 *** sub rd,imm16 */
- {
- #ifdef NICENAMES
- "sub rd,imm16",16,7,0x3c,
- #endif
- "sub",OPC_sub,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+3,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,183},
- /* 1000 0011 ssss dddd *** sub rd,rs */
- {
- #ifdef NICENAMES
- "sub rd,rs",16,4,0x3c,
- #endif
- "sub",OPC_sub,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+3,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,183},
- /* 0000 0010 ssN0 dddd *** subb rbd,@rs */
- {
- #ifdef NICENAMES
- "subb rbd,@rs",8,7,0x3f,
- #endif
- "subb",OPC_subb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+2,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,184},
- /* 0100 0010 0000 dddd address_src *** subb rbd,address_src */
- {
- #ifdef NICENAMES
- "subb rbd,address_src",8,9,0x3f,
- #endif
- "subb",OPC_subb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,184},
- /* 0100 0010 ssN0 dddd address_src *** subb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "subb rbd,address_src(rs)",8,10,0x3f,
- #endif
- "subb",OPC_subb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+2,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,184},
- /* 0000 0010 0000 dddd imm8 imm8 *** subb rbd,imm8 */
- {
- #ifdef NICENAMES
- "subb rbd,imm8",8,7,0x3f,
- #endif
- "subb",OPC_subb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,184},
- /* 1000 0010 ssss dddd *** subb rbd,rbs */
- {
- #ifdef NICENAMES
- "subb rbd,rbs",8,4,0x3f,
- #endif
- "subb",OPC_subb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+2,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,184},
- /* 0001 0010 ssN0 dddd *** subl rrd,@rs */
- {
- #ifdef NICENAMES
- "subl rrd,@rs",32,14,0x3c,
- #endif
- "subl",OPC_subl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+1,CLASS_BIT+2,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,185},
- /* 0101 0010 0000 dddd address_src *** subl rrd,address_src */
- {
- #ifdef NICENAMES
- "subl rrd,address_src",32,15,0x3c,
- #endif
- "subl",OPC_subl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+5,CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,185},
- /* 0101 0010 ssN0 dddd address_src *** subl rrd,address_src(rs) */
- {
- #ifdef NICENAMES
- "subl rrd,address_src(rs)",32,16,0x3c,
- #endif
- "subl",OPC_subl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+5,CLASS_BIT+2,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,185},
- /* 0001 0010 0000 dddd imm32 *** subl rrd,imm32 */
- {
- #ifdef NICENAMES
- "subl rrd,imm32",32,14,0x3c,
- #endif
- "subl",OPC_subl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_IMM+(ARG_IMM32),},
- {CLASS_BIT+1,CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM32),0,0,0,0,},2,6,185},
- /* 1001 0010 ssss dddd *** subl rrd,rrs */
- {
- #ifdef NICENAMES
- "subl rrd,rrs",32,8,0x3c,
- #endif
- "subl",OPC_subl,0,{CLASS_REG_LONG+(ARG_RD),CLASS_REG_LONG+(ARG_RS),},
- {CLASS_BIT+9,CLASS_BIT+2,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,185},
- /* 1010 1111 dddd cccc *** tcc cc,rd */
- {
- #ifdef NICENAMES
- "tcc cc,rd",16,5,0x00,
- #endif
- "tcc",OPC_tcc,0,{CLASS_CC,CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+0xa,CLASS_BIT+0xf,CLASS_REG+(ARG_RD),CLASS_CC,0,0,0,0,0,},2,2,186},
- /* 1010 1110 dddd cccc *** tccb cc,rbd */
- {
- #ifdef NICENAMES
- "tccb cc,rbd",8,5,0x00,
- #endif
- "tccb",OPC_tccb,0,{CLASS_CC,CLASS_REG_BYTE+(ARG_RD),},
- {CLASS_BIT+0xa,CLASS_BIT+0xe,CLASS_REG+(ARG_RD),CLASS_CC,0,0,0,0,0,},2,2,187},
- /* 0000 1101 ddN0 0100 *** test @rd */
- {
- #ifdef NICENAMES
- "test @rd",16,8,0x18,
- #endif
- "test",OPC_test,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+4,0,0,0,0,0,},1,2,188},
- /* 0100 1101 0000 0100 address_dst *** test address_dst */
- {
- #ifdef NICENAMES
- "test address_dst",16,11,0x00,
- #endif
- "test",OPC_test,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+4,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,188},
- /* 0100 1101 ddN0 0100 address_dst *** test address_dst(rd) */
- {
- #ifdef NICENAMES
- "test address_dst(rd)",16,12,0x00,
- #endif
- "test",OPC_test,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+4,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,188},
- /* 1000 1101 dddd 0100 *** test rd */
- {
- #ifdef NICENAMES
- "test rd",16,7,0x00,
- #endif
- "test",OPC_test,0,{CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_REG+(ARG_RD),CLASS_BIT+4,0,0,0,0,0,},1,2,188},
- /* 0000 1100 ddN0 0100 *** testb @rd */
- {
- #ifdef NICENAMES
- "testb @rd",8,8,0x1c,
- #endif
- "testb",OPC_testb,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+4,0,0,0,0,0,},1,2,189},
- /* 0100 1100 0000 0100 address_dst *** testb address_dst */
- {
- #ifdef NICENAMES
- "testb address_dst",8,11,0x1c,
- #endif
- "testb",OPC_testb,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+4,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,189},
- /* 0100 1100 ddN0 0100 address_dst *** testb address_dst(rd) */
- {
- #ifdef NICENAMES
- "testb address_dst(rd)",8,12,0x1c,
- #endif
- "testb",OPC_testb,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+4,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,189},
- /* 1000 1100 dddd 0100 *** testb rbd */
- {
- #ifdef NICENAMES
- "testb rbd",8,7,0x1c,
- #endif
- "testb",OPC_testb,0,{CLASS_REG_BYTE+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_BIT+4,0,0,0,0,0,},1,2,189},
- /* 0001 1100 ddN0 1000 *** testl @rd */
- {
- #ifdef NICENAMES
- "testl @rd",32,13,0x18,
- #endif
- "testl",OPC_testl,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+1,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+8,0,0,0,0,0,},1,2,190},
- /* 0101 1100 0000 1000 address_dst *** testl address_dst */
- {
- #ifdef NICENAMES
- "testl address_dst",32,16,0x18,
- #endif
- "testl",OPC_testl,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+5,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+8,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,190},
- /* 0101 1100 ddN0 1000 address_dst *** testl address_dst(rd) */
- {
- #ifdef NICENAMES
- "testl address_dst(rd)",32,17,0x18,
- #endif
- "testl",OPC_testl,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+5,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+8,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,190},
- /* 1001 1100 dddd 1000 *** testl rrd */
- {
- #ifdef NICENAMES
- "testl rrd",32,13,0x18,
- #endif
- "testl",OPC_testl,0,{CLASS_REG_LONG+(ARG_RD),},
- {CLASS_BIT+9,CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_BIT+8,0,0,0,0,0,},1,2,190},
- /* 1011 1000 ddN0 1000 0000 rrrr ssN0 0000 *** trdb @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "trdb @rd,@rs,rr",8,25,0x04,
- #endif
- "trdb",OPC_trdb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RD),CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RS),CLASS_BIT+0,0,},3,4,191},
- /* 1011 1000 ddN0 1100 0000 rrrr ssN0 0000 *** trdrb @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "trdrb @rd,@rs,rr",8,25,0x04,
- #endif
- "trdrb",OPC_trdrb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RD),CLASS_BIT+0xc,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RS),CLASS_BIT+0,0,},3,4,192},
- /* 1011 1000 ddN0 0000 0000 rrrr ssN0 0000 *** trib @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "trib @rd,@rs,rr",8,25,0x04,
- #endif
- "trib",OPC_trib,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RD),CLASS_BIT+0,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RS),CLASS_BIT+0,0,},3,4,193},
- /* 1011 1000 ddN0 0100 0000 rrrr ssN0 0000 *** trirb @rd,@rs,rr */
- {
- #ifdef NICENAMES
- "trirb @rd,@rs,rr",8,25,0x04,
- #endif
- "trirb",OPC_trirb,0,{CLASS_IR+(ARG_RD),CLASS_IR+(ARG_RS),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RD),CLASS_BIT+4,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RS),CLASS_BIT+0,0,},3,4,194},
- /* 1011 1000 aaN0 1010 0000 rrrr bbN0 0000 *** trtdb @ra,@rb,rr */
- {
- #ifdef NICENAMES
- "trtdb @ra,@rb,rr",8,25,0x14,
- #endif
- "trtdb",OPC_trtdb,0,{CLASS_IR+(ARG_RA),CLASS_IR+(ARG_RB),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RA),CLASS_BIT+0xa,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RB),CLASS_BIT+0,0,},3,4,195},
- /* 1011 1000 aaN0 1110 0000 rrrr bbN0 1110 *** trtdrb @ra,@rb,rr */
- {
- #ifdef NICENAMES
- "trtdrb @ra,@rb,rr",8,25,0x14,
- #endif
- "trtdrb",OPC_trtdrb,0,{CLASS_IR+(ARG_RA),CLASS_IR+(ARG_RB),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RA),CLASS_BIT+0xe,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RB),CLASS_BIT+0xe,0,},3,4,196},
- /* 1011 1000 aaN0 0010 0000 rrrr bbN0 0000 *** trtib @ra,@rb,rr */
- {
- #ifdef NICENAMES
- "trtib @ra,@rb,rr",8,25,0x14,
- #endif
- "trtib",OPC_trtib,0,{CLASS_IR+(ARG_RA),CLASS_IR+(ARG_RB),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RA),CLASS_BIT+2,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RB),CLASS_BIT+0,0,},3,4,197},
- /* 1011 1000 aaN0 0110 0000 rrrr bbN0 1110 *** trtirb @ra,@rb,rr */
- {
- #ifdef NICENAMES
- "trtirb @ra,@rb,rr",8,25,0x14,
- #endif
- "trtirb",OPC_trtirb,0,{CLASS_IR+(ARG_RA),CLASS_IR+(ARG_RB),CLASS_REG_WORD+(ARG_RR),},
- {CLASS_BIT+0xb,CLASS_BIT+8,CLASS_REGN0+(ARG_RA),CLASS_BIT+6,CLASS_BIT+0,CLASS_REG+(ARG_RR),CLASS_REGN0+(ARG_RB),CLASS_BIT+0xe,0,},3,4,198},
- /* 0000 1101 ddN0 0110 *** tset @rd */
- {
- #ifdef NICENAMES
- "tset @rd",16,11,0x08,
- #endif
- "tset",OPC_tset,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+6,0,0,0,0,0,},1,2,199},
- /* 0100 1101 0000 0110 address_dst *** tset address_dst */
- {
- #ifdef NICENAMES
- "tset address_dst",16,14,0x08,
- #endif
- "tset",OPC_tset,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_BIT+0,CLASS_BIT+6,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,199},
- /* 0100 1101 ddN0 0110 address_dst *** tset address_dst(rd) */
- {
- #ifdef NICENAMES
- "tset address_dst(rd)",16,15,0x08,
- #endif
- "tset",OPC_tset,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xd,CLASS_REGN0+(ARG_RD),CLASS_BIT+6,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,199},
- /* 1000 1101 dddd 0110 *** tset rd */
- {
- #ifdef NICENAMES
- "tset rd",16,7,0x08,
- #endif
- "tset",OPC_tset,0,{CLASS_REG_WORD+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xd,CLASS_REG+(ARG_RD),CLASS_BIT+6,0,0,0,0,0,},1,2,199},
- /* 0000 1100 ddN0 0110 *** tsetb @rd */
- {
- #ifdef NICENAMES
- "tsetb @rd",8,11,0x08,
- #endif
- "tsetb",OPC_tsetb,0,{CLASS_IR+(ARG_RD),},
- {CLASS_BIT+0,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+6,0,0,0,0,0,},1,2,200},
- /* 0100 1100 0000 0110 address_dst *** tsetb address_dst */
- {
- #ifdef NICENAMES
- "tsetb address_dst",8,14,0x08,
- #endif
- "tsetb",OPC_tsetb,0,{CLASS_DA+(ARG_DST),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_BIT+0,CLASS_BIT+6,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,200},
- /* 0100 1100 ddN0 0110 address_dst *** tsetb address_dst(rd) */
- {
- #ifdef NICENAMES
- "tsetb address_dst(rd)",8,15,0x08,
- #endif
- "tsetb",OPC_tsetb,0,{CLASS_X+(ARG_RD),},
- {CLASS_BIT+4,CLASS_BIT+0xc,CLASS_REGN0+(ARG_RD),CLASS_BIT+6,CLASS_ADDRESS+(ARG_DST),0,0,0,0,},1,4,200},
- /* 1000 1100 dddd 0110 *** tsetb rbd */
- {
- #ifdef NICENAMES
- "tsetb rbd",8,7,0x08,
- #endif
- "tsetb",OPC_tsetb,0,{CLASS_REG_BYTE+(ARG_RD),},
- {CLASS_BIT+8,CLASS_BIT+0xc,CLASS_REG+(ARG_RD),CLASS_BIT+6,0,0,0,0,0,},1,2,200},
- /* 0000 1001 ssN0 dddd *** xor rd,@rs */
- {
- #ifdef NICENAMES
- "xor rd,@rs",16,7,0x18,
- #endif
- "xor",OPC_xor,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+9,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,201},
- /* 0100 1001 0000 dddd address_src *** xor rd,address_src */
- {
- #ifdef NICENAMES
- "xor rd,address_src",16,9,0x18,
- #endif
- "xor",OPC_xor,0,{CLASS_REG_WORD+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,201},
- /* 0100 1001 ssN0 dddd address_src *** xor rd,address_src(rs) */
- {
- #ifdef NICENAMES
- "xor rd,address_src(rs)",16,10,0x18,
- #endif
- "xor",OPC_xor,0,{CLASS_REG_WORD+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+9,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,201},
- /* 0000 1001 0000 dddd imm16 *** xor rd,imm16 */
- {
- #ifdef NICENAMES
- "xor rd,imm16",16,7,0x18,
- #endif
- "xor",OPC_xor,0,{CLASS_REG_WORD+(ARG_RD),CLASS_IMM+(ARG_IMM16),},
- {CLASS_BIT+0,CLASS_BIT+9,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM16),0,0,0,0,},2,4,201},
- /* 1000 1001 ssss dddd *** xor rd,rs */
- {
- #ifdef NICENAMES
- "xor rd,rs",16,4,0x18,
- #endif
- "xor",OPC_xor,0,{CLASS_REG_WORD+(ARG_RD),CLASS_REG_WORD+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+9,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,201},
- /* 0000 1000 ssN0 dddd *** xorb rbd,@rs */
- {
- #ifdef NICENAMES
- "xorb rbd,@rs",8,7,0x1c,
- #endif
- "xorb",OPC_xorb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IR+(ARG_RS),},
- {CLASS_BIT+0,CLASS_BIT+8,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,202},
- /* 0100 1000 0000 dddd address_src *** xorb rbd,address_src */
- {
- #ifdef NICENAMES
- "xorb rbd,address_src",8,9,0x1c,
- #endif
- "xorb",OPC_xorb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_DA+(ARG_SRC),},
- {CLASS_BIT+4,CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,202},
- /* 0100 1000 ssN0 dddd address_src *** xorb rbd,address_src(rs) */
- {
- #ifdef NICENAMES
- "xorb rbd,address_src(rs)",8,10,0x1c,
- #endif
- "xorb",OPC_xorb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_X+(ARG_RS),},
- {CLASS_BIT+4,CLASS_BIT+8,CLASS_REGN0+(ARG_RS),CLASS_REG+(ARG_RD),CLASS_ADDRESS+(ARG_SRC),0,0,0,0,},2,4,202},
- /* 0000 1000 0000 dddd imm8 imm8 *** xorb rbd,imm8 */
- {
- #ifdef NICENAMES
- "xorb rbd,imm8",8,7,0x1c,
- #endif
- "xorb",OPC_xorb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_IMM+(ARG_IMM8),},
- {CLASS_BIT+0,CLASS_BIT+8,CLASS_BIT+0,CLASS_REG+(ARG_RD),CLASS_IMM+(ARG_IMM8),CLASS_IMM+(ARG_IMM8),0,0,0,},2,4,202},
- /* 1000 1000 ssss dddd *** xorb rbd,rbs */
- {
- #ifdef NICENAMES
- "xorb rbd,rbs",8,4,0x1c,
- #endif
- "xorb",OPC_xorb,0,{CLASS_REG_BYTE+(ARG_RD),CLASS_REG_BYTE+(ARG_RS),},
- {CLASS_BIT+8,CLASS_BIT+8,CLASS_REG+(ARG_RS),CLASS_REG+(ARG_RD),0,0,0,0,0,},2,2,202},
- /* end marker */
- {
- #ifdef NICENAMES
- NULL,0,0,
- 0,
- #endif
- NULL,0,0,{0,0,0,0},{0,0,0,0,0,0,0,0,0,0},0,0,0}
- };
- #endif
|