开发者

convert x86 asm code to arm code on iOS

开发者 https://www.devze.com 2023-04-03 20:42 出处:网络
Can anyone help me convert following x86 inline asm code to arm format? 开发者_运维知识库bool N_FLAG = 0;

Can anyone help me convert following x86 inline asm code to arm format?

开发者_运维知识库
bool N_FLAG = 0;
bool C_FLAG = 0;
bool Z_FLAG = 0;
bool V_FLAG = 0;

asm  ("sub %1, %%ebx;"\
"setsb N_FLAG;"\
"setzb Z_FLAG;"\
"setncb C_FLAG;"\
"setob V_FLAG;"\
: "=b" (reg[dest].I)\
: "r" (reg[base].I), "b" (value));


How about converting this into C?

It looks like the code subtracts two numbers (value - reg[base].I), stores the result into reg[dest].I and then checks the various flags.

So something (roughly, not tested) like:

reg[dest].I = value - reg[base].I;
Z_FLAG = (reg[dest].I == 0);
N_FLAG = (reg[dest].I < 0);
/* repeat for: carry, overflow */

And then let the compiler do its magic? The ARM gcc compiler is not bad in mapping this sort of stuff to the right ARM instructions.

If you want to go ARM assembly you're probably looking at using conditional move instructions, something like (wrote quickly - untested):

__asm__ (
"subs %[out], %[in2], %[in1]\n\t"
"movmi %[N_FLAG], #1\n\t"
"moveq %[Z_FLAG], #1\n\t"
"movcs %[C_FLAG], #1\n\t"
"movvs %[V_FLAG], #1\n\t"
: [N_FLAG]"+r"(N_FLAG), [Z_FLAG]"+r"(Z_FLAG), [C_FLAG]"+r"(C_FLAG), [V_FLAG]"+r"(V_FLAG), [out]"=r" (reg[dest].I)
: [in1]"r" (reg[base].I), [in2]"r"(value))
: "cc"
);


This code works for me using clang:

int sub(int a, int b)
{
  int c;
  asm ("sub %0, %2, %1" : "=r" (c) : "r" (b), "r" (a));
  return c;
}

Notice the commas between the register arguments.

0

精彩评论

暂无评论...
验证码 换一张
取 消