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

问题描述 投票:0回答:1

当我运行包含一些 go asm 代码的 golang 程序时,出现以下错误消息:

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解码方法,但我只得到了操作码0。

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

CPU:Intel(R) Xeon(R) CPU E5-2620)
操作系统:Linux

go assembly x86-64
1个回答
0
投票

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

© www.soinside.com 2019 - 2024. All rights reserved.