版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、脈寬調(diào)制器與通用定時(shí)器畢業(yè)論文中英文資料外文翻譯文獻(xiàn)ARM Cortex-M3脈寬調(diào)制器 (PWM)與通用定時(shí)器1.PWM脈寬調(diào)制(PWM)是一項(xiàng)功能強(qiáng)大的技術(shù),它是一種對(duì)模擬信號(hào)電平進(jìn)行數(shù)字化編碼的方法。在脈寬調(diào)制中使用高分辨率計(jì)數(shù)器來產(chǎn)生方波,并且可以通過調(diào)整方波的占空比來對(duì)模擬信號(hào)電平進(jìn)行編碼。PWM通常使用在開關(guān)電源(switching power)和電機(jī)控制中。StellarisPWM模塊由 3個(gè) PWM發(fā)生器模塊 1個(gè)控制模塊組成。每個(gè) PWM發(fā)生器模塊包含1個(gè)定時(shí)器(16位遞減或先遞增后遞減計(jì)數(shù)器),2個(gè)PWM比較器,PWM信號(hào)發(fā)生器,死區(qū)發(fā)生器和中斷/ADC-觸發(fā) 選擇器。而控
2、制模塊決定了PWM信號(hào)的極性,以及將哪個(gè)信號(hào)傳遞到管腳。每個(gè) PWM發(fā)生器模塊產(chǎn)生兩個(gè)PWM信號(hào),這兩個(gè)PWM信號(hào)可以是獨(dú)立的信號(hào)(基于同一定時(shí)器因而頻率相同的獨(dú)立信號(hào)除外),也可以是一對(duì)插入了死區(qū)延遲的互補(bǔ)(complementary)信號(hào)。這些PWM發(fā)生模塊的輸出信號(hào)在傳遞到器件管腳之前由輸出控制模塊管理。StellarisPWM模塊具有極大的靈活性。它可以產(chǎn)生簡單的PWM信號(hào),如簡易充電泵需要的信號(hào);也可以產(chǎn)生帶死區(qū)延遲的成對(duì)PWM信號(hào),如供半-H橋(half-H bridge)驅(qū)動(dòng)電路使用的信號(hào)。3個(gè)發(fā)生器模塊也可產(chǎn)生3相反相器橋所需的完整6通道門控。PWM定時(shí)器每個(gè)PWM發(fā)生器的定時(shí)
3、器都有兩種工作模式:遞減計(jì)數(shù)模式或先遞增后遞減計(jì)數(shù)模式。在遞減計(jì)數(shù)模式中,定時(shí)器從裝載值開始計(jì)數(shù),計(jì)數(shù)到零時(shí)又返回到裝載值并繼續(xù)遞減計(jì)數(shù)。在先遞增后遞減計(jì)數(shù)模式中,定時(shí)器從0開始往上計(jì)數(shù),一直計(jì)數(shù)到裝載值,然后從裝載值遞減到零,接著再遞增到裝載值,依此類推。通常,遞減計(jì)數(shù)模式是用來產(chǎn)生左對(duì)齊或右對(duì)齊的PWM信號(hào),而先遞增后遞減計(jì)數(shù)模式是用來產(chǎn)生中心對(duì)齊的PWM信號(hào)。PWM定時(shí)器輸出3個(gè)信號(hào),這些信號(hào)在生成PWM信號(hào)的過程中使用:方向信號(hào)(在遞減計(jì)數(shù)模式中,該信號(hào)始終為低電平,在先遞增后遞減計(jì)數(shù)模式中,則是在低高電平之間切換);當(dāng)計(jì)數(shù)器計(jì)數(shù)值為0時(shí),一個(gè)寬度等于時(shí)鐘周期的高電平脈沖;當(dāng)計(jì)數(shù)器計(jì)數(shù)
4、值等于裝載值時(shí),一個(gè)寬度等于時(shí)鐘周期的高電平脈沖。注:在遞減計(jì)數(shù)模式中,零脈沖之后緊跟著一個(gè)裝載脈沖。PWM比較器每個(gè)PWM發(fā)生器含兩個(gè)比較器,用于監(jiān)控計(jì)數(shù)器的值;當(dāng)比較器的值與計(jì)數(shù)器的值相等時(shí),比較器輸出寬度為單時(shí)鐘周期的高電平脈沖。在先遞增后遞減計(jì)數(shù)模式中,比較器在遞增和遞減計(jì)數(shù)時(shí)都要進(jìn)行比較,因此必須通過計(jì)數(shù)器的方向信號(hào)來限定。這些限定脈沖在生成PWM信號(hào)的過程中使用。如果任一比較器的值大于計(jì)數(shù)器的裝載值,則該比較器永遠(yuǎn)不會(huì)輸出高電平脈沖。 PWM信號(hào)發(fā)生器PWM發(fā)生器捕獲這些脈沖(由方向信號(hào)來限定),并產(chǎn)生兩個(gè)PWM信號(hào)。在遞減計(jì)數(shù)模式中,能夠影響PWM信號(hào)的事件有4個(gè):零、裝載、匹配
5、A遞減、匹配B遞減。在先遞增后遞減計(jì)數(shù)模式中,能夠影響PWM信號(hào)的事件有6個(gè):零、裝載、匹配A遞減、匹配A遞增、匹配B遞減、匹配B遞增。當(dāng)匹配A或匹配B事件與零或裝載事件重合時(shí),它們可以被忽略。如果匹配A與匹配B事件重合,則第一個(gè)信號(hào)PWMA只根據(jù)匹配A事件生成,第二個(gè)信號(hào)PWMB只根據(jù)匹配B事件生成。死區(qū)發(fā)生器PWM發(fā)生器產(chǎn)生的兩個(gè)PWM信號(hào)被傳遞到死區(qū)發(fā)生器。如果死區(qū)發(fā)生器禁能,則PWM信號(hào)只簡單地通過該模塊,而不會(huì)發(fā)生改變。如果死區(qū)發(fā)生器使能,則丟棄第二個(gè)PWM信號(hào),并在第一個(gè)PWM信號(hào)基礎(chǔ)上產(chǎn)生兩個(gè)PWM信號(hào)。第一個(gè)輸出PWM信號(hào)為帶上升沿延遲的輸入信號(hào),延遲時(shí)間可編程。第二個(gè)輸出PW
6、M信號(hào)為輸入信號(hào)的反相信號(hào),在輸入信號(hào)的下降沿和這個(gè)新信號(hào)的上升沿之間增加了可編程的延遲時(shí)間。中斷/ADC-觸發(fā) 選擇器PWM發(fā)生器還捕獲相同的4個(gè)(或6個(gè))計(jì)數(shù)器事件,并使用它們來產(chǎn)生中斷或ADC觸發(fā)信號(hào)。用戶可以選擇這些事件中的任一個(gè)或一組作為中斷源;只要其中一個(gè)所選事件發(fā)生就會(huì)產(chǎn)生中斷。此外,你也可以選擇相同事件、不同事件、同組事件、不同組事件作為ADC觸發(fā)源;只要其中一個(gè)所選事發(fā)生就會(huì)產(chǎn)生ADC觸發(fā)脈沖。選擇的事件不同,在PWM信號(hào)內(nèi)產(chǎn)生中斷 或ADC觸發(fā) 的位置也不同。注:中斷 和ADC 觸發(fā)都是基于原始(raw)事件的;而不考慮死區(qū)發(fā)生器在PWM信號(hào)邊沿上產(chǎn)生的延遲。同步方法具有全
7、局復(fù)位功能,該功能可同時(shí)復(fù)位PWM發(fā)生器中的任何或全部計(jì)數(shù)器。如果多個(gè)PWM發(fā)生器使用相同的計(jì)數(shù)器裝載值來配置,那么可以保證PWM發(fā)生器也具有相同的計(jì)數(shù)值(這不表示PWM發(fā)生器必須在其同步之前被配置)。這樣,通過那些信號(hào)邊沿之間的已知關(guān)系可產(chǎn)生2個(gè)以上的PWM信號(hào),因?yàn)橛?jì)數(shù)器總是具有相同的值。在PWM發(fā)生器中,要對(duì)計(jì)數(shù)器裝載值和比較器匹配值進(jìn)行更新有兩種方法。一種是立即更新,計(jì)數(shù)器計(jì)數(shù)一到零就立即使用新值。由于要等計(jì)數(shù)器計(jì)數(shù)到零才能使用新值,因而在更新過程中定義了一個(gè)約定(guaranteed)行為,避免出現(xiàn)過短或過長的PWM輸出脈沖。另一種方法是同步更新,它要等全局同步更新信號(hào)有效才使用新值
8、,同步更新信號(hào)有效時(shí),計(jì)數(shù)器一到零就立即使用新值。第二種方法可以同時(shí)對(duì)多個(gè)PWM發(fā)生器中的多項(xiàng)進(jìn)行更新,而不會(huì)在更新過程中出現(xiàn)意外的影響;所有邏輯在根據(jù)新值運(yùn)行之前都先在原來的值上運(yùn)行。 裝載和比較器匹配的更新方法可以在各個(gè)PWM發(fā)生器模塊中單獨(dú)配置。當(dāng)那些模塊中的定時(shí)器同步時(shí),通??梢栽赑WM發(fā)生器模塊中使用同步更新機(jī)制,盡管該機(jī)制正常工作時(shí)不要求這個(gè)。故障狀態(tài)影響PWM模塊的外部條件有兩個(gè);一個(gè)是故障管腳的信號(hào)輸入,另一個(gè)是由調(diào)試器引發(fā)的控制器中止。我們可以采用兩種機(jī)制來處理這些情況,一是強(qiáng)制將輸出信號(hào)變?yōu)闊o效(inactive)狀態(tài),以及/或者讓PWM定時(shí)器停止運(yùn)行。每個(gè)輸出信號(hào)都帶有一
9、個(gè)故障位。若故障位置位,則故障輸入信號(hào)將會(huì)使相應(yīng)的輸出信號(hào)變?yōu)闊o效狀態(tài)。如果無效狀態(tài)指的是信號(hào)能夠長期停留的安全狀態(tài),那么這樣可避免輸出信號(hào)在故障狀態(tài)下以危險(xiǎn)的方式驅(qū)動(dòng)外部電路。此外,故障條件還可以產(chǎn)生控制器中斷。用戶可以將PWM發(fā)生器配置為在停止條件期間停止計(jì)數(shù)。T也可以選擇讓計(jì)數(shù)器一直運(yùn)行,直到計(jì)數(shù)值為零才停止,或計(jì)數(shù)值為零時(shí)繼續(xù)計(jì)數(shù)和重裝。停止?fàn)顟B(tài)不會(huì)產(chǎn)生控制器中斷。輸出控制模塊每個(gè) PWM發(fā)生器模塊產(chǎn)生的是兩個(gè)原始PWM信號(hào),輸出控制模塊在PWM信號(hào)進(jìn)入管腳之前要對(duì)其最后的狀態(tài)進(jìn)行控制。通過一個(gè)寄存器就能夠?qū)?shí)際傳遞到管腳的PWM信號(hào)進(jìn)行修改。例如,通過對(duì)寄存器執(zhí)行寫操作來修改PWM信
10、號(hào)(而無需通過修改反饋控制回路來修改各個(gè)PWM發(fā)生器),以實(shí)現(xiàn)無電刷直流電機(jī)通信。同樣地,故障控制也能夠禁能所有的PWM信號(hào)。能夠?qū)θ我籔WM信號(hào)執(zhí)行最終的反相操作,使得默認(rèn)高電平有效的信號(hào)變?yōu)榈碗娖接行А?.通用定時(shí)器可編程定時(shí)器可對(duì)驅(qū)動(dòng)定時(shí)器輸入管腳的外部事件進(jìn)行計(jì)數(shù)或定時(shí)。Stellaris? 通用定時(shí)器模塊(GPTM) 包含 3個(gè) GPTM 模塊 (定時(shí)器0, 定時(shí)器1和定時(shí)器 2)。每個(gè)GPTM模塊包含兩個(gè)16位的定時(shí)器/計(jì)數(shù)器(稱作TimerA和TimerB),用戶可以將它們配置成獨(dú)立運(yùn)行的定時(shí)器 或事件計(jì)數(shù)器,或?qū)⑺鼈兣渲贸?個(gè)32位定時(shí)器 或一個(gè)32位實(shí)時(shí)時(shí)鐘 (RTC)。定時(shí)
11、器也可用于觸發(fā)模數(shù)(ADC) 轉(zhuǎn)換。由于所有通用定時(shí)器的觸發(fā)信號(hào)在到達(dá)ADC模塊前一起進(jìn)行或操作,因而只需使用一個(gè)定時(shí)器來觸發(fā)ADC事件。注意: 定時(shí)器2是一個(gè)內(nèi)部定時(shí)器,只能用來產(chǎn)生內(nèi)部中斷 或觸發(fā)ADC時(shí)間。通用定時(shí)器模塊是 Stellaris? 微控制器的一個(gè)定時(shí)資源。其它定時(shí)器資源還包括系統(tǒng)定時(shí)器 (SysTick)支持以下模式: 32-位定時(shí)器模式 可編程單次觸發(fā)(one-shot)定時(shí)器 可編程周期定時(shí)器 使用32.768-KHz 輸入時(shí)鐘的實(shí)時(shí)時(shí)鐘 事件的停止可由軟件來控制(RTC模式除外) 16-位定時(shí)器模式 帶8位預(yù)分頻器的通用定時(shí)器功能模塊 (僅單次觸發(fā)模式和周期模式) 可
12、編程單次觸發(fā)(one-shot)定時(shí)器 可編程周期定時(shí)器 事件的停止可由軟件來控制 16-位輸入捕獲模式 輸入邊沿計(jì)數(shù)捕獲 輸入邊沿定時(shí)捕獲 16-位PWM模式 簡單的PWM模式,可通過軟件實(shí)現(xiàn)PWM信號(hào)的輸出反相。功能描述每個(gè)GPTM模塊的主要元件包括兩個(gè)自由運(yùn)行的先遞增后遞減計(jì)數(shù)器(稱作TimerA和TimerB)、兩個(gè)16位匹配寄存器、兩個(gè)預(yù)分頻器匹配寄存器、兩個(gè)16位裝載/初始化寄存器和它們相關(guān)的控制功能。GPTM的準(zhǔn)確功能可由軟件來控制,并通過寄存器接口進(jìn)行配置。在通過軟件對(duì)GPTM進(jìn)行配置時(shí)需用到GPTM 配置 (GPTMCFG) 寄存器 、GPTM TimerA模式 (GPTMT
13、AMR) 寄存器和 GPTM TimerB 模式 (GPTMTBMR) 寄存器。當(dāng)GPTM模塊處于其中一種32位模式時(shí),該定時(shí)器只能作為32位定時(shí)器使用。但如果配置為16位模式,則GPTM的兩個(gè)16位定時(shí)器可配置為16位模式的任意組合。GPTM 復(fù)位條件GPTM模塊復(fù)位后處于未激活狀態(tài),所有控制寄存器均被清零,同時(shí)進(jìn)入默認(rèn)狀態(tài)。計(jì)數(shù)器TimerA和TimerB連同與它們對(duì)應(yīng)的裝載寄存器:GPTM TimerA 間隔裝載(GPTMTAILR) 寄存器和 GPTM TimerB 間隔裝載 (GPTMTBILR)寄存器一起初始化為0xFFFF。預(yù)分頻計(jì)數(shù)器:GPTM TimerA 預(yù)分頻(GPTMT
14、APR) 寄存器) 和GPTM TimerB 預(yù)分頻(GPTMTBPR) 寄存器初始化為0x00。位定時(shí)器工作模式介紹GPTM的3種32位定時(shí)器模式(單次觸發(fā)、周期、RTC),并對(duì)其配置進(jìn)行描述。通過向GPTM 配置 (GPTMCFG)寄存器寫入0(單次觸發(fā)/32位周期定時(shí)器模式)或1(RTC模式),可將GPTM模塊配置為32位模式。在兩種配置中,都需將某些GPTM寄存器連在一起形成偽32位寄存器。這些寄存器包括: GPTM TimerA 間隔裝載(GPTMTAILR) 寄存器 15:0, GPTM TimerB 間隔裝載(GPTMTBILR) 寄存器 15:0, GPTM TimerA(GP
15、TMTAR) 寄存器 15:0, GPTM TimerB (GPTMTBR) 寄存器 15:0, 在32位模式中,GPTM把對(duì)GPTMTAILR的32位寫訪問轉(zhuǎn)換為對(duì)GPTMTAILR和GPTMTBILR的寫訪問。這樣,寫操作最終的字順序?yàn)椋篏PTMTBILR15:0:GPTMTAILR15:0同樣,對(duì)GPTMTAR的讀操作返回的值為:GPTMTBR15:0:GPTMTAR15:032-位單次觸發(fā)/周期定時(shí)器模式在32位單次觸發(fā)和周期定時(shí)器模式中,TimerA和TimerB寄存器連在一起被配置為32位遞減計(jì)數(shù)器。然后根據(jù)寫入GPTM TimerA模式 (GPTMTAMR)寄存器 (見 167頁
16、)的 TAMR 位域的值可確定選擇的是單次觸發(fā)模式還是周期模式,此時(shí)不需要寫GPTM TimerB 模式 (GPTMTBMR) 寄存器。當(dāng)軟件對(duì)GPTM 控制 (GPTMCTL) 寄存器 (見 171頁)的TAEN位執(zhí)行寫操作時(shí),定時(shí)器從其預(yù)加載的值開始遞減計(jì)數(shù)。當(dāng)?shù)竭_(dá)0x0000.0000狀態(tài)時(shí),定時(shí)器會(huì)在下一個(gè)周期從相連的GPTMTAILR中重新裝載它的初值。如果配置為單次觸發(fā)模式,則定時(shí)器停止計(jì)數(shù)并將GPTMCTL寄存器的TAEN位清零。如果配置為周期定時(shí)器,它將繼續(xù)計(jì)數(shù)。除了重裝計(jì)數(shù)值,GPTM還在到達(dá)0x00000000狀態(tài)時(shí)產(chǎn)生中斷并輸出觸發(fā)信號(hào)。GPTM將GPTM 原始中斷狀態(tài)
17、(GPTMRIS)寄存器 中的TATORIS位置位,并保持該值直到向GPTM 中斷清零(GPTMICR) 寄存器執(zhí)行寫操作將其清零。如果GPTM 中斷屏蔽 (GPTIMR) 寄存的超時(shí)(time-out)中斷使能,則GPTM還將GPTM 屏蔽后的中斷狀態(tài) (GPTMMIS) 寄存器 的TATOMIS位置位。輸出觸發(fā)信號(hào)是一個(gè)單時(shí)鐘周期的脈沖,它在計(jì)數(shù)器剛好到達(dá)0x00000000狀態(tài)時(shí)生效,在緊接著的下一個(gè)周期失效。通過將GPTMCTL中的TAOTE位置位可將輸出觸發(fā)使能,并且可以觸發(fā)啟動(dòng)轉(zhuǎn)換(SoC)事件,如ADC轉(zhuǎn)換。如果軟件在計(jì)數(shù)器運(yùn)行過程中重裝GPTMTAILR寄存器,則計(jì)數(shù)器在下一個(gè)
18、時(shí)鐘周期裝載新值并從新值繼續(xù)計(jì)數(shù)。如果GPTMCTL寄存器的TASTALL 位有效,則定時(shí)器停止(freeze)計(jì)數(shù)直到該信號(hào)失效。32-位實(shí)時(shí)時(shí)鐘定時(shí)器模式在實(shí)時(shí)時(shí)鐘(RTC)模式中,TimerA和TimerB寄存器連在一起被配置為32位遞增計(jì)數(shù)器。在首次選擇RTC模式時(shí),計(jì)數(shù)器裝載的值為0x0000.0001。后面裝載的值全都必須通過控制器寫入GPTMTimerA 匹配 (GPTMTAMATCHR) 寄存器。在RTC模式中,要求CCP0, CCP2或CCP4管腳上的輸入時(shí)鐘為32.768KHz。然后將時(shí)鐘信號(hào)分頻為1Hz,將其傳送給32位計(jì)數(shù)器的輸入端。在軟件寫GPTMCTL中的TAEN位
19、時(shí),計(jì)數(shù)器從其預(yù)裝載的值0x0000.0001開始遞增計(jì)數(shù)。在當(dāng)前計(jì)數(shù)值與GPTMTAMATCHR中的預(yù)裝載值匹配時(shí),計(jì)數(shù)器返回到0x0000.0000并繼續(xù)計(jì)數(shù),直到出現(xiàn)硬件復(fù)位或被軟件禁能(TAEN位清零),計(jì)數(shù)停止。當(dāng)計(jì)數(shù)值與預(yù)裝載值匹配時(shí),GPTM讓GPTMRIS中的RTCRIS位有效。如果GPTIMR中的RTC中斷使能,那么GPTM 也會(huì)將GPTMISR中的 RTCMIS位置位并產(chǎn)生一個(gè)控制器中斷。 通過寫 GPTMICR的RTCCINT位可將狀態(tài)標(biāo)志清零。如果GPTMCTL寄存器中的 TASTALL位和/或 TBSTALL 位置位,那么定時(shí)器在GPTMCTL的RTCEN位置位時(shí)不會(huì)
20、停止計(jì)數(shù)。16-位定時(shí)器的工作模式通過向GPTM配置 (GPTMCFG) 寄存器寫入0x04,可將GPTM配置為全局16位模式。本小節(jié)將描述每一個(gè)GPTM的16-位操作模式。TimerA和TimerB的模式相同,因此我們只介紹一次,并用字母n來表示這兩個(gè)定時(shí)器的寄存器。16-位單次觸發(fā)/周期定時(shí)器模式在16位單次觸發(fā)/周期定時(shí)器模式中,定時(shí)器被配置為帶可選的8位預(yù)分頻器的16位遞減計(jì)數(shù)器,預(yù)分頻器可有效地將定時(shí)器的計(jì)數(shù)范圍擴(kuò)大到24位。選擇單次觸發(fā)模式還是周期模式由寫入 GPTMTnMR寄存器中TnMR位域的值來決定。可選預(yù)分頻器中的值被加載到GPTM Timern 預(yù)分頻 (GPTMTnPR
21、)寄存器中。在軟件對(duì)GPTMCTL寄存器的TnEN位執(zhí)行寫操作時(shí),定時(shí)器從其預(yù)裝載的值開始遞減計(jì)數(shù)。一旦到達(dá)0x0000狀態(tài),定時(shí)器便在下一個(gè)周期到來時(shí)將GPTMTnILR和GPTMTnPR的值重新載入。如果配置為單次觸發(fā)模式,則定時(shí)器停止計(jì)數(shù)并將GPTMCTL寄存器的TnEN位清零。如果配置為周期定時(shí)器,它將繼續(xù)計(jì)數(shù)。在到達(dá)0x0000狀態(tài)時(shí),定時(shí)器除了重裝計(jì)數(shù)值,還產(chǎn)生中斷并輸出觸發(fā)信號(hào)。GPTM將GPTMRIS寄存器的TnTORIS位置位,并保持該值直到執(zhí)行GPTMICR寄存器寫操作將該位清零。如果GPTIMR的超時(shí)中斷使能,則GPTM還將 GPTMISR寄存器的TnTOMIS位置位并產(chǎn)
22、生控制器中斷。輸出觸發(fā)信號(hào)是一個(gè)單時(shí)鐘周期的脈沖,在計(jì)數(shù)器剛好到達(dá)0x0000狀態(tài)時(shí)生效,并在緊接著的下一個(gè)周期失效。它通過對(duì)GPTMCTL寄存器中的TnOTE位置位來使能,并且可以觸發(fā)啟動(dòng)轉(zhuǎn)換(SoC)事件如ADC轉(zhuǎn)換。如果軟件在計(jì)數(shù)器運(yùn)行過程中重裝GPTMTAILR寄存器,則計(jì)數(shù)器在下一個(gè)時(shí)鐘周期裝載新值并從新值繼續(xù)計(jì)數(shù)。如果GPTMCTL寄存器中的 TnSTALL 位被使能,那么定時(shí)器停止(freeze)計(jì)數(shù),直到該信號(hào)失效后再繼續(xù)計(jì)數(shù)。16-位輸入邊沿計(jì)數(shù)模式在邊沿計(jì)數(shù)模式中,定時(shí)器被配置為能夠捕獲3種事件類型的遞減計(jì)數(shù)器,這3種事件類型為上升沿、下降沿、或上升/下降沿。為了把定時(shí)器設(shè)
23、置為邊沿計(jì)數(shù)模式,GPTMTnMR寄存器的TnCMR 位必須設(shè)為0。定時(shí)器計(jì)數(shù)時(shí)所采用的邊沿類型由GPTMCTL寄存器的TnEVENT位域決定。在初始化過程中,需對(duì)GPTM Timern 匹配 (GPTMTnMATCHR)寄存器進(jìn)行配置,以便GPTMTnILR寄存器和GPTMTnMATCHR寄存器之間的差值等于必須計(jì)算的邊沿事件的數(shù)目。當(dāng)軟件寫GPTM控制(GPTMCTL)寄存器的TnEN位時(shí),定時(shí)器使能并用于事件捕獲。CCP管腳上每輸入一個(gè)事件,計(jì)數(shù)器的值就減1,直到事件計(jì)數(shù)的值與GPTMTnMATCHR的值匹配。這時(shí),GPTM讓GPTMRIS寄存器的CnMRIS位有效(如果中斷沒有屏蔽,則
24、也要讓CnMMIS位有效)。然后計(jì)數(shù)器使用GPTMTnILR中的值執(zhí)行重裝操作,并且由于GPTM自動(dòng)將GPTMCTL寄存器的TnEN位清零,因此計(jì)數(shù)器停止計(jì)數(shù)。一旦事件計(jì)數(shù)值滿足要求,接下來的所有事件都將被忽略, 直到通過軟件重新將TnEN使能。在邊沿定時(shí)模式中,定時(shí)器被配置為自由運(yùn)行的遞減計(jì)數(shù)器,其初始值從GPTMTnILR寄存器中加載(復(fù)位時(shí)初始化為0xFFFF)。該模式允許在上升沿或下降沿捕獲事件。通過置位GPTMTnMR寄存器的TnCMR位可將定時(shí)器置于邊沿定時(shí)模式,而定時(shí)器捕獲時(shí)采用的事件類型由GPTMCnTL寄存器的TnEVENT位域來決定。在軟件寫GPTMCTL寄存器的TnEN
25、位時(shí),定時(shí)器使能并用于事件捕獲。在檢測(cè)到所選的輸入事件時(shí),從GPTMTnR寄存器中捕獲Tn計(jì)數(shù)器的當(dāng)前值,且該值可通過控制器來讀取。 然后GPTM讓CnERIS位有效(如果中斷沒有被屏蔽,則也讓CnEMIS位有效)。在捕獲到事件之后,定時(shí)器不會(huì)停止計(jì)數(shù)。它會(huì)繼續(xù)計(jì)數(shù),直至 TnEN 位清零。當(dāng)定時(shí)器到達(dá)0x0000狀態(tài)時(shí),將GPTMnILR 寄存器中的值重新載入定時(shí)器。定時(shí)器配置為捕獲上升沿事件。每當(dāng)檢測(cè)到上升沿事件時(shí),當(dāng)前計(jì)數(shù)值便裝載到GPTMTnR寄存器中,且該值一直保持在寄存器中直到檢測(cè)到下一個(gè)上升沿(在此上升沿處,新的計(jì)數(shù)值裝載到GPTMTnR中)。16-位PWM模式GPTM支持簡單的
26、PWM生成模式。在PWM模式中,定時(shí)器配置為遞減計(jì)數(shù)器,初值由GPTMTnILR定義。通過將GPTMTnMR寄存器的TnAMS位置為0x1、TnCMR位置為0x0、TnMR位域置為0x2來使能PWM模式。在軟件寫GPTMCTL寄存器的 TnEN 位時(shí),計(jì)數(shù)器開始遞減計(jì)數(shù),直到計(jì)數(shù)值到達(dá)0x0000。在下一個(gè)計(jì)數(shù)周期,計(jì)數(shù)器將GPTMTnILR寄存器中的值重新載入,作為它的初值(如果使用了預(yù)分頻器,則還要重新裝載GPTMTnPR中的值),并繼續(xù)計(jì)數(shù)直到計(jì)數(shù)器因軟件將GPTMCTL寄存器的TnEN位清零而被禁止。在PWM模式中,不產(chǎn)生中斷或狀態(tài)位。當(dāng)計(jì)數(shù)器的值與GPTMTnILR 寄存器的值(計(jì)數(shù)
27、器的初始狀態(tài))相等時(shí),輸出PWM信號(hào)生效,當(dāng)計(jì)數(shù)器的值與GPTM Timern 匹配 寄存器 (GPTMnMATCHR)的值相等時(shí),輸出PWM信號(hào)失效。通過將GPTMCTL寄存器的TnPWML位置位,軟件可實(shí)現(xiàn)將輸出PWM信號(hào)反相的功能。Pulse Width Modulator (PWM) General-Purpose Timers1.PWMPulse width modulation (PWM) is a powerful technique for digitally encoding analog signal levels.High-resolution counters are
28、used to generate a square wave, and the duty cycle of the squarewave is modulated to encode an analog signal. Typical applications include switching power suppliesand motor control.The Stellaris PWM module consists of three PWM generator blocks and a control block. The controlblock determines the po
29、larity of the PWM signals, and which signals are passed through to the pins.Each PWM generator block produces two PWM signals that can either be independent signals(other than being based on the same timer and therefore having the same frequency) or a singlepair of complementary signals with dead-ba
30、nd delays inserted. The output of the PWM generationblocks are managed by the output control block before being passed to the device pins.The Stellaris PWM module provides a great deal of flexibility. It can generate simple PWM signals,such as those required by a simple charge pump. It can also gene
31、rate paired PWM signals withdead-band delays, such as those required by a half-H bridge driver. Three generator blocks canalso generate the full six channels of gate controls required by a 3-phase inverter bridge.PWM TimerThe timer in each PWM generator runs in one of two modes: Count-Down mode or C
32、ount-Up/Downmode. In Count-Down mode, the timer counts from the load value to zero, goes back to the loadvalue, and continues counting down. In Count-Up/Down mode, the timer counts from zero up to the load value, back down to zero, back up to the load value, and so on. Generally, Count-Down mode is
33、used for generating left- or right-aligned PWM signals, while the Count-Up/Down mode is usedfor generating center-aligned PWM signals.The timers output three signals that are used in the PWM generation process: the direction signal(this is always Low in Count-Down mode, but alternates between Low an
34、d High in Count-Up/Down mode), a single-clock-cycle-width High pulse when the counter is zero, and a single-clock-cycle-width High pulse when the counter is equal to the load value. Note that in Count-Down mode, the zeropulse is immediately followed by the load pulse.PWM ComparatorsThere are two com
35、parators in each PWM generator that monitor the value of the counter; when either match the counter, they output a single-clock-cycle-width High pulse. When in Count-Up/Down mode, these comparators match both when counting up and when counting down; they are therefore qualified by the counter direct
36、ion signal. These qualified pulses are used in the PWM generation process. If either comparator match value is greater than the counter load value, then that comparator never outputs a High pulse.Figure 15-3 on page 493 shows the behavior of the counter and the relationship of these pulses when the
37、counter is in Count-Down mode. Figure 15-4 on page 493 shows the behavior of the counter and the relationship of these pulses when the counter is in Count-Up/Down mode.PWM Signal GeneratorThe PWM generator takes these pulses (qualified by the direction signal), and generates two PWM signals. In Coun
38、t-Down mode, there are four events that can affect the PWM signal: zero, load,match A down, and match B down. In Count-Up/Down mode, there are six events that can affect the PWM signal: zero, load, match A down, match A up, match B down, and match B up. The matchA or match B events are ignored when
39、they coincide with the zero or load events. If the match A and match B events coincide, the first signal, PWMA, is generated based only on the match A event,and the second signal, PWMB, is generated based only on the match B event.Dead-Band GeneratorThe two PWM signals produced by the PWM generator
40、are passed to the dead-band generator. If disabled, the PWM signals simply pass through unmodified. If enabled, the second PWM signal is lost and two PWM signals are generated based on the first PWM signal. The first output PWM signal is the input signal with the rising edge delayed by a programmabl
41、e amount. The second output PWM signal is the inversion of the input signal with a programmable delay added between the falling edge of the input signal and the rising edge of this new signal.Interrupt/ADC-Trigger SelectorThe PWM generator also takes the same four (or six) counter events and uses th
42、em to generate an interrupt or an ADC trigger. Any of these events or a set of these events can be selected as a source for an interrupt; when any of the selected events occur, an interrupt is generated. Additionally, the same event, a different event, the same set of events, or a different set of e
43、vents can be selectedas a source for an ADC trigger; when any of these selected events occur, an ADC trigger pulse is generated. The selection of events allows the interrupt or ADC trigger to occur at a specific position within the PWM signal. Note that interrupts and ADC triggers are based on the r
44、aw events; delays in the PWM signal edges caused by the dead-band generator are not taken into account.Synchronization MethodsThere is a global reset capability that can synchronously reset any or all of the counters in the PWM generators. If multiple PWM generators are configured with the same coun
45、ter load value, this can be used to guarantee that they also have the same count value (this does imply that the PWM generators must be configured before they are synchronized). With this, more than two PWM signals can be produced with a known relationship between the edges of those signals since th
46、e counters always have the same values.The counter load values and comparator match values of the PWM generator can be updated in two ways. The first is immediate update mode, where a new value is used as soon as the counter reaches zero. By waiting for the counter to reach zero, a guaranteed behavi
47、or is defined, and overly short or overly long output PWM pulses are prevented.The other update method is synchronous, where the new value is not used until a global synchronized update signal is asserted, at which point the new value is used as soon as the counter reaches zero. This second mode all
48、ows multiple items in multiple PWM generators to be updated simultaneously without odd effects during the update; everything runs from the old values until a point at which they all run from the new values. The Update mode of the load and comparator match values can be individually configured in eac
49、h PWM generator block. It typically makes sense to use the synchronous update mechanism across PWM generator blocks when the timers in those blocks are synchronized, though this is not required in order for this mechanism to function properly.Fault ConditionsThere are two external conditions that af
50、fect the PWM block; the signal input on the Fault pin and the stalling of the controller by a debugger. There are two mechanisms available to handle such conditions: the output signals can be forced into an inactive state and/or the PWM timers can be stopped.Each output signal has a fault bit. If se
51、t, a fault input signal causes the corresponding output signal to go into the inactive state. If the inactive state is a safe condition for the signal to be in for an extended period of time, this keeps the output signal from driving the outside world in a dangerous manner during the fault condition
52、. A fault condition can also generate a controller interrupt.Each PWM generator can also be configured to stop counting during a stall condition. The user can select for the counters to run until they reach zero then stop, or to continue counting and reloading.A stall condition does not generate a c
53、ontroller interrupt.Output Control BlockWith each PWM generator block producing two raw PWM signals, the output control block takes care of the final conditioning of the PWM signals before they go to the pins. Via a single register,the set of PWM signals that are actually enabled to the pins can be
54、modified; this can be used, for example, to perform commutation of a brushless DC motor with a single register write (and without modifying the individual PWM generators, which are modified by the feedback control loop). Similarly,fault control can disable any of the PWM signals as well. A final inv
55、ersion can be applied to any ofthe PWM signals, making them active Low instead of the default active High.General-Purpose TimersProgrammable timers can be used to count or time external events that drive the Timer input pins.The Stellaris? General-Purpose Timer Module (GPTM) contains three GPTM bloc
56、ks (Timer0, Timer1,and Timer 2). Each GPTM block provides two 16-bit timers/counters (referred to as TimerA andTimerB) that can be configured to operate independently as timers or event counters, or configuredto operate as one 32-bit timer or one 32-bit Real-Time Clock (RTC).In addition, timers can
57、be used to trigger analog-to-digital conversions (ADC). The ADC triggersignals from all of the general-purpose timers are ORed together before reaching the ADC module,so only one timer should be used to trigger ADC events.The GPT Module is one timing resource available on the Stellaris? microcontrol
58、lers. Other timerresources include the System Timer (SysTick) and the PWM timer in thePWM module.The General-Purpose Timers provide the following features: Three General-Purpose Timer Modules (GPTM), each of which provides two 16-bittimers/counters. Each GPTM can be configured to operate independently: As a single 32-bit timer As one 32-bit Real-Time Clock (RTC) to event capture For Pulse Width Modulation (PWM) To trigger analog-to-digital conversions 32-bit Timer modes Programmable one-shot timer Programmable periodic timer Real-Time Clock when using an external
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年財(cái)務(wù)咨詢服務(wù)條款3篇
- 2025年度智能電網(wǎng)關(guān)鍵設(shè)備變壓器安裝及運(yùn)維服務(wù)承包合同3篇
- 2025年度倉儲(chǔ)設(shè)施建設(shè)與運(yùn)營維護(hù)合同3篇
- 2024版貨運(yùn)運(yùn)輸合同范文
- 世界地理分區(qū)習(xí)題《帶答案》大全
- 2025年度數(shù)字工廠廠房出租居間服務(wù)協(xié)議3篇
- 馬良三夢(mèng)好詞好句好段讀后感
- 2024年智能暖通系統(tǒng)節(jié)能優(yōu)化改造工程合同3篇
- 浙江水利水電學(xué)院《面向?qū)ο蟮某绦蛟O(shè)計(jì)》2023-2024學(xué)年第一學(xué)期期末試卷
- 湖南環(huán)境生物職業(yè)技術(shù)學(xué)院《生物醫(yī)用高分子村料》2023-2024學(xué)年第一學(xué)期期末試卷
- 車輛駕駛業(yè)務(wù)外包服務(wù)方案
- 工業(yè)機(jī)器人控制器:FANUC R-30iB:機(jī)器人實(shí)時(shí)監(jiān)控與數(shù)據(jù)采集技術(shù)教程
- 2024年9月2390國開電大??啤豆糯鷿h語(1)》期末考試試題及答案
- 湖北省2024年村干部定向考試真題
- 二年級(jí)上冊(cè)數(shù)學(xué)解決問題100道(滿分必刷)
- CH-Z9031-2021室內(nèi)三維測(cè)圖數(shù)據(jù)獲取與處理技術(shù)規(guī)程
- 2022鋼橋面環(huán)氧瀝青混凝土鋪裝施工技術(shù)規(guī)程
- 勞務(wù)服務(wù)合作協(xié)議書范本
- 駕駛員勞務(wù)派遣應(yīng)急預(yù)案
- 中醫(yī)五臟心完整版本
- 聚合工藝作業(yè)安全培訓(xùn)課件
評(píng)論
0/150
提交評(píng)論