不知你在DEBUG程序,又或者閱讀操作系統(tǒng)源碼時(shí)候有沒細(xì)心觀察,從一個(gè)普通子函數(shù)返回與異常(中斷)返回的匯編指令都是BX LR,但是這兩者的意義是一樣的嗎?這篇文章就來揭開LR寄存器的神秘面紗。
當(dāng)單片機(jī)涉及函數(shù)跳轉(zhuǎn)或者任務(wù)調(diào)度的時(shí)候,理解MCU如何處理堆棧與改變各個(gè)通用寄存器的狀態(tài)尤為重要,下面就來比較一下在不同情況下LR寄存器的意義。
上圖是一個(gè)簡單的例子,當(dāng)仿真點(diǎn)擊“下一步”的時(shí)候,MCU就會(huì)執(zhí)行BX LR指令,并且從aa子函數(shù)返回到main函數(shù)中,可以看到在普通子函數(shù)里執(zhí)行BX LR的意義是“跳轉(zhuǎn)到LR寄存器里的地址執(zhí)行”。
對比一下一段ucos的源碼,如果對M3內(nèi)核有所了解的小伙伴一定知道堆棧為什么是這樣定義的,那么這時(shí)候我們發(fā)現(xiàn)OS_TaskReturn是作為一個(gè)錯(cuò)誤返回函數(shù),并且賦值到堆棧中R14(LR)相應(yīng)的位置。
任務(wù)調(diào)度函數(shù)會(huì)將PSP堆棧指針指向我們定義自定義的堆棧,然后最后一句匯編是BX LR,那么按照普通子函數(shù)執(zhí)行BX LR的意義,這個(gè)時(shí)候MCU是會(huì)運(yùn)行OS_TaskReturn這個(gè)函數(shù)嗎?這樣不就進(jìn)入錯(cuò)誤函數(shù)了嗎?
其實(shí)不然,因?yàn)橛肕系列實(shí)現(xiàn)ucos的任務(wù)調(diào)度是在PendSV異常(中斷)里面實(shí)現(xiàn)的,而在異常(中斷)里的LR寄存器不再是普通函數(shù)里面“返回地址”的意義,而是一個(gè)定義為一個(gè)稱作exc-return的值,當(dāng)執(zhí)行BX LR時(shí)候,這個(gè)值決定了MCU退出異常(中斷)之后的運(yùn)行等級是在特權(quán)級還是用戶級以及用的堆棧是MSP還是PSP,而MCU即將要執(zhí)行的是從PSP堆棧中POP出來的p_task函數(shù),而不是OS_TaskReturn函數(shù)。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
原文標(biāo)題:神秘的LR寄存器
文章出處:【微信號:Zlgmcu7890,微信公眾號:周立功單片機(jī)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
相關(guān)推薦
本文主要介紹Matlab如何實(shí)現(xiàn)移位寄存器,首先介紹的是移位寄存器的原理及作用,其次介紹了m序列的生成原理及m序列的matlab 仿真實(shí)現(xiàn),最后介紹了Matlab如何實(shí)現(xiàn)移位寄存器的代碼。
發(fā)表于 04-26 09:28
?1.7w次閱讀
筆者今天來聊聊對于ARM幾個(gè)特殊寄存器的理解,F(xiàn)P、SP和LR。
發(fā)表于 11-22 09:02
?3688次閱讀
連接寄存器(Link Register, LR),在ARM體系結(jié)構(gòu)中LR的特殊用途有兩種:一是用來保存子程序返回地址;二是當(dāng)異常發(fā)生時(shí),LR
發(fā)表于 01-27 14:21
寄存器與移位寄存器
寄存器是用來寄存數(shù)碼的邏輯部件,所以必須具備接收和寄存數(shù)碼的功能。任何一種
發(fā)表于 03-12 15:19
?59次下載
寄存器,寄存器是什么意思
寄存器定義 寄存器是中央處理器內(nèi)的組成部分。寄存器是有限存貯容量
發(fā)表于 03-08 14:26
?2.2w次閱讀
數(shù)據(jù)寄存器,數(shù)據(jù)寄存器是什么意思
數(shù)據(jù)寄存器數(shù)據(jù)寄存器包括累加器AX、基址寄存器BX、計(jì)數(shù)
發(fā)表于 03-08 14:38
?1.2w次閱讀
移位寄存器,移位寄存器是什么意思
移位寄存器_
發(fā)表于 03-08 14:50
?1.7w次閱讀
寄存器與移位寄存器:介紹寄存器原理和移位寄存器的原理及實(shí)現(xiàn)。
發(fā)表于 05-20 11:47
?0次下載
本文開始介紹了暫存器的定義和結(jié)構(gòu)組成,其次介紹了暫存器分類與寄存器定義,最后介紹了寄存器的原理。
發(fā)表于 04-11 09:30
?1.6w次閱讀
8086有14個(gè)16位寄存器,這14個(gè)寄存器按其用途可分為通用寄存器、指令指針、標(biāo)志寄存器和段寄存器等4類。下面就來看看這四個(gè)
發(fā)表于 04-16 11:36
?1w次閱讀
工業(yè)機(jī)器人FANUC數(shù)據(jù)位置寄存器和位置寄存器的運(yùn)用
一、寄存器指令 Registers① 寄存器指令R[i] i=1~200② 位置
發(fā)表于 06-22 10:08
?3.2w次閱讀
MIPS 有32個(gè)寄存器(0~31), 每個(gè)寄存器各有不同的用途。
發(fā)表于 06-23 08:59
?7465次閱讀
),對應(yīng)引腳輸出高電平。上拉是一個(gè)電阻接到一個(gè)電壓,其實(shí)就是增強(qiáng)IO的驅(qū)動(dòng)能力。下拉寄存器下拉就是一個(gè)電阻接到地,保證IO口是低電平。...
發(fā)表于 01-14 14:31
?10次下載
幾乎我們設(shè)計(jì)的每個(gè)模塊都會(huì)有寄存器,而它們的寄存器或多或少能被CPU訪問到。但CPU的接口通常只有一組總線去訪問這些模塊,所以設(shè)計(jì)上都會(huì)把CPU和各個(gè)模塊掛到總線上。這樣CPU作為Master就能夠訪問到所有的模塊了。
發(fā)表于 07-26 13:52
?9863次閱讀
寄存器是計(jì)算機(jī)中用于存儲(chǔ)數(shù)據(jù)的高速存儲(chǔ)單元,它們是CPU內(nèi)部的重要組成部分。寄存器可以分為基本寄存器和擴(kuò)展寄存器兩種類型。 一、基本
發(fā)表于 07-12 10:31
?635次閱讀
評論