www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]ARM的9種尋址方式1)立即尋址操作數(shù)是立即數(shù),以“#”為前綴,表示 16 進(jìn)制數(shù)值時以“0x”表示。例:MOV R0,#0xFF00 ;0xFF00 -> R0SUBS R0,R0,#1 ;R0 – 1 -> R02)寄存器尋址操作數(shù)的值在寄存器中,指令執(zhí)行時直接取

ARM的9種尋址方式

1)立即尋址

操作數(shù)是立即數(shù),以“#”為前綴,表示 16 進(jìn)制數(shù)值時以“0x”表示。

例:

MOV R0,#0xFF00 ;0xFF00 -> R0

SUBS R0,R0,#1 ;R0 – 1 -> R0

2)寄存器尋址

操作數(shù)的值在寄存器中,指令執(zhí)行時直接取出寄存器值操作。

例:

MOV R1,R2 ;R2 -> R1

SUB R0,R1,R2 ;R1 - R2 -> R0

3)寄存器偏移尋址

當(dāng)?shù)诙僮鲾?shù)是寄存器偏移方式時,第二個寄存器操作數(shù)在與第一個操作數(shù)結(jié)合之前,選擇進(jìn)行移位操作。

例:

MOV R0,R2,LSL #3 ;R2 的值左移 3 位,結(jié)果放入 R0,即 R0 = R2 * 8

ANDS R1,R1,R2,LSL #3 ;R2 的值左移 3 位,然后和 R1 相與操作,結(jié)果放入 R1

可采用的移位操作:

LSL:邏輯左移(Logical Shift Left),低端空出位補(bǔ) 0

LSR:邏輯右移(Logical Shift Right),高端空出位補(bǔ) 0

ASR:算術(shù)右移(Arithmetic Shift Right),移位過程中符號位不變,即源操作數(shù)為正數(shù),則高端空出位補(bǔ) 0,否則補(bǔ) 1

ROR:循環(huán)右移(Rotate Right),由低端移出位填入高端空出位

RRX:帶擴(kuò)展的循環(huán)右移(Rotate Right eXtended by 1 place),操作數(shù)右移一位,高端空出位用原 C 標(biāo)志值填充。

4)寄存器間接尋址

操作數(shù)保存在寄存器指定地址的存儲單元中,即寄存器為操作數(shù)的地址指針。

例:

LDR R1,[R2] ;將 R2 中的數(shù)值作為地址,取出此地址中的數(shù)據(jù)保存在 R1 中

SWP R1,R1,[R2] ;將R2中的數(shù)值作為地址,取出此地址中的數(shù)值與 R1 中的值**

5)基址尋址

將基址寄存器的值與偏移量相加,形成操作數(shù)的有效地址,基址尋址用于訪問基址附近的存儲單元,常用于查表、數(shù)組操作、功能寄存器訪問等。

例:

LDR R2,[R3,#0x0F] ;將R3中的數(shù)值加 0x0F 作為地址,取此地址的值保存在 R2 中

STR R1,[R0,#-2] ;將R0中的數(shù)值減 2 作為地址,把 R1的值保存到此地址中

6)多寄存器尋址

一次傳送多個寄存器值,允許一條指令傳送 16 個寄存器的任何子集或所有寄存器。多寄存器尋址時,寄存器子集按由小到大的順序排列,連續(xù)的寄存器可用“-”連接,否則,用“,”分隔書寫。

例:

LDMIA R1!,{R2-R7,R12} ;將 R1的值讀出到 R2-R7,R12,過程中R1 自動加 1

STMIA R0!,{R3-R6,R10};將 R3-R6,R10的值保存到 R0 指向的地址,過程中R0 自動加 1

7)堆棧尋址

堆棧尋址使用堆棧指針SP,即R13,指向堆棧的棧頂。堆??煞譃閮煞N:

向上生長:向高地址方向生長,稱為遞增堆棧,

向下生長:向低地址方向生長,稱為遞減堆棧,

堆棧指針指向最后壓入的有效數(shù)據(jù)項,稱為滿堆棧,

堆棧指針指向下一個要放入的空位置,稱為空堆棧,這樣就有 4 種類型的堆棧。

A)滿遞增:堆棧地址向上增長,堆棧指針指向有效數(shù)據(jù)的最高地址。如 LDMFA,STMFA。

B)空遞增:堆棧地址向上增長,堆棧指針指向堆棧上的第一個空位置。如 LDMEA,STMEA 。

C)滿遞減:堆棧地址向下增長,堆棧指針指向有效數(shù)據(jù)項的最低地址。如 LDMFD,STMFD。

D)空遞減:堆棧地址向下增長,堆棧指針指向堆棧下的第一個空位置。如 LDMED,STMED 。

例:

STMFD SP!,{R1-R7,LR} ; 將 R1~R7,LR 入棧。滿遞減堆棧。

LDMFD SP!,{R1-R7,LR} ;數(shù)據(jù)出棧,放入 R1~R7,LR 寄存器。滿遞減堆棧。

8)塊拷貝尋址

用于將一塊數(shù)據(jù)從存儲器的某一位置拷貝到另一位置。

例:

STMIA R0!,{R1-R7} ;將R1~R7的數(shù)據(jù)保存到存儲器中,存儲器指針在保存第一個值之后增加,增長方向為向上增長。

STMIB R0!,{R1-R7} ;將R1~R7的數(shù)據(jù)保存到存儲器中,存儲器指針在保存第一個值之前增加,增長方向為向上增長。

STMDA R0!,{R1-R7} ;將R1~R7的數(shù)據(jù)保存到存儲器中,存儲器指針在保存第一個值之后增加,增長方向為向下增長。

STMDB R0!,{R1-R7} ;將R1~R7的數(shù)據(jù)保存到存儲器中,存儲器指針在保存第一個值之前增加,增長方向為向下增長。

9)相對尋址

相對尋址是基址尋址的一種變通,由程序計數(shù)器 PC 提供基準(zhǔn)地址,指令中的地址

碼字段作為偏移量,兩者相加后得到有效地址。

例:

BL ROUTE1 ;調(diào)用ROUTE1 子程序

BEQ LOOP ;條件跳轉(zhuǎn)到 LOOP 標(biāo)號處

LOOP MOV R2,#2

ROUTE1


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

ARM系統(tǒng)幾乎都采用Linux的操作系統(tǒng),而且?guī)缀跛械挠布到y(tǒng)都要單獨(dú)構(gòu)建自己的系統(tǒng),與其他系統(tǒng)不能兼容,這也導(dǎo)致其應(yīng)用軟件不能方便移植,這一點(diǎn)一直嚴(yán)重制約了ARM系統(tǒng)的發(fā)展和應(yīng)用。GOOGLE開發(fā)了開放式的Andro...

關(guān)鍵字: Linux x86 ARM

隨著計算需求的多樣化,尤其是隨著移動設(shè)備、嵌入式系統(tǒng)和云計算的興起,ARM 和 x86 架構(gòu)之間的爭論變得更加突出。ARM(高級 RISC 機(jī)器)和 x86 代表兩種不同類型的處理器架構(gòu),每種架構(gòu)都針對不同的工作負(fù)載和用...

關(guān)鍵字: Linux x86 ARM

從畫質(zhì)優(yōu)化 (NSS) 到幀率提升 (NFRU) 和光線追蹤(NSSD),Arm 計劃覆蓋移動端圖形處理的多個維度,推動邊緣 AI 圖形革命。而未來通過持續(xù)的技術(shù)迭代,Arm也將保持在移動計算領(lǐng)域的技術(shù)領(lǐng)先,滿足手游、A...

關(guān)鍵字: ARM 神經(jīng)圖形技術(shù) GPU AI ML

7月31日消息,據(jù)媒體報道,芯片架構(gòu)提供商Arm Holdings首席執(zhí)行官Rene Haas宣布,公司正加大投入開發(fā)自有芯片產(chǎn)品,此舉標(biāo)志著其從傳統(tǒng)IP授權(quán)模式向提供實體芯片的戰(zhàn)略重大轉(zhuǎn)變。

關(guān)鍵字: ARM META

7月28日消息,2025年,中國AI硬件市場規(guī)模將首次突破萬億元大關(guān)。

關(guān)鍵字: AI ARM

受生成式 AI 驅(qū)動, RISC-V 芯片市場快速發(fā)展。預(yù)計到2030年,RISC-V SoC出貨量將達(dá)到1618.1億顆,營收將達(dá)到927億美元。其中,用于AI加速器的RISC-V SoC出貨量將達(dá)到41億顆,營收將達(dá)...

關(guān)鍵字: RISC-V CPU AI CUDA ARM 推理
關(guān)閉