日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]ARM是一類嵌入式微處理器,同時(shí)也是一個(gè)公司的名字。ARM公司于1990年11月成立于英國劍橋,它是一家專門從事16/32位RISC微處理器知識產(chǎn)權(quán)設(shè)計(jì)的供應(yīng)商。ARM公司本身不直接從事芯片生產(chǎn),而只是授權(quán)ARM內(nèi)核,再給生產(chǎn)和銷售半導(dǎo)體的合作伙伴,同時(shí)也提供基于ARM架構(gòu)的開發(fā)設(shè)計(jì)技術(shù)。

4.2ARM處理器硬件開發(fā)平臺4.2.1ARM處理器簡介

ARM是一類嵌入式微處理器,同時(shí)也是一個(gè)公司的名字。ARM公司于1990年11月成立于英國劍橋,它是一家專門從事16/32位RISC微處理器知識產(chǎn)權(quán)設(shè)計(jì)的供應(yīng)商。ARM公司本身不直接從事芯片生產(chǎn),而只是授權(quán)ARM內(nèi)核,再給生產(chǎn)和銷售半導(dǎo)體的合作伙伴,同時(shí)也提供基于ARM架構(gòu)的開發(fā)設(shè)計(jì)技術(shù)。世界各大半導(dǎo)體生產(chǎn)商從ARM公司處購買其設(shè)計(jì)的ARM微處理器核,根據(jù)各自不同的應(yīng)用領(lǐng)域,加入適當(dāng)?shù)耐鈬娐?,從而形成自己的ARM微處理器芯片進(jìn)入市場。

ARM公司從成立至今,在短短幾十年的時(shí)間就占據(jù)了75%的市場份額,如今,ARM微處理器及技術(shù)的應(yīng)用幾乎已經(jīng)深入到各個(gè)領(lǐng)域。采用ARM技術(shù)的微處理器現(xiàn)在已經(jīng)遍及各類電子產(chǎn)品,汽車、消費(fèi)娛樂、影像、工業(yè)控制、海量存儲、網(wǎng)絡(luò)、安保和無線等市場。到2001年就幾乎已經(jīng)壟斷了全球RISC芯片市場,成為業(yè)界實(shí)際的RISC芯片標(biāo)準(zhǔn)。圖4.3列舉了使用ARM微處理器的公司名稱。

圖4.3ARMIP核用戶

ARM的成功,一方面得益于它獨(dú)特的公司運(yùn)作模式,另一方面,當(dāng)然來自于ARM處理器自身的優(yōu)良性能。ARM處理器有如下特點(diǎn)。

n 體積小、低功耗、低成本、高性能。

n 支持ARM(32位)/Thumb(16位)/Thumb2(16/32位混合)指令集,能很好地兼容8位/16位器件。

n 大量使用寄存器,指令執(zhí)行速度更快。

n 大多數(shù)數(shù)據(jù)操作都在寄存器中完成。

n 尋址方式靈活簡單,執(zhí)行效率高。

n 指令長度固定。

小知識

常見的CPU指令集分為CISC和RISC兩種。

CISC(ComplexInstructionSetComputer)是“復(fù)雜指令集”。自PC機(jī)誕生以來,32位以前的處理器都采用CISC指令集方式。由于這種指令系統(tǒng)的指令不等長,因此指令的數(shù)目非常多,編程和設(shè)計(jì)處理器時(shí)都較為麻煩。但由于基于CISC指令架構(gòu)系統(tǒng)設(shè)計(jì)的軟件已經(jīng)非常普遍了,所以包括Intel、AMD等眾多廠商至今使用的仍為CISC。

RISC(ReducedInstructionSetComputing)是“精簡指令集”。研究人員在對CISC指令集進(jìn)行測試時(shí)發(fā)現(xiàn),各種指令的使用頻度相當(dāng)懸殊,其中最常使用的是一些比較簡單的指令,它們僅占指令總數(shù)的20%,但在程序中出現(xiàn)的頻度卻占80%。RISC正是基于這種思想提出的。采用RISC指令集的微處理器處理能力強(qiáng),并且還通過采用超標(biāo)量和超流水線結(jié)構(gòu),大大增強(qiáng)并行處理能力。

4.2.2ARM體系結(jié)構(gòu)簡介1.ARM微處理器工作狀態(tài)

ARM微處理器的工作狀態(tài)一般有三種,并可來回切換。

n 第一種為ARM狀態(tài),此時(shí)處理器執(zhí)行32位的字對齊的ARM指令。

n 第二種為Thumb狀態(tài),此時(shí)處理器執(zhí)行16位的、半字對齊的Thumb指令。

n 第三種為Thumb2狀態(tài),此時(shí)處理執(zhí)行16/32位混合的、多類型對齊的指令。

2.ARM體系結(jié)構(gòu)的存儲格式

n 大端格式:在這種格式中,字?jǐn)?shù)據(jù)的高字節(jié)存儲在低地址中,而字?jǐn)?shù)據(jù)的低字節(jié)則存放在高地址中。

n 小端格式:與大端存儲格式相反,在小端存儲格式中,低地址中存放的是字?jǐn)?shù)據(jù)的低字節(jié),高地址存放的是字?jǐn)?shù)據(jù)的高字節(jié)。

3.ARM處理器模式

ARM微處理器支持7種運(yùn)行模式,分別如下。

n 用戶模式(usr):應(yīng)用程序執(zhí)行狀態(tài)。

n 快速中斷模式(fiq):用于高速數(shù)據(jù)傳輸或通道處理等快速中斷處理。

n 外部中斷模式(irq):用于通用的中斷處理。

n 管理模式(svc):特權(quán)模式,操作系統(tǒng)使用的保護(hù)模式。

n 數(shù)據(jù)訪問終止模式(abt):當(dāng)數(shù)據(jù)或指令預(yù)取終止時(shí)進(jìn)入該模式,可用于虛擬存儲及存儲保護(hù)。

n 系統(tǒng)模式(sys):運(yùn)行具有特權(quán)的操作系統(tǒng)任務(wù)。

4.2.3ARM9體系結(jié)構(gòu)1.ARM微處理器系列簡介

ARM微處理器系列主要特點(diǎn)如表4.2所示。

表4.2 ARM微處理器系列

ARM核

主要特點(diǎn)

ARM7TDMI

•使用v4T體系結(jié)構(gòu)

•最普通的低端ARM核

•3級流水線

•馮·諾依曼體系結(jié)構(gòu)

•CPI約為1.9

T表示支持Thumb指令集(ARM指令是32位的;Thumb指令是16位的)

DI表示“EmbeddedICELogic”,支持JTAG調(diào)試

M表示內(nèi)嵌硬件乘法器

ARM720T是具有cache、MMU(內(nèi)存管理單元)和寫緩沖的一種ARM7TDMI

ARM9TDMI

•使用v4T體系結(jié)構(gòu)

•5級流水線:CPI被提高到1.5,提高了最高主頻

•哈佛體系結(jié)構(gòu):增加了存儲器有效帶寬(指令存儲器接口和數(shù)據(jù)存儲器接口),實(shí)現(xiàn)了同時(shí)訪問指令存儲器和數(shù)據(jù)存儲器的功能。

•一般提供附帶的cache:ARM922T有2X8KB的cache、MMU和寫緩沖;ARM920T除了有2×16KB的cache之外,其他的與ARM922t相同;ARM940T有一個(gè)MPU(內(nèi)存保護(hù)單元)

ARM9E

•ARM9E是在ARM9TDMI的基礎(chǔ)上,增加了一些功能:支持V5TE版本的體系結(jié)構(gòu),實(shí)現(xiàn)了單周期32×16乘法器和EmbeddedICELogicRT

•ARM926EJ-S/ARM946E-S:有可配置的指令和數(shù)據(jù)cache、指令和數(shù)據(jù)TCM接口以及AHB總線接口。ARM926EJ-S有MMU,ARM946E-S有MPU

•ARM966E-S:有指令和數(shù)據(jù)TCM接口,沒有cache、MPU/MMU

ARM11系列

•ARM1136JF-S:使用ARMV6體系結(jié)構(gòu),性能強(qiáng)大(8級流水線,有靜態(tài)/動態(tài)分支預(yù)測器和返回堆棧),有低延遲中斷模式,有MMU,有支持物理標(biāo)記的4-64k指令和數(shù)據(jù)cache,有一些內(nèi)嵌的可配置的TCM,有4個(gè)主存端口(64位存儲器接口),可以集成VFP協(xié)處理器(可選)。

•ARM1156T2(F)-S:有MPU,支持Thumb2ISA。

•ARM1176JZ(F)-S:在ARM1136JF-S基礎(chǔ)上實(shí)現(xiàn)了TrustZone技術(shù)。

Cortex系列

•Cortex-A8:使用v7A體系結(jié)構(gòu),支持MMU、AXI、VFP和NEON。

•Cortex-R4:使用v7R體系結(jié)構(gòu),支持MPU(可選)、AXI和DualIssue技術(shù)。

•Cortex-M3:使用v7M體系結(jié)構(gòu),支持MPU(可選)、AHBLite和APB

因?yàn)楸緯捎玫腇S2410開發(fā)板的S3C2410X是一款A(yù)RM9核處理器,所以下面重點(diǎn)學(xué)習(xí)ARM9核處理器。

2.ARM9主要特點(diǎn)

ARM處理器憑借它的低功耗、高性能等特點(diǎn),被廣泛應(yīng)用于個(gè)人通信等嵌入式領(lǐng)域,而ARM7也曾在中低端手持設(shè)備中占據(jù)了一席之地。然而,ARM7的處理性能逐漸無法滿足人們?nèi)找嬖鲩L的高性能處理的需求,它開始退出主流應(yīng)用領(lǐng)域,取而代之的是性能更加強(qiáng)大的ARM9系列處理器。

新一代的ARM9處理器,通過全新的設(shè)計(jì),能夠達(dá)到兩倍以上于ARM7處理器的處理能力。它的主要特點(diǎn)如下所述。

(1)5級流水線。

ARM7處理器采用的3級流水線設(shè)計(jì),而ARM9則采用5級流水線設(shè)計(jì),如圖4.4所示。

通過使用5級流水線機(jī)制,在每一個(gè)時(shí)鐘周期內(nèi)可以同時(shí)執(zhí)行5條指令。這樣就大大提高了處理性能。在同樣的加工工藝下,ARM9處理器的時(shí)鐘頻率是ARM7的1.8~2.2倍。

圖4.4ARM7與ARM9流水線比較

(2)采用哈佛結(jié)構(gòu)。

首先讀者需要了解什么叫哈佛結(jié)構(gòu)。在計(jì)算機(jī)中,根據(jù)計(jì)算機(jī)的存儲器結(jié)構(gòu)及其總線連接形式,計(jì)算機(jī)系統(tǒng)可以被分為馮·諾依曼結(jié)構(gòu)和哈佛結(jié)構(gòu),其中馮·諾依曼結(jié)構(gòu)共用數(shù)據(jù)存儲空間和程序存儲空間,它們共享存儲器總線,這也是以往設(shè)計(jì)時(shí)常用的方式;而哈佛結(jié)構(gòu)則具有分離的數(shù)據(jù)和程序空間及分離的訪問總線。所以哈佛結(jié)構(gòu)在指令執(zhí)行時(shí),取址和取數(shù)可以并行,因此具有更高的執(zhí)行效率。ARM9采用的就是哈佛結(jié)構(gòu),而ARM7采用的則是馮·諾依曼結(jié)構(gòu)。如圖4.5和圖4.6分別體現(xiàn)了馮·諾依曼結(jié)構(gòu)和哈佛結(jié)構(gòu)的數(shù)據(jù)存儲方式。

圖4.5馮·諾依曼結(jié)構(gòu) 圖4.6哈佛結(jié)構(gòu)

由于在RISC架構(gòu)的處理器中,程序中大約有30%的指令是Load-Store指令,而采用哈佛結(jié)構(gòu)大大提升了這兩個(gè)指令的執(zhí)行速度,因此對提高系統(tǒng)效率的貢獻(xiàn)是非常明顯的。

(3)高速緩存和寫緩存的引入。

由于在處理器中,一般處理器速度遠(yuǎn)遠(yuǎn)高于存儲器訪問速度,那么,如果存儲器訪問成為系統(tǒng)性能的瓶頸,則處理器再快都毫無作用。在這種情況下,高速緩存(Cache)和寫緩存(WriteBuffer)可以很好地解決這個(gè)問題,它們存儲了最近常用的代碼和數(shù)據(jù),以供CPU快速存儲,如圖4.7所示。

(4)支持MMU。

圖4.7ARM9的高速緩存和讀緩存

MMU是內(nèi)存管理單元,它把內(nèi)存以“頁(page)”為單位來進(jìn)行處理。一頁內(nèi)存是指一個(gè)具有一定大小的連續(xù)的內(nèi)存塊,通常為4096B或8192B。操作系統(tǒng)為每個(gè)正在運(yùn)行的程序建立并維護(hù)一張被稱為進(jìn)程內(nèi)存映射(ProcessMemoryMap)的表,表中記錄了程序可以存取的所有內(nèi)存頁以及它們的實(shí)際位置。

每當(dāng)程序存取一塊內(nèi)存時(shí),它會把相應(yīng)的虛擬地址(virtualaddress)傳送給MMU,而MMU會在PMM中查找這塊內(nèi)存的實(shí)際位置,也就是物理地址(physicaladdress),物理地址可以在內(nèi)存中或磁盤上的任何位置。如果程序要存取的位置在磁盤上,就必須把包含該地址的頁從磁盤上讀到內(nèi)存中,并且必須更新PMM以反映這個(gè)變化(這被稱為pagefault,即“頁錯”)。MMU的實(shí)現(xiàn)過程如圖4.8所示。

圖4.8MMU的實(shí)現(xiàn)過程

只有擁有了MMU才能真正實(shí)現(xiàn)內(nèi)存保護(hù)。例如當(dāng)A進(jìn)程的程序試圖直接訪問屬于B進(jìn)程的虛擬地址中的數(shù)據(jù),那么MMU會產(chǎn)生一個(gè)異常(Exception)來阻止A的越界操作。這樣,通過內(nèi)存保護(hù),一個(gè)進(jìn)程的失敗并不會影響其他進(jìn)程的運(yùn)行,從而增強(qiáng)了系統(tǒng)的穩(wěn)定性,如圖4.9所示。ARM9也正是因?yàn)閾碛辛薓MU,所以比ARM7具有更強(qiáng)的穩(wěn)定性和可靠性。

圖4.9內(nèi)存保護(hù)示意圖

4.2.4S3C2410處理器詳解

本書所采用的硬件平臺是深圳優(yōu)龍科技有限公司的開發(fā)板FS2410(如圖4.10所示),它的中央處理器是三星公司的S3C2410X。S3C2410X是使用ARM920T核、采用0.18mm工藝CMOS標(biāo)準(zhǔn)宏單元和存儲編譯器開發(fā)而成的。由于采用了由ARM公司設(shè)計(jì)的16/32位ARM920TRISC處理器,因此S3C2410X實(shí)現(xiàn)了MMU和獨(dú)立的16KB指令和16KB數(shù)據(jù)哈佛結(jié)構(gòu)的緩存,且每個(gè)緩存均為8個(gè)字長度的流水線。它的低功耗、精簡而出色的全靜態(tài)設(shè)計(jì)特別適用于對成本和功耗敏感的領(lǐng)域。

S3C2410X提供全面的、通用的片上外設(shè),大大降低系統(tǒng)的成本,下面列舉了S3C2410X的主要片上功能。

n 1.8VARM920T內(nèi)核供電,1.8V/2.5V/3.3V存儲器供電;

n 16KB指令和16KB數(shù)據(jù)緩存的MMU內(nèi)存管理單元;

n 外部存儲器控制(SDRAM控制和芯片選擇邏輯);

n 提供LCD控制器(最大支持4K色的STN或256K色TFT的LCD),并帶有1個(gè)通道的LCD專用DMA控制器;

n 提供4通道DMA,具有外部請求引腳;

n 提供3通道UART(支持IrDA1.0,16字節(jié)發(fā)送FIFO及16字節(jié)接收FIFO)/2通道SPI接口;

n 提供1個(gè)通道多主IIC總線控制器/1通道IIS總線控制器;

n 兼容SD主機(jī)接口1.0版及MMC卡協(xié)議2.11版;

n 提供2個(gè)主機(jī)接口的USB口/1個(gè)設(shè)備USB口(1.1版本);

n 4通道PWM定時(shí)器/1通道內(nèi)部計(jì)時(shí)器;

圖4.10優(yōu)龍F(tuán)S2410開發(fā)板實(shí)物圖

n 提供看門狗定時(shí)器;

n 提供117個(gè)通用I/O口/24通道外部中斷源;

n 提供不同的電源控制模式:正常、慢速、空閑及電源關(guān)閉模式;

n 提供帶觸摸屏接口的8通道10位ADC;

n 提供帶日歷功能的實(shí)時(shí)時(shí)鐘控制器(RTC);

n 具有PLL的片上時(shí)鐘發(fā)生器。

S3C2410X系統(tǒng)結(jié)構(gòu)圖如圖4.11所示。

下面依次對S3C2410X的系統(tǒng)管理器、NandFlash引導(dǎo)裝載器、緩沖存儲器、時(shí)鐘和電源管理及中斷控制進(jìn)行簡要講解,要注意,其中所有模式的選擇都是通過對相關(guān)寄存器特定值的設(shè)定來實(shí)現(xiàn)的,因此,當(dāng)讀者需要對此進(jìn)行修改時(shí),請參閱三星公司提供S3C2410X用戶手冊。

1.系統(tǒng)管理器

S3C2410X支持小/大端模式,它將系統(tǒng)的存儲空間分為8個(gè)組(bank),其中每個(gè)bank有128MB,總共為1GB。每個(gè)組可編程的數(shù)據(jù)總線寬度為8/16/32位,其中bank0~bank5具有固定的bank起始地址和結(jié)束地址,用于ROM和SRAM。而bank6和bank7是大小可變的,用于ROM、SRAM或SDRAM。這里,所有的存儲器bank都具有可編程的操作周期,并且支持掉電時(shí)的SDRAM自刷新模式和多種類型的引導(dǎo)ROM。

2.nandflash引導(dǎo)裝載器

S3C2410X支持從nandflash存儲器啟動,其中,開始的4KB為內(nèi)置緩沖存儲器,它在啟動時(shí)將被轉(zhuǎn)載(裝載or轉(zhuǎn)載)到SDRAM中并執(zhí)行引導(dǎo),之后該4KB可以用作其他用途。

圖4.11S3C2410X系統(tǒng)結(jié)構(gòu)圖

小知識

Flash是一種非易失閃存技術(shù)。Intel于1988年首先開發(fā)出NorFlash技術(shù)之后,徹底改變了原先由EPROM和EEPROM一統(tǒng)天下的局面。緊接著,1989年東芝公司發(fā)布了NandFlash結(jié)構(gòu),強(qiáng)調(diào)降低每比特的成本、更高的性能,并且像磁盤一樣可以通過接口輕松升級。

NorFlash的特點(diǎn)是芯片內(nèi)執(zhí)行(ExecuteInPlace),這樣應(yīng)用程序可以直接在Flash閃存內(nèi)運(yùn)行,而不必再把代碼讀到系統(tǒng)RAM中。NorFlash的傳輸效率很高,在1~4MB的小容量時(shí)具有很高的成本效益,但是很低的寫入和擦除速度大大影響了它的性能。

Nandflash結(jié)構(gòu)能提供極高的單元密度,可以達(dá)到高存儲密度,NAND讀和寫操作采用512字節(jié)的塊,單元尺寸幾乎是nor器件的一半,同時(shí)由于生產(chǎn)過程更為簡單,大大降低了生產(chǎn)的成本。NAND閃存中每個(gè)塊的最大擦寫次數(shù)是100萬次,是NorFlash的10倍,這些都使得NandFlash越來越受到人們的歡迎。

同時(shí),S3C2410X也支持從外部nGCS0片選的Norflash啟動,如在優(yōu)龍的開發(fā)板上將JP1跳線去掉就可從NorFlash啟動(默認(rèn)從NandFlash啟動)。在這兩種啟動模式下,各片選的存儲空間分配是不同的,如圖4.12所示。

圖4.12S3C2410兩種啟動模式地址映射

3.緩沖存儲器

S3C2410X是帶有指令緩存(16KB)和數(shù)據(jù)緩存(16KB)的聯(lián)合緩存裝置,一個(gè)緩沖區(qū)能夠保持16字的數(shù)據(jù)和4個(gè)地址。

4.時(shí)鐘和電源管理

S3C2410X采用獨(dú)特的時(shí)鐘管理模式,它具有PLL(相位鎖定環(huán)路,用于穩(wěn)定頻率)的芯片時(shí)鐘發(fā)生器,而在此,PLL又分為UPLL和MPLL。其中UPLL時(shí)鐘發(fā)生器用于主/從USB操作,MPLL時(shí)鐘發(fā)生器用于產(chǎn)生主時(shí)鐘,使其能以極限頻率203MHz(1.8V)運(yùn)行。

S3C2410X的電源管理模式又分為正常、慢速、空閑和掉電4種模式。其中慢速模式為不帶PLL的低頻時(shí)鐘模式,空閑模式始終為CPU停止模式,掉電模式為所有外圍設(shè)備全部掉電僅內(nèi)核電源供電的模式。

另外,S3C2410X對片內(nèi)的各個(gè)部件采用獨(dú)立的供電方式。

n 1.8V的內(nèi)核供電。

n 3.3V的存儲器獨(dú)立供電(通常對SDRAM采用3.3V,對移動SDRAM采用1.8/2.5V)。

n 3.3V的VDDQ。

n 3.3V的I/O獨(dú)立供電。

由于在嵌入式系統(tǒng)中電源管理非常關(guān)鍵,它直接涉及功耗等各方面的系統(tǒng)性能,而S3C2410X的電源管理中獨(dú)立的供電方式和多種模式可以有效地處理系統(tǒng)的不同狀態(tài),從而達(dá)到最優(yōu)的配置。

5.中斷控制

中斷處理在嵌入式系統(tǒng)開發(fā)中非常重要,尤其對于從單片機(jī)轉(zhuǎn)入到嵌入式的讀者來說,與單片機(jī)中簡單的中斷模式相比,ARM中的中斷處理要復(fù)雜得多。如果讀者無相關(guān)基礎(chǔ),建議先熟悉相關(guān)的基礎(chǔ)概念再進(jìn)行下一步學(xué)習(xí)。

首先給出了一般的中斷處理流程,如圖4.13所示。

圖4.13一般中斷處理流程

S3C2410X包括55個(gè)中斷源,其中有1個(gè)看門狗定時(shí)器中斷、5個(gè)定時(shí)器中斷、9個(gè)通用異步串行口中斷、24個(gè)外部中斷、4個(gè)DMA中斷、2個(gè)RTC(實(shí)時(shí)時(shí)鐘控制器)中斷、2個(gè)USB中斷、1個(gè)LCD中斷和1個(gè)電池故障。其中,對外部中斷源具有電平/邊沿兩種觸發(fā)模式。另外,對于非常緊急的中斷可以支持使用快速中斷請求(FIQ)。

S3C2410X的中斷處理流程(該圖摘自S3C2410X用戶手冊)如圖4.14所示。

圖4.14S3C2410X中斷處理流程

圖中的SUBSRCPND、SRCPND、SUBMASK、MASK和MODE都是與中斷相關(guān)的寄存器,其中SUBSRCPND和SRCPND寄存器用來表示有哪些中斷被觸發(fā)了和是否正在等待處理(pending);SUBMASK(INTSUBMSK寄存器)和MASK(INTMSK寄存器)用于屏蔽某些中斷。

圖中的“Requestsources(withsub–register)”表示的是INT_RXD0、INT_TXD0等11個(gè)中斷源,它們不同于“Requestsources(withoutsub–register)”的操作如下:

(1)“Requestsources(withoutsub–register)”中的中斷源被觸發(fā)之后,SRCPND寄存器中相應(yīng)位被置1,如果此中斷沒有被INTMSK寄存器屏蔽、或者是快中斷(FIQ)的話,它將被進(jìn)一步處理。

(2)對于“Requestsources(withsub–register)”中的中斷源被觸發(fā)之后,SUBSRCPND寄存器中的相應(yīng)位被置1,如果此中斷沒有被SUBMSK寄存器屏蔽的話,它在SRCPND寄存器中的相應(yīng)位也被置1。在此之后的兩者的處理過程是一樣的。

接下來,在SRCPND寄存器中,被觸發(fā)的中斷的相應(yīng)位被置1,等待處理。

(1)如果被觸發(fā)的中斷中有快中斷(FIQ)——MODE(INTMOD寄存器)中為1的位對應(yīng)的中斷,則CPU的FIQ中斷函數(shù)被調(diào)用。注意:FIQ只能分配一個(gè),即INTMOD中只能有一位被設(shè)為1。

(2)對于一般中斷IRQ,可能同時(shí)有幾個(gè)中斷被觸發(fā),未被INTMSK寄存器屏蔽的中斷經(jīng)過比較后,選出優(yōu)先級最高的中斷,然后CPU調(diào)用IRQ中斷處理函數(shù)。中斷處理函數(shù)可以通過讀取INTPND(標(biāo)識最高優(yōu)先級的寄存器)寄存器來確定中斷源是哪個(gè),也可以讀INTOFFSET寄存器來確定中斷源。

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

在工業(yè)物聯(lián)網(wǎng)設(shè)備部署中,Modbus通信故障是導(dǎo)致系統(tǒng)停機(jī)的首要原因之一。據(jù)統(tǒng)計(jì),超過60%的現(xiàn)場問題源于通信配置錯誤或數(shù)據(jù)解析異常。本文從嵌入式系統(tǒng)開發(fā)視角,系統(tǒng)闡述Modbus通信調(diào)試的方法論,結(jié)合實(shí)際案例解析如何高...

關(guān)鍵字: 嵌入式系統(tǒng) Modbus通信

在嵌入式系統(tǒng)開發(fā)中,看門狗(Watchdog Timer, WDT)是保障系統(tǒng)可靠性的核心組件,其初始化時(shí)機(jī)的選擇直接影響系統(tǒng)抗干擾能力和穩(wěn)定性。本文從硬件架構(gòu)、軟件流程、安全規(guī)范三個(gè)維度,系統(tǒng)分析看門狗初始化的最佳實(shí)踐...

關(guān)鍵字: 單片機(jī) 看門狗 嵌入式系統(tǒng)

人工智能(AI)和機(jī)器學(xué)習(xí)(ML)是使系統(tǒng)能夠從數(shù)據(jù)中學(xué)習(xí)、進(jìn)行推理并隨著時(shí)間的推移提高性能的關(guān)鍵技術(shù)。這些技術(shù)通常用于大型數(shù)據(jù)中心和功能強(qiáng)大的GPU,但在微控制器(MCU)等資源受限的器件上部署這些技術(shù)的需求也在不斷增...

關(guān)鍵字: 嵌入式系統(tǒng) 人工智能 機(jī)器學(xué)習(xí)

Zephyr開源項(xiàng)目由Linux基金會維護(hù),是一個(gè)針對資源受限的嵌入式設(shè)備優(yōu)化的小型、可縮放、多體系結(jié)構(gòu)實(shí)時(shí)操作系統(tǒng)(RTOS)。近年來,Zephyr RTOS在嵌入式開發(fā)中的采用度逐步增加,支持的開發(fā)板和傳感器不斷增加...

關(guān)鍵字: 嵌入式系統(tǒng) 軟件開發(fā) 實(shí)時(shí)操作系統(tǒng) Zephyr項(xiàng)目

在資源受限的嵌入式系統(tǒng)中,代碼執(zhí)行效率和內(nèi)存占用始終是開發(fā)者需要權(quán)衡的核心問題。內(nèi)聯(lián)函數(shù)(inline functions)和宏(macros)作為兩種常見的代碼展開技術(shù),在性能、可維護(hù)性和安全性方面表現(xiàn)出顯著差異。本文...

關(guān)鍵字: 內(nèi)聯(lián)函數(shù) 嵌入式系統(tǒng)

在嵌入式系統(tǒng)和服務(wù)器開發(fā)中,日志系統(tǒng)是故障排查和運(yùn)行監(jiān)控的核心組件。本文基于Linux環(huán)境實(shí)現(xiàn)一個(gè)輕量級C語言日志庫,支持DEBUG/INFO/WARN/ERROR四級日志分級,并實(shí)現(xiàn)按大小滾動的文件輪轉(zhuǎn)機(jī)制。該設(shè)計(jì)在某...

關(guān)鍵字: C語言 嵌入式系統(tǒng)

在嵌入式系統(tǒng)和底層驅(qū)動開發(fā)中,C語言因其高效性和可控性成為主流選擇,但缺乏原生單元測試支持成為開發(fā)痛點(diǎn)。本文提出一種基于宏定義和測試用例管理的輕量級單元測試框架方案,通過自定義斷言宏和測試注冊機(jī)制,實(shí)現(xiàn)無需外部依賴的嵌入...

關(guān)鍵字: C語言 嵌入式系統(tǒng) 驅(qū)動開發(fā)

在嵌入式系統(tǒng)與驅(qū)動開發(fā)中,內(nèi)存映射I/O(Memory-Mapped I/O, MMIO)是一種將硬件寄存器映射到處理器地址空間的技術(shù),允許開發(fā)者通過指針直接讀寫寄存器,實(shí)現(xiàn)高效、低延遲的硬件控制。本文通過C語言實(shí)戰(zhàn)案例...

關(guān)鍵字: 內(nèi)存映射 I/O操作 嵌入式系統(tǒng)

在嵌入式系統(tǒng)開發(fā)和多線程編程中,程序崩潰、內(nèi)存越界等復(fù)雜問題常令開發(fā)者困擾。GDB作為強(qiáng)大的調(diào)試工具,其條件斷點(diǎn)和內(nèi)存查看功能可精準(zhǔn)定位隱蔽缺陷。本文通過實(shí)際案例演示這些高級功能的應(yīng)用,幫助開發(fā)者提升調(diào)試效率。

關(guān)鍵字: GDB 嵌入式系統(tǒng)
關(guān)閉