从英特尔语法转换为& t

时间:2013-10-08 08:56:02

标签: assembly g++ att

我正在尝试将此代码(ARM NEON)从intel转换为& 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'

你知道为什么我会遇到这个问题,或者你能给我一个很好的参考资料吗?我可以用这个参考资料从英特尔翻译到& 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'

0 个答案:

没有答案