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

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]跳轉(zhuǎn)指令B使程序跳轉(zhuǎn)到指定的地址執(zhí)行程序。帶連接的跳轉(zhuǎn)指令BL將下一條指令的地址拷貝到r14(即返回地址連接寄存器LR)寄存器中,然后跳轉(zhuǎn)到指定地址運(yùn)行程序。需要注意的是,這兩條指令和目標(biāo)地址處的指令都要屬于ARM指令集。兩條指令都可以根據(jù)CPSR中的條件標(biāo)志位的值決定指令是否執(zhí)行。

跳轉(zhuǎn)(B)和跳轉(zhuǎn)連接(BL)指令是改變指令執(zhí)行順序的標(biāo)準(zhǔn)方式。ARM一般按照字地址順序執(zhí)行指令,需要時(shí)使用條件執(zhí)行跳過某段指令。只要程序必須偏離順序執(zhí)行,就要使用控制流指令來修改程序計(jì)數(shù)器。盡管在特定情況下還有其他幾種方式實(shí)現(xiàn)這個(gè)目的,但轉(zhuǎn)移和轉(zhuǎn)移連接指令是標(biāo)準(zhǔn)的方式。

跳轉(zhuǎn)指令改變程序的執(zhí)行流程或者調(diào)用子程序。這種指令使得一個(gè)程序可以使用子程序、if-then-else結(jié)構(gòu)以及循環(huán)。執(zhí)行流程的改變迫使程序計(jì)數(shù)器PC指向一個(gè)新的地址,ARMv5架構(gòu)指令集包含的跳轉(zhuǎn)指令如表8.1所示。

表8.1 ARMv5架構(gòu)跳轉(zhuǎn)指令

助記符

說明

操作

B

跳轉(zhuǎn)指令

pc←label

BL

帶返回的連接跳轉(zhuǎn)

pc←label(lr←BL后面的第一條指令)

BX

跳轉(zhuǎn)并切換狀態(tài)

pc←Rm&0xfffffffe,T←Rm&1

BLX

帶返回的跳轉(zhuǎn)并切換狀態(tài)

pc←lable,T←1

pc←Rm&0xfffffffe,T←Rm&1

lr←BL后面的第一條指令

另一種實(shí)現(xiàn)指令跳轉(zhuǎn)的方式是通過直接向PC寄存器中寫入目標(biāo)地址值,實(shí)現(xiàn)在4GB地址空間中任意跳轉(zhuǎn),這種跳轉(zhuǎn)指令又被稱為長跳轉(zhuǎn)。如果在長跳轉(zhuǎn)指令之前使用“MOVLR”或“MOVPC”等指令,可以保存將來返回的地址值,也就實(shí)現(xiàn)了在4GB的地址空間中的子程序調(diào)用。

在ARMv5以前的版本中,傳送到PC寄存器中的目標(biāo)地址值的低兩位bits[1∶0]被忽略,跳轉(zhuǎn)指令只能在ARM指令集中執(zhí)行,即程序不能從ARM狀態(tài)切換到Thumb狀態(tài)。在非T系列版本5的ARM體系不含Thumb指令,當(dāng)程序試圖切換到Thumb狀態(tài)時(shí),將產(chǎn)生未定義指令異常中斷。

在ARMv5以后的版本中,有兩種類型的帶連接的跳轉(zhuǎn)切換指令(BLX),敘述如下。

(1)形式如“BLX<Rm>”,它是一種類似于帶寄存器Rm的BX指令。指令執(zhí)行BX操作,同時(shí)將返回地址放到LR寄存器中。這種形式的帶狀態(tài)切換的跳轉(zhuǎn)連接指令,方便了ARM/Thumb互交的子程序調(diào)用。

(2)另一種類型的BLX指令類似于BL指令,指令使程序跳轉(zhuǎn)到指定地址,并將返回地址保存到LR寄存器中,該指令能夠?qū)崿F(xiàn)32MB地址空間的跳轉(zhuǎn)。與BL指令的不同之處在于它返回到Thumb狀態(tài),而不是ARM狀態(tài)。

8.1跳轉(zhuǎn)指令B及帶連接的跳轉(zhuǎn)指令BL1.指令編碼格式

跳轉(zhuǎn)指令B使程序跳轉(zhuǎn)到指定的地址執(zhí)行程序。帶連接的跳轉(zhuǎn)指令BL將下一條指令的地址拷貝到r14(即返回地址連接寄存器LR)寄存器中,然后跳轉(zhuǎn)到指定地址運(yùn)行程序。需要注意的是,這兩條指令和目標(biāo)地址處的指令都要屬于ARM指令集。兩條指令都可以根據(jù)CPSR中的條件標(biāo)志位的值決定指令是否執(zhí)行。

指令的編碼格式如圖8.1所示。

圖8.1B&BL指令編碼格式

2.指令的語法格式

B{L}{<cond>}<target_address>

①<cond>

為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當(dāng)<cond>忽略時(shí),指令為無條件執(zhí)行(cond=AL(Alway))。

②L

L位(bit[24])=1,指令存儲(chǔ)返回地址到LR;L位(bit[24])=0,指令僅實(shí)現(xiàn)跳轉(zhuǎn),不保存返回指令。

③<target_addrss>

指令跳轉(zhuǎn)的目標(biāo)地址。指令通過下面的方法計(jì)算目標(biāo)地址。

·將24位的立即數(shù)符號(hào)擴(kuò)展為32位。

·將擴(kuò)展后的32位立即數(shù)左移兩位。

·將得到的值加到PC寄存器中,即得到跳轉(zhuǎn)的目標(biāo)地址。

注意

由于以上原因,B和BL指令只能實(shí)現(xiàn)±32MB空間的跳轉(zhuǎn)。

3.指令操作的偽代碼

指令操作的偽代碼如下面程序段所示。

IfconditionPassed{cond}then

IfL==1then

LR=addressoftheinstructionafterthebranchinstruftion

PC=PC+(SignExtend(signed_immed_24)<<2)

4.指令的使用

BL指令用于實(shí)現(xiàn)子程序調(diào)用。子程序的返回可以通過將LR寄存器的值復(fù)制到PC寄存器來實(shí)現(xiàn)。下面三種指令可以實(shí)現(xiàn)子程序返回。

·BXr14(如果體系結(jié)構(gòu)支持BX指令)。

·MOVPC,r14。

·當(dāng)子程序在入口處使用了壓棧指令:

STMFDr13!,{<registers>,r14},

可以使用指令。

LDMFDr13!,{<registers>,PC}

將子程序返回地址放入PC中。

ARM匯編器通過以下步驟計(jì)算指令編碼中的signed_immed_24。

(1)將PC寄存器的值作為本跳轉(zhuǎn)指令的基地址值。

(2)從跳轉(zhuǎn)的目標(biāo)地址中減去上面所說的跳轉(zhuǎn)的基地址,生成字節(jié)偏移量。由于ARM指令是字對齊的,該字節(jié)偏移量為4的倍數(shù)。

(3)當(dāng)上面生成的字節(jié)偏移量超過-33554432~+33554430時(shí),不同的匯編器使用不同的代碼產(chǎn)生策略。

(4)否則,將指令編碼字中的signed_immed_24設(shè)置成上述字節(jié)偏移量的bits[25∶2]。

注意

在一些RISC體系結(jié)構(gòu)的處理器中,存在延時(shí)跳轉(zhuǎn)(delayedbranch)模式,即在程序執(zhí)行跳轉(zhuǎn)指令跳轉(zhuǎn)到目標(biāo)地址之前,程序會(huì)執(zhí)行跳轉(zhuǎn)指令之后的指令。但在ARM體系中,沒有這種延時(shí)跳轉(zhuǎn)機(jī)制。

5.指令舉例

(1)程序跳轉(zhuǎn)到LABLE標(biāo)號(hào)處。

BLABLE;

ADDr1,r2,#4

ADDr3,r2,#8

SUBr3,r3,r1

LABLE

SUBr1,r2,#8

(2)跳轉(zhuǎn)到絕對地址0x1234處。

B0x1234

(3)跳轉(zhuǎn)到子程序func處執(zhí)行,同時(shí)將當(dāng)前PC值保存到LR中。

BLfunc

(4)條件跳轉(zhuǎn):當(dāng)CPSR寄存器中的C條件標(biāo)志位為1時(shí),程序跳轉(zhuǎn)到標(biāo)號(hào)LABLE處執(zhí)行。

BCCLABLE

(5)通過跳轉(zhuǎn)指令建立一個(gè)無限循環(huán)。

LOOP

ADDr1,r2,#4

ADDr3,r2,#8

SUBr3,r3,r1

BLOOP

(6)通過使用跳轉(zhuǎn)使程序體循環(huán)10次。

MOVr0,#10

LOOP

SUBSr0,#1

BNELOOP

(7)條件子程序調(diào)用示例。

……

CMPr0,#5;如果r0<5

BLLTSUB1;則調(diào)用

BLGESUB2;否則調(diào)用SUB2

注意

只有SUB1不改變條件碼,本例才能正確執(zhí)行,因?yàn)槿绻鸅LLT執(zhí)行了轉(zhuǎn)移,將返回到BLGE指令。如果條件碼被SUB1子程序改變,則SUB2可能又會(huì)被執(zhí)行,從而達(dá)不到指令的預(yù)期效果。

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

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉