新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > ARM Cortex-M3 學習筆記(3)

        ARM Cortex-M3 學習筆記(3)

        作者: 時間:2016-11-20 來源:網絡 收藏
        最近在學ARM Cortex-M3,找了本號稱很經典的書“An Definitive Guide to The ARM Cortex-M3”在看。這個系列學習筆記其實就是在學習這本書的過程中做的讀書筆記。

        第三章 Cortex-M3 基礎

        這章的內容有不少是和第二章重復的。重復的部分這里就不再提了。

        堆棧

        Cortex-M3 的堆棧是倒生的,實棧頂。也就是R13指向最后一次壓入堆棧的內容。
        下面是個簡單的例子:
        PUSH {R0} ; *(--R13)=R0。R13是long*的指針
        POP {R0} ; R0= *R13++

        PUSH 和 POP 可以一次操作多個寄存器:
        subroutine_1
        PUSH {R0-R7, R12, R14} ; 保存寄存器列表
        … ; 執行處理
        POP {R0-R7, R12, R14} ; 恢復寄存器列表
        BX R14 ; 返回到主調函數
        上面的例子中順帶也用到了R14。因此就不單獨講解R14了。

        特殊功能寄存器組

        訪問特殊功能寄存器需要用專用指令:
        MRS , ;讀特殊功能寄存器的值到通用寄存器
        MSR , ;寫通用寄存器的值到特殊功能寄存器

        程序狀態寄存器在其內部又被分為三個子狀態寄存器:
        ? 應用程序PSR(APSR)
        ? 中斷號PSR(IPSR)
        ? 執行PSR(EPSR)
        參看下圖:

        本文引用地址:http://www.104case.com/article/201611/318828.htm

        圖 6 Cortex-M3中的程序狀態寄存器(xPSR)

        PRIMASK,FAULTMASK和BASEPRI 控制中斷和異常的開啟和屏蔽
        PRIMASK = 1后只有NMI和硬fault可以響應,默認為0
        FAULTMASK = 1后只有NMI和硬fault可以響應,默認為0
        BASEPRI:優先級號大于等于此值的中斷都被屏蔽
        只有在特權級下,才允許訪問這3個寄存器。

        控制寄存器(CONTROL)
        CONTROL[0]=1,用戶級的線程模式
        CONTROL[0]=0,特權級的線程模式
        CONTROL[1]=1,選擇使用MSP
        CONTROL[1]=0,選擇使用PSP

        中斷向量表

        默認的中斷向量表在地址0處,利用NVIC的重定位寄存器可以將其重定位。
        另外,中斷向量表的第一個向量的位置存放的是MSP的初始值。



        關鍵詞: ARMCortex-M

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 昌平区| 长沙市| 涟水县| 辽源市| 佛教| 新蔡县| 偏关县| 贵溪市| 中宁县| 西乌珠穆沁旗| 沧源| 达拉特旗| 平远县| 乡城县| 基隆市| 肃南| 叙永县| 张北县| 香河县| 台南县| 永福县| 临邑县| 鄂伦春自治旗| 辽阳县| 布尔津县| 东莞市| 龙井市| 海宁市| 西昌市| 衡水市| 华容县| 甘德县| 浦东新区| 喀什市| 灵璧县| 溆浦县| 丘北县| 温宿县| 苗栗市| 乐亭县| 抚松县|