打印Java热点JIT汇编代码
作者:互联网
我在Java中编写了一个非常愚蠢的测试类:
public class Vector3 {
public double x,y,z ;
public Vector3(double x, double y, double z) {
this.x=x ; this.y=y ; this.z=z ;
}
public Vector3 subst(Vector3 v) {
return new Vector3(x-v.x,y-v.y,z-v.z) ;
}
}
然后我想看看Java Hotspot JIT(Client VM build 23.7-b01)生成的代码.我使用了“-XX:PrintAssembly”选项和http://classparser.blogspot.dk/2010/03/hsdis-i386dll.html的hsdis-i386.dll
这是生成代码的有趣部分(我已经跳过了新对象的初始化.编辑:subst方法的代码).显然,ebx是“this”指针,而edx是指向参数的指针.
lds edi,(bad)
sti
adc BYTE PTR [ebx+8],al ;*getfield x
mov edx,DWORD PTR [esp+56]
lds edi,(bad) ; implicit exception: dispatches to 0x02611f2d
sti
adc BYTE PTR [edx+8],cl ;*getfield x
lds edi,(bad)
sti
adc BYTE PTR [ebx+16],dl ;*getfield y
lds edi,(bad)
sti
adc BYTE PTR [edx+16],bl ;*getfield y
lds edi,(bad)
sti
adc BYTE PTR [ebx+24],ah ;*getfield z
lds edi,(bad)
sti
adc BYTE PTR [edx+24],ch ;*getfield z
lds edi,(bad)
sti
pop esp
rol ebp,0xfb
adc DWORD PTR [eax+8],eax ;*putfield x
lds ebp,(bad)
jmp 0x02611f66
rol ebp,cl
sti
adc DWORD PTR [eax+16],edx ;*putfield y
lds ebx,(bad)
fistp DWORD PTR [ebp-59]
sti
adc DWORD PTR [eax+24],esp ;*putfield z
老实说,我对x86汇编并不熟悉,但这些代码对你有意义吗?那些奇怪的指令是什么,比如“adc BYTE PTR [edx 8],cl”在做什么?我本来期待一些FPU指令.
解决方法:
又是我.我使用最新的binutils 2.23构建了hsdis-i386.dll.由于http://dropzone.nfshost.com/hsdis.htm中的说明,它比我预期的要容易
(至少对于x86版本.64位版本编译但立即停止JVM而没有任何错误消息)
输出现在看起来好多了:
vmovsd xmm0,QWORD PTR [ebx+0x8] ;*getfield x
mov edx,DWORD PTR [esp+0x40]
vmovsd xmm1,QWORD PTR [edx+0x8] ;*getfield x
vmovsd xmm2,QWORD PTR [ebx+0x10] ;*getfield y
vmovsd xmm3,QWORD PTR [edx+0x10] ;*getfield y
vmovsd xmm4,QWORD PTR [ebx+0x18] ;*getfield z
vmovsd xmm5,QWORD PTR [edx+0x18] ;*getfield z
vsubsd xmm0,xmm0,xmm1
vmovsd QWORD PTR [eax+0x8],xmm0 ;*putfield x
vsubsd xmm2,xmm2,xmm3
vmovsd QWORD PTR [eax+0x10],xmm2 ;*putfield y
vsubsd xmm4,xmm4,xmm5
vmovsd QWORD PTR [eax+0x18],xmm4 ;*putfield z
标签:java,assembly,jvm-hotspot,jit,disassembly 来源: https://codeday.me/bug/20190517/1122925.html