2
0

x86ins.dat 111 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427
  1. ;
  2. ; Table of assembler instructions for Free Pascal
  3. ; adapted from Netwide Assembler by Peter Vreman
  4. ;
  5. ; The Netwide Assembler is copyright (C) 1996 Simon Tatham and
  6. ; Julian Hall. All rights reserved.
  7. ;
  8. ; Layout
  9. ; [OPCODE,attnameX] (X means suffix in att name)
  10. ; arguments bytes flags
  11. ;
  12. [NONE]
  13. (Ch_None, Ch_None, Ch_None)
  14. void void none
  15. [AAA]
  16. (Ch_MEAX, Ch_WFlags, Ch_None)
  17. void \1\x37 8086,NOX86_64
  18. [AAD,aadX]
  19. (Ch_MEAX, Ch_WFlags, Ch_None)
  20. void \2\xD5\x0A 8086,NOX86_64
  21. imm \1\xD5\24 8086,SB,NOX86_64
  22. [AAM,aamX]
  23. (Ch_MEAX, Ch_WFlags, Ch_None)
  24. void \2\xD4\x0A 8086,NOX86_64
  25. imm \1\xD4\24 8086,SB,NOX86_64
  26. [AAS]
  27. (Ch_MEAX, Ch_WFlags, Ch_None)
  28. void \1\x3F 8086,NOX86_64
  29. [ADC,adcX]
  30. (Ch_Mop2, Ch_Rop1, Ch_RWFlags)
  31. regmem,reg16|32|64 \320\1\x11\101 8086,SM
  32. reg16|32|64,regmem \320\1\x13\110 8086,SM
  33. rm8,reg8 \1\x10\101 8086
  34. reg8,rm8 \1\x12\110 8086
  35. rm16|32|64,imm8 \320\1\x83\202\15 8086
  36. reg_eax,imm \325\1\x15\41 386,SM
  37. reg_rax,imm \326\1\x15\255 X86_64,SM
  38. rm32,imm \325\1\x81\202\41 386,SM
  39. rm64,imm \326\1\x81\202\255 X86_64,SM
  40. reg_ax,imm \324\1\x15\31 8086,SW
  41. rm16,imm \324\1\x81\202\31 8086,SW
  42. reg_al,imm \1\x14\21 8086,SB
  43. rm8,imm \1\x80\202\21 8086,SB
  44. [ADD,addX]
  45. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  46. regmem,reg16|32|64 \320\1\x01\101 8086,SM
  47. reg16|32|64,regmem \320\1\x03\110 8086,SM
  48. rm8,reg8 \1\x00\101 8086
  49. reg8,rm8 \1\x02\110 8086,SM
  50. rm16|32|64,imm8 \320\1\x83\200\15 8086
  51. reg_eax,imm \320\1\x05\41 386,SM
  52. reg_rax,imm \326\1\x05\255 X86_64,SM
  53. rm32,imm \325\1\x81\200\41 386,SM
  54. rm64,imm \326\1\x81\200\255 X86_64,SM
  55. reg_ax,imm \324\1\x05\31 8086,SW
  56. rm16,imm \324\1\x81\200\31 8086,SW
  57. reg_al,imm \1\x04\21 8086,SB
  58. rm8,imm \1\x80\200\21 8086,SB
  59. [AND,andX]
  60. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  61. regmem,reg16|32|64 \320\1\x21\101 8086,SM
  62. reg16|32|64,regmem \320\1\x23\110 8086,SM
  63. rm8,reg8 \1\x20\101 8086
  64. reg8,rm8 \1\x22\110 8086
  65. rm16|32|64,imm8 \320\1\x83\204\15 8086
  66. reg_eax,imm \325\1\x25\41 386,SM
  67. reg_rax,imm \326\1\x25\255 X86_64,SM
  68. rm32,imm \325\1\x81\204\41 386,SM
  69. rm64,imm \326\1\x81\204\255 X86_64,SM
  70. reg_ax,imm \324\1\x25\31 8086,SW
  71. rm16,imm \324\1\x81\204\31 8086,SW
  72. reg_al,imm \1\x24\21 8086,SB
  73. rm8,imm \1\x80\204\21 8086,SB
  74. [ARPL,arplX]
  75. (Ch_WFlags, Ch_None, Ch_None)
  76. reg16,reg16 \1\x63\101 286,PROT,NOX86_64
  77. mem,reg16 \1\x63\101 286,PROT,SM,NOX86_64
  78. [BOUND,boundX]
  79. (Ch_Rop1, Ch_None, Ch_None)
  80. reg16|32,mem \320\1\x62\110 186,NOX86_64
  81. [BSF,bsfX]
  82. (Ch_Wop2, Ch_WFlags, Ch_Rop1)
  83. reg16|32|64,regmem \320\2\x0F\xBC\110 386,SM
  84. [BSR,bsrX]
  85. (Ch_Wop2, Ch_WFlags, Ch_Rop1)
  86. reg16|32|64,regmem \320\2\x0F\xBD\110 386,SM
  87. [BSWAP,bswapX]
  88. (Ch_MOp1, Ch_None, Ch_None)
  89. reg32|64 \320\1\x0F\10\xC8 486
  90. [BT,btX]
  91. (Ch_WFlags, Ch_Rop1, Ch_Rop2)
  92. regmem,reg16|32|64 \320\2\x0F\xA3\101 386,SM
  93. rm16|32|64,imm \320\2\x0F\xBA\204\25 386,SB
  94. [BTC,btcX]
  95. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  96. regmem,reg16|32|64 \320\2\x0F\xBB\101 386,SM
  97. rm16|32|64,imm \320\2\x0F\xBA\207\25 386,SB
  98. [BTR,btrX]
  99. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  100. regmem,reg16|32|64 \320\2\x0F\xB3\101 386,SM
  101. rm16|32|64,imm \320\2\x0F\xBA\206\25 386,SB
  102. [BTS,btsX]
  103. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  104. regmem,reg16|32|64 \320\2\x0F\xAB\101 386,SM
  105. rm16|32|64,imm \320\2\x0F\xBA\205\25 386,SB
  106. [CALL,call]
  107. ; don't know value of any register
  108. (Ch_ROp1, Ch_All, Ch_None)
  109. imm \320\1\xE8\64 8086
  110. rm16|32|64 \320\1\xFF\202 8086
  111. imm|near \320\1\xE8\64 8086
  112. imm|far \320\1\x9A\34\37 8086,ND,NOX86_64
  113. mem|near \320\1\xFF\202 8086
  114. mem|far \320\1\xFF\203 8086
  115. imm:imm \327\1\x9A\35\30 8086,NOX86_64
  116. imm16:imm \324\1\x9A\31\30 8086,NOX86_64
  117. imm:imm16 \324\1\x9A\31\30 8086,NOX86_64
  118. imm32:imm \325\1\x9A\41\30 386,NOX86_64
  119. imm:imm32 \325\1\x9A\41\30 386,NOX86_64
  120. [CBW,cbtw]
  121. (Ch_MEAX, Ch_None, Ch_None)
  122. void \324\1\x98 8086
  123. [CDQ,cltd]
  124. (Ch_MEAX, Ch_WEDX, Ch_None)
  125. void \325\1\x99 386
  126. [CLC]
  127. (Ch_WFlags, Ch_None, Ch_None)
  128. void \1\xF8 8086
  129. [CLD]
  130. (Ch_CDirFlag, Ch_None, Ch_None)
  131. void \1\xFC 8086
  132. [CLI]
  133. (Ch_WFlags, Ch_None, Ch_None)
  134. void \1\xFA 8086
  135. [CLTS]
  136. (Ch_None, Ch_None, Ch_None)
  137. void \2\x0F\x06 286,PRIV
  138. [CMC]
  139. (Ch_WFlags, Ch_None, Ch_None)
  140. void \1\xF5 8086
  141. [CMP,cmpX]
  142. (Ch_ROp1, Ch_ROp2, Ch_WFlags)
  143. regmem,reg16|32|64 \320\1\x39\101 8086,SM
  144. reg16|32|64,regmem \320\1\x3B\110 8086,SM
  145. rm8,reg8 \1\x38\101 8086
  146. reg8,rm8 \1\x3A\110 8086
  147. rm16|32|64,imm8 \320\1\x83\207\15 8086
  148. reg_eax,imm \325\1\x3D\41 386,SM
  149. reg_rax,imm \326\1\x3D\255 X86_64,SM
  150. rm32,imm \325\1\x81\207\41 386,SM
  151. rm64,imm \326\1\x81\207\255 X86_64,SM
  152. reg_ax,imm \324\1\x3D\31 8086,SW
  153. rm16,imm \324\1\x81\207\31 8086,SW
  154. reg_al,imm \1\x3C\21 8086,SB
  155. rm8,imm \1\x80\207\21 8086,SB
  156. mem,imm32 \325\1\x81\207\41 386,SD
  157. mem,imm16 \324\1\x81\207\31 8086,SW
  158. mem,imm8 \1\x80\207\21 8086,SB
  159. [CMPSB]
  160. (Ch_All, Ch_None, Ch_None)
  161. void \332\1\xA6 8086
  162. [CMPSD,cmpsl]
  163. (Ch_All, Ch_None, Ch_None)
  164. void \332\325\1\xA7 386
  165. xmmreg,xmmrm,imm \334\2\x0F\xC2\110\26 WILLAMETTE,SSE2,SM2,SB,AR2
  166. [CMPSW]
  167. (Ch_All, Ch_None, Ch_None)
  168. void \332\324\1\xA7 8086
  169. [CMPXCHG,cmpxchgX]
  170. (Ch_All, Ch_None, Ch_None)
  171. regmem,reg16|32|64 \320\2\x0F\xB1\101 PENT,SM
  172. rm8,reg8 \2\x0F\xB0\101 PENT
  173. [CMPXCHG486,cmpxchg486X]
  174. (Ch_All, Ch_None, Ch_None)
  175. regmem,reg16|32|64 \320\2\x0F\xA7\101 486,SM
  176. rm8,reg8 \2\x0F\xA6\101 486,UNDOC
  177. [CMPXCHG8B,cmpxchg8b]
  178. (Ch_All, Ch_None, Ch_None)
  179. mem \2\x0F\xC7\201 PENT
  180. [CPUID]
  181. (Ch_All, Ch_None, Ch_none)
  182. void \2\x0F\xA2 PENT
  183. [CWD]
  184. (Ch_MEAX, Ch_WEDX, Ch_None)
  185. void \324\1\x99 8086
  186. [CWDE,cwtl]
  187. (Ch_MEAX, Ch_None, Ch_None)
  188. void \325\1\x98 386
  189. [DAA]
  190. (Ch_MEAX, Ch_None, Ch_None)
  191. void \1\x27 8086,NOX86_64
  192. [DAS]
  193. (Ch_MEAX, Ch_None, Ch_None)
  194. void \1\x2F 8086,NOX86_64
  195. [DEC,decX]
  196. (Ch_Mop1, Ch_WFlags, Ch_None)
  197. reg16|32 \320\10\x48 8086,NOX86_64
  198. rm16|32|64 \320\1\xFF\201 8086
  199. rm8 \1\xFE\201 8086
  200. [DIV,divX]
  201. (Ch_RWEAX, Ch_WEDX, Ch_WFlags)
  202. rm16|32|64 \320\1\xF7\206 8086
  203. rm8 \1\xF6\206 8086
  204. [EMMS]
  205. (Ch_FPU, Ch_None, Ch_None)
  206. void \2\x0F\x77 PENT,MMX
  207. [ENTER,enterX]
  208. (Ch_RWESP, Ch_None, Ch_None)
  209. imm,imm \1\xC8\30\25 186
  210. [F2XM1]
  211. (Ch_FPU, Ch_None, Ch_None)
  212. void \2\xD9\xF0 8086,FPU
  213. [FABS]
  214. (Ch_FPU, Ch_None, Ch_None)
  215. void \2\xD9\xE1 8086,FPU
  216. [FADD,faddF]
  217. (Ch_FPU, Ch_ROp1, Ch_None)
  218. mem32 \1\xD8\200 8086,FPU
  219. mem64 \1\xDC\200 8086,FPU
  220. void \2\xDE\xC1 8086,FPU
  221. fpureg|to \1\xDC\10\xC0 8086,FPU
  222. fpureg,fpu0 \1\xDC\10\xC0 8086,FPU
  223. fpureg \1\xD8\10\xC0 8086,FPU
  224. fpu0,fpureg \1\xD8\11\xC0 8086,FPU
  225. [FADDP,faddpF]
  226. (Ch_FPU, Ch_ROp1, Ch_None)
  227. void \2\xDE\xC1 8086,FPU
  228. fpureg \1\xDE\10\xC0 8086,FPU
  229. fpureg,fpu0 \1\xDE\10\xC0 8086,FPU
  230. [FBLD,fbldF]
  231. (Ch_Rop1, Ch_FPU, Ch_None)
  232. mem80 \1\xDF\204 8086,FPU
  233. mem \1\xDF\204 8086,FPU
  234. [FBSTP,fbstpF]
  235. (Ch_Wop1, Ch_FPU, Ch_None)
  236. mem80 \1\xDF\206 8086,FPU
  237. mem \1\xDF\206 8086,FPU
  238. [FCHS]
  239. (Ch_FPU, Ch_None, Ch_None)
  240. void \2\xD9\xE0 8086,FPU
  241. [FCLEX]
  242. (Ch_FPU, Ch_None, Ch_None)
  243. void \3\x9B\xDB\xE2 8086,FPU
  244. [FCMOVB,fcmovbF]
  245. (Ch_FPU, Ch_RFLAGS, Ch_None)
  246. void \2\xDA\xC1 P6,FPU
  247. fpureg \1\xDA\10\xC0 P6,FPU
  248. fpu0,fpureg \1\xDA\11\xC0 P6,FPU
  249. [FCMOVBE,fcmovbeF]
  250. (Ch_FPU, Ch_RFLAGS, Ch_None)
  251. void \2\xDA\xD1 P6,FPU
  252. fpureg \1\xDA\10\xD0 P6,FPU
  253. fpu0,fpureg \1\xDA\11\xD0 P6,FPU
  254. [FCMOVE,fcmoveF]
  255. (Ch_FPU, Ch_RFLAGS, Ch_None)
  256. void \2\xDA\xC9 P6,FPU
  257. fpureg \1\xDA\10\xC8 P6,FPU
  258. fpu0,fpureg \1\xDA\11\xC8 P6,FPU
  259. [FCMOVNB,fcmovnbF]
  260. (Ch_FPU, Ch_RFLAGS, Ch_None)
  261. void \2\xDB\xC1 P6,FPU
  262. fpureg \1\xDB\10\xC0 P6,FPU
  263. fpu0,fpureg \1\xDB\11\xC0 P6,FPU
  264. [FCMOVNBE,fcmovnbeF]
  265. (Ch_FPU, Ch_RFLAGS, Ch_None)
  266. void \2\xDB\xD1 P6,FPU
  267. fpureg \1\xDB\10\xD0 P6,FPU
  268. fpu0,fpureg \1\xDB\11\xD0 P6,FPU
  269. [FCMOVNE,fcmovneF]
  270. (Ch_FPU, Ch_RFLAGS, Ch_None)
  271. void \2\xDB\xC9 P6,FPU
  272. fpureg \1\xDB\10\xC8 P6,FPU
  273. fpu0,fpureg \1\xDB\11\xC8 P6,FPU
  274. [FCMOVNU,fcmovnuF]
  275. (Ch_FPU, Ch_RFLAGS, Ch_None)
  276. void \2\xDB\xD9 P6,FPU
  277. fpureg \1\xDB\10\xD8 P6,FPU
  278. fpu0,fpureg \1\xDB\11\xD8 P6,FPU
  279. [FCMOVU,fcmovuF]
  280. (Ch_FPU, Ch_RFLAGS, Ch_None)
  281. void \2\xDA\xD9 P6,FPU
  282. fpureg \1\xDA\10\xD8 P6,FPU
  283. fpu0,fpureg \1\xDA\11\xD8 P6,FPU
  284. [FCOM,fcomF]
  285. (Ch_FPU, Ch_None, Ch_None)
  286. mem32 \1\xD8\202 8086,FPU
  287. mem64 \1\xDC\202 8086,FPU
  288. void \2\xD8\xD1 8086,FPU
  289. fpureg \1\xD8\10\xD0 8086,FPU
  290. fpu0,fpureg \1\xD8\11\xD0 8086,FPU
  291. [FCOMI,fcomiF]
  292. (Ch_WFLAGS, Ch_None, Ch_None)
  293. void \2\xDB\xF1 P6,FPU
  294. fpureg \1\xDB\10\xF0 P6,FPU
  295. fpu0,fpureg \1\xDB\11\xF0 P6,FPU
  296. [FCOMIP,fcomipF]
  297. (Ch_FPU, Ch_WFLAGS, Ch_None)
  298. void \2\xDF\xF1 P6,FPU
  299. fpureg \1\xDF\10\xF0 P6,FPU
  300. fpu0,fpureg \1\xDF\11\xF0 P6,FPU
  301. [FCOMP,fcompF]
  302. (Ch_FPU, Ch_None, Ch_None)
  303. mem32 \1\xD8\203 8086,FPU
  304. mem64 \1\xDC\203 8086,FPU
  305. void \2\xD8\xD9 8086,FPU
  306. fpureg \1\xD8\10\xD8 8086,FPU
  307. fpu0,fpureg \1\xD8\11\xD8 8086,FPU
  308. [FCOMPP]
  309. (Ch_FPU, Ch_None, Ch_None)
  310. void \2\xDE\xD9 8086,FPU
  311. [FCOS]
  312. (Ch_FPU, Ch_None, Ch_None)
  313. void \2\xD9\xFF 386,FPU
  314. [FDECSTP]
  315. (Ch_FPU, Ch_None, Ch_None)
  316. void \2\xD9\xF6 8086,FPU
  317. [FDISI]
  318. (Ch_FPU, Ch_None, Ch_None)
  319. void \3\x9B\xDB\xE1 8086,FPU
  320. [FDIV,fdivF]
  321. (Ch_FPU, Ch_ROp1, Ch_None)
  322. mem32 \1\xD8\206 8086,FPU
  323. mem64 \1\xDC\206 8086,FPU
  324. void \2\xDC\xF1 8086,FPU
  325. fpureg|to \1\xDC\10\xF0 8086,FPU
  326. fpureg,fpu0 \1\xDC\10\xF0 8086,FPU
  327. fpureg \1\xD8\10\xF0 8086,FPU
  328. fpu0,fpureg \1\xD8\11\xF0 8086,FPU
  329. [FDIVP,fdivpF]
  330. (Ch_FPU, Ch_ROp1, Ch_None)
  331. void \2\xDE\xF1 8086,FPU
  332. fpureg,fpu0 \1\xDE\10\xF0 8086,FPU
  333. fpureg \1\xDE\10\xF0 8086,FPU
  334. [FDIVR,fdivrF]
  335. (Ch_FPU, Ch_ROp1, Ch_None)
  336. mem32 \1\xD8\207 8086,FPU
  337. mem64 \1\xDC\207 8086,FPU
  338. void \2\xDC\xF9 8086,FPU
  339. fpureg|to \1\xDC\10\xF8 8086,FPU
  340. fpureg,fpu0 \1\xDC\10\xF8 8086,FPU
  341. fpureg \1\xD8\10\xF8 8086,FPU
  342. fpu0,fpureg \1\xD8\11\xF8 8086,FPU
  343. [FDIVRP,fdivrpF]
  344. (Ch_FPU, Ch_ROp1, Ch_None)
  345. void \2\xDE\xF9 8086,FPU
  346. fpureg \1\xDE\10\xF8 8086,FPU
  347. fpureg,fpu0 \1\xDE\10\xF8 8086,FPU
  348. [FEMMS]
  349. (Ch_All, Ch_None, Ch_None)
  350. void \2\x0F\x0E PENT,3DNOW
  351. [FENI]
  352. (Ch_FPU, Ch_None, Ch_None)
  353. void \3\x9B\xDB\xE0 8086,FPU
  354. [FFREE]
  355. (Ch_FPU, Ch_None, Ch_None)
  356. fpureg \1\xDD\10\xC0 8086,FPU
  357. [FIADD,fiaddR]
  358. (Ch_FPU, Ch_ROp1, Ch_None)
  359. mem16 \1\xDE\200 8086,FPU
  360. mem32 \1\xDA\200 8086,FPU
  361. [FICOM,ficomR]
  362. (Ch_FPU, Ch_None, Ch_None)
  363. mem16 \1\xDE\202 8086,FPU
  364. mem32 \1\xDA\202 8086,FPU
  365. [FICOMP,ficompR]
  366. (Ch_FPU, Ch_None, Ch_None)
  367. mem16 \1\xDE\203 8086,FPU
  368. mem32 \1\xDA\203 8086,FPU
  369. [FIDIV,fidivR]
  370. (Ch_FPU, Ch_ROp1, Ch_None)
  371. mem16 \1\xDE\206 8086,FPU
  372. mem32 \1\xDA\206 8086,FPU
  373. [FIDIVR,fidivrR]
  374. (Ch_FPU, Ch_ROp1, Ch_None)
  375. mem16 \1\xDE\207 8086,FPU
  376. mem32 \1\xDA\207 8086,FPU
  377. [FILD,fildR]
  378. (Ch_FPU, Ch_ROp1, Ch_None)
  379. mem32 \1\xDB\200 8086,FPU
  380. mem16 \1\xDF\200 8086,FPU
  381. mem64 \1\xDF\205 8086,FPU
  382. [FIMUL,fimulR]
  383. (Ch_FPU, Ch_ROp1, Ch_None)
  384. mem16 \1\xDE\201 8086,FPU
  385. mem32 \1\xDA\201 8086,FPU
  386. [FINCSTP]
  387. (Ch_FPU, Ch_None, Ch_None)
  388. void \2\xD9\xF7 8086,FPU
  389. [FINIT]
  390. (Ch_FPU, Ch_None, Ch_None)
  391. void \3\x9B\xDB\xE3 8086,FPU
  392. [FIST,fistR]
  393. (Ch_Wop1, Ch_None, Ch_None)
  394. mem32 \1\xDB\202 8086,FPU
  395. mem16 \324\1\xDF\202 8086,FPU
  396. [FISTP,fistpR]
  397. (Ch_Wop1, Ch_None, Ch_None)
  398. mem32 \1\xDB\203 8086,FPU
  399. mem16 \324\1\xDF\203 8086,FPU
  400. mem64 \1\xDF\207 8086,FPU
  401. [FISTTP,fisttpR]
  402. (Ch_Wop1, Ch_None, Ch_None)
  403. mem32 \1\xDB\201 PRESCOTT,FPU
  404. mem16 \1\xDF\201 PRESCOTT,FPU
  405. mem64 \1\xDD\201 PRESCOTT,FPU
  406. [FISUB,fisubR]
  407. (Ch_FPU, Ch_ROp1, Ch_None)
  408. mem16 \1\xDE\204 8086,FPU
  409. mem32 \1\xDA\204 8086,FPU
  410. [FISUBR,fisubrR]
  411. (Ch_FPU, Ch_ROp1, Ch_None)
  412. mem16 \1\xDE\205 8086,FPU
  413. mem32 \1\xDA\205 8086,FPU
  414. [FLD,fldF]
  415. (Ch_Rop1, Ch_FPU, Ch_None)
  416. mem32 \1\xD9\200 8086,FPU
  417. mem64 \1\xDD\200 8086,FPU
  418. mem80 \1\xDB\205 8086,FPU
  419. fpureg \1\xD9\10\xC0 8086,FPU
  420. [FLD1]
  421. (Ch_FPU, Ch_None, Ch_None)
  422. void \2\xD9\xE8 8086,FPU
  423. [FLDCW,fldcwX]
  424. (Ch_FPU, Ch_None, Ch_None)
  425. mem \1\xD9\205 8086,FPU,SW
  426. [FLDENV,fldenv]
  427. (Ch_FPU, Ch_None, Ch_None)
  428. mem \1\xD9\204 8086,FPU
  429. [FLDL2E]
  430. (Ch_FPU, Ch_None, Ch_None)
  431. void \2\xD9\xEA 8086,FPU
  432. [FLDL2T]
  433. (Ch_FPU, Ch_None, Ch_None)
  434. void \2\xD9\xE9 8086,FPU
  435. [FLDLG2]
  436. (Ch_FPU, Ch_None, Ch_None)
  437. void \2\xD9\xEC 8086,FPU
  438. [FLDLN2]
  439. (Ch_FPU, Ch_None, Ch_None)
  440. void \2\xD9\xED 8086,FPU
  441. [FLDPI]
  442. (Ch_FPU, Ch_None, Ch_None)
  443. void \2\xD9\xEB 8086,FPU
  444. [FLDZ]
  445. (Ch_FPU, Ch_None, Ch_None)
  446. void \2\xD9\xEE 8086,FPU
  447. [FMUL,fmulF]
  448. (Ch_ROp1, Ch_FPU, Ch_None)
  449. mem32 \1\xD8\201 8086,FPU
  450. mem64 \1\xDC\201 8086,FPU
  451. void \2\xDC\xC9 8086,FPU
  452. fpureg|to \1\xDC\10\xC8 8086,FPU
  453. fpureg,fpu0 \1\xDC\10\xC8 8086,FPU
  454. fpureg \1\xD8\10\xC8 8086,FPU
  455. fpu0,fpureg \1\xD8\11\xC8 8086,FPU
  456. [FMULP,fmulpF]
  457. (Ch_ROp1, Ch_FPU, Ch_None)
  458. void \2\xDE\xC9 8086,FPU
  459. fpureg \1\xDE\10\xC8 8086,FPU
  460. fpureg,fpu0 \1\xDE\10\xC8 8086,FPU
  461. [FNCLEX]
  462. (Ch_FPU, Ch_None, Ch_None)
  463. void \2\xDB\xE2 8086,FPU
  464. [FNDISI]
  465. (Ch_FPU, Ch_None, Ch_None)
  466. void \2\xDB\xE1 8086,FPU
  467. [FNENI]
  468. (Ch_FPU, Ch_None, Ch_None)
  469. void \2\xDB\xE0 8086,FPU
  470. [FNINIT]
  471. (Ch_FPU, Ch_None, Ch_None)
  472. void \2\xDB\xE3 8086,FPU
  473. [FNOP]
  474. (Ch_FPU, Ch_None, Ch_None)
  475. void \2\xD9\xD0 8086,FPU
  476. [FNSAVE,fnsave]
  477. (Ch_FPU, Ch_None, Ch_None)
  478. mem \1\xDD\206 8086,FPU
  479. [FNSTCW,fnstcwX]
  480. (Ch_Wop1, Ch_None, Ch_None)
  481. mem \1\xD9\207 8086,FPU,SW
  482. [FNSTENV,fnstenv]
  483. (Ch_Wop1, Ch_None, Ch_None)
  484. mem \1\xD9\206 8086,FPU
  485. [FNSTSW,fnstswX]
  486. (Ch_Wop1, Ch_None, Ch_None)
  487. mem \1\xDD\207 8086,FPU,SW
  488. reg_ax \2\xDF\xE0 286,FPU
  489. [FPATAN]
  490. (Ch_FPU, Ch_None, Ch_None)
  491. void \2\xD9\xF3 8086,FPU
  492. [FPREM]
  493. (Ch_FPU, Ch_None, Ch_None)
  494. void \2\xD9\xF8 8086,FPU
  495. [FPREM1]
  496. (Ch_FPU, Ch_None, Ch_None)
  497. void \2\xD9\xF5 386,FPU
  498. [FPTAN]
  499. (Ch_FPU, Ch_None, Ch_None)
  500. void \2\xD9\xF2 8086,FPU
  501. [FRNDINT]
  502. (Ch_FPU, Ch_None, Ch_None)
  503. void \2\xD9\xFC 8086,FPU
  504. [FRSTOR,frstor]
  505. (Ch_FPU, Ch_None, Ch_None)
  506. mem \1\xDD\204 8086,FPU
  507. [FSAVE,fsave]
  508. (Ch_Wop1, Ch_None, Ch_None)
  509. mem \2\x9B\xDD\206 8086,FPU
  510. [FSCALE]
  511. (Ch_FPU, Ch_None, Ch_None)
  512. void \2\xD9\xFD 8086,FPU
  513. [FSETPM]
  514. (Ch_FPU, Ch_None, Ch_None)
  515. void \2\xDB\xE4 286,FPU
  516. [FSIN]
  517. (Ch_FPU, Ch_None, Ch_None)
  518. void \2\xD9\xFE 386,FPU
  519. [FSINCOS]
  520. (Ch_FPU, Ch_None, Ch_None)
  521. void \2\xD9\xFB 386,FPU
  522. [FSQRT]
  523. (Ch_FPU, Ch_None, Ch_None)
  524. void \2\xD9\xFA 8086,FPU
  525. [FST,fstF]
  526. (Ch_Wop1, Ch_None, Ch_None)
  527. mem32 \1\xD9\202 8086,FPU
  528. mem64 \1\xDD\202 8086,FPU
  529. fpureg \1\xDD\10\xD0 8086,FPU
  530. [FSTCW,fstcwX]
  531. (Ch_Wop1, Ch_None, Ch_None)
  532. mem \2\x9B\xD9\207 8086,FPU,SW
  533. [FSTENV,fstenv]
  534. (Ch_Wop1, Ch_None, Ch_None)
  535. mem \2\x9B\xD9\206 8086,FPU
  536. [FSTP,fstpF]
  537. (Ch_Wop1, Ch_FPU, Ch_None)
  538. mem32 \1\xD9\203 8086,FPU
  539. mem64 \1\xDD\203 8086,FPU
  540. mem80 \1\xDB\207 8086,FPU
  541. fpureg \1\xDD\10\xD8 8086,FPU
  542. [FSTSW,fstswX]
  543. (Ch_Wop1, Ch_None, Ch_None)
  544. mem \2\x9B\xDD\207 8086,FPU,SW
  545. void \3\x9B\xDF\xE0 286,FPU
  546. reg_ax \3\x9B\xDF\xE0 286,FPU
  547. [FSUB,fsubF]
  548. (Ch_ROp1, Ch_FPU, Ch_None)
  549. mem32 \1\xD8\204 8086,FPU
  550. mem64 \1\xDC\204 8086,FPU
  551. void \2\xDC\xE1 8086,FPU
  552. fpureg|to \1\xDC\10\xE0 8086,FPU
  553. fpureg,fpu0 \1\xDC\10\xE0 8086,FPU
  554. fpureg \1\xD8\10\xE0 8086,FPU
  555. fpu0,fpureg \1\xD8\11\xE0 8086,FPU
  556. [FSUBP,fsubpF]
  557. (Ch_ROp1, Ch_FPU, Ch_None)
  558. void \2\xDE\xE1 8086,FPU
  559. fpureg \1\xDE\10\xE0 8086,FPU
  560. fpureg,fpu0 \1\xDE\10\xE0 8086,FPU
  561. [FSUBR,fsubrF]
  562. (Ch_ROp1, Ch_FPU, Ch_None)
  563. mem32 \1\xD8\205 8086,FPU
  564. mem64 \1\xDC\205 8086,FPU
  565. void \2\xDC\xE9 8086,FPU
  566. fpureg|to \1\xDC\10\xE8 8086,FPU
  567. fpureg,fpu0 \1\xDC\10\xE8 8086,FPU
  568. fpureg \1\xD8\10\xE8 8086,FPU
  569. fpu0,fpureg \1\xD8\11\xE8 8086,FPU
  570. [FSUBRP,fsubrpF]
  571. (Ch_ROp1, Ch_FPU, Ch_None)
  572. void \2\xDE\xE9 8086,FPU
  573. fpureg \1\xDE\10\xE8 8086,FPU
  574. fpureg,fpu0 \1\xDE\10\xE8 8086,FPU
  575. [FTST]
  576. (Ch_FPU, Ch_None, Ch_None)
  577. void \2\xD9\xE4 8086,FPU
  578. [FUCOM,fucomF]
  579. (Ch_None, Ch_None, Ch_None)
  580. void \2\xDD\xE1 386,FPU
  581. fpureg \1\xDD\10\xE0 386,FPU
  582. fpu0,fpureg \1\xDD\11\xE0 386,FPU
  583. [FUCOMI,fucomiF]
  584. (Ch_WFLAGS, Ch_None, Ch_None)
  585. void \2\xDB\xE9 P6,FPU
  586. fpureg \1\xDB\10\xE8 P6,FPU
  587. fpu0,fpureg \1\xDB\11\xE8 P6,FPU
  588. [FUCOMIP,fucomipF]
  589. (Ch_FPU, Ch_WFLAGS, Ch_None)
  590. void \2\xDF\xE9 P6,FPU
  591. fpureg \1\xDF\10\xE8 P6,FPU
  592. fpu0,fpureg \1\xDF\11\xE8 P6,FPU
  593. [FUCOMP,fucompF]
  594. (Ch_FPU, Ch_None, Ch_None)
  595. void \2\xDD\xE9 386,FPU
  596. fpureg \1\xDD\10\xE8 386,FPU
  597. fpu0,fpureg \1\xDD\11\xE8 386,FPU
  598. [FUCOMPP]
  599. (Ch_FPU, Ch_None, Ch_None)
  600. void \2\xDA\xE9 386,FPU
  601. [FWAIT]
  602. (Ch_FPU, Ch_None, Ch_None)
  603. void \1\x9B 8086,FPU
  604. [FXAM]
  605. (Ch_FPU, Ch_None, Ch_None)
  606. void \2\xD9\xE5 8086,FPU
  607. [FXCH,fxchF]
  608. (Ch_FPU, Ch_None, Ch_None)
  609. void \2\xD9\xC9 8086,FPU
  610. fpureg \1\xD9\10\xC8 8086,FPU
  611. fpureg,fpu0 \1\xD9\10\xC8 8086,FPU
  612. fpu0,fpureg \1\xD9\11\xC8 8086,FPU
  613. [FXTRACT]
  614. (Ch_FPU, Ch_None, Ch_None)
  615. void \2\xD9\xF4 8086,FPU
  616. [FYL2X]
  617. (Ch_FPU, Ch_None, Ch_None)
  618. void \2\xD9\xF1 8086,FPU
  619. [FYL2XP1]
  620. (Ch_FPU, Ch_None, Ch_None)
  621. void \2\xD9\xF9 8086,FPU
  622. [HLT]
  623. (Ch_None, Ch_None, Ch_None)
  624. void \1\xF4 8086,PRIV
  625. [IBTS,ibtsX]
  626. (Ch_All, Ch_None, Ch_None)
  627. regmem,reg16|32|64 \320\2\x0F\xA7\101 386,SM,UNDOC,ND
  628. [ICEBP]
  629. (Ch_All, Ch_None, Ch_None)
  630. void \1\xF1 386,ND
  631. [IDIV,idivX]
  632. (Ch_RWEAX, Ch_WEDX, Ch_WFlags)
  633. rm16|32|64 \320\1\xF7\207 8086
  634. rm8 \1\xF6\207 8086
  635. [IMUL,imulX]
  636. (Ch_RWEAX, Ch_WEDX, Ch_WFlags)
  637. reg16|32|64,regmem \320\2\x0F\xAF\110 386,SM
  638. rm16|32|64 \320\1\xF7\205 8086
  639. reg32|64,regmem,imm8 \320\1\x6B\110\16 286,SM
  640. reg32|64,regmem,imm \320\1\x69\110\42 286,SM,SD,AR2
  641. reg32|64,imm8 \320\1\x6B\100\15 286
  642. reg32,imm \325\1\x69\100\41 286,SD
  643. reg64,imm \326\1\x69\100\255 X86_64
  644. reg16,regmem,imm8 \324\1\x6B\110\16 286,SM
  645. reg16,regmem,imm \324\1\x69\110\32 286,SM,SW,AR2
  646. reg16,imm8 \324\1\x6B\100\15 286
  647. reg16,imm \324\1\x69\100\31 286,SW
  648. rm8 \1\xF6\205 8086
  649. ; 64-bit variant does not exist
  650. [IN,inX]
  651. (Ch_Wop2, Ch_Rop1, Ch_None)
  652. reg_al,imm \1\xE4\25 8086,SB
  653. reg_ax|32,imm \320\1\xE5\25 8086,SB
  654. reg_al,reg_dx \1\xEC 8086
  655. reg_ax|32,reg_dx \320\1\xED 8086
  656. [INC,incX]
  657. (Ch_Mop1, Ch_WFlags, Ch_None)
  658. reg16|32 \320\10\x40 8086,NOX86_64
  659. rm16|32|64 \320\1\xFF\200 8086
  660. rm8 \1\xFE\200 8086
  661. [INSB]
  662. (Ch_WMemEDI, Ch_RWEDI, Ch_REDX)
  663. void \1\x6C 186
  664. [INSD,insl]
  665. (Ch_WMemEDI, Ch_RWEDI, Ch_REDX)
  666. void \325\1\x6D 386
  667. [INSW]
  668. (Ch_WMemEDI, Ch_RWEDI, Ch_REDX)
  669. void \324\1\x6D 186
  670. [INT]
  671. (Ch_All, Ch_None, Ch_None)
  672. imm \1\xCD\24 8086,SB
  673. [INT01]
  674. (Ch_All, Ch_None, Ch_None)
  675. void \1\xF1 386,ND
  676. [INT1]
  677. (Ch_All, Ch_None, Ch_None)
  678. void \1\xF1 386
  679. [INT03]
  680. (Ch_None, Ch_None, Ch_None)
  681. void \1\xCC 8086,ND
  682. [INT3]
  683. (Ch_None, Ch_None, Ch_None)
  684. void \1\xCC 8086
  685. [INTO]
  686. (Ch_All, Ch_None, Ch_None)
  687. void \1\xCE 8086,NOX86_64
  688. [INVD]
  689. (Ch_All, Ch_None, Ch_None)
  690. void \2\x0F\x08 486,PRIV
  691. [INVLPG,invlpgX]
  692. (Ch_All, Ch_None, Ch_None)
  693. mem \2\x0F\x01\207 486,PRIV
  694. [IRET]
  695. (Ch_All, Ch_None, Ch_None)
  696. void \327\1\xCF 8086
  697. [IRETD,iret]
  698. (Ch_All, Ch_None, Ch_None)
  699. void \325\1\xCF 386
  700. [IRETW]
  701. (Ch_All, Ch_None, Ch_None)
  702. void \324\1\xCF 8086
  703. [JCXZ]
  704. (Ch_RECX, Ch_None, Ch_None)
  705. imm \310\1\xE3\50 8086,NOX86_64
  706. [JECXZ]
  707. (Ch_RECX, Ch_None, Ch_None)
  708. imm \311\1\xE3\50 386
  709. [JRCXZ]
  710. (Ch_RECX, Ch_None, Ch_None)
  711. imm \1\xE3\50 X86_64
  712. [JMP,jmpX]
  713. (Ch_ROp1, Ch_None, Ch_None)
  714. imm8 \1\xEB\50 8086,PASS2
  715. imm16|32 \320\1\xE9\64 8086,PASS2
  716. rm16|32|64 \320\1\xFF\204 8086
  717. imm|short \1\xEB\50 8086,PASS2
  718. imm|near \320\1\xE9\64 8086,ND,PASS2
  719. imm|far \320\1\xEA\34\37 8086,ND,PASS2,NOX86_64
  720. mem|near \320\1\xFF\204 8086
  721. mem|far \320\1\xFF\205 8086
  722. imm:imm \327\1\xEA\35\30 8086,NOX86_64
  723. imm:imm16 \324\1\xEA\31\30 8086,NOX86_64
  724. imm:imm32 \325\1\xEA\41\30 386,NOX86_64
  725. ; SAHF/LAHF are valid in x86_64 only if CPUID.80000001h:ECX.0=1
  726. [LAHF]
  727. (Ch_WEAX, Ch_RFlags, Ch_None)
  728. void \1\x9F 8086
  729. [LAR,larX]
  730. (Ch_Wop2, Ch_None, Ch_None)
  731. reg16|32|64,regmem \320\2\x0F\x02\110 286,PROT,SM
  732. [LCALL,lcall]
  733. ; don't know value of any register
  734. (Ch_All, Ch_None, Ch_None)
  735. rm16|32|64 \320\1\xFF\202 8086
  736. mem|near \320\1\xFF\202 8086
  737. mem|far \320\1\xFF\203 8086
  738. [LDS,ldsX]
  739. (Ch_Wop2, Ch_Rop1, Ch_None)
  740. reg16|32,mem \320\1\xC5\110 8086,NOX86_64
  741. [LEA,leaX]
  742. (Ch_Wop2, Ch_Rop1, Ch_None)
  743. reg32|64,mem \320\1\x8D\110 8086
  744. reg32|64,imm \320\1\x8D\110 8086,SD
  745. [LEAVE]
  746. (Ch_RWESP, Ch_WEBP, Ch_None)
  747. void \1\xC9 186
  748. [LES,lesX]
  749. (Ch_Wop2, Ch_Rop1, Ch_None)
  750. reg16|32,mem \320\1\xC4\110 8086,NOX86_64
  751. [LFS,lfsX]
  752. (Ch_Wop2, Ch_Rop1, Ch_None)
  753. reg16|32,mem \320\2\x0F\xB4\110 386
  754. [LGDT,lgdtX]
  755. (Ch_None, Ch_None, Ch_None)
  756. mem \2\x0F\x01\202 286,PRIV
  757. [LGS,lgsX]
  758. (Ch_Wop2, Ch_Rop1, Ch_None)
  759. reg16|32,mem \320\2\x0F\xB5\110 386
  760. [LIDT,lidtX]
  761. (Ch_None, Ch_None, Ch_None)
  762. mem \2\x0F\x01\203 286,PRIV
  763. [LJMP,ljmp]
  764. (Ch_ROp1, Ch_None, Ch_None)
  765. rm16|32|64 \320\1\xFF\205 8086
  766. mem|far \320\1\xFF\205 8086
  767. mem|near \320\1\xFF\204 8086
  768. [LLDT,lldtX]
  769. (Ch_None, Ch_None, Ch_None)
  770. rm16 \2\x0F\x00\202 286,PROT,PRIV
  771. [LMSW,lmswX]
  772. (Ch_None, Ch_None, Ch_None)
  773. rm16 \2\x0F\x01\206 286,PRIV
  774. [LOADALL]
  775. (Ch_All, Ch_None, Ch_None)
  776. void \2\x0F\x07 386,UNDOC
  777. [LOADALL286]
  778. (Ch_All, Ch_None, Ch_None)
  779. void \2\x0F\x05 286,UNDOC
  780. [LOCK]
  781. (Ch_None, Ch_None, Ch_None)
  782. void \1\xF0 8086,PRE
  783. [LODSB]
  784. (Ch_WEAX, Ch_RWESI, Ch_None)
  785. void \1\xAC 8086
  786. [LODSD,lodsl]
  787. (Ch_WEAX, Ch_RWESI, Ch_None)
  788. void \325\1\xAD 386
  789. [LODSW]
  790. (Ch_WEAX, Ch_RWESI, Ch_None)
  791. void \324\1\xAD 8086
  792. [LOOP]
  793. (Ch_RWECX, Ch_None, Ch_None)
  794. imm \312\1\xE2\50 8086
  795. imm,reg_cx \310\1\xE2\50 8086,NOX86_64
  796. imm,reg_ecx|64 \311\1\xE2\50 386
  797. [LOOPE]
  798. (Ch_RWECX, Ch_RFlags, Ch_None)
  799. imm \312\1\xE1\50 8086
  800. imm,reg_cx \310\1\xE1\50 8086,NOX86_64
  801. imm,reg_ecx|64 \311\1\xE1\50 386
  802. [LOOPNE]
  803. (Ch_RWECX, Ch_RFlags, Ch_None)
  804. imm \312\1\xE0\50 8086
  805. imm,reg_cx \310\1\xE0\50 8086,NOX86_64
  806. imm,reg_ecx|64 \311\1\xE0\50 386
  807. [LOOPNZ]
  808. (Ch_RWECX, Ch_RFlags, Ch_None)
  809. imm \312\1\xE0\50 8086
  810. imm,reg_cx \310\1\xE0\50 8086,NOX86_64
  811. imm,reg_ecx|64 \311\1\xE0\50 386
  812. [LOOPZ]
  813. (Ch_RWECX, Ch_RFlags, Ch_None)
  814. imm \312\1\xE1\50 8086
  815. imm,reg_cx \310\1\xE1\50 8086,NOX86_64
  816. imm,reg_ecx|64 \311\1\xE1\50 386
  817. [LSL,lslX]
  818. (Ch_Wop2, Ch_WFlags, Ch_None)
  819. reg16|32|64,regmem \320\2\x0F\x03\110 286,PROT,SM
  820. [LSS,lssX]
  821. (Ch_Wop2, Ch_ROP1, Ch_None)
  822. reg16|32|64,mem \320\2\x0F\xB2\110 386
  823. [LTR,ltrX]
  824. (Ch_None, Ch_None, Ch_None)
  825. rm16 \2\x0F\x00\203 286,PROT,PRIV
  826. [MONITOR]
  827. (Ch_None, Ch_None, Ch_None)
  828. void \3\x0F\x01\xC8 PRESCOTT
  829. reg_eax,reg_ecx,reg_edx \3\x0F\x01\xC8 PRESCOTT,ND
  830. [MOV,movX]
  831. (Ch_Wop2, Ch_Rop1, Ch_None)
  832. mem_offs,reg_ax \324\1\xA3\44 8086,SM
  833. mem_offs,reg_eax \325\1\xA3\44 386,SM
  834. mem_offs,reg_rax \326\1\xA3\44 X86_64,SM
  835. regmem,reg16|32|64 \320\1\x89\101 8086,SM
  836. reg_ax,mem_offs \324\1\xA1\45 8086,SM
  837. reg_eax,mem_offs \325\1\xA1\45 386,SM
  838. reg_rax,mem_offs \326\1\xA1\45 X86_64,SM
  839. reg16|32|64,regmem \320\1\x8B\110 8086,SM
  840. reg32,imm \325\10\xB8\41 386,SD
  841. reg64,imm \326\10\xB8\55 X86_64,SM
  842. rm32,imm \325\1\xC7\200\41 386,SM
  843. rm64,imm \326\1\xC7\200\255 X86_64,SM
  844. reg16,imm \324\10\xB8\31 8086,SW
  845. rm16,imm \324\1\xC7\200\31 8086,SW
  846. mem_offs,reg_al \1\xA2\44 8086,SM
  847. rm8,reg8 \1\x88\101 8086
  848. reg_al,mem_offs \1\xA0\45 8086,SM
  849. reg8,rm8 \1\x8A\110 8086,SM
  850. reg8,imm \10\xB0\21 8086,SB
  851. rm8,imm \1\xC6\200\21 8086,SB
  852. rm16|32,reg_cs \320\1\x8C\201 8086
  853. rm16|32,reg_dess \320\1\x8C\101 8086
  854. rm16|32,reg_fsgs \320\1\x8C\101 386
  855. reg_dess,rm16|32 \321\1\x8E\110 8086,SM
  856. reg_fsgs,rm16|32 \321\1\x8E\110 386,SM
  857. reg32,reg_cr4 \2\x0F\x20\204 PENT,PRIV,NOX86_64
  858. reg32,reg_creg \2\x0F\x20\101 386,PRIV,NOX86_64
  859. reg32,reg_dreg \2\x0F\x21\101 386,PRIV,NOX86_64
  860. reg32,reg_treg \2\x0F\x24\101 386,PRIV,NOX86_64
  861. reg64,reg_cr4 \2\x0F\x20\204 PENT,PRIV,X86_64
  862. reg64,reg_creg \2\x0F\x20\101 386,PRIV,X86_64
  863. reg64,reg_dreg \2\x0F\x21\101 386,PRIV,X86_64
  864. reg64,reg_treg \2\x0F\x24\101 386,PRIV,X86_64
  865. reg_cr4,reg32 \2\x0F\x22\214 PENT,PRIV,NOX86_64
  866. reg_creg,reg32 \2\x0F\x22\110 386,PRIV,NOX86_64
  867. reg_dreg,reg32 \2\x0F\x23\110 386,PRIV,NOX86_64
  868. reg_treg,reg32 \2\x0F\x26\110 386,PRIV,NOX86_64
  869. reg_cr4,reg64 \2\x0F\x22\214 PENT,PRIV,X86_64
  870. reg_creg,reg64 \2\x0F\x22\110 386,PRIV,X86_64
  871. reg_dreg,reg64 \2\x0F\x23\110 386,PRIV,X86_64
  872. reg_treg,reg64 \2\x0F\x26\110 386,PRIV,X86_64
  873. [MOVD,movd]
  874. (Ch_Rop1, Ch_Wop2, Ch_None)
  875. mmxreg,rm32 \2\x0F\x6E\110 PENT,MMX,SD
  876. rm32,mmxreg \2\x0F\x7E\101 PENT,MMX,SD
  877. xmmreg,rm32 \361\2\x0F\x6E\110 WILLAMETTE,SSE2
  878. rm32,xmmreg \361\2\x0F\x7E\101 WILLAMETTE,SSE2
  879. [MOVQ,movq]
  880. (Ch_Rop1, Ch_Wop2, Ch_None)
  881. mmxreg,mmxrm \2\x0F\x6F\110 PENT,MMX,SM
  882. mmxrm,mmxreg \2\x0F\x7F\101 PENT,MMX,SM
  883. mmxreg,rm64 \326\2\x0F\x6E\110 X86_64,MMX
  884. rm64,mmxreg \326\2\x0F\x7E\101 X86_64,MMX
  885. xmmreg,xmmrm \333\2\x0F\x7E\110 WILLAMETTE,SSE2
  886. xmmrm,xmmreg \361\2\x0F\xD6\101 WILLAMETTE,SSE2
  887. xmmreg,reg64 \361\326\2\x0F\x6E\110 WILLAMETTE,SSE2,X86_64
  888. reg64,xmmreg \361\326\2\x0F\x7E\101 WILLAMETTE,SSE2,X86_64
  889. [MOVSB]
  890. (Ch_All, Ch_None, Ch_None)
  891. void \1\xA4 8086
  892. [MOVSD,movsl]
  893. ; Ch_All isn't correct for the sse move, but how can it be solved? (FK)
  894. (Ch_All, Ch_None, Ch_None)
  895. void \325\1\xA5 386
  896. xmmreg,xmmrm \334\2\x0F\x10\110 WILLAMETTE,SSE2
  897. xmmrm,xmmreg \334\2\x0F\x11\101 WILLAMETTE,SSE2
  898. [MOVSQ]
  899. (Ch_All, Ch_None, Ch_None)
  900. void \326\1\xA5 X86_64
  901. [MOVSW]
  902. (Ch_All, Ch_None, Ch_None)
  903. void \324\1\xA5 8086
  904. [MOVSX,movsY]
  905. (Ch_Wop2, Ch_Rop1, Ch_None)
  906. reg32|64,rm16 \320\2\x0F\xBF\110 386
  907. reg16|32|64,rm8 \320\2\x0F\xBE\110 386
  908. [MOVZX,movzY]
  909. (Ch_Wop2, Ch_Rop1, Ch_None)
  910. reg32|64,rm16 \320\2\x0F\xB7\110 386
  911. reg16|32|64,rm8 \320\2\x0F\xB6\110 386
  912. [MUL,mulX]
  913. (Ch_RWEAX, Ch_WEDX, Ch_WFlags)
  914. rm16|32|64 \320\1\xF7\204 8086
  915. rm8 \1\xF6\204 8086
  916. [MWAIT]
  917. (Ch_None, Ch_None, Ch_None)
  918. void \3\x0F\x01\xC9 PRESCOTT
  919. reg_eax,reg_ecx \3\x0F\x01\xC9 PRESCOTT,ND
  920. [NEG,negX]
  921. (Ch_Mop1, Ch_None, Ch_None)
  922. rm16|32|64 \320\1\xF7\203 8086
  923. rm8 \1\xF6\203 8086
  924. [NOP]
  925. (Ch_None, Ch_None, Ch_None)
  926. void \1\x90 8086
  927. [NOT,notX]
  928. (Ch_Mop1, Ch_WFlags, Ch_None)
  929. rm16|32|64 \320\1\xF7\202 8086
  930. rm8 \1\xF6\202 8086
  931. [OR,orX]
  932. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  933. regmem,reg16|32|64 \320\1\x09\101 8086,SM
  934. reg16|32|64,regmem \320\1\x0B\110 8086,SM
  935. rm8,reg8 \1\x08\101 8086
  936. reg8,rm8 \1\x0A\110 8086,SM
  937. rm16|32|64,imm8 \320\1\x83\201\15 8086
  938. reg_eax,imm \325\1\x0D\41 386,SM
  939. reg_rax,imm \326\1\x0D\255 X86_64,SM
  940. rm32,imm \325\1\x81\201\41 386,SM
  941. rm64,imm \326\1\x81\201\255 X86_64,SM
  942. reg_ax,imm \324\1\x0D\31 8086,SW
  943. rm16,imm \324\1\x81\201\31 8086,SW
  944. reg_al,imm \1\x0C\21 8086,SB
  945. rm8,imm \1\x80\201\21 8086,SB
  946. [OUT,outX]
  947. (Ch_Rop1, Ch_Rop2, Ch_None)
  948. imm,reg_al \1\xE6\24 8086,SB
  949. imm,reg_ax \324\1\xE7\24 8086,SB
  950. imm,reg_eax \325\1\xE7\24 386,SB
  951. reg_dx,reg_al \1\xEE 8086
  952. reg_dx,reg_ax \324\1\xEF 8086
  953. reg_dx,reg_eax \325\1\xEF 386
  954. [OUTSB]
  955. (Ch_All, Ch_None, Ch_None)
  956. void \1\x6E 186
  957. [OUTSD,outsl]
  958. (Ch_All, Ch_None, Ch_None)
  959. void \325\1\x6F 386
  960. [OUTSW]
  961. (Ch_All, Ch_None, Ch_None)
  962. void \324\1\x6F 186
  963. [PACKSSDW]
  964. (Ch_All, Ch_None, Ch_None)
  965. mmxreg,mmxrm \2\x0F\x6B\110 PENT,MMX,SM
  966. xmmreg,xmmrm \361\2\x0F\x6B\110 WILLAMETTE,SSE2,SM
  967. [PACKSSWB]
  968. (Ch_All, Ch_None, Ch_None)
  969. mmxreg,mmxrm \2\x0F\x63\110 PENT,MMX,SM
  970. xmmreg,xmmrm \361\2\x0F\x63\110 WILLAMETTE,SSE2,SM
  971. [PACKUSWB]
  972. (Ch_All, Ch_None, Ch_None)
  973. mmxreg,mmxrm \2\x0F\x67\110 PENT,MMX,SM
  974. xmmreg,xmmrm \361\2\x0F\x67\110 WILLAMETTE,SSE2,SM
  975. [PADDB]
  976. (Ch_Mop2, Ch_Rop1, Ch_None)
  977. mmxreg,mmxrm \2\x0F\xFC\110 PENT,MMX,SM
  978. xmmreg,xmmrm \361\2\x0F\xFC\110 WILLAMETTE,SSE2,SM
  979. [PADDD]
  980. (Ch_Mop2, Ch_Rop1, Ch_None)
  981. mmxreg,mmxrm \2\x0F\xFE\110 PENT,MMX,SM
  982. xmmreg,xmmrm \361\2\x0F\xFE\110 WILLAMETTE,SSE2,SM
  983. [PADDSB]
  984. (Ch_Mop2, Ch_Rop1, Ch_None)
  985. mmxreg,mmxrm \2\x0F\xEC\110 PENT,MMX,SM
  986. xmmreg,xmmrm \361\2\x0F\xEC\110 WILLAMETTE,SSE2,SM
  987. [PADDSIW]
  988. (Ch_Mop2, Ch_Rop1, Ch_None)
  989. mmxreg,mmxrm \2\x0F\x51\110 PENT,MMX,SM,CYRIX
  990. [PADDSW]
  991. (Ch_Mop2, Ch_Rop1, Ch_None)
  992. mmxreg,mmxrm \2\x0F\xED\110 PENT,MMX,SM
  993. xmmreg,xmmrm \361\2\x0F\xED\110 WILLAMETTE,SSE2,SM
  994. [PADDUSB]
  995. (Ch_All, Ch_None, Ch_None)
  996. mmxreg,mmxrm \2\x0F\xDC\110 PENT,MMX,SM
  997. xmmreg,xmmrm \361\2\x0F\xDC\110 WILLAMETTE,SSE2,SM
  998. [PADDUSW]
  999. (Ch_All, Ch_None, Ch_None)
  1000. mmxreg,mmxrm \2\x0F\xDD\110 PENT,MMX,SM
  1001. xmmreg,xmmrm \361\2\x0F\xDD\110 WILLAMETTE,SSE2,SM
  1002. [PADDW]
  1003. (Ch_All, Ch_None, Ch_None)
  1004. mmxreg,mmxrm \2\x0F\xFD\110 PENT,MMX,SM
  1005. xmmreg,xmmrm \361\2\x0F\xFD\110 WILLAMETTE,SSE2,SM
  1006. [PAND]
  1007. (Ch_All, Ch_None, Ch_None)
  1008. mmxreg,mmxrm \2\x0F\xDB\110 PENT,MMX,SM
  1009. xmmreg,xmmrm \361\2\x0F\xDB\110 WILLAMETTE,SSE2,SM
  1010. [PANDN]
  1011. (Ch_All, Ch_None, Ch_None)
  1012. mmxreg,mmxrm \2\x0F\xDF\110 PENT,MMX,SM
  1013. xmmreg,xmmrm \361\2\x0F\xDF\110 WILLAMETTE,SSE2,SM
  1014. [PAVEB]
  1015. (Ch_All, Ch_None, Ch_None)
  1016. mmxreg,mmxrm \2\x0F\x50\110 PENT,MMX,SM,CYRIX
  1017. [PAVGUSB]
  1018. (Ch_All, Ch_None, Ch_None)
  1019. mmxreg,mmxrm \2\x0F\x0F\110\01\xBF PENT,3DNOW,SM
  1020. [PCMPEQB]
  1021. (Ch_All, Ch_None, Ch_None)
  1022. mmxreg,mmxrm \2\x0F\x74\110 PENT,MMX,SM
  1023. xmmreg,xmmrm \361\2\x0F\x74\110 WILLAMETTE,SSE2,SM
  1024. [PCMPEQD]
  1025. (Ch_All, Ch_None, Ch_None)
  1026. mmxreg,mmxrm \2\x0F\x76\110 PENT,MMX,SM
  1027. xmmreg,xmmrm \361\2\x0F\x76\110 WILLAMETTE,SSE2,SM
  1028. [PCMPEQW]
  1029. (Ch_All, Ch_None, Ch_None)
  1030. mmxreg,mmxrm \2\x0F\x75\110 PENT,MMX,SM
  1031. xmmreg,xmmrm \361\2\x0F\x75\110 WILLAMETTE,SSE2,SM
  1032. [PCMPGTB]
  1033. (Ch_All, Ch_None, Ch_None)
  1034. mmxreg,mmxrm \2\x0F\x64\110 PENT,MMX,SM
  1035. xmmreg,xmmrm \361\2\x0F\x64\110 WILLAMETTE,SSE2,SM
  1036. [PCMPGTD]
  1037. (Ch_All, Ch_None, Ch_None)
  1038. mmxreg,mmxrm \2\x0F\x66\110 PENT,MMX,SM
  1039. xmmreg,xmmrm \361\2\x0F\x66\110 WILLAMETTE,SSE2,SM
  1040. [PCMPGTW]
  1041. (Ch_All, Ch_None, Ch_None)
  1042. mmxreg,mmxrm \2\x0F\x65\110 PENT,MMX,SM
  1043. xmmreg,xmmrm \361\2\x0F\x65\110 WILLAMETTE,SSE2,SM
  1044. [PDISTIB]
  1045. (Ch_All, Ch_None, Ch_None)
  1046. mmxreg,mem \2\x0F\x54\110 PENT,MMX,SM,CYRIX
  1047. [PF2ID]
  1048. (Ch_All, Ch_None, Ch_None)
  1049. mmxreg,mmxrm \2\x0F\x0F\110\01\x1D PENT,3DNOW,SM
  1050. [PFACC]
  1051. (Ch_All, Ch_None, Ch_None)
  1052. mmxreg,mmxrm \2\x0F\x0F\110\01\xAE PENT,3DNOW,SM
  1053. [PFADD]
  1054. (Ch_All, Ch_None, Ch_None)
  1055. mmxreg,mmxrm \2\x0F\x0F\110\01\x9E PENT,3DNOW,SM
  1056. [PFCMPEQ]
  1057. (Ch_All, Ch_None, Ch_None)
  1058. mmxreg,mmxrm \2\x0F\x0F\110\01\xB0 PENT,3DNOW,SM
  1059. [PFCMPGE]
  1060. (Ch_All, Ch_None, Ch_None)
  1061. mmxreg,mmxrm \2\x0F\x0F\110\01\x90 PENT,3DNOW,SM
  1062. [PFCMPGT]
  1063. (Ch_All, Ch_None, Ch_None)
  1064. mmxreg,mmxrm \2\x0F\x0F\110\01\xA0 PENT,3DNOW,SM
  1065. [PFMAX]
  1066. (Ch_All, Ch_None, Ch_None)
  1067. mmxreg,mmxrm \2\x0F\x0F\110\01\xA4 PENT,3DNOW,SM
  1068. [PFMIN]
  1069. (Ch_All, Ch_None, Ch_None)
  1070. mmxreg,mmxrm \2\x0F\x0F\110\01\x94 PENT,3DNOW,SM
  1071. [PFMUL]
  1072. (Ch_All, Ch_None, Ch_None)
  1073. mmxreg,mmxrm \2\x0F\x0F\110\01\xB4 PENT,3DNOW,SM
  1074. [PFRCP]
  1075. (Ch_All, Ch_None, Ch_None)
  1076. mmxreg,mmxrm \2\x0F\x0F\110\01\x96 PENT,3DNOW,SM
  1077. [PFRCPIT1]
  1078. (Ch_All, Ch_None, Ch_None)
  1079. mmxreg,mmxrm \2\x0F\x0F\110\01\xA6 PENT,3DNOW,SM
  1080. [PFRCPIT2]
  1081. (Ch_All, Ch_None, Ch_None)
  1082. mmxreg,mmxrm \2\x0F\x0F\110\01\xB6 PENT,3DNOW,SM
  1083. [PFRSQIT1]
  1084. (Ch_All, Ch_None, Ch_None)
  1085. mmxreg,mmxrm \2\x0F\x0F\110\01\xA7 PENT,3DNOW,SM
  1086. [PFRSQRT]
  1087. (Ch_All, Ch_None, Ch_None)
  1088. mmxreg,mmxrm \2\x0F\x0F\110\01\x97 PENT,3DNOW,SM
  1089. [PFSUB]
  1090. (Ch_All, Ch_None, Ch_None)
  1091. mmxreg,mmxrm \2\x0F\x0F\110\01\x9A PENT,3DNOW,SM
  1092. [PFSUBR]
  1093. (Ch_All, Ch_None, Ch_None)
  1094. mmxreg,mmxrm \2\x0F\x0F\110\01\xAA PENT,3DNOW,SM
  1095. [PI2FD]
  1096. (Ch_All, Ch_None, Ch_None)
  1097. mmxreg,mmxrm \2\x0F\x0F\110\01\x0D PENT,3DNOW,SM
  1098. [PMACHRIW]
  1099. (Ch_All, Ch_None, Ch_None)
  1100. mmxreg,mem \2\x0F\x5E\110 PENT,MMX,SM,CYRIX
  1101. [PMADDWD]
  1102. (Ch_All, Ch_None, Ch_None)
  1103. mmxreg,mmxrm \2\x0F\xF5\110 PENT,MMX,SM
  1104. xmmreg,xmmrm \361\2\x0F\xF5\110 WILLAMETTE,SM,SSE2
  1105. [PMAGW]
  1106. (Ch_All, Ch_None, Ch_None)
  1107. mmxreg,mmxrm \2\x0F\x52\110 PENT,MMX,SM,CYRIX
  1108. [PMULHRIW]
  1109. (Ch_All, Ch_None, Ch_None)
  1110. mmxreg,mmxrm \2\x0F\x5D\110 PENT,MMX,SM,CYRIX
  1111. [PMULHRWA]
  1112. (Ch_All, Ch_None, Ch_None)
  1113. mmxreg,mmxrm \2\x0F\x0F\110\1\xB7 PENT,3DNOW,SM
  1114. [PMULHRWC]
  1115. (Ch_All, Ch_None, Ch_None)
  1116. mmxreg,mmxrm \2\x0F\x59\110 PENT,MMX,SM,CYRIX
  1117. [PMULHW]
  1118. (Ch_All, Ch_None, Ch_None)
  1119. mmxreg,mmxrm \2\x0F\xE5\110 PENT,MMX,SM
  1120. xmmreg,xmmrm \361\2\x0F\xE5\110 WILLAMETTE,SSE2,SM
  1121. [PMULLW]
  1122. (Ch_All, Ch_None, Ch_None)
  1123. mmxreg,mmxrm \2\x0F\xD5\110 PENT,MMX,SM
  1124. xmmreg,xmmrm \361\2\x0F\xD5\110 WILLAMETTE,SSE2,SM
  1125. [PMVGEZB]
  1126. (Ch_All, Ch_None, Ch_None)
  1127. mmxreg,mem \2\x0F\x5C\110 PENT,MMX,SM,CYRIX
  1128. [PMVLZB]
  1129. (Ch_All, Ch_None, Ch_None)
  1130. mmxreg,mem \2\x0F\x5B\110 PENT,MMX,SM,CYRIX
  1131. [PMVNZB]
  1132. (Ch_All, Ch_None, Ch_None)
  1133. mmxreg,mem \2\x0F\x5A\110 PENT,MMX,SM,CYRIX
  1134. [PMVZB]
  1135. (Ch_All, Ch_None, Ch_None)
  1136. mmxreg,mem \2\x0F\x58\110 PENT,MMX,SM,CYRIX
  1137. [POP,popX]
  1138. (Ch_Wop1, Ch_RWESP, Ch_None)
  1139. reg16 \324\10\x58 8086
  1140. reg32 \325\10\x58 386,NOX86_64
  1141. reg64 \335\10\x58 X86_64
  1142. rm16 \324\1\x8F\200 8086
  1143. rm32 \325\1\x8F\200 386,NOX86_64
  1144. rm64 \335\1\x8F\200 X86_64
  1145. reg_cs \1\x0F 8086,UNDOC,ND
  1146. reg_dess \4 8086,NOX86_64
  1147. reg_fsgs \1\x0F\5\335 386
  1148. [POPA,popaX]
  1149. (Ch_All, Ch_None, Ch_None)
  1150. void \327\1\x61 186,NOX86_64
  1151. [POPAD,popal]
  1152. (Ch_All, Ch_None, Ch_None)
  1153. void \325\1\x61 386,NOX86_64
  1154. [POPAW]
  1155. (Ch_All, Ch_None, Ch_None)
  1156. void \324\1\x61 186,NOX86_64
  1157. [POPF]
  1158. (Ch_RWESP, Ch_WFlags, Ch_None)
  1159. void \327\1\x9D 186,NOX86_64
  1160. void \326\1\x9D X86_64
  1161. [POPFD,popfl]
  1162. (Ch_RWESP, Ch_WFlags, Ch_None)
  1163. void \325\1\x9D 386,NOX86_64
  1164. [POPFW]
  1165. (Ch_RWESP, Ch_WFLAGS, Ch_None)
  1166. void \324\1\x9D 186,NOX86_64
  1167. void \1\x9D X86_64
  1168. [POPFQ]
  1169. (Ch_RWESP, Ch_WFlags, Ch_None)
  1170. void \326\1\x9D X86_64
  1171. [POR]
  1172. (Ch_All, Ch_None, Ch_None)
  1173. mmxreg,mmxrm \2\x0F\xEB\110 PENT,MMX,SM
  1174. xmmreg,xmmreg \361\2\x0F\xEB\110 WILLAMETTE,SSE2,SM
  1175. [PREFETCH,prefetchX]
  1176. (Ch_All, Ch_None, Ch_None)
  1177. mem \2\x0F\x0D\200 PENT,3DNOW,SM
  1178. [PREFETCHW,prefetchwX]
  1179. (Ch_All, Ch_None, Ch_None)
  1180. mem \2\x0F\x0D\201 PENT,3DNOW,SM
  1181. [PSLLD]
  1182. (Ch_All, Ch_None, Ch_None)
  1183. mmxreg,mmxrm \2\x0F\xF2\110 PENT,MMX,SM
  1184. mmxreg,imm \2\x0F\x72\206\25 PENT,MMX,SB,AR1
  1185. xmmreg,xmmrm \361\2\x0F\xF2\110 WILLAMETTE,SSE2,SM
  1186. xmmreg,imm \361\2\x0F\x72\206\25 WILLAMETTE,SSE2,SB,AR1
  1187. [PSLLDQ]
  1188. (Ch_All, Ch_None, Ch_None)
  1189. xmmreg,imm \361\2\x0F\x73\207\25 WILLAMETTE,SSE2,SB,AR1
  1190. [PSLLQ]
  1191. (Ch_All, Ch_None, Ch_None)
  1192. mmxreg,mmxrm \2\x0F\xF3\110 PENT,MMX,SM
  1193. mmxreg,imm \2\x0F\x73\206\25 PENT,MMX,SB,AR1
  1194. xmmreg,xmmrm \361\2\x0F\xF3\110 WILLAMETTE,SSE2,SM
  1195. xmmreg,imm \361\2\x0F\x73\206\25 WILLAMETTE,SSE2,SB,AR1
  1196. [PSLLW]
  1197. (Ch_All, Ch_None, Ch_None)
  1198. mmxreg,mmxrm \2\x0F\xF1\110 PENT,MMX,SM
  1199. mmxreg,imm \2\x0F\x71\206\25 PENT,MMX,SB,AR1
  1200. xmmreg,xmmrm \361\2\x0F\xF1\110 WILLAMETTE,SSE2,SM
  1201. xmmreg,imm \361\2\x0F\x71\206\25 WILLAMETTE,SSE2,SB,AR1
  1202. [PSRAD]
  1203. (Ch_All, Ch_None, Ch_None)
  1204. mmxreg,mmxrm \2\x0F\xE2\110 PENT,MMX,SM
  1205. mmxreg,imm \2\x0F\x72\204\25 PENT,MMX,SB,AR1
  1206. xmmreg,xmmrm \361\2\x0F\xE2\110 WILLAMETTE,SSE2,SM
  1207. xmmreg,imm \361\2\x0F\x72\204\25 WILLAMETTE,SSE2,SB,AR1
  1208. [PSRAW]
  1209. (Ch_All, Ch_None, Ch_None)
  1210. mmxreg,mmxrm \2\x0F\xE1\110 PENT,MMX,SM
  1211. mmxreg,imm \2\x0F\x71\204\25 PENT,MMX,SB,AR1
  1212. xmmreg,xmmrm \361\2\x0F\xE1\110 WILLAMETTE,SSE2,SM
  1213. xmmreg,imm \361\2\x0F\x71\204\25 WILLAMETTE,SSE2,SB,AR1
  1214. [PSRLD]
  1215. (Ch_All, Ch_None, Ch_None)
  1216. mmxreg,mmxrm \2\x0F\xD2\110 PENT,MMX,SM
  1217. mmxreg,imm \2\x0F\x72\202\25 PENT,MMX,SB,AR1
  1218. xmmreg,xmmrm \361\2\x0F\xD2\110 WILLAMETTE,SSE2,SM
  1219. xmmreg,imm \361\2\x0F\x72\202\25 WILLAMETTE,SSE2,SB,AR1
  1220. [PSRLQ]
  1221. (Ch_All, Ch_None, Ch_None)
  1222. mmxreg,mmxrm \2\x0F\xD3\110 PENT,MMX,SM
  1223. mmxreg,imm \2\x0F\x73\202\25 PENT,MMX,SB,AR1
  1224. xmmreg,xmmrm \361\2\x0F\xD3\110 WILLAMETTE,SSE2,SM
  1225. xmmreg,imm \361\2\x0F\x73\202\25 WILLAMETTE,SSE2,SB,AR1
  1226. [PSRLW]
  1227. (Ch_All, Ch_None, Ch_None)
  1228. mmxreg,mmxrm \2\x0F\xD1\110 PENT,MMX,SM
  1229. mmxreg,imm \2\x0F\x71\202\25 PENT,MMX,SB,AR1
  1230. xmmreg,xmmrm \361\2\x0F\xD1\110 WILLAMETTE,SSE2,SM
  1231. xmmreg,imm \361\2\x0F\x71\202\25 WILLAMETTE,SSE2,SB,AR1
  1232. [PSUBB]
  1233. (Ch_All, Ch_None, Ch_None)
  1234. mmxreg,mmxrm \2\x0F\xF8\110 PENT,MMX,SM
  1235. xmmreg,xmmrm \361\2\x0F\xF8\110 WILLAMETTE,SSE2,SM
  1236. [PSUBD]
  1237. (Ch_All, Ch_None, Ch_None)
  1238. mmxreg,mmxrm \2\x0F\xFA\110 PENT,MMX,SM
  1239. xmmreg,xmmrm \361\2\x0F\xFA\110 WILLAMETTE,SSE2,SM
  1240. [PSUBSB]
  1241. (Ch_All, Ch_None, Ch_None)
  1242. mmxreg,mmxrm \2\x0F\xE8\110 PENT,MMX,SM
  1243. xmmreg,xmmrm \361\2\x0F\xE8\110 WILLAMETTE,SSE2,SM
  1244. [PSUBSIW]
  1245. (Ch_All, Ch_None, Ch_None)
  1246. mmxreg,mem \2\x0F\x55\110 PENT,MMX,SM,CYRIX
  1247. mmxreg,mmxreg \2\x0F\x55\110 PENT,MMX,CYRIX
  1248. [PSUBSW]
  1249. (Ch_All, Ch_None, Ch_None)
  1250. mmxreg,mmxrm \2\x0F\xE9\110 PENT,MMX,SM
  1251. xmmreg,xmmrm \361\2\x0F\xE9\110 WILLAMETTE,SSE2,SM
  1252. [PSUBUSB]
  1253. (Ch_All, Ch_None, Ch_None)
  1254. mmxreg,mmxrm \2\x0F\xD8\110 PENT,MMX,SM
  1255. xmmreg,xmmrm \361\2\x0F\xD8\110 WILLAMETTE,SSE2,SM
  1256. [PSUBUSW]
  1257. (Ch_All, Ch_None, Ch_None)
  1258. mmxreg,mmxrm \2\x0F\xD9\110 PENT,MMX,SM
  1259. xmmreg,xmmrm \361\2\x0F\xD9\110 WILLAMETTE,SSE2,SM
  1260. [PSUBW]
  1261. (Ch_All, Ch_None, Ch_None)
  1262. mmxreg,mmxrm \2\x0F\xF9\110 PENT,MMX,SM
  1263. xmmreg,xmmrm \361\2\x0F\xF9\110 WILLAMETTE,SSE2,SM
  1264. [PUNPCKHBW]
  1265. (Ch_All, Ch_None, Ch_None)
  1266. mmxreg,mmxrm \2\x0F\x68\110 PENT,MMX,SM
  1267. xmmreg,xmmrm \361\2\x0F\x68\110 WILLAMETTE,SSE2,SM
  1268. [PUNPCKHDQ]
  1269. (Ch_All, Ch_None, Ch_None)
  1270. mmxreg,mmxrm \2\x0F\x6A\110 PENT,MMX,SM
  1271. xmmreg,xmmrm \361\2\x0F\x6A\110 WILLAMETTE,SSE2,SM
  1272. [PUNPCKHWD]
  1273. (Ch_All, Ch_None, Ch_None)
  1274. mmxreg,mmxrm \2\x0F\x69\110 PENT,MMX,SM
  1275. xmmreg,xmmrm \361\2\x0F\x69\110 WILLAMETTE,SSE2,SM
  1276. [PUNPCKLBW]
  1277. (Ch_All, Ch_None, Ch_None)
  1278. mmxreg,mmxrm \2\x0F\x60\110 PENT,MMX,SM
  1279. xmmreg,xmmrm \361\2\x0F\x60\110 WILLAMETTE,SSE2,SM
  1280. [PUNPCKLDQ]
  1281. (Ch_All, Ch_None, Ch_None)
  1282. mmxreg,mmxrm \2\x0F\x62\110 PENT,MMX,SM
  1283. xmmreg,xmmrm \361\2\x0F\x62\110 WILLAMETTE,SSE2,SM
  1284. [PUNPCKLWD]
  1285. (Ch_All, Ch_None, Ch_None)
  1286. mmxreg,mmxrm \2\x0F\x61\110 PENT,MMX,SM
  1287. xmmreg,xmmrm \361\2\x0F\x61\110 WILLAMETTE,SSE2,SM
  1288. [PUSH,pushX]
  1289. (Ch_Rop1, Ch_RWESP, Ch_None)
  1290. reg16 \324\10\x50 8086
  1291. reg32 \325\10\x50 386,NOX86_64
  1292. reg64 \335\10\x50 X86_64
  1293. rm16 \324\1\xFF\206 8086
  1294. rm32 \325\1\xFF\206 386,NOX86_64
  1295. rm64 \335\1\xFF\206 X86_64
  1296. imm32 \325\1\x68\40\335 386
  1297. imm16 \324\1\x68\30\335 286
  1298. imm8 \1\x6A\14\335 286
  1299. reg_fsgs \1\x0F\7\335 386,NOX86_64
  1300. reg_sreg \6 8086,NOX86_64
  1301. [PUSHA,pushaX]
  1302. (Ch_All, Ch_None, Ch_None)
  1303. void \327\1\x60 186,NOX86_64
  1304. [PUSHAD,pushal]
  1305. (Ch_All, Ch_None, Ch_None)
  1306. void \325\1\x60 386,NOX86_64
  1307. [PUSHAW]
  1308. (Ch_All, Ch_None, Ch_None)
  1309. void \324\1\x60 186,NOX86_64
  1310. [PUSHF]
  1311. (Ch_RWESP, Ch_RFlags, Ch_None)
  1312. void \327\1\x9C 186
  1313. [PUSHFD,pushfl]
  1314. (Ch_RWESP, Ch_RFlags, Ch_None)
  1315. void \325\1\x9C 386,NOX86_64
  1316. [PUSHFW]
  1317. (Ch_RWESP, Ch_RFLAGS, Ch_None)
  1318. void \324\1\x9C 186
  1319. [PUSHFQ]
  1320. (Ch_RWESP, Ch_RFlags, Ch_None)
  1321. void \326\1\x9C X86_64
  1322. [PXOR]
  1323. (Ch_Mop2, Ch_Rop1, Ch_None)
  1324. mmxreg,mmxrm \2\x0F\xEF\110 PENT,MMX,SM
  1325. xmmreg,xmmrm \361\2\x0F\xEF\110 WILLAMETTE,SSE2,SM
  1326. [RCL,rclX]
  1327. (Ch_Mop2, Ch_Rop1, Ch_RWFlags)
  1328. rm16|32|64,unity \320\1\xD1\202 8086
  1329. rm16|32|64,reg_cl \320\1\xD3\202 8086
  1330. rm16|32|64,imm \320\1\xC1\202\25 8086,SB
  1331. rm8,unity \1\xD0\202 8086
  1332. rm8,reg_cl \1\xD2\202 8086
  1333. rm8,imm \1\xC0\202\25 186,SB
  1334. [RCR,rcrX]
  1335. (Ch_Mop2, Ch_Rop1, Ch_RWFlags)
  1336. rm16|32|64,unity \320\1\xD1\203 8086
  1337. rm16|32|64,reg_cl \320\1\xD3\203 8086
  1338. rm16|32|64,imm \320\1\xC1\203\25 8086,SB
  1339. rm8,unity \1\xD0\203 8086
  1340. rm8,reg_cl \1\xD2\203 8086
  1341. rm8,imm \1\xC0\203\25 186,SB
  1342. [RDSHR]
  1343. (Ch_All, Ch_None, Ch_None)
  1344. void \2\x0F\x36 P6,CYRIX,SMM
  1345. [RDMSR]
  1346. (Ch_WEAX, Ch_WEDX, Ch_None)
  1347. void \2\x0F\x32 PENT,PRIV
  1348. [RDPMC]
  1349. (Ch_WEAX, Ch_WEDX, Ch_None)
  1350. void \2\x0F\x33 P6
  1351. [RDTSC]
  1352. (Ch_WEAX, Ch_WEDX, Ch_None)
  1353. void \2\x0F\x31 PENT
  1354. [REP]
  1355. (Ch_RWECX, Ch_RWFlags, Ch_None)
  1356. void \1\xF3 8086,PRE
  1357. [REPE]
  1358. (Ch_RWECX, Ch_RWFlags, Ch_None)
  1359. void \1\xF3 8086,PRE
  1360. [REPNE]
  1361. (Ch_RWECX, Ch_RWFlags, Ch_None)
  1362. void \1\xF2 8086,PRE
  1363. [REPNZ]
  1364. (Ch_RWECX, Ch_RWFLAGS, Ch_None)
  1365. void \1\xF2 8086,PRE
  1366. [REPZ]
  1367. (Ch_RWECX, Ch_RWFLAGS, Ch_None)
  1368. void \1\xF3 8086,PRE
  1369. [RET]
  1370. (Ch_All, Ch_None, Ch_None)
  1371. void \1\xC3 8086
  1372. imm \1\xC2\30 8086,SW
  1373. [RETF,lret]
  1374. (Ch_All, Ch_None, Ch_None)
  1375. void \1\xCB 8086
  1376. imm \1\xCA\30 8086,SW
  1377. [RETN,ret]
  1378. (Ch_All, Ch_None, Ch_None)
  1379. void \1\xC3 8086
  1380. imm \1\xC2\30 8086,SW
  1381. [ROL,rolX]
  1382. (Ch_Mop2, Ch_Rop1, Ch_RWFlags)
  1383. rm16|32|64,unity \320\1\xD1\200 8086
  1384. rm16|32|64,reg_cl \320\1\xD3\200 8086
  1385. rm16|32|64,imm \320\1\xC1\200\25 8086,SB
  1386. rm8,unity \1\xD0\200 8086
  1387. rm8,reg_cl \1\xD2\200 8086
  1388. rm8,imm \1\xC0\200\25 186,SB
  1389. [ROR,rorX]
  1390. (Ch_Mop2, Ch_Rop1, Ch_RWFlags)
  1391. rm16|32|64,unity \320\1\xD1\201 8086
  1392. rm16|32|64,reg_cl \320\1\xD3\201 8086
  1393. rm16|32|64,imm \320\1\xC1\201\25 8086,SB
  1394. rm8,unity \1\xD0\201 8086
  1395. rm8,reg_cl \1\xD2\201 8086
  1396. rm8,imm \1\xC0\201\25 186,SB
  1397. [RSDC]
  1398. (Ch_All, Ch_None, Ch_None)
  1399. reg_sreg,mem80 \2\x0F\x79\101 486,CYRIX,SMM
  1400. [RSLDT]
  1401. (Ch_All, Ch_None, Ch_None)
  1402. mem80 \2\x0F\x7B\200 486,CYRIX,SMM
  1403. [RSM]
  1404. (Ch_All, Ch_None, Ch_None)
  1405. void \2\x0F\xAA PENT,SMM
  1406. ; SAHF/LAHF are valid in x86_64 only if CPUID.80000001h:ECX.0=1
  1407. [SAHF]
  1408. (Ch_WFlags, Ch_REAX, Ch_None)
  1409. void \1\x9E 8086
  1410. [SAL,salX]
  1411. (Ch_Mop2, Ch_Rop1, Ch_RWFlags)
  1412. rm16|32|64,unity \320\1\xD1\204 8086,ND
  1413. rm16|32|64,reg_cl \320\1\xD3\204 8086,ND
  1414. rm16|32|64,imm \320\1\xC1\204\25 8086,ND,SB
  1415. rm8,unity \1\xD0\204 8086,ND
  1416. rm8,reg_cl \1\xD2\204 8086,ND
  1417. rm8,imm \1\xC0\204\25 186,ND,SB
  1418. [SALC]
  1419. (Ch_WEAX, Ch_RFLAGS, Ch_None)
  1420. void \1\xD6 8086,UNDOC,NOX86_64
  1421. [SAR,sarX]
  1422. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  1423. rm16|32|64,unity \320\1\xD1\207 8086
  1424. rm16|32|64,reg_cl \320\1\xD3\207 8086
  1425. rm16|32|64,imm \320\1\xC1\207\25 8086,SB
  1426. rm8,unity \1\xD0\207 8086
  1427. rm8,reg_cl \1\xD2\207 8086
  1428. rm8,imm \1\xC0\207\25 186,SB
  1429. [SBB,sbbX]
  1430. (Ch_Mop2, Ch_Rop1, Ch_RWFlags)
  1431. regmem,reg16|32|64 \320\1\x19\101 8086,SM
  1432. reg16|32|64,regmem \320\1\x1B\110 8086,SM
  1433. rm16|32|64,imm8 \320\1\x83\203\15 8086
  1434. rm8,reg8 \1\x18\101 8086
  1435. reg8,rm8 \1\x1A\110 8086,SM
  1436. reg_eax,imm \325\1\x1D\41 386,SM
  1437. reg_rax,imm \326\1\x1D\255 X86_64,SM
  1438. rm32,imm \320\1\x81\203\41 386,SM
  1439. rm64,imm \326\1\x81\203\255 X86_64,SM
  1440. reg_ax,imm \324\1\x1D\31 8086,SW
  1441. rm16,imm \320\1\x81\203\31 8086,SW
  1442. reg_al,imm \1\x1C\21 8086,SB
  1443. rm8,imm \1\x80\203\21 8086,SB
  1444. [SCASB]
  1445. (Ch_All, Ch_None, Ch_None)
  1446. void \332\1\xAE 8086
  1447. [SCASD,scasl]
  1448. (Ch_All, Ch_None, Ch_None)
  1449. void \332\325\1\xAF 386
  1450. [SCASQ]
  1451. (Ch_All, Ch_None, Ch_None)
  1452. void \332\326\1\xAF X86_64
  1453. [SCASW]
  1454. (Ch_All, Ch_None, Ch_None)
  1455. void \332\324\1\xAF 8086
  1456. [SEGCS,cs]
  1457. (Ch_None, Ch_None, Ch_None)
  1458. void \1\x2E 8086,PRE
  1459. [SEGDS,ds]
  1460. (Ch_None, Ch_None, Ch_None)
  1461. void \1\x3E 8086,PRE
  1462. [SEGES,es]
  1463. (Ch_None, Ch_None, Ch_None)
  1464. void \1\x26 8086,PRE
  1465. [SEGFS,fs]
  1466. (Ch_None, Ch_None, Ch_None)
  1467. void \1\x64 8086,PRE
  1468. [SEGGS,gs]
  1469. (Ch_None, Ch_None, Ch_None)
  1470. void \1\x65 8086,PRE
  1471. [SEGSS,ss]
  1472. (Ch_None, Ch_None, Ch_None)
  1473. void \1\x36 8086,PRE
  1474. [SGDT]
  1475. (Ch_Wop1, Ch_None, Ch_None)
  1476. mem \2\x0F\x01\200 286
  1477. [SHL,shlX]
  1478. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  1479. rm16|32|64,unity \320\1\xD1\204 8086
  1480. rm16|32|64,reg_cl \320\1\xD3\204 8086
  1481. rm16|32|64,imm \320\1\xC1\204\25 186,SW
  1482. rm8,unity \1\xD0\204 8086
  1483. rm8,reg_cl \1\xD2\204 8086
  1484. rm8,imm \1\xC0\204\25 186,SB
  1485. [SHLD,shldX]
  1486. (Ch_MOp3, Ch_RWFlags, Ch_Rop2)
  1487. rm16|32|64,reg16|32|64,imm \321\2\x0F\xA4\101\26 386,SM2,SB,AR2
  1488. rm16|32|64,reg16|32|64,reg_cl \321\2\x0F\xA5\101 386,SM
  1489. [SHR,shrX]
  1490. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  1491. rm16|32|64,unity \320\1\xD1\205 8086
  1492. rm16|32|64,reg_cl \320\1\xD3\205 8086
  1493. rm16|32|64,imm \320\1\xC1\205\25 186,SW
  1494. rm8,unity \1\xD0\205 8086
  1495. rm8,reg_cl \1\xD2\205 8086
  1496. rm8,imm \1\xC0\205\25 186,SB
  1497. [SHRD,shrdX]
  1498. (Ch_MOp3, Ch_RWFlags, Ch_Rop2)
  1499. rm16|32|64,reg16|32|64,imm \321\2\x0F\xAC\101\26 386,SM2,SB,AR2
  1500. rm16|32|64,reg16|32|64,reg_cl \321\2\x0F\xAD\101 386,SM
  1501. [SIDT,sidtX]
  1502. (Ch_Wop1, Ch_None, Ch_None)
  1503. mem \2\x0F\x01\201 286
  1504. [SLDT,sldtX]
  1505. (Ch_Wop1, Ch_None, Ch_None)
  1506. mem \2\x0F\x00\200 286
  1507. reg16|32|64 \320\2\x0F\x00\200 286
  1508. [SMI]
  1509. (Ch_All, Ch_None, Ch_None)
  1510. void \1\xF1 386,UNDOC
  1511. [SMINT]
  1512. (Ch_All, Ch_None, Ch_None)
  1513. void \2\x0F\x38 P6,CYRIX
  1514. [SMINTOLD]
  1515. (Ch_All, Ch_None, Ch_None)
  1516. void \2\x0F\x7E 486,CYRIX,ND
  1517. [SMSW,smswX]
  1518. (Ch_Wop1, Ch_None, Ch_None)
  1519. rm16|32|64 \320\2\x0F\x01\204 286
  1520. [STC]
  1521. (Ch_WFlags, Ch_None, Ch_None)
  1522. void \1\xF9 8086
  1523. [STD]
  1524. (Ch_SDirFlag, Ch_None, Ch_None)
  1525. void \1\xFD 8086
  1526. [STI]
  1527. (Ch_WFlags, Ch_None, Ch_None)
  1528. void \1\xFB 8086
  1529. [STOSB]
  1530. (Ch_REAX, Ch_WMemEDI, Ch_RWEDI)
  1531. void \1\xAA 8086
  1532. [STOSD,stosl]
  1533. (Ch_REAX, Ch_WMemEDI, Ch_RWEDI)
  1534. void \325\1\xAB 386
  1535. [STOSW]
  1536. (Ch_REAX, Ch_WMemEDI, Ch_RWEDI)
  1537. void \324\1\xAB 8086
  1538. [STR,strX]
  1539. (Ch_Wop1, Ch_None, Ch_None)
  1540. mem \2\x0F\x00\201 286,PROT
  1541. reg16|32|64 \320\2\x0F\x00\201 286,PROT
  1542. [SUB,subX]
  1543. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  1544. regmem,reg16|32|64 \320\1\x29\101 8086,SM
  1545. reg16|32|64,regmem \320\1\x2B\110 8086,SM
  1546. rm8,reg8 \1\x28\101 8086
  1547. reg8,rm8 \1\x2A\110 8086,SM
  1548. rm16|32|64,imm8 \320\1\x83\205\15 8086
  1549. reg_eax,imm \325\1\x2D\41 386,SM
  1550. reg_rax,imm \326\1\x2D\255 X86_64,SM
  1551. rm32,imm \320\1\x81\205\41 386,SM
  1552. rm64,imm \326\1\x81\205\255 X86_64,SM
  1553. reg_ax,imm \324\1\x2D\31 8086,SW
  1554. rm16,imm \324\1\x81\205\31 8086,SW
  1555. reg_al,imm \1\x2C\21 8086,SB
  1556. rm8,imm \1\x80\205\21 8086,SB
  1557. [SVDC,svdcX]
  1558. (Ch_All, Ch_None, Ch_None)
  1559. mem80,reg_sreg \2\x0F\x78\101 486,CYRIX,SMM
  1560. [SVLDT,svldtX]
  1561. (Ch_All, Ch_None, Ch_None)
  1562. mem80 \2\x0F\x7A\200 486,CYRIX,SMM
  1563. [SVTS,svtsX]
  1564. (Ch_All, Ch_None, Ch_None)
  1565. mem80 \2\x0F\x7C\200 486,CYRIX,SMM
  1566. [SYSCALL]
  1567. (Ch_All, Ch_None, Ch_None)
  1568. void \2\x0F\x05 P6,AMD
  1569. [SYSENTER]
  1570. (Ch_All, Ch_None, Ch_None)
  1571. void \2\x0F\x34 P6
  1572. [SYSEXIT]
  1573. (Ch_All, Ch_None, Ch_None)
  1574. void \2\x0F\x35 P6,PRIV
  1575. [SYSRET]
  1576. (Ch_All, Ch_None, Ch_None)
  1577. void \2\x0F\x07 P6,PRIV,AMD
  1578. [TEST,testX]
  1579. (Ch_WFlags, Ch_Rop1, Ch_Rop2)
  1580. regmem,reg16|32|64 \320\1\x85\101 8086,SM
  1581. reg16|32|64,mem \320\1\x85\110 8086,SM
  1582. reg8,reg8 \1\x84\101 8086
  1583. rm8,reg8 \1\x84\101 8086,SM
  1584. reg_rax,imm \326\1\xA9\255 X86_64,SM
  1585. reg_eax,imm \325\1\xA9\41 386,SM
  1586. reg_ax,imm \324\1\xA9\31 8086,SM
  1587. reg_al,imm \1\xA8\21 8086,SM
  1588. rm64,imm \326\1\xF7\200\255 X86_64,SM
  1589. rm32,imm \325\1\xF7\200\41 386,SM
  1590. rm16,imm \324\1\xF7\200\31 8086,SM
  1591. rm8,imm \1\xF6\200\21 8086,SM
  1592. mem,imm32 \325\1\xF7\200\41 386,SM
  1593. mem,imm16 \324\1\xF7\200\31 8086,SM
  1594. mem,imm8 \1\xF6\200\21 8086,SM
  1595. [UD1]
  1596. (Ch_All, Ch_None, Ch_None)
  1597. void \2\x0F\xB9 286,UNDOC
  1598. [UD2]
  1599. (Ch_All, Ch_None, Ch_None)
  1600. void \2\x0F\x0B 286
  1601. [UMOV,umovX]
  1602. (Ch_All, Ch_None, Ch_None)
  1603. regmem,reg16|32|64 \320\2\x0F\x11\101 386,UNDOC,SM
  1604. reg16|32|64,mem \320\2\x0F\x13\110 386,UNDOC,SM
  1605. rm8,reg8 \2\x0F\x10\101 386,UNDOC
  1606. reg8,rm8 \2\x0F\x12\110 386,UNDOC
  1607. [VERR,verrX]
  1608. (Ch_WFlags, Ch_None, Ch_None)
  1609. mem \2\x0F\x00\204 286,PROT
  1610. mem16 \2\x0F\x00\204 286,PROT
  1611. reg16 \2\x0F\x00\204 286,PROT
  1612. [VERW]
  1613. (Ch_WFlags, Ch_None, Ch_None)
  1614. mem \2\x0F\x00\205 286,PROT
  1615. mem16 \2\x0F\x00\205 286,PROT
  1616. reg16 \2\x0F\x00\205 286,PROT
  1617. [WAIT]
  1618. (Ch_None, Ch_None, Ch_None)
  1619. void \1\x9B 8086
  1620. [WBINVD]
  1621. (Ch_None, Ch_None, Ch_None)
  1622. void \2\x0F\x09 486,PRIV
  1623. [WRSHR]
  1624. (Ch_All, Ch_None, Ch_None)
  1625. void \2\x0F\x37 P6,CYRIX,SMM
  1626. [WRMSR]
  1627. (Ch_All, Ch_None, Ch_None)
  1628. void \2\x0F\x30 PENT,PRIV
  1629. [XADD,xaddX]
  1630. (Ch_All, Ch_None, Ch_None)
  1631. mem,reg16|32|64 \320\2\x0F\xC1\101 486,SM
  1632. rm8,reg8 \2\x0F\xC0\101 486
  1633. [XBTS,xbtsX]
  1634. (Ch_All, Ch_None, Ch_None)
  1635. reg16,mem \324\2\x0F\xA6\110 386,SW,UNDOC,ND
  1636. reg16,reg16 \324\2\x0F\xA6\110 386,UNDOC,ND
  1637. reg32,mem \325\2\x0F\xA6\110 386,SD,UNDOC,ND
  1638. reg32,reg32 \325\2\x0F\xA6\110 386,UNDOC,ND
  1639. [XCHG,xchgX]
  1640. (Ch_RWop1, Ch_RWop2, Ch_None)
  1641. reg_ax,reg16 \324\11\x90 8086
  1642. reg_eax,reg32 \325\11\x90 386
  1643. reg_rax,reg64 \326\11\x90 X86_64
  1644. reg16,reg_ax \324\10\x90 8086
  1645. reg32,reg_eax \325\10\x90 386
  1646. reg64,reg_rax \326\10\x90 X86_64
  1647. reg16|32|64,regmem \320\1\x87\110 8086,SM
  1648. mem,reg16|32|64 \320\1\x87\101 8086,SM
  1649. reg8,rm8 \1\x86\110 8086
  1650. mem8,reg8 \1\x86\101 8086
  1651. [XLAT]
  1652. (Ch_WEAX, Ch_REBX, Ch_None)
  1653. void \1\xD7 8086
  1654. [XLATB]
  1655. (Ch_WEAX, Ch_REBX, Ch_None)
  1656. void \1\xD7 8086
  1657. [XOR,xorX]
  1658. (Ch_Mop2, Ch_Rop1, Ch_WFlags)
  1659. regmem,reg16|32|64 \320\1\x31\101 8086,SM
  1660. reg16|32|64,regmem \320\1\x33\110 8086,SM
  1661. rm8,reg8 \1\x30\101 8086
  1662. reg8,rm8 \1\x32\110 8086
  1663. rm16|32|64,imm8 \320\1\x83\206\15 8086
  1664. reg_eax,imm \325\1\x35\41 386,SM
  1665. reg_rax,imm \326\1\x35\255 X86_64,SM
  1666. rm32,imm \320\1\x81\206\41 386,SM
  1667. rm64,imm \326\1\x81\206\255 X86_64,SM
  1668. reg_ax,imm \324\1\x35\31 8086,SW
  1669. rm16,imm \324\1\x81\206\31 8086,SW
  1670. reg_al,imm \1\x34\21 8086,SB
  1671. rm8,imm \1\x80\206\21 8086,SB
  1672. [XSTORE]
  1673. (Ch_All, Ch_None, Ch_None)
  1674. void \3\x0F\xA7\xC0 P6,CYRIX
  1675. [XCRYPTECB]
  1676. (Ch_All, Ch_None, Ch_None)
  1677. void \333\3\x0F\xA7\xC8 P6,CYRIX
  1678. [XCRYPTCBC]
  1679. (Ch_All, Ch_None, Ch_None)
  1680. void \333\3\x0F\xA7\xD0 P6,CYRIX
  1681. [XCRYPTCFB]
  1682. (Ch_All, Ch_None, Ch_None)
  1683. void \333\3\x0F\xA7\xE0 P6,CYRIX
  1684. [XCRYPTOFB]
  1685. (Ch_All, Ch_None, Ch_None)
  1686. void \333\3\x0F\xA7\xE8 P6,CYRIX
  1687. [CMOVcc,cmovCCX]
  1688. (Ch_ROp1, Ch_WOp2, Ch_RFLAGS)
  1689. reg16|32|64,regmem \320\1\x0F\13\x40\110 P6,SM
  1690. [Jcc]
  1691. (Ch_RFLAGS, Ch_None, Ch_None)
  1692. imm8 \13\x70\50 8086
  1693. imm16|32 \320\1\x0F\13\x80\64 386,PASS2
  1694. imm|short \13\x70\50 8086
  1695. imm|near \320\1\x0F\13\x80\64 386,PASS2
  1696. [SETcc,setCCX]
  1697. (Ch_RFLAGS, Ch_WOp1, Ch_None)
  1698. rm8 \1\x0F\13\x90\200 386
  1699. ;
  1700. ; Katmai Streaming SIMD instructions (SSE -- a.k.a. KNI, XMM, MMX2)
  1701. ;
  1702. [ADDPS]
  1703. (Ch_Mop2, Ch_Rop1, Ch_None)
  1704. xmmreg,xmmrm \331\2\x0F\x58\110 KATMAI,SSE
  1705. [ADDSS]
  1706. (Ch_Mop2, Ch_Rop1, Ch_None)
  1707. xmmreg,xmmrm \333\2\x0F\x58\110 KATMAI,SSE
  1708. [ANDNPS]
  1709. (Ch_Mop2, Ch_Rop1, Ch_None)
  1710. xmmreg,xmmrm \2\x0F\x55\110 KATMAI,SSE
  1711. [ANDPS]
  1712. (Ch_Mop2, Ch_Rop1, Ch_None)
  1713. xmmreg,xmmrm \2\x0F\x54\110 KATMAI,SSE
  1714. [CMPEQPS]
  1715. (Ch_All, Ch_None, Ch_None)
  1716. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x00 KATMAI,SSE
  1717. [CMPEQSS]
  1718. (Ch_All, Ch_None, Ch_None)
  1719. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x00 KATMAI,SSE
  1720. [CMPLEPS]
  1721. (Ch_All, Ch_None, Ch_None)
  1722. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x02 KATMAI,SSE
  1723. [CMPLESS]
  1724. (Ch_All, Ch_None, Ch_None)
  1725. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x02 KATMAI,SSE
  1726. [CMPLTPS]
  1727. (Ch_All, Ch_None, Ch_None)
  1728. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x01 KATMAI,SSE
  1729. [CMPLTSS]
  1730. (Ch_All, Ch_None, Ch_None)
  1731. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x01 KATMAI,SSE
  1732. [CMPNEQPS]
  1733. (Ch_All, Ch_None, Ch_None)
  1734. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x04 KATMAI,SSE
  1735. [CMPNEQSS]
  1736. (Ch_All, Ch_None, Ch_None)
  1737. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x04 KATMAI,SSE
  1738. [CMPNLEPS]
  1739. (Ch_All, Ch_None, Ch_None)
  1740. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x06 KATMAI,SSE
  1741. [CMPNLESS]
  1742. (Ch_All, Ch_None, Ch_None)
  1743. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x06 KATMAI,SSE
  1744. [CMPNLTPS]
  1745. (Ch_All, Ch_None, Ch_None)
  1746. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x05 KATMAI,SSE
  1747. [CMPNLTSS]
  1748. (Ch_All, Ch_None, Ch_None)
  1749. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x05 KATMAI,SSE
  1750. [CMPORDPS]
  1751. (Ch_All, Ch_None, Ch_None)
  1752. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x07 KATMAI,SSE
  1753. [CMPORDSS]
  1754. (Ch_All, Ch_None, Ch_None)
  1755. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x07 KATMAI,SSE
  1756. [CMPUNORDPS]
  1757. (Ch_All, Ch_None, Ch_None)
  1758. xmmreg,xmmrm \331\2\x0F\xC2\110\1\x03 KATMAI,SSE
  1759. [CMPUNORDSS]
  1760. (Ch_All, Ch_None, Ch_None)
  1761. xmmreg,xmmrm \333\2\x0F\xC2\110\1\x03 KATMAI,SSE
  1762. ;
  1763. ; CMPPS/CMPSS must come after the specific ops; that way the disassembler will find the
  1764. ; specific ops first and only disassemble illegal ones as cmpps.
  1765. ;
  1766. [CMPPS]
  1767. (Ch_All, Ch_None, Ch_None)
  1768. xmmreg,xmmrm,imm \331\2\x0F\xC2\110\22 KATMAI,SSE,SB,AR2
  1769. [CMPSS]
  1770. (Ch_All, Ch_None, Ch_None)
  1771. xmmreg,xmmrm,imm \333\2\x0F\xC2\110\22 KATMAI,SSE,SB,AR2
  1772. [COMISS]
  1773. (Ch_All, Ch_None, Ch_None)
  1774. xmmreg,xmmrm \2\x0F\x2F\110 KATMAI,SSE
  1775. [CVTPI2PS]
  1776. (Ch_Wop2, Ch_Rop1, Ch_None)
  1777. xmmreg,mem \331\2\x0F\x2A\110 KATMAI,SSE,MMX
  1778. xmmreg,mmxreg \331\2\x0F\x2A\110 KATMAI,SSE,MMX
  1779. [CVTPS2PI]
  1780. (Ch_Wop2, Ch_Rop1, Ch_None)
  1781. mmxreg,mem \331\2\x0F\x2D\110 KATMAI,SSE,MMX
  1782. mmxreg,xmmreg \331\2\x0F\x2D\110 KATMAI,SSE,MMX
  1783. [CVTSI2SS,cvtsi2ssX]
  1784. (Ch_Wop2, Ch_Rop1, Ch_None)
  1785. xmmreg,mem \333\321\2\x0F\x2A\110 KATMAI,SSE
  1786. xmmreg,reg32|64 \333\321\2\x0F\x2A\110 KATMAI,SSE
  1787. [CVTSS2SI,cvtss2siX]
  1788. (Ch_Wop2, Ch_Rop1, Ch_None)
  1789. reg32|64,mem \333\320\2\x0F\x2D\110 KATMAI,SSE
  1790. reg32|64,xmmreg \333\320\2\x0F\x2D\110 KATMAI,SSE
  1791. [CVTTPS2PI]
  1792. (Ch_Wop2, Ch_Rop1, Ch_None)
  1793. mmxreg,mem \331\2\x0F\x2C\110 KATMAI,SSE,MMX
  1794. mmxreg,xmmreg \331\2\x0F\x2C\110 KATMAI,SSE,MMX
  1795. [CVTTSS2SI,cvttss2siX]
  1796. (Ch_Wop2, Ch_Rop1, Ch_None)
  1797. reg32|64,mem \333\320\2\x0F\x2C\110 KATMAI,SSE
  1798. reg32|64,xmmreg \333\320\2\x0F\x2C\110 KATMAI,SSE
  1799. [DIVPS]
  1800. (Ch_Mop2, Ch_Rop1, Ch_None)
  1801. xmmreg,xmmrm \331\2\x0F\x5E\110 KATMAI,SSE
  1802. [DIVSS]
  1803. (Ch_Mop2, Ch_Rop1, Ch_None)
  1804. xmmreg,xmmrm \333\2\x0F\x5E\110 KATMAI,SSE
  1805. [LDMXCSR]
  1806. (Ch_All, Ch_None, Ch_None)
  1807. mem \2\x0F\xAE\202 KATMAI,SSE,SD
  1808. [MAXPS]
  1809. (Ch_All, Ch_None, Ch_None)
  1810. xmmreg,xmmrm \331\2\x0F\x5F\110 KATMAI,SSE
  1811. [MAXSS]
  1812. (Ch_All, Ch_None, Ch_None)
  1813. xmmreg,xmmrm \333\2\x0F\x5F\110 KATMAI,SSE
  1814. [MINPS]
  1815. (Ch_All, Ch_None, Ch_None)
  1816. xmmreg,xmmrm \331\2\x0F\x5D\110 KATMAI,SSE
  1817. [MINSS]
  1818. (Ch_All, Ch_None, Ch_None)
  1819. xmmreg,xmmrm \333\2\x0F\x5D\110 KATMAI,SSE
  1820. [MOVAPS]
  1821. (Ch_ROp1, Ch_WOp2, Ch_None)
  1822. xmmreg,xmmrm \2\x0F\x28\110 KATMAI,SSE
  1823. xmmrm,xmmreg \2\x0F\x29\101 KATMAI,SSE
  1824. [MOVHPS]
  1825. (Ch_All, Ch_None, Ch_None)
  1826. xmmreg,mem \2\x0F\x16\110 KATMAI,SSE
  1827. mem,xmmreg \2\x0F\x17\101 KATMAI,SSE
  1828. [MOVLHPS]
  1829. (Ch_All, Ch_None, Ch_None)
  1830. xmmreg,xmmreg \2\x0F\x16\110 KATMAI,SSE
  1831. [MOVLPS]
  1832. (Ch_All, Ch_None, Ch_None)
  1833. xmmreg,mem \2\x0F\x12\110 KATMAI,SSE
  1834. mem,xmmreg \2\x0F\x13\101 KATMAI,SSE
  1835. [MOVHLPS]
  1836. (Ch_All, Ch_None, Ch_None)
  1837. xmmreg,xmmreg \2\x0F\x12\110 KATMAI,SSE
  1838. [MOVMSKPS]
  1839. (Ch_All, Ch_None, Ch_None)
  1840. reg32,xmmreg \2\x0F\x50\110 KATMAI,SSE
  1841. [MOVNTPS]
  1842. (Ch_All, Ch_None, Ch_None)
  1843. mem,xmmreg \2\x0F\x2B\101 KATMAI,SSE
  1844. [MOVSS]
  1845. (Ch_Wop2, Ch_Rop1, Ch_None)
  1846. xmmreg,xmmrm \333\2\x0F\x10\110 KATMAI,SSE
  1847. xmmrm,xmmreg \333\2\x0F\x11\101 KATMAI,SSE
  1848. [MOVUPS]
  1849. (Ch_All, Ch_None, Ch_None)
  1850. xmmreg,xmmrm \331\2\x0F\x10\110 KATMAI,SSE
  1851. xmmrm,xmmreg \331\2\x0F\x11\101 KATMAI,SSE
  1852. [MULPS]
  1853. (Ch_Mop2, Ch_Rop1, Ch_None)
  1854. xmmreg,xmmrm \2\x0F\x59\110 KATMAI,SSE
  1855. [MULSS]
  1856. (Ch_Mop2, Ch_Rop1, Ch_None)
  1857. xmmreg,xmmrm \333\2\x0F\x59\110 KATMAI,SSE
  1858. [ORPS]
  1859. (Ch_Mop2, Ch_Rop1, Ch_None)
  1860. xmmreg,xmmrm \2\x0F\x56\110 KATMAI,SSE
  1861. [RCPPS]
  1862. (Ch_All, Ch_None, Ch_None)
  1863. xmmreg,xmmrm \331\2\x0F\x53\110 KATMAI,SSE
  1864. [RCPSS]
  1865. (Ch_All, Ch_None, Ch_None)
  1866. xmmreg,xmmrm \333\2\x0F\x53\110 KATMAI,SSE
  1867. [RSQRTPS]
  1868. (Ch_All, Ch_None, Ch_None)
  1869. xmmreg,xmmrm \331\2\x0F\x52\110 KATMAI,SSE
  1870. [RSQRTSS]
  1871. (Ch_All, Ch_None, Ch_None)
  1872. xmmreg,xmmrm \333\2\x0F\x52\110 KATMAI,SSE
  1873. [SHUFPS]
  1874. (Ch_All, Ch_None, Ch_None)
  1875. xmmreg,xmmrm,imm \2\x0F\xC6\110\22 KATMAI,SSE,SB,AR2
  1876. [SQRTPS]
  1877. (Ch_Mop2, Ch_Rop1, Ch_None)
  1878. xmmreg,xmmrm \331\2\x0F\x51\110 KATMAI,SSE
  1879. [SQRTSS]
  1880. (Ch_Mop2, Ch_Rop1, Ch_None)
  1881. xmmreg,xmmrm \333\2\x0F\x51\110 KATMAI,SSE
  1882. [STMXCSR]
  1883. (Ch_All, Ch_None, Ch_None)
  1884. mem \2\x0F\xAE\203 KATMAI,SSE,SD
  1885. [SUBPS]
  1886. (Ch_Mop2, Ch_Rop1, Ch_None)
  1887. xmmreg,xmmrm \331\2\x0F\x5C\110 KATMAI,SSE
  1888. [SUBSS]
  1889. (Ch_Mop2, Ch_Rop1, Ch_None)
  1890. xmmreg,xmmrm \333\2\x0F\x5C\110 KATMAI,SSE
  1891. [UCOMISS]
  1892. (Ch_All, Ch_None, Ch_None)
  1893. xmmreg,xmmrm \2\x0F\x2E\110 KATMAI,SSE
  1894. [UNPCKHPS]
  1895. (Ch_All, Ch_None, Ch_None)
  1896. xmmreg,xmmrm \2\x0F\x15\110 KATMAI,SSE
  1897. [UNPCKLPS]
  1898. (Ch_All, Ch_None, Ch_None)
  1899. xmmreg,xmmrm \2\x0F\x14\110 KATMAI,SSE
  1900. [XORPS]
  1901. (Ch_Mop2, Ch_Rop1, Ch_None)
  1902. xmmreg,xmmrm \2\x0F\x57\110 KATMAI,SSE
  1903. ;
  1904. ; Introduced in Dechutes but necessary for SSE support
  1905. ;
  1906. [FXRSTOR]
  1907. (Ch_All, Ch_None, Ch_None)
  1908. mem \2\x0F\xAE\201 P6,SSE,FPU
  1909. [FXSAVE]
  1910. (Ch_All, Ch_None, Ch_None)
  1911. mem \2\x0F\xAE\200 P6,SSE,FPU
  1912. ;
  1913. ; These instructions aren't SSE-specific; they are generic memory operations
  1914. ; and work even if CR4.OSFXFR == 0
  1915. ;
  1916. [PREFETCHNTA]
  1917. (Ch_All, Ch_None, Ch_None)
  1918. mem \2\x0F\x18\200 KATMAI
  1919. [PREFETCHT0]
  1920. (Ch_All, Ch_None, Ch_None)
  1921. mem \2\x0F\x18\201 KATMAI
  1922. [PREFETCHT1]
  1923. (Ch_All, Ch_None, Ch_None)
  1924. mem \2\x0F\x18\202 KATMAI
  1925. [PREFETCHT2]
  1926. (Ch_All, Ch_None, Ch_None)
  1927. mem \2\x0F\x18\203 KATMAI
  1928. [SFENCE]
  1929. (Ch_All, Ch_None, Ch_None)
  1930. void \3\x0F\xAE\xF8 KATMAI
  1931. ;
  1932. ; New MMX instructions introduced in Katmai
  1933. ;
  1934. [MASKMOVQ]
  1935. (Ch_All, Ch_None, Ch_None)
  1936. mmxreg,mmxreg \2\x0F\xF7\110 KATMAI,MMX
  1937. [MOVNTQ]
  1938. (Ch_All, Ch_None, Ch_None)
  1939. mem,mmxreg \2\x0F\xE7\101 KATMAI,MMX,SM
  1940. [PAVGB]
  1941. (Ch_All, Ch_None, Ch_None)
  1942. mmxreg,mmxrm \2\x0F\xE0\110 KATMAI,MMX,SM
  1943. xmmreg,xmmrm \361\2\x0F\xE0\110 WILLAMETTE,SSE2,SM
  1944. [PAVGW]
  1945. (Ch_All, Ch_None, Ch_None)
  1946. mmxreg,mmxrm \2\x0F\xE3\110 KATMAI,MMX,SM
  1947. xmmreg,xmmrm \361\2\x0F\xE3\110 WILLAMETTE,SSE2,SM
  1948. [PEXTRW]
  1949. (Ch_All, Ch_None, Ch_None)
  1950. reg32,mmxreg,imm \2\x0F\xC5\110\22 KATMAI,MMX,SB,AR2
  1951. reg32,xmmreg,imm \361\2\x0F\xC5\110\26 SSE41
  1952. mem32,xmmreg,imm \361\3\x0F\x3A\x15\101\26 SSE41
  1953. [PINSRW]
  1954. (Ch_All, Ch_None, Ch_None)
  1955. ; PINSRW is documented as using a reg32, but it's really using only 16 bit
  1956. ; -- accept either, but be truthful in disassembly
  1957. mmxreg,reg16,imm \2\x0F\xC4\110\22 KATMAI,MMX,SB,AR2
  1958. mmxreg,reg32,imm \2\x0F\xC4\110\22 KATMAI,MMX,SB,AR2,ND
  1959. mmxreg,mem,imm \2\x0F\xC4\110\22 KATMAI,MMX,SB,AR2
  1960. mmxreg,mem16,imm \2\x0F\xC4\110\22 KATMAI,MMX,SB,AR2,ND
  1961. xmmreg,reg16,imm \361\2\x0F\xC4\110\26 WILLAMETTE,SSE2,SB,AR2
  1962. xmmreg,reg32,imm \361\2\x0F\xC4\110\26 WILLAMETTE,SSE2,SB,AR2,ND
  1963. xmmreg,mem,imm \361\2\x0F\xC4\110\26 WILLAMETTE,SSE2,SB,AR2
  1964. xmmreg,mem16,imm \361\2\x0F\xC4\110\26 WILLAMETTE,SSE2,SB,AR2,ND
  1965. [PMAXSW]
  1966. (Ch_All, Ch_None, Ch_None)
  1967. mmxreg,mmxrm \2\x0F\xEE\110 KATMAI,MMX,SM
  1968. xmmreg,xmmrm \361\2\x0F\xEE\110 WILLAMETTE,SSE2,SM
  1969. [PMAXUB]
  1970. (Ch_All, Ch_None, Ch_None)
  1971. mmxreg,mmxrm \2\x0F\xDE\110 KATMAI,MMX,SM
  1972. xmmreg,xmmrm \361\2\x0F\xDE\110 WILLAMETTE,SSE2,SM
  1973. [PMINSW]
  1974. (Ch_All, Ch_None, Ch_None)
  1975. mmxreg,mmxrm \2\x0F\xEA\110 KATMAI,MMX,SM
  1976. xmmreg,xmmrm \361\2\x0F\xEA\110 WILLAMETTE,SSE2,SM
  1977. [PMINUB]
  1978. (Ch_All, Ch_None, Ch_None)
  1979. mmxreg,mmxrm \2\x0F\xDA\110 KATMAI,MMX,SM
  1980. xmmreg,xmmrm \361\2\x0F\xDA\110 WILLAMETTE,SSE2,SM
  1981. [PMOVMSKB]
  1982. (Ch_All, Ch_None, Ch_None)
  1983. reg32,mmxreg \2\x0F\xD7\110 KATMAI,MMX
  1984. reg32,xmmreg \361\2\x0F\xD7\110 WILLAMETTE,SSE2
  1985. [PMULHUW]
  1986. (Ch_All, Ch_None, Ch_None)
  1987. mmxreg,mmxrm \2\x0F\xE4\110 KATMAI,MMX,SM
  1988. xmmreg,xmmrm \361\2\x0F\xE4\110 WILLAMETTE,SSE2,SM
  1989. [PSADBW]
  1990. (Ch_All, Ch_None, Ch_None)
  1991. mmxreg,mmxrm \2\x0F\xF6\110 KATMAI,MMX,SM
  1992. xmmreg,xmmrm \361\2\x0F\xF6\110 WILLAMETTE,SSE2,SM
  1993. [PSHUFW]
  1994. (Ch_All, Ch_None, Ch_None)
  1995. mmxreg,mmxrm,imm \2\x0F\x70\110\22 KATMAI,MMX,SM2,SB,AR2
  1996. ;
  1997. ; New Athlon Instructions
  1998. ;
  1999. [PFNACC]
  2000. (Ch_All, Ch_None, Ch_None)
  2001. mmxreg,mmxrm \2\x0F\x0F\110\01\x8A PENT,3DNOW,SM
  2002. [PFPNACC]
  2003. (Ch_All, Ch_None, Ch_None)
  2004. mmxreg,mmxrm \2\x0F\x0F\110\01\x8E PENT,3DNOW,SM
  2005. [PI2FW]
  2006. (Ch_All, Ch_None, Ch_None)
  2007. mmxreg,mmxrm \2\x0F\x0F\110\01\x0C PENT,3DNOW,SM
  2008. [PF2IW]
  2009. (Ch_All, Ch_None, Ch_None)
  2010. mmxreg,mmxrm \2\x0F\x0F\110\01\x1C PENT,3DNOW,SM
  2011. [PSWAPD]
  2012. (Ch_All, Ch_None, Ch_None)
  2013. mmxreg,mmxrm \2\x0F\x0F\110\01\xBB PENT,3DNOW,SM
  2014. [FFREEP]
  2015. (Ch_All, Ch_None, Ch_None)
  2016. fpureg \1\xDF\10\xC0 PENT,3DNOW,FPU
  2017. ; Willamette SSE2 Cacheability Instructions
  2018. [MASKMOVDQU]
  2019. (Ch_All, Ch_None, Ch_None)
  2020. xmmreg,xmmreg \361\2\x0F\xF7\110 WILLAMETTE,SSE2
  2021. ; CLFLUSH needs its own feature flag implemented one day
  2022. [CLFLUSH]
  2023. (Ch_All, Ch_None, Ch_None)
  2024. mem \2\x0F\xAE\207 WILLAMETTE,SSE2
  2025. [MOVNTDQ]
  2026. (Ch_All, Ch_None, Ch_None)
  2027. mem,xmmreg \361\2\x0F\xE7\101 WILLAMETTE,SSE2,SM
  2028. [MOVNTI,movntiX]
  2029. (Ch_All, Ch_None, Ch_None)
  2030. mem,reg32|64 \320\2\x0F\xC3\101 WILLAMETTE,SSE2,SM
  2031. [MOVNTPD]
  2032. (Ch_All, Ch_None, Ch_None)
  2033. mem,xmmreg \361\2\x0F\x2B\101 WILLAMETTE,SSE2,SM
  2034. [PAUSE]
  2035. (Ch_All, Ch_None, Ch_None)
  2036. void \333\1\x90 WILLAMETTE,SSE2
  2037. [LFENCE]
  2038. (Ch_All, Ch_None, Ch_None)
  2039. void \3\x0F\xAE\xE8 WILLAMETTE,SSE2
  2040. [MFENCE]
  2041. (Ch_All, Ch_None, Ch_None)
  2042. void \3\x0F\xAE\xF0 WILLAMETTE,SSE2
  2043. ;
  2044. ; Willamette MMX instructions (SSE2 SIMD Integer Instructions)
  2045. ;
  2046. [MOVDQA]
  2047. (Ch_All, Ch_None, Ch_None)
  2048. xmmrm,xmmreg \361\2\x0F\x7F\101 WILLAMETTE,SSE2,SM
  2049. xmmreg,xmmrm \361\2\x0F\x6F\110 WILLAMETTE,SSE2,SM
  2050. [MOVDQU]
  2051. (Ch_All, Ch_None, Ch_None)
  2052. xmmrm,xmmreg \333\2\x0F\x7F\101 WILLAMETTE,SSE2,SM
  2053. xmmreg,xmmrm \333\2\x0F\x6F\110 WILLAMETTE,SSE2,SM
  2054. [MOVDQ2Q]
  2055. (Ch_All, Ch_None, Ch_None)
  2056. mmxreg,xmmreg \334\2\x0F\xD6\110 WILLAMETTE,SSE2
  2057. [MOVQ2DQ]
  2058. (Ch_All, Ch_None, Ch_None)
  2059. xmmreg,mmxreg \333\2\x0F\xD6\110 WILLAMETTE,SSE2
  2060. [PADDQ]
  2061. (Ch_All, Ch_None, Ch_None)
  2062. mmxreg,mmxrm \2\x0F\xD4\110 WILLAMETTE,SSE2,SM
  2063. xmmreg,xmmrm \361\2\x0F\xD4\110 WILLAMETTE,SSE2,SM
  2064. [PMULUDQ]
  2065. (Ch_All, Ch_None, Ch_None)
  2066. mmxreg,mmxrm \2\x0F\xF4\110 WILLAMETTE,SSE2,SM
  2067. xmmreg,xmmrm \361\2\x0F\xF4\110 WILLAMETTE,SSE2,SM
  2068. [PSHUFD]
  2069. (Ch_All, Ch_None, Ch_None)
  2070. xmmreg,xmmrm,imm \361\2\x0F\x70\110\22 WILLAMETTE,SSE2,SM2,SB,AR2
  2071. [PSHUFHW]
  2072. (Ch_All, Ch_None, Ch_None)
  2073. xmmreg,xmmrm,imm \333\2\x0F\x70\110\22 WILLAMETTE,SSE2,SM2,SB,AR2
  2074. [PSHUFLW]
  2075. (Ch_All, Ch_None, Ch_None)
  2076. xmmreg,xmmrm,imm \334\2\x0F\x70\110\22 WILLAMETTE,SSE2,SM2,SB,AR2
  2077. [PSRLDQ]
  2078. (Ch_All, Ch_None, Ch_None)
  2079. xmmreg,imm \361\2\x0F\x73\203\25 WILLAMETTE,SSE2,SB,AR1
  2080. [PSUBQ]
  2081. (Ch_All, Ch_None, Ch_None)
  2082. mmxreg,mmxrm \2\x0F\xFB\110 WILLAMETTE,SSE2,SM
  2083. xmmreg,xmmrm \361\2\x0F\xFB\110 WILLAMETTE,SSE2,SM
  2084. [PUNPCKHQDQ]
  2085. (Ch_All, Ch_None, Ch_None)
  2086. xmmreg,xmmrm \361\2\x0F\x6D\110 WILLAMETTE,SSE2,SM
  2087. [PUNPCKLQDQ]
  2088. (Ch_All, Ch_None, Ch_None)
  2089. xmmreg,xmmrm \361\2\x0F\x6C\110 WILLAMETTE,SSE2,SM
  2090. ;
  2091. ; Willamette Streaming SIMD instructions (SSE2)
  2092. ;
  2093. [ADDPD]
  2094. (Ch_Mop2, Ch_Rop1, Ch_None)
  2095. xmmreg,xmmrm \361\2\x0F\x58\110 WILLAMETTE,SSE2,SM
  2096. [ADDSD]
  2097. (Ch_Mop2, Ch_Rop1, Ch_None)
  2098. xmmreg,xmmrm \334\2\x0F\x58\110 WILLAMETTE,SSE2
  2099. [ANDNPD]
  2100. (Ch_Mop2, Ch_Rop1, Ch_None)
  2101. xmmreg,xmmrm \361\2\x0F\x55\110 WILLAMETTE,SSE2,SM
  2102. [ANDPD]
  2103. (Ch_Mop2, Ch_Rop1, Ch_None)
  2104. xmmreg,xmmrm \361\2\x0F\x54\110 WILLAMETTE,SSE2,SM
  2105. [CMPEQPD]
  2106. (Ch_All, Ch_None, Ch_None)
  2107. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x00 WILLAMETTE,SSE2,SM
  2108. ; note: no SM flag on CMPxxSD, they use 64-bit memory location, not 128-bit
  2109. [CMPEQSD]
  2110. (Ch_All, Ch_None, Ch_None)
  2111. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x00 WILLAMETTE,SSE2
  2112. [CMPLEPD]
  2113. (Ch_All, Ch_None, Ch_None)
  2114. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x02 WILLAMETTE,SSE2,SM
  2115. [CMPLESD]
  2116. (Ch_All, Ch_None, Ch_None)
  2117. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x02 WILLAMETTE,SSE2
  2118. [CMPLTPD]
  2119. (Ch_All, Ch_None, Ch_None)
  2120. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x01 WILLAMETTE,SSE2,SM
  2121. [CMPLTSD]
  2122. (Ch_All, Ch_None, Ch_None)
  2123. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x01 WILLAMETTE,SSE2
  2124. [CMPNEQPD]
  2125. (Ch_All, Ch_None, Ch_None)
  2126. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x04 WILLAMETTE,SSE2,SM
  2127. [CMPNEQSD]
  2128. (Ch_All, Ch_None, Ch_None)
  2129. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x04 WILLAMETTE,SSE2
  2130. [CMPNLEPD]
  2131. (Ch_All, Ch_None, Ch_None)
  2132. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x06 WILLAMETTE,SSE2,SM
  2133. [CMPNLESD]
  2134. (Ch_All, Ch_None, Ch_None)
  2135. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x06 WILLAMETTE,SSE2
  2136. [CMPNLTPD]
  2137. (Ch_All, Ch_None, Ch_None)
  2138. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x05 WILLAMETTE,SSE2,SM
  2139. [CMPNLTSD]
  2140. (Ch_All, Ch_None, Ch_None)
  2141. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x05 WILLAMETTE,SSE2
  2142. [CMPORDPD]
  2143. (Ch_All, Ch_None, Ch_None)
  2144. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x07 WILLAMETTE,SSE2,SM
  2145. [CMPORDSD]
  2146. (Ch_All, Ch_None, Ch_None)
  2147. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x07 WILLAMETTE,SSE2
  2148. [CMPUNORDPD]
  2149. (Ch_All, Ch_None, Ch_None)
  2150. xmmreg,xmmrm \361\2\x0F\xC2\110\1\x03 WILLAMETTE,SSE2,SM
  2151. [CMPUNORDSD]
  2152. (Ch_All, Ch_None, Ch_None)
  2153. xmmreg,xmmrm \334\2\x0F\xC2\110\1\x03 WILLAMETTE,SSE2
  2154. ; CMPPD/CMPSD must come after the specific ops; that way the disassembler will find the
  2155. ; specific ops first and only disassemble illegal ones as cmppd/cmpsd.
  2156. [CMPPD]
  2157. (Ch_All, Ch_None, Ch_None)
  2158. xmmreg,xmmrm,imm \361\2\x0F\xC2\110\26 WILLAMETTE,SSE2,SM2,SB,AR2
  2159. [COMISD]
  2160. (Ch_All, Ch_None, Ch_None)
  2161. xmmreg,xmmrm \361\2\x0F\x2F\110 WILLAMETTE,SSE2
  2162. [CVTDQ2PD]
  2163. (Ch_Wop2, Ch_Rop1, Ch_None)
  2164. xmmreg,xmmrm \333\2\x0F\xE6\110 WILLAMETTE,SSE2
  2165. [CVTDQ2PS]
  2166. (Ch_Wop2, Ch_Rop1, Ch_None)
  2167. xmmreg,xmmrm \2\x0F\x5B\110 WILLAMETTE,SSE2,SM
  2168. [CVTPD2DQ]
  2169. (Ch_Wop2, Ch_Rop1, Ch_None)
  2170. xmmreg,xmmrm \334\2\x0F\xE6\110 WILLAMETTE,SSE2,SM
  2171. [CVTPD2PI]
  2172. (Ch_Wop2, Ch_Rop1, Ch_None)
  2173. mmxreg,xmmrm \361\2\x0F\x2D\110 WILLAMETTE,SSE2 ;,SO
  2174. [CVTPD2PS]
  2175. (Ch_Wop2, Ch_Rop1, Ch_None)
  2176. xmmreg,xmmrm \361\2\x0F\x5A\110 WILLAMETTE,SSE2,SM
  2177. [CVTPI2PD]
  2178. (Ch_Wop2, Ch_Rop1, Ch_None)
  2179. xmmreg,mmxrm \361\2\x0F\x2A\110 WILLAMETTE,SSE2 ;,SO
  2180. [CVTPS2DQ]
  2181. (Ch_Wop2, Ch_Rop1, Ch_None)
  2182. xmmreg,xmmrm \361\2\x0F\x5B\110 WILLAMETTE,SSE2,SM
  2183. [CVTPS2PD]
  2184. (Ch_Wop2, Ch_Rop1, Ch_None)
  2185. xmmreg,xmmrm \2\x0F\x5A\110 WILLAMETTE,SSE2 ;,SQ
  2186. [CVTSD2SI,cvtsd2siX]
  2187. (Ch_Wop2, Ch_Rop1, Ch_None)
  2188. reg32|64,xmmreg \334\320\2\x0F\x2D\110 WILLAMETTE,SSE2
  2189. reg32|64,mem \334\320\2\x0F\x2D\110 WILLAMETTE,SSE2
  2190. [CVTSD2SS]
  2191. (Ch_Wop2, Ch_Rop1, Ch_None)
  2192. xmmreg,xmmrm \334\2\x0F\x5A\110 WILLAMETTE,SSE2 ;,SQ
  2193. [CVTSI2SD,cvtsi2sdX]
  2194. (Ch_Wop2, Ch_Rop1, Ch_None)
  2195. xmmreg,reg32|64 \334\321\2\x0F\x2A\110 WILLAMETTE,SSE2
  2196. xmmreg,mem \334\321\2\x0F\x2A\110 WILLAMETTE,SSE2
  2197. [CVTSS2SD]
  2198. (Ch_Wop2, Ch_Rop1, Ch_None)
  2199. xmmreg,xmmrm \333\2\x0F\x5A\110 WILLAMETTE,SSE2 ;,SD
  2200. [CVTTPD2PI]
  2201. (Ch_Wop2, Ch_Rop1, Ch_None)
  2202. mmxreg,xmmreg \361\2\x0F\x2C\110 WILLAMETTE,SSE2
  2203. mmxreg,mem \361\2\x0F\x2C\110 WILLAMETTE,SSE2
  2204. [CVTTPD2DQ]
  2205. (Ch_Wop2, Ch_Rop1, Ch_None)
  2206. xmmreg,xmmrm \361\2\x0F\xE6\110 WILLAMETTE,SSE2,SM
  2207. [CVTTPS2DQ]
  2208. (Ch_Wop2, Ch_Rop1, Ch_None)
  2209. xmmreg,xmmrm \333\2\x0F\x5B\110 WILLAMETTE,SSE2,SM
  2210. [CVTTSD2SI,cvttsd2siX]
  2211. (Ch_Wop2, Ch_Rop1, Ch_None)
  2212. reg32|64,xmmreg \334\320\2\x0F\x2C\110 WILLAMETTE,SSE2
  2213. reg32|64,mem \334\320\2\x0F\x2C\110 WILLAMETTE,SSE2
  2214. [DIVPD]
  2215. (Ch_Mop2, Ch_Rop1, Ch_None)
  2216. xmmreg,xmmrm \361\2\x0F\x5E\110 WILLAMETTE,SSE2,SM
  2217. [DIVSD]
  2218. (Ch_Mop2, Ch_Rop1, Ch_None)
  2219. xmmreg,xmmrm \334\2\x0F\x5E\110 WILLAMETTE,SSE2
  2220. [MAXPD]
  2221. (Ch_All, Ch_None, Ch_None)
  2222. xmmreg,xmmrm \361\2\x0F\x5F\110 WILLAMETTE,SSE2,SM
  2223. [MAXSD]
  2224. (Ch_All, Ch_None, Ch_None)
  2225. xmmreg,xmmrm \334\2\x0F\x5F\110 WILLAMETTE,SSE2
  2226. [MINPD]
  2227. (Ch_All, Ch_None, Ch_None)
  2228. xmmreg,xmmrm \361\2\x0F\x5D\110 WILLAMETTE,SSE2,SM
  2229. [MINSD]
  2230. (Ch_All, Ch_None, Ch_None)
  2231. xmmreg,xmmrm \334\2\x0F\x5D\110 WILLAMETTE,SSE2
  2232. [MOVAPD]
  2233. (Ch_ROp1, Ch_WOp2, Ch_None)
  2234. xmmrm,xmmreg \361\2\x0F\x29\101 WILLAMETTE,SSE2,SM
  2235. xmmreg,xmmrm \361\2\x0F\x28\110 WILLAMETTE,SSE2,SM
  2236. [MOVHPD]
  2237. (Ch_All, Ch_None, Ch_None)
  2238. mem,xmmreg \361\2\x0F\x17\101 WILLAMETTE,SSE2
  2239. xmmreg,mem \361\2\x0F\x16\110 WILLAMETTE,SSE2
  2240. [MOVLPD]
  2241. (Ch_All, Ch_None, Ch_None)
  2242. mem,xmmreg \361\2\x0F\x13\101 WILLAMETTE,SSE2
  2243. xmmreg,mem \361\2\x0F\x12\110 WILLAMETTE,SSE2
  2244. [MOVMSKPD]
  2245. (Ch_All, Ch_None, Ch_None)
  2246. reg32,xmmreg \361\2\x0F\x50\110 WILLAMETTE,SSE2
  2247. [MOVUPD]
  2248. (Ch_All, Ch_None, Ch_None)
  2249. xmmrm,xmmreg \361\2\x0F\x11\101 WILLAMETTE,SSE2,SM
  2250. xmmreg,xmmrm \361\2\x0F\x10\110 WILLAMETTE,SSE2,SM
  2251. [MULPD]
  2252. (Ch_Mop2, Ch_Rop1, Ch_None)
  2253. xmmreg,xmmrm \361\2\x0F\x59\110 WILLAMETTE,SSE2,SM
  2254. [MULSD]
  2255. (Ch_Mop2, Ch_Rop1, Ch_None)
  2256. xmmreg,xmmrm \334\2\x0F\x59\110 WILLAMETTE,SSE2
  2257. [ORPD]
  2258. (Ch_Mop2, Ch_Rop1, Ch_None)
  2259. xmmreg,xmmrm \361\2\x0F\x56\110 WILLAMETTE,SSE2,SM
  2260. [SHUFPD]
  2261. (Ch_All, Ch_None, Ch_None)
  2262. xmmreg,xmmrm,imm \361\2\x0F\xC6\110\26 WILLAMETTE,SSE2,SM2,SB,AR2
  2263. [SQRTPD]
  2264. (Ch_Mop2, Ch_Rop1, Ch_None)
  2265. xmmreg,xmmrm \361\2\x0F\x51\110 WILLAMETTE,SSE2,SM
  2266. [SQRTSD]
  2267. (Ch_Mop2, Ch_Rop1, Ch_None)
  2268. xmmreg,xmmrm \334\2\x0F\x51\110 WILLAMETTE,SSE2
  2269. [SUBPD]
  2270. (Ch_Mop2, Ch_Rop1, Ch_None)
  2271. xmmreg,xmmrm \361\2\x0F\x5C\110 WILLAMETTE,SSE2,SM
  2272. [SUBSD]
  2273. (Ch_Mop2, Ch_Rop1, Ch_None)
  2274. xmmreg,xmmrm \334\2\x0F\x5C\110 WILLAMETTE,SSE2
  2275. [UCOMISD]
  2276. (Ch_All, Ch_None, Ch_None)
  2277. xmmreg,xmmrm \361\2\x0F\x2E\110 WILLAMETTE,SSE2
  2278. [UNPCKHPD]
  2279. (Ch_All, Ch_None, Ch_None)
  2280. xmmreg,xmmrm \361\2\x0F\x15\110 WILLAMETTE,SSE2,SM
  2281. [UNPCKLPD]
  2282. (Ch_All, Ch_None, Ch_None)
  2283. xmmreg,xmmrm \361\2\x0F\x14\110 WILLAMETTE,SSE2,SM
  2284. [XORPD]
  2285. (Ch_Mop2, Ch_Rop1, Ch_None)
  2286. xmmreg,xmmrm \361\2\x0F\x57\110 WILLAMETTE,SSE2,SM
  2287. ;
  2288. ; Prescott New Instructions (SSE3)
  2289. ;
  2290. [ADDSUBPD]
  2291. (Ch_All, Ch_None, Ch_None)
  2292. xmmreg,xmmrm \361\2\x0F\xD0\110 PRESCOTT,SSE3,SM
  2293. [ADDSUBPS]
  2294. (Ch_All, Ch_None, Ch_None)
  2295. xmmreg,xmmrm \334\2\x0F\xD0\110 PRESCOTT,SSE3,SM
  2296. [HADDPD]
  2297. (Ch_All, Ch_None, Ch_None)
  2298. xmmreg,xmmrm \361\2\x0F\x7C\110 PRESCOTT,SSE3,SM
  2299. [HADDPS]
  2300. (Ch_All, Ch_None, Ch_None)
  2301. xmmreg,xmmrm \334\2\x0F\x7C\110 PRESCOTT,SSE3,SM
  2302. [HSUBPD]
  2303. (Ch_All, Ch_None, Ch_None)
  2304. xmmreg,xmmrm \361\2\x0F\x7D\110 PRESCOTT,SSE3,SM
  2305. [HSUBPS]
  2306. (Ch_All, Ch_None, Ch_None)
  2307. xmmreg,xmmrm \334\2\x0F\x7D\110 PRESCOTT,SSE3,SM
  2308. [LDDQU]
  2309. (Ch_All, Ch_None, Ch_None)
  2310. xmmreg,mem \334\2\x0F\xF0\110 PRESCOTT,SSE3
  2311. [MOVDDUP]
  2312. (Ch_All, Ch_None, Ch_None)
  2313. xmmreg,xmmrm \334\2\x0F\x12\110 PRESCOTT,SSE3
  2314. [MOVSHDUP]
  2315. (Ch_All, Ch_None, Ch_None)
  2316. xmmreg,xmmrm \333\2\x0F\x16\110 PRESCOTT,SSE3,SM
  2317. [MOVSLDUP]
  2318. (Ch_All, Ch_None, Ch_None)
  2319. xmmreg,xmmrm \333\2\x0F\x12\110 PRESCOTT,SSE3,SM
  2320. ;
  2321. ; Intel VT
  2322. ;
  2323. [VMREAD]
  2324. (Ch_All, Ch_None, Ch_None)
  2325. reg32,reg32 \2\x0F\x78\101 386,PRIV,PROT
  2326. mem,reg32 \2\x0F\x78\101 386,PRIV,PROT,SM
  2327. [VMWRITE]
  2328. (Ch_All, Ch_None, Ch_None)
  2329. reg32,reg32 \2\x0F\x79\110 386,PRIV,PROT
  2330. reg32,mem \2\x0F\x79\110 386,PRIV,PROT,SM
  2331. [VMCALL]
  2332. (Ch_All, Ch_None, Ch_None)
  2333. void \3\x0F\x01\xC1 386,PRIV,PROT
  2334. [VMLAUNCH]
  2335. (Ch_All, Ch_None, Ch_None)
  2336. void \3\x0F\x01\xC2 386,PRIV,PROT
  2337. [VMRESUME]
  2338. (Ch_All, Ch_None, Ch_None)
  2339. void \3\x0F\x01\xC3 386,PRIV,PROT
  2340. [VMXOFF]
  2341. (Ch_All, Ch_None, Ch_None)
  2342. void \3\x0F\x01\xC4 386,PRIV,PROT
  2343. ; note: ideally the following should be tagged with SQ
  2344. [VMXON]
  2345. (Ch_All, Ch_None, Ch_None)
  2346. mem \333\2\x0F\xC7\206 PRIV,PROT
  2347. [VMCLEAR]
  2348. (Ch_All, Ch_None, Ch_None)
  2349. mem \361\2\x0F\xC7\206 PRIV,PROT
  2350. [VMPTRLD]
  2351. (Ch_All, Ch_None, Ch_None)
  2352. mem \2\x0F\xC7\206 PRIV,PROT
  2353. [VMPTRST]
  2354. (Ch_All, Ch_None, Ch_None)
  2355. mem \2\x0F\xC7\207 PRIV,PROT
  2356. ;
  2357. ; AMD SVM
  2358. ;
  2359. [VMRUN]
  2360. (Ch_All, Ch_None, Ch_None)
  2361. void \3\x0F\x01\xD8 386,SVM,PRIV,PROT
  2362. [VMMCALL]
  2363. (Ch_All, Ch_None, Ch_None)
  2364. void \3\x0F\x01\xD9 386,SVM
  2365. [VMLOAD]
  2366. (Ch_All, Ch_None, Ch_None)
  2367. void \3\x0F\x01\xDA 386,SVM,PRIV,PROT
  2368. [VMSAVE]
  2369. (Ch_All, Ch_None, Ch_None)
  2370. void \3\x0F\x01\xDB 386,SVM,PRIV,PROT
  2371. [STGI]
  2372. (Ch_All, Ch_None, Ch_None)
  2373. void \3\x0F\x01\xDC 386,SVM,PRIV,PROT
  2374. [CLGI]
  2375. (Ch_All, Ch_None, Ch_None)
  2376. void \3\x0F\x01\xDD 386,SVM,PRIV,PROT
  2377. [SKINIT]
  2378. (Ch_All, Ch_None, Ch_None)
  2379. void \3\x0F\x01\xDE 386,SVM,PRIV,PROT
  2380. [INVLPGA]
  2381. (Ch_All, Ch_None, Ch_None)
  2382. void \3\x0F\x01\xDF 386,SVM,PRIV,PROT
  2383. ;
  2384. ; Centaur
  2385. ;
  2386. [MONTMUL]
  2387. (Ch_All, Ch_None, Ch_None)
  2388. void \333\3\x0F\xA6\xC0 CENTAUR
  2389. [XSHA1]
  2390. (Ch_All, Ch_None, Ch_None)
  2391. void \333\3\x0F\xA6\xC8 CENTAUR
  2392. [XSHA256]
  2393. (Ch_All, Ch_None, Ch_None)
  2394. void \333\3\x0F\xA6\xD0 CENTAUR
  2395. ;
  2396. ; Geode
  2397. ;
  2398. [DMINT]
  2399. (Ch_All, Ch_None, Ch_None)
  2400. void \2\x0F\x39 P6,CYRIX
  2401. [RDM]
  2402. (Ch_All, Ch_None, Ch_None)
  2403. void \2\x0F\x3A P6,CYRIX
  2404. ;
  2405. ; GAS specific x86-64 instructions
  2406. ;
  2407. [MOVABS]
  2408. (Ch_Wop2, Ch_Rop1, Ch_None)
  2409. reg_al,mem_offs \1\xA0\45 X86_64,SM
  2410. reg_ax|32|64,mem_offs \320\1\xA1\45 X86_64,SM
  2411. mem_offs,reg_al \1\xA2\44 X86_64,SM
  2412. mem_offs,reg_ax|32|64 \321\xA3\44 X86_64,SM
  2413. reg64,imm \326\10\xB8\55 X86_64
  2414. [MOVSXD,movslq]
  2415. (Ch_Wop2, Ch_Rop1, Ch_None)
  2416. reg64,mem \326\1\x63\110 X86_64
  2417. reg64,reg32 \326\1\x63\110 X86_64
  2418. [CQO,cqto]
  2419. (Ch_MRAX, Ch_WRDX, Ch_None)
  2420. void \326\1\x99 X86_64
  2421. [CMPXCHG16B,cmpxchg16bX]
  2422. (Ch_All, Ch_None, Ch_None)
  2423. mem \326\2\x0F\xC7\201 X86_64
  2424. ;
  2425. ; SSE4a (AMD Barcelona CPUs, n/a on Intel)
  2426. ;
  2427. [MOVNTSS]
  2428. (Ch_All, Ch_None, Ch_None)
  2429. mem,xmmreg \333\2\x0F\x2B\101 SSE4,SD
  2430. [MOVNTSD]
  2431. (Ch_All, Ch_None, Ch_None)
  2432. mem,xmmreg \334\325\2\x0F\x2B\101 SSE4 ;,SQ
  2433. [INSERTQ]
  2434. (Ch_All, Ch_None, Ch_None)
  2435. xmmreg,xmmreg \334\2\x0F\x79\110 SSE4
  2436. ; four operands are not possible yet
  2437. ; xmmreg,xmmreg,imm,imm \334\2\x0F\x78\110\26\27 SSE4,SB
  2438. [EXTRQ]
  2439. (Ch_All, Ch_None, Ch_None)
  2440. xmmreg,imm,imm \361\2\x0F\x78\200\25\26 SSE4,SB
  2441. xmmreg,xmmreg \361\2\x0F\x79\110 SSE4
  2442. [LZCNT,lzcntX]
  2443. (Ch_All, Ch_None, Ch_None)
  2444. reg16,regmem \320\333\2\x0F\xBD\110 386,SM,SSE4
  2445. reg32|64,regmem \321\333\2\x0F\xBD\110 386,SM,SSE4
  2446. ;*******************************************************************************
  2447. ;**********SSSE3****************************************************************
  2448. ;*******************************************************************************
  2449. [PABSB]
  2450. (Ch_All, Ch_None, Ch_None)
  2451. mmxreg,mmxrm \331\3\x0F\x38\x1C\110 SSSE3,MMX,SM
  2452. xmmreg,xmmrm \361\3\x0F\x38\x1C\110 SSSE3,SM
  2453. [PABSW]
  2454. (Ch_All, Ch_None, Ch_None)
  2455. mmxreg,mmxrm \331\3\x0F\x38\x1D\110 SSSE3,MMX,SM
  2456. xmmreg,xmmrm \361\3\x0F\x38\x1D\110 SSSE3,SM
  2457. [PABSD]
  2458. (Ch_All, Ch_None, Ch_None)
  2459. mmxreg,mmxrm \331\3\x0F\x38\x1E\110 SSSE3,MMX,SM
  2460. xmmreg,xmmrm \361\3\x0F\x38\x1E\110 SSSE3,SM
  2461. [PALIGNR]
  2462. (Ch_All, Ch_None, Ch_None)
  2463. mmxreg,mmxrm,imm \331\3\x0F\x3A\x0F\110\26 SSSE3,MMX,SM2,SB,AR2
  2464. xmmreg,xmmrm,imm \361\3\x0F\x3A\x0F\110\26 SSSE3,SM2,SB,AR2
  2465. [PHADDW]
  2466. (Ch_All, Ch_None, Ch_None)
  2467. mmxreg,mmxrm \331\3\x0F\x38\x01\110 SSSE3,MMX,SM
  2468. xmmreg,xmmrm \361\3\x0F\x38\x01\110 SSSE3,SM
  2469. [PHADDD]
  2470. (Ch_All, Ch_None, Ch_None)
  2471. mmxreg,mmxrm \331\3\x0F\x38\x02\110 SSSE3,MMX,SM
  2472. xmmreg,xmmrm \361\3\x0F\x38\x02\110 SSSE3,SM
  2473. [PHADDSW]
  2474. (Ch_All, Ch_None, Ch_None)
  2475. mmxreg,mmxrm \331\3\x0F\x38\x03\110 SSSE3,MMX,SM
  2476. xmmreg,xmmrm \361\3\x0F\x38\x03\110 SSSE3,SM
  2477. [PHSUBW]
  2478. (Ch_All, Ch_None, Ch_None)
  2479. mmxreg,mmxrm \331\3\x0F\x38\x05\110 SSSE3,MMX,SM
  2480. xmmreg,xmmrm \361\3\x0F\x38\x05\110 SSSE3,SM
  2481. [PHSUBD]
  2482. (Ch_All, Ch_None, Ch_None)
  2483. mmxreg,mmxrm \331\3\x0F\x38\x06\110 SSSE3,MMX,SM
  2484. xmmreg,xmmrm \361\3\x0F\x38\x06\110 SSSE3,SM
  2485. [PHSUBSW]
  2486. (Ch_All, Ch_None, Ch_None)
  2487. mmxreg,mmxrm \331\3\x0F\x38\x07\110 SSSE3,MMX,SM
  2488. xmmreg,xmmrm \361\3\x0F\x38\x07\110 SSSE3,SM
  2489. [PMADDUBSW]
  2490. (Ch_All, Ch_None, Ch_None)
  2491. mmxreg,mmxrm \331\3\x0F\x38\x04\110 SSSE3,MMX,SM
  2492. xmmreg,xmmrm \361\3\x0F\x38\x04\110 SSSE3,SM
  2493. [PMULHRSW]
  2494. (Ch_All, Ch_None, Ch_None)
  2495. mmxreg,mmxrm \331\3\x0F\x38\x0B\110 SSSE3,MMX,SM
  2496. xmmreg,xmmrm \361\3\x0F\x38\x0B\110 SSSE3,SM
  2497. [PSHUFB]
  2498. (Ch_All, Ch_None, Ch_None)
  2499. mmxreg,mmxrm \331\3\x0F\x38\x00\110 SSSE3,MMX,SM
  2500. xmmreg,xmmrm \361\3\x0F\x38\x00\110 SSSE3,SM
  2501. [PSIGNB]
  2502. (Ch_All, Ch_None, Ch_None)
  2503. mmxreg,mmxrm \331\3\x0F\x38\x08\110 SSSE3,MMX,SM
  2504. xmmreg,xmmrm \361\3\x0F\x38\x08\110 SSSE3,SM
  2505. [PSIGNW]
  2506. (Ch_All, Ch_None, Ch_None)
  2507. mmxreg,mmxrm \331\3\x0F\x38\x09\110 SSSE3,MMX,SM
  2508. xmmreg,xmmrm \361\3\x0F\x38\x09\110 SSSE3,SM
  2509. [PSIGND]
  2510. (Ch_All, Ch_None, Ch_None)
  2511. mmxreg,mmxrm \331\3\x0F\x38\x0A\110 SSSE3,MMX,SM
  2512. xmmreg,xmmrm \361\3\x0F\x38\x0A\110 SSSE3,SM
  2513. ;*******************************************************************************
  2514. ;**********SSE4.1***************************************************************
  2515. ;*******************************************************************************
  2516. [BLENDPS]
  2517. (Ch_All, Ch_None, Ch_None)
  2518. xmmreg,xmmrm,imm \361\3\x0F\x3A\x0C\110\26 SSE41,SM2,SB,AR2
  2519. [BLENDPD]
  2520. (Ch_All, Ch_None, Ch_None)
  2521. xmmreg,xmmrm,imm \361\3\x0F\x3A\x0D\110\26 SSE41,SM2,SB,AR2
  2522. [BLENDVPS]
  2523. (Ch_All, Ch_None, Ch_None)
  2524. xmmreg,xmmrm \361\3\x0F\x38\x14\110 SSE41,SM
  2525. [BLENDVPD]
  2526. (Ch_All, Ch_None, Ch_None)
  2527. xmmreg,xmmrm \361\3\x0F\x38\x15\110 SSE41,SM
  2528. [DPPS]
  2529. (Ch_All, Ch_None, Ch_None)
  2530. xmmreg,xmmrm,imm \361\3\x0F\x3A\x40\110\26 SSE41,SM2,SB,AR2
  2531. [DPPD]
  2532. (Ch_All, Ch_None, Ch_None)
  2533. xmmreg,xmmrm,imm \361\3\x0F\x3A\x41\110\26 SSE41,SM2,SB,AR2
  2534. [EXTRACTPS]
  2535. (Ch_All, Ch_None, Ch_None)
  2536. mem,xmmreg,imm \361\325\3\x0F\x3A\x17\101\26 SSE41,SB,AR2
  2537. reg32|64,xmmreg,imm \361\3\x0F\x3A\x17\101\26 SSE41,SB,AR2
  2538. [INSERTPS]
  2539. (Ch_All, Ch_None, Ch_None)
  2540. xmmreg,xmmrm,imm \361\3\x0F\x3A\x21\110\26 SSE41,SM2,SB,AR2
  2541. [MOVNTDQA]
  2542. (Ch_All, Ch_None, Ch_None)
  2543. xmmreg,mem \361\3\x0F\x38\x2A\110 SSE41,SM
  2544. [MPSADBW]
  2545. (Ch_All, Ch_None, Ch_None)
  2546. xmmreg,xmmrm,imm \361\3\x0F\x3A\x42\110\26 SSE41,SM2,SB,AR2
  2547. [PACKUSDW]
  2548. (Ch_All, Ch_None, Ch_None)
  2549. xmmreg,xmmrm \361\3\x0F\x38\x2B\110 SSE41,SM
  2550. [PBLENDVB]
  2551. (Ch_All, Ch_None, Ch_None)
  2552. xmmreg,xmmrm \361\3\x0F\x38\x10\110 SSE41,SM
  2553. [PBLENDW]
  2554. (Ch_All, Ch_None, Ch_None)
  2555. xmmreg,xmmrm,imm \361\3\x0F\x3A\x0E\110\26 SSE41,SM2,SB,AR2
  2556. [PCMPEQQ]
  2557. (Ch_All, Ch_None, Ch_None)
  2558. xmmreg,xmmrm \361\3\x0F\x38\x29\110 SSE41,SM
  2559. [PEXTRB]
  2560. (Ch_All, Ch_None, Ch_None)
  2561. reg32|64,xmmreg,imm \361\3\x0F\x3A\x14\101\26 SSE41,SB,AR2
  2562. mem8,xmmreg,imm \361\3\x0F\x3A\x14\101\26 SSE41,SB,AR2
  2563. ;PEXTRW - Look is prev. implementation
  2564. [PEXTRD]
  2565. (Ch_All, Ch_None, Ch_None)
  2566. reg32,xmmreg,imm \361\3\x0F\x3A\x16\101\26 SSE41,SB,AR2
  2567. mem32,xmmreg,imm \361\3\x0F\x3A\x16\101\26 SSE41,SB,AR2
  2568. [PEXTRQ]
  2569. (Ch_All, Ch_None, Ch_None)
  2570. reg64,xmmreg,imm \361\326\3\x0F\x3A\x16\101\26 SSE41,X86_64,SB,AR2
  2571. mem64,xmmreg,imm \361\326\3\x0F\x3A\x16\101\26 SSE41,X86_64,SB,AR2
  2572. [PHMINPOSUW]
  2573. (Ch_All, Ch_None, Ch_None)
  2574. xmmreg,xmmrm \361\3\x0F\x38\x41\110 SSE41,SM
  2575. [PINSRB]
  2576. (Ch_All, Ch_None, Ch_None)
  2577. xmmreg,reg32|64,imm \361\3\x0F\x3A\x20\110\26 SSE41,SB,AR2
  2578. xmmreg,mem8,imm \361\3\x0F\x3A\x20\110\26 SSE41,SB,AR2
  2579. [PINSRD]
  2580. (Ch_All, Ch_None, Ch_None)
  2581. xmmreg,reg32,imm \361\3\x0F\x3A\x22\110\26 SSE41,SB,AR2
  2582. xmmreg,mem32,imm \361\3\x0F\x3A\x22\110\26 SSE41,SB,AR2
  2583. [PINSRQ]
  2584. (Ch_All, Ch_None, Ch_None)
  2585. xmmreg,reg64,imm \361\326\3\x0F\x3A\x22\110\26 SSE41,X86_64,SB,AR2
  2586. xmmreg,mem64,imm \361\326\3\x0F\x3A\x22\110\26 SSE41,X86_64,SB,AR2
  2587. [PMAXSB]
  2588. (Ch_All, Ch_None, Ch_None)
  2589. xmmreg,xmmrm \361\3\x0F\x38\x3C\110 SSE41,SM
  2590. [PMAXSD]
  2591. (Ch_All, Ch_None, Ch_None)
  2592. xmmreg,xmmrm \361\3\x0F\x38\x3D\110 SSE41,SM
  2593. [PMAXUD]
  2594. (Ch_All, Ch_None, Ch_None)
  2595. xmmreg,xmmrm \361\3\x0F\x38\x3F\110 SSE41,SM
  2596. [PMAXUW]
  2597. (Ch_All, Ch_None, Ch_None)
  2598. xmmreg,xmmrm \361\3\x0F\x38\x3E\110 SSE41,SM
  2599. [PMINSB]
  2600. (Ch_All, Ch_None, Ch_None)
  2601. xmmreg,xmmrm \361\3\x0F\x38\x38\110 SSE41,SM
  2602. [PMINSD]
  2603. (Ch_All, Ch_None, Ch_None)
  2604. xmmreg,xmmrm \361\3\x0F\x38\x39\110 SSE41,SM
  2605. [PMINUW]
  2606. (Ch_All, Ch_None, Ch_None)
  2607. xmmreg,xmmrm \361\3\x0F\x38\x3A\110 SSE41,SM
  2608. [PMINUD]
  2609. (Ch_All, Ch_None, Ch_None)
  2610. xmmreg,xmmrm \361\3\x0F\x38\x3B\110 SSE41,SM
  2611. [PMOVSXBW]
  2612. (Ch_All, Ch_None, Ch_None)
  2613. xmmreg,xmmrm \361\3\x0F\x38\x20\110 SSE41,SM
  2614. [PMOVSXBD]
  2615. (Ch_All, Ch_None, Ch_None)
  2616. xmmreg,xmmrm \361\3\x0F\x38\x21\110 SSE41,SM
  2617. [PMOVSXBQ]
  2618. (Ch_All, Ch_None, Ch_None)
  2619. xmmreg,xmmrm \361\3\x0F\x38\x22\110 SSE41,SM
  2620. [PMOVSXWD]
  2621. (Ch_All, Ch_None, Ch_None)
  2622. xmmreg,xmmrm \361\3\x0F\x38\x23\110 SSE41,SM
  2623. [PMOVSXWQ]
  2624. (Ch_All, Ch_None, Ch_None)
  2625. xmmreg,xmmrm \361\3\x0F\x38\x24\110 SSE41,SM
  2626. [PMOVSXDQ]
  2627. (Ch_All, Ch_None, Ch_None)
  2628. xmmreg,xmmrm \361\3\x0F\x38\x25\110 SSE41,SM
  2629. [PMOVZXBW]
  2630. (Ch_All, Ch_None, Ch_None)
  2631. xmmreg,xmmrm \361\3\x0F\x38\x30\110 SSE41,SM
  2632. [PMOVZXBD]
  2633. (Ch_All, Ch_None, Ch_None)
  2634. xmmreg,xmmrm \361\3\x0F\x38\x31\110 SSE41,SM
  2635. [PMOVZXBQ]
  2636. (Ch_All, Ch_None, Ch_None)
  2637. xmmreg,xmmrm \361\3\x0F\x38\x32\110 SSE41,SM
  2638. [PMOVZXWD]
  2639. (Ch_All, Ch_None, Ch_None)
  2640. xmmreg,xmmrm \361\3\x0F\x38\x33\110 SSE41,SM
  2641. [PMOVZXWQ]
  2642. (Ch_All, Ch_None, Ch_None)
  2643. xmmreg,xmmrm \361\3\x0F\x38\x34\110 SSE41,SM
  2644. [PMOVZXDQ]
  2645. (Ch_All, Ch_None, Ch_None)
  2646. xmmreg,xmmrm \361\3\x0F\x38\x35\110 SSE41,SM
  2647. [PMULDQ]
  2648. (Ch_All, Ch_None, Ch_None)
  2649. xmmreg,xmmrm \361\3\x0F\x38\x28\110 SSE41,SM
  2650. [PMULLD]
  2651. (Ch_All, Ch_None, Ch_None)
  2652. xmmreg,xmmrm \361\3\x0F\x38\x40\110 SSE41,SM
  2653. [PTEST]
  2654. (Ch_All, Ch_None, Ch_None)
  2655. xmmreg,xmmrm \361\3\x0F\x38\x17\110 SSE41,SM
  2656. [ROUNDPS]
  2657. (Ch_All, Ch_None, Ch_None)
  2658. xmmreg,xmmrm,imm \361\3\x0F\x3A\x08\110\26 SSE41,SM2,SB,AR2
  2659. [ROUNDPD]
  2660. (Ch_All, Ch_None, Ch_None)
  2661. xmmreg,xmmrm,imm \361\3\x0F\x3A\x09\110\26 SSE41,SM2,SB,AR2
  2662. [ROUNDSS]
  2663. (Ch_All, Ch_None, Ch_None)
  2664. xmmreg,xmmrm,imm \361\3\x0F\x3A\x0A\110\26 SSE41,SM2,SB,AR2
  2665. [ROUNDSD]
  2666. (Ch_All, Ch_None, Ch_None)
  2667. xmmreg,xmmrm,imm \361\3\x0F\x3A\x0B\110\26 SSE41,SM2,SB,AR2
  2668. ;*******************************************************************************
  2669. ;**********SSE4.2***************************************************************
  2670. ;*******************************************************************************
  2671. [CRC32,crc32X]
  2672. (Ch_Mop1, Ch_Rop2, Ch_None)
  2673. reg32,rm8 \334\3\x0F\x38\xF0\110 SSE42
  2674. reg32,rm16|32 \321\334\3\x0F\x38\xF1\110 SSE42
  2675. reg64,rm8 \334\326\3\x0F\x38\xF0\110 SSE42,X86_64
  2676. reg64,rm64 \334\326\3\x0F\x38\xF1\110 SSE42,X86_64
  2677. [PCMPESTRI]
  2678. (Ch_All, Ch_None, Ch_None)
  2679. xmmreg,xmmrm,imm \361\3\x0F\x3A\x61\110\26 SSE42,SM2,SB,AR2
  2680. [PCMPESTRM]
  2681. (Ch_All, Ch_None, Ch_None)
  2682. xmmreg,xmmrm,imm \361\3\x0F\x3A\x60\110\26 SSE42,SM2,SB,AR2
  2683. [PCMPISTRI]
  2684. (Ch_All, Ch_None, Ch_None)
  2685. xmmreg,xmmrm,imm \361\3\x0F\x3A\x63\110\26 SSE42,SM2,SB,AR2
  2686. [PCMPISTRM]
  2687. (Ch_All, Ch_None, Ch_None)
  2688. xmmreg,xmmrm,imm \361\3\x0F\x3A\x62\110\26 SSE42,SM2,SB,AR2
  2689. [PCMPGTQ]
  2690. (Ch_All, Ch_None, Ch_None)
  2691. xmmreg,xmmrm \361\3\x0F\x38\x37\110 SSE42,SM
  2692. [POPCNT,popcntX]
  2693. (Ch_All, Ch_None, Ch_None)
  2694. reg16,rm16 \333\320\2\x0F\xB8\110 386,SM,SSE4
  2695. reg32,rm32 \333\320\2\x0F\xB8\110 386,SM,SSE4
  2696. reg64,rm64 \333\320\2\x0F\xB8\110 386,SM,SSE4,X86_64
  2697. ;*******************************************************************************
  2698. ;**********AES******************************************************************
  2699. ;*******************************************************************************
  2700. ;Use SSE4, but need special flag for AES insructions set
  2701. [AESENC]
  2702. (Ch_All, Ch_None, Ch_None)
  2703. xmmreg,xmmrm \361\3\x0F\x38\xDC\110 SSE4,SM
  2704. [AESENCLAST]
  2705. (Ch_All, Ch_None, Ch_None)
  2706. xmmreg,xmmrm \361\3\x0F\x38\xDD\110 SSE4,SM
  2707. [AESDEC]
  2708. (Ch_All, Ch_None, Ch_None)
  2709. xmmreg,xmmrm \361\3\x0F\x38\xDE\110 SSE4,SM
  2710. [AESDECLAST]
  2711. (Ch_All, Ch_None, Ch_None)
  2712. xmmreg,xmmrm \361\3\x0F\x38\xDF\110 SSE4,SM
  2713. [AESIMC]
  2714. (Ch_All, Ch_None, Ch_None)
  2715. xmmreg,xmmrm \361\3\x0F\x38\xDB\110 SSE4,SM
  2716. [AESKEYGENASSIST]
  2717. (Ch_All, Ch_None, Ch_None)
  2718. xmmreg,xmmrm,imm \361\3\x0F\x3A\xDF\110\26 SSE4,SB,AR2
  2719. ;*******************************************************************************
  2720. ;*******************************************************************************
  2721. ;*******************************************************************************
  2722. [STOSQ]
  2723. (Ch_RRAX, Ch_WMemEDI, Ch_RWRDI)
  2724. void \326\1\xAB X86_64
  2725. [LODSQ]
  2726. (Ch_WRAX, Ch_RWRSI, Ch_None)
  2727. void \326\1\xAD X86_64
  2728. [CMPSQ]
  2729. (Ch_All, Ch_None, Ch_None)
  2730. void \326\1\xA7 X86_64