1. 程式人生 > >在STM32 應用的如何將OSC32_IN和OSC32_OUT設置為其它模式

在STM32 應用的如何將OSC32_IN和OSC32_OUT設置為其它模式

interrupt _id oom and 檢測 handler 操作 最大 ear

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等。

技術分享

庫函數用法:

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC | RCC_APB2Periph_AFIO, ENABLE);//開C口時鐘,復用時鐘。
GPIO_InitTypeDef GPIO_InitStructure;//設為輸出 註意:2MHZ
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12|GPIO_Pin_13 |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);
PWR_BackupAccessCmd(ENABLE);//允許修改RTC 和後備寄存器
RCC_LSEConfig(RCC_LSE_OFF);//關閉外部低速外部時鐘信號功能 後,PC13 PC14 PC15 才可以當普通IO用。
BKP_TamperPinCmd(DISABLE);//關閉入侵檢測功能,也就是 PC13,也可以當普通IO 使用
BKP_ITConfig(DISABLE);//備份區寫保護

寄存器操作:

RCC->APB2ENR|=1<<4; //使能PORTC時鐘
RCC->APB2ENR|=1<<0; //使能AFIO時鐘
GPIOA->CRL&=0XFFF00000; //PA0,1,2,3,4設置成輸出
GPIOA->CRL|=0X00033333;
GPIOC->CRH&=0X000FFFFF; //PC13,14,15設置成輸出 2MHz 推挽輸出
GPIOC->CRH|=0X22200000;
PWR->CR|=1<<8; //取消備份區寫保護
RCC->BDCR&=0xFFFFFFFE; //外部低俗振蕩器關閉 PC14,PC15成為普通IO
BKP->CR&=0xFFFFFFFE; //侵入檢測TAMPER引腳作為通用IO口使用
PWR->CR&=0xFFFFFEFF; //備份區寫保護

作為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 */
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
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);

}

}

在STM32 應用的如何將OSC32_IN和OSC32_OUT設置為其它模式