历史上的今天
返回首页

历史上的今天

今天是:2024年08月22日(星期四)

正在发生

2019年08月22日 | stm32103R8C6 捕捉2路pwm 串口打印捕捉数据

2019-08-22 来源:eefocus

第一路使用定时器2的通道1,先捕捉一个上升沿,清楚所有数据开始捕捉下降沿,捕捉到下降沿后再捕捉一个上升沿。 

第二路使用定时器4的通道4,使用其他通道的时候要注意,定时器的中断时CC4,设置上升沿和下降沿的时候也要改为通道4。

这里写图片描述

//定时器2通道1输入捕获配置


TIM_ICInitTypeDef TIM2_ICInitStructure;


void TIM2_Cap_Init(u16 arr,u16 psc) 

GPIO_InitTypeDef GPIO_InitStructure; 

TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; 

NVIC_InitTypeDef NVIC_InitStructure;


RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);    //使能TIM2时钟

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);  //使能GPIOA时钟


GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_0;  //PA0 清除之前设置  

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; //PA0 输入  

GPIO_Init(GPIOA, &GPIO_InitStructure);

GPIO_ResetBits(GPIOA,GPIO_Pin_0);                        //PA0 下拉


//初始化定时器5 TIM2   

TIM_TimeBaseStructure.TIM_Period = arr; //设定计数器自动重装值 

TIM_TimeBaseStructure.TIM_Prescaler =psc;   //预分频器   

TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_tim

TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式

TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); //根据TIM_TimeBaseInitStruct中指定的参数初始化TIMx的时间基数单位


//初始化TIM2输入捕获参数

TIM2_ICInitStructure.TIM_Channel = TIM_Channel_1; //CC1S=01     选择输入端 IC1映射到TI1上

TIM2_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising;    //上升沿捕获

TIM2_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; //映射到TI1上

TIM2_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1;   //配置输入分频,不分频 

TIM2_ICInitStructure.TIM_ICFilter = 0x01;//IC1F=0000 配置输入滤波器 不滤波

TIM_ICInit(TIM2, &TIM2_ICInitStructure);


//中断分组初始化

NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;  //TIM3中断

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;  //先占优先级2级

NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  //从优先级0级

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能

NVIC_Init(&NVIC_InitStructure);  //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器 


TIM_ITConfig(TIM2,TIM_IT_Update|TIM_IT_CC1,ENABLE);//允许更新中断 ,允许CC1IE捕获中断    


TIM_Cmd(TIM2,ENABLE );  //使能定时器2


}


u8 TIM2CH1_CAPTURE_STA=0; //输入捕获状态 

u16 TIM2CH1_CAPTURE_VAL; //输入捕获高电平值 

u16 TIM2CH1_LOW_CAPTURE_VAL; //输入捕获低电平值 

u8 TIM2CH1_LOW_CAPTURE_STA=0;


//定时器2中断服务程序 

void TIM2_IRQHandler(void) 

{


if((TIM2CH1_CAPTURE_STA&0X20)==0)//还未成功捕获   

{     

    if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)


    {       

        if(TIM2CH1_CAPTURE_STA&0xc0)//已经捕获到高电平了

        {

            if((TIM2CH1_CAPTURE_STA&0X1F)==0X1F)//高电平太长了

            {

                TIM2CH1_CAPTURE_STA|=0X80;//标记成功捕获了一次

                TIM2CH1_CAPTURE_VAL=0XFFFF;

                TIM2CH1_LOW_CAPTURE_STA|=0x80;

                TIM2CH1_LOW_CAPTURE_VAL=0XFFFF;

            }else 

            {

                TIM2CH1_CAPTURE_STA++;

                TIM2CH1_LOW_CAPTURE_STA++;

            }

        }    

    }

if (TIM_GetITStatus(TIM2, TIM_IT_CC1) != RESET)//捕获1发生捕获事件

    {   


        //printf("TIM2CH1_CAPTURE_STA:     0x%x =============rn",TIM2CH1_CAPTURE_STA );

        if(TIM2CH1_CAPTURE_STA&0x80)        //已经检测到下降沿,检测低电平时间

        {

            TIM2CH1_LOW_CAPTURE_VAL=TIM_GetCapture1(TIM2);              

            TIM2CH1_CAPTURE_STA|=0X20;

        }else           

        if(TIM2CH1_CAPTURE_STA&0X40)        //捕获到一个下降沿      

        {               

            TIM2CH1_CAPTURE_STA|=0X80;      //标记成功捕获到一次高电平脉宽

            TIM2CH1_CAPTURE_VAL=TIM_GetCapture1(TIM2);


            TIM_SetCounter(TIM2,0);

            TIM_OC1PolarityConfig(TIM2,TIM_ICPolarity_Rising); //CC1P=0 设置为上升沿捕获                

        }else        //还未开始,第一次捕获上升沿

        {

            TIM2CH1_CAPTURE_STA=0;          //清空

            TIM2CH1_CAPTURE_VAL=0;

            TIM2CH1_LOW_CAPTURE_VAL=0;

            TIM2CH1_LOW_CAPTURE_STA=0;


            TIM_SetCounter(TIM2,0);

            TIM2CH1_CAPTURE_STA|=0X40;      //标记捕获到了上升沿

            TIM_OC1PolarityConfig(TIM2,TIM_ICPolarity_Falling);     //c  设置为下降沿捕获

            //TIM_OC1PolarityConfig(TIM2,TIM_ICPolarity_Rising);        //CC1P=1 设置为上升沿捕获

        }           

    }                                              

}


TIM_ClearITPendingBit(TIM2, TIM_IT_CC1|TIM_IT_Update); //清除中断标志位


}


===========================================================================


//定时器4通道4输入捕获配置


TIM_ICInitTypeDef TIM4_ICInitStructure;


void TIM4_Cap_Init(u16 arr,u16 psc) 

GPIO_InitTypeDef GPIO_InitStructure; 

TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; 

NVIC_InitTypeDef NVIC_InitStructure;


RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);    //使能TIM4时钟

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);  //使能GPIOB时钟


GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_9;  //PB9 清除之前设置  

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; //PB9 输入  

GPIO_Init(GPIOB, &GPIO_InitStructure);

GPIO_ResetBits(GPIOB,GPIO_Pin_9);                        //PB9 下拉


//初始化定时器4 TIM4   

TIM_TimeBaseStructure.TIM_Period = arr; //设定计数器自动重装值 

TIM_TimeBaseStructure.TIM_Prescaler =psc;   //预分频器   

TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_tim

TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式

TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure); //根据TIM_TimeBaseInitStruct中指定的参数初始化TIMx的时间基数单位


//初始化TIM4输入捕获参数

TIM4_ICInitStructure.TIM_Channel = TIM_Channel_4; //CC1S=01     选择输入端 IC1映射到TI1上

TIM4_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising;    //上升沿捕获

TIM4_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; //映射到TI1上

TIM4_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1;   //配置输入分频,不分频 

TIM4_ICInitStructure.TIM_ICFilter = 0x01;//IC1F=0000 配置输入滤波器 不滤波

TIM_ICInit(TIM4, &TIM4_ICInitStructure);


//中断分组初始化

NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn;  //TIM3中断

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3;  //先占优先级2级

NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  //从优先级0级

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能

NVIC_Init(&NVIC_InitStructure);  //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器 


TIM_ITConfig(TIM4,TIM_IT_Update|TIM_IT_CC4,ENABLE);//允许更新中断 ,允许CC1IE捕获中断    


TIM_Cmd(TIM4,ENABLE );  //使能定时器2


}


u8 TIM4CH4_CAPTURE_STA=0; //输入捕获状态 

u16 TIM4CH4_CAPTURE_VAL; //输入捕获高电平值 

u16 TIM4CH4_LOW_CAPTURE_VAL; //输入捕获低电平值 

u8 TIM4CH4_LOW_CAPTURE_STA=0;


//定时器4中断服务程序 

void TIM4_IRQHandler(void) 

{


if((TIM4CH4_CAPTURE_STA&0X20)==0)//还未成功捕获   

{     

    if (TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET)


    {       

        if(TIM4CH4_CAPTURE_STA&0xc0)//已经捕获到高电平了

        {

            if((TIM4CH4_CAPTURE_STA&0X1F)==0X1F)//高电平太长了

            {

                TIM4CH4_CAPTURE_STA|=0X80;//标记成功捕获了一次

                TIM4CH4_CAPTURE_VAL=0XFFFF;

                TIM4CH4_LOW_CAPTURE_STA|=0x80;

                TIM4CH4_LOW_CAPTURE_VAL=0XFFFF;

            }else 

            {

                TIM4CH4_CAPTURE_STA++;

                TIM4CH4_LOW_CAPTURE_STA++;

            }

        }    

    }

if (TIM_GetITStatus(TIM4, TIM_IT_CC4) != RESET)//捕获1发生捕获事件

    {   


        //printf("TIM4CH4_CAPTURE_STA:     0x%x =============rn",TIM4CH4_CAPTURE_STA );

        if(TIM4CH4_CAPTURE_STA&0x80)        //已经检测到下降沿,检测低电平时间

        {

            TIM4CH4_LOW_CAPTURE_VAL=TIM_GetCapture4(TIM4);              

            TIM4CH4_CAPTURE_STA|=0X20;

        }else           

推荐阅读

史海拾趣

APC (APC by Schneider Electric)公司的发展小趣事

在电子行业的早期,电源的稳定性是许多企业和个人用户面临的一大难题。正是在这样的背景下,APC公司凭借其敏锐的市场洞察力,将重心放在小型桌面不中断电力供应(UPS)系统的电源保护及开发上。1984年,APC推出了公司的首个UPS产品,为PC、PC服务器及其网络提供了可靠的电力保障。这一创新举措不仅解决了当时的电力供应问题,更为APC在UPS电源保护领域奠定了坚实的基础。

Condor公司的发展小趣事

进入21世纪,数据中心成为了企业信息化建设的核心。APC凭借其在UPS电源保护领域的深厚积累,稳步向数据中心市场拓展。通过并购和技术创新,APC不仅成为了首个收入达到十亿美元的以UPS为主营业务的公司,更在数据中心领域推出了多款创新产品,如InfraStruXure®架构。这一架构将电源、制冷、机架和管理无缝集成为一个模块化、可扩展的、预制式解决方案,为数据中心带来了前所未有的效率和可靠性提升。

Apex Tool Group公司的发展小趣事

在电子行业的早期,电源的稳定性是许多企业和个人用户面临的一大难题。正是在这样的背景下,APC公司凭借其敏锐的市场洞察力,将重心放在小型桌面不中断电力供应(UPS)系统的电源保护及开发上。1984年,APC推出了公司的首个UPS产品,为PC、PC服务器及其网络提供了可靠的电力保障。这一创新举措不仅解决了当时的电力供应问题,更为APC在UPS电源保护领域奠定了坚实的基础。

Electron Products Inc公司的发展小趣事

随着科技的快速发展,EPI意识到只有不断创新才能在竞争激烈的电子行业中立足。因此,公司加大了对研发的投入,并成功推出了一系列具有创新性和领先性的电子产品。这些产品不仅提升了用户体验,还为公司带来了更多的市场份额和利润。

GE (General Electric)公司的发展小趣事
首先确认电源是否正常接入,电源电压是否符合要求。
Electro-Films Inc Semi-Films Div公司的发展小趣事

进入21世纪后,随着全球电子产业的蓬勃发展,Semi-Films Division 开始积极拓展国际市场。公司参加了多个国际性的电子产品展览会,与全球各地的客户建立了联系。同时,公司还加大了对海外市场的投入,设立了多个海外办事处和代理商,为客户提供更加便捷的服务。这些举措使得 Semi-Films 的产品逐渐走向世界,成为国际知名的薄膜材料供应商。

问答坊 | AI 解惑

电子元件基础教程

工控与测量的基本功…

查看全部问答>

关于Linux嵌入式系统的培训效果!

想参加培训,但是不知道效果如何? 请大家来谈谈自己的经验吧~~ 谢绝销售…

查看全部问答>

串口接收问题

各位大侠好!请教一下,我利用C51的串口向S3C2440的串口1发数据,然后将该数据用串口0显示出来(串口调试工具),两个串口的波特率都是9600,奇偶校验都是一样的,为什么我收到的数据不是我发的数据,我用C51持续不断的发送十六进制的01,可我接受 ...…

查看全部问答>

一个例子看不明白

/* 打问号的地方不明白,希望大家给加下注释,谢谢了 这是一个蜂鸣器的程序(运行在arm9(mini2440)上的Linux下) */ #include #include #include #include #define PWM_IOCTL_SET_FREQ            &nb ...…

查看全部问答>

单片机技术

   单片机的经典电路时咋样的呀,希望大家给点建议啊。最好给个protel 99se的看看。…

查看全部问答>

WinCE中断处理--物理中断号与逻辑中断号的问题

各位大侠好:    小弟现在正在搞WinCE下面的中断处理,遇到了一点问题,希望大家踊跃发言,不吝赐教、    中断处理过程中,需要把物理中断号转化为系统的逻辑中断号,但是我却不怎么清楚物理中断号是怎么回事。看了不少网上 ...…

查看全部问答>

北京 诚聘 windows驱动软件开发工程师(兼或全职)

职位描述 Windows驱动程序设计和实现 职位要求 1.计算机、电子工程、通信、自动化等相关专业本科以上学历; 2.熟练掌握C/C++语言编程; 3.精通WDM, WDF编程,熟悉DriverStudio, WINDBG等开发工具; 4.深入理解Windows操作系统组成原理和内核 ...…

查看全部问答>

wince gprs 拨号的问题

我的程序是先打开串口,然后向串口写入at指令,最后调用rasdial()函数进行拨号连接,现在的问题是拨号能成功但是中间他会弹出一个终端窗口,要我们点 开始 -> 继续  才能继续走下去,我想实现不 弹出任何窗口 直接拨号连接.不知道大家有没有做 ...…

查看全部问答>

基于LM3S8962的多个报文对象的CAN收发例程

本例程所用的驱动库版本是:5961 演示了一个CAN控制器的多个报文对象进行CAN收发, 本例程在Stellaris 8962的评估套件上顺利运行,其中8962板作接收方,2110小板作发送方。  …

查看全部问答>