fisk 1.0.0 → 2.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1246) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/Rakefile +9 -3
  4. data/bin/build-machine.rb +44 -2
  5. data/bin/instruction.rb.erb +91 -0
  6. data/bin/instructions.rb.erb +45 -0
  7. data/fisk.gemspec +12 -0
  8. data/lib/fisk.rb +138 -50
  9. data/lib/fisk/encoding.rb +61 -0
  10. data/lib/fisk/helpers.rb +7 -0
  11. data/lib/fisk/instructions.rb +5054 -0
  12. data/lib/fisk/instructions/adc.rb +760 -0
  13. data/lib/fisk/instructions/adcx.rb +113 -0
  14. data/lib/fisk/instructions/add.rb +760 -0
  15. data/lib/fisk/instructions/addpd.rb +59 -0
  16. data/lib/fisk/instructions/addps.rb +57 -0
  17. data/lib/fisk/instructions/addsd.rb +59 -0
  18. data/lib/fisk/instructions/addss.rb +59 -0
  19. data/lib/fisk/instructions/addsubpd.rb +59 -0
  20. data/lib/fisk/instructions/addsubps.rb +59 -0
  21. data/lib/fisk/instructions/adox.rb +113 -0
  22. data/lib/fisk/instructions/aesdec.rb +61 -0
  23. data/lib/fisk/instructions/aesdeclast.rb +61 -0
  24. data/lib/fisk/instructions/aesenc.rb +61 -0
  25. data/lib/fisk/instructions/aesenclast.rb +61 -0
  26. data/lib/fisk/instructions/aesimc.rb +61 -0
  27. data/lib/fisk/instructions/aeskeygenassist.rb +65 -0
  28. data/lib/fisk/instructions/and.rb +760 -0
  29. data/lib/fisk/instructions/andn.rb +85 -0
  30. data/lib/fisk/instructions/andnpd.rb +59 -0
  31. data/lib/fisk/instructions/andnps.rb +57 -0
  32. data/lib/fisk/instructions/andpd.rb +59 -0
  33. data/lib/fisk/instructions/andps.rb +57 -0
  34. data/lib/fisk/instructions/bextr.rb +165 -0
  35. data/lib/fisk/instructions/blcfill.rb +81 -0
  36. data/lib/fisk/instructions/blci.rb +81 -0
  37. data/lib/fisk/instructions/blcic.rb +81 -0
  38. data/lib/fisk/instructions/blcmsk.rb +81 -0
  39. data/lib/fisk/instructions/blcs.rb +81 -0
  40. data/lib/fisk/instructions/blendpd.rb +65 -0
  41. data/lib/fisk/instructions/blendps.rb +65 -0
  42. data/lib/fisk/instructions/blendvpd.rb +63 -0
  43. data/lib/fisk/instructions/blendvps.rb +63 -0
  44. data/lib/fisk/instructions/blsfill.rb +81 -0
  45. data/lib/fisk/instructions/blsi.rb +81 -0
  46. data/lib/fisk/instructions/blsic.rb +81 -0
  47. data/lib/fisk/instructions/blsmsk.rb +81 -0
  48. data/lib/fisk/instructions/blsr.rb +81 -0
  49. data/lib/fisk/instructions/bsf.rb +155 -0
  50. data/lib/fisk/instructions/bsr.rb +155 -0
  51. data/lib/fisk/instructions/bswap.rb +47 -0
  52. data/lib/fisk/instructions/bt.rb +307 -0
  53. data/lib/fisk/instructions/btc.rb +307 -0
  54. data/lib/fisk/instructions/btr.rb +307 -0
  55. data/lib/fisk/instructions/bts.rb +307 -0
  56. data/lib/fisk/instructions/bzhi.rb +85 -0
  57. data/lib/fisk/instructions/call.rb +66 -0
  58. data/lib/fisk/instructions/cbw.rb +21 -0
  59. data/lib/fisk/instructions/cdq.rb +20 -0
  60. data/lib/fisk/instructions/cdqe.rb +26 -0
  61. data/lib/fisk/instructions/clc.rb +20 -0
  62. data/lib/fisk/instructions/cld.rb +20 -0
  63. data/lib/fisk/instructions/clflush.rb +32 -0
  64. data/lib/fisk/instructions/clflushopt.rb +33 -0
  65. data/lib/fisk/instructions/clwb.rb +33 -0
  66. data/lib/fisk/instructions/clzero.rb +22 -0
  67. data/lib/fisk/instructions/cmc.rb +20 -0
  68. data/lib/fisk/instructions/cmova.rb +155 -0
  69. data/lib/fisk/instructions/cmovae.rb +155 -0
  70. data/lib/fisk/instructions/cmovb.rb +155 -0
  71. data/lib/fisk/instructions/cmovbe.rb +155 -0
  72. data/lib/fisk/instructions/cmovc.rb +155 -0
  73. data/lib/fisk/instructions/cmove.rb +155 -0
  74. data/lib/fisk/instructions/cmovg.rb +155 -0
  75. data/lib/fisk/instructions/cmovge.rb +155 -0
  76. data/lib/fisk/instructions/cmovl.rb +155 -0
  77. data/lib/fisk/instructions/cmovle.rb +155 -0
  78. data/lib/fisk/instructions/cmovna.rb +155 -0
  79. data/lib/fisk/instructions/cmovnae.rb +155 -0
  80. data/lib/fisk/instructions/cmovnb.rb +155 -0
  81. data/lib/fisk/instructions/cmovnbe.rb +155 -0
  82. data/lib/fisk/instructions/cmovnc.rb +155 -0
  83. data/lib/fisk/instructions/cmovne.rb +155 -0
  84. data/lib/fisk/instructions/cmovng.rb +155 -0
  85. data/lib/fisk/instructions/cmovnge.rb +155 -0
  86. data/lib/fisk/instructions/cmovnl.rb +155 -0
  87. data/lib/fisk/instructions/cmovnle.rb +155 -0
  88. data/lib/fisk/instructions/cmovno.rb +155 -0
  89. data/lib/fisk/instructions/cmovnp.rb +155 -0
  90. data/lib/fisk/instructions/cmovns.rb +155 -0
  91. data/lib/fisk/instructions/cmovnz.rb +155 -0
  92. data/lib/fisk/instructions/cmovo.rb +155 -0
  93. data/lib/fisk/instructions/cmovp.rb +155 -0
  94. data/lib/fisk/instructions/cmovpe.rb +155 -0
  95. data/lib/fisk/instructions/cmovpo.rb +155 -0
  96. data/lib/fisk/instructions/cmovs.rb +155 -0
  97. data/lib/fisk/instructions/cmovz.rb +155 -0
  98. data/lib/fisk/instructions/cmp.rb +760 -0
  99. data/lib/fisk/instructions/cmppd.rb +63 -0
  100. data/lib/fisk/instructions/cmpps.rb +61 -0
  101. data/lib/fisk/instructions/cmpsd.rb +63 -0
  102. data/lib/fisk/instructions/cmpss.rb +63 -0
  103. data/lib/fisk/instructions/cmpxchg.rb +203 -0
  104. data/lib/fisk/instructions/cmpxchg16b.rb +32 -0
  105. data/lib/fisk/instructions/cmpxchg8b.rb +32 -0
  106. data/lib/fisk/instructions/comisd.rb +59 -0
  107. data/lib/fisk/instructions/comiss.rb +57 -0
  108. data/lib/fisk/instructions/cpuid.rb +21 -0
  109. data/lib/fisk/instructions/cqo.rb +26 -0
  110. data/lib/fisk/instructions/crc32.rb +271 -0
  111. data/lib/fisk/instructions/cvtdq2pd.rb +59 -0
  112. data/lib/fisk/instructions/cvtdq2ps.rb +57 -0
  113. data/lib/fisk/instructions/cvtpd2dq.rb +59 -0
  114. data/lib/fisk/instructions/cvtpd2pi.rb +59 -0
  115. data/lib/fisk/instructions/cvtpd2ps.rb +59 -0
  116. data/lib/fisk/instructions/cvtpi2pd.rb +59 -0
  117. data/lib/fisk/instructions/cvtpi2ps.rb +57 -0
  118. data/lib/fisk/instructions/cvtps2dq.rb +59 -0
  119. data/lib/fisk/instructions/cvtps2pd.rb +57 -0
  120. data/lib/fisk/instructions/cvtps2pi.rb +57 -0
  121. data/lib/fisk/instructions/cvtsd2si.rb +109 -0
  122. data/lib/fisk/instructions/cvtsd2ss.rb +59 -0
  123. data/lib/fisk/instructions/cvtsi2sd.rb +109 -0
  124. data/lib/fisk/instructions/cvtsi2ss.rb +109 -0
  125. data/lib/fisk/instructions/cvtss2sd.rb +59 -0
  126. data/lib/fisk/instructions/cvtss2si.rb +109 -0
  127. data/lib/fisk/instructions/cvttpd2dq.rb +59 -0
  128. data/lib/fisk/instructions/cvttpd2pi.rb +59 -0
  129. data/lib/fisk/instructions/cvttps2dq.rb +59 -0
  130. data/lib/fisk/instructions/cvttps2pi.rb +57 -0
  131. data/lib/fisk/instructions/cvttsd2si.rb +109 -0
  132. data/lib/fisk/instructions/cvttss2si.rb +109 -0
  133. data/lib/fisk/instructions/cwd.rb +21 -0
  134. data/lib/fisk/instructions/cwde.rb +20 -0
  135. data/lib/fisk/instructions/dec.rb +187 -0
  136. data/lib/fisk/instructions/div.rb +187 -0
  137. data/lib/fisk/instructions/divpd.rb +59 -0
  138. data/lib/fisk/instructions/divps.rb +57 -0
  139. data/lib/fisk/instructions/divsd.rb +59 -0
  140. data/lib/fisk/instructions/divss.rb +59 -0
  141. data/lib/fisk/instructions/dppd.rb +65 -0
  142. data/lib/fisk/instructions/dpps.rb +65 -0
  143. data/lib/fisk/instructions/emms.rb +21 -0
  144. data/lib/fisk/instructions/extractps.rb +65 -0
  145. data/lib/fisk/instructions/extrq.rb +62 -0
  146. data/lib/fisk/instructions/femms.rb +21 -0
  147. data/lib/fisk/instructions/haddpd.rb +59 -0
  148. data/lib/fisk/instructions/haddps.rb +59 -0
  149. data/lib/fisk/instructions/hsubpd.rb +59 -0
  150. data/lib/fisk/instructions/hsubps.rb +59 -0
  151. data/lib/fisk/instructions/idiv.rb +187 -0
  152. data/lib/fisk/instructions/imul.rb +637 -0
  153. data/lib/fisk/instructions/inc.rb +187 -0
  154. data/lib/fisk/instructions/insertps.rb +65 -0
  155. data/lib/fisk/instructions/insertq.rb +63 -0
  156. data/lib/fisk/instructions/int.rb +34 -0
  157. data/lib/fisk/instructions/ja.rb +36 -0
  158. data/lib/fisk/instructions/jae.rb +36 -0
  159. data/lib/fisk/instructions/jb.rb +36 -0
  160. data/lib/fisk/instructions/jbe.rb +36 -0
  161. data/lib/fisk/instructions/jc.rb +36 -0
  162. data/lib/fisk/instructions/je.rb +36 -0
  163. data/lib/fisk/instructions/jecxz.rb +22 -0
  164. data/lib/fisk/instructions/jg.rb +36 -0
  165. data/lib/fisk/instructions/jge.rb +36 -0
  166. data/lib/fisk/instructions/jl.rb +36 -0
  167. data/lib/fisk/instructions/jle.rb +36 -0
  168. data/lib/fisk/instructions/jmp.rb +79 -0
  169. data/lib/fisk/instructions/jna.rb +36 -0
  170. data/lib/fisk/instructions/jnae.rb +36 -0
  171. data/lib/fisk/instructions/jnb.rb +36 -0
  172. data/lib/fisk/instructions/jnbe.rb +36 -0
  173. data/lib/fisk/instructions/jnc.rb +36 -0
  174. data/lib/fisk/instructions/jne.rb +36 -0
  175. data/lib/fisk/instructions/jng.rb +36 -0
  176. data/lib/fisk/instructions/jnge.rb +36 -0
  177. data/lib/fisk/instructions/jnl.rb +36 -0
  178. data/lib/fisk/instructions/jnle.rb +36 -0
  179. data/lib/fisk/instructions/jno.rb +36 -0
  180. data/lib/fisk/instructions/jnp.rb +36 -0
  181. data/lib/fisk/instructions/jns.rb +36 -0
  182. data/lib/fisk/instructions/jnz.rb +36 -0
  183. data/lib/fisk/instructions/jo.rb +36 -0
  184. data/lib/fisk/instructions/jp.rb +36 -0
  185. data/lib/fisk/instructions/jpe.rb +36 -0
  186. data/lib/fisk/instructions/jpo.rb +36 -0
  187. data/lib/fisk/instructions/jrcxz.rb +22 -0
  188. data/lib/fisk/instructions/js.rb +36 -0
  189. data/lib/fisk/instructions/jz.rb +36 -0
  190. data/lib/fisk/instructions/kaddb.rb +28 -0
  191. data/lib/fisk/instructions/kaddd.rb +28 -0
  192. data/lib/fisk/instructions/kaddq.rb +28 -0
  193. data/lib/fisk/instructions/kaddw.rb +28 -0
  194. data/lib/fisk/instructions/kandb.rb +28 -0
  195. data/lib/fisk/instructions/kandd.rb +28 -0
  196. data/lib/fisk/instructions/kandnb.rb +28 -0
  197. data/lib/fisk/instructions/kandnd.rb +28 -0
  198. data/lib/fisk/instructions/kandnq.rb +28 -0
  199. data/lib/fisk/instructions/kandnw.rb +28 -0
  200. data/lib/fisk/instructions/kandq.rb +28 -0
  201. data/lib/fisk/instructions/kandw.rb +28 -0
  202. data/lib/fisk/instructions/kmovb.rb +99 -0
  203. data/lib/fisk/instructions/kmovd.rb +99 -0
  204. data/lib/fisk/instructions/kmovq.rb +99 -0
  205. data/lib/fisk/instructions/kmovw.rb +99 -0
  206. data/lib/fisk/instructions/knotb.rb +27 -0
  207. data/lib/fisk/instructions/knotd.rb +27 -0
  208. data/lib/fisk/instructions/knotq.rb +27 -0
  209. data/lib/fisk/instructions/knotw.rb +27 -0
  210. data/lib/fisk/instructions/korb.rb +28 -0
  211. data/lib/fisk/instructions/kord.rb +28 -0
  212. data/lib/fisk/instructions/korq.rb +28 -0
  213. data/lib/fisk/instructions/kortestb.rb +27 -0
  214. data/lib/fisk/instructions/kortestd.rb +27 -0
  215. data/lib/fisk/instructions/kortestq.rb +27 -0
  216. data/lib/fisk/instructions/kortestw.rb +27 -0
  217. data/lib/fisk/instructions/korw.rb +28 -0
  218. data/lib/fisk/instructions/kshiftlb.rb +29 -0
  219. data/lib/fisk/instructions/kshiftld.rb +29 -0
  220. data/lib/fisk/instructions/kshiftlq.rb +29 -0
  221. data/lib/fisk/instructions/kshiftlw.rb +29 -0
  222. data/lib/fisk/instructions/kshiftrb.rb +29 -0
  223. data/lib/fisk/instructions/kshiftrd.rb +29 -0
  224. data/lib/fisk/instructions/kshiftrq.rb +29 -0
  225. data/lib/fisk/instructions/kshiftrw.rb +29 -0
  226. data/lib/fisk/instructions/ktestb.rb +27 -0
  227. data/lib/fisk/instructions/ktestd.rb +27 -0
  228. data/lib/fisk/instructions/ktestq.rb +27 -0
  229. data/lib/fisk/instructions/ktestw.rb +27 -0
  230. data/lib/fisk/instructions/kunpckbw.rb +28 -0
  231. data/lib/fisk/instructions/kunpckdq.rb +28 -0
  232. data/lib/fisk/instructions/kunpckwd.rb +28 -0
  233. data/lib/fisk/instructions/kxnorb.rb +28 -0
  234. data/lib/fisk/instructions/kxnord.rb +28 -0
  235. data/lib/fisk/instructions/kxnorq.rb +28 -0
  236. data/lib/fisk/instructions/kxnorw.rb +28 -0
  237. data/lib/fisk/instructions/kxorb.rb +28 -0
  238. data/lib/fisk/instructions/kxord.rb +28 -0
  239. data/lib/fisk/instructions/kxorq.rb +28 -0
  240. data/lib/fisk/instructions/kxorw.rb +28 -0
  241. data/lib/fisk/instructions/lddqu.rb +34 -0
  242. data/lib/fisk/instructions/ldmxcsr.rb +32 -0
  243. data/lib/fisk/instructions/lea.rb +79 -0
  244. data/lib/fisk/instructions/lfence.rb +22 -0
  245. data/lib/fisk/instructions/lzcnt.rb +161 -0
  246. data/lib/fisk/instructions/maskmovdqu.rb +34 -0
  247. data/lib/fisk/instructions/maskmovq.rb +33 -0
  248. data/lib/fisk/instructions/maxpd.rb +59 -0
  249. data/lib/fisk/instructions/maxps.rb +57 -0
  250. data/lib/fisk/instructions/maxsd.rb +59 -0
  251. data/lib/fisk/instructions/maxss.rb +59 -0
  252. data/lib/fisk/instructions/mfence.rb +22 -0
  253. data/lib/fisk/instructions/minpd.rb +59 -0
  254. data/lib/fisk/instructions/minps.rb +57 -0
  255. data/lib/fisk/instructions/minsd.rb +59 -0
  256. data/lib/fisk/instructions/minss.rb +59 -0
  257. data/lib/fisk/instructions/monitor.rb +22 -0
  258. data/lib/fisk/instructions/monitorx.rb +22 -0
  259. data/lib/fisk/instructions/mov.rb +682 -0
  260. data/lib/fisk/instructions/movapd.rb +103 -0
  261. data/lib/fisk/instructions/movaps.rb +99 -0
  262. data/lib/fisk/instructions/movbe.rb +161 -0
  263. data/lib/fisk/instructions/movd.rb +205 -0
  264. data/lib/fisk/instructions/movddup.rb +59 -0
  265. data/lib/fisk/instructions/movdq2q.rb +34 -0
  266. data/lib/fisk/instructions/movdqa.rb +103 -0
  267. data/lib/fisk/instructions/movdqu.rb +103 -0
  268. data/lib/fisk/instructions/movhlps.rb +33 -0
  269. data/lib/fisk/instructions/movhpd.rb +59 -0
  270. data/lib/fisk/instructions/movhps.rb +57 -0
  271. data/lib/fisk/instructions/movlhps.rb +33 -0
  272. data/lib/fisk/instructions/movlpd.rb +59 -0
  273. data/lib/fisk/instructions/movlps.rb +57 -0
  274. data/lib/fisk/instructions/movmskpd.rb +34 -0
  275. data/lib/fisk/instructions/movmskps.rb +33 -0
  276. data/lib/fisk/instructions/movntdq.rb +34 -0
  277. data/lib/fisk/instructions/movntdqa.rb +35 -0
  278. data/lib/fisk/instructions/movnti.rb +57 -0
  279. data/lib/fisk/instructions/movntpd.rb +34 -0
  280. data/lib/fisk/instructions/movntps.rb +33 -0
  281. data/lib/fisk/instructions/movntq.rb +33 -0
  282. data/lib/fisk/instructions/movntsd.rb +34 -0
  283. data/lib/fisk/instructions/movntss.rb +34 -0
  284. data/lib/fisk/instructions/movq.rb +365 -0
  285. data/lib/fisk/instructions/movq2dq.rb +34 -0
  286. data/lib/fisk/instructions/movsd.rb +103 -0
  287. data/lib/fisk/instructions/movshdup.rb +59 -0
  288. data/lib/fisk/instructions/movsldup.rb +59 -0
  289. data/lib/fisk/instructions/movss.rb +103 -0
  290. data/lib/fisk/instructions/movsx.rb +251 -0
  291. data/lib/fisk/instructions/movsxd.rb +55 -0
  292. data/lib/fisk/instructions/movupd.rb +103 -0
  293. data/lib/fisk/instructions/movups.rb +99 -0
  294. data/lib/fisk/instructions/movzx.rb +251 -0
  295. data/lib/fisk/instructions/mpsadbw.rb +65 -0
  296. data/lib/fisk/instructions/mul.rb +187 -0
  297. data/lib/fisk/instructions/mulpd.rb +59 -0
  298. data/lib/fisk/instructions/mulps.rb +57 -0
  299. data/lib/fisk/instructions/mulsd.rb +59 -0
  300. data/lib/fisk/instructions/mulss.rb +59 -0
  301. data/lib/fisk/instructions/mulx.rb +85 -0
  302. data/lib/fisk/instructions/mwait.rb +22 -0
  303. data/lib/fisk/instructions/mwaitx.rb +22 -0
  304. data/lib/fisk/instructions/neg.rb +187 -0
  305. data/lib/fisk/instructions/nop.rb +20 -0
  306. data/lib/fisk/instructions/not.rb +187 -0
  307. data/lib/fisk/instructions/or.rb +760 -0
  308. data/lib/fisk/instructions/orpd.rb +59 -0
  309. data/lib/fisk/instructions/orps.rb +57 -0
  310. data/lib/fisk/instructions/pabsb.rb +111 -0
  311. data/lib/fisk/instructions/pabsd.rb +111 -0
  312. data/lib/fisk/instructions/pabsw.rb +111 -0
  313. data/lib/fisk/instructions/packssdw.rb +107 -0
  314. data/lib/fisk/instructions/packsswb.rb +107 -0
  315. data/lib/fisk/instructions/packusdw.rb +61 -0
  316. data/lib/fisk/instructions/packuswb.rb +107 -0
  317. data/lib/fisk/instructions/paddb.rb +107 -0
  318. data/lib/fisk/instructions/paddd.rb +107 -0
  319. data/lib/fisk/instructions/paddq.rb +107 -0
  320. data/lib/fisk/instructions/paddsb.rb +107 -0
  321. data/lib/fisk/instructions/paddsw.rb +107 -0
  322. data/lib/fisk/instructions/paddusb.rb +107 -0
  323. data/lib/fisk/instructions/paddusw.rb +107 -0
  324. data/lib/fisk/instructions/paddw.rb +107 -0
  325. data/lib/fisk/instructions/palignr.rb +119 -0
  326. data/lib/fisk/instructions/pand.rb +107 -0
  327. data/lib/fisk/instructions/pandn.rb +107 -0
  328. data/lib/fisk/instructions/pause.rb +21 -0
  329. data/lib/fisk/instructions/pavgb.rb +107 -0
  330. data/lib/fisk/instructions/pavgusb.rb +59 -0
  331. data/lib/fisk/instructions/pavgw.rb +107 -0
  332. data/lib/fisk/instructions/pblendvb.rb +63 -0
  333. data/lib/fisk/instructions/pblendw.rb +65 -0
  334. data/lib/fisk/instructions/pclmulqdq.rb +65 -0
  335. data/lib/fisk/instructions/pcmpeqb.rb +107 -0
  336. data/lib/fisk/instructions/pcmpeqd.rb +107 -0
  337. data/lib/fisk/instructions/pcmpeqq.rb +61 -0
  338. data/lib/fisk/instructions/pcmpeqw.rb +107 -0
  339. data/lib/fisk/instructions/pcmpestri.rb +65 -0
  340. data/lib/fisk/instructions/pcmpestrm.rb +65 -0
  341. data/lib/fisk/instructions/pcmpgtb.rb +107 -0
  342. data/lib/fisk/instructions/pcmpgtd.rb +107 -0
  343. data/lib/fisk/instructions/pcmpgtq.rb +61 -0
  344. data/lib/fisk/instructions/pcmpgtw.rb +107 -0
  345. data/lib/fisk/instructions/pcmpistri.rb +65 -0
  346. data/lib/fisk/instructions/pcmpistrm.rb +65 -0
  347. data/lib/fisk/instructions/pdep.rb +85 -0
  348. data/lib/fisk/instructions/pext.rb +85 -0
  349. data/lib/fisk/instructions/pextrb.rb +65 -0
  350. data/lib/fisk/instructions/pextrd.rb +65 -0
  351. data/lib/fisk/instructions/pextrq.rb +65 -0
  352. data/lib/fisk/instructions/pextrw.rb +111 -0
  353. data/lib/fisk/instructions/pf2id.rb +59 -0
  354. data/lib/fisk/instructions/pf2iw.rb +59 -0
  355. data/lib/fisk/instructions/pfacc.rb +59 -0
  356. data/lib/fisk/instructions/pfadd.rb +59 -0
  357. data/lib/fisk/instructions/pfcmpeq.rb +59 -0
  358. data/lib/fisk/instructions/pfcmpge.rb +59 -0
  359. data/lib/fisk/instructions/pfcmpgt.rb +59 -0
  360. data/lib/fisk/instructions/pfmax.rb +59 -0
  361. data/lib/fisk/instructions/pfmin.rb +59 -0
  362. data/lib/fisk/instructions/pfmul.rb +59 -0
  363. data/lib/fisk/instructions/pfnacc.rb +59 -0
  364. data/lib/fisk/instructions/pfpnacc.rb +59 -0
  365. data/lib/fisk/instructions/pfrcp.rb +59 -0
  366. data/lib/fisk/instructions/pfrcpit1.rb +59 -0
  367. data/lib/fisk/instructions/pfrcpit2.rb +59 -0
  368. data/lib/fisk/instructions/pfrsqit1.rb +59 -0
  369. data/lib/fisk/instructions/pfrsqrt.rb +59 -0
  370. data/lib/fisk/instructions/pfsub.rb +59 -0
  371. data/lib/fisk/instructions/pfsubr.rb +59 -0
  372. data/lib/fisk/instructions/phaddd.rb +111 -0
  373. data/lib/fisk/instructions/phaddsw.rb +111 -0
  374. data/lib/fisk/instructions/phaddw.rb +111 -0
  375. data/lib/fisk/instructions/phminposuw.rb +61 -0
  376. data/lib/fisk/instructions/phsubd.rb +111 -0
  377. data/lib/fisk/instructions/phsubsw.rb +111 -0
  378. data/lib/fisk/instructions/phsubw.rb +111 -0
  379. data/lib/fisk/instructions/pi2fd.rb +59 -0
  380. data/lib/fisk/instructions/pi2fw.rb +59 -0
  381. data/lib/fisk/instructions/pinsrb.rb +65 -0
  382. data/lib/fisk/instructions/pinsrd.rb +65 -0
  383. data/lib/fisk/instructions/pinsrq.rb +65 -0
  384. data/lib/fisk/instructions/pinsrw.rb +115 -0
  385. data/lib/fisk/instructions/pmaddubsw.rb +111 -0
  386. data/lib/fisk/instructions/pmaddwd.rb +107 -0
  387. data/lib/fisk/instructions/pmaxsb.rb +61 -0
  388. data/lib/fisk/instructions/pmaxsd.rb +61 -0
  389. data/lib/fisk/instructions/pmaxsw.rb +107 -0
  390. data/lib/fisk/instructions/pmaxub.rb +107 -0
  391. data/lib/fisk/instructions/pmaxud.rb +61 -0
  392. data/lib/fisk/instructions/pmaxuw.rb +61 -0
  393. data/lib/fisk/instructions/pminsb.rb +61 -0
  394. data/lib/fisk/instructions/pminsd.rb +61 -0
  395. data/lib/fisk/instructions/pminsw.rb +107 -0
  396. data/lib/fisk/instructions/pminub.rb +107 -0
  397. data/lib/fisk/instructions/pminud.rb +61 -0
  398. data/lib/fisk/instructions/pminuw.rb +61 -0
  399. data/lib/fisk/instructions/pmovmskb.rb +58 -0
  400. data/lib/fisk/instructions/pmovsxbd.rb +61 -0
  401. data/lib/fisk/instructions/pmovsxbq.rb +61 -0
  402. data/lib/fisk/instructions/pmovsxbw.rb +61 -0
  403. data/lib/fisk/instructions/pmovsxdq.rb +61 -0
  404. data/lib/fisk/instructions/pmovsxwd.rb +61 -0
  405. data/lib/fisk/instructions/pmovsxwq.rb +61 -0
  406. data/lib/fisk/instructions/pmovzxbd.rb +61 -0
  407. data/lib/fisk/instructions/pmovzxbq.rb +61 -0
  408. data/lib/fisk/instructions/pmovzxbw.rb +61 -0
  409. data/lib/fisk/instructions/pmovzxdq.rb +61 -0
  410. data/lib/fisk/instructions/pmovzxwd.rb +61 -0
  411. data/lib/fisk/instructions/pmovzxwq.rb +61 -0
  412. data/lib/fisk/instructions/pmuldq.rb +61 -0
  413. data/lib/fisk/instructions/pmulhrsw.rb +111 -0
  414. data/lib/fisk/instructions/pmulhrw.rb +59 -0
  415. data/lib/fisk/instructions/pmulhuw.rb +107 -0
  416. data/lib/fisk/instructions/pmulhw.rb +107 -0
  417. data/lib/fisk/instructions/pmulld.rb +61 -0
  418. data/lib/fisk/instructions/pmullw.rb +107 -0
  419. data/lib/fisk/instructions/pmuludq.rb +107 -0
  420. data/lib/fisk/instructions/pop.rb +126 -0
  421. data/lib/fisk/instructions/popcnt.rb +161 -0
  422. data/lib/fisk/instructions/por.rb +107 -0
  423. data/lib/fisk/instructions/prefetch.rb +32 -0
  424. data/lib/fisk/instructions/prefetchnta.rb +32 -0
  425. data/lib/fisk/instructions/prefetcht0.rb +32 -0
  426. data/lib/fisk/instructions/prefetcht1.rb +32 -0
  427. data/lib/fisk/instructions/prefetcht2.rb +32 -0
  428. data/lib/fisk/instructions/prefetchw.rb +32 -0
  429. data/lib/fisk/instructions/prefetchwt1.rb +32 -0
  430. data/lib/fisk/instructions/psadbw.rb +107 -0
  431. data/lib/fisk/instructions/pshufb.rb +111 -0
  432. data/lib/fisk/instructions/pshufd.rb +63 -0
  433. data/lib/fisk/instructions/pshufhw.rb +63 -0
  434. data/lib/fisk/instructions/pshuflw.rb +63 -0
  435. data/lib/fisk/instructions/pshufw.rb +61 -0
  436. data/lib/fisk/instructions/psignb.rb +111 -0
  437. data/lib/fisk/instructions/psignd.rb +111 -0
  438. data/lib/fisk/instructions/psignw.rb +111 -0
  439. data/lib/fisk/instructions/pslld.rb +158 -0
  440. data/lib/fisk/instructions/pslldq.rb +35 -0
  441. data/lib/fisk/instructions/psllq.rb +158 -0
  442. data/lib/fisk/instructions/psllw.rb +158 -0
  443. data/lib/fisk/instructions/psrad.rb +158 -0
  444. data/lib/fisk/instructions/psraw.rb +158 -0
  445. data/lib/fisk/instructions/psrld.rb +158 -0
  446. data/lib/fisk/instructions/psrldq.rb +35 -0
  447. data/lib/fisk/instructions/psrlq.rb +158 -0
  448. data/lib/fisk/instructions/psrlw.rb +158 -0
  449. data/lib/fisk/instructions/psubb.rb +107 -0
  450. data/lib/fisk/instructions/psubd.rb +107 -0
  451. data/lib/fisk/instructions/psubq.rb +107 -0
  452. data/lib/fisk/instructions/psubsb.rb +107 -0
  453. data/lib/fisk/instructions/psubsw.rb +107 -0
  454. data/lib/fisk/instructions/psubusb.rb +107 -0
  455. data/lib/fisk/instructions/psubusw.rb +107 -0
  456. data/lib/fisk/instructions/psubw.rb +107 -0
  457. data/lib/fisk/instructions/pswapd.rb +59 -0
  458. data/lib/fisk/instructions/ptest.rb +61 -0
  459. data/lib/fisk/instructions/punpckhbw.rb +107 -0
  460. data/lib/fisk/instructions/punpckhdq.rb +107 -0
  461. data/lib/fisk/instructions/punpckhqdq.rb +59 -0
  462. data/lib/fisk/instructions/punpckhwd.rb +107 -0
  463. data/lib/fisk/instructions/punpcklbw.rb +107 -0
  464. data/lib/fisk/instructions/punpckldq.rb +107 -0
  465. data/lib/fisk/instructions/punpcklqdq.rb +59 -0
  466. data/lib/fisk/instructions/punpcklwd.rb +107 -0
  467. data/lib/fisk/instructions/push.rb +152 -0
  468. data/lib/fisk/instructions/pxor.rb +107 -0
  469. data/lib/fisk/instructions/rcl.rb +575 -0
  470. data/lib/fisk/instructions/rcpps.rb +57 -0
  471. data/lib/fisk/instructions/rcpss.rb +59 -0
  472. data/lib/fisk/instructions/rcr.rb +575 -0
  473. data/lib/fisk/instructions/rdrand.rb +79 -0
  474. data/lib/fisk/instructions/rdseed.rb +79 -0
  475. data/lib/fisk/instructions/rdtsc.rb +21 -0
  476. data/lib/fisk/instructions/rdtscp.rb +22 -0
  477. data/lib/fisk/instructions/ret.rb +33 -0
  478. data/lib/fisk/instructions/rol.rb +575 -0
  479. data/lib/fisk/instructions/ror.rb +575 -0
  480. data/lib/fisk/instructions/rorx.rb +89 -0
  481. data/lib/fisk/instructions/roundpd.rb +65 -0
  482. data/lib/fisk/instructions/roundps.rb +65 -0
  483. data/lib/fisk/instructions/roundsd.rb +65 -0
  484. data/lib/fisk/instructions/roundss.rb +65 -0
  485. data/lib/fisk/instructions/rsqrtps.rb +57 -0
  486. data/lib/fisk/instructions/rsqrtss.rb +59 -0
  487. data/lib/fisk/instructions/sal.rb +575 -0
  488. data/lib/fisk/instructions/sar.rb +575 -0
  489. data/lib/fisk/instructions/sarx.rb +85 -0
  490. data/lib/fisk/instructions/sbb.rb +760 -0
  491. data/lib/fisk/instructions/seta.rb +55 -0
  492. data/lib/fisk/instructions/setae.rb +55 -0
  493. data/lib/fisk/instructions/setb.rb +55 -0
  494. data/lib/fisk/instructions/setbe.rb +55 -0
  495. data/lib/fisk/instructions/setc.rb +55 -0
  496. data/lib/fisk/instructions/sete.rb +55 -0
  497. data/lib/fisk/instructions/setg.rb +55 -0
  498. data/lib/fisk/instructions/setge.rb +55 -0
  499. data/lib/fisk/instructions/setl.rb +55 -0
  500. data/lib/fisk/instructions/setle.rb +55 -0
  501. data/lib/fisk/instructions/setna.rb +55 -0
  502. data/lib/fisk/instructions/setnae.rb +55 -0
  503. data/lib/fisk/instructions/setnb.rb +55 -0
  504. data/lib/fisk/instructions/setnbe.rb +55 -0
  505. data/lib/fisk/instructions/setnc.rb +55 -0
  506. data/lib/fisk/instructions/setne.rb +55 -0
  507. data/lib/fisk/instructions/setng.rb +55 -0
  508. data/lib/fisk/instructions/setnge.rb +55 -0
  509. data/lib/fisk/instructions/setnl.rb +55 -0
  510. data/lib/fisk/instructions/setnle.rb +55 -0
  511. data/lib/fisk/instructions/setno.rb +55 -0
  512. data/lib/fisk/instructions/setnp.rb +55 -0
  513. data/lib/fisk/instructions/setns.rb +55 -0
  514. data/lib/fisk/instructions/setnz.rb +55 -0
  515. data/lib/fisk/instructions/seto.rb +55 -0
  516. data/lib/fisk/instructions/setp.rb +55 -0
  517. data/lib/fisk/instructions/setpe.rb +55 -0
  518. data/lib/fisk/instructions/setpo.rb +55 -0
  519. data/lib/fisk/instructions/sets.rb +55 -0
  520. data/lib/fisk/instructions/setz.rb +55 -0
  521. data/lib/fisk/instructions/sfence.rb +22 -0
  522. data/lib/fisk/instructions/sha1msg1.rb +59 -0
  523. data/lib/fisk/instructions/sha1msg2.rb +59 -0
  524. data/lib/fisk/instructions/sha1nexte.rb +59 -0
  525. data/lib/fisk/instructions/sha1rnds4.rb +63 -0
  526. data/lib/fisk/instructions/sha256msg1.rb +59 -0
  527. data/lib/fisk/instructions/sha256msg2.rb +59 -0
  528. data/lib/fisk/instructions/sha256rnds2.rb +61 -0
  529. data/lib/fisk/instructions/shl.rb +575 -0
  530. data/lib/fisk/instructions/shld.rb +319 -0
  531. data/lib/fisk/instructions/shlx.rb +85 -0
  532. data/lib/fisk/instructions/shr.rb +575 -0
  533. data/lib/fisk/instructions/shrd.rb +319 -0
  534. data/lib/fisk/instructions/shrx.rb +85 -0
  535. data/lib/fisk/instructions/shufpd.rb +63 -0
  536. data/lib/fisk/instructions/shufps.rb +61 -0
  537. data/lib/fisk/instructions/sqrtpd.rb +59 -0
  538. data/lib/fisk/instructions/sqrtps.rb +57 -0
  539. data/lib/fisk/instructions/sqrtsd.rb +59 -0
  540. data/lib/fisk/instructions/sqrtss.rb +59 -0
  541. data/lib/fisk/instructions/stc.rb +20 -0
  542. data/lib/fisk/instructions/std.rb +20 -0
  543. data/lib/fisk/instructions/stmxcsr.rb +32 -0
  544. data/lib/fisk/instructions/sub.rb +760 -0
  545. data/lib/fisk/instructions/subpd.rb +59 -0
  546. data/lib/fisk/instructions/subps.rb +57 -0
  547. data/lib/fisk/instructions/subsd.rb +59 -0
  548. data/lib/fisk/instructions/subss.rb +59 -0
  549. data/lib/fisk/instructions/syscall.rb +21 -0
  550. data/lib/fisk/instructions/t1mskc.rb +81 -0
  551. data/lib/fisk/instructions/test.rb +452 -0
  552. data/lib/fisk/instructions/tzcnt.rb +161 -0
  553. data/lib/fisk/instructions/tzmsk.rb +81 -0
  554. data/lib/fisk/instructions/ucomisd.rb +59 -0
  555. data/lib/fisk/instructions/ucomiss.rb +57 -0
  556. data/lib/fisk/instructions/ud2.rb +21 -0
  557. data/lib/fisk/instructions/unpckhpd.rb +59 -0
  558. data/lib/fisk/instructions/unpckhps.rb +57 -0
  559. data/lib/fisk/instructions/unpcklpd.rb +59 -0
  560. data/lib/fisk/instructions/unpcklps.rb +57 -0
  561. data/lib/fisk/instructions/vaddpd.rb +200 -0
  562. data/lib/fisk/instructions/vaddps.rb +200 -0
  563. data/lib/fisk/instructions/vaddsd.rb +86 -0
  564. data/lib/fisk/instructions/vaddss.rb +86 -0
  565. data/lib/fisk/instructions/vaddsubpd.rb +85 -0
  566. data/lib/fisk/instructions/vaddsubps.rb +85 -0
  567. data/lib/fisk/instructions/vaesdec.rb +47 -0
  568. data/lib/fisk/instructions/vaesdeclast.rb +47 -0
  569. data/lib/fisk/instructions/vaesenc.rb +47 -0
  570. data/lib/fisk/instructions/vaesenclast.rb +47 -0
  571. data/lib/fisk/instructions/vaesimc.rb +45 -0
  572. data/lib/fisk/instructions/vaeskeygenassist.rb +49 -0
  573. data/lib/fisk/instructions/valignd.rb +135 -0
  574. data/lib/fisk/instructions/valignq.rb +135 -0
  575. data/lib/fisk/instructions/vandnpd.rb +199 -0
  576. data/lib/fisk/instructions/vandnps.rb +199 -0
  577. data/lib/fisk/instructions/vandpd.rb +199 -0
  578. data/lib/fisk/instructions/vandps.rb +199 -0
  579. data/lib/fisk/instructions/vblendmpd.rb +123 -0
  580. data/lib/fisk/instructions/vblendmps.rb +123 -0
  581. data/lib/fisk/instructions/vblendpd.rb +93 -0
  582. data/lib/fisk/instructions/vblendps.rb +93 -0
  583. data/lib/fisk/instructions/vblendvpd.rb +93 -0
  584. data/lib/fisk/instructions/vblendvps.rb +93 -0
  585. data/lib/fisk/instructions/vbroadcastf128.rb +27 -0
  586. data/lib/fisk/instructions/vbroadcastf32x2.rb +81 -0
  587. data/lib/fisk/instructions/vbroadcastf32x4.rb +45 -0
  588. data/lib/fisk/instructions/vbroadcastf32x8.rb +27 -0
  589. data/lib/fisk/instructions/vbroadcastf64x2.rb +45 -0
  590. data/lib/fisk/instructions/vbroadcastf64x4.rb +27 -0
  591. data/lib/fisk/instructions/vbroadcasti128.rb +27 -0
  592. data/lib/fisk/instructions/vbroadcasti32x2.rb +117 -0
  593. data/lib/fisk/instructions/vbroadcasti32x4.rb +45 -0
  594. data/lib/fisk/instructions/vbroadcasti32x8.rb +27 -0
  595. data/lib/fisk/instructions/vbroadcasti64x2.rb +45 -0
  596. data/lib/fisk/instructions/vbroadcasti64x4.rb +27 -0
  597. data/lib/fisk/instructions/vbroadcastsd.rb +117 -0
  598. data/lib/fisk/instructions/vbroadcastss.rb +153 -0
  599. data/lib/fisk/instructions/vcmppd.rb +220 -0
  600. data/lib/fisk/instructions/vcmpps.rb +220 -0
  601. data/lib/fisk/instructions/vcmpsd.rb +94 -0
  602. data/lib/fisk/instructions/vcmpss.rb +94 -0
  603. data/lib/fisk/instructions/vcomisd.rb +82 -0
  604. data/lib/fisk/instructions/vcomiss.rb +82 -0
  605. data/lib/fisk/instructions/vcompresspd.rb +117 -0
  606. data/lib/fisk/instructions/vcompressps.rb +117 -0
  607. data/lib/fisk/instructions/vcvtdq2pd.rb +189 -0
  608. data/lib/fisk/instructions/vcvtdq2ps.rb +190 -0
  609. data/lib/fisk/instructions/vcvtpd2dq.rb +190 -0
  610. data/lib/fisk/instructions/vcvtpd2ps.rb +190 -0
  611. data/lib/fisk/instructions/vcvtpd2qq.rb +118 -0
  612. data/lib/fisk/instructions/vcvtpd2udq.rb +118 -0
  613. data/lib/fisk/instructions/vcvtpd2uqq.rb +118 -0
  614. data/lib/fisk/instructions/vcvtph2ps.rb +190 -0
  615. data/lib/fisk/instructions/vcvtps2dq.rb +190 -0
  616. data/lib/fisk/instructions/vcvtps2pd.rb +190 -0
  617. data/lib/fisk/instructions/vcvtps2ph.rb +210 -0
  618. data/lib/fisk/instructions/vcvtps2qq.rb +118 -0
  619. data/lib/fisk/instructions/vcvtps2udq.rb +118 -0
  620. data/lib/fisk/instructions/vcvtps2uqq.rb +118 -0
  621. data/lib/fisk/instructions/vcvtqq2pd.rb +118 -0
  622. data/lib/fisk/instructions/vcvtqq2ps.rb +118 -0
  623. data/lib/fisk/instructions/vcvtsd2si.rb +155 -0
  624. data/lib/fisk/instructions/vcvtsd2ss.rb +86 -0
  625. data/lib/fisk/instructions/vcvtsd2usi.rb +83 -0
  626. data/lib/fisk/instructions/vcvtsi2sd.rb +162 -0
  627. data/lib/fisk/instructions/vcvtsi2ss.rb +163 -0
  628. data/lib/fisk/instructions/vcvtss2sd.rb +86 -0
  629. data/lib/fisk/instructions/vcvtss2si.rb +155 -0
  630. data/lib/fisk/instructions/vcvtss2usi.rb +83 -0
  631. data/lib/fisk/instructions/vcvttpd2dq.rb +190 -0
  632. data/lib/fisk/instructions/vcvttpd2qq.rb +118 -0
  633. data/lib/fisk/instructions/vcvttpd2udq.rb +118 -0
  634. data/lib/fisk/instructions/vcvttpd2uqq.rb +118 -0
  635. data/lib/fisk/instructions/vcvttps2dq.rb +190 -0
  636. data/lib/fisk/instructions/vcvttps2qq.rb +118 -0
  637. data/lib/fisk/instructions/vcvttps2udq.rb +118 -0
  638. data/lib/fisk/instructions/vcvttps2uqq.rb +118 -0
  639. data/lib/fisk/instructions/vcvttsd2si.rb +155 -0
  640. data/lib/fisk/instructions/vcvttsd2usi.rb +83 -0
  641. data/lib/fisk/instructions/vcvttss2si.rb +155 -0
  642. data/lib/fisk/instructions/vcvttss2usi.rb +83 -0
  643. data/lib/fisk/instructions/vcvtudq2pd.rb +117 -0
  644. data/lib/fisk/instructions/vcvtudq2ps.rb +118 -0
  645. data/lib/fisk/instructions/vcvtuqq2pd.rb +118 -0
  646. data/lib/fisk/instructions/vcvtuqq2ps.rb +118 -0
  647. data/lib/fisk/instructions/vcvtusi2sd.rb +86 -0
  648. data/lib/fisk/instructions/vcvtusi2ss.rb +87 -0
  649. data/lib/fisk/instructions/vdbpsadbw.rb +135 -0
  650. data/lib/fisk/instructions/vdivpd.rb +200 -0
  651. data/lib/fisk/instructions/vdivps.rb +200 -0
  652. data/lib/fisk/instructions/vdivsd.rb +86 -0
  653. data/lib/fisk/instructions/vdivss.rb +86 -0
  654. data/lib/fisk/instructions/vdppd.rb +51 -0
  655. data/lib/fisk/instructions/vdpps.rb +93 -0
  656. data/lib/fisk/instructions/vexp2pd.rb +46 -0
  657. data/lib/fisk/instructions/vexp2ps.rb +46 -0
  658. data/lib/fisk/instructions/vexpandpd.rb +117 -0
  659. data/lib/fisk/instructions/vexpandps.rb +117 -0
  660. data/lib/fisk/instructions/vextractf128.rb +49 -0
  661. data/lib/fisk/instructions/vextractf32x4.rb +89 -0
  662. data/lib/fisk/instructions/vextractf32x8.rb +49 -0
  663. data/lib/fisk/instructions/vextractf64x2.rb +89 -0
  664. data/lib/fisk/instructions/vextractf64x4.rb +49 -0
  665. data/lib/fisk/instructions/vextracti128.rb +49 -0
  666. data/lib/fisk/instructions/vextracti32x4.rb +89 -0
  667. data/lib/fisk/instructions/vextracti32x8.rb +49 -0
  668. data/lib/fisk/instructions/vextracti64x2.rb +89 -0
  669. data/lib/fisk/instructions/vextracti64x4.rb +49 -0
  670. data/lib/fisk/instructions/vextractps.rb +89 -0
  671. data/lib/fisk/instructions/vfixupimmpd.rb +136 -0
  672. data/lib/fisk/instructions/vfixupimmps.rb +136 -0
  673. data/lib/fisk/instructions/vfixupimmsd.rb +52 -0
  674. data/lib/fisk/instructions/vfixupimmss.rb +52 -0
  675. data/lib/fisk/instructions/vfmadd132pd.rb +200 -0
  676. data/lib/fisk/instructions/vfmadd132ps.rb +200 -0
  677. data/lib/fisk/instructions/vfmadd132sd.rb +86 -0
  678. data/lib/fisk/instructions/vfmadd132ss.rb +86 -0
  679. data/lib/fisk/instructions/vfmadd213pd.rb +200 -0
  680. data/lib/fisk/instructions/vfmadd213ps.rb +200 -0
  681. data/lib/fisk/instructions/vfmadd213sd.rb +86 -0
  682. data/lib/fisk/instructions/vfmadd213ss.rb +86 -0
  683. data/lib/fisk/instructions/vfmadd231pd.rb +200 -0
  684. data/lib/fisk/instructions/vfmadd231ps.rb +200 -0
  685. data/lib/fisk/instructions/vfmadd231sd.rb +86 -0
  686. data/lib/fisk/instructions/vfmadd231ss.rb +86 -0
  687. data/lib/fisk/instructions/vfmaddpd.rb +161 -0
  688. data/lib/fisk/instructions/vfmaddps.rb +161 -0
  689. data/lib/fisk/instructions/vfmaddsd.rb +85 -0
  690. data/lib/fisk/instructions/vfmaddss.rb +85 -0
  691. data/lib/fisk/instructions/vfmaddsub132pd.rb +200 -0
  692. data/lib/fisk/instructions/vfmaddsub132ps.rb +200 -0
  693. data/lib/fisk/instructions/vfmaddsub213pd.rb +200 -0
  694. data/lib/fisk/instructions/vfmaddsub213ps.rb +200 -0
  695. data/lib/fisk/instructions/vfmaddsub231pd.rb +200 -0
  696. data/lib/fisk/instructions/vfmaddsub231ps.rb +200 -0
  697. data/lib/fisk/instructions/vfmaddsubpd.rb +161 -0
  698. data/lib/fisk/instructions/vfmaddsubps.rb +161 -0
  699. data/lib/fisk/instructions/vfmsub132pd.rb +200 -0
  700. data/lib/fisk/instructions/vfmsub132ps.rb +200 -0
  701. data/lib/fisk/instructions/vfmsub132sd.rb +86 -0
  702. data/lib/fisk/instructions/vfmsub132ss.rb +86 -0
  703. data/lib/fisk/instructions/vfmsub213pd.rb +200 -0
  704. data/lib/fisk/instructions/vfmsub213ps.rb +200 -0
  705. data/lib/fisk/instructions/vfmsub213sd.rb +86 -0
  706. data/lib/fisk/instructions/vfmsub213ss.rb +86 -0
  707. data/lib/fisk/instructions/vfmsub231pd.rb +200 -0
  708. data/lib/fisk/instructions/vfmsub231ps.rb +200 -0
  709. data/lib/fisk/instructions/vfmsub231sd.rb +86 -0
  710. data/lib/fisk/instructions/vfmsub231ss.rb +86 -0
  711. data/lib/fisk/instructions/vfmsubadd132pd.rb +200 -0
  712. data/lib/fisk/instructions/vfmsubadd132ps.rb +200 -0
  713. data/lib/fisk/instructions/vfmsubadd213pd.rb +200 -0
  714. data/lib/fisk/instructions/vfmsubadd213ps.rb +200 -0
  715. data/lib/fisk/instructions/vfmsubadd231pd.rb +200 -0
  716. data/lib/fisk/instructions/vfmsubadd231ps.rb +200 -0
  717. data/lib/fisk/instructions/vfmsubaddpd.rb +161 -0
  718. data/lib/fisk/instructions/vfmsubaddps.rb +161 -0
  719. data/lib/fisk/instructions/vfmsubpd.rb +161 -0
  720. data/lib/fisk/instructions/vfmsubps.rb +161 -0
  721. data/lib/fisk/instructions/vfmsubsd.rb +85 -0
  722. data/lib/fisk/instructions/vfmsubss.rb +85 -0
  723. data/lib/fisk/instructions/vfnmadd132pd.rb +200 -0
  724. data/lib/fisk/instructions/vfnmadd132ps.rb +200 -0
  725. data/lib/fisk/instructions/vfnmadd132sd.rb +86 -0
  726. data/lib/fisk/instructions/vfnmadd132ss.rb +86 -0
  727. data/lib/fisk/instructions/vfnmadd213pd.rb +200 -0
  728. data/lib/fisk/instructions/vfnmadd213ps.rb +200 -0
  729. data/lib/fisk/instructions/vfnmadd213sd.rb +86 -0
  730. data/lib/fisk/instructions/vfnmadd213ss.rb +86 -0
  731. data/lib/fisk/instructions/vfnmadd231pd.rb +200 -0
  732. data/lib/fisk/instructions/vfnmadd231ps.rb +200 -0
  733. data/lib/fisk/instructions/vfnmadd231sd.rb +86 -0
  734. data/lib/fisk/instructions/vfnmadd231ss.rb +86 -0
  735. data/lib/fisk/instructions/vfnmaddpd.rb +161 -0
  736. data/lib/fisk/instructions/vfnmaddps.rb +161 -0
  737. data/lib/fisk/instructions/vfnmaddsd.rb +85 -0
  738. data/lib/fisk/instructions/vfnmaddss.rb +85 -0
  739. data/lib/fisk/instructions/vfnmsub132pd.rb +200 -0
  740. data/lib/fisk/instructions/vfnmsub132ps.rb +200 -0
  741. data/lib/fisk/instructions/vfnmsub132sd.rb +86 -0
  742. data/lib/fisk/instructions/vfnmsub132ss.rb +86 -0
  743. data/lib/fisk/instructions/vfnmsub213pd.rb +200 -0
  744. data/lib/fisk/instructions/vfnmsub213ps.rb +200 -0
  745. data/lib/fisk/instructions/vfnmsub213sd.rb +86 -0
  746. data/lib/fisk/instructions/vfnmsub213ss.rb +86 -0
  747. data/lib/fisk/instructions/vfnmsub231pd.rb +200 -0
  748. data/lib/fisk/instructions/vfnmsub231ps.rb +200 -0
  749. data/lib/fisk/instructions/vfnmsub231sd.rb +86 -0
  750. data/lib/fisk/instructions/vfnmsub231ss.rb +86 -0
  751. data/lib/fisk/instructions/vfnmsubpd.rb +161 -0
  752. data/lib/fisk/instructions/vfnmsubps.rb +161 -0
  753. data/lib/fisk/instructions/vfnmsubsd.rb +85 -0
  754. data/lib/fisk/instructions/vfnmsubss.rb +85 -0
  755. data/lib/fisk/instructions/vfpclasspd.rb +129 -0
  756. data/lib/fisk/instructions/vfpclassps.rb +129 -0
  757. data/lib/fisk/instructions/vfpclasssd.rb +49 -0
  758. data/lib/fisk/instructions/vfpclassss.rb +49 -0
  759. data/lib/fisk/instructions/vfrczpd.rb +81 -0
  760. data/lib/fisk/instructions/vfrczps.rb +81 -0
  761. data/lib/fisk/instructions/vfrczsd.rb +45 -0
  762. data/lib/fisk/instructions/vfrczss.rb +45 -0
  763. data/lib/fisk/instructions/vgatherdpd.rb +101 -0
  764. data/lib/fisk/instructions/vgatherdps.rb +101 -0
  765. data/lib/fisk/instructions/vgatherpf0dpd.rb +26 -0
  766. data/lib/fisk/instructions/vgatherpf0dps.rb +26 -0
  767. data/lib/fisk/instructions/vgatherpf0qpd.rb +26 -0
  768. data/lib/fisk/instructions/vgatherpf0qps.rb +26 -0
  769. data/lib/fisk/instructions/vgatherpf1dpd.rb +26 -0
  770. data/lib/fisk/instructions/vgatherpf1dps.rb +26 -0
  771. data/lib/fisk/instructions/vgatherpf1qpd.rb +26 -0
  772. data/lib/fisk/instructions/vgatherpf1qps.rb +26 -0
  773. data/lib/fisk/instructions/vgatherqpd.rb +101 -0
  774. data/lib/fisk/instructions/vgatherqps.rb +101 -0
  775. data/lib/fisk/instructions/vgetexppd.rb +118 -0
  776. data/lib/fisk/instructions/vgetexpps.rb +118 -0
  777. data/lib/fisk/instructions/vgetexpsd.rb +48 -0
  778. data/lib/fisk/instructions/vgetexpss.rb +48 -0
  779. data/lib/fisk/instructions/vgetmantpd.rb +130 -0
  780. data/lib/fisk/instructions/vgetmantps.rb +130 -0
  781. data/lib/fisk/instructions/vgetmantsd.rb +52 -0
  782. data/lib/fisk/instructions/vgetmantss.rb +52 -0
  783. data/lib/fisk/instructions/vhaddpd.rb +85 -0
  784. data/lib/fisk/instructions/vhaddps.rb +85 -0
  785. data/lib/fisk/instructions/vhsubpd.rb +85 -0
  786. data/lib/fisk/instructions/vhsubps.rb +85 -0
  787. data/lib/fisk/instructions/vinsertf128.rb +51 -0
  788. data/lib/fisk/instructions/vinsertf32x4.rb +93 -0
  789. data/lib/fisk/instructions/vinsertf32x8.rb +51 -0
  790. data/lib/fisk/instructions/vinsertf64x2.rb +93 -0
  791. data/lib/fisk/instructions/vinsertf64x4.rb +51 -0
  792. data/lib/fisk/instructions/vinserti128.rb +51 -0
  793. data/lib/fisk/instructions/vinserti32x4.rb +93 -0
  794. data/lib/fisk/instructions/vinserti32x8.rb +51 -0
  795. data/lib/fisk/instructions/vinserti64x2.rb +93 -0
  796. data/lib/fisk/instructions/vinserti64x4.rb +51 -0
  797. data/lib/fisk/instructions/vinsertps.rb +93 -0
  798. data/lib/fisk/instructions/vlddqu.rb +45 -0
  799. data/lib/fisk/instructions/vldmxcsr.rb +26 -0
  800. data/lib/fisk/instructions/vmaskmovdqu.rb +27 -0
  801. data/lib/fisk/instructions/vmaskmovpd.rb +85 -0
  802. data/lib/fisk/instructions/vmaskmovps.rb +85 -0
  803. data/lib/fisk/instructions/vmaxpd.rb +200 -0
  804. data/lib/fisk/instructions/vmaxps.rb +200 -0
  805. data/lib/fisk/instructions/vmaxsd.rb +86 -0
  806. data/lib/fisk/instructions/vmaxss.rb +86 -0
  807. data/lib/fisk/instructions/vminpd.rb +200 -0
  808. data/lib/fisk/instructions/vminps.rb +200 -0
  809. data/lib/fisk/instructions/vminsd.rb +86 -0
  810. data/lib/fisk/instructions/vminss.rb +86 -0
  811. data/lib/fisk/instructions/vmovapd.rb +339 -0
  812. data/lib/fisk/instructions/vmovaps.rb +339 -0
  813. data/lib/fisk/instructions/vmovd.rb +153 -0
  814. data/lib/fisk/instructions/vmovddup.rb +189 -0
  815. data/lib/fisk/instructions/vmovdqa.rb +141 -0
  816. data/lib/fisk/instructions/vmovdqa32.rb +207 -0
  817. data/lib/fisk/instructions/vmovdqa64.rb +207 -0
  818. data/lib/fisk/instructions/vmovdqu.rb +141 -0
  819. data/lib/fisk/instructions/vmovdqu16.rb +207 -0
  820. data/lib/fisk/instructions/vmovdqu32.rb +207 -0
  821. data/lib/fisk/instructions/vmovdqu64.rb +207 -0
  822. data/lib/fisk/instructions/vmovdqu8.rb +207 -0
  823. data/lib/fisk/instructions/vmovhlps.rb +47 -0
  824. data/lib/fisk/instructions/vmovhpd.rb +83 -0
  825. data/lib/fisk/instructions/vmovhps.rb +83 -0
  826. data/lib/fisk/instructions/vmovlhps.rb +47 -0
  827. data/lib/fisk/instructions/vmovlpd.rb +83 -0
  828. data/lib/fisk/instructions/vmovlps.rb +83 -0
  829. data/lib/fisk/instructions/vmovmskpd.rb +45 -0
  830. data/lib/fisk/instructions/vmovmskps.rb +45 -0
  831. data/lib/fisk/instructions/vmovntdq.rb +99 -0
  832. data/lib/fisk/instructions/vmovntdqa.rb +99 -0
  833. data/lib/fisk/instructions/vmovntpd.rb +99 -0
  834. data/lib/fisk/instructions/vmovntps.rb +99 -0
  835. data/lib/fisk/instructions/vmovq.rb +261 -0
  836. data/lib/fisk/instructions/vmovsd.rb +143 -0
  837. data/lib/fisk/instructions/vmovshdup.rb +189 -0
  838. data/lib/fisk/instructions/vmovsldup.rb +189 -0
  839. data/lib/fisk/instructions/vmovss.rb +143 -0
  840. data/lib/fisk/instructions/vmovupd.rb +339 -0
  841. data/lib/fisk/instructions/vmovups.rb +339 -0
  842. data/lib/fisk/instructions/vmpsadbw.rb +93 -0
  843. data/lib/fisk/instructions/vmulpd.rb +200 -0
  844. data/lib/fisk/instructions/vmulps.rb +200 -0
  845. data/lib/fisk/instructions/vmulsd.rb +86 -0
  846. data/lib/fisk/instructions/vmulss.rb +86 -0
  847. data/lib/fisk/instructions/vorpd.rb +199 -0
  848. data/lib/fisk/instructions/vorps.rb +199 -0
  849. data/lib/fisk/instructions/vpabsb.rb +189 -0
  850. data/lib/fisk/instructions/vpabsd.rb +189 -0
  851. data/lib/fisk/instructions/vpabsq.rb +117 -0
  852. data/lib/fisk/instructions/vpabsw.rb +189 -0
  853. data/lib/fisk/instructions/vpackssdw.rb +199 -0
  854. data/lib/fisk/instructions/vpacksswb.rb +199 -0
  855. data/lib/fisk/instructions/vpackusdw.rb +199 -0
  856. data/lib/fisk/instructions/vpackuswb.rb +199 -0
  857. data/lib/fisk/instructions/vpaddb.rb +199 -0
  858. data/lib/fisk/instructions/vpaddd.rb +199 -0
  859. data/lib/fisk/instructions/vpaddq.rb +199 -0
  860. data/lib/fisk/instructions/vpaddsb.rb +199 -0
  861. data/lib/fisk/instructions/vpaddsw.rb +199 -0
  862. data/lib/fisk/instructions/vpaddusb.rb +199 -0
  863. data/lib/fisk/instructions/vpaddusw.rb +199 -0
  864. data/lib/fisk/instructions/vpaddw.rb +199 -0
  865. data/lib/fisk/instructions/vpalignr.rb +219 -0
  866. data/lib/fisk/instructions/vpand.rb +85 -0
  867. data/lib/fisk/instructions/vpandd.rb +123 -0
  868. data/lib/fisk/instructions/vpandn.rb +85 -0
  869. data/lib/fisk/instructions/vpandnd.rb +123 -0
  870. data/lib/fisk/instructions/vpandnq.rb +123 -0
  871. data/lib/fisk/instructions/vpandq.rb +123 -0
  872. data/lib/fisk/instructions/vpavgb.rb +199 -0
  873. data/lib/fisk/instructions/vpavgw.rb +199 -0
  874. data/lib/fisk/instructions/vpblendd.rb +93 -0
  875. data/lib/fisk/instructions/vpblendmb.rb +123 -0
  876. data/lib/fisk/instructions/vpblendmd.rb +123 -0
  877. data/lib/fisk/instructions/vpblendmq.rb +123 -0
  878. data/lib/fisk/instructions/vpblendmw.rb +123 -0
  879. data/lib/fisk/instructions/vpblendvb.rb +93 -0
  880. data/lib/fisk/instructions/vpblendw.rb +93 -0
  881. data/lib/fisk/instructions/vpbroadcastb.rb +243 -0
  882. data/lib/fisk/instructions/vpbroadcastd.rb +243 -0
  883. data/lib/fisk/instructions/vpbroadcastmb2q.rb +63 -0
  884. data/lib/fisk/instructions/vpbroadcastmw2d.rb +63 -0
  885. data/lib/fisk/instructions/vpbroadcastq.rb +243 -0
  886. data/lib/fisk/instructions/vpbroadcastw.rb +243 -0
  887. data/lib/fisk/instructions/vpclmulqdq.rb +51 -0
  888. data/lib/fisk/instructions/vpcmov.rb +161 -0
  889. data/lib/fisk/instructions/vpcmpb.rb +135 -0
  890. data/lib/fisk/instructions/vpcmpd.rb +135 -0
  891. data/lib/fisk/instructions/vpcmpeqb.rb +199 -0
  892. data/lib/fisk/instructions/vpcmpeqd.rb +199 -0
  893. data/lib/fisk/instructions/vpcmpeqq.rb +199 -0
  894. data/lib/fisk/instructions/vpcmpeqw.rb +199 -0
  895. data/lib/fisk/instructions/vpcmpestri.rb +49 -0
  896. data/lib/fisk/instructions/vpcmpestrm.rb +49 -0
  897. data/lib/fisk/instructions/vpcmpgtb.rb +199 -0
  898. data/lib/fisk/instructions/vpcmpgtd.rb +199 -0
  899. data/lib/fisk/instructions/vpcmpgtq.rb +199 -0
  900. data/lib/fisk/instructions/vpcmpgtw.rb +199 -0
  901. data/lib/fisk/instructions/vpcmpistri.rb +49 -0
  902. data/lib/fisk/instructions/vpcmpistrm.rb +49 -0
  903. data/lib/fisk/instructions/vpcmpq.rb +135 -0
  904. data/lib/fisk/instructions/vpcmpub.rb +135 -0
  905. data/lib/fisk/instructions/vpcmpud.rb +135 -0
  906. data/lib/fisk/instructions/vpcmpuq.rb +135 -0
  907. data/lib/fisk/instructions/vpcmpuw.rb +135 -0
  908. data/lib/fisk/instructions/vpcmpw.rb +135 -0
  909. data/lib/fisk/instructions/vpcomb.rb +51 -0
  910. data/lib/fisk/instructions/vpcomd.rb +51 -0
  911. data/lib/fisk/instructions/vpcompressd.rb +117 -0
  912. data/lib/fisk/instructions/vpcompressq.rb +117 -0
  913. data/lib/fisk/instructions/vpcomq.rb +51 -0
  914. data/lib/fisk/instructions/vpcomub.rb +51 -0
  915. data/lib/fisk/instructions/vpcomud.rb +51 -0
  916. data/lib/fisk/instructions/vpcomuq.rb +51 -0
  917. data/lib/fisk/instructions/vpcomuw.rb +51 -0
  918. data/lib/fisk/instructions/vpcomw.rb +51 -0
  919. data/lib/fisk/instructions/vpconflictd.rb +117 -0
  920. data/lib/fisk/instructions/vpconflictq.rb +117 -0
  921. data/lib/fisk/instructions/vperm2f128.rb +51 -0
  922. data/lib/fisk/instructions/vperm2i128.rb +51 -0
  923. data/lib/fisk/instructions/vpermb.rb +123 -0
  924. data/lib/fisk/instructions/vpermd.rb +123 -0
  925. data/lib/fisk/instructions/vpermi2b.rb +123 -0
  926. data/lib/fisk/instructions/vpermi2d.rb +123 -0
  927. data/lib/fisk/instructions/vpermi2pd.rb +123 -0
  928. data/lib/fisk/instructions/vpermi2ps.rb +123 -0
  929. data/lib/fisk/instructions/vpermi2q.rb +123 -0
  930. data/lib/fisk/instructions/vpermi2w.rb +123 -0
  931. data/lib/fisk/instructions/vpermil2pd.rb +167 -0
  932. data/lib/fisk/instructions/vpermil2ps.rb +167 -0
  933. data/lib/fisk/instructions/vpermilpd.rb +399 -0
  934. data/lib/fisk/instructions/vpermilps.rb +399 -0
  935. data/lib/fisk/instructions/vpermpd.rb +205 -0
  936. data/lib/fisk/instructions/vpermps.rb +123 -0
  937. data/lib/fisk/instructions/vpermq.rb +205 -0
  938. data/lib/fisk/instructions/vpermt2b.rb +123 -0
  939. data/lib/fisk/instructions/vpermt2d.rb +123 -0
  940. data/lib/fisk/instructions/vpermt2pd.rb +123 -0
  941. data/lib/fisk/instructions/vpermt2ps.rb +123 -0
  942. data/lib/fisk/instructions/vpermt2q.rb +123 -0
  943. data/lib/fisk/instructions/vpermt2w.rb +123 -0
  944. data/lib/fisk/instructions/vpermw.rb +123 -0
  945. data/lib/fisk/instructions/vpexpandd.rb +117 -0
  946. data/lib/fisk/instructions/vpexpandq.rb +117 -0
  947. data/lib/fisk/instructions/vpextrb.rb +89 -0
  948. data/lib/fisk/instructions/vpextrd.rb +89 -0
  949. data/lib/fisk/instructions/vpextrq.rb +89 -0
  950. data/lib/fisk/instructions/vpextrw.rb +115 -0
  951. data/lib/fisk/instructions/vpgatherdd.rb +101 -0
  952. data/lib/fisk/instructions/vpgatherdq.rb +101 -0
  953. data/lib/fisk/instructions/vpgatherqd.rb +101 -0
  954. data/lib/fisk/instructions/vpgatherqq.rb +101 -0
  955. data/lib/fisk/instructions/vphaddbd.rb +45 -0
  956. data/lib/fisk/instructions/vphaddbq.rb +45 -0
  957. data/lib/fisk/instructions/vphaddbw.rb +45 -0
  958. data/lib/fisk/instructions/vphaddd.rb +85 -0
  959. data/lib/fisk/instructions/vphadddq.rb +45 -0
  960. data/lib/fisk/instructions/vphaddsw.rb +85 -0
  961. data/lib/fisk/instructions/vphaddubd.rb +45 -0
  962. data/lib/fisk/instructions/vphaddubq.rb +45 -0
  963. data/lib/fisk/instructions/vphaddubw.rb +45 -0
  964. data/lib/fisk/instructions/vphaddudq.rb +45 -0
  965. data/lib/fisk/instructions/vphadduwd.rb +45 -0
  966. data/lib/fisk/instructions/vphadduwq.rb +45 -0
  967. data/lib/fisk/instructions/vphaddw.rb +85 -0
  968. data/lib/fisk/instructions/vphaddwd.rb +45 -0
  969. data/lib/fisk/instructions/vphaddwq.rb +45 -0
  970. data/lib/fisk/instructions/vphminposuw.rb +45 -0
  971. data/lib/fisk/instructions/vphsubbw.rb +45 -0
  972. data/lib/fisk/instructions/vphsubd.rb +85 -0
  973. data/lib/fisk/instructions/vphsubdq.rb +45 -0
  974. data/lib/fisk/instructions/vphsubsw.rb +85 -0
  975. data/lib/fisk/instructions/vphsubw.rb +85 -0
  976. data/lib/fisk/instructions/vphsubwd.rb +45 -0
  977. data/lib/fisk/instructions/vpinsrb.rb +93 -0
  978. data/lib/fisk/instructions/vpinsrd.rb +93 -0
  979. data/lib/fisk/instructions/vpinsrq.rb +93 -0
  980. data/lib/fisk/instructions/vpinsrw.rb +93 -0
  981. data/lib/fisk/instructions/vplzcntd.rb +117 -0
  982. data/lib/fisk/instructions/vplzcntq.rb +117 -0
  983. data/lib/fisk/instructions/vpmacsdd.rb +51 -0
  984. data/lib/fisk/instructions/vpmacsdqh.rb +51 -0
  985. data/lib/fisk/instructions/vpmacsdql.rb +51 -0
  986. data/lib/fisk/instructions/vpmacssdd.rb +51 -0
  987. data/lib/fisk/instructions/vpmacssdqh.rb +51 -0
  988. data/lib/fisk/instructions/vpmacssdql.rb +51 -0
  989. data/lib/fisk/instructions/vpmacsswd.rb +51 -0
  990. data/lib/fisk/instructions/vpmacssww.rb +51 -0
  991. data/lib/fisk/instructions/vpmacswd.rb +51 -0
  992. data/lib/fisk/instructions/vpmacsww.rb +51 -0
  993. data/lib/fisk/instructions/vpmadcsswd.rb +51 -0
  994. data/lib/fisk/instructions/vpmadcswd.rb +51 -0
  995. data/lib/fisk/instructions/vpmadd52huq.rb +123 -0
  996. data/lib/fisk/instructions/vpmadd52luq.rb +123 -0
  997. data/lib/fisk/instructions/vpmaddubsw.rb +199 -0
  998. data/lib/fisk/instructions/vpmaddwd.rb +199 -0
  999. data/lib/fisk/instructions/vpmaskmovd.rb +85 -0
  1000. data/lib/fisk/instructions/vpmaskmovq.rb +85 -0
  1001. data/lib/fisk/instructions/vpmaxsb.rb +199 -0
  1002. data/lib/fisk/instructions/vpmaxsd.rb +199 -0
  1003. data/lib/fisk/instructions/vpmaxsq.rb +123 -0
  1004. data/lib/fisk/instructions/vpmaxsw.rb +199 -0
  1005. data/lib/fisk/instructions/vpmaxub.rb +199 -0
  1006. data/lib/fisk/instructions/vpmaxud.rb +199 -0
  1007. data/lib/fisk/instructions/vpmaxuq.rb +123 -0
  1008. data/lib/fisk/instructions/vpmaxuw.rb +199 -0
  1009. data/lib/fisk/instructions/vpminsb.rb +199 -0
  1010. data/lib/fisk/instructions/vpminsd.rb +199 -0
  1011. data/lib/fisk/instructions/vpminsq.rb +123 -0
  1012. data/lib/fisk/instructions/vpminsw.rb +199 -0
  1013. data/lib/fisk/instructions/vpminub.rb +199 -0
  1014. data/lib/fisk/instructions/vpminud.rb +199 -0
  1015. data/lib/fisk/instructions/vpminuq.rb +123 -0
  1016. data/lib/fisk/instructions/vpminuw.rb +199 -0
  1017. data/lib/fisk/instructions/vpmovb2m.rb +63 -0
  1018. data/lib/fisk/instructions/vpmovd2m.rb +63 -0
  1019. data/lib/fisk/instructions/vpmovdb.rb +117 -0
  1020. data/lib/fisk/instructions/vpmovdw.rb +117 -0
  1021. data/lib/fisk/instructions/vpmovm2b.rb +63 -0
  1022. data/lib/fisk/instructions/vpmovm2d.rb +63 -0
  1023. data/lib/fisk/instructions/vpmovm2q.rb +63 -0
  1024. data/lib/fisk/instructions/vpmovm2w.rb +63 -0
  1025. data/lib/fisk/instructions/vpmovmskb.rb +45 -0
  1026. data/lib/fisk/instructions/vpmovq2m.rb +63 -0
  1027. data/lib/fisk/instructions/vpmovqb.rb +117 -0
  1028. data/lib/fisk/instructions/vpmovqd.rb +117 -0
  1029. data/lib/fisk/instructions/vpmovqw.rb +117 -0
  1030. data/lib/fisk/instructions/vpmovsdb.rb +117 -0
  1031. data/lib/fisk/instructions/vpmovsdw.rb +117 -0
  1032. data/lib/fisk/instructions/vpmovsqb.rb +117 -0
  1033. data/lib/fisk/instructions/vpmovsqd.rb +117 -0
  1034. data/lib/fisk/instructions/vpmovsqw.rb +117 -0
  1035. data/lib/fisk/instructions/vpmovswb.rb +117 -0
  1036. data/lib/fisk/instructions/vpmovsxbd.rb +189 -0
  1037. data/lib/fisk/instructions/vpmovsxbq.rb +189 -0
  1038. data/lib/fisk/instructions/vpmovsxbw.rb +189 -0
  1039. data/lib/fisk/instructions/vpmovsxdq.rb +189 -0
  1040. data/lib/fisk/instructions/vpmovsxwd.rb +189 -0
  1041. data/lib/fisk/instructions/vpmovsxwq.rb +189 -0
  1042. data/lib/fisk/instructions/vpmovusdb.rb +117 -0
  1043. data/lib/fisk/instructions/vpmovusdw.rb +117 -0
  1044. data/lib/fisk/instructions/vpmovusqb.rb +117 -0
  1045. data/lib/fisk/instructions/vpmovusqd.rb +117 -0
  1046. data/lib/fisk/instructions/vpmovusqw.rb +117 -0
  1047. data/lib/fisk/instructions/vpmovuswb.rb +117 -0
  1048. data/lib/fisk/instructions/vpmovw2m.rb +63 -0
  1049. data/lib/fisk/instructions/vpmovwb.rb +117 -0
  1050. data/lib/fisk/instructions/vpmovzxbd.rb +189 -0
  1051. data/lib/fisk/instructions/vpmovzxbq.rb +189 -0
  1052. data/lib/fisk/instructions/vpmovzxbw.rb +189 -0
  1053. data/lib/fisk/instructions/vpmovzxdq.rb +189 -0
  1054. data/lib/fisk/instructions/vpmovzxwd.rb +189 -0
  1055. data/lib/fisk/instructions/vpmovzxwq.rb +189 -0
  1056. data/lib/fisk/instructions/vpmuldq.rb +199 -0
  1057. data/lib/fisk/instructions/vpmulhrsw.rb +199 -0
  1058. data/lib/fisk/instructions/vpmulhuw.rb +199 -0
  1059. data/lib/fisk/instructions/vpmulhw.rb +199 -0
  1060. data/lib/fisk/instructions/vpmulld.rb +199 -0
  1061. data/lib/fisk/instructions/vpmullq.rb +123 -0
  1062. data/lib/fisk/instructions/vpmullw.rb +199 -0
  1063. data/lib/fisk/instructions/vpmultishiftqb.rb +123 -0
  1064. data/lib/fisk/instructions/vpmuludq.rb +199 -0
  1065. data/lib/fisk/instructions/vpopcntd.rb +45 -0
  1066. data/lib/fisk/instructions/vpopcntq.rb +45 -0
  1067. data/lib/fisk/instructions/vpor.rb +85 -0
  1068. data/lib/fisk/instructions/vpord.rb +123 -0
  1069. data/lib/fisk/instructions/vporq.rb +123 -0
  1070. data/lib/fisk/instructions/vpperm.rb +85 -0
  1071. data/lib/fisk/instructions/vprold.rb +129 -0
  1072. data/lib/fisk/instructions/vprolq.rb +129 -0
  1073. data/lib/fisk/instructions/vprolvd.rb +123 -0
  1074. data/lib/fisk/instructions/vprolvq.rb +123 -0
  1075. data/lib/fisk/instructions/vprord.rb +129 -0
  1076. data/lib/fisk/instructions/vprorq.rb +129 -0
  1077. data/lib/fisk/instructions/vprorvd.rb +123 -0
  1078. data/lib/fisk/instructions/vprorvq.rb +123 -0
  1079. data/lib/fisk/instructions/vprotb.rb +118 -0
  1080. data/lib/fisk/instructions/vprotd.rb +118 -0
  1081. data/lib/fisk/instructions/vprotq.rb +118 -0
  1082. data/lib/fisk/instructions/vprotw.rb +118 -0
  1083. data/lib/fisk/instructions/vpsadbw.rb +199 -0
  1084. data/lib/fisk/instructions/vpscatterdd.rb +63 -0
  1085. data/lib/fisk/instructions/vpscatterdq.rb +63 -0
  1086. data/lib/fisk/instructions/vpscatterqd.rb +63 -0
  1087. data/lib/fisk/instructions/vpscatterqq.rb +63 -0
  1088. data/lib/fisk/instructions/vpshab.rb +78 -0
  1089. data/lib/fisk/instructions/vpshad.rb +78 -0
  1090. data/lib/fisk/instructions/vpshaq.rb +78 -0
  1091. data/lib/fisk/instructions/vpshaw.rb +78 -0
  1092. data/lib/fisk/instructions/vpshlb.rb +78 -0
  1093. data/lib/fisk/instructions/vpshld.rb +78 -0
  1094. data/lib/fisk/instructions/vpshlq.rb +78 -0
  1095. data/lib/fisk/instructions/vpshlw.rb +78 -0
  1096. data/lib/fisk/instructions/vpshufb.rb +199 -0
  1097. data/lib/fisk/instructions/vpshufd.rb +209 -0
  1098. data/lib/fisk/instructions/vpshufhw.rb +209 -0
  1099. data/lib/fisk/instructions/vpshuflw.rb +209 -0
  1100. data/lib/fisk/instructions/vpsignb.rb +85 -0
  1101. data/lib/fisk/instructions/vpsignd.rb +85 -0
  1102. data/lib/fisk/instructions/vpsignw.rb +85 -0
  1103. data/lib/fisk/instructions/vpslld.rb +359 -0
  1104. data/lib/fisk/instructions/vpslldq.rb +169 -0
  1105. data/lib/fisk/instructions/vpsllq.rb +359 -0
  1106. data/lib/fisk/instructions/vpsllvd.rb +199 -0
  1107. data/lib/fisk/instructions/vpsllvq.rb +199 -0
  1108. data/lib/fisk/instructions/vpsllvw.rb +123 -0
  1109. data/lib/fisk/instructions/vpsllw.rb +359 -0
  1110. data/lib/fisk/instructions/vpsrad.rb +359 -0
  1111. data/lib/fisk/instructions/vpsraq.rb +243 -0
  1112. data/lib/fisk/instructions/vpsravd.rb +199 -0
  1113. data/lib/fisk/instructions/vpsravq.rb +123 -0
  1114. data/lib/fisk/instructions/vpsravw.rb +123 -0
  1115. data/lib/fisk/instructions/vpsraw.rb +359 -0
  1116. data/lib/fisk/instructions/vpsrld.rb +359 -0
  1117. data/lib/fisk/instructions/vpsrldq.rb +169 -0
  1118. data/lib/fisk/instructions/vpsrlq.rb +359 -0
  1119. data/lib/fisk/instructions/vpsrlvd.rb +199 -0
  1120. data/lib/fisk/instructions/vpsrlvq.rb +199 -0
  1121. data/lib/fisk/instructions/vpsrlvw.rb +123 -0
  1122. data/lib/fisk/instructions/vpsrlw.rb +359 -0
  1123. data/lib/fisk/instructions/vpsubb.rb +199 -0
  1124. data/lib/fisk/instructions/vpsubd.rb +199 -0
  1125. data/lib/fisk/instructions/vpsubq.rb +199 -0
  1126. data/lib/fisk/instructions/vpsubsb.rb +199 -0
  1127. data/lib/fisk/instructions/vpsubsw.rb +199 -0
  1128. data/lib/fisk/instructions/vpsubusb.rb +199 -0
  1129. data/lib/fisk/instructions/vpsubusw.rb +199 -0
  1130. data/lib/fisk/instructions/vpsubw.rb +199 -0
  1131. data/lib/fisk/instructions/vpternlogd.rb +135 -0
  1132. data/lib/fisk/instructions/vpternlogq.rb +135 -0
  1133. data/lib/fisk/instructions/vptest.rb +81 -0
  1134. data/lib/fisk/instructions/vptestmb.rb +123 -0
  1135. data/lib/fisk/instructions/vptestmd.rb +123 -0
  1136. data/lib/fisk/instructions/vptestmq.rb +123 -0
  1137. data/lib/fisk/instructions/vptestmw.rb +123 -0
  1138. data/lib/fisk/instructions/vptestnmb.rb +123 -0
  1139. data/lib/fisk/instructions/vptestnmd.rb +123 -0
  1140. data/lib/fisk/instructions/vptestnmq.rb +123 -0
  1141. data/lib/fisk/instructions/vptestnmw.rb +123 -0
  1142. data/lib/fisk/instructions/vpunpckhbw.rb +199 -0
  1143. data/lib/fisk/instructions/vpunpckhdq.rb +199 -0
  1144. data/lib/fisk/instructions/vpunpckhqdq.rb +199 -0
  1145. data/lib/fisk/instructions/vpunpckhwd.rb +199 -0
  1146. data/lib/fisk/instructions/vpunpcklbw.rb +199 -0
  1147. data/lib/fisk/instructions/vpunpckldq.rb +199 -0
  1148. data/lib/fisk/instructions/vpunpcklqdq.rb +199 -0
  1149. data/lib/fisk/instructions/vpunpcklwd.rb +199 -0
  1150. data/lib/fisk/instructions/vpxor.rb +85 -0
  1151. data/lib/fisk/instructions/vpxord.rb +123 -0
  1152. data/lib/fisk/instructions/vpxorq.rb +123 -0
  1153. data/lib/fisk/instructions/vrangepd.rb +136 -0
  1154. data/lib/fisk/instructions/vrangeps.rb +136 -0
  1155. data/lib/fisk/instructions/vrangesd.rb +52 -0
  1156. data/lib/fisk/instructions/vrangess.rb +52 -0
  1157. data/lib/fisk/instructions/vrcp14pd.rb +117 -0
  1158. data/lib/fisk/instructions/vrcp14ps.rb +117 -0
  1159. data/lib/fisk/instructions/vrcp14sd.rb +47 -0
  1160. data/lib/fisk/instructions/vrcp14ss.rb +47 -0
  1161. data/lib/fisk/instructions/vrcp28pd.rb +46 -0
  1162. data/lib/fisk/instructions/vrcp28ps.rb +46 -0
  1163. data/lib/fisk/instructions/vrcp28sd.rb +48 -0
  1164. data/lib/fisk/instructions/vrcp28ss.rb +48 -0
  1165. data/lib/fisk/instructions/vrcpps.rb +81 -0
  1166. data/lib/fisk/instructions/vrcpss.rb +47 -0
  1167. data/lib/fisk/instructions/vreducepd.rb +129 -0
  1168. data/lib/fisk/instructions/vreduceps.rb +129 -0
  1169. data/lib/fisk/instructions/vreducesd.rb +51 -0
  1170. data/lib/fisk/instructions/vreducess.rb +51 -0
  1171. data/lib/fisk/instructions/vrndscalepd.rb +130 -0
  1172. data/lib/fisk/instructions/vrndscaleps.rb +130 -0
  1173. data/lib/fisk/instructions/vrndscalesd.rb +52 -0
  1174. data/lib/fisk/instructions/vrndscaless.rb +52 -0
  1175. data/lib/fisk/instructions/vroundpd.rb +89 -0
  1176. data/lib/fisk/instructions/vroundps.rb +89 -0
  1177. data/lib/fisk/instructions/vroundsd.rb +51 -0
  1178. data/lib/fisk/instructions/vroundss.rb +51 -0
  1179. data/lib/fisk/instructions/vrsqrt14pd.rb +117 -0
  1180. data/lib/fisk/instructions/vrsqrt14ps.rb +117 -0
  1181. data/lib/fisk/instructions/vrsqrt14sd.rb +47 -0
  1182. data/lib/fisk/instructions/vrsqrt14ss.rb +47 -0
  1183. data/lib/fisk/instructions/vrsqrt28pd.rb +46 -0
  1184. data/lib/fisk/instructions/vrsqrt28ps.rb +46 -0
  1185. data/lib/fisk/instructions/vrsqrt28sd.rb +48 -0
  1186. data/lib/fisk/instructions/vrsqrt28ss.rb +48 -0
  1187. data/lib/fisk/instructions/vrsqrtps.rb +81 -0
  1188. data/lib/fisk/instructions/vrsqrtss.rb +47 -0
  1189. data/lib/fisk/instructions/vscalefpd.rb +124 -0
  1190. data/lib/fisk/instructions/vscalefps.rb +124 -0
  1191. data/lib/fisk/instructions/vscalefsd.rb +48 -0
  1192. data/lib/fisk/instructions/vscalefss.rb +48 -0
  1193. data/lib/fisk/instructions/vscatterdpd.rb +63 -0
  1194. data/lib/fisk/instructions/vscatterdps.rb +63 -0
  1195. data/lib/fisk/instructions/vscatterpf0dpd.rb +26 -0
  1196. data/lib/fisk/instructions/vscatterpf0dps.rb +26 -0
  1197. data/lib/fisk/instructions/vscatterpf0qpd.rb +26 -0
  1198. data/lib/fisk/instructions/vscatterpf0qps.rb +26 -0
  1199. data/lib/fisk/instructions/vscatterpf1dpd.rb +26 -0
  1200. data/lib/fisk/instructions/vscatterpf1dps.rb +26 -0
  1201. data/lib/fisk/instructions/vscatterpf1qpd.rb +26 -0
  1202. data/lib/fisk/instructions/vscatterpf1qps.rb +26 -0
  1203. data/lib/fisk/instructions/vscatterqpd.rb +63 -0
  1204. data/lib/fisk/instructions/vscatterqps.rb +63 -0
  1205. data/lib/fisk/instructions/vshuff32x4.rb +93 -0
  1206. data/lib/fisk/instructions/vshuff64x2.rb +93 -0
  1207. data/lib/fisk/instructions/vshufi32x4.rb +93 -0
  1208. data/lib/fisk/instructions/vshufi64x2.rb +93 -0
  1209. data/lib/fisk/instructions/vshufpd.rb +219 -0
  1210. data/lib/fisk/instructions/vshufps.rb +219 -0
  1211. data/lib/fisk/instructions/vsqrtpd.rb +190 -0
  1212. data/lib/fisk/instructions/vsqrtps.rb +190 -0
  1213. data/lib/fisk/instructions/vsqrtsd.rb +86 -0
  1214. data/lib/fisk/instructions/vsqrtss.rb +86 -0
  1215. data/lib/fisk/instructions/vstmxcsr.rb +26 -0
  1216. data/lib/fisk/instructions/vsubpd.rb +200 -0
  1217. data/lib/fisk/instructions/vsubps.rb +200 -0
  1218. data/lib/fisk/instructions/vsubsd.rb +86 -0
  1219. data/lib/fisk/instructions/vsubss.rb +86 -0
  1220. data/lib/fisk/instructions/vtestpd.rb +81 -0
  1221. data/lib/fisk/instructions/vtestps.rb +81 -0
  1222. data/lib/fisk/instructions/vucomisd.rb +82 -0
  1223. data/lib/fisk/instructions/vucomiss.rb +82 -0
  1224. data/lib/fisk/instructions/vunpckhpd.rb +199 -0
  1225. data/lib/fisk/instructions/vunpckhps.rb +199 -0
  1226. data/lib/fisk/instructions/vunpcklpd.rb +199 -0
  1227. data/lib/fisk/instructions/vunpcklps.rb +199 -0
  1228. data/lib/fisk/instructions/vxorpd.rb +199 -0
  1229. data/lib/fisk/instructions/vxorps.rb +199 -0
  1230. data/lib/fisk/instructions/vzeroall.rb +21 -0
  1231. data/lib/fisk/instructions/vzeroupper.rb +21 -0
  1232. data/lib/fisk/instructions/xadd.rb +203 -0
  1233. data/lib/fisk/instructions/xchg.rb +473 -0
  1234. data/lib/fisk/instructions/xgetbv.rb +22 -0
  1235. data/lib/fisk/instructions/xlatb.rb +37 -0
  1236. data/lib/fisk/instructions/xor.rb +760 -0
  1237. data/lib/fisk/instructions/xorpd.rb +59 -0
  1238. data/lib/fisk/instructions/xorps.rb +57 -0
  1239. data/test/helper.rb +6 -0
  1240. data/test/test_fisk.rb +53 -0
  1241. data/test/test_run_fisk.rb +78 -5
  1242. metadata +1234 -6
  1243. data/bin/machine.rb.erb +0 -100
  1244. data/lib/fisk/machine.rb +0 -35
  1245. data/lib/fisk/machine/encoding.rb +0 -78
  1246. data/lib/fisk/machine/generated.rb +0 -124746
@@ -0,0 +1,59 @@
1
+ # frozen_string_literal: true
2
+
3
+ class Fisk
4
+ module Instructions
5
+ # Instruction XORPD
6
+ forms = []
7
+ operands = []
8
+ encodings = []
9
+ # xorpd: xmm, xmm
10
+ operands << OPERAND_TYPES[23]
11
+ operands << OPERAND_TYPES[24]
12
+ encodings << Class.new(Fisk::Encoding) {
13
+ def encode buffer, operands
14
+ add_prefix buffer, operands, 0x66, true
15
+ add_rex(buffer, operands,
16
+ false,
17
+ 0,
18
+ (operands[0].value >> 3),
19
+ 0,
20
+ (operands[1].value >> 3))
21
+ add_opcode buffer, 0x0F, 0
22
+ add_opcode buffer, 0x57, 0
23
+ add_modrm(buffer, operands,
24
+ 3,
25
+ operands[0].value,
26
+ operands[1].value)
27
+ end
28
+
29
+ def bytesize; 3; end
30
+ }.new
31
+ forms << Form.new(operands, encodings)
32
+ operands = []
33
+ encodings = []
34
+ # xorpd: xmm, m128
35
+ operands << OPERAND_TYPES[23]
36
+ operands << OPERAND_TYPES[25]
37
+ encodings << Class.new(Fisk::Encoding) {
38
+ def encode buffer, operands
39
+ add_prefix buffer, operands, 0x66, true
40
+ add_rex(buffer, operands,
41
+ false,
42
+ 0,
43
+ (operands[0].value >> 3),
44
+ (operands[1].value >> 3),
45
+ (operands[1].value >> 3))
46
+ add_opcode buffer, 0x0F, 0
47
+ add_opcode buffer, 0x57, 0
48
+ add_modrm(buffer, operands,
49
+ 0,
50
+ operands[0].value,
51
+ operands[1].value)
52
+ end
53
+
54
+ def bytesize; 3; end
55
+ }.new
56
+ forms << Form.new(operands, encodings)
57
+ XORPD = Instruction.new("XORPD", forms)
58
+ end
59
+ end
@@ -0,0 +1,57 @@
1
+ # frozen_string_literal: true
2
+
3
+ class Fisk
4
+ module Instructions
5
+ # Instruction XORPS
6
+ forms = []
7
+ operands = []
8
+ encodings = []
9
+ # xorps: xmm, xmm
10
+ operands << OPERAND_TYPES[23]
11
+ operands << OPERAND_TYPES[24]
12
+ encodings << Class.new(Fisk::Encoding) {
13
+ def encode buffer, operands
14
+ add_rex(buffer, operands,
15
+ false,
16
+ 0,
17
+ (operands[0].value >> 3),
18
+ 0,
19
+ (operands[1].value >> 3))
20
+ add_opcode buffer, 0x0F, 0
21
+ add_opcode buffer, 0x57, 0
22
+ add_modrm(buffer, operands,
23
+ 3,
24
+ operands[0].value,
25
+ operands[1].value)
26
+ end
27
+
28
+ def bytesize; 3; end
29
+ }.new
30
+ forms << Form.new(operands, encodings)
31
+ operands = []
32
+ encodings = []
33
+ # xorps: xmm, m128
34
+ operands << OPERAND_TYPES[23]
35
+ operands << OPERAND_TYPES[25]
36
+ encodings << Class.new(Fisk::Encoding) {
37
+ def encode buffer, operands
38
+ add_rex(buffer, operands,
39
+ false,
40
+ 0,
41
+ (operands[0].value >> 3),
42
+ (operands[1].value >> 3),
43
+ (operands[1].value >> 3))
44
+ add_opcode buffer, 0x0F, 0
45
+ add_opcode buffer, 0x57, 0
46
+ add_modrm(buffer, operands,
47
+ 0,
48
+ operands[0].value,
49
+ operands[1].value)
50
+ end
51
+
52
+ def bytesize; 3; end
53
+ }.new
54
+ forms << Form.new(operands, encodings)
55
+ XORPS = Instruction.new("XORPS", forms)
56
+ end
57
+ end
data/test/helper.rb CHANGED
@@ -5,4 +5,10 @@ ENV["MT_NO_PLUGINS"] = "1"
5
5
  require "minitest/autorun"
6
6
 
7
7
  class Fisk::Test < Minitest::Test
8
+ def print_disasm binary
9
+ cs = Crabstone::Disassembler.new(Crabstone::ARCH_X86, Crabstone::MODE_64)
10
+ cs.disasm(binary, 0x0000).each {|i|
11
+ printf("0x%x:\t%s\t\t%s\n",i.address, i.mnemonic, i.op_str)
12
+ }
13
+ end
8
14
  end
data/test/test_fisk.rb CHANGED
@@ -8,6 +8,59 @@ class FiskTest < Fisk::Test
8
8
  @fisk = Fisk.new
9
9
  end
10
10
 
11
+ def test_lazy_labels
12
+ fisk.jmp fisk.label(:foo)
13
+ fisk.make_label(:foo)
14
+ fisk.nop
15
+ jmp, nop = disasm(fisk.to_binary)
16
+ assert_equal "jmp", jmp.mnemonic.to_s
17
+ assert_equal "5", jmp.op_str.to_s
18
+ assert_equal "nop", nop.mnemonic.to_s
19
+ assert_equal 5, nop.address
20
+ end
21
+
22
+ def test_read_with_edge_negative_offset
23
+ fisk.mov fisk.m64(fisk.rcx, -0xFF), fisk.rcx
24
+ i = disasm(fisk.to_binary).first
25
+ assert_equal "mov", i.mnemonic.to_s
26
+ assert_equal "qword ptr [rcx - 0xff], rcx", i.op_str.to_s
27
+ end
28
+
29
+ def test_read_with_large_negative_offset
30
+ fisk.mov fisk.m64(fisk.rcx, -0xcafe), fisk.rcx
31
+ i = disasm(fisk.to_binary).first
32
+ assert_equal "mov", i.mnemonic.to_s
33
+ assert_equal "qword ptr [rcx - 0xcafe], rcx", i.op_str.to_s
34
+ end
35
+
36
+ def test_read_with_negative_offset
37
+ fisk.mov fisk.m64(fisk.rcx, -8), fisk.rcx
38
+ i = disasm(fisk.to_binary).first
39
+ assert_equal "mov", i.mnemonic.to_s
40
+ assert_equal "qword ptr [rcx - 8], rcx", i.op_str.to_s
41
+ end
42
+
43
+ def test_read_with_zero_offset
44
+ fisk.mov fisk.m64(fisk.rcx), fisk.rcx
45
+ i = disasm(fisk.to_binary).first
46
+ assert_equal "mov", i.mnemonic.to_s
47
+ assert_equal "qword ptr [rcx], rcx", i.op_str.to_s
48
+ end
49
+
50
+ def test_read_with_non_zero_offset
51
+ fisk.mov fisk.m64(fisk.rcx, 0xa), fisk.rcx
52
+ i = disasm(fisk.to_binary).first
53
+ assert_equal "mov", i.mnemonic.to_s
54
+ assert_equal "qword ptr [rcx + 0xa], rcx", i.op_str.to_s
55
+ end
56
+
57
+ def test_jmp_extended_register
58
+ fisk.jmp fisk.r8
59
+ i = disasm(fisk.to_binary).first
60
+ assert_equal "jmp", i.mnemonic.to_s
61
+ assert_equal "r8", i.op_str.to_s
62
+ end
63
+
11
64
  def test_sub
12
65
  fisk.sub fisk.rsp, fisk.imm8(16)
13
66
  i = disasm(fisk.to_binary).first
@@ -2,11 +2,84 @@ require "helper"
2
2
  require "fisk/helpers"
3
3
 
4
4
  class RunFiskTest < Fisk::Test
5
- def disasm binary
6
- cs = Crabstone::Disassembler.new(Crabstone::ARCH_X86, Crabstone::MODE_64)
7
- cs.disasm(binary, 0x0000).each {|i|
8
- printf("0x%x:\t%s\t\t%s\n",i.address, i.mnemonic, i.op_str)
9
- }
5
+ def test_forward_label_rel32
6
+ fisk = Fisk.new
7
+ jitbuf = Fisk::Helpers.jitbuffer 4096
8
+
9
+ str = " " * 0xFFFFF
10
+ ptr = Fiddle::Pointer[str]
11
+
12
+ fisk.asm jitbuf do
13
+ push rbp
14
+ mov rbp, rsp
15
+ mov rdx, imm32(1)
16
+ jmp label(:foo)
17
+ mov r8, imm64(ptr.to_i)
18
+ mov r8, m64(r8, 0xFFFF)
19
+ int lit(3) # crash if we don't jump over this
20
+ make_label :foo
21
+ mov rax, imm32(0x3)
22
+ pop rbp
23
+ ret
24
+ end
25
+
26
+ func = jitbuf.to_function [], Fiddle::TYPE_INT
27
+ assert_equal 3, func.call
28
+ end
29
+
30
+ def test_label_rel32
31
+ fisk = Fisk.new
32
+ jitbuf = Fisk::Helpers.jitbuffer 4096
33
+
34
+ str = " " * 0xFFFFF
35
+ ptr = Fiddle::Pointer[str]
36
+
37
+ fisk.asm jitbuf do
38
+ push rbp
39
+ mov rbp, rsp
40
+ mov rdx, imm32(1)
41
+ mov r8, imm64(ptr.to_i)
42
+ mov r8, m64(r8, 0xFFFF)
43
+ xor rax, rax
44
+ make_label :loop
45
+ add rax, rdx
46
+ 500.times { nop }
47
+ inc rdx
48
+ cmp rdx, imm32(10)
49
+ jbe label(:loop)
50
+ pop rbp
51
+ ret
52
+ end
53
+
54
+ func = jitbuf.to_function [], Fiddle::TYPE_INT
55
+ assert_equal 11.times.inject(:+), func.call
56
+ end
57
+
58
+ def test_label_rel8
59
+ fisk = Fisk.new
60
+ jitbuf = Fisk::Helpers.jitbuffer 4096
61
+
62
+ str = " " * 0xFFFFF
63
+ ptr = Fiddle::Pointer[str]
64
+
65
+ fisk.asm jitbuf do
66
+ push rbp
67
+ mov rbp, rsp
68
+ mov rdx, imm32(1)
69
+ mov r8, imm64(ptr.to_i)
70
+ mov r8, m64(r8, 0xFFFF)
71
+ xor rax, rax
72
+ make_label :loop
73
+ add rax, rdx
74
+ inc rdx
75
+ cmp rdx, imm32(10)
76
+ jbe label(:loop)
77
+ pop rbp
78
+ ret
79
+ end
80
+
81
+ func = jitbuf.to_function [], Fiddle::TYPE_INT
82
+ assert_equal 11.times.inject(:+), func.call
10
83
  end
11
84
 
12
85
  def test_sum
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: fisk
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.0
4
+ version: 2.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Aaron Patterson
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-06-02 00:00:00.000000000 Z
11
+ date: 2021-07-01 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: Tired of writing Ruby in Ruby? Now you can write assembly in Ruby!
14
14
  email: tenderlove@ruby-lang.org
@@ -21,13 +21,1241 @@ files:
21
21
  - README.md
22
22
  - Rakefile
23
23
  - bin/build-machine.rb
24
- - bin/machine.rb.erb
24
+ - bin/instruction.rb.erb
25
+ - bin/instructions.rb.erb
25
26
  - examples/print-string.rb
27
+ - fisk.gemspec
26
28
  - lib/fisk.rb
29
+ - lib/fisk/encoding.rb
27
30
  - lib/fisk/helpers.rb
28
- - lib/fisk/machine.rb
29
- - lib/fisk/machine/encoding.rb
30
- - lib/fisk/machine/generated.rb
31
+ - lib/fisk/instructions.rb
32
+ - lib/fisk/instructions/adc.rb
33
+ - lib/fisk/instructions/adcx.rb
34
+ - lib/fisk/instructions/add.rb
35
+ - lib/fisk/instructions/addpd.rb
36
+ - lib/fisk/instructions/addps.rb
37
+ - lib/fisk/instructions/addsd.rb
38
+ - lib/fisk/instructions/addss.rb
39
+ - lib/fisk/instructions/addsubpd.rb
40
+ - lib/fisk/instructions/addsubps.rb
41
+ - lib/fisk/instructions/adox.rb
42
+ - lib/fisk/instructions/aesdec.rb
43
+ - lib/fisk/instructions/aesdeclast.rb
44
+ - lib/fisk/instructions/aesenc.rb
45
+ - lib/fisk/instructions/aesenclast.rb
46
+ - lib/fisk/instructions/aesimc.rb
47
+ - lib/fisk/instructions/aeskeygenassist.rb
48
+ - lib/fisk/instructions/and.rb
49
+ - lib/fisk/instructions/andn.rb
50
+ - lib/fisk/instructions/andnpd.rb
51
+ - lib/fisk/instructions/andnps.rb
52
+ - lib/fisk/instructions/andpd.rb
53
+ - lib/fisk/instructions/andps.rb
54
+ - lib/fisk/instructions/bextr.rb
55
+ - lib/fisk/instructions/blcfill.rb
56
+ - lib/fisk/instructions/blci.rb
57
+ - lib/fisk/instructions/blcic.rb
58
+ - lib/fisk/instructions/blcmsk.rb
59
+ - lib/fisk/instructions/blcs.rb
60
+ - lib/fisk/instructions/blendpd.rb
61
+ - lib/fisk/instructions/blendps.rb
62
+ - lib/fisk/instructions/blendvpd.rb
63
+ - lib/fisk/instructions/blendvps.rb
64
+ - lib/fisk/instructions/blsfill.rb
65
+ - lib/fisk/instructions/blsi.rb
66
+ - lib/fisk/instructions/blsic.rb
67
+ - lib/fisk/instructions/blsmsk.rb
68
+ - lib/fisk/instructions/blsr.rb
69
+ - lib/fisk/instructions/bsf.rb
70
+ - lib/fisk/instructions/bsr.rb
71
+ - lib/fisk/instructions/bswap.rb
72
+ - lib/fisk/instructions/bt.rb
73
+ - lib/fisk/instructions/btc.rb
74
+ - lib/fisk/instructions/btr.rb
75
+ - lib/fisk/instructions/bts.rb
76
+ - lib/fisk/instructions/bzhi.rb
77
+ - lib/fisk/instructions/call.rb
78
+ - lib/fisk/instructions/cbw.rb
79
+ - lib/fisk/instructions/cdq.rb
80
+ - lib/fisk/instructions/cdqe.rb
81
+ - lib/fisk/instructions/clc.rb
82
+ - lib/fisk/instructions/cld.rb
83
+ - lib/fisk/instructions/clflush.rb
84
+ - lib/fisk/instructions/clflushopt.rb
85
+ - lib/fisk/instructions/clwb.rb
86
+ - lib/fisk/instructions/clzero.rb
87
+ - lib/fisk/instructions/cmc.rb
88
+ - lib/fisk/instructions/cmova.rb
89
+ - lib/fisk/instructions/cmovae.rb
90
+ - lib/fisk/instructions/cmovb.rb
91
+ - lib/fisk/instructions/cmovbe.rb
92
+ - lib/fisk/instructions/cmovc.rb
93
+ - lib/fisk/instructions/cmove.rb
94
+ - lib/fisk/instructions/cmovg.rb
95
+ - lib/fisk/instructions/cmovge.rb
96
+ - lib/fisk/instructions/cmovl.rb
97
+ - lib/fisk/instructions/cmovle.rb
98
+ - lib/fisk/instructions/cmovna.rb
99
+ - lib/fisk/instructions/cmovnae.rb
100
+ - lib/fisk/instructions/cmovnb.rb
101
+ - lib/fisk/instructions/cmovnbe.rb
102
+ - lib/fisk/instructions/cmovnc.rb
103
+ - lib/fisk/instructions/cmovne.rb
104
+ - lib/fisk/instructions/cmovng.rb
105
+ - lib/fisk/instructions/cmovnge.rb
106
+ - lib/fisk/instructions/cmovnl.rb
107
+ - lib/fisk/instructions/cmovnle.rb
108
+ - lib/fisk/instructions/cmovno.rb
109
+ - lib/fisk/instructions/cmovnp.rb
110
+ - lib/fisk/instructions/cmovns.rb
111
+ - lib/fisk/instructions/cmovnz.rb
112
+ - lib/fisk/instructions/cmovo.rb
113
+ - lib/fisk/instructions/cmovp.rb
114
+ - lib/fisk/instructions/cmovpe.rb
115
+ - lib/fisk/instructions/cmovpo.rb
116
+ - lib/fisk/instructions/cmovs.rb
117
+ - lib/fisk/instructions/cmovz.rb
118
+ - lib/fisk/instructions/cmp.rb
119
+ - lib/fisk/instructions/cmppd.rb
120
+ - lib/fisk/instructions/cmpps.rb
121
+ - lib/fisk/instructions/cmpsd.rb
122
+ - lib/fisk/instructions/cmpss.rb
123
+ - lib/fisk/instructions/cmpxchg.rb
124
+ - lib/fisk/instructions/cmpxchg16b.rb
125
+ - lib/fisk/instructions/cmpxchg8b.rb
126
+ - lib/fisk/instructions/comisd.rb
127
+ - lib/fisk/instructions/comiss.rb
128
+ - lib/fisk/instructions/cpuid.rb
129
+ - lib/fisk/instructions/cqo.rb
130
+ - lib/fisk/instructions/crc32.rb
131
+ - lib/fisk/instructions/cvtdq2pd.rb
132
+ - lib/fisk/instructions/cvtdq2ps.rb
133
+ - lib/fisk/instructions/cvtpd2dq.rb
134
+ - lib/fisk/instructions/cvtpd2pi.rb
135
+ - lib/fisk/instructions/cvtpd2ps.rb
136
+ - lib/fisk/instructions/cvtpi2pd.rb
137
+ - lib/fisk/instructions/cvtpi2ps.rb
138
+ - lib/fisk/instructions/cvtps2dq.rb
139
+ - lib/fisk/instructions/cvtps2pd.rb
140
+ - lib/fisk/instructions/cvtps2pi.rb
141
+ - lib/fisk/instructions/cvtsd2si.rb
142
+ - lib/fisk/instructions/cvtsd2ss.rb
143
+ - lib/fisk/instructions/cvtsi2sd.rb
144
+ - lib/fisk/instructions/cvtsi2ss.rb
145
+ - lib/fisk/instructions/cvtss2sd.rb
146
+ - lib/fisk/instructions/cvtss2si.rb
147
+ - lib/fisk/instructions/cvttpd2dq.rb
148
+ - lib/fisk/instructions/cvttpd2pi.rb
149
+ - lib/fisk/instructions/cvttps2dq.rb
150
+ - lib/fisk/instructions/cvttps2pi.rb
151
+ - lib/fisk/instructions/cvttsd2si.rb
152
+ - lib/fisk/instructions/cvttss2si.rb
153
+ - lib/fisk/instructions/cwd.rb
154
+ - lib/fisk/instructions/cwde.rb
155
+ - lib/fisk/instructions/dec.rb
156
+ - lib/fisk/instructions/div.rb
157
+ - lib/fisk/instructions/divpd.rb
158
+ - lib/fisk/instructions/divps.rb
159
+ - lib/fisk/instructions/divsd.rb
160
+ - lib/fisk/instructions/divss.rb
161
+ - lib/fisk/instructions/dppd.rb
162
+ - lib/fisk/instructions/dpps.rb
163
+ - lib/fisk/instructions/emms.rb
164
+ - lib/fisk/instructions/extractps.rb
165
+ - lib/fisk/instructions/extrq.rb
166
+ - lib/fisk/instructions/femms.rb
167
+ - lib/fisk/instructions/haddpd.rb
168
+ - lib/fisk/instructions/haddps.rb
169
+ - lib/fisk/instructions/hsubpd.rb
170
+ - lib/fisk/instructions/hsubps.rb
171
+ - lib/fisk/instructions/idiv.rb
172
+ - lib/fisk/instructions/imul.rb
173
+ - lib/fisk/instructions/inc.rb
174
+ - lib/fisk/instructions/insertps.rb
175
+ - lib/fisk/instructions/insertq.rb
176
+ - lib/fisk/instructions/int.rb
177
+ - lib/fisk/instructions/ja.rb
178
+ - lib/fisk/instructions/jae.rb
179
+ - lib/fisk/instructions/jb.rb
180
+ - lib/fisk/instructions/jbe.rb
181
+ - lib/fisk/instructions/jc.rb
182
+ - lib/fisk/instructions/je.rb
183
+ - lib/fisk/instructions/jecxz.rb
184
+ - lib/fisk/instructions/jg.rb
185
+ - lib/fisk/instructions/jge.rb
186
+ - lib/fisk/instructions/jl.rb
187
+ - lib/fisk/instructions/jle.rb
188
+ - lib/fisk/instructions/jmp.rb
189
+ - lib/fisk/instructions/jna.rb
190
+ - lib/fisk/instructions/jnae.rb
191
+ - lib/fisk/instructions/jnb.rb
192
+ - lib/fisk/instructions/jnbe.rb
193
+ - lib/fisk/instructions/jnc.rb
194
+ - lib/fisk/instructions/jne.rb
195
+ - lib/fisk/instructions/jng.rb
196
+ - lib/fisk/instructions/jnge.rb
197
+ - lib/fisk/instructions/jnl.rb
198
+ - lib/fisk/instructions/jnle.rb
199
+ - lib/fisk/instructions/jno.rb
200
+ - lib/fisk/instructions/jnp.rb
201
+ - lib/fisk/instructions/jns.rb
202
+ - lib/fisk/instructions/jnz.rb
203
+ - lib/fisk/instructions/jo.rb
204
+ - lib/fisk/instructions/jp.rb
205
+ - lib/fisk/instructions/jpe.rb
206
+ - lib/fisk/instructions/jpo.rb
207
+ - lib/fisk/instructions/jrcxz.rb
208
+ - lib/fisk/instructions/js.rb
209
+ - lib/fisk/instructions/jz.rb
210
+ - lib/fisk/instructions/kaddb.rb
211
+ - lib/fisk/instructions/kaddd.rb
212
+ - lib/fisk/instructions/kaddq.rb
213
+ - lib/fisk/instructions/kaddw.rb
214
+ - lib/fisk/instructions/kandb.rb
215
+ - lib/fisk/instructions/kandd.rb
216
+ - lib/fisk/instructions/kandnb.rb
217
+ - lib/fisk/instructions/kandnd.rb
218
+ - lib/fisk/instructions/kandnq.rb
219
+ - lib/fisk/instructions/kandnw.rb
220
+ - lib/fisk/instructions/kandq.rb
221
+ - lib/fisk/instructions/kandw.rb
222
+ - lib/fisk/instructions/kmovb.rb
223
+ - lib/fisk/instructions/kmovd.rb
224
+ - lib/fisk/instructions/kmovq.rb
225
+ - lib/fisk/instructions/kmovw.rb
226
+ - lib/fisk/instructions/knotb.rb
227
+ - lib/fisk/instructions/knotd.rb
228
+ - lib/fisk/instructions/knotq.rb
229
+ - lib/fisk/instructions/knotw.rb
230
+ - lib/fisk/instructions/korb.rb
231
+ - lib/fisk/instructions/kord.rb
232
+ - lib/fisk/instructions/korq.rb
233
+ - lib/fisk/instructions/kortestb.rb
234
+ - lib/fisk/instructions/kortestd.rb
235
+ - lib/fisk/instructions/kortestq.rb
236
+ - lib/fisk/instructions/kortestw.rb
237
+ - lib/fisk/instructions/korw.rb
238
+ - lib/fisk/instructions/kshiftlb.rb
239
+ - lib/fisk/instructions/kshiftld.rb
240
+ - lib/fisk/instructions/kshiftlq.rb
241
+ - lib/fisk/instructions/kshiftlw.rb
242
+ - lib/fisk/instructions/kshiftrb.rb
243
+ - lib/fisk/instructions/kshiftrd.rb
244
+ - lib/fisk/instructions/kshiftrq.rb
245
+ - lib/fisk/instructions/kshiftrw.rb
246
+ - lib/fisk/instructions/ktestb.rb
247
+ - lib/fisk/instructions/ktestd.rb
248
+ - lib/fisk/instructions/ktestq.rb
249
+ - lib/fisk/instructions/ktestw.rb
250
+ - lib/fisk/instructions/kunpckbw.rb
251
+ - lib/fisk/instructions/kunpckdq.rb
252
+ - lib/fisk/instructions/kunpckwd.rb
253
+ - lib/fisk/instructions/kxnorb.rb
254
+ - lib/fisk/instructions/kxnord.rb
255
+ - lib/fisk/instructions/kxnorq.rb
256
+ - lib/fisk/instructions/kxnorw.rb
257
+ - lib/fisk/instructions/kxorb.rb
258
+ - lib/fisk/instructions/kxord.rb
259
+ - lib/fisk/instructions/kxorq.rb
260
+ - lib/fisk/instructions/kxorw.rb
261
+ - lib/fisk/instructions/lddqu.rb
262
+ - lib/fisk/instructions/ldmxcsr.rb
263
+ - lib/fisk/instructions/lea.rb
264
+ - lib/fisk/instructions/lfence.rb
265
+ - lib/fisk/instructions/lzcnt.rb
266
+ - lib/fisk/instructions/maskmovdqu.rb
267
+ - lib/fisk/instructions/maskmovq.rb
268
+ - lib/fisk/instructions/maxpd.rb
269
+ - lib/fisk/instructions/maxps.rb
270
+ - lib/fisk/instructions/maxsd.rb
271
+ - lib/fisk/instructions/maxss.rb
272
+ - lib/fisk/instructions/mfence.rb
273
+ - lib/fisk/instructions/minpd.rb
274
+ - lib/fisk/instructions/minps.rb
275
+ - lib/fisk/instructions/minsd.rb
276
+ - lib/fisk/instructions/minss.rb
277
+ - lib/fisk/instructions/monitor.rb
278
+ - lib/fisk/instructions/monitorx.rb
279
+ - lib/fisk/instructions/mov.rb
280
+ - lib/fisk/instructions/movapd.rb
281
+ - lib/fisk/instructions/movaps.rb
282
+ - lib/fisk/instructions/movbe.rb
283
+ - lib/fisk/instructions/movd.rb
284
+ - lib/fisk/instructions/movddup.rb
285
+ - lib/fisk/instructions/movdq2q.rb
286
+ - lib/fisk/instructions/movdqa.rb
287
+ - lib/fisk/instructions/movdqu.rb
288
+ - lib/fisk/instructions/movhlps.rb
289
+ - lib/fisk/instructions/movhpd.rb
290
+ - lib/fisk/instructions/movhps.rb
291
+ - lib/fisk/instructions/movlhps.rb
292
+ - lib/fisk/instructions/movlpd.rb
293
+ - lib/fisk/instructions/movlps.rb
294
+ - lib/fisk/instructions/movmskpd.rb
295
+ - lib/fisk/instructions/movmskps.rb
296
+ - lib/fisk/instructions/movntdq.rb
297
+ - lib/fisk/instructions/movntdqa.rb
298
+ - lib/fisk/instructions/movnti.rb
299
+ - lib/fisk/instructions/movntpd.rb
300
+ - lib/fisk/instructions/movntps.rb
301
+ - lib/fisk/instructions/movntq.rb
302
+ - lib/fisk/instructions/movntsd.rb
303
+ - lib/fisk/instructions/movntss.rb
304
+ - lib/fisk/instructions/movq.rb
305
+ - lib/fisk/instructions/movq2dq.rb
306
+ - lib/fisk/instructions/movsd.rb
307
+ - lib/fisk/instructions/movshdup.rb
308
+ - lib/fisk/instructions/movsldup.rb
309
+ - lib/fisk/instructions/movss.rb
310
+ - lib/fisk/instructions/movsx.rb
311
+ - lib/fisk/instructions/movsxd.rb
312
+ - lib/fisk/instructions/movupd.rb
313
+ - lib/fisk/instructions/movups.rb
314
+ - lib/fisk/instructions/movzx.rb
315
+ - lib/fisk/instructions/mpsadbw.rb
316
+ - lib/fisk/instructions/mul.rb
317
+ - lib/fisk/instructions/mulpd.rb
318
+ - lib/fisk/instructions/mulps.rb
319
+ - lib/fisk/instructions/mulsd.rb
320
+ - lib/fisk/instructions/mulss.rb
321
+ - lib/fisk/instructions/mulx.rb
322
+ - lib/fisk/instructions/mwait.rb
323
+ - lib/fisk/instructions/mwaitx.rb
324
+ - lib/fisk/instructions/neg.rb
325
+ - lib/fisk/instructions/nop.rb
326
+ - lib/fisk/instructions/not.rb
327
+ - lib/fisk/instructions/or.rb
328
+ - lib/fisk/instructions/orpd.rb
329
+ - lib/fisk/instructions/orps.rb
330
+ - lib/fisk/instructions/pabsb.rb
331
+ - lib/fisk/instructions/pabsd.rb
332
+ - lib/fisk/instructions/pabsw.rb
333
+ - lib/fisk/instructions/packssdw.rb
334
+ - lib/fisk/instructions/packsswb.rb
335
+ - lib/fisk/instructions/packusdw.rb
336
+ - lib/fisk/instructions/packuswb.rb
337
+ - lib/fisk/instructions/paddb.rb
338
+ - lib/fisk/instructions/paddd.rb
339
+ - lib/fisk/instructions/paddq.rb
340
+ - lib/fisk/instructions/paddsb.rb
341
+ - lib/fisk/instructions/paddsw.rb
342
+ - lib/fisk/instructions/paddusb.rb
343
+ - lib/fisk/instructions/paddusw.rb
344
+ - lib/fisk/instructions/paddw.rb
345
+ - lib/fisk/instructions/palignr.rb
346
+ - lib/fisk/instructions/pand.rb
347
+ - lib/fisk/instructions/pandn.rb
348
+ - lib/fisk/instructions/pause.rb
349
+ - lib/fisk/instructions/pavgb.rb
350
+ - lib/fisk/instructions/pavgusb.rb
351
+ - lib/fisk/instructions/pavgw.rb
352
+ - lib/fisk/instructions/pblendvb.rb
353
+ - lib/fisk/instructions/pblendw.rb
354
+ - lib/fisk/instructions/pclmulqdq.rb
355
+ - lib/fisk/instructions/pcmpeqb.rb
356
+ - lib/fisk/instructions/pcmpeqd.rb
357
+ - lib/fisk/instructions/pcmpeqq.rb
358
+ - lib/fisk/instructions/pcmpeqw.rb
359
+ - lib/fisk/instructions/pcmpestri.rb
360
+ - lib/fisk/instructions/pcmpestrm.rb
361
+ - lib/fisk/instructions/pcmpgtb.rb
362
+ - lib/fisk/instructions/pcmpgtd.rb
363
+ - lib/fisk/instructions/pcmpgtq.rb
364
+ - lib/fisk/instructions/pcmpgtw.rb
365
+ - lib/fisk/instructions/pcmpistri.rb
366
+ - lib/fisk/instructions/pcmpistrm.rb
367
+ - lib/fisk/instructions/pdep.rb
368
+ - lib/fisk/instructions/pext.rb
369
+ - lib/fisk/instructions/pextrb.rb
370
+ - lib/fisk/instructions/pextrd.rb
371
+ - lib/fisk/instructions/pextrq.rb
372
+ - lib/fisk/instructions/pextrw.rb
373
+ - lib/fisk/instructions/pf2id.rb
374
+ - lib/fisk/instructions/pf2iw.rb
375
+ - lib/fisk/instructions/pfacc.rb
376
+ - lib/fisk/instructions/pfadd.rb
377
+ - lib/fisk/instructions/pfcmpeq.rb
378
+ - lib/fisk/instructions/pfcmpge.rb
379
+ - lib/fisk/instructions/pfcmpgt.rb
380
+ - lib/fisk/instructions/pfmax.rb
381
+ - lib/fisk/instructions/pfmin.rb
382
+ - lib/fisk/instructions/pfmul.rb
383
+ - lib/fisk/instructions/pfnacc.rb
384
+ - lib/fisk/instructions/pfpnacc.rb
385
+ - lib/fisk/instructions/pfrcp.rb
386
+ - lib/fisk/instructions/pfrcpit1.rb
387
+ - lib/fisk/instructions/pfrcpit2.rb
388
+ - lib/fisk/instructions/pfrsqit1.rb
389
+ - lib/fisk/instructions/pfrsqrt.rb
390
+ - lib/fisk/instructions/pfsub.rb
391
+ - lib/fisk/instructions/pfsubr.rb
392
+ - lib/fisk/instructions/phaddd.rb
393
+ - lib/fisk/instructions/phaddsw.rb
394
+ - lib/fisk/instructions/phaddw.rb
395
+ - lib/fisk/instructions/phminposuw.rb
396
+ - lib/fisk/instructions/phsubd.rb
397
+ - lib/fisk/instructions/phsubsw.rb
398
+ - lib/fisk/instructions/phsubw.rb
399
+ - lib/fisk/instructions/pi2fd.rb
400
+ - lib/fisk/instructions/pi2fw.rb
401
+ - lib/fisk/instructions/pinsrb.rb
402
+ - lib/fisk/instructions/pinsrd.rb
403
+ - lib/fisk/instructions/pinsrq.rb
404
+ - lib/fisk/instructions/pinsrw.rb
405
+ - lib/fisk/instructions/pmaddubsw.rb
406
+ - lib/fisk/instructions/pmaddwd.rb
407
+ - lib/fisk/instructions/pmaxsb.rb
408
+ - lib/fisk/instructions/pmaxsd.rb
409
+ - lib/fisk/instructions/pmaxsw.rb
410
+ - lib/fisk/instructions/pmaxub.rb
411
+ - lib/fisk/instructions/pmaxud.rb
412
+ - lib/fisk/instructions/pmaxuw.rb
413
+ - lib/fisk/instructions/pminsb.rb
414
+ - lib/fisk/instructions/pminsd.rb
415
+ - lib/fisk/instructions/pminsw.rb
416
+ - lib/fisk/instructions/pminub.rb
417
+ - lib/fisk/instructions/pminud.rb
418
+ - lib/fisk/instructions/pminuw.rb
419
+ - lib/fisk/instructions/pmovmskb.rb
420
+ - lib/fisk/instructions/pmovsxbd.rb
421
+ - lib/fisk/instructions/pmovsxbq.rb
422
+ - lib/fisk/instructions/pmovsxbw.rb
423
+ - lib/fisk/instructions/pmovsxdq.rb
424
+ - lib/fisk/instructions/pmovsxwd.rb
425
+ - lib/fisk/instructions/pmovsxwq.rb
426
+ - lib/fisk/instructions/pmovzxbd.rb
427
+ - lib/fisk/instructions/pmovzxbq.rb
428
+ - lib/fisk/instructions/pmovzxbw.rb
429
+ - lib/fisk/instructions/pmovzxdq.rb
430
+ - lib/fisk/instructions/pmovzxwd.rb
431
+ - lib/fisk/instructions/pmovzxwq.rb
432
+ - lib/fisk/instructions/pmuldq.rb
433
+ - lib/fisk/instructions/pmulhrsw.rb
434
+ - lib/fisk/instructions/pmulhrw.rb
435
+ - lib/fisk/instructions/pmulhuw.rb
436
+ - lib/fisk/instructions/pmulhw.rb
437
+ - lib/fisk/instructions/pmulld.rb
438
+ - lib/fisk/instructions/pmullw.rb
439
+ - lib/fisk/instructions/pmuludq.rb
440
+ - lib/fisk/instructions/pop.rb
441
+ - lib/fisk/instructions/popcnt.rb
442
+ - lib/fisk/instructions/por.rb
443
+ - lib/fisk/instructions/prefetch.rb
444
+ - lib/fisk/instructions/prefetchnta.rb
445
+ - lib/fisk/instructions/prefetcht0.rb
446
+ - lib/fisk/instructions/prefetcht1.rb
447
+ - lib/fisk/instructions/prefetcht2.rb
448
+ - lib/fisk/instructions/prefetchw.rb
449
+ - lib/fisk/instructions/prefetchwt1.rb
450
+ - lib/fisk/instructions/psadbw.rb
451
+ - lib/fisk/instructions/pshufb.rb
452
+ - lib/fisk/instructions/pshufd.rb
453
+ - lib/fisk/instructions/pshufhw.rb
454
+ - lib/fisk/instructions/pshuflw.rb
455
+ - lib/fisk/instructions/pshufw.rb
456
+ - lib/fisk/instructions/psignb.rb
457
+ - lib/fisk/instructions/psignd.rb
458
+ - lib/fisk/instructions/psignw.rb
459
+ - lib/fisk/instructions/pslld.rb
460
+ - lib/fisk/instructions/pslldq.rb
461
+ - lib/fisk/instructions/psllq.rb
462
+ - lib/fisk/instructions/psllw.rb
463
+ - lib/fisk/instructions/psrad.rb
464
+ - lib/fisk/instructions/psraw.rb
465
+ - lib/fisk/instructions/psrld.rb
466
+ - lib/fisk/instructions/psrldq.rb
467
+ - lib/fisk/instructions/psrlq.rb
468
+ - lib/fisk/instructions/psrlw.rb
469
+ - lib/fisk/instructions/psubb.rb
470
+ - lib/fisk/instructions/psubd.rb
471
+ - lib/fisk/instructions/psubq.rb
472
+ - lib/fisk/instructions/psubsb.rb
473
+ - lib/fisk/instructions/psubsw.rb
474
+ - lib/fisk/instructions/psubusb.rb
475
+ - lib/fisk/instructions/psubusw.rb
476
+ - lib/fisk/instructions/psubw.rb
477
+ - lib/fisk/instructions/pswapd.rb
478
+ - lib/fisk/instructions/ptest.rb
479
+ - lib/fisk/instructions/punpckhbw.rb
480
+ - lib/fisk/instructions/punpckhdq.rb
481
+ - lib/fisk/instructions/punpckhqdq.rb
482
+ - lib/fisk/instructions/punpckhwd.rb
483
+ - lib/fisk/instructions/punpcklbw.rb
484
+ - lib/fisk/instructions/punpckldq.rb
485
+ - lib/fisk/instructions/punpcklqdq.rb
486
+ - lib/fisk/instructions/punpcklwd.rb
487
+ - lib/fisk/instructions/push.rb
488
+ - lib/fisk/instructions/pxor.rb
489
+ - lib/fisk/instructions/rcl.rb
490
+ - lib/fisk/instructions/rcpps.rb
491
+ - lib/fisk/instructions/rcpss.rb
492
+ - lib/fisk/instructions/rcr.rb
493
+ - lib/fisk/instructions/rdrand.rb
494
+ - lib/fisk/instructions/rdseed.rb
495
+ - lib/fisk/instructions/rdtsc.rb
496
+ - lib/fisk/instructions/rdtscp.rb
497
+ - lib/fisk/instructions/ret.rb
498
+ - lib/fisk/instructions/rol.rb
499
+ - lib/fisk/instructions/ror.rb
500
+ - lib/fisk/instructions/rorx.rb
501
+ - lib/fisk/instructions/roundpd.rb
502
+ - lib/fisk/instructions/roundps.rb
503
+ - lib/fisk/instructions/roundsd.rb
504
+ - lib/fisk/instructions/roundss.rb
505
+ - lib/fisk/instructions/rsqrtps.rb
506
+ - lib/fisk/instructions/rsqrtss.rb
507
+ - lib/fisk/instructions/sal.rb
508
+ - lib/fisk/instructions/sar.rb
509
+ - lib/fisk/instructions/sarx.rb
510
+ - lib/fisk/instructions/sbb.rb
511
+ - lib/fisk/instructions/seta.rb
512
+ - lib/fisk/instructions/setae.rb
513
+ - lib/fisk/instructions/setb.rb
514
+ - lib/fisk/instructions/setbe.rb
515
+ - lib/fisk/instructions/setc.rb
516
+ - lib/fisk/instructions/sete.rb
517
+ - lib/fisk/instructions/setg.rb
518
+ - lib/fisk/instructions/setge.rb
519
+ - lib/fisk/instructions/setl.rb
520
+ - lib/fisk/instructions/setle.rb
521
+ - lib/fisk/instructions/setna.rb
522
+ - lib/fisk/instructions/setnae.rb
523
+ - lib/fisk/instructions/setnb.rb
524
+ - lib/fisk/instructions/setnbe.rb
525
+ - lib/fisk/instructions/setnc.rb
526
+ - lib/fisk/instructions/setne.rb
527
+ - lib/fisk/instructions/setng.rb
528
+ - lib/fisk/instructions/setnge.rb
529
+ - lib/fisk/instructions/setnl.rb
530
+ - lib/fisk/instructions/setnle.rb
531
+ - lib/fisk/instructions/setno.rb
532
+ - lib/fisk/instructions/setnp.rb
533
+ - lib/fisk/instructions/setns.rb
534
+ - lib/fisk/instructions/setnz.rb
535
+ - lib/fisk/instructions/seto.rb
536
+ - lib/fisk/instructions/setp.rb
537
+ - lib/fisk/instructions/setpe.rb
538
+ - lib/fisk/instructions/setpo.rb
539
+ - lib/fisk/instructions/sets.rb
540
+ - lib/fisk/instructions/setz.rb
541
+ - lib/fisk/instructions/sfence.rb
542
+ - lib/fisk/instructions/sha1msg1.rb
543
+ - lib/fisk/instructions/sha1msg2.rb
544
+ - lib/fisk/instructions/sha1nexte.rb
545
+ - lib/fisk/instructions/sha1rnds4.rb
546
+ - lib/fisk/instructions/sha256msg1.rb
547
+ - lib/fisk/instructions/sha256msg2.rb
548
+ - lib/fisk/instructions/sha256rnds2.rb
549
+ - lib/fisk/instructions/shl.rb
550
+ - lib/fisk/instructions/shld.rb
551
+ - lib/fisk/instructions/shlx.rb
552
+ - lib/fisk/instructions/shr.rb
553
+ - lib/fisk/instructions/shrd.rb
554
+ - lib/fisk/instructions/shrx.rb
555
+ - lib/fisk/instructions/shufpd.rb
556
+ - lib/fisk/instructions/shufps.rb
557
+ - lib/fisk/instructions/sqrtpd.rb
558
+ - lib/fisk/instructions/sqrtps.rb
559
+ - lib/fisk/instructions/sqrtsd.rb
560
+ - lib/fisk/instructions/sqrtss.rb
561
+ - lib/fisk/instructions/stc.rb
562
+ - lib/fisk/instructions/std.rb
563
+ - lib/fisk/instructions/stmxcsr.rb
564
+ - lib/fisk/instructions/sub.rb
565
+ - lib/fisk/instructions/subpd.rb
566
+ - lib/fisk/instructions/subps.rb
567
+ - lib/fisk/instructions/subsd.rb
568
+ - lib/fisk/instructions/subss.rb
569
+ - lib/fisk/instructions/syscall.rb
570
+ - lib/fisk/instructions/t1mskc.rb
571
+ - lib/fisk/instructions/test.rb
572
+ - lib/fisk/instructions/tzcnt.rb
573
+ - lib/fisk/instructions/tzmsk.rb
574
+ - lib/fisk/instructions/ucomisd.rb
575
+ - lib/fisk/instructions/ucomiss.rb
576
+ - lib/fisk/instructions/ud2.rb
577
+ - lib/fisk/instructions/unpckhpd.rb
578
+ - lib/fisk/instructions/unpckhps.rb
579
+ - lib/fisk/instructions/unpcklpd.rb
580
+ - lib/fisk/instructions/unpcklps.rb
581
+ - lib/fisk/instructions/vaddpd.rb
582
+ - lib/fisk/instructions/vaddps.rb
583
+ - lib/fisk/instructions/vaddsd.rb
584
+ - lib/fisk/instructions/vaddss.rb
585
+ - lib/fisk/instructions/vaddsubpd.rb
586
+ - lib/fisk/instructions/vaddsubps.rb
587
+ - lib/fisk/instructions/vaesdec.rb
588
+ - lib/fisk/instructions/vaesdeclast.rb
589
+ - lib/fisk/instructions/vaesenc.rb
590
+ - lib/fisk/instructions/vaesenclast.rb
591
+ - lib/fisk/instructions/vaesimc.rb
592
+ - lib/fisk/instructions/vaeskeygenassist.rb
593
+ - lib/fisk/instructions/valignd.rb
594
+ - lib/fisk/instructions/valignq.rb
595
+ - lib/fisk/instructions/vandnpd.rb
596
+ - lib/fisk/instructions/vandnps.rb
597
+ - lib/fisk/instructions/vandpd.rb
598
+ - lib/fisk/instructions/vandps.rb
599
+ - lib/fisk/instructions/vblendmpd.rb
600
+ - lib/fisk/instructions/vblendmps.rb
601
+ - lib/fisk/instructions/vblendpd.rb
602
+ - lib/fisk/instructions/vblendps.rb
603
+ - lib/fisk/instructions/vblendvpd.rb
604
+ - lib/fisk/instructions/vblendvps.rb
605
+ - lib/fisk/instructions/vbroadcastf128.rb
606
+ - lib/fisk/instructions/vbroadcastf32x2.rb
607
+ - lib/fisk/instructions/vbroadcastf32x4.rb
608
+ - lib/fisk/instructions/vbroadcastf32x8.rb
609
+ - lib/fisk/instructions/vbroadcastf64x2.rb
610
+ - lib/fisk/instructions/vbroadcastf64x4.rb
611
+ - lib/fisk/instructions/vbroadcasti128.rb
612
+ - lib/fisk/instructions/vbroadcasti32x2.rb
613
+ - lib/fisk/instructions/vbroadcasti32x4.rb
614
+ - lib/fisk/instructions/vbroadcasti32x8.rb
615
+ - lib/fisk/instructions/vbroadcasti64x2.rb
616
+ - lib/fisk/instructions/vbroadcasti64x4.rb
617
+ - lib/fisk/instructions/vbroadcastsd.rb
618
+ - lib/fisk/instructions/vbroadcastss.rb
619
+ - lib/fisk/instructions/vcmppd.rb
620
+ - lib/fisk/instructions/vcmpps.rb
621
+ - lib/fisk/instructions/vcmpsd.rb
622
+ - lib/fisk/instructions/vcmpss.rb
623
+ - lib/fisk/instructions/vcomisd.rb
624
+ - lib/fisk/instructions/vcomiss.rb
625
+ - lib/fisk/instructions/vcompresspd.rb
626
+ - lib/fisk/instructions/vcompressps.rb
627
+ - lib/fisk/instructions/vcvtdq2pd.rb
628
+ - lib/fisk/instructions/vcvtdq2ps.rb
629
+ - lib/fisk/instructions/vcvtpd2dq.rb
630
+ - lib/fisk/instructions/vcvtpd2ps.rb
631
+ - lib/fisk/instructions/vcvtpd2qq.rb
632
+ - lib/fisk/instructions/vcvtpd2udq.rb
633
+ - lib/fisk/instructions/vcvtpd2uqq.rb
634
+ - lib/fisk/instructions/vcvtph2ps.rb
635
+ - lib/fisk/instructions/vcvtps2dq.rb
636
+ - lib/fisk/instructions/vcvtps2pd.rb
637
+ - lib/fisk/instructions/vcvtps2ph.rb
638
+ - lib/fisk/instructions/vcvtps2qq.rb
639
+ - lib/fisk/instructions/vcvtps2udq.rb
640
+ - lib/fisk/instructions/vcvtps2uqq.rb
641
+ - lib/fisk/instructions/vcvtqq2pd.rb
642
+ - lib/fisk/instructions/vcvtqq2ps.rb
643
+ - lib/fisk/instructions/vcvtsd2si.rb
644
+ - lib/fisk/instructions/vcvtsd2ss.rb
645
+ - lib/fisk/instructions/vcvtsd2usi.rb
646
+ - lib/fisk/instructions/vcvtsi2sd.rb
647
+ - lib/fisk/instructions/vcvtsi2ss.rb
648
+ - lib/fisk/instructions/vcvtss2sd.rb
649
+ - lib/fisk/instructions/vcvtss2si.rb
650
+ - lib/fisk/instructions/vcvtss2usi.rb
651
+ - lib/fisk/instructions/vcvttpd2dq.rb
652
+ - lib/fisk/instructions/vcvttpd2qq.rb
653
+ - lib/fisk/instructions/vcvttpd2udq.rb
654
+ - lib/fisk/instructions/vcvttpd2uqq.rb
655
+ - lib/fisk/instructions/vcvttps2dq.rb
656
+ - lib/fisk/instructions/vcvttps2qq.rb
657
+ - lib/fisk/instructions/vcvttps2udq.rb
658
+ - lib/fisk/instructions/vcvttps2uqq.rb
659
+ - lib/fisk/instructions/vcvttsd2si.rb
660
+ - lib/fisk/instructions/vcvttsd2usi.rb
661
+ - lib/fisk/instructions/vcvttss2si.rb
662
+ - lib/fisk/instructions/vcvttss2usi.rb
663
+ - lib/fisk/instructions/vcvtudq2pd.rb
664
+ - lib/fisk/instructions/vcvtudq2ps.rb
665
+ - lib/fisk/instructions/vcvtuqq2pd.rb
666
+ - lib/fisk/instructions/vcvtuqq2ps.rb
667
+ - lib/fisk/instructions/vcvtusi2sd.rb
668
+ - lib/fisk/instructions/vcvtusi2ss.rb
669
+ - lib/fisk/instructions/vdbpsadbw.rb
670
+ - lib/fisk/instructions/vdivpd.rb
671
+ - lib/fisk/instructions/vdivps.rb
672
+ - lib/fisk/instructions/vdivsd.rb
673
+ - lib/fisk/instructions/vdivss.rb
674
+ - lib/fisk/instructions/vdppd.rb
675
+ - lib/fisk/instructions/vdpps.rb
676
+ - lib/fisk/instructions/vexp2pd.rb
677
+ - lib/fisk/instructions/vexp2ps.rb
678
+ - lib/fisk/instructions/vexpandpd.rb
679
+ - lib/fisk/instructions/vexpandps.rb
680
+ - lib/fisk/instructions/vextractf128.rb
681
+ - lib/fisk/instructions/vextractf32x4.rb
682
+ - lib/fisk/instructions/vextractf32x8.rb
683
+ - lib/fisk/instructions/vextractf64x2.rb
684
+ - lib/fisk/instructions/vextractf64x4.rb
685
+ - lib/fisk/instructions/vextracti128.rb
686
+ - lib/fisk/instructions/vextracti32x4.rb
687
+ - lib/fisk/instructions/vextracti32x8.rb
688
+ - lib/fisk/instructions/vextracti64x2.rb
689
+ - lib/fisk/instructions/vextracti64x4.rb
690
+ - lib/fisk/instructions/vextractps.rb
691
+ - lib/fisk/instructions/vfixupimmpd.rb
692
+ - lib/fisk/instructions/vfixupimmps.rb
693
+ - lib/fisk/instructions/vfixupimmsd.rb
694
+ - lib/fisk/instructions/vfixupimmss.rb
695
+ - lib/fisk/instructions/vfmadd132pd.rb
696
+ - lib/fisk/instructions/vfmadd132ps.rb
697
+ - lib/fisk/instructions/vfmadd132sd.rb
698
+ - lib/fisk/instructions/vfmadd132ss.rb
699
+ - lib/fisk/instructions/vfmadd213pd.rb
700
+ - lib/fisk/instructions/vfmadd213ps.rb
701
+ - lib/fisk/instructions/vfmadd213sd.rb
702
+ - lib/fisk/instructions/vfmadd213ss.rb
703
+ - lib/fisk/instructions/vfmadd231pd.rb
704
+ - lib/fisk/instructions/vfmadd231ps.rb
705
+ - lib/fisk/instructions/vfmadd231sd.rb
706
+ - lib/fisk/instructions/vfmadd231ss.rb
707
+ - lib/fisk/instructions/vfmaddpd.rb
708
+ - lib/fisk/instructions/vfmaddps.rb
709
+ - lib/fisk/instructions/vfmaddsd.rb
710
+ - lib/fisk/instructions/vfmaddss.rb
711
+ - lib/fisk/instructions/vfmaddsub132pd.rb
712
+ - lib/fisk/instructions/vfmaddsub132ps.rb
713
+ - lib/fisk/instructions/vfmaddsub213pd.rb
714
+ - lib/fisk/instructions/vfmaddsub213ps.rb
715
+ - lib/fisk/instructions/vfmaddsub231pd.rb
716
+ - lib/fisk/instructions/vfmaddsub231ps.rb
717
+ - lib/fisk/instructions/vfmaddsubpd.rb
718
+ - lib/fisk/instructions/vfmaddsubps.rb
719
+ - lib/fisk/instructions/vfmsub132pd.rb
720
+ - lib/fisk/instructions/vfmsub132ps.rb
721
+ - lib/fisk/instructions/vfmsub132sd.rb
722
+ - lib/fisk/instructions/vfmsub132ss.rb
723
+ - lib/fisk/instructions/vfmsub213pd.rb
724
+ - lib/fisk/instructions/vfmsub213ps.rb
725
+ - lib/fisk/instructions/vfmsub213sd.rb
726
+ - lib/fisk/instructions/vfmsub213ss.rb
727
+ - lib/fisk/instructions/vfmsub231pd.rb
728
+ - lib/fisk/instructions/vfmsub231ps.rb
729
+ - lib/fisk/instructions/vfmsub231sd.rb
730
+ - lib/fisk/instructions/vfmsub231ss.rb
731
+ - lib/fisk/instructions/vfmsubadd132pd.rb
732
+ - lib/fisk/instructions/vfmsubadd132ps.rb
733
+ - lib/fisk/instructions/vfmsubadd213pd.rb
734
+ - lib/fisk/instructions/vfmsubadd213ps.rb
735
+ - lib/fisk/instructions/vfmsubadd231pd.rb
736
+ - lib/fisk/instructions/vfmsubadd231ps.rb
737
+ - lib/fisk/instructions/vfmsubaddpd.rb
738
+ - lib/fisk/instructions/vfmsubaddps.rb
739
+ - lib/fisk/instructions/vfmsubpd.rb
740
+ - lib/fisk/instructions/vfmsubps.rb
741
+ - lib/fisk/instructions/vfmsubsd.rb
742
+ - lib/fisk/instructions/vfmsubss.rb
743
+ - lib/fisk/instructions/vfnmadd132pd.rb
744
+ - lib/fisk/instructions/vfnmadd132ps.rb
745
+ - lib/fisk/instructions/vfnmadd132sd.rb
746
+ - lib/fisk/instructions/vfnmadd132ss.rb
747
+ - lib/fisk/instructions/vfnmadd213pd.rb
748
+ - lib/fisk/instructions/vfnmadd213ps.rb
749
+ - lib/fisk/instructions/vfnmadd213sd.rb
750
+ - lib/fisk/instructions/vfnmadd213ss.rb
751
+ - lib/fisk/instructions/vfnmadd231pd.rb
752
+ - lib/fisk/instructions/vfnmadd231ps.rb
753
+ - lib/fisk/instructions/vfnmadd231sd.rb
754
+ - lib/fisk/instructions/vfnmadd231ss.rb
755
+ - lib/fisk/instructions/vfnmaddpd.rb
756
+ - lib/fisk/instructions/vfnmaddps.rb
757
+ - lib/fisk/instructions/vfnmaddsd.rb
758
+ - lib/fisk/instructions/vfnmaddss.rb
759
+ - lib/fisk/instructions/vfnmsub132pd.rb
760
+ - lib/fisk/instructions/vfnmsub132ps.rb
761
+ - lib/fisk/instructions/vfnmsub132sd.rb
762
+ - lib/fisk/instructions/vfnmsub132ss.rb
763
+ - lib/fisk/instructions/vfnmsub213pd.rb
764
+ - lib/fisk/instructions/vfnmsub213ps.rb
765
+ - lib/fisk/instructions/vfnmsub213sd.rb
766
+ - lib/fisk/instructions/vfnmsub213ss.rb
767
+ - lib/fisk/instructions/vfnmsub231pd.rb
768
+ - lib/fisk/instructions/vfnmsub231ps.rb
769
+ - lib/fisk/instructions/vfnmsub231sd.rb
770
+ - lib/fisk/instructions/vfnmsub231ss.rb
771
+ - lib/fisk/instructions/vfnmsubpd.rb
772
+ - lib/fisk/instructions/vfnmsubps.rb
773
+ - lib/fisk/instructions/vfnmsubsd.rb
774
+ - lib/fisk/instructions/vfnmsubss.rb
775
+ - lib/fisk/instructions/vfpclasspd.rb
776
+ - lib/fisk/instructions/vfpclassps.rb
777
+ - lib/fisk/instructions/vfpclasssd.rb
778
+ - lib/fisk/instructions/vfpclassss.rb
779
+ - lib/fisk/instructions/vfrczpd.rb
780
+ - lib/fisk/instructions/vfrczps.rb
781
+ - lib/fisk/instructions/vfrczsd.rb
782
+ - lib/fisk/instructions/vfrczss.rb
783
+ - lib/fisk/instructions/vgatherdpd.rb
784
+ - lib/fisk/instructions/vgatherdps.rb
785
+ - lib/fisk/instructions/vgatherpf0dpd.rb
786
+ - lib/fisk/instructions/vgatherpf0dps.rb
787
+ - lib/fisk/instructions/vgatherpf0qpd.rb
788
+ - lib/fisk/instructions/vgatherpf0qps.rb
789
+ - lib/fisk/instructions/vgatherpf1dpd.rb
790
+ - lib/fisk/instructions/vgatherpf1dps.rb
791
+ - lib/fisk/instructions/vgatherpf1qpd.rb
792
+ - lib/fisk/instructions/vgatherpf1qps.rb
793
+ - lib/fisk/instructions/vgatherqpd.rb
794
+ - lib/fisk/instructions/vgatherqps.rb
795
+ - lib/fisk/instructions/vgetexppd.rb
796
+ - lib/fisk/instructions/vgetexpps.rb
797
+ - lib/fisk/instructions/vgetexpsd.rb
798
+ - lib/fisk/instructions/vgetexpss.rb
799
+ - lib/fisk/instructions/vgetmantpd.rb
800
+ - lib/fisk/instructions/vgetmantps.rb
801
+ - lib/fisk/instructions/vgetmantsd.rb
802
+ - lib/fisk/instructions/vgetmantss.rb
803
+ - lib/fisk/instructions/vhaddpd.rb
804
+ - lib/fisk/instructions/vhaddps.rb
805
+ - lib/fisk/instructions/vhsubpd.rb
806
+ - lib/fisk/instructions/vhsubps.rb
807
+ - lib/fisk/instructions/vinsertf128.rb
808
+ - lib/fisk/instructions/vinsertf32x4.rb
809
+ - lib/fisk/instructions/vinsertf32x8.rb
810
+ - lib/fisk/instructions/vinsertf64x2.rb
811
+ - lib/fisk/instructions/vinsertf64x4.rb
812
+ - lib/fisk/instructions/vinserti128.rb
813
+ - lib/fisk/instructions/vinserti32x4.rb
814
+ - lib/fisk/instructions/vinserti32x8.rb
815
+ - lib/fisk/instructions/vinserti64x2.rb
816
+ - lib/fisk/instructions/vinserti64x4.rb
817
+ - lib/fisk/instructions/vinsertps.rb
818
+ - lib/fisk/instructions/vlddqu.rb
819
+ - lib/fisk/instructions/vldmxcsr.rb
820
+ - lib/fisk/instructions/vmaskmovdqu.rb
821
+ - lib/fisk/instructions/vmaskmovpd.rb
822
+ - lib/fisk/instructions/vmaskmovps.rb
823
+ - lib/fisk/instructions/vmaxpd.rb
824
+ - lib/fisk/instructions/vmaxps.rb
825
+ - lib/fisk/instructions/vmaxsd.rb
826
+ - lib/fisk/instructions/vmaxss.rb
827
+ - lib/fisk/instructions/vminpd.rb
828
+ - lib/fisk/instructions/vminps.rb
829
+ - lib/fisk/instructions/vminsd.rb
830
+ - lib/fisk/instructions/vminss.rb
831
+ - lib/fisk/instructions/vmovapd.rb
832
+ - lib/fisk/instructions/vmovaps.rb
833
+ - lib/fisk/instructions/vmovd.rb
834
+ - lib/fisk/instructions/vmovddup.rb
835
+ - lib/fisk/instructions/vmovdqa.rb
836
+ - lib/fisk/instructions/vmovdqa32.rb
837
+ - lib/fisk/instructions/vmovdqa64.rb
838
+ - lib/fisk/instructions/vmovdqu.rb
839
+ - lib/fisk/instructions/vmovdqu16.rb
840
+ - lib/fisk/instructions/vmovdqu32.rb
841
+ - lib/fisk/instructions/vmovdqu64.rb
842
+ - lib/fisk/instructions/vmovdqu8.rb
843
+ - lib/fisk/instructions/vmovhlps.rb
844
+ - lib/fisk/instructions/vmovhpd.rb
845
+ - lib/fisk/instructions/vmovhps.rb
846
+ - lib/fisk/instructions/vmovlhps.rb
847
+ - lib/fisk/instructions/vmovlpd.rb
848
+ - lib/fisk/instructions/vmovlps.rb
849
+ - lib/fisk/instructions/vmovmskpd.rb
850
+ - lib/fisk/instructions/vmovmskps.rb
851
+ - lib/fisk/instructions/vmovntdq.rb
852
+ - lib/fisk/instructions/vmovntdqa.rb
853
+ - lib/fisk/instructions/vmovntpd.rb
854
+ - lib/fisk/instructions/vmovntps.rb
855
+ - lib/fisk/instructions/vmovq.rb
856
+ - lib/fisk/instructions/vmovsd.rb
857
+ - lib/fisk/instructions/vmovshdup.rb
858
+ - lib/fisk/instructions/vmovsldup.rb
859
+ - lib/fisk/instructions/vmovss.rb
860
+ - lib/fisk/instructions/vmovupd.rb
861
+ - lib/fisk/instructions/vmovups.rb
862
+ - lib/fisk/instructions/vmpsadbw.rb
863
+ - lib/fisk/instructions/vmulpd.rb
864
+ - lib/fisk/instructions/vmulps.rb
865
+ - lib/fisk/instructions/vmulsd.rb
866
+ - lib/fisk/instructions/vmulss.rb
867
+ - lib/fisk/instructions/vorpd.rb
868
+ - lib/fisk/instructions/vorps.rb
869
+ - lib/fisk/instructions/vpabsb.rb
870
+ - lib/fisk/instructions/vpabsd.rb
871
+ - lib/fisk/instructions/vpabsq.rb
872
+ - lib/fisk/instructions/vpabsw.rb
873
+ - lib/fisk/instructions/vpackssdw.rb
874
+ - lib/fisk/instructions/vpacksswb.rb
875
+ - lib/fisk/instructions/vpackusdw.rb
876
+ - lib/fisk/instructions/vpackuswb.rb
877
+ - lib/fisk/instructions/vpaddb.rb
878
+ - lib/fisk/instructions/vpaddd.rb
879
+ - lib/fisk/instructions/vpaddq.rb
880
+ - lib/fisk/instructions/vpaddsb.rb
881
+ - lib/fisk/instructions/vpaddsw.rb
882
+ - lib/fisk/instructions/vpaddusb.rb
883
+ - lib/fisk/instructions/vpaddusw.rb
884
+ - lib/fisk/instructions/vpaddw.rb
885
+ - lib/fisk/instructions/vpalignr.rb
886
+ - lib/fisk/instructions/vpand.rb
887
+ - lib/fisk/instructions/vpandd.rb
888
+ - lib/fisk/instructions/vpandn.rb
889
+ - lib/fisk/instructions/vpandnd.rb
890
+ - lib/fisk/instructions/vpandnq.rb
891
+ - lib/fisk/instructions/vpandq.rb
892
+ - lib/fisk/instructions/vpavgb.rb
893
+ - lib/fisk/instructions/vpavgw.rb
894
+ - lib/fisk/instructions/vpblendd.rb
895
+ - lib/fisk/instructions/vpblendmb.rb
896
+ - lib/fisk/instructions/vpblendmd.rb
897
+ - lib/fisk/instructions/vpblendmq.rb
898
+ - lib/fisk/instructions/vpblendmw.rb
899
+ - lib/fisk/instructions/vpblendvb.rb
900
+ - lib/fisk/instructions/vpblendw.rb
901
+ - lib/fisk/instructions/vpbroadcastb.rb
902
+ - lib/fisk/instructions/vpbroadcastd.rb
903
+ - lib/fisk/instructions/vpbroadcastmb2q.rb
904
+ - lib/fisk/instructions/vpbroadcastmw2d.rb
905
+ - lib/fisk/instructions/vpbroadcastq.rb
906
+ - lib/fisk/instructions/vpbroadcastw.rb
907
+ - lib/fisk/instructions/vpclmulqdq.rb
908
+ - lib/fisk/instructions/vpcmov.rb
909
+ - lib/fisk/instructions/vpcmpb.rb
910
+ - lib/fisk/instructions/vpcmpd.rb
911
+ - lib/fisk/instructions/vpcmpeqb.rb
912
+ - lib/fisk/instructions/vpcmpeqd.rb
913
+ - lib/fisk/instructions/vpcmpeqq.rb
914
+ - lib/fisk/instructions/vpcmpeqw.rb
915
+ - lib/fisk/instructions/vpcmpestri.rb
916
+ - lib/fisk/instructions/vpcmpestrm.rb
917
+ - lib/fisk/instructions/vpcmpgtb.rb
918
+ - lib/fisk/instructions/vpcmpgtd.rb
919
+ - lib/fisk/instructions/vpcmpgtq.rb
920
+ - lib/fisk/instructions/vpcmpgtw.rb
921
+ - lib/fisk/instructions/vpcmpistri.rb
922
+ - lib/fisk/instructions/vpcmpistrm.rb
923
+ - lib/fisk/instructions/vpcmpq.rb
924
+ - lib/fisk/instructions/vpcmpub.rb
925
+ - lib/fisk/instructions/vpcmpud.rb
926
+ - lib/fisk/instructions/vpcmpuq.rb
927
+ - lib/fisk/instructions/vpcmpuw.rb
928
+ - lib/fisk/instructions/vpcmpw.rb
929
+ - lib/fisk/instructions/vpcomb.rb
930
+ - lib/fisk/instructions/vpcomd.rb
931
+ - lib/fisk/instructions/vpcompressd.rb
932
+ - lib/fisk/instructions/vpcompressq.rb
933
+ - lib/fisk/instructions/vpcomq.rb
934
+ - lib/fisk/instructions/vpcomub.rb
935
+ - lib/fisk/instructions/vpcomud.rb
936
+ - lib/fisk/instructions/vpcomuq.rb
937
+ - lib/fisk/instructions/vpcomuw.rb
938
+ - lib/fisk/instructions/vpcomw.rb
939
+ - lib/fisk/instructions/vpconflictd.rb
940
+ - lib/fisk/instructions/vpconflictq.rb
941
+ - lib/fisk/instructions/vperm2f128.rb
942
+ - lib/fisk/instructions/vperm2i128.rb
943
+ - lib/fisk/instructions/vpermb.rb
944
+ - lib/fisk/instructions/vpermd.rb
945
+ - lib/fisk/instructions/vpermi2b.rb
946
+ - lib/fisk/instructions/vpermi2d.rb
947
+ - lib/fisk/instructions/vpermi2pd.rb
948
+ - lib/fisk/instructions/vpermi2ps.rb
949
+ - lib/fisk/instructions/vpermi2q.rb
950
+ - lib/fisk/instructions/vpermi2w.rb
951
+ - lib/fisk/instructions/vpermil2pd.rb
952
+ - lib/fisk/instructions/vpermil2ps.rb
953
+ - lib/fisk/instructions/vpermilpd.rb
954
+ - lib/fisk/instructions/vpermilps.rb
955
+ - lib/fisk/instructions/vpermpd.rb
956
+ - lib/fisk/instructions/vpermps.rb
957
+ - lib/fisk/instructions/vpermq.rb
958
+ - lib/fisk/instructions/vpermt2b.rb
959
+ - lib/fisk/instructions/vpermt2d.rb
960
+ - lib/fisk/instructions/vpermt2pd.rb
961
+ - lib/fisk/instructions/vpermt2ps.rb
962
+ - lib/fisk/instructions/vpermt2q.rb
963
+ - lib/fisk/instructions/vpermt2w.rb
964
+ - lib/fisk/instructions/vpermw.rb
965
+ - lib/fisk/instructions/vpexpandd.rb
966
+ - lib/fisk/instructions/vpexpandq.rb
967
+ - lib/fisk/instructions/vpextrb.rb
968
+ - lib/fisk/instructions/vpextrd.rb
969
+ - lib/fisk/instructions/vpextrq.rb
970
+ - lib/fisk/instructions/vpextrw.rb
971
+ - lib/fisk/instructions/vpgatherdd.rb
972
+ - lib/fisk/instructions/vpgatherdq.rb
973
+ - lib/fisk/instructions/vpgatherqd.rb
974
+ - lib/fisk/instructions/vpgatherqq.rb
975
+ - lib/fisk/instructions/vphaddbd.rb
976
+ - lib/fisk/instructions/vphaddbq.rb
977
+ - lib/fisk/instructions/vphaddbw.rb
978
+ - lib/fisk/instructions/vphaddd.rb
979
+ - lib/fisk/instructions/vphadddq.rb
980
+ - lib/fisk/instructions/vphaddsw.rb
981
+ - lib/fisk/instructions/vphaddubd.rb
982
+ - lib/fisk/instructions/vphaddubq.rb
983
+ - lib/fisk/instructions/vphaddubw.rb
984
+ - lib/fisk/instructions/vphaddudq.rb
985
+ - lib/fisk/instructions/vphadduwd.rb
986
+ - lib/fisk/instructions/vphadduwq.rb
987
+ - lib/fisk/instructions/vphaddw.rb
988
+ - lib/fisk/instructions/vphaddwd.rb
989
+ - lib/fisk/instructions/vphaddwq.rb
990
+ - lib/fisk/instructions/vphminposuw.rb
991
+ - lib/fisk/instructions/vphsubbw.rb
992
+ - lib/fisk/instructions/vphsubd.rb
993
+ - lib/fisk/instructions/vphsubdq.rb
994
+ - lib/fisk/instructions/vphsubsw.rb
995
+ - lib/fisk/instructions/vphsubw.rb
996
+ - lib/fisk/instructions/vphsubwd.rb
997
+ - lib/fisk/instructions/vpinsrb.rb
998
+ - lib/fisk/instructions/vpinsrd.rb
999
+ - lib/fisk/instructions/vpinsrq.rb
1000
+ - lib/fisk/instructions/vpinsrw.rb
1001
+ - lib/fisk/instructions/vplzcntd.rb
1002
+ - lib/fisk/instructions/vplzcntq.rb
1003
+ - lib/fisk/instructions/vpmacsdd.rb
1004
+ - lib/fisk/instructions/vpmacsdqh.rb
1005
+ - lib/fisk/instructions/vpmacsdql.rb
1006
+ - lib/fisk/instructions/vpmacssdd.rb
1007
+ - lib/fisk/instructions/vpmacssdqh.rb
1008
+ - lib/fisk/instructions/vpmacssdql.rb
1009
+ - lib/fisk/instructions/vpmacsswd.rb
1010
+ - lib/fisk/instructions/vpmacssww.rb
1011
+ - lib/fisk/instructions/vpmacswd.rb
1012
+ - lib/fisk/instructions/vpmacsww.rb
1013
+ - lib/fisk/instructions/vpmadcsswd.rb
1014
+ - lib/fisk/instructions/vpmadcswd.rb
1015
+ - lib/fisk/instructions/vpmadd52huq.rb
1016
+ - lib/fisk/instructions/vpmadd52luq.rb
1017
+ - lib/fisk/instructions/vpmaddubsw.rb
1018
+ - lib/fisk/instructions/vpmaddwd.rb
1019
+ - lib/fisk/instructions/vpmaskmovd.rb
1020
+ - lib/fisk/instructions/vpmaskmovq.rb
1021
+ - lib/fisk/instructions/vpmaxsb.rb
1022
+ - lib/fisk/instructions/vpmaxsd.rb
1023
+ - lib/fisk/instructions/vpmaxsq.rb
1024
+ - lib/fisk/instructions/vpmaxsw.rb
1025
+ - lib/fisk/instructions/vpmaxub.rb
1026
+ - lib/fisk/instructions/vpmaxud.rb
1027
+ - lib/fisk/instructions/vpmaxuq.rb
1028
+ - lib/fisk/instructions/vpmaxuw.rb
1029
+ - lib/fisk/instructions/vpminsb.rb
1030
+ - lib/fisk/instructions/vpminsd.rb
1031
+ - lib/fisk/instructions/vpminsq.rb
1032
+ - lib/fisk/instructions/vpminsw.rb
1033
+ - lib/fisk/instructions/vpminub.rb
1034
+ - lib/fisk/instructions/vpminud.rb
1035
+ - lib/fisk/instructions/vpminuq.rb
1036
+ - lib/fisk/instructions/vpminuw.rb
1037
+ - lib/fisk/instructions/vpmovb2m.rb
1038
+ - lib/fisk/instructions/vpmovd2m.rb
1039
+ - lib/fisk/instructions/vpmovdb.rb
1040
+ - lib/fisk/instructions/vpmovdw.rb
1041
+ - lib/fisk/instructions/vpmovm2b.rb
1042
+ - lib/fisk/instructions/vpmovm2d.rb
1043
+ - lib/fisk/instructions/vpmovm2q.rb
1044
+ - lib/fisk/instructions/vpmovm2w.rb
1045
+ - lib/fisk/instructions/vpmovmskb.rb
1046
+ - lib/fisk/instructions/vpmovq2m.rb
1047
+ - lib/fisk/instructions/vpmovqb.rb
1048
+ - lib/fisk/instructions/vpmovqd.rb
1049
+ - lib/fisk/instructions/vpmovqw.rb
1050
+ - lib/fisk/instructions/vpmovsdb.rb
1051
+ - lib/fisk/instructions/vpmovsdw.rb
1052
+ - lib/fisk/instructions/vpmovsqb.rb
1053
+ - lib/fisk/instructions/vpmovsqd.rb
1054
+ - lib/fisk/instructions/vpmovsqw.rb
1055
+ - lib/fisk/instructions/vpmovswb.rb
1056
+ - lib/fisk/instructions/vpmovsxbd.rb
1057
+ - lib/fisk/instructions/vpmovsxbq.rb
1058
+ - lib/fisk/instructions/vpmovsxbw.rb
1059
+ - lib/fisk/instructions/vpmovsxdq.rb
1060
+ - lib/fisk/instructions/vpmovsxwd.rb
1061
+ - lib/fisk/instructions/vpmovsxwq.rb
1062
+ - lib/fisk/instructions/vpmovusdb.rb
1063
+ - lib/fisk/instructions/vpmovusdw.rb
1064
+ - lib/fisk/instructions/vpmovusqb.rb
1065
+ - lib/fisk/instructions/vpmovusqd.rb
1066
+ - lib/fisk/instructions/vpmovusqw.rb
1067
+ - lib/fisk/instructions/vpmovuswb.rb
1068
+ - lib/fisk/instructions/vpmovw2m.rb
1069
+ - lib/fisk/instructions/vpmovwb.rb
1070
+ - lib/fisk/instructions/vpmovzxbd.rb
1071
+ - lib/fisk/instructions/vpmovzxbq.rb
1072
+ - lib/fisk/instructions/vpmovzxbw.rb
1073
+ - lib/fisk/instructions/vpmovzxdq.rb
1074
+ - lib/fisk/instructions/vpmovzxwd.rb
1075
+ - lib/fisk/instructions/vpmovzxwq.rb
1076
+ - lib/fisk/instructions/vpmuldq.rb
1077
+ - lib/fisk/instructions/vpmulhrsw.rb
1078
+ - lib/fisk/instructions/vpmulhuw.rb
1079
+ - lib/fisk/instructions/vpmulhw.rb
1080
+ - lib/fisk/instructions/vpmulld.rb
1081
+ - lib/fisk/instructions/vpmullq.rb
1082
+ - lib/fisk/instructions/vpmullw.rb
1083
+ - lib/fisk/instructions/vpmultishiftqb.rb
1084
+ - lib/fisk/instructions/vpmuludq.rb
1085
+ - lib/fisk/instructions/vpopcntd.rb
1086
+ - lib/fisk/instructions/vpopcntq.rb
1087
+ - lib/fisk/instructions/vpor.rb
1088
+ - lib/fisk/instructions/vpord.rb
1089
+ - lib/fisk/instructions/vporq.rb
1090
+ - lib/fisk/instructions/vpperm.rb
1091
+ - lib/fisk/instructions/vprold.rb
1092
+ - lib/fisk/instructions/vprolq.rb
1093
+ - lib/fisk/instructions/vprolvd.rb
1094
+ - lib/fisk/instructions/vprolvq.rb
1095
+ - lib/fisk/instructions/vprord.rb
1096
+ - lib/fisk/instructions/vprorq.rb
1097
+ - lib/fisk/instructions/vprorvd.rb
1098
+ - lib/fisk/instructions/vprorvq.rb
1099
+ - lib/fisk/instructions/vprotb.rb
1100
+ - lib/fisk/instructions/vprotd.rb
1101
+ - lib/fisk/instructions/vprotq.rb
1102
+ - lib/fisk/instructions/vprotw.rb
1103
+ - lib/fisk/instructions/vpsadbw.rb
1104
+ - lib/fisk/instructions/vpscatterdd.rb
1105
+ - lib/fisk/instructions/vpscatterdq.rb
1106
+ - lib/fisk/instructions/vpscatterqd.rb
1107
+ - lib/fisk/instructions/vpscatterqq.rb
1108
+ - lib/fisk/instructions/vpshab.rb
1109
+ - lib/fisk/instructions/vpshad.rb
1110
+ - lib/fisk/instructions/vpshaq.rb
1111
+ - lib/fisk/instructions/vpshaw.rb
1112
+ - lib/fisk/instructions/vpshlb.rb
1113
+ - lib/fisk/instructions/vpshld.rb
1114
+ - lib/fisk/instructions/vpshlq.rb
1115
+ - lib/fisk/instructions/vpshlw.rb
1116
+ - lib/fisk/instructions/vpshufb.rb
1117
+ - lib/fisk/instructions/vpshufd.rb
1118
+ - lib/fisk/instructions/vpshufhw.rb
1119
+ - lib/fisk/instructions/vpshuflw.rb
1120
+ - lib/fisk/instructions/vpsignb.rb
1121
+ - lib/fisk/instructions/vpsignd.rb
1122
+ - lib/fisk/instructions/vpsignw.rb
1123
+ - lib/fisk/instructions/vpslld.rb
1124
+ - lib/fisk/instructions/vpslldq.rb
1125
+ - lib/fisk/instructions/vpsllq.rb
1126
+ - lib/fisk/instructions/vpsllvd.rb
1127
+ - lib/fisk/instructions/vpsllvq.rb
1128
+ - lib/fisk/instructions/vpsllvw.rb
1129
+ - lib/fisk/instructions/vpsllw.rb
1130
+ - lib/fisk/instructions/vpsrad.rb
1131
+ - lib/fisk/instructions/vpsraq.rb
1132
+ - lib/fisk/instructions/vpsravd.rb
1133
+ - lib/fisk/instructions/vpsravq.rb
1134
+ - lib/fisk/instructions/vpsravw.rb
1135
+ - lib/fisk/instructions/vpsraw.rb
1136
+ - lib/fisk/instructions/vpsrld.rb
1137
+ - lib/fisk/instructions/vpsrldq.rb
1138
+ - lib/fisk/instructions/vpsrlq.rb
1139
+ - lib/fisk/instructions/vpsrlvd.rb
1140
+ - lib/fisk/instructions/vpsrlvq.rb
1141
+ - lib/fisk/instructions/vpsrlvw.rb
1142
+ - lib/fisk/instructions/vpsrlw.rb
1143
+ - lib/fisk/instructions/vpsubb.rb
1144
+ - lib/fisk/instructions/vpsubd.rb
1145
+ - lib/fisk/instructions/vpsubq.rb
1146
+ - lib/fisk/instructions/vpsubsb.rb
1147
+ - lib/fisk/instructions/vpsubsw.rb
1148
+ - lib/fisk/instructions/vpsubusb.rb
1149
+ - lib/fisk/instructions/vpsubusw.rb
1150
+ - lib/fisk/instructions/vpsubw.rb
1151
+ - lib/fisk/instructions/vpternlogd.rb
1152
+ - lib/fisk/instructions/vpternlogq.rb
1153
+ - lib/fisk/instructions/vptest.rb
1154
+ - lib/fisk/instructions/vptestmb.rb
1155
+ - lib/fisk/instructions/vptestmd.rb
1156
+ - lib/fisk/instructions/vptestmq.rb
1157
+ - lib/fisk/instructions/vptestmw.rb
1158
+ - lib/fisk/instructions/vptestnmb.rb
1159
+ - lib/fisk/instructions/vptestnmd.rb
1160
+ - lib/fisk/instructions/vptestnmq.rb
1161
+ - lib/fisk/instructions/vptestnmw.rb
1162
+ - lib/fisk/instructions/vpunpckhbw.rb
1163
+ - lib/fisk/instructions/vpunpckhdq.rb
1164
+ - lib/fisk/instructions/vpunpckhqdq.rb
1165
+ - lib/fisk/instructions/vpunpckhwd.rb
1166
+ - lib/fisk/instructions/vpunpcklbw.rb
1167
+ - lib/fisk/instructions/vpunpckldq.rb
1168
+ - lib/fisk/instructions/vpunpcklqdq.rb
1169
+ - lib/fisk/instructions/vpunpcklwd.rb
1170
+ - lib/fisk/instructions/vpxor.rb
1171
+ - lib/fisk/instructions/vpxord.rb
1172
+ - lib/fisk/instructions/vpxorq.rb
1173
+ - lib/fisk/instructions/vrangepd.rb
1174
+ - lib/fisk/instructions/vrangeps.rb
1175
+ - lib/fisk/instructions/vrangesd.rb
1176
+ - lib/fisk/instructions/vrangess.rb
1177
+ - lib/fisk/instructions/vrcp14pd.rb
1178
+ - lib/fisk/instructions/vrcp14ps.rb
1179
+ - lib/fisk/instructions/vrcp14sd.rb
1180
+ - lib/fisk/instructions/vrcp14ss.rb
1181
+ - lib/fisk/instructions/vrcp28pd.rb
1182
+ - lib/fisk/instructions/vrcp28ps.rb
1183
+ - lib/fisk/instructions/vrcp28sd.rb
1184
+ - lib/fisk/instructions/vrcp28ss.rb
1185
+ - lib/fisk/instructions/vrcpps.rb
1186
+ - lib/fisk/instructions/vrcpss.rb
1187
+ - lib/fisk/instructions/vreducepd.rb
1188
+ - lib/fisk/instructions/vreduceps.rb
1189
+ - lib/fisk/instructions/vreducesd.rb
1190
+ - lib/fisk/instructions/vreducess.rb
1191
+ - lib/fisk/instructions/vrndscalepd.rb
1192
+ - lib/fisk/instructions/vrndscaleps.rb
1193
+ - lib/fisk/instructions/vrndscalesd.rb
1194
+ - lib/fisk/instructions/vrndscaless.rb
1195
+ - lib/fisk/instructions/vroundpd.rb
1196
+ - lib/fisk/instructions/vroundps.rb
1197
+ - lib/fisk/instructions/vroundsd.rb
1198
+ - lib/fisk/instructions/vroundss.rb
1199
+ - lib/fisk/instructions/vrsqrt14pd.rb
1200
+ - lib/fisk/instructions/vrsqrt14ps.rb
1201
+ - lib/fisk/instructions/vrsqrt14sd.rb
1202
+ - lib/fisk/instructions/vrsqrt14ss.rb
1203
+ - lib/fisk/instructions/vrsqrt28pd.rb
1204
+ - lib/fisk/instructions/vrsqrt28ps.rb
1205
+ - lib/fisk/instructions/vrsqrt28sd.rb
1206
+ - lib/fisk/instructions/vrsqrt28ss.rb
1207
+ - lib/fisk/instructions/vrsqrtps.rb
1208
+ - lib/fisk/instructions/vrsqrtss.rb
1209
+ - lib/fisk/instructions/vscalefpd.rb
1210
+ - lib/fisk/instructions/vscalefps.rb
1211
+ - lib/fisk/instructions/vscalefsd.rb
1212
+ - lib/fisk/instructions/vscalefss.rb
1213
+ - lib/fisk/instructions/vscatterdpd.rb
1214
+ - lib/fisk/instructions/vscatterdps.rb
1215
+ - lib/fisk/instructions/vscatterpf0dpd.rb
1216
+ - lib/fisk/instructions/vscatterpf0dps.rb
1217
+ - lib/fisk/instructions/vscatterpf0qpd.rb
1218
+ - lib/fisk/instructions/vscatterpf0qps.rb
1219
+ - lib/fisk/instructions/vscatterpf1dpd.rb
1220
+ - lib/fisk/instructions/vscatterpf1dps.rb
1221
+ - lib/fisk/instructions/vscatterpf1qpd.rb
1222
+ - lib/fisk/instructions/vscatterpf1qps.rb
1223
+ - lib/fisk/instructions/vscatterqpd.rb
1224
+ - lib/fisk/instructions/vscatterqps.rb
1225
+ - lib/fisk/instructions/vshuff32x4.rb
1226
+ - lib/fisk/instructions/vshuff64x2.rb
1227
+ - lib/fisk/instructions/vshufi32x4.rb
1228
+ - lib/fisk/instructions/vshufi64x2.rb
1229
+ - lib/fisk/instructions/vshufpd.rb
1230
+ - lib/fisk/instructions/vshufps.rb
1231
+ - lib/fisk/instructions/vsqrtpd.rb
1232
+ - lib/fisk/instructions/vsqrtps.rb
1233
+ - lib/fisk/instructions/vsqrtsd.rb
1234
+ - lib/fisk/instructions/vsqrtss.rb
1235
+ - lib/fisk/instructions/vstmxcsr.rb
1236
+ - lib/fisk/instructions/vsubpd.rb
1237
+ - lib/fisk/instructions/vsubps.rb
1238
+ - lib/fisk/instructions/vsubsd.rb
1239
+ - lib/fisk/instructions/vsubss.rb
1240
+ - lib/fisk/instructions/vtestpd.rb
1241
+ - lib/fisk/instructions/vtestps.rb
1242
+ - lib/fisk/instructions/vucomisd.rb
1243
+ - lib/fisk/instructions/vucomiss.rb
1244
+ - lib/fisk/instructions/vunpckhpd.rb
1245
+ - lib/fisk/instructions/vunpckhps.rb
1246
+ - lib/fisk/instructions/vunpcklpd.rb
1247
+ - lib/fisk/instructions/vunpcklps.rb
1248
+ - lib/fisk/instructions/vxorpd.rb
1249
+ - lib/fisk/instructions/vxorps.rb
1250
+ - lib/fisk/instructions/vzeroall.rb
1251
+ - lib/fisk/instructions/vzeroupper.rb
1252
+ - lib/fisk/instructions/xadd.rb
1253
+ - lib/fisk/instructions/xchg.rb
1254
+ - lib/fisk/instructions/xgetbv.rb
1255
+ - lib/fisk/instructions/xlatb.rb
1256
+ - lib/fisk/instructions/xor.rb
1257
+ - lib/fisk/instructions/xorpd.rb
1258
+ - lib/fisk/instructions/xorps.rb
31
1259
  - test/helper.rb
32
1260
  - test/test_fisk.rb
33
1261
  - test/test_run_fisk.rb