1

我正在使用符号扩展将 32 位变量更改为 64 位变量。但是,当我在 64 位变量上使用逻辑左移时,它会丢失位,就好像它仍然是 32 位一样。

我希望最终能够将所有内容从我的原始变量转移到 64 位变量的上侧。(0xFFFFFFFF00000000 是我期待的结果)

下面的代码显示了 8 位的移位,以演示丢失的位:

str_fmt:.string "\nWord Value: 0x%08x \nWord Extended to 64-bit: 0x%016x\nLSL: 0x%016x\n\n"

        .balign 4   
        .global main    

main:   stp     x29, x30, [sp, -16]!    
        mov     x29, sp         

        mov     w19, 0xFFFFFFFF
        sxtw    x20, w19

        lsl     x21, x20, 8

results:
        adrp    x0, str_fmt     
        add     x0, x0, :lo12:str_fmt
        mov     w1, w19             
        mov     x2, x20
        mov     x3, x21
        bl      printf

done:   ldp     x29, x30, [sp], 16  
        ret 

输出如下:

字值:0xffffffff 字扩展为 64 位:0x00000000ffffffff LSL:0x00000000ffffff00

我的代码中缺少什么以允许逻辑左移导致 0xFFFFFFFF00000000?

4

1 回答 1

2

x格式说明符在我知道的 ARM ABI 上打印一个unsigned32 位类型的参数。这会导致printf忽略参数的高 32 位。用于llx打印long long unsigned参数;long long unsigned至少是 64 位类型。

于 2017-10-12T19:57:16.130 回答