ARM9的中斷控制器

来源:http://www.cnblogs.com/Forever-LJX/archive/2016/08/25/5807775.html
-Advertisement-
Play Games

簡要複習一下ARM9中斷控制器的控制過程: 1.首先能識別觸發的中斷(對應中斷源必須打開,然後查詢當前中斷狀態寄存器),硬體會操控PC跳到中斷向量入口(IRQ_HANDLE,硬體控制的只要是IRQ中斷類型就會進入),在中斷跳轉函數裡面保存現場(保存R0等等工作寄存器)--跳到服務函數(裡面進行中斷源 ...


簡要複習一下ARM9中斷控制器的控制過程:

1.首先能識別觸發的中斷(對應中斷源必須打開,然後查詢當前中斷狀態寄存器),硬體會操控PC跳到中斷向量入口(IRQ_HANDLE,硬體控制的只要是IRQ中斷類型就會進入),在中斷跳轉函數裡面保存現場(保存R0等等工作寄存器)--跳到服務函數(裡面進行中斷源判斷和處理)---恢復現場,基本流程是這樣。

2.中斷的觸發:高低電平,上升下降沿等等,具體的設置寄存器實現。

3.中斷能否傳到CPU?觸發以後還要通過許多開關(寄存器設置使能與否)確保到達CPU,這樣CPU才能識別(有的中斷源是不需要的),有些中斷是二級中斷,需要開關比較多,註意晶元手冊說明

4.

比如我們要觸發的是INT_TC這個二級中斷信號。好,那麼我們要打開的開關是什麼呢?在二級中斷信號里,INTSUBMSK是二級中斷信號的開關,我們要在裡面找到INT_TC這個位並設置為1即可。二級中斷還得傳到一級中控器處理,那麼我們先找出INT_TC是屬於哪個一級中斷信號的,看表裡的紫色框起來的是二級屬於同一個一級信號的,一級信號處理那個也有個紫色框,INT_ADC就是我們要找到的對應一級信號。而它也有對應的開關,那麼就是INTMSK這個控制器。我們把INTMSK里的INT_ADC位設置為1就算成功了。

代碼也就是  

INTSUBMSK |= ( 0x1 << 9);//因為INT_TCINTSUBMSK里的第9位,註意從0開始

INTMSK |= (0x1 << 31); //INT_ADCINTMSK里的第31位。

 

其他的類似外部中斷也是這樣操作。只是一級中斷的可以直接從一級中控器處理,那麼就只設置一級中控器的相應開關即可。也就是說,我們要用到的設備介面,我們就把相應的開關打開就可以了,其他的讓ARM來處理就可以了。

 

5.EIN4_7屬於一級中斷源,但是該中斷源包含EIN4\EIN5\EIN6\EIN7四個子中斷源。

SRCPND源掛起寄存器。

該寄存器在中斷源發出請求時候,處理器就會自動置位該寄存器的相應的位為1.

 

註意:根據三星文檔知道,該位不受寄存器影響,這個寄存器是屏蔽寄存器。在則在執行服務程式時候,該位不許進行清除,否則會導致連續中斷。清除方法是往該位寫入1。

 

 INTMOD中斷模式寄存器

 

該寄存器決定中斷源為FIQ中斷還是IRQ中斷。

 

註意:根據三星文檔,INTPND寄存器和INTOFFSET寄存器只對IRQ模式有效

 

 INTMSK中斷屏蔽寄存器

 

決定是否屏蔽某中斷源

 

註意:沒有

 

 PRIORITY優先順序寄存器

 

決定中斷源優先順序。

 

 INTPND中斷服務程式標誌位

 

根據文檔說,在中斷源沒被屏蔽,並且在等待中斷服務,優先順序也是最最高的置1.啥意思,就是該寄存器對應位置1,表示CPU已經響應該對應的中斷請求。

 

註意:和SRCPND一樣,在中斷服務程式時候要清除該對應位。

 

 INTOFFSET寄存器

 

該寄存器和INTPND配合使用的。標明INTPND寄存器里對應IRQ中斷反映在INTOFFSET寄存器的值

 

註意:也需要清除位

 

 SUBSRCPND寄存器

 

該寄存器與.SRCPND寄存器配合使用,在子中斷源發出請求時候,處理器就會自動置位該寄存器的相應的位為1.

 

 INTSUBMSK寄存器

 

該寄存器和INTMSK寄存器一樣,只不過是相對於子中斷而言而已。

 

6.借用別人網站的圖

 

 其中深黑色的就是編程要用的寄存器,而淺黑色的寄存器時CPU根據我們配置的寄存器產生的標誌位寄存器。

 

7.最後我感覺和51還是比較類似的,設置引腳為外部中斷(有的是內部中斷),使能,確定優先順序,識別到觸發,保存現場,處理,恢復現場。嵌入式linux的程式需要和彙編一起組織,目前不是特別熟悉,學習ing~

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 知識點1 ALTER 下列代碼意義:向已存在的表my_foods中新增自動排列的列 作為主鍵 如果不需要作為主鍵,則去掉 PRIMARY KEY 即可! 排序關鍵字: FIRST - --把 列id 安置於所有其他列的前面 LAST -- 把列 id 安置於其他列的後面 SECOND -- 把列 i ...
  • 回到目錄 本文是Redis集群系列的一篇文章,主要介紹使用StackExchange.Redis進行Twemproxy(文中簡稱TW)代理服務的連接過程,事務上,對於TW來說,我們需要理解一下它的物理架構,它類似於Nugix,主要實現的是請求轉發,但它還有一個重要的功能,那就是自動分片,這對於大數據 ...
  • Hive作為大數據環境下的數據倉庫工具,支持基於hadoop以sql的方式執行mapreduce的任務,非常適合對大量的數據進行全量的查詢分析。 本文主要講述下hive載cli中如何導入導出數據: 導入數據 第一種方式,直接從本地文件系統導入數據 我的本機有一個test1.txt文件,這個文件中有三 ...
  • 本文介紹Vim編輯器的使用 vi和vim的區別 它們都是多模式編輯器 不同的是vim是vi的升級版本 它不僅相容vi的所有指令而且還有一些新的特性在裡面 vim的這些優勢主要體現在以下幾個方面 + 多級撤消 在vi里 按u只能撤消上次命令 而在vim里可以無限制的撤消 + 易用性 vi只能運行於un ...
  • 複製和移動文件 cp:copy cp SRC DEST cp file1 file2 file3 //file1,file2為源文件,file3為目標 複製一個文件到一個文件 複製多個文件到一個目錄,目錄必須存在 cp /etc/passwd /tmp/ 複製到/tmp/下,文件名為passwd 若 ...
  • 在windows主機安裝centos虛擬機後,遇到虛擬機連接外網問題。 解決方案:http://blog.csdn.net/pang040328/article/details/12427359 經過如上操作,確認可以ping 8.8.8.8,表示虛擬機可以連接外網了。不過,ping www.bai ...
  • 首先根據書中講解的實例代碼(標準實例來源於UCOS ii經典教程 邵貝貝) 並且在另一個任務中進行消息發送,如下代碼 無論是斷點調試,還是從輸出的調試信息中都可以確定每次都有消息發送,但是在OSMboxPend中始終沒有接收到消息導致err一直等於OS_TIMEOUT而無法進行正確消息處理 但是只要 ...
  • 最近公司團隊的項目用到ESP8266,使用的是stm32c8t6晶元,軟體使用MDK,於是寫下調試過程中的一些註意點。具體代碼和涉及思路不能外泄,這裡只給出我們調試過程中的註意的方面。 關於ESP8266,我們首先做一些說明,這些都是我們團隊在調試過程中總結出來的,都是經過實際的測試,而不是談論或是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...