asm中未知的寄存器名称“q0”(arm64)

时间:2013-11-14 17:26:18

标签: ios llvm xcode5 neon arm64

我目前正在尝试为新的arm64 arch编译我的lib。我有一堆NEON程序集,对于所有这些我收到错误

  

asm中的未知寄存器名称“q0”。

即使我像这样简单地写smth:

asm (
     ""
     :
     :
     : "q0", "q1", "q2", "q3"
     );

我认为arm64支持NEON。我错过了什么吗?

1 个答案:

答案 0 :(得分:4)

“V0”:

scanon$ cat bar.c
int foo(void) {
  __asm__("":::"q0");
  return 0;
}
scanon$ xcrun -sdk iphoneos clang bar.c -arch arm64 -c
bar.c:2:16: error: unknown register name 'q0' in asm
  __asm__("":::"q0");
               ^
1 error generated.
scanon$ cat foo.c
int foo(void) {
  __asm__("":::"v0");
  return 0;
}
scanon$ xcrun -sdk iphoneos clang foo.c -arch arm64 -c
scanon$

arm64是一个新的ISA。实际的NEON指令和寄存器布局是全新的。您需要重新编写或调整新架构的汇编代码。