/*******************************************************************************
* 程序说明 : 思路PWM波生成函数
* 函数功能 : 使用TIM3的PWM功能生成思路PWM,
* 输 入 : 无
* 输 出 : 四路PWM,通过GPIO引脚复用,对TIM3的四个输出通道引脚重映射为PC6、PC7、PC8、PC9
*******************************************************************************/
#include"stm32f10x.h"
void RCC_Cfg(void);
void GPIO_Cfg(void);
void TIM_Cfg(void);
void NVIC_Cfg(void);
void delay_ms(u32 i);
void PWM_Cfg(float dutyfactor1,float dutyfactor2,float dutyfactor3,float dutyfactor4);
int main()
{
u8 flag = 1;
float ooo=0.5;
RCC_Cfg();
NVIC_Cfg();
GPIO_Cfg();
TIM_Cfg();
//开启定时器2
TIM_Cmd(TIM3,ENABLE);
//呼吸灯
while(1){
PWM_Cfg(ooo,10,50+0.5*ooo,200-2*ooo);
if(flag == 1)
{
ooo=ooo+0.002;
}
if(flag == 0)
{
ooo=ooo-0.002;
}
if(ooo>100){
flag = 0;
}
if(ooo<0.5)
{
flag = 1;
}
}
}
void GPIO_Cfg(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
//RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_GPIOA|RCC_APB2Periph_AFIO,ENABLE);
//全部映射,将TIM3_CH2映射到PB5
//根据STM32中文参考手册2010中第第119页可知:
//当没有重映射时,TIM3的四个通道CH1,CH2,CH3,CH4分别对应PA6,PA7,PB0,PB1
//当部分重映射时,TIM3的四个通道CH1,CH2,CH3,CH4分别对应PB4,PB5,PB0,PB1
//当完全重映射时,TIM3的四个通道CH1,CH2,CH3,CH4分别对应PC6,PC7,PC8,PC9
//也即是说,完全重映射之后,四个通道的PWM输出引脚分别为PC6,PC7,PC8,PC9,我们用到了通道1和通道2,所以对应引脚为PC6,PC7,PC8,PC9,我们用到了通道1和通道2,所以对应引脚为
GPIO_PinRemapConfig(GPIO_FullRemap_TIM3, ENABLE);
//部分重映射的参数
//GPIO_PinRemapConfig(GPIO_PartialRemap_TIM3, ENABLE);
//设置PC6、PC7、PC8、PC9为复用输出,输出4路PWM
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9;
GPIO_Init(GPIOC,&GPIO_InitStructure);
}
void TIM_Cfg(void)
{
//定义结构体
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
//重新将Timer设置为缺省值
TIM_DeInit(TIM3);
//采用内部时钟给TIM2提供时钟源
TIM_InternalClockConfig(TIM3);
//预分频系数为0,即不进行预分频,此时TIMER的频率为72MHzre.TIM_Prescaler =0;
TIM_TimeBaseStructure.TIM_Prescaler = 0;
//设置计数溢出大小,每计20000个数就产生一个更新事件
TIM_TimeBaseStructure.TIM_Period = 7200 - 1;
//设置时钟分割
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
//设置计数器模式为向上计数模式
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
//将配置应用到TIM2中
TIM_TimeBaseInit(TIM3,&TIM_TimeBaseStructure);
//清除溢出中断标志
//TIM_ClearFlag(TIM2, TIM_FLAG_Update);
//禁止ARR预装载缓冲器
//TIM_ARRPreloadConfig(TIM2, DISABLE);
//开启TIM2的中断
//TIM_ITConfig(TIM2,TIM_IT_Update,ENABLE);
}
/*******************************************************************************
* 函 数 名 : PWM波产生配置函数
* 函数功能 : PWM_Cfg
* 输 入 : dutyfactor 占空比数值,大小从0.014到100
* 输 出 : 无
*******************************************************************************/
void PWM_Cfg(float dutyfactor1,float dutyfactor2,float dutyfactor3,float dutyfactor4)
{
TIM_OCInitTypeDef TIM_OCInitStructure;
//设置缺省值
TIM_OCStructInit(&TIM_OCInitStructure);
//TIM3的CH1输出
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //设置是PWM模式还是比较模式
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能,使能PWM输出到端口
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //设置极性是高还是低
//设置占空比,占空比=(CCRx/ARR)*100%或(TIM_Pulse/TIM_Period)*100%
TIM_OCInitStructure.TIM_Pulse = dutyfactor1 * 7200 / 100;
TIM_OC1Init(TIM3, &TIM_OCInitStructure);
//TIM3的CH2输出
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //设置是PWM模式还是比较模式
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能,使能PWM输出到端口
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //设置极性是高还是低
//设置占空比,占空比=(CCRx/ARR)*100%或(TIM_Pulse/TIM_Period)*100%
TIM_OCInitStructure.TIM_Pulse = dutyfactor2 * 7200 / 100;
TIM_OC2Init(TIM3, &TIM_OCInitStructure);
//TIM3的CH3输出
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //设置是PWM模式还是比较模式
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能,使能PWM输出到端口
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //设置极性是高还是低
//设置占空比,占空比=(CCRx/ARR)*100%或(TIM_Pulse/TIM_Period)*100%
TIM_OCInitStructure.TIM_Pulse = dutyfactor3 * 7200 / 100;
TIM_OC3Init(TIM3, &TIM_OCInitStructure);
//TIM3的CH4输出
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //设置是PWM模式还是比较模式
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能,使能PWM输出到端口
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //设置极性是高还是低
//设置占空比,占空比=(CCRx/ARR)*100%或(TIM_Pulse/TIM_Period)*100%
TIM_OCInitStructure.TIM_Pulse = dutyfactor4 * 7200 / 100;
TIM_OC4Init(TIM3, &TIM_OCInitStructure);
//使能输出状态
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
//设置TIM3的PWM输出为使能
TIM_CtrlPWMOutputs(TIM3,ENABLE);
}
void NVIC_Cfg(void)
{
//定义结构体
NVIC_InitTypeDef NVIC_InitStructure;
//选择中断分组1
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
//选择TIM2的中断通道
NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;
//抢占式中断优先级设置为0
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
//响应式中断优先级设置为0
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
//使能中断
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
}
void RCC_Cfg(void)
{
//定义错误状态变量
ErrorStatus HSEStartUpStatus;
//将RCC寄存器重新设置为默认值
RCC_DeInit();
//打开外部高速时钟晶振
RCC_HSEConfig(RCC_HSE_ON);
//等待外部高速时钟晶振工作
HSEStartUpStatus = RCC_WaitForHSEStartUp();
if(HSEStartUpStatus == SUCCESS)
{
//设置AHB时钟(HCLK)为系统时钟
RCC_HCLKConfig(RCC_SYSCLK_Div1);
//设置高速AHB时钟(APB2)为HCLK时钟
RCC_PCLK2Config(RCC_HCLK_Div1);
//设置低速AHB时钟(APB1)为HCLK的2分频
RCC_PCLK1Config(RCC_HCLK_Div2);
//设置FLASH代码延时
FLASH_SetLatency(FLASH_Latency_2);
//使能预取指缓存
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
//设置PLL时钟,为HSE的9倍频 8MHz * 9 = 72MHz
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
上一篇:STM32实现电机的正反转
下一篇:stm32f0设置tim2单脉冲模式-tim1内部触发
推荐阅读
史海拾趣
2010年中国模拟IC将近2000亿元 (中国电子报) 赛迪顾问半导体事业部分析师 岳婷 2006-7-18 2005年,中国模拟IC市场持续高速增长,全年销售额达到617亿元。在电子产品中,模拟IC的用途非常广泛, ...… 查看全部问答∨ |
|
“尽管目前上网本(Netbook)很火,但是我们认为相对于其它电子产品,它仅是一个较小的市场,我们并不十分关注。”ARM公司全球总裁Tudor Brown在日前接受专访时表示。“虽然我们会推动XP以及Vista等开放操作系统在ARM平台上的应用,并且我们也有两个 ...… 查看全部问答∨ |
|
使用WINCE实现一个通讯录的数据库, 现在要写一个通过电话号码查找记录的函数, 所以使用到了CeSeekDatabaseEx的函数。 使用时,发现使用报87号ERROR,也就是ERROR_INVALID_PARAMETER, 通过网上的查询,发现可能是在打开数据库的时候,应 ...… 查看全部问答∨ |
|
DX们,TCPMP又来问题了。。关于player节点的set的参数。。 myplayer->Set(myplayer,PLAYER_PLAY,1,sizeof(int)); 这个报错:F:\\GPS项目\\软件\\GPS(09.03.13)\\MusicDlg.cpp(264) : error C2664: \'int (void *,int,const void *,int)\' : cannot convert parameter 3 from \'const int\' to \'const vo ...… 查看全部问答∨ |
用单片机设计一个控制器。如何存储用户设置的参数(掉电之后也不丢数据)? 最近用AT89C51设计一个控制器,里面有几个参数用户需要现场设置。要求在关闭电源后不能丢失,下次开机还能读出来。 由于单片机没有硬盘,实在不知道该存到哪里去。目前只好借鉴PC主板CMOS电路的方法,打算使用DS12887来存储这些参数。 总感觉这样 ...… 查看全部问答∨ |
欢迎来到电源设计小贴士!随着现在对更高效、更低成本电源解决方案需求的强调,我们创建了该专栏,就各种电源管理课题提出一些对您有帮助的小技巧。该专栏面向各级设计工程师。无论您是从事电源业务多年还是刚刚步入电源领域,您都可以在这里找到一 ...… 查看全部问答∨ |
【连载】【ALIENTEK 战舰STM32开发板】STM32开发指南--第三十七章 无线通信实验 第三十七章 无线通信实验 ALIENTKE战舰STM32开发板带有一个2.4G无线模块(NRF24L01模块)通信接口,采用8脚插针方式与开发板连接。本章我们将以NRF24L01模块为例向大家介绍如何在ALIENTEK战舰STM32开发板上实现无线通信。在本章中,我们 ...… 查看全部问答∨ |