卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章33909本站已运行390

如何从指令字节中获取相关的指令代码?

如何从指令字节中获取相关的指令代码?

问题内容

当我运行包含一些 Go 汇编代码的 Go 程序时,收到以下错误消息:

SIGILL: illegal instruction
PC=0x508c04 m=0 sigcode=2
instruction bytes: 0xc4 0x42 0x68 0xf2 0xea 0xc5 0xf9 0xef 0xc1 0x41 0x9 0xfd 0x45 0x1 0xee 0xc1

如何从指令字节中获取相关的指令代码?我尝试了 https://github.com/golang/arch Decode 方法,但我只得到了操作码 0。

从第一个字节0xc4开始,应该是VEX前缀。

CPU:Intel(R) Xeon(R) CPU E5-2620)

操作系统:Linux


正确答案


这是 ANDN,它是 BMI1 指令集的一部分。在英特尔上,Haswell 及更新版本支持 BMI1,但您的芯片是 Sandy Bridge,它太旧了一代(或两代,取决于您如何计算)。

卓越飞翔博客
上一篇: 共享变量和线程.Lock
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏