一、概念理解
PWM輸入捕獲模式是輸入捕獲模式的特例,自己理解如下
1. 每個定時器有四個輸入捕獲通道IC1、IC2、IC3、IC4。且IC1 IC2一組,IC3 IC4一組。並且可是設置管腳和寄存器的對應關係。
2. 同一個TIx輸入映射了兩個ICx信號。
3. 這兩個ICx信號分別在相反的極性邊沿有效。
4. 兩個邊沿信號中的一個被選為觸發信號,並且從模式控制器被設置成復位模式。
5. 當觸發信號來臨時,被設置成觸發輸入信號的捕獲寄存器,捕獲「一個PWM周期(即連續的兩個上升沿或下降沿)」,它等於包含TIM時鐘周期的個數(即捕獲寄存器中捕獲的為TIM的計數個數n)。
6. 同樣另一個捕獲通道捕獲觸發信號和下一個相反極性的邊沿信號的計數個數m,即(即高電平的周期或低電平的周期)
7. 由此可以計算出PWM的時鐘周期和佔空比了
frequency=f(TIM時鐘頻率)/n。
duty cycle=(高電平計數個數/n),
若m為高電平計數個數,則duty cycle=m/n
若m為低電平計數個數,則duty cycle=(n-m)/n
註:因為計數器為16位,所以一個周期最多計數65535個,所以測得的 最小頻率= TIM時鐘頻率/65535。
二、程序設計與分析
1. 程序概述:選擇TIM3作為PWM輸入捕獲。IC2設置為上升沿,並設置為有效的觸發輸入信號。所以IC2的捕獲寄存器捕獲PWM周期,
IC1的捕獲寄存器捕獲PWM的高電平周期。
2.程序代碼如下:
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE); //時鐘配置
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7; //GPIO配置
PIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn; //NVIC配置
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
TIM_ICInitStructure.TIM_Channel = TIM_Channel_2; //通道選擇
TIM_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising; //上升沿觸發
TIM_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; //管腳與寄存器對應關係
TIM_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1; //輸入預分頻。意思是控制在多少個輸入周期做一次捕獲,如果
//輸入的信號頻率沒有變,測得的周期也不會變。比如選擇4分頻,則每四個輸入周期才做一次捕獲,這樣在輸入信號變化不頻繁的情況下,
//可以減少軟體被不斷中斷的次數。
TIM_ICInitStructure.TIM_ICFilter = 0x0; //濾波設置,經歷幾個周期跳變認定波形穩定0x0~0xF
TIM_PWMIConfig(TIM3, &TIM_ICInitStructure); //根據參數配置TIM外設信息
TIM_SelectInputTrigger(TIM3, TIM_TS_TI2FP2); //選擇IC2為始終觸發源
TIM_SelectSlaveMode(TIM3, TIM_SlaveMode_Reset);//TIM從模式:觸發信號的上升沿重新初始化計數器和觸發寄存器的更新事件
TIM_SelectMasterSlaveMode(TIM3, TIM_MasterSlaveMode_Enable); //啟動定時器的被動觸發
TIM_Cmd(TIM3, ENABLE); //啟動TIM2
TIM_ITConfig(TIM3, TIM_IT_CC2, ENABLE); //打開中斷
中斷處理函數
void TIM3_IRQHandler(void)
{
TIM_ClearITPendingBit(TIM3, TIM_IT_CC2); //清楚TIM的中斷待處理位
IC2Value = TIM_GetCapture2(TIM3); //讀取IC2捕獲寄存器的值,即為PWM周期的計數值
if (IC2Value != 0)
{
DutyCycle = (TIM_GetCapture1(TIM3) * 100) / IC2Value; //讀取IC1捕獲寄存器的值,並計算佔空比
Frequency = 72000000 / IC2Value; //計算PWM頻率。
}
else
{
DutyCycle = 0;
Frequency = 0;
}
}
注(一):若想改變測量的PWM頻率範圍,可將TIM時鐘頻率做分頻處理
TIM_TimeBaseStructure.TIM_Period = 0xFFFF; //周期0~FFFF
TIM_TimeBaseStructure.TIM_Prescaler = 5; //時鐘分頻,分頻數為5+1即6分頻
TIM_TimeBaseStructure.TIM_ClockDivision = 0; //時鐘分割
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;//模式
TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);//基本初始化
注注(二):定時器TIM的倍頻器X1或X2。在APB分頻為1時,倍頻值為1,否則為2。
筆記:之前調試的時候,想檢測低頻,按照上面方法進行分頻處理時,怎麼都不行,後來才搞明白,由於檢測時要進行計數,印記預裝載值TIM_Period還是要設置成0xffff,而TIM_Prescaler是進行分頻用的,也就是說,如果定時器時鐘為72M,則將TIM_Prescaler設置成5後,TIM的時鐘為14.4M,此時可以檢測的最小頻率=14.4M/0xffff,也就是說最小檢測頻率= 14.4M/TIM_Period;
之前關於這個TIM_Period自動重載值沒有理解好,怎麼都調試不同,終於搞定了,記錄一下,以便後期查閱
推薦閱讀
基於上一次將第一章:STM32MxCube 基本使用方法,本章直接講敘述STM32配置串口2的。查看STM32F407電路圖:可得USART2接在PA2、PA3。下面新建STM32MxCube工程,開始配置。這裡我們配置IO(定義PF9、PF10引腳為LED)、RCC(使用HSE)、USART(串口)。配置USART(串口)USART的配置有好幾種,也是最常見的一種」UART異步串行通信」配置來講述。選擇USART2模式為「asynchronous」(異步通信)對應的引腳自動轉換為USART。對於系統時鐘應該都知道它的作用,就是驅動整個晶片工作的心臟,如果沒有了它,就等於人沒有了心跳。時鐘的快慢也就決定了程序的快慢。STM32
發表於 2020-05-04
完整源碼下載:https://github.com/simonliu009/STM32CubeMX-GPIO-Control軟體版本:STM32CubeMX V4.25.0 System Workbench V2.4固件庫版本:STM32Cube FW_F1 V1.6.1硬體:OneNet 麒麟座V2.3在STM32CubeMX中新建項目,選擇正確的MCU型號首先設置RCC和SYS,如下圖然後根據板子實際情況設置時鐘(麒麟座外部晶振是12M,STM32F103x的最高主頻是72M),如下圖GPIO設置 PC7, PC8, PA12和 PC10為GPIO_OUTPUT, (這是麒麟座V2.3的四個LED管腳),如下圖
發表於 2020-05-04
Cube配置USART配置在Connectivity中選中USART1MODE = AsynchronousHardware Flow Control = DisableParameter Settings中配置Baud Rate = 115200Word Length = 8bitParity = NoneStop Bits =1Data Direction = Receive and TransmitOver Sampling = 16 SamplesNVIC Setting勾選Enable,Preemption Priority =2生成代碼修改代碼生成代碼後,即可使用HAL_UART_Transmit_IT(&
發表於 2020-04-29
; PS:在明白原理的情況下建議自己手寫一次模擬UART。明白了之後,代碼重複的事就由STM32晶片的硬體功能來實現就可以了,你只需要會看邏輯分析儀或者示波器分析數據便可。 所謂硬體功能 就是你把數據填充到寄存器,然後配置好相關參數,他會自動幫你發送出去。通俗點說,自己手寫整個協議代碼實現實現就像你自己把一個快件送到到別人那裡再回來,而硬體功能則是你把快件給快遞員,快遞員幫你送過去。 明顯 後者會幫你節省大量時間和精力。它是一個硬體組成,並且你也為此付費
發表於 2020-04-29
前言: STM32串口介紹串行通信是單片機與外部設備或其他計算機交換信息的一個方式, 數據一位一位的按順序傳送, 其優點是只需要一條傳輸線, 協議簡單, 但是缺點就是傳送速度較慢。串口是單片機上非常便捷的一個工具, 當寫程序需要調試的時候, 它可以很方便的提供調試方法, 只要在一些關鍵代碼執行的地方, 通過串口給串口調試助手發送相關信息, 就可以使我們很方便的查看代碼在這個位置的執行情況。下面看一下我所使用的單片機上串口的原理圖接線外部的發送端TXD就是單片機串口的接收端USART_RX, 外部接收端RXD就是單片機串口的發送端USART_TXTXD : Transmit(TX) Data(D) Receive(RX
發表於 2020-04-29
STM32CubeMX: Version 4.26.1MDK-ARM: Version 5.24.2開發板: 中移onenet 麒麟座MINI板晶片: STM32F103CBT61.STM32CubeMX設置設置外部時鐘源設置Debug設置串口 使用USART1 PA9,PA10設置時鐘頻率設置USART1詳細參數生成MDK-ARM工程2.重定向Printf 及 Scanf主要用到兩個函數HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout
發表於 2020-04-29