版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第2章嵌入式微處理器及ARM9
硬件開發(fā)平臺(tái)
2.l嵌入式微處理器2.2ARM9微處理器簡(jiǎn)介2.1.1嵌入式微處理器的類型
嵌入式微處理器是指應(yīng)用在嵌入式計(jì)算機(jī)系統(tǒng)中的微處理器。與通用計(jì)算機(jī)系統(tǒng)的CPU相比,嵌入式微處理器具有品種多、體積小、成本低、集成度高的特點(diǎn)。從1971年Intel公司推出第一塊微處理器芯片4004到今天,嵌入式微處理器已經(jīng)有30多年的發(fā)展歷史。2.l嵌入式微處理器如圖2-1所示,嵌入式硬件系統(tǒng)一般由嵌入式微處理器、存儲(chǔ)器和輸入/輸出部分組成。其中嵌入式微處理器是嵌入式硬件系統(tǒng)的核心,通常由三大部分組成:控制單元、算術(shù)邏輯單元和寄存器。圖2-1嵌入式硬件系統(tǒng)的基本結(jié)構(gòu)各部分的主要功能如下:
(1)控制單元:主要負(fù)責(zé)取指、譯碼和取操作數(shù)等基本操作,并發(fā)送主要的控制指令??刂茊卧邪▋蓚€(gè)重要的寄存器:程序計(jì)數(shù)器(PC)和指令寄存器(IR)。程序計(jì)數(shù)器用于記錄下一條程序指令在內(nèi)存中的位置,以便控制單元能到正確的內(nèi)存處取指;指令寄存器負(fù)責(zé)存放被控制單元所取的指令,通過譯碼,產(chǎn)生必要的控制信號(hào)送到算術(shù)邏輯單元完成相關(guān)的數(shù)據(jù)處理。
(2)算術(shù)邏輯單元:算術(shù)邏輯單元分為兩部分,一部分是算術(shù)運(yùn)算單元,主要處理數(shù)值型數(shù)據(jù),完成數(shù)學(xué)運(yùn)算,如加、減、乘、除或數(shù)值的比較;另一部分是邏輯運(yùn)算單元,主要處理邏輯運(yùn)算,如AND、OR、XOR或NOT等運(yùn)算。
(3)寄存器:用于存儲(chǔ)暫時(shí)性的數(shù)據(jù),主要是由存儲(chǔ)器中所得到的數(shù)據(jù)(這些數(shù)據(jù)被送到算術(shù)邏輯單元中進(jìn)行處理)和算術(shù)邏輯單元中處理好的數(shù)據(jù)。嵌入式微處理器的字長(zhǎng)寬度可為4位、8位、16位、32位和64位。一般把16位及以下的稱為嵌入式微控制器,32位及以上的稱為嵌入式微處理器。
如果按集成度劃分,嵌入式微處理器系統(tǒng)可分為兩種:一種是微處理器內(nèi)部?jī)H包含單純的中央處理器單元,稱為一般用途型微處理器;另一種則是將CPU、ROM、RAM及I/O等部件集成到同一個(gè)芯片上,稱為單芯片微控制器。如果按用途劃分,嵌入式微處理器可分為以下幾類:
(1)嵌入式微控制器(MCU),又稱為單片機(jī)。微控制器的片上外設(shè)資源一般比較豐富,適合于控制領(lǐng)域,因此稱為微控制器。微控制器芯片內(nèi)部集成有ROM/EPROM、RAM、總線、總線邏輯、定時(shí)/計(jì)數(shù)器、看門狗、I/O、串行口、脈寬調(diào)制輸出(PWM)、A/D、D/A、Flash、EEPROM等各種必要功能和外設(shè)。和嵌入式微處理器相比,微控制器的最大特點(diǎn)是單片化,體積大大減小,從而使功耗和成本下降,可靠性提高。由于嵌入式微控制器低廉的價(jià)格、優(yōu)良的功能,因此品種和數(shù)量最多,比較有代表性的包括8051、MCS-251、MCS-96/196/296、C166/167、68K系列以及MCU8XC930/931、C540、C541,并且支持I2C、CAN-BUS、LCD及眾多專用嵌入式微控制器和兼容系列。目前嵌入式微控制器占嵌入式系統(tǒng)約70%的市場(chǎng)份額。
(2)嵌入式微處理器(EMPU),它由通用計(jì)算機(jī)中的CPU發(fā)展而來。它的特征是具有32位以上的處理器,較高的性能,當(dāng)然其價(jià)格也相應(yīng)較高。但與計(jì)算機(jī)CPU不同的是,在實(shí)際嵌入式應(yīng)用中,EMPU只保留和嵌入式應(yīng)用緊密相關(guān)的功能硬件,去除其他的冗余功能部分,這樣就可以最低的功耗和資源實(shí)現(xiàn)嵌入式應(yīng)用的特殊要求。嵌入式微處理器與用于桌面計(jì)算機(jī)的CPU相比具有體積小、重量輕、功耗低、成本低及可靠性高的優(yōu)點(diǎn)。通常嵌入式微處理器把CPU、ROM、RAM及I/O等元件做到同一個(gè)芯片上,也稱為單板計(jì)算機(jī)。當(dāng)前,主要的嵌入式微處理器有ARM、MIPS、POWERPC和基于X86的386EX等。
(3)嵌入式DSP處理器,是專門用于信號(hào)處理方面的處理器,其在系統(tǒng)結(jié)構(gòu)和指令算法方面進(jìn)行了特殊設(shè)計(jì),具有很高的編譯效率和指令執(zhí)行速度。在數(shù)字濾波、FFT、頻譜分析等各種儀器上,DSP獲得了大量的應(yīng)用。
(4)嵌入式片上系統(tǒng)(SOC),是追求產(chǎn)品系統(tǒng)最大包容的集成器件。SOC最大的特點(diǎn)是成功實(shí)現(xiàn)了軟/硬件無縫結(jié)合,直接在處理器片內(nèi)嵌入操作系統(tǒng)的代碼模塊。而且SOC具有極高的綜合性,在一個(gè)硅片內(nèi)部運(yùn)用VHDL等硬件描述語言,可實(shí)現(xiàn)一個(gè)復(fù)雜的系統(tǒng)。用戶不需要再像傳統(tǒng)的系統(tǒng)設(shè)計(jì)一樣,繪制龐大復(fù)雜的電路板,一點(diǎn)點(diǎn)地連接焊制,只需要使用精確的語言,綜合時(shí)序設(shè)計(jì),直接在器件庫(kù)中調(diào)用各種通用處理器的標(biāo)準(zhǔn),然后通過仿真,之后就可以直接交付芯片廠商進(jìn)行生產(chǎn)。SOC的絕大部分系統(tǒng)構(gòu)件都是在系統(tǒng)內(nèi)部,整個(gè)系統(tǒng)就特別簡(jiǎn)潔,不僅減小了系統(tǒng)的體積和功耗,而且提高了系統(tǒng)的可靠性,提高了設(shè)計(jì)生產(chǎn)效率。2.1.2典型32位ARM微處理器的結(jié)構(gòu)和特點(diǎn)
32位微處理器采用32位的地址和數(shù)據(jù)總線,其地址空間達(dá)到了4?G。目前主流的32位嵌入式微處理器系列主要有ARM系列、MIPS系列、PoweRPC系列等。屬于這些系列的嵌入式微處理器產(chǎn)品,有千種以上。
1.ARM概述
ARM(AdvancedRISCMachine)公司是一家專門從事芯片IP設(shè)計(jì)與授權(quán)業(yè)務(wù)的英國(guó)公司,其產(chǎn)品有ARM內(nèi)核以及外圍接口。ARM內(nèi)核是一種32位RISC微處理器,具有功耗低、性價(jià)比高和代碼密度高等特點(diǎn)。
ARM微處理器核技術(shù)廣泛用于便攜式通信產(chǎn)品、手持運(yùn)算、多媒體和嵌入式解決方案等領(lǐng)域,已成為AISC標(biāo)準(zhǔn)。ARM處理器核是系統(tǒng)中的引擎,它從存儲(chǔ)器讀取ARM或Thumb的指令并執(zhí)行這些指令。ARM微處理器體系結(jié)構(gòu)目前被公認(rèn)為是嵌入式應(yīng)用領(lǐng)域領(lǐng)先的32位嵌入式RISC微處理器結(jié)構(gòu)。自誕生至今,ARM體系結(jié)構(gòu)發(fā)展并定義了7種不同的版本。從版本1到版本7,ARM體系的指令集功能不斷擴(kuò)展。ARM處理器系列中的各種處理器,雖然在實(shí)現(xiàn)技術(shù)、應(yīng)用場(chǎng)合和性能方面都不相同,但只要支持相同的ARM體系版本,那么基于它們的應(yīng)用軟件就都是兼容的。目前基于ARM核的處理器有以下幾類:ARM7系列處理器;ARM9系列處理器,ARM9E系列處理器,ARM10E系列處理器,ARM11系列處理器,SecurCore系列處理器,OPtimoDE數(shù)據(jù)引擎內(nèi)核;MPCore多處理器系列處理器;Intel公司的StrongARM/XScale系列處理器。
目前,70%的移動(dòng)電話、大量的游戲機(jī)、手持PC和機(jī)頂盒等都已采用了ARM處理器,許多一流的芯片廠商都是ARM的授權(quán)用戶,如Intel、三星等公司。
作為一種RISC體系結(jié)構(gòu)的微處理器,ARM處理器具有RISC體系結(jié)構(gòu)的典型特征,同時(shí)具有以下特點(diǎn):●每條數(shù)據(jù)處理指令都控制算術(shù)邏輯單元ALU和移位器,以使ALU和移位器獲得最大的利用率。
●具有自動(dòng)遞增和自動(dòng)尋址模式,以優(yōu)化程序中的循環(huán)。
●可同時(shí)執(zhí)行Load和Store多條指令,以增加數(shù)據(jù)吞吐量。
●所有指令都可以條件執(zhí)行,以執(zhí)行吞吐量。
這些對(duì)基本RISC體系結(jié)構(gòu)的增強(qiáng),使得ARM處理器可以在高性能、小代碼尺寸、低功耗和小芯片面積之間獲得良好的平衡。
2.ARM的數(shù)據(jù)類型
字(Word):在ARM體系結(jié)構(gòu)中,字的長(zhǎng)度為32位,而在8位/16位處理器體系結(jié)構(gòu)中,字的長(zhǎng)度一般為16位。
半字(Half-word):在ARM體系結(jié)構(gòu)中,半字的長(zhǎng)度為16位,與8位/16位處理器體系結(jié)構(gòu)中字的長(zhǎng)度一致。
字節(jié)(Byte):在ARM體系結(jié)構(gòu)和8位/16位處理器體系結(jié)構(gòu)中,字節(jié)的長(zhǎng)度均為8位。
3.ARM的運(yùn)行模式
ARM處理器有7種運(yùn)行模式,如表2-1所示。大多數(shù)應(yīng)用程序在User模式下執(zhí)行,當(dāng)特定的異常出現(xiàn)時(shí),進(jìn)入相應(yīng)的6種異常模式之一。每種模式都有某些附加的寄存器保存相應(yīng)的狀態(tài)。除User模式外,其他模式都被稱為特權(quán)模式,可以存取系統(tǒng)中的任何資源。
User模式下程序不能訪問某些受保護(hù)的資源,也不能直接改變CPU的模式,而只能通過異常的形式來改變CPU的當(dāng)前運(yùn)行模式。軟件可以控制CPU模式的改變,外部中斷也可以引起模式的改變。表2-1ARM處理器的7種運(yùn)行模式
處理器模式說明用戶模式(User)正常程序執(zhí)行模式,用于應(yīng)用程序異常模式(FIQ)快速中斷處理,用于支持高速數(shù)據(jù)傳送通道處理異常模式(IRQ)用于一般中斷處理異常模式(Supervisor)特權(quán)模式,用于操作系統(tǒng)處理異常模式(Abort)存儲(chǔ)器保護(hù)異常處理異常模式(Undefined)未定義指令異常處理系統(tǒng)模式(System)運(yùn)行特權(quán)操作系統(tǒng)任務(wù)(ARMv4以上版本)
4.寄存器結(jié)構(gòu)
ARM微處理器共有37個(gè)32位寄存器,其中31個(gè)為通用寄存器,6個(gè)為狀態(tài)寄存器。但是這些寄存器不能被同時(shí)訪問,具體哪些寄存器是可編程訪問的,取決于微處理器的工作狀態(tài)及具體的運(yùn)行模式。但在任何時(shí)候,通用寄存器R14~R0、程序計(jì)數(shù)器R15(或PC)、一個(gè)或兩個(gè)狀態(tài)寄存器都是可訪問的。
(1)?R0~R15。ARM中的通用寄存器是R0~R15(R15也是PC)。它們可以被劃分為以下三類:①未分組的寄存器R0~R7。對(duì)于所有的模式,R0~R7所對(duì)應(yīng)的物理寄存器都是相同的。這8個(gè)寄存器是真正意義上的通用寄存器,ARM體系結(jié)構(gòu)中對(duì)它們沒有作任何特殊的假設(shè),它們的功能都是等同的。在中斷或者異常處理程序中一般都需要對(duì)這幾個(gè)寄存器進(jìn)行保存。②分組的寄存器R8~R14。程序訪問的物理寄存器取決于當(dāng)前的處理器模式。若要訪問特定的物理寄存器而不依賴于當(dāng)前的處理器模式,則要使用規(guī)定的名字。R8~R12有兩組物理寄存器:一組是FIQ模式;另一組是除FIQ以外的其他模式。R13~R14有6個(gè)組的物理寄存器,一組用于用戶模式和系統(tǒng)模式,其他5組分別用于5種異常模式。R13(也被稱為SP指針)被用做棧指針,通常在系統(tǒng)初始化時(shí)需要對(duì)所有模式的SP指針賦值;當(dāng)CPU在不同的模式時(shí),棧指針會(huì)被自動(dòng)切換成相應(yīng)模式下的值。R14有兩個(gè)用途:一是在調(diào)用子程序時(shí)用于保存調(diào)用返回地址;二是在發(fā)生異常時(shí)用于保存異常返回地址。③程序計(jì)數(shù)器R15(或PC)。R15雖然可以用作通用寄存器,但是有一些指令在使用R15時(shí)存在特殊限制,若不注意,執(zhí)行的結(jié)果將是不可預(yù)料的。
(2)?CPSR。CPSR(當(dāng)前程序狀態(tài)寄存器)在所有的模式下都是可以讀/寫的。它主要包含條件標(biāo)志、中斷標(biāo)志、當(dāng)前處理器的模式、其他的一些狀態(tài)和控制標(biāo)志。
CPSR的格式如下:
①條件標(biāo)志包括N、Z、C、V。
N表示Negative,負(fù)標(biāo)志。
Z表示Zero,零標(biāo)志。
C表示Carry,進(jìn)位標(biāo)志。
V表示overflow,溢出標(biāo)志。
②中斷標(biāo)志包括I和F。
I置1表示禁止IRQ中斷的響應(yīng),置0表示允許CPU響應(yīng)IRQ中斷。
F置1表示禁止FIQ中斷的響應(yīng),置0表示允許CPU響應(yīng)FIQ中斷。
③ARM/Thumb控制標(biāo)志:T。
T置0表示執(zhí)行32位的ARM指令。
T置1表示執(zhí)行16位的Thumb指令。
④模式控制位M0~M4,見表2-2。表2-2模式控制位M0~M4
M[4:0]模式可用寄存器0b10000UserPC,R14~R0,CPSR0b10001FIQPC,R14_fiq~R8fiq,R7~R0,CPSR,SPSR_fiq0b10010IRQPC,R14_irq,R13_irq,R12~R0,CPSRSPSR_irq0b10011SupervisorPC,R14_svc,R13_svc,R12~R0,CPSRSPSR_svc0b10111AbortPC,R14_abt,R13_abt,R12~R0,CPSRSPSR_abt0b11011UndefinedPC,R14_und,R13_und,R12~R0,CPSRSPSR_und0b11111SystemPC,R14~R0,CPSR
5.指令集
CPU指令集是硬件和軟件之間的一個(gè)重要的分水嶺。根據(jù)分層的思想,指令集向上要支持編譯器,向下要方便實(shí)現(xiàn)硬件設(shè)計(jì)。ARM是典型的RISC體系,根據(jù)RISC的設(shè)計(jì)思想,其指令集的設(shè)計(jì)應(yīng)該盡可能地簡(jiǎn)單。和CISC體系相比,ARM可以通過一系列簡(jiǎn)單的指令來實(shí)現(xiàn)復(fù)雜指令的功能。
ARM的指令集包括6種典型的指令:分支指令,如B、BL等;數(shù)據(jù)處理指令,如ADD、SUB、AND等;轉(zhuǎn)移指令,如MRS、MSR等;Load-Store數(shù)據(jù)移動(dòng)指令,如LDR等;協(xié)處理器指令,如LDC、STC等;異常處理指令,如SWI等。
ARM指令集是一個(gè)非常優(yōu)秀的指令集,具有以下特點(diǎn):
(1)所有ARM指令都是32位定長(zhǎng),在內(nèi)存中以4字節(jié)邊界保存(地址最后兩位為0),這樣方便譯碼電路和流水線的實(shí)現(xiàn)。ARM內(nèi)核一般也支持一種16位的指令集Thumb。Thumb指令集的功能是32位ARM指令集的功能子集,它在處理器中仍然要擴(kuò)展為標(biāo)準(zhǔn)的32位ARM指令運(yùn)行。用戶采用16位Thumb指令集最大的好處就是可以獲得更高的代碼密度和降低功耗。
(2)?Load-Store體系結(jié)構(gòu)。ARM指令集屬于RISC體系。RISC體系的特征是:一般指令只能把內(nèi)部寄存器和立即數(shù)作為操作數(shù),只有Load-StoRe類型的數(shù)據(jù)移動(dòng)指令才可以訪問內(nèi)存,在內(nèi)存和寄存器之間轉(zhuǎn)移數(shù)據(jù)。
(3)由于硬件上有桶形(Barrel)移位器,因此ARM可以在一條指令中用一個(gè)指令周期完成一個(gè)移位操作和一個(gè)ALU(算術(shù)邏輯)操作。
(4)任何指令的高4位都是條件指示位,根據(jù)CPSR中的N、Z、C、V決定該指令是否執(zhí)行。這樣可以方便高級(jí)語言的編譯器設(shè)計(jì),很容易實(shí)現(xiàn)分支和循環(huán)。
(5)具有功能很強(qiáng)的加載和存儲(chǔ)(Load-Store)多個(gè)寄存器的指令:LDM和STM。當(dāng)發(fā)生過程調(diào)用或中斷處理時(shí),只用一條指令就能把當(dāng)前多個(gè)寄存器的內(nèi)容保護(hù)到內(nèi)存堆棧中。
6.異常
異常是由內(nèi)部或外部原因引起的。當(dāng)異常發(fā)生時(shí),CPU自動(dòng)到指定的向量地址讀取指令或地址并且執(zhí)行。
對(duì)于X86CPU,當(dāng)有異常發(fā)生時(shí),CPU到指定的向量地址讀取要執(zhí)行的程序的地址,跳轉(zhuǎn)到相應(yīng)的地址并執(zhí)行;而對(duì)于ARMCPU,當(dāng)有異常發(fā)生時(shí),CPU通過向量地址讀取指令并執(zhí)行,也就是說,ARM的向量地址存放的是一條指令(一般是一條跳轉(zhuǎn)指令)。
ARM將引起異常的類型分為7種,如表2-3所列。表2-3ARM的異常類型
異常種類模式優(yōu)先級(jí)一般向量地址高向量地址ResetSupervisor10x000000000xFFFF0000UndefinedInstructionUndefined60x000000040xFFFF0004SoftwareInterruptSupervisor60x000000080xFFFF0008PtefetchAbortAbort50x0000000C0xFFFF000CDataAbortAbort20x000000100xFFFF0010IRQ(interrupt)IRQ40x000000180xFFFF0018FIQ(fastinterrupt)FIQ30x0000001C0xFFFF001C
7.內(nèi)存和I/O地址
ARM的尋址空間是線性地址空間,最大為4?G。ARM支持大端和小端的內(nèi)存數(shù)據(jù)方式,可以通過硬件的方式設(shè)置端模式。
I/O端口的編址方法(即地址安排方式)有兩種:I/O映射編址和存儲(chǔ)器映射編址。
(1)?I/O映射編址。如圖2-2所示,I/O映射編址采用I/O端口與內(nèi)存單元分開編址,互不影響。I/O單元與內(nèi)存單元都有自己獨(dú)立的地址空間,通過專門的輸入指令(IN)和輸出指令(OUT)來完成I/O操作。其優(yōu)點(diǎn)是I/O單元不占用內(nèi)存空間,易區(qū)分I/O程序;缺點(diǎn)是只用I/O指令訪問I/O端口,功能有限且要采用專用I/O周期和專用I/O控制線,使微處理器復(fù)雜化。X86體系的微處理器大多采用I/O映射編址方式。
(2)存儲(chǔ)器映射編址。如圖2-3所示,存儲(chǔ)器映射編址采用I/O端口的地址與內(nèi)存地址統(tǒng)一編址方式,I/O單元與內(nèi)存單元共享同一地址空間。這種編址方式不區(qū)分存儲(chǔ)器地址空間和I/O端口地址空間,把所有的I/O端口都當(dāng)作是存儲(chǔ)器的一個(gè)單元對(duì)待,每個(gè)接口芯片都安排一個(gè)或幾個(gè)與存儲(chǔ)器統(tǒng)一編號(hào)的地址號(hào),也不設(shè)專門的輸入/輸出指令,所有傳送和訪問存儲(chǔ)器的指令都可用來對(duì)I/O端口操作。其優(yōu)點(diǎn)是可采用豐富的內(nèi)存操作指令訪問I/O單元,無需單獨(dú)的I/O地址譯碼電路,無需專用的I/O指令;缺點(diǎn)是外設(shè)占用內(nèi)存空間,不易區(qū)分I/O程序,ARM微處理器大多采用存儲(chǔ)器映射編碼方式。圖2-2I/O映射編碼方式圖2-3存儲(chǔ)器映射編碼方式2.2ARM9微處理器簡(jiǎn)介目前市場(chǎng)上的主流ARM處理器都使用ARM7或ARM9內(nèi)核。本書所采用的博創(chuàng)公司開發(fā)平臺(tái)使用了基于ARM9核心的處理器,因此本節(jié)重點(diǎn)介紹三星S3C2410ARM9處理器。2.2.1ARM9與ARM7處理器的比較
與ARM7TDMI相比,ARM9TDMI核將處理器的功能顯著提高到更高、更強(qiáng)的水平。ARM9TDMI也支持Thumb指令集,并支持片上調(diào)試,最顯著的區(qū)別是流水線從3級(jí)增加到5級(jí)。ARM9使用5級(jí)流水線是受StrongARM流水線的啟發(fā)而設(shè)計(jì)的,并針對(duì)StrongARM的某些不足加以改進(jìn),從而獲得了更好的性能。ARM7的流水線操作如圖2-4所示。圖2-4ARM7的流水線操作到ARM7為止,上述的3級(jí)流水線性價(jià)比很高,隨著對(duì)性能的要求不斷提高,使用原有的3級(jí)流水線無法滿足要求,因此ARM9處理器使用了5級(jí)流水線,同時(shí)具有分開的指令和數(shù)據(jù)存儲(chǔ)器,減少了在每個(gè)時(shí)鐘周期內(nèi)必須完成的最大工作,進(jìn)而允許使用更高的時(shí)鐘頻率。5級(jí)流水線具體如下:
取指:從存儲(chǔ)器中取出指令,并將其放入指令流水線。
譯碼:對(duì)指令進(jìn)行譯碼。
執(zhí)行:把一個(gè)操作數(shù)移位,產(chǎn)生ALU的結(jié)果。緩沖/數(shù)據(jù):如果需要,則訪問數(shù)據(jù)存儲(chǔ)器;否則ALU的結(jié)果只是簡(jiǎn)單地緩沖一個(gè)時(shí)鐘周期,以便所有的指令具有同樣的流水線流程。
回寫:將指令產(chǎn)生的結(jié)果回寫到寄存器堆,包括任何從存儲(chǔ)器中讀取的數(shù)據(jù)。
圖2-5比較了ARM7的3級(jí)流水線和ARM9的5級(jí)流水線。該圖顯示了處理器如何在增加的流水線之間重新分配,以使時(shí)鐘頻率在相同的工藝下得到提高。圖2-5ARM7和ARM9流水線操作對(duì)比
2.2.2三星S3C2410XARM9處理器寄存器詳解
本書所采用的硬件平臺(tái)是基于ARM體系結(jié)構(gòu),由北京博創(chuàng)興業(yè)科技有限公司開發(fā)的UP-NetARM2410-S實(shí)驗(yàn)儀器。UP-NetARM2410-S的CPU為具有ARM920T內(nèi)核的三星S3c2410芯片,由于有MMU可以運(yùn)行標(biāo)準(zhǔn)的ARM-LINUX內(nèi)核。UP-NetARM2410-S及相關(guān)產(chǎn)品的資料可以訪問博創(chuàng)公司的網(wǎng)站?
獲得。本節(jié)以UP-NetARM2410-S為例,詳細(xì)介紹S3C2410XARM9處理器寄存器。
UP-NetARM2410-S開發(fā)箱的硬件配置如表2-4所示。S3C2410結(jié)構(gòu)圖如圖2-6所示。
表2-4UP-NetARM2410-S的硬件配置
配置名稱型號(hào)說明CPUARM920T結(jié)構(gòu)芯片三星S3C2410X工作頻率203
MHzFlashSAMSUNGK9F120864MNANDSDRAMHY57V561620AT-H32M×2=64MEtherNet網(wǎng)卡AX8879610/100M自適應(yīng)LCDLQ080V3DG018寸16位TFT觸摸屏SX-080-W4R-FBFM7843驅(qū)動(dòng)USB接口4個(gè)HOST/1個(gè)DEVICE由AT43301構(gòu)成USBHUBUART/IrDA2個(gè)RS232,1個(gè)RS485,1個(gè)IrDA從處理器的UART2引出AD由S3C2410芯片引出3個(gè)電位器控制輸入AUDIOIIS總線,UDA1341芯片44.1?kHz音頻擴(kuò)展卡插槽168PinEXPORT總線直接擴(kuò)展GPS_GPRS擴(kuò)展板SIMCOM的SIM300-E模塊支持雙道語音通信IDE/CF卡插座筆記本硬盤,CF卡PCMCIA和SD卡插座PS2PC鍵盤和鼠標(biāo)由ATMEGA8單片機(jī)控制IC卡座AT24CXX系列由ATMEGA8單片機(jī)控制DC/STEP電機(jī)DC由PWM控制,STEP由74HC573控制CANBUS由
MCP2510和TJA1050構(gòu)成DAMAX504一個(gè)10位DAC端口調(diào)試接口JTAG14針、20針圖2-6S3C2410X芯片結(jié)構(gòu)
S3C2410272-FBGA封裝,如圖2-7所示。圖2-7S3C2410物理封裝
ARM920T核由ARM9TDMI、存儲(chǔ)管理單元(MMU)和高速緩存三部分組成。其中,MMU可以管理虛擬內(nèi)存,高速緩存由獨(dú)立的16?KB地址和16?KB數(shù)據(jù)高速Cache組成。ARM920T有兩個(gè)內(nèi)部協(xié)處理器:CP14和CP15。CP14用于調(diào)試控制,CP15用于存儲(chǔ)系統(tǒng)控制以及測(cè)試控制。
S3C2410X芯片集成了大量的功能單元,列舉如下:
(1)內(nèi)核采用1.8?V供電,存儲(chǔ)單元采用3.3?V獨(dú)立供電,外部IO采用3.3?V獨(dú)立供電,16?KB數(shù)據(jù)Cache,16?KB指令Cache,MMU。
(2)內(nèi)置外部存儲(chǔ)器控制器(SDRAM控制和芯片選擇邏輯)。
(3)?LCD控制器(最高4K色STN和256K彩色TFT),一個(gè)LCD專用DMA。
(4)?4路帶外部請(qǐng)求線的DMA。
(5)?3個(gè)通用異步串行端口,2通道SPI。
(6)一個(gè)多主IIC總線,一個(gè)IIS總線控制器。
(7)?SD主接口版本1.0和多媒體卡協(xié)議版本2.11兼容。
(8)?2個(gè)USBHost接口,一個(gè)USBDevice(VER1.1)接口。
(9)?4個(gè)PWM定時(shí)器和一個(gè)內(nèi)部定時(shí)器。
(10)看門狗定時(shí)器。
(11)?117個(gè)通用I/O。
(12)?24個(gè)外部中斷。
(13)電源控制模式:標(biāo)準(zhǔn)、慢速、休眠、掉電。
(14)?8通道10位ADC和觸摸屏接口。
(15)帶日歷功能的實(shí)時(shí)時(shí)鐘。
(16)芯片內(nèi)置PLL。
(17)?16/32位RISC體系結(jié)構(gòu),使用ARM920TCPU核的強(qiáng)大指令集。
(18)?ARM帶MMU的先進(jìn)體系結(jié)構(gòu),支持WindowsCE、EPOC32、Linux。
(19)指令緩存(Cache)、數(shù)據(jù)緩存、寫緩沖和物理地址TAGRAM,減小了對(duì)主存儲(chǔ)器帶寬和性能的影響。
(20)?ARM920TCPU核支持ARM調(diào)試體系結(jié)構(gòu)。
(21)內(nèi)部先進(jìn)的位控制器總線(AMBA2.0、AHB/APB)。系統(tǒng)管理方面的特點(diǎn)如下:
(1)小端/大端支持。
(2)地址空間:每個(gè)BANK為128?MB(全部為1?GB)。
(3)每個(gè)BANK可編程為8/16/32位數(shù)據(jù)總線。
(4)?BANK0~BANK6為固定起始地址。
(5)?BANK7可編程BANK的起始地址和大小。
(6)共有8個(gè)存儲(chǔ)器BANK。
(7)?6個(gè)存儲(chǔ)器BANK用于ROM、SRAM及其他。
(8)?2個(gè)存儲(chǔ)器BANK用于ROM、SRAM及同步DRAM。
(9)每個(gè)存儲(chǔ)器BANK可編程存取周期。
(10)支持等待信號(hào),用以擴(kuò)展總線周期。
(11)支持SDRAM掉電模式下的自刷新。
(12)支持不同類型的ROM,如用于啟動(dòng)NOR/NANDFlash、EEPROM及其他。
在時(shí)鐘方面,S3C2410X芯片集成了一個(gè)具有日歷功能的RTC和具有PLL(MPLL和UPLL)的芯片時(shí)鐘發(fā)生器。MPLL產(chǎn)生主時(shí)鐘,能夠使處理器工作頻率最高達(dá)到203?MHz。這個(gè)工作頻率能夠使處理器輕松運(yùn)行WinCE、Linux等操作系統(tǒng),以及進(jìn)行較為復(fù)雜的信息處理。UPLL產(chǎn)生實(shí)現(xiàn)主從USB功能的時(shí)鐘。
S3C2410X將系統(tǒng)的存儲(chǔ)空間分成8組(BANK),每組的大小是128?MB,共1?GB。BANK0~BANK6的開始地址是固定的,用于ROM或SRAM。BANK6和BANK7用于ROM、SRAM或SDRAM,這兩個(gè)組可編程且大小相同。BANK7的開始地址是BANK6的結(jié)束地址,靈活可變。所有內(nèi)存塊的訪問周期都可編程。S3C2410X采用nGCS[7:0],8個(gè)通用片選信號(hào)選擇這些組。
S3C2410X支持從NANDFlash啟動(dòng),NANDFlash具有容量大、比NORFlash價(jià)格低等特點(diǎn)。系統(tǒng)采用NANDFlash與SDRAM組合,可以獲得非常高的性價(jià)比。S3C2410X具有三種啟動(dòng)方式,可通過OM[1:0]管腳進(jìn)行選擇:
OM[1:0]=00時(shí)處理器從NANDFlash啟動(dòng)
OM[1:0]=01時(shí)處理器從16位ROM啟動(dòng)
OM[1:0]=10時(shí)處理器從32位ROM啟動(dòng)
用戶可以將引導(dǎo)代碼和操作系統(tǒng)鏡像存放在外部的NANDFlash中,并從NANDFlash啟動(dòng)。當(dāng)處理器在這種模式下電復(fù)位時(shí),內(nèi)置的NANDFlash將訪問控制接口,并將引導(dǎo)代碼自動(dòng)加載到內(nèi)部SRAM(此時(shí)該SRAM定位于起始地址空間0x00000000,容量為4?KB)并且運(yùn)行。之后,SRAM中的引導(dǎo)程序?qū)⒉僮飨到y(tǒng)鏡像加載到SDRAM中,操作系統(tǒng)就能夠在SDRAM中運(yùn)行。啟動(dòng)完畢后,4?KB的啟動(dòng)SRAM就可以用于其他用途。
如果從其他方式啟動(dòng),啟動(dòng)ROM就要定位于內(nèi)存的起始地址空間0x00000000,處理器直接在ROM上運(yùn)行啟動(dòng)程序,而4?KB的啟動(dòng)SRAM被定位于內(nèi)存地址的0x40000000處。
S3C2410X對(duì)于片內(nèi)的各個(gè)部件采用了獨(dú)立的電源供給方式:內(nèi)核采用1.8?V供電;存儲(chǔ)單元采用3.3?V獨(dú)立供電,對(duì)于一般SDRAM可以采用3.3?V,對(duì)于移動(dòng)SDRAM可以采用VDD=1.8/2.5?V供電;VDDQ?=3.0/3.3?V供電;I/O采用獨(dú)立3.3?V供電。
1.內(nèi)存控制器
寄存器的狀態(tài)決定硬件如何工作,所以控制某個(gè)硬件時(shí),一定要熟悉每個(gè)相關(guān)的寄存器。簡(jiǎn)單而言,S3C2410X處理器的工作頻率可達(dá)到203?MHz,該頻率是通過寄存器配置獲得的。開發(fā)人員通過修改內(nèi)部寄存器的值,可以使S3C2410X工作在不同頻率下。
下面將列出S3C2410X處理器的一些寄存器,以及這些寄存器在軟件上的定義。
1)寄存器的設(shè)置
S3C2410X的內(nèi)存控制器為外部?jī)?nèi)存訪問提供了內(nèi)存控制信號(hào)。
(1)總線寬度和等待控制寄存器見表2-5。表2-5總線寬度和等待控制寄存器
寄存器地址讀/寫說明復(fù)位后的值BWSCON0x48000000讀/寫總線寬度和等待控制寄存器0x000000
(2)組控制寄存器見表2-6。表2-6組控制寄存器
寄存器地址讀/寫說明復(fù)位后的值BANKCON00x48000004讀/寫B(tài)ANK0控制寄存器0x0700BANKCON10x48000008讀/寫B(tài)ANK1控制寄存器0x0700BANKCON20x4800000c讀/寫B(tài)ANK2控制寄存器0x0700BANKCON30x48000010讀/寫B(tài)ANK3控制寄存器0x0700BANKCON40x48000014讀/寫B(tài)ANK4控制寄存器0x0700BANKCON50x48000018讀/寫B(tài)ANK5控制寄存器0x0700BANKCON60x4800001c讀/寫B(tài)ANK6控制寄存器0x18008BANKCON70x48000020讀/寫B(tài)ANK7控制寄存器0x18008
(3)?REFRESH控制寄存器見表2-7。表2-7REFRESH控制寄存器寄存器地址讀/寫說明復(fù)位后的值REFRESH0x48000024讀/寫SDRAM控制寄存器0xac0000
(4)?BANKSIZE寄存器見表2-8。表2-8BANKSIZE寄存器寄存器地址讀/寫說明復(fù)位后的值BANKSIZE0x48000028讀/寫可變的組大小寄存器0x0(5)?SDRAM模式寄存器(MRSR)見表2-9。表2-9SDRAM模式寄存器寄存器地址讀/寫說明復(fù)位后的值MRSRB60x48000028讀/寫B(tài)ANK6的模式設(shè)置寄存器xxxMRSRB70x48000028讀/寫B(tài)ANK7的模式設(shè)置寄存器xxx
2)寄存器的定義
ViVi的s3c2410.h文件中定義了上述寄存器的值,具體如下:
/*MemoryController*/
#defineMEM_CTL_BASE0x48000000
#definebMEMCTL(Nb)__REGl(MEM_CTL_BASE+
(Nb))
/*Offset*/
#defineoBWSCON
0x00
/*R/W,Buswidthand
waitstatusctrlreg.*/#defineoBANKCON00x04
/*R/W,Bank0controlreg.*/
#defineoBANKCONl0x08
/*R/W,Banklcontrolreg.*/
#defineoBANKCON20x0C
/*R/W,Bank2controlfeg.*/
#defineoBANKCON30xl0
/*R/W,Bank3controlreg.*/
#defineoBANKCON40xl4/*R/W,Bank4controlreg.*/
#defineoBANKCON50xl8/*R/W,Bank5controlreg.*/
#defineoBANKCON60xlC/*R/W,Bank6controlreg.*/
#defineoBANKCON70x20/*R/W,Bank7controlreg.*/
#defineoREFRESH0x24/*R/W,SDRAMrefreshcontrolregister*/#defineoBANKSIZE0x28/*R/W,FlexibleBank
sizeregister*/
#defineoMRSRB60x2C/*R/W,Moderegisterset
registerBank6*/
#defineoMRSRB70x30/*R/W,ModCregisterset
registerBank7*/
/*Registers*/
#defineBWSCON bMEMCTL(oBWSCON)
#defineBANKCON0
bMEMCTL(oBANKCON0)
#defineBANKCON1bMEMCTL(oBANKCON1)
#defineBANKCON2
bMEMCTL(oBANKCON2)
#defineBANKCON3
bMEMCTL(oBANKCON3)#defineBANKCON4 bMEMCTL(oBANKCON4)
#defineBANKCON5 bMEMCTL(oBANKCON5)
#defineBANKCON6 bMEMCTL(oBANKCON6)
#defineBANKCON7 bMEMCTL(oBANKCON7)
#defineREFRESH bMEMCTL(oREFRESH)
#defineBANKSIZE bMEMCTL(oBANKSIZE)
#defineMRSRB6 bMEMCTL(oMRSRB6)
#defineMRSRB7 bMEMCTL(oMRSRB7)
2.NANDFlash控制器
S3C2410X處理器的啟動(dòng)代碼可以在外部的NANDFlash上執(zhí)行。啟動(dòng)時(shí),NANDFlash的前4?KB(地址為0x00000000,OM[1:0]=0)將被裝載到SDRAM中被稱做Steppingstone的地址中,然后開始執(zhí)行這段代碼。啟動(dòng)以后,該4?KB的空間可用做其他用途。訪問流程如圖2-8所示。圖2-8NANDFlash訪問流程自動(dòng)啟動(dòng)模式如下:
●復(fù)位。
●把NANDFlash的前4?KB復(fù)制到Steppingstone處。
●?Steppingstone映射到nGCS0。
●?CPU執(zhí)行Steppingstone中的代碼。
NANDFlash模式如下:
●通過NFCONF寄存器設(shè)置NANDFlash配置。
●把NANDFlash命令寫入NFCMD寄存器。
●把NANDFlash地址寫入NFADDR寄存器。
●通過NFSTAT寄存器檢測(cè)NANDFlash狀態(tài)時(shí)讀/寫數(shù)據(jù)。讀操作以前或者編程操作以后應(yīng)該檢查R/nB信號(hào)。
NANDFlash的內(nèi)存映射如圖2-9所示。圖2-9NANDFlash的內(nèi)存映射
1)寄存器的設(shè)置
(1)?NANDFlash配置寄存器見表2-10。表2-10NANDFlash配置寄存器寄存器地址讀/寫說明復(fù)位后的值MRSRB60x48000028讀/寫B(tài)ANK6的模式設(shè)置寄存器xxxMRSRB70x48000028讀/寫B(tài)ANK7的模式設(shè)置寄存器xxx
(2)?NANDFlash命令設(shè)置寄存器見表2-11。表2-11NANDFlash命令設(shè)置寄存器寄存器地址讀/寫說明復(fù)位后的值NFCMD0x4E000004讀/寫設(shè)置NANDFlash命令—(3)?NANDFlash地址設(shè)置寄存器見表2-12。表2-12NANDFlash地址設(shè)置寄存器寄存器地址讀/寫說明復(fù)位后的值NFADDR0x4E000008讀/寫設(shè)置NANDFlash地址—
(4)?NANDFlash數(shù)據(jù)寄存器見表2-13。表2-13NANDFlash數(shù)據(jù)寄存器寄存器地址讀/寫說明復(fù)位后的值NFDATA0x4E00000c讀/寫NANDFlash數(shù)據(jù)寄存器—
(5)?NANDFlash操作狀態(tài)寄存器見表2-14。表2-14NANDFlash操作狀態(tài)寄存器寄存器地址讀/寫說明復(fù)位后的值NFSRAT0x4E000010讀/寫NANDFlash操作狀態(tài)—
(6)?NANDFlashECC寄存器見表2-15。表2-15NANDFlashECC寄存器寄存器地址讀/寫說明復(fù)位后的值NFECC0x4E000014讀/寫NANDFlashECC寄存器—
2)寄存器的定義
和NANDFlash相關(guān)的寄存器定義在\vivi-srcVnclude
\s3c2410.h文件中(如沒有特別指出,后面提到的S3C2410H就是指該目錄下的s3c2410.h文件),具體如下:
#definebNAND_CTL(Nb)_REG(0x4e00000+(Nb))
#defineNFCONF bNAND_CTL(0x00)
#defineNFCMD bNAND_CTL(0x04)
#defineNFADDR bNAND_CTL(0x08)
#defineNFDATA bNAND_CTL(0x0c)
#defineNFSTAT bNAND_CTL(0x10)
#defineNFECC bNAND_CTL(0x14)
3.時(shí)鐘和電源管理
S3C2410X可以生成三種時(shí)鐘信號(hào),分別是CPU使用的FCLK、AHB總線使用的HCLK和APB總線使用的PCLK。同時(shí),S3C2410X有兩個(gè)鎖相環(huán),一個(gè)用于前面提到的FCLK、HCLK和PCLK,稱為MPLL;另一個(gè)用于USB設(shè)備,稱為UPLL。
1)?HCLK、PCLK和FCLK的使用
S3C2410X支持HCLK、PCLK和FCLK的分頻選擇,其比率是通過HDIVN、PDIVN寄存器控制的,見表2-16。表2-16使用HCLK、PCLK和FCLK
HDIVNPDIVNFCLKHCLKPCLK比率00FCLKFCLKFCLK1∶1∶1(默認(rèn)值)01FCLKFCLKFCLK/21∶1∶210FCLKFCLK/2FCLK/21∶2∶211FCLKFCLK/2FCLK/41∶2∶4(推薦值)
2)時(shí)鐘源的選擇
時(shí)鐘源的選擇見表2-17表2-17時(shí)鐘源的選擇
0M[3:2]MPLL狀態(tài)UPLL狀態(tài)主時(shí)鐘源USB時(shí)鐘源00ONONCrystalCrystal01ONONCrystalEXTCLK10ONONEXTCLKCrystal11ONONEXTCLKEXTCLK
S3C2410X通過四種電源管理模式有效地控制功耗。這四種模式分別是NORMAL模式、SLOW模式、IDLE模式和POWER_OFF模式。這四種模式的轉(zhuǎn)換關(guān)系如圖2-10所示。嵌入式產(chǎn)品對(duì)功耗極為敏感,特別對(duì)于手持設(shè)備來說更是如此。系統(tǒng)的功耗可以通過電源模式變化獲得很好的控制,因此掌握處理器的電源模式轉(zhuǎn)換非常重要。電源模式可以通過手冊(cè)查到,其轉(zhuǎn)換條件可以通過軟件進(jìn)行控制。一個(gè)典型的例子是手機(jī)屏幕背光:若5?s內(nèi)不按任何鍵,則關(guān)閉顯示屏的背光。圖2-10S3C2410X的電源管理模式轉(zhuǎn)換關(guān)系圖
3)寄存器的設(shè)置
(l)?LOCK計(jì)數(shù)寄存器見表2-18。表2-18LOCK計(jì)數(shù)寄存器
寄存器地址讀/寫說明復(fù)位后的值LOCKTIME0x4C000000讀/寫PLL計(jì)數(shù)器0x00FFFFFF
(2)鎖相環(huán)控制寄存器見表2-19。表2-19鎖相環(huán)控制寄存器寄存器地址讀/寫說明復(fù)位后的值MPLLCON0x4C000004讀/寫MPLL的配置寄存器0x0005C080UPLLCON0x4C000008讀/寫UPLL的配置寄存器0x00028080
(3)時(shí)鐘控制寄存器見表2-20。表2-20時(shí)鐘控制寄存器寄存器地址讀/寫說明復(fù)位后的值CLKCON0x4C00000C讀/寫時(shí)鐘信號(hào)生成的控制寄存器0x7FFF0
(4)慢時(shí)鐘控制寄存器見表2-21。表2-21慢時(shí)鐘控制寄存器寄存器地址讀/寫說明復(fù)位后的值CLKSLOW0x4C000010讀/寫SLOW時(shí)鐘的控制寄存器0x00000004
(5)時(shí)鐘分頻控制寄存器見表2-22表2-22時(shí)鐘分頻控制寄存器寄存器地址讀/寫說明復(fù)位后的值CLKDIVN0x4C000014讀/寫時(shí)鐘分頻的控制寄存器0x00000000
4)寄存器的定義
和時(shí)鐘、電源管理相關(guān)的寄存器定義在s3c2410.h文件中,具體如下:
/*ClockandPowerManagement*/
#defineCLK_CTL_BASE0x4C000000
#definebCLKCTL(Nb)
_REGl(CLK_CTL_BASE
+(Nb))
/*Offset*/
#defineoLOCKTIME
0x00/*R/W,PLLlock
timecountregister*/#defineoMPLLCON0x04/*R/W,MPLLconflguration
register*/
#defineoUPLLCON0x08/*R/W,UPLLconfiguration
register*/
#defineoCLKCON0x0C/*R/W,Clockgenerator
controlreg.*/
#defineoCLKSLOW0x10/*R/W,SlowclockcontrOl
register*/
#defineoCLKDIVN0x14/*R/W,Clockdividercontrol
*/
/*Registers*/
#defineLOCKTIME bCLKCTL(oLOCKTIME)
#defineMPLLCON bCLKCTL(oMPLLCON)
#defineUPLLCON bCLKCTL(oUPLLCON)
#defineCLKCON bCLKCTL(oCLKCON)
#defineCLKSLOW bCLKCTL(oCLKSLOW)
#defineCLKDIVN bCLKCTL(oCLKDIVN)
4.DMA
S3C2410X支持四通道DMA控制器。使用DMA的最大好處是無須CPU的干預(yù)就可以進(jìn)行數(shù)據(jù)傳輸。DMA操作可以通過軟件或者硬件進(jìn)行初始化。
1)?DMA通道的請(qǐng)求源
DMA通道的請(qǐng)求源見表2-23。表2-23DMA通道的請(qǐng)求源
Source0Source1Source2Source3Source4通道0nXDREQ0UART0SDITimerUSB設(shè)備EP1通道1nXDREQ1UART1I2SSDISPI0USB設(shè)備EP2通道2I2SSDOI2SSDISDITimerUSB設(shè)備EP3通道3UART2SDISDI1TimerUSB設(shè)備EP4表中,nXDREQ0和nXDREQ1代表兩個(gè)外部源,I2SSDO和I2SSDI分別代表IIS的傳輸和發(fā)送。
2)?DMA寄存器的設(shè)置
每一個(gè)DMA通道有9個(gè)控制寄存器(4個(gè)通道共計(jì)36個(gè)寄存器),6個(gè)用來控制DMA傳輸,其他3個(gè)用來監(jiān)視DMA控制器的狀態(tài)。
(1)?DMA初始化源寄存器見表2-24。表2-24DMA初始化源寄存器
寄存器地址讀/寫說明復(fù)位后的值DISRC00x4b000000讀/寫DMA0初始化源寄存器0x00000000DISRC10x4b000040讀/寫DMA1初始化源寄存器0x00000000DISRC20x4b000080讀/寫DMA2初始化源寄存器0x00000000DISRC30x4b0000c0讀/寫DMA3初始化源寄存器0x00000000
(2)?DMA初始化源控制寄存器見表2-25。表2-25DMA初始化源控制寄存器寄存器地址讀/寫說明復(fù)位后的值DISRCC00x4b000004讀/寫DMA0初始化源控制寄存器0x00000000DISRCC10x4b000044讀/寫DMA1初始化源控制寄存器0x00000000DISRCC20x4b000084讀/寫DMA2初始化源控制寄存器0x00000000DISRCC30x4b0000c4讀/寫DMA3初始化源控制寄存器0x00000000
(3)?DMA初始化目的寄存器見表2-26。表2-26DMA初始化目的寄存器寄存器地址讀/寫說明復(fù)位后的值DIDST00x4b000008讀/寫DMA0初始化目的寄存器0x00000000DIDST10x4b000048讀/寫DMA1初始化目的寄存器0x00000000DIDST20x4b000088讀/寫DMA2初始化目的寄存器0x00000000DIDST30x4b0000c8讀/寫DMA3初始化目的寄存器0x00000000
(4)?DMA初始化目的控制寄存器見表2-27。表2-27DMA初始化目的控制寄存器寄存器地址讀/寫說明復(fù)位后的值DIDSTC00x4b00000c讀/寫DMA0初始化目的控制寄存器0x00000000DIDSTC10x4b00004c讀/寫DMA1初始化目的控制寄存器0x00000000DIDSTC20x4b00008c讀/寫DMA2初始化目的控制寄存器0x00000000DIDSTC30x4b0000cc讀/寫DMA3初始化目的控制寄存器0x00000000
(5)?DMA控制寄存器見表2-28。表2-28DMA控制寄存器寄存器地址讀/寫說明復(fù)位后的值DCON00x4b000010讀/寫DMA0控制寄存器0x00000000DCON10x4b000050讀/寫DMA1控制寄存器0x00000000DCON20x4b000090讀/寫DMA2控制寄存器0x00000000DCON30x4b0000d0讀/寫DMA3控制寄存器0x00000000
(6)?DMA狀態(tài)寄存器見表2-29。表2-29DMA狀態(tài)寄存器寄存器地址讀/寫說明復(fù)位后的值DSTAT00x4b000014讀DMA0計(jì)數(shù)寄存器000000hDSTAT10x4b000054讀DMA1計(jì)數(shù)寄存器000000hDSTAT20x4b000094讀DMA2計(jì)數(shù)寄存器000000hDSTAT30x4b0000d4讀DMA3計(jì)數(shù)寄存器000000h
(7)?DMA通用源寄存器見表2-30表2-30DMA通用源寄存器寄存器地址讀/寫說明復(fù)位后的值DCSRC00x4b000018讀DMA0通用源寄存器0x00000000DCSRC10x4b000058讀DMA1通用源寄存器0x00000000DCSRC20x4b000098讀DMA2通用源寄存器0x00000000DCSRC30x4b0000d8讀DMA3通用源寄存器0x00000000
(8)?DMA通用目的寄存器見表2-31。表2-31DMA通用目的寄存器寄存器地址讀/寫說明復(fù)位后的值DCDST00x4b00001c讀DMA0通用目的寄存器0x00000000DCDST10x4b00005c讀DMA1通用目的寄存器0x00000000DCDST20x4b00009c讀DMA2通用目的寄存器0x00000000DCDST30x4b0000dc讀DMA3通用目的寄存器0x00000000
(9)?DMA掩碼觸發(fā)寄存器見表2-32。表2-32DMA掩碼觸發(fā)寄存器寄存器地址讀/寫說明復(fù)位后的值DMASKTRIG00x4b000020讀/寫DMA0掩碼觸發(fā)寄存器000DMASKTRIG10x4b000060讀/寫DMA1掩碼觸發(fā)寄存器000DMASKTRIG20x4b0000a0讀/寫DMA2掩碼觸發(fā)寄存器000DMASKTRIG30x4b0000e0讀/寫DMA3掩碼觸發(fā)寄存器000
3)寄存器的定義
和DMA相關(guān)的寄存器定義在\include\asm-ARM\arch-s3c2410\s3c2410.h文件中,具體如下:
/*DMA*/
#defineDMA_CTL_BASE0x4b000000
#definebDMA_CTL(Nb,x)
_REG(DMA_CTL_BASE
+(0x40*Nb)+(x))
/*DMAchannel0*/
#defineDISRC0
bDMA_CTL(0,0x00)
#defineDlSRCC0bDMA_CTL(0,0x04)
#defineDIDST0 bDMA_CTL(0,0x08)
#defineDIDSTC0bDMA_CTL(0,0x0C)
#defineDCON0 bDMA_CTL(0,0x10)
#defineDSTAT0bDMA_CTL(0,0x14)
#defineDCSRC0bDMA_CTL(0,0x18)
#defineDCDST0bDMA_CTL(0,0x1C)
#defineDMTRIG0bDMA_CTL(0,0x20)
/*DMAchannell*/
#defineDISRC1 bDMA_CTL(1,0x00)
#defineDlSRCC1 bDMA_CTL(1,0x04)
#defineDIDST1 bDMA_CTL(1,0x08)
#defineDIDSTC1 bDMA_CTL(1,0x0C)
#defineDCON1 bDMA_CTL(1,0x10)
#defineDSTAT1 bDMA_CTL(1,0x14)
#defineDCSRC1 bDMA_CTL(1,0x18)
#defineDCDST1 bDMA_CTL(1,0x1C)
#defineDMTRIG1 bDMA_CTL(1,0x20)
/*DMAchannel2*/
#defineDISRC2 bDMA_CTL(2,0x00)
#defineDlSRCC2 bDMA_CTL(2,0x04)
#defineDIDST2 bDMA_CTL(2,0x08)
#defineDIDSTC2 bDMA_CTL(2,0x0C)
#defineDCON2 bDMA_CTL(2,0x10)
#defineDSTAT2 bDMA_CTL(2,0x14)
#defineDCSRC2 bDMA_CTL(2,0x18)
#defineDCDST2 bDMA_CTL(2,0x1C)
#defineDMTRIG2 bDMA_CTL(21,0x20)
/*DMAchannel3*/
#defineDISRC3 bDMA_CTL(3,0x00)
#defineDlSRCC3 bDMA_CTL(3,0x04)
#defineDIDST3 bDMA_CTL(3,0x08)
#defineDIDSTC3 bDMA_CTL(3,0x0C)
#defineDCON3 bDMA_CTL(3,0x10)
#defineDSTAT3 bDMA_CTL(3,0x14)
#defineDCSRC3 bDMA_CTL(3,0x18)
#defineDCDST3 bDMA_CTL(3,0x1C)
#defineDMTRIG3 bDMA_CTL(3,0x20)
5.輸入/輸出口
S3C2410X有117個(gè)通用I/O口(PORTA~PORTH)。這些I/O口為系統(tǒng)編程提供了極大的方便。
l)寄存器的設(shè)置
(1)?PORTA控制寄存器見表2-33。表2-33PORTA控制寄存器
寄存器地址讀/寫說明復(fù)位后的值GPACON0x56000000讀/寫配置PORTA的管腳0x7FFFFFGPADA10x56000004讀/寫PORTA數(shù)據(jù)寄存器未定義保留0x56000008—保留未定義保留0x5600000c—保留未定義
(2)?PORTB控制寄存器見表2-34。表2-34PORTB控制寄存器寄存器地址讀/寫說明復(fù)位后的值GPBCON0x56000010讀/寫配置PORTB的管腳0x0GPBDAT0x56000014讀/寫PORTB數(shù)據(jù)寄存器未定義GPBUP0x56000018讀/寫禁止PORTB上拉0x0保留0x5600001c—保留未定義
(3)?PORTC控制寄存器見表2-35。表2-35PORTC控制寄存器寄存器地址讀/寫說明復(fù)位后的值GPCCON0x56000020讀/寫配置PORTC的管腳0x0GPCDAT0x56000024讀/寫PORTC數(shù)據(jù)寄存器未定義GPCUP0x56000028讀/寫禁止PORTC上拉0x0保留0x5600002c—保留未定義
(4)?PORTD控制寄存器見表2-36表2-36PORTD控制寄存器寄存器地址讀/寫說明復(fù)位后的值GPECON0x56000040讀/寫配置PORTE的管腳0x0GPEDAT0x56000044讀/寫PORTE數(shù)據(jù)寄存器未定義GPEUP0x56000048讀/寫禁止PORTE上拉0X0保留0x5600004c—保留未定義
(5)?PORTE控制寄存器見表2-37表2-37PORTE控制寄存器寄存器地址讀/寫說明復(fù)位后的值GPECON0x56000040讀/寫配置PORTE的管腳0x0GPEDAT0x56000044讀/寫PORTE數(shù)據(jù)寄存器未定義GPEUP0x56000048讀/寫禁止PORTE上拉0X0保留0x5600004c—保留未定義
(6)?PORTF控制寄存器見表2-38表2-38PORTF控制寄存器寄存器地址讀/寫說明復(fù)位后的值GPFCON0x56000050讀/寫配置PORTF的管腳0x0GPFDAT0x56000054讀/寫PORTF數(shù)據(jù)寄存器未定義GPFUP0x56000058讀/寫禁止PORTF上拉0X0保留0x5600005c—保留未定義
(7)?PORTG控制寄存器見表2-39。表2-39PORTG控制寄存器寄存器地址讀/寫說明復(fù)位后的值GPGCON0x56000060讀/寫配置PORTG的管腳0x0GPGDAT0x56000064讀/寫PORTG數(shù)據(jù)寄存器未定義GPGUP0x56000068讀/寫禁止PORTG上拉0X0保留0x5600006c—保留未定義
(8)?PORTH控制寄存器見表2-40。表2-40PORTH控制寄存器寄存器地址讀/寫說明復(fù)位后的值GPHCON0x56000070讀/寫配置PORTH的管腳0x0GPHDAT0x56000074讀/寫PORTH數(shù)據(jù)寄存器未定義GPHUP0x56000078讀/寫禁止PORTH上拉0X0保留0x5600007c—保留未定義
(9)其他控制寄存器見表2-41。表2-41其他控制寄存器寄存器地址讀/寫說明復(fù)位后的值MISCCR0x56000080讀/寫其他0x10330
(10)?DCLK控制寄存器見表2-42。表2-42DCLK控制寄存器寄存器地址讀/寫說明復(fù)位后的值DCLKCON0x56000084讀/寫DCLK0/1寄存器0x0
(11)外部中斷控制寄存器見表2-43。表2-43外部中斷控制寄存器寄存器地址讀/寫說明復(fù)位后的值EXTINT00x56000088讀/寫外部中斷控制寄存器00x0EXTINT10x5600008c讀/寫外部中斷控制寄存器10x0EXTINT20x56000090讀/寫外部中斷控制寄存器20x0
(l2)外部中斷過濾寄存器見表2-44。表2-44外部中斷過濾寄存器寄存器地址讀/寫說明復(fù)位后的值EINTF
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- GB/T 16895.3-2024低壓電氣裝置第5-54部分:電氣設(shè)備的選擇和安裝接地配置和保護(hù)導(dǎo)體
- 2024年起重設(shè)備出口合同模板國(guó)際標(biāo)準(zhǔn)條款3篇
- 2025標(biāo)準(zhǔn)建筑材料質(zhì)量檢測(cè)采購(gòu)合同3篇
- 2智能語音電子病歷系統(tǒng)(2024年)開發(fā)合同
- 2024影視作品海外發(fā)行與版權(quán)交易合同
- 2024年股東協(xié)議:公司控制權(quán)及決策機(jī)制
- 2025年度GRC構(gòu)件生產(chǎn)與裝配技術(shù)創(chuàng)新合同3篇
- 2024消防工程設(shè)計(jì)與安裝一體化服務(wù)合同5篇
- 職業(yè)學(xué)院固定資產(chǎn)購(gòu)置項(xiàng)目方案
- 個(gè)人電動(dòng)車租賃合同(2024版)一
- GB 4053.2-2009固定式鋼梯及平臺(tái)安全要求第2部分:鋼斜梯
- GB 28261-2012安全氣囊氣體發(fā)生器用點(diǎn)火具生產(chǎn)安全技術(shù)條件
- 通力電梯培訓(xùn)教材:《LCE控制系統(tǒng)課程》
- RT qPCR(實(shí)時(shí)熒光定量PCR)課件
- 品管圈PDCA持續(xù)質(zhì)量改進(jìn)提高靜脈血栓栓塞癥規(guī)范預(yù)防率
- 醫(yī)院發(fā)熱門診工作考核表
- 陜西省榆林市各縣區(qū)鄉(xiāng)鎮(zhèn)行政村村莊村名居民村民委員會(huì)明細(xì)
- 螺桿空壓機(jī)作業(yè)指導(dǎo)書
- 中國(guó)智能物聯(lián)網(wǎng)(AIoT)研究報(bào)告
- 江蘇新海石化有限公司廢氣治理項(xiàng)目環(huán)境影響報(bào)告書
- 6.8相遇問題(課件) 數(shù)學(xué)四年級(jí)下冊(cè)(共15張PPT)人教版
評(píng)論
0/150
提交評(píng)論