【问题标题】:Assembly unknown mnemonic AArch64 ARMv8汇编未知助记符 AArch64 ARMv8
【发布时间】:2015-05-27 07:52:42
【问题描述】:

我正在尝试使用几个针对 ARMv8 AArch64 架构编写的程序集文件来编译一个项目(来自 GitHub:link)。当我尝试编译这些文件时,几乎每一行都会出现相同的错误,它的开头是:

authenc_ac_gcm_low.S:汇编器消息:

authenc_ac_gcm_low.S:80: Error: unknown mnemonic `ld1.16b' -- `ld1.16b {v0},[x1]'
authenc_ac_gcm_low.S:81: Error: unknown mnemonic `rbit.16b' -- `rbit.16b v0,v0'
authenc_ac_gcm_low.S:82: Error: unknown mnemonic `st1.16b' -- `st1.16b {v0},[x0]'
authenc_ac_gcm_low.S:90: Error: unknown mnemonic `ld1.16b' -- `ld1.16b {v24},[x0]'
authenc_ac_gcm_low.S:92: Error: unknown mnemonic `ld1.16b' -- `ld1.16b {v0,v1,v2,v3},[x1],#64'
authenc_ac_gcm_low.S:93: Error: unknown mnemonic `ld1.16b' -- `ld1.16b {v4,v5,v6,v7},[x1]'

一小部分代码:(第 78 到 87 行)

ac_gcm_convert_low:
_ac_gcm_convert_low:
    ld1.16b {v0}, [x1]
    rbit.16b v0, v0
    st1.16b {v0}, [x0]
    ret

ac_gcm_ghash_low:
_ac_gcm_ghash_low:
    cbz x3, exit //this might be the only line it doesn't error

我正在为 AArch64 使用 Linaro 交叉编译器,我使用 -mcpu=cortex-a53+crypto 标志进行编译;不这样做会导致“没有这样的指令”错误。 我对组装的经验很少,显然我在这里犯了一些错误,但我找不到。如何摆脱错误?

【问题讨论】:

  • 我见过不同的汇编程序对 neon 指令的助记符略有不同。如果“ld1.16b {v0},[x1]”不起作用,请尝试“ld1 {v0.16b},[x1]”

标签: gcc assembly cross-compiling arm64


【解决方案1】:

看起来那是古怪的 Apple 语法 - GCC 使用稍微详细一点的 architectural syntax,其中大小说明符出现在每个寄存器参数上,而不是指令本身,例如

ld1 {v0.16b}, [x1]
rbit v0.16b, v0.16b
st1 {v0.16b}, [x0]

我不相信 AArch64 binutils 有任何方式支持 Apple 语法,所以我认为可用的解决方案仅限于“手动修复代码”或“改用 Clang/LLVM”。

【讨论】:

  • 是的,就是这样,永远不会注意到这一点。谢谢!
猜你喜欢
  • 2022-12-09
  • 1970-01-01
  • 1970-01-01
  • 2016-05-05
  • 1970-01-01
  • 2013-09-16
  • 2018-01-19
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多