捕获实验为什么gpio设置为下拉输入

2019-08-17 01:32发布

捕获实验为什么gpio设置为下拉输入
QQ图片20160418221309.png QQ图片20160418221323.png
//¶¨ê±Æ÷5í¨μà1êäèë2¶»ñÅäÖÃ

TIM_ICInitTypeDef  TIM5_ICInitStructure;

void TIM5_Cap_Init(u16 arr,u16 psc)
{         
        GPIO_InitTypeDef GPIO_InitStructure;
        TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
           NVIC_InitTypeDef NVIC_InitStructure;

        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM5, ENABLE);        //ê1ÄüTIM5ê±Öó
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);  //ê1ÄüGPIOAê±Öó
       
        GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_0;  //PA0 Çå3y֮ǰéèÖà 
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; //PA0 êäèë  
        GPIO_Init(GPIOA, &GPIO_InitStructure);
        GPIO_ResetBits(GPIOA,GPIO_Pin_0);                                                 //PA0 ÏÂà-
       
        //3õê¼»ˉ¶¨ê±Æ÷5 TIM5         
        TIM_TimeBaseStructure.TIM_Period = arr; //é趨¼ÆêyÆ÷×Ô¶ˉÖØ×°Öμ
        TIM_TimeBaseStructure.TIM_Prescaler =psc;         //Ô¤·ÖÆμÆ÷   
        TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //éèÖÃê±Öó·Ö¸î:TDTS = Tck_tim
        TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIMÏòéϼÆêyÄ£ê½
        TIM_TimeBaseInit(TIM5, &TIM_TimeBaseStructure); //¸ù¾YTIM_TimeBaseInitStructÖDÖ¸¶¨μÄ2Îêy3õê¼»ˉTIMxμÄê±¼ä»ùêyμ¥λ

        //3õê¼»ˉTIM5êäèë2¶»ñ2Îêy
        TIM5_ICInitStructure.TIM_Channel = TIM_Channel_1; //CC1S=01         Ñ¡Ôñêäèë¶Ë IC1ó3éäμ½TI1éÏ
          TIM5_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising;        //éÏéyÑØ2¶»ñ
          TIM5_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; //ó3éäμ½TI1éÏ
          TIM5_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1;         //ÅäÖÃêäèë·ÖÆμ,2»·ÖÆμ
          TIM5_ICInitStructure.TIM_ICFilter = 0x00;//IC1F=0000 ÅäÖÃêäèëÂË2¨Æ÷ 2»ÂË2¨
          TIM_ICInit(TIM5, &TIM5_ICInitStructure);
       
        //ÖD¶Ï·Ö×é3õê¼»ˉ
        NVIC_InitStructure.NVIC_IRQChannel = TIM5_IRQn;  //TIM3ÖD¶Ï
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;  //ÏèÕ¼óÅÏ輶2¼¶
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  //′óóÅÏ輶0¼¶
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQí¨μà±»ê1Äü
        NVIC_Init(&NVIC_InitStructure);  //¸ù¾YNVIC_InitStructÖDÖ¸¶¨μÄ2Îêy3õê¼»ˉíaéèNVIC¼Ä′æÆ÷
       
        TIM_ITConfig(TIM5,TIM_IT_Update|TIM_IT_CC1,ENABLE);//ÔêDí¸üDÂÖD¶Ï ,ÔêDíCC1IE2¶»ñÖD¶Ï       
       
           TIM_Cmd(TIM5,ENABLE );         //ê1Äü¶¨ê±Æ÷5



}

u8  TIM5CH1_CAPTURE_STA=0;        //êäèë2¶»ñ×′쬠                                                  
u16        TIM5CH1_CAPTURE_VAL;        //êäèë2¶»ñÖμ

//¶¨ê±Æ÷5ÖD¶Ï·tÎñ3ìDò         
void TIM5_IRQHandler(void)
{

        if((TIM5CH1_CAPTURE_STA&0X80)==0)//»1Î′3é1|2¶»ñ       
        {          
                if (TIM_GetITStatus(TIM5, TIM_IT_Update) != RESET)
                 
                {            
                        if(TIM5CH1_CAPTURE_STA&0X40)//òѾ-2¶»ñμ½¸ßμçƽáË
                        {
                                if((TIM5CH1_CAPTURE_STA&0X3F)==0X3F)//¸ßμçƽì«3¤áË
                                {
                                        TIM5CH1_CAPTURE_STA|=0X80;//±ê¼Ç3é1|2¶»ñáËò»′Î
                                        TIM5CH1_CAPTURE_VAL=0XFFFF;
                                }else TIM5CH1_CAPTURE_STA++;
                        }         
                }
        if (TIM_GetITStatus(TIM5, TIM_IT_CC1) != RESET)//2¶»ñ1·¢éú2¶»ñê¼t
                {       
                        if(TIM5CH1_CAPTURE_STA&0X40)                //2¶»ñμ½ò»¸öϽμÑØ                
                        {                                 
                                TIM5CH1_CAPTURE_STA|=0X80;                //±ê¼Ç3é1|2¶»ñμ½ò»′θßμçƽÂö¿í
                                TIM5CH1_CAPTURE_VAL=TIM_GetCapture1(TIM5);
                                   TIM_OC1PolarityConfig(TIM5,TIM_ICPolarity_Rising); //CC1P=0 éèÖÃÎaéÏéyÑØ2¶»ñ
                        }else                                                                  //»1Î′¿aê¼,μúò»′Î2¶»ñéÏéyÑØ
                        {
                                TIM5CH1_CAPTURE_STA=0;                        //Çå¿Õ
                                TIM5CH1_CAPTURE_VAL=0;
                                 TIM_SetCounter(TIM5,0);
                                TIM5CH1_CAPTURE_STA|=0X40;                //±ê¼Ç2¶»ñμ½áËéÏéyÑØ
                                   TIM_OC1PolarityConfig(TIM5,TIM_ICPolarity_Falling);                //CC1P=1 éèÖÃÎaϽμÑØ2¶»ñ
                        }                    
                }                                                                                   
        }

    TIM_ClearITPendingBit(TIM5, TIM_IT_CC1|TIM_IT_Update); //Çå3yÖD¶Ï±ê־λ

}



友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
7条回答
憨厚诚实大叔
1楼-- · 2019-08-17 03:19
烟草圈儿 发表于 2016-5-6 15:42
我们配置gpio口时不都应该按照手册进行配置吗?

输入的上下拉都是弱上下拉,很容易给外部拉高或拉低,如果你外部不能一直帮你维持无效电平,就要内部上下拉帮你维持无效电平了,比如你这个捕获,如果某一段时间不需要捕获的时候,捕获的外器件要失能,引脚就等于浮空了,他没办法帮你维持无效电平了,这个时候就内部的上下拉就能继续帮你维持无效电平
憨厚诚实大叔
2楼-- · 2019-08-17 05:25
只要你理解什么是下拉输入,不用过于纠结这个问题,一般设为浮空输入的时候,都是有外部的上下拉维持电平的,而且设置的上下拉,都是弱上下拉。在外部电路有确定电平的时候,内部设不设上下拉都一样
xuande
3楼-- · 2019-08-17 09:27
本帖最后由 xuande 于 2016-4-18 23:02 编辑

“输入”没问题,LZ想知道“下拉”?

和外界信号的无效电平相同、有效信号相反,一般都这样,
目的是进一步确保平时为无效状态。


393523361
4楼-- · 2019-08-17 10:29
具体为什么设置成上拉或者下拉你要根据GPIO的结构图来分析,IO口是上拉还是下拉要根据IO口外部接的空闲电平设置,如按键不按下时是低电平,则应该设置为下拉输入。
烟草圈儿
5楼-- · 2019-08-17 10:38
 精彩回答 2  元偷偷看……
烟草圈儿
6楼-- · 2019-08-17 11:28
憨厚诚实大叔 发表于 2016-5-7 10:23
输入的上下拉都是弱上下拉,很容易给外部拉高或拉低,如果你外部不能一直帮你维持无效电平,就要内部上下 ...

多谢,多谢,多谢,多谢,多谢,

一周热门 更多>