有人使用STM32H7系列芯片開發產品,其中用到TIM1/TIM8兩個定時器做PWM輸出,并且TIM1/TIM8建立起主從關系同時啟動,使用完全相同的時間參數和PWM配置,各自輸出3路同頻同相的PWM驅動信號。不過,在使用過程中,可能時不時地需要暫停兩個定時器的輸出,等到適當時機再啟動全部通道PWM輸出。可他發現,2個定時器的PWM輸出剛開始還同步得好好的,但隨著程序的運行,一段時間后,來自兩個定時器的PWM輸出明顯不再同步了,而是出現了相移。
我這里各選TIM1/TIM8的CH1來做說明。比方說,程序剛開始運行時,來自2個定時器的2個通道PWM輸出是完全同步的,如下圖所示:
LATER……
經過一段時間后,2個定時器的PWM輸出變得有相差了,就像下面的樣子,兩個定時器的PWM輸出相差隨著程序的運行還在不停變化,輸出不再有同步可言。
經過測試發現,如果沒有中途時不時的通道啟、停動作,2個定時器的PWM輸出倒是一直同步得很好。也就是說,中途不時地對輸出通道的啟、停導致了PWM輸出的相移。
查看了他的相關操作代碼,大致是這樣操作的。【下面是我參考客戶寫法重寫的驗證代碼。TIM8是MASTER,TIM1是SLAVE。功能簡單、清晰,就是讓來自TIM1和TIM8的2個通道先運行一會,然后暫停一會,這樣循環。下面代碼重點看while(1)循環體。】
HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_1); //Start PWM of TIM1_CH1 HAL_TIM_PWM_Start(&htim8, TIM_CHANNEL_1); //Start PWM of TIM8_CH1 。。。。。。 while (1) { HAL_TIM_PWM_Stop(&htim1, TIM_CHANNEL_1);//Stop PWM of TIM1_CH1 HAL_TIM_PWM_Stop(&htim8, TIM_CHANNEL_1);//Stop PWM of TIM8_CH1 HAL_Delay(2000); HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_1); //Start PWM of TIM1_CH1 HAL_TIM_PWM_Start(&htim8, TIM_CHANNEL_1); //Start PWM of TIM8_CH1 HAL_Delay(2000); }
使用上面測試代碼運行一陣子后,本來同步得很好的2路PWM波形就漸漸產生相移了。
這里調用的HAL_TIM_PWM_Stop()函數來關閉指定通道的PWM輸出,是有效的。不過,當我們點進該函數里面去閱讀時,該函數不僅關閉了相應通道的輸出功能,連計數器也關閉了。下面截圖是該函數的內容,其中箭頭所指是關閉定時器的計數器的代碼。
根據客戶的需求,每次關閉通道輸出只是臨時性的,每次一同把計數器也關斷似乎太過了,不是很合適的做法,明顯不必要。那么,如果我們把這個函數換成只針對定時器通道的輸出功能做關閉、開啟的函數會怎么樣呢?
在HAL庫里,有個函數就是實現此功能的:
//關閉通道輸出功能
TIM_CCxChannelCmd(TIMx, TIM_CHANNEL_1, TIM_CCx_DISABLE);
//啟用通道輸出功能
TIM_CCxChannelCmd(TIMx, TIM_CHANNEL_1, TIM_CCx_ENABLE);
我們把前面的測試代碼改換成下面的寫法再來驗證。
HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_1); //Start PWM of TIM1_CH1 HAL_TIM_PWM_Start(&htim8, TIM_CHANNEL_1); //Start PWM of TIM8_CH1 。。。。。。 while (1) { TIM_CCxChannelCmd(htim1.Instance,TIM_CHANNEL_1,TIM_CCx_DISABLE);//關閉輸出 TIM_CCxChannelCmd(htim8.Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); //關閉輸出 HAL_Delay(2000); TIM_CCxChannelCmd(htim1.Instance,TIM_CHANNEL_1,TIM_CCx_ENABLE);//啟用輸出 TIM_CCxChannelCmd(htim8.Instance,TIM_CHANNEL_1,TIM_CCx_ENABLE);//啟用輸出 HAL_Delay(2000); }
針對修改過的測試代碼進行驗證,結果發現來自2個定時器的PWM輸出同步得很好很穩定,不飄不移了。
第2種新寫法跟原寫法的最大差別就在于-----新寫法的代碼里對通道輸出做啟停操作時完全不涉及計數器的開、關, 2個TIMER的計數器自始至終就不曾受到其它干預而影響正常計數,一直在持續地、按部就班地、周期性地計數,因為完全相同的時間參數,所以2個計數器的計數也保持著很好的同步。
現在的問題是,為何第一種寫法會讓2個定時器的PWM輸出產生相移呢?
原因就出在使用HAL_TIM_PWM_Stop()函數來關閉通道輸出這個做法上,這里調用它來實現通道的關閉不合理。前面我們分析了,該函數不僅關閉通道輸出,而且還停止了相應計數器。我們看看其中的兩行關閉通道PWM輸出的代碼:
在程序里面,一前一后,即先停止TIM1的計數器,然后才停止TIM8的計數器。顯然,因為這個先后關系,導致TIM8停止時總要比TIM1多計些數。這里我們簡單點以便于溝通,假設TIM8停止計數時比TIM1多計2個數。也就是說每次對2個通道做關閉操作時,同時對2個計數器也做一次停止操作,每次對定時器的停止操作使得TIM8比TIM1多計2個數。隨著這種操作次數的增加,每次重新啟動2個定時器時,2個計數器的起點值的差距也在增加【當然,這個差距變化可能會有周期性】,最終導致2個定時器的PWM輸出產生了相移,而且相移還在不斷變化。
關于頻繁啟停通道導致2個計數器每次停止后再次啟動時的計數器起始值的差值總在變化的結論,我換個比較通俗形象的類比說法來解釋。
假設有2個運動員A和B,下圖中的紅星和綠星分別代表這兩個運動員。他倆經常一起繞圈跑步訓練,跑步速度一樣。我們現在模擬2個場景。
第一個場景,就是他倆一起從某點開始跑步,要跑就一起跑,要停就一起停。顯然,這樣的話,任何時候他倆都是在一起,物理上來看二人相對靜止。此場景對應下圖中的左邊圓圈情形。
第二個場景,還是他倆一起繞圈跑步,跑步速度始終一樣,不過這時旁邊多了個教練。當他倆從某點開始跑起來后,若要停下歇息需得到教練指令。這個教練有個習慣,每次都是先叫A停下,然后才叫B停下歇息,導致每次2個人停下歇息時,B總要比A多跑兩步,但二人每次重新起跑時又是同時的。就這樣持續,不難想象二人之間的距離總是在變化,再也看不到場景1情形下的相對靜止了。這兩個運動員在跑道上的間距變化就像基于第一種代碼寫法下的2個計數器值的差值變動。見下圖的右邊圓圈紅星與綠星的間距變化。這里只畫一圈示意下。
我們知道,這里定時器的PWM輸出是根據TIMER比較器的值與計數器值的比較結果而決定其輸出電平。盡管2個定時器的基本配置參數都一樣,但由于頻繁啟停計數器,導致每次啟動時計數初始值都在變化,進而導致PWM波形輸出不再保持同步。
這樣說可能有點抽象,我們不妨結合下面圖形看看會直觀點。下圖帶箭頭斜線示意計數方向、計數起點、終點。紅色虛線表示2個定時器CH1設置的CCR值的水平。
基于客戶原寫法代碼,假設經過多次針對通道的啟、停操作后的某個時刻【Tx】重新啟動2個定時器及PWM輸出,A,B兩點表示TIM1和TIM8計數器在Tx時刻的起始值,其它配置參數都一樣。下面是基于應用當前場景,分別來自TIM1/TIM8的2路PWM輸出波形示意圖。【這里假定TIM1和TIM8的使用相同配置,且當CCR>CNT時輸出高,否則輸出低】
因2個定時器采用完全相同的配置,所以2路PWM波形特征是一樣的。但由于啟動時刻2個定時器的計數初值不一樣,輸出的波形卻有了相差,如上圖所示。
這里或許有人會問,原始寫法里調用HAL_TIM_PWM_Start();是不是也不太合理呢?談不上不合理,但用得不太合適,從功能實現上看不夠簡潔、利落。這里TIM1/TIM8基于觸發啟動的主從關系,作為主定時器的TIM8的啟動放在TIM1的后面就可以了,TIM8啟動的同時啟動從TIM1。
結合這里的應用,改過寫的第2種代碼比較清爽簡潔。那么,順便問一句,可否在原寫法的代碼基礎上不做大的改寫,只做局部微調來解決問題呢?答案是肯定的,我也做過較長時間的驗證測試。有興趣的話可以自行研究下,其實前面文字里也隱含了答案。
審核編輯:湯梓紅
-
PWM
+關注
關注
116文章
5344瀏覽量
217790 -
信號
+關注
關注
11文章
2839瀏覽量
77843 -
定時器
+關注
關注
23文章
3284瀏覽量
117023 -
代碼
+關注
關注
30文章
4886瀏覽量
70179 -
stm32h7
+關注
關注
0文章
37瀏覽量
1753
原文標題:本來同步的信號為何有相差了?
文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
DAC3162EVM輸出信號為何總是正負信號?
DDC112的CLK和CONV引腳如果同步效果差,比如相差0.1us,會影響什么?
請問如何利用ADF4351實現多路相干信號
同步信號為鋸齒波的觸發電路的優點是什么
用AD9680做多通道同步,多次用脈沖信號做同步觸發后,顯示相差不固定是為什么?
5G信號為何難以入室
同步的信號為什么會出現相差

評論