首页系统arm32?arm处理器是什么

arm32?arm处理器是什么

编程之家2024-04-0212次浏览

一、32是arm吗

这说明光遇只有64位版本,ARM32位是指你的手机处理器的位宽,你的手机每次最多只能处理数据宽度为32位的指令

arm32?arm处理器是什么

而64位的程序使用的指令宽度是64位的,从原理上来讲,你的手机没有能力处理64位的程序,显然以你的手机的能力,根本无法运行这个游戏

很可惜,这个唯一的解决办法就是官方出32位的游戏程序,或者换一个64位处理器的手机

二、arm中mov和mov32的区别

1、两者含义不同

Mov只能在寄存器之间移动数据,或将立即数移到寄存器中。x86中没有LDR指令,因为x86的MOV指令可以将数据从内存移动到寄存器,但也有LDR伪指令。

尽管LDR伪指令与arm的LDR指令非常相似,但它们具有不同的功能,LDR伪指令可以在immediate之前加=来指示地址已写入寄存器。

2、两者功能不同

arm32?arm处理器是什么

Mov为寄存器分配立即数,但需要立即数范围,它只能是8位连续有效位通过偶数移位得到的数。如果立即数超出此范围,则无法使用MOV指令将值赋给寄存器,除了普通的读数外,LDR还具有给寄存器分配立即数的功能。

1、LDR指令

LDR指令的格式为:LDR{条件}目的寄存器,<存储器地址>

LDR指令用于从存储器中将一个32位的字数据传送到目的寄存器中。该指令通常用于从存储器中读取32位的字数据到通用寄存器,然后对数据进行处理。

当程序计数器PC作为目的寄存器时,指令从存储器中读取的字数据被当作目的地址,从而可以实现程序流程的跳转。该指令在程序设计中比较常用,且寻址方式灵活多样。

指令示例:

arm32?arm处理器是什么

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。记得差不多是这样。

js代码格式化,编程代码格式错了怎么改正诺基亚e65(诺基亚e65好不好用)