arm32?arm处理器是什么
一、32是arm吗
这说明光遇只有64位版本,ARM32位是指你的手机处理器的位宽,你的手机每次最多只能处理数据宽度为32位的指令
而64位的程序使用的指令宽度是64位的,从原理上来讲,你的手机没有能力处理64位的程序,显然以你的手机的能力,根本无法运行这个游戏
很可惜,这个唯一的解决办法就是官方出32位的游戏程序,或者换一个64位处理器的手机
二、arm中mov和mov32的区别
1、两者含义不同
Mov只能在寄存器之间移动数据,或将立即数移到寄存器中。x86中没有LDR指令,因为x86的MOV指令可以将数据从内存移动到寄存器,但也有LDR伪指令。
尽管LDR伪指令与arm的LDR指令非常相似,但它们具有不同的功能,LDR伪指令可以在immediate之前加=来指示地址已写入寄存器。
2、两者功能不同
Mov为寄存器分配立即数,但需要立即数范围,它只能是8位连续有效位通过偶数移位得到的数。如果立即数超出此范围,则无法使用MOV指令将值赋给寄存器,除了普通的读数外,LDR还具有给寄存器分配立即数的功能。
1、LDR指令
LDR指令的格式为:LDR{条件}目的寄存器,<存储器地址>
LDR指令用于从存储器中将一个32位的字数据传送到目的寄存器中。该指令通常用于从存储器中读取32位的字数据到通用寄存器,然后对数据进行处理。
当程序计数器PC作为目的寄存器时,指令从存储器中读取的字数据被当作目的地址,从而可以实现程序流程的跳转。该指令在程序设计中比较常用,且寻址方式灵活多样。
指令示例:
LDRR0,[R1];将存储器地址为R1的字数据读入寄存器R0。
LDRR0,[R1,R2];将存储器地址为R1+R2的字数据读入寄存器R0。
LDRR0,[R1,#8];将存储器地址为R1+8的字数据读入寄存器R0。
LDRR0,[R1,R2]!;将存储器地址为R1+R2的字数据读入寄存器R0,并将新地址R1+R2写入R1。
LDRR0,[R1,#8]!;将存储器地址为R1+8的字数据读入寄存器R0,并将新地址R1+8写入R1。
LDRR0,[R1],R2;将存储器地址为R1的字数据读入寄存器R0,并将新地址R1+R2写入R1。
LDRR0,[R1,R2,LSL#2]!;将存储器地址为R1+R2×4的字数据读入寄存器R0,并将新地址R1+R2×4写入R1。
LDRR0,[R1],R2,LSL#2;将存储器地址为R1的字数据读入寄存器R0,并将新地址R1+R2×4写入R1。
2、MOV指令
MOV数据传送指令格式:MOV{<cond>}{S}<Rd>,<op1>;
功能:Rd=op1
op1可以是寄存器、被移位的寄存器或立即数。
例如:
MOVR0,#5;R0=5
MOVR0,R1;R0=R1
MOVR0,R1,LSL#5;R0=R1左移5位
三、armv8 中64位与32位切换
ARM架构文档有详细的描述。简单来说,32和64并不是随意混用的,是基于EL级别的,每个EL切换时可以选择32或者64。例如64的HYP,在之上可以独立运行32的guestOS和64的guestOS。记得差不多是这样。