0

我正在尝试将此代码(ARM NEON)从 intel 转换为 at&t 语法:

AREA    BRISK_ASM_NEON, CODE, READNOLY
    EXPORT  Function
    CODE32

Function    FUNCTION

loop
    pld     [r0, #192]
    vld2.32     {q8, q9}, [r0]!
    vld2.32     {q10, q11}, [r0]!
    pld     [r0, #192]
    vld2.32     {q12, q13}, [r0]!
    vld2.32     {q14, q15}, [r0]!

vcgt.u32    q8, q8, q9
vcgt.u32    q9, q10, q11
vcgt.u32    q10, q12, q13
vcgt.u32    q11, q14, q15

pld     [r0, #192]
vld2.32     {q12, q13}, [r0]!
vld2.32     {q14, q15}, [r0]!
pld     [r0, #192]
vld2.32     {q0, q1}, [r0]!
vld2.32     {q2, q3}, [r0]!

vcgt.u32    q12, q12, q13
vcgt.u32    q13, q14, q15
vcgt.u32    q14, q0, q1
vcgt.u32    q15, q2, q3

vsli.32     q8, q10, #8
vsli.32     q9, q11, #8
vsli.32     q8, q12, #16
vsli.32     q9, q13, #16
vsli.32     q8, q14, #24
vsli.32     q9, q15, #24

vsli.8      d16, d17, #2
vsli.8      d18, d19, #2
vsli.8      d16, d18, #4

vbic.i8     d16, #0xaa
vshr.u64    d17, d16, #31
vorr        d16, d16, d17

vst1.32     {d16[0]}, [r1]!

subs        r2, r2, #32
bgt     loop

bx  lr

ENDFUNC
END

我正在用 g++ 编译。我发现这可以在编译时通过添加指令 *.intel_syntax* 来完成,但如果我这样做了,我会从编译器获得这条消息:

Error: unknown pseudo-op: `.intel_syntax'.

我也尝试在编译时添加 -masm=intel 但我得到:

g++: error: unrecognized command line option '-masm=intel'

你知道我为什么会遇到这个问题,或者你能给我一个很好的参考资料,我可以用它来从 intel 翻译成 at&t 吗?谢谢你。

编辑:我这样更正了

.globl function

function:

loop:
    pld     [r0, #192]
    vld2.32     {q8, q9}, [r0]!
    vld2.32     {q10, q11}, [r0]!
    pld     [r0, #192]
    vld2.32     {q12, q13}, [r0]!
    vld2.32     {q14, q15}, [r0]!

    vcgt.u32    q8, q8, q9
    vcgt.u32    q9, q10, q11
    vcgt.u32    q10, q12, q13
    vcgt.u32    q11, q14, q15

    pld     [r0, #192]
    vld2.32     {q12, q13}, [r0]!
    vld2.32     {q14, q15}, [r0]!
    pld     [r0, #192]
    vld2.32     {q0, q1}, [r0]!
    vld2.32     {q2, q3}, [r0]!

    vcgt.u32    q12, q12, q13
    vcgt.u32    q13, q14, q15
    vcgt.u32    q14, q0, q1
    vcgt.u32    q15, q2, q3

    vsli.32     q8, q10, #8
    vsli.32     q9, q11, #8
    vsli.32     q8, q12, #16
    vsli.32     q9, q13, #16
    vsli.32     q8, q14, #24
    vsli.32     q9, q15, #24

    vsli.8      d16, d17, #2
    vsli.8      d18, d19, #2
    vsli.8      d16, d18, #4

    vbic.i8     d16, 10101010
    vshr.u64    d17, d16, #31
    vorr        d16, d16, d17

    vst1.32     {d16[0]}, [r1]!

    subs        r2, r2, #32
    bgt     loop

    bx  lr

现在它编译得很好,除了这个错误:

Error: immediate value out of range -- `vbic.i8 d16,#0xaa'
4

0 回答 0