stm32 pc13~pc15 tamper-rtc OSC32-IN/OSC32-OUT 配置成IO口

在STM32的数据手册的管脚分配图中可以看到:PC14与OSC32_IN公用一个引脚,PC15与OSC32_OUT公用一个引脚,它们的使用方法如下:

当LSE(低速外部时钟信号)开启时,这两个公用管脚的功能是OSC32_IN和OSC32_OUT。
当LSE(低速外部时钟信号)关闭时这两个公用管脚的功能是PC14和PC15。

备用区域控制寄存器(RCC_BDCR)的LSEON用于控制LSE的开启或关闭。关于这个寄存器的用法请参看《STM3210x技术参考手册》。

——————————————————————————————————————————————————————————————————

文档下面有一段话:
PC13,PC14和PC15引脚通过电源开关进行供电,因此这三个引脚作为输出引脚时有以下限制: 
作为输出脚时只能工作在2MHz模式下 
最大驱动负载为30pF  
同一时间,三个引脚中只有一个引脚能作为输出引脚。

在最新版本的文档中,“同一时间,三个引脚中只有一个引脚能作为输出引脚”这句话已经去掉了,即三个引脚可以同时作为输出引脚,但其他条件没有变:不能用

这些引脚作为电流源,比如驱动一个LED等。

库函数用法:

 

  1. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC | RCC_APB2Periph_AFIO, ENABLE);//开C口时钟,复用时钟。
  2. GPIO_InitTypeDef GPIO_InitStructure;//设为输出 注意:2MHZ
  3. GPIO_InitStructure.GPIO_Pin =   GPIO_Pin_12|GPIO_Pin_13 |GPIO_Pin_14 | GPIO_Pin_15; 
  4. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
  5. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;           
  6. GPIO_Init(GPIOC, &GPIO_InitStructure); 
  7. PWR_BackupAccessCmd(ENABLE);//允许修改RTC 和后备寄存器
  8. RCC_LSEConfig(RCC_LSE_OFF);//关闭外部低速外部时钟信号功能 后,PC13 PC14 PC15 才可以当普通IO用。
  9. BKP_TamperPinCmd(DISABLE);//关闭入侵检测功能,也就是 PC13,也可以当普通IO 使用
  10. BKP_ITConfig(DISABLE);
  11. //备份区写保护

复制代码


 

 

寄存器操作:

 

  1. RCC->APB2ENR|=1<<4;      //使能PORTC时钟  
  2. RCC->APB2ENR|=1<<0;      //使能AFIO时钟 
  3. GPIOA->CRL&=0XFFF00000; //PA0,1,2,3,4设置成输出   
  4. GPIOA->CRL|=0X00033333; 
  5. GPIOC->CRH&=0X000FFFFF; //PC13,14,15设置成输出 2MHz 推挽输出   
  6. GPIOC->CRH|=0X22200000; 
  7. PWR->CR|=1<<8; //取消备份区写保护 
  8. RCC->BDCR&=0xFFFFFFFE;  //外部低俗振荡器关闭 PC14,PC15成为普通IO   
  9. BKP->CR&=0xFFFFFFFE;    //侵入检测TAMPER引脚作为通用IO口使用 
  10. PWR->CR&=0xFFFFFEFF;    //备份区写保护

复制代码


 

 

 

 

作为GPIO输出的配置过程:

(1).使能GPIOC时钟
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
(2).配置GPIOC

  1.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14 | GPIO_Pin_15;
  2.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
  3.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  4.   GPIO_Init(GPIOC, &GPIO_InitStructure);

复制代码


 

 

(3).然后写高写低

  1.   GPIO_WriteBit(GPIOC, GPIO_Pin_14, Bit_SET); 
  2.   GPIO_WriteBit(GPIOC, GPIO_Pin_15, Bit_SET); 
  3.   GPIO_WriteBit(GPIOC, GPIO_Pin_14, Bit_RESET); 
  4.   GPIO_WriteBit(GPIOC, GPIO_Pin_15, Bit_RESET);

复制代码


 

 

以上代码跑在两个板子上,一个是backup区域里的RCC_DBCR的LSEON为0,即LSE关闭,以上(3)的操作从示波器上看到了电平相应变换;另外一个板子,backup区域里的RCC_DBCR的LSEON为1,即LSE打开,则以上(3)的操作从示波器上看到无效。

 

作为GPIO输入的配置过程:

只是把以上的(2)稍微改一下,(3)就不用了

  1. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14 | GPIO_Pin_15;
  2.    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  3.    GPIO_Init(GPIOC, &GPIO_InitStructure);

复制代码



外部连接为:在PC14引脚焊了一个电阻,电阻另一端通过跳线在上拉到3.3V和下拉到地的两种情况下,读出GPIOC_IDR.14分别为"1"和"0"。

 

 

作为外部中断输入的配置过程:

1.时钟使能

  1. // + osc32_in/out --> pc14/15
  2.   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC |RCC_APB2Periph_AFIO, ENABLE);

复制代码



注意要使能AFIO的时钟哦
2.中断配置 

  1.   // + for EXTI on PC.14 at falling edge
  2.     /* Configure one bit for preemption priority */
  3.    NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
  4.    NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQChannel;
  5.    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  6.    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
  7.    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  8.    NVIC_Init(&NVIC_InitStructure);

复制代码



3. GPIO配置同上
4. EXTI配置

  1. // + for PC14 EXTI @ falling edge
  2.    GPIO_EXTILineConfig(GPIO_PortSourceGPIOC, GPIO_PinSource14);
  3.    EXTI_InitStructure.EXTI_Line = EXTI_Line14;
  4.    EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
  5.    EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
  6.    EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  7.    EXTI_Init(&EXTI_InitStructure);

复制代码



5. 中断处理ISR

  1. void EXTI15_10_IRQHandler(void)
  2. {
  3.    if(EXTI_GetITStatus(EXTI_Line14) != RESET)
  4.   {
  5.      /* Clear the EXTI line 9 pending bit */
  6.    EXTI_ClearITPendingBit(EXTI_Line14);
  7.    }
  8. }

复制代码

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值