ARM base instruction -- movz


Move wide with zero moves an optionally-shifted 16-bit immediate value to a register.

用零移动宽值将可选移位的16位即时值移动到寄存器。即把立即数移动寄存器前先把寄存器清零。


32-bit variant
    MOVZ <Wd>, #<imm>{, LSL #<shift>}

64-bit variant
    MOVZ <Xd>, #<imm>{, LSL #<shift>}


Operation
    bits(datasize) result; 
    result = Zeros(); 
    result<pos+15:pos> = imm16; 
    X[d] = result; 


/* msg.s */

        .data
msg:
        .ascii "hello asm!\n"
len = . - msg

        .text
        .global _start

_start:
        movz x8, #64
        movz x0, #0
        ldr x1, =msg
        ldr x2, =len
        #movz x2, #13
        svc #0


# aarch64-linux-gcc msg.s -o msg -nostdlib  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值