我试图弄清楚jp
/ jnp
指令在LLVM生成的C代码中的用途。样品:
int main(int argc, const char * argv[]) {
double value = 1.5;
if (value == 1.5) {
value = 3.0;
}
return 0;
}
装配输出:
Ltmp4:
movsd LCPI0_0(%rip), %xmm0
movl $0, -4(%rbp)
movl %edi, -8(%rbp)
movq %rsi, -16(%rbp)
Ltmp5:
movsd %xmm0, -24(%rbp)
Ltmp6:
movsd -24(%rbp), %xmm1
ucomisd %xmm0, %xmm1
jne LBB0_2
jp LBB0_2
## BB#1:
movabsq $3, %rax
cvtsi2sdq %rax, %xmm0
Ltmp7:
movsd %xmm0, -24(%rbp)
Ltmp8:
LBB0_2:
movl $0, %eax
popq %rbp
retq
jne
正在检查是否value != 1.5
并跳过作业,但jp
在此背景下做了什么?
答案 0 :(得分:12)
jne
为jump if not equal
,即如果未设置零标志则跳转。 jp
为jump if parity
。
ucomisd
定义为比较两个doubles
。它表明它们是四个方面之一:无序,相等,大于或小于。
如果数字无序或相等,则设置零标志。因此jne
避免了大于或小于的剩余案例。
仅在结果无序时才设置奇偶校验。 jp
抓住了这个。
所以两者一起避免:无序,大于,小于。只留下第四种可能性,相等。