在STM32的数据手册的管脚分配图中能够看到:PC14与OSC32_IN共用一个引脚,PC15与OSC32_OUT共用一个引脚,它们的使用方法如下:
当LSE(低速外部时钟信号)敞开时,这两个共用管脚的功用是OSC32_IN和OSC32_OUT。
当LSE(低速外部时钟信号)封闭时这两个共用管脚的功用是PC14和PC15。
备用区域操控寄存器(RCC_BDCR)的LSEON用于操控LSE的敞开或封闭。关于这个寄存器的用法请参看《STM3210x技能参考手册》。
作为GPIO输出的装备进程:
(1).使能GPIOC时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
(2).装备GPIOC
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14 | GPIO_Pin_15;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIOC, &GPIO_InitStructure);
(3).然后写高写低
GPIO_WriteBit(GPIOC, GPIO_Pin_14, Bit_SET);
GPIO_WriteBit(GPIOC, GPIO_Pin_15, Bit_SET);
GPIO_WriteBit(GPIOC, GPIO_Pin_14, Bit_RESET);
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)就不用了
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14 | GPIO_Pin_15;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOC, &GPIO_InitStructure);
外部衔接为:在PC14引脚焊了一个电阻,电阻另一端经过跳线在上拉到3.3V和下拉到地的两种情况下,读出GPIOC_IDR.14分别为”1″和”0″。
作为外部中止输入的装备进程:
1.时钟使能
// + osc32_in/out –> pc14/15
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC |RCC_APB2Periph_AFIO, ENABLE);
留意要使能AFIO的时钟哦
2.中止装备
// + for EXTI on PC.14 at falling edge
/* Configure one bit for preemption priority */
3. GPIO装备同上
4. EXTI装备
// + for PC14 EXTI @ falling edge
GPIO_EXTILineConfig(GPIO_PortSourceGPIOC, GPIO_PinSource14);
EXTI_InitStructure.EXTI_Line = EXTI_Line14;
EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
EXTI_InitStructure.EXTI_LineCmd = ENABLE;
EXTI_Init(&EXTI_InitStructure);
5. 中止处理ISR
void EXTI15_10_IRQHandler(void)
{
if(EXTI_GetITStatus(EXTI_Line14) != RESET)
{
/* Clear the EXTI line 9 pending bit */
EXTI_ClearITPendingBit(EXTI_Line14);
}
}
在中止处设置断点,只要按下key,就进入中止,跑出中止,再按key,再次进入,屡试不爽,实验完结~~~