久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费
標題:
stm32硬件實現SCCB總線讀取ID
[打印本頁]
作者:
xuwei
時間:
2015-6-14 01:27
標題:
stm32硬件實現SCCB總線讀取ID
本帖最后由 xuwei 于 2015-6-14 01:29 編輯
一前聽說ST的I2C總線難弄,現在我知道了,不是難弄是相當的難!那個標志位啊,那個狀態啊,那個事件啊,我暈啊,一天半,整整一天半啊,我昨天就搞定了除了停止信號以外的事件結點,就是這個停止信號,我是怎么也沒想到會卡主我。我最初就是想停止信號和開始一樣啊,發送 完畢就檢測事件不就OK嗎?但是任憑我怎么檢測,就是返回00,真他媽的奇了怪了,那個停止狀態位就是不為1,郁悶啊,直到我把狀態位取消了,假設我發出的停止位是有效地,繼續寫下面的時序,結果我成功了,我的假定是成立的,他的確發出了停止位,至于為什么沒有檢測到,我表示。。∵有就是要嚴格的按照EV6事件進行,讓你讀SR1,之后讀SR2,你就必須那樣做,不做就出錯,有待進一步鉆研!
這個程序是讀取OV7670的0A地址的寄存器,就是他的ID序列號:當我在電腦屏幕上看到76H,我的心!C了。!
ID序列號我終于讀出來了!
今天值得紀念
與天津第四項目部宿舍
代碼是調試源碼,沒有封裝,所以亂了點,不過。。我喜歡!
/* Includes ------------------------------------------------------------------*/
#include "stm32f10x.h"
GPIO_InitTypeDef GPIO_InitStructure;
void SCCB_IIC_INIT(void);//IIC初始化函數
uint8_t SCCB_IIC_READ(void);//讀一個字節數據
void mysysinit(void);//系統時鐘初始
void my_USART_init(void);//初始化
void my_send_byte(unsigned char send_date); //發送一個字節
void delay(uint32_t a);
int main(void)
{
uint8_t a;
mysysinit();
/* GPIOD Periph clock enable */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);//使能APB2的GPIO_A時鐘
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);//使能APB1的USART2時鐘
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);//使能APB1的USART2時鐘
/* Enable BKP and PWR clocks */
RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1,ENABLE);
/* Configure PD0 and PD2 in output pushpull mode */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8 | GPIO_Pin_9;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIOD, &GPIO_InitStructure);
/* Configure PB10 and PB11 in 開樓復用輸出 mode */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6 | GPIO_Pin_7;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_OD;
GPIO_Init(GPIOB, &GPIO_InitStructure);
my_USART_init();//初始化
my_send_byte(0x00); //發送一個字節
my_send_byte(0x01); //發送一個字節
my_send_byte(0x02); //發送一個字節
my_send_byte(0x03); //發送一個字節
SCCB_IIC_INIT();//IIC初始化函數
a=SCCB_IIC_READ();
my_send_byte(a);
while(1);
}
uint8_t SCCB_IIC_READ()//讀一個字節數據
{
uint8_t date;
uint16_t a;
I2C1->CR1=1;//開啟IIC
my_send_byte(0x80);
I2C1->CR1=0x0101;//發送起始位
while(1)
{ a=I2C1->SR1;
a=(a&0x0001);
my_send_byte(0x11);
if(a==0x0001)
break;
}//EV5是向下
I2C1->DR=0x42;//寫入地址
delay(1000000);
while(1)
{ a=I2C1->SR1;
a=(a&0x0002);
my_send_byte(0x22);
if(a==0x0002)
break;
}//EV6ADDR發送?是向下,否等待
my_send_byte((I2C1->SR1));
my_send_byte((I2C1->SR2)); //必須讀SR1
I2C1->DR=0x0a;//寫入寄存地址
while(1)
{ a=I2C1->SR1;
a=(a&0x0080);
my_send_byte(0x33);
if(a==0x0080)
break;
}//EV8寄存器為空?是向下,否等待
delay(1000000);
while(1)
{ a=I2C1->SR1;
a=(a&0x0084);
my_send_byte(0x44);
if(a==0x0084)
break;
}//EV8-2發送完成,寄存器為空?是向下,否等待
I2C1->CR1=0x0201;//STOP
delay(10000);
my_send_byte(0x88);
I2C1->CR1=0x0101;//發送起始位
while(1)
{ a=I2C1->SR1;
a=(a&0x0001);
my_send_byte(0x55);
if(a==0x0001)
break;
}//EV5是向下
I2C1->DR=0x43;//寫入地址
delay(1000000);
while(1)
{ a=I2C1->SR1;
a=(a&0x0002);
my_send_byte(0x66);
if(a==0x0002)
break;
}//EV6ADDR發送?是向下,否等待
my_send_byte(I2C1->SR1);
my_send_byte(I2C1->SR2);
while(1)
{ a=I2C1->SR1;
a=(a&0x0040);
my_send_byte(0x77);
if(a==0x0040)
break;
}//EV7ARXEN發送?是向下,否等待
date=I2C1->DR;
I2C1->CR1=0x0201;//STOP
return date;
}
void SCCB_IIC_INIT()//IIC初始化函數
{
I2C1->CR1=0;//關閉I2C
I2C1->CR2=8;//IIC的時鐘源設為8MHZ,但是這不是總線上的時鐘,他是由CCR1,分頻后作為SCL時鐘 的,見手冊,
I2C1->CCR=400;//標準IIC模式,對IIC時鐘源的分頻系數是40,用來產生10KHZ的SCL時鐘
I2C1->TRISE=3;//SCL的上升沿時間寬度為300NS
I2C1->CR1=1;//開啟IIC;
}
void delay(uint32_t a)
{
while(a--);
}
/***********************************
發送一個字節函數通過串口
************************************/
void my_send_byte(unsigned char send_date )
{
while( (USART1->SR&0x00000080)!=0x80);//發送寄存器為空
USART1->DR=send_date;
}
/**********************************
初始化串口
**********************************/
void my_USART_init()
{
/*USART2的優先級設為5*/
NVIC->IP[37]=5;
/*開啟38號中斷即USART2,關閉其他所有外部的中斷*/
NVIC->ISER[1]=0x00000020;
/*設置復用模式下的引腳模式為全雙工:TX輸出推挽復用,RX為輸入上拉模式,速度50MHZ*/
GPIOA->CRH=0x000008b0;
/* 1.開啟USART,
*
*/
USART1->CR1=0x2000;
/* 1.關閉局域網模式
* 2.1個停止位
* 3.CK引腳禁能
*/
USART1->CR2=0;
/* 1.關閉調制解調模式
* 2.關閉DMA模式
* 3.關閉智能卡、紅外模式
* 4.關閉錯誤中斷
*/
USART1->CR3=0;
/* 波特率設置
2011年8月11日
王均偉
天津第四項目部宿舍
BRR中的第四位(DIV_Fraction)作為小數,高12位(DIV_MANtissa)作為整數部分,
1,根據公式:波特率=fck/16*usardiv,其中usardivBRR寄存器的值,所以變形得:USARDIV=fck/16*波特率
2.算出來BRR寄存器的值后就要把這個值變成16進制數據寫入BRR寄存器中,
遵循以下規則:
小數部分*16=DIV_Fraction或者取近似的值
整數部分直接=DIV_MANtissa
3.把這個16進制值寫入BRR寄存器
例如我要算波特率設成9600bps的BRR寄存器值,
1.先求USARDIV=36000000/16*9600=234.375
2.換成十六進制:DIV_Fraction=16*0.375=0x6
DIV_MANtissa=234=0xea
3.組合并寫入寄存器
USART2->BRR=0x0ea6;值得注意的是這里是16位半字操作,所以不要以為是32位。
*/
USART1->BRR=0x0ea6;
/* 1.開啟USART
* 2.開啟接收完畢中斷
* 3.開啟發送功能
* 4.開啟接收功能
*/
USART1->CR1=0x202c;
}
void mysysinit()//系統初始化程序
{
ErrorStatus HSEStartUpStatus;//說明標志位
RCC_DeInit();//所有外設全部缺省設置
/* Enable HSE */
RCC_HSEConfig(RCC_HSE_ON);
/* Wait till HSE is ready and if Time out is reached exit */
HSEStartUpStatus = RCC_WaitForHSEStartUp();
if(HSEStartUpStatus == SUCCESS)//啟動成功
{
/*這兩條FLASH指令必須加上,不知為啥?不加上就運行幾秒后出錯,參照系統初始化*/
/* Enable The Prefetch Buffer */
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);//FLASH緩存開啟
/* Configure the Latency cycle: Set 2 Latency cycles */
FLASH_SetLatency(FLASH_Latency_2); //設置FLASH這些位表示SYSCLK(系統時鐘)周期與閃存訪問時間的比例,為010:兩個等待狀態,當 48MHz < SYSCLK ≤ 72MHz
/* Set PLL clock output to 72MHz using HSE (8MHz) as entry clock */
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);//外部時鐘為8M,PLL的輸入時鐘=8MHZ,倍頻系數9,
/* Configure HCLK such as HCLK = SYSCLK */
RCC_HCLKConfig(RCC_SYSCLK_Div1);//設置了啦AHB分頻器的分頻系數=1,即HCLK=SYSCLK=72MHZ
/* Configure PCLK1 such as PCLK1 = HCLK/2 */
RCC_PCLK1Config(RCC_HCLK_Div2);//設置了APB1外設的時鐘頻率最大是36M這里是APB1的分頻器設為2,PCLK1=HCLK/2=72/2=36MHZ正好是最大值
/* Configure PCLK2 such as PCLK2 = HCLK */
RCC_PCLK2Config(RCC_HCLK_Div1);//設置PLCK2=HCLK=72MHZ,的APB2分頻器=1
/* Select the PLL as system clock source */
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//設置了SYSCLK的提供者為PLL,頻率由上面算出=72MHZ
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_PLLRDY, DISABLE);//PLL中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_HSERDY,DISABLE);//HSE中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_HSIRDY, DISABLE); //HSI中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_LSERDY, DISABLE); //LSE中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_LSIRDY, DISABLE); //LSI中斷關閉
/* PLL clock divided by 1.5 used as USB clock source */
RCC_USBCLKConfig(RCC_USBCLKSource_PLLCLK_1Div5);//設置USB的時鐘為=72、1.5=48mhz
/* Configure ADCCLK such as ADCCLK = PCLK2/2 */
RCC_ADCCLKConfig(RCC_PCLK2_Div2);//設置ADC時鐘=PCLK2/2= 36MHZ
/* disable the LSE */
RCC_LSEConfig(RCC_LSE_OFF);//外部低速晶振關閉
/*DISable the RTC clock */
RCC_RTCCLKCmd(DISABLE);
/* DISable the Clock Security System */
RCC_ClockSecuritySystemCmd(DISABLE);
/* Enable the PLL */
RCC_PLLCmd(ENABLE);//使能PLL
/* PLL ans system clock config */
}
else
{
/* Add here some code to deal with this error */
}
}
復制代碼
作者:
xuwei
時間:
2015-6-14 01:30
SCCB讀寫時序----ARM硬件實現
/* Includes ------------------------------------------------------------------*/
#include "stm32f10x.h"
GPIO_InitTypeDef GPIO_InitStructure;
void SCCB_IIC_INIT(void);//IIC初始化函數
uint8_t SCCB_IIC_READ(uint8_t add);//讀一個字節數據
void mysysinit(void);//系統時鐘初始
void my_USART_init(void);//初始化
void my_send_byte(unsigned char send_date); //發送一個字節
void delay(uint32_t a);
void SCCB_IIC_WRITE(uint8_t add,uint8_t date);
int main(void)
{
uint8_t a;
mysysinit();
/* GPIOD Periph clock enable */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);//使能APB2的GPIO_A時鐘
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);//使能APB1的USART2時鐘
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);//使能APB1的USART2時鐘
/* Enable BKP and PWR clocks */
RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1,ENABLE);
/* Configure PD0 and PD2 in output pushpull mode */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8 | GPIO_Pin_9;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIOD, &GPIO_InitStructure);
/* Configure PB10 and PB11 in 開樓復用輸出 mode */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6 | GPIO_Pin_7;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_OD;
GPIO_Init(GPIOB, &GPIO_InitStructure);
my_USART_init();//初始化
my_send_byte(0x00); //發送一個字節
my_send_byte(0x01); //發送一個字節
my_send_byte(0x02); //發送一個字節
my_send_byte(0x03); //發送一個字節
delay(5000);
SCCB_IIC_INIT();//IIC初始化函數
SCCB_IIC_WRITE(0x15,0x20);
delay(10);
a=SCCB_IIC_READ(0x15);
my_send_byte(a);
while(1);
}
/**************************************
SCCB底層操作函數,寫一個寄存器地址的數據
無返回值
形參:寄存器地址&寄存器數據!!
*****************************************/
void SCCB_IIC_WRITE(uint8_t add,uint8_t date)
{ uint8_t a;
I2C1->CR1=1;//開啟IIC
//my_send_byte(0x80);
I2C1->CR1=0x0101;//發送起始位
while(1)
{ a=I2C1->SR1;
a=(a&0x0001);
delay(1);
//my_send_byte(0x11);
if(a==0x0001)
break;
}//EV5是向下
I2C1->DR=0x42;//寫入地址
delay(10);
while(1)
{ a=I2C1->SR1;
a=(a&0x0002);
delay(1);
// my_send_byte(0x22);
if(a==0x0002)
break;
}//EV6ADDR發送?是向下,否等待
a=I2C1->SR1;
a=I2C1->SR2;
//my_send_byte((I2C1->SR1));
//my_send_byte((I2C1->SR2)); //必須讀SR1
I2C1->DR=add;//寫入寄存地址
while(1)
{ a=I2C1->SR1;
a=(a&0x0080);
delay(1);
//my_send_byte(0x33);
if(a==0x0080)
break;
}//EV8寄存器為空?是向下,否等待
a=I2C1->SR1;
a=I2C1->SR2;
//my_send_byte((I2C1->SR1));
//my_send_byte((I2C1->SR2)); //必須讀SR1
I2C1->DR=date;//寫數據
while(1)
{ a=I2C1->SR1;
a=(a&0x0080);
delay(1);
// my_send_byte(0x44);
if(a==0x0080)
break;
}//EV8寄存器為空?是向下,否等待
delay(1);
while(1)
{a=I2C1->SR1;
a=(a&0x0084);
delay(1);
// my_send_byte(0x55);
if(a==0x0084)
break;
}//EV8-2發送完成,寄存器為空?是向下,否等待
I2C1->CR1=0x0201;//STOP
}
/******************************
SCCB底層操作函數利用硬件模塊IIC讀取一個指定地址的數據
返回值:為讀取的數據
形參:為將要讀取的寄存器地址
*****************************8*/
uint8_t SCCB_IIC_READ(uint8_t add)//讀一個字節數據
{
uint8_t date;
uint16_t a;
delay(3000);
I2C1->CR1=1;//開啟IIC
//my_send_byte(0x80);
I2C1->CR1=0x0101;//發送起始位
while(1)
{ a=I2C1->SR1;
a=(a&0x0001);
delay(2);
// my_send_byte(0x11);
if(a==0x0001)
break;
}//EV5是向下
I2C1->DR=0x42;//寫入地址
delay(10);
while(1)
{ a=I2C1->SR1;
a=(a&0x0002);
delay(1);
// my_send_byte(0x22);
if(a==0x0002)
break;
}//EV6ADDR發送?是向下,否等待
a=I2C1->SR1;
a=I2C1->SR2;
//my_send_byte((I2C1->SR1));
//my_send_byte((I2C1->SR2)); //必須讀SR1
I2C1->DR=add;//寫入寄存地址
while(1)
{ a=I2C1->SR1;
a=(a&0x0080);
delay(1);
// my_send_byte(0x33);
if(a==0x0080)
break;
}//EV8寄存器為空?是向下,否等待
delay(1);
while(1)
{a=I2C1->SR1;
a=(a&0x0084);
delay(1);
// my_send_byte(0x44);
if(a==0x0084)
break;
}//EV8-2發送完成,寄存器為空?是向下,否等待
I2C1->CR1=0x0201;//STOP
//delay(1000000);
///delay(10000);
delay(10);
//my_send_byte(0x88);
I2C1->CR1=0x0101;//發送起始位
while(1)
{ a=I2C1->SR1;
a=(a&0x0001);
delay(2);
//my_send_byte(0x55);
if(a==0x0001)
break;
}//EV5是向下
I2C1->DR=0x43;//寫入地址
delay(1);
while(1)
{ a=I2C1->SR1;
a=(a&0x0002);
delay(1);
// my_send_byte(0x66);
if(a==0x0002)
break;
}//EV6ADDR發送?是向下,否等待
a=I2C1->SR1;
a=I2C1->SR2;
delay(1);
// my_send_byte(I2C1->SR1);
// my_send_byte(I2C1->SR2);
while(1)
{ a=I2C1->SR1;
a=(a&0x0040);
delay(1);
//my_send_byte(0x77);
if(a==0x0040)
break;
}//EV7ARXEN發送?是向下,否等待
date=I2C1->DR;
I2C1->CR1=0x0201;//STOP
return date;
}
void SCCB_IIC_INIT()//IIC初始化函數
{
I2C1->CR1=0;//關閉I2C
I2C1->CR2=8;//IIC的時鐘源設為8MHZ,但是這不是總線上的時鐘,他是由CCR1,分頻后作為SCL時鐘 的,見手冊,
I2C1->CCR=400;//標準IIC模式,對IIC時鐘源的分頻系數是40,用來產生10KHZ的SCL時鐘
I2C1->TRISE=3;//SCL的上升沿時間寬度為300NS
I2C1->CR1=1;//開啟IIC;
}
void delay(uint32_t a)
{
for(a=23980;a;a--);
}
/***********************************
發送一個字節函數通過串口
************************************/
void my_send_byte(unsigned char send_date )
{
while( (USART1->SR&0x00000080)!=0x80);//發送寄存器為空
USART1->DR=send_date;
}
/**********************************
初始化串口
**********************************/
void my_USART_init()
{
/*USART2的優先級設為5*/
NVIC->IP[37]=5;
/*開啟38號中斷即USART2,關閉其他所有外部的中斷*/
NVIC->ISER[1]=0x00000020;
/*設置復用模式下的引腳模式為全雙工:TX輸出推挽復用,RX為輸入上拉模式,速度50MHZ*/
GPIOA->CRH=0x000008b0;
/* 1.開啟USART,
*
*/
USART1->CR1=0x2000;
/* 1.關閉局域網模式
* 2.1個停止位
* 3.CK引腳禁能
*/
USART1->CR2=0;
/* 1.關閉調制解調模式
* 2.關閉DMA模式
* 3.關閉智能卡、紅外模式
* 4.關閉錯誤中斷
*/
USART1->CR3=0;
/* 波特率設置
2011年8月11日
王均偉
天津第四項目部宿舍
BRR中的第四位(DIV_Fraction)作為小數,高12位(DIV_MANtissa)作為整數部分,
1,根據公式:波特率=fck/16*usardiv,其中usardivBRR寄存器的值,所以變形得:USARDIV=fck/16*波特率
2.算出來BRR寄存器的值后就要把這個值變成16進制數據寫入BRR寄存器中,
遵循以下規則:
小數部分*16=DIV_Fraction或者取近似的值
整數部分直接=DIV_MANtissa
3.把這個16進制值寫入BRR寄存器
例如我要算波特率設成9600bps的BRR寄存器值,
1.先求USARDIV=36000000/16*9600=234.375
2.換成十六進制:DIV_Fraction=16*0.375=0x6
DIV_MANtissa=234=0xea
3.組合并寫入寄存器
USART2->BRR=0x0ea6;值得注意的是這里是16位半字操作,所以不要以為是32位。
*/
USART1->BRR=0x0ea6;
/* 1.開啟USART
* 2.開啟接收完畢中斷
* 3.開啟發送功能
* 4.開啟接收功能
*/
USART1->CR1=0x202c;
}
void mysysinit()//系統初始化程序
{
ErrorStatus HSEStartUpStatus;//說明標志位
RCC_DeInit();//所有外設全部缺省設置
/* Enable HSE */
RCC_HSEConfig(RCC_HSE_ON);
/* Wait till HSE is ready and if Time out is reached exit */
HSEStartUpStatus = RCC_WaitForHSEStartUp();
if(HSEStartUpStatus == SUCCESS)//啟動成功
{
/*這兩條FLASH指令必須加上,不知為啥?不加上就運行幾秒后出錯,參照系統初始化*/
/* Enable The Prefetch Buffer */
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);//FLASH緩存開啟
/* Configure the Latency cycle: Set 2 Latency cycles */
FLASH_SetLatency(FLASH_Latency_2); //設置FLASH這些位表示SYSCLK(系統時鐘)周期與閃存訪問時間的比例,為010:兩個等待狀態,當 48MHz < SYSCLK ≤ 72MHz
/* Set PLL clock output to 72MHz using HSE (8MHz) as entry clock */
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);//外部時鐘為8M,PLL的輸入時鐘=8MHZ,倍頻系數9,
/* Configure HCLK such as HCLK = SYSCLK */
RCC_HCLKConfig(RCC_SYSCLK_Div1);//設置了啦AHB分頻器的分頻系數=1,即HCLK=SYSCLK=72MHZ
/* Configure PCLK1 such as PCLK1 = HCLK/2 */
RCC_PCLK1Config(RCC_HCLK_Div2);//設置了APB1外設的時鐘頻率最大是36M這里是APB1的分頻器設為2,PCLK1=HCLK/2=72/2=36MHZ正好是最大值
/* Configure PCLK2 such as PCLK2 = HCLK */
RCC_PCLK2Config(RCC_HCLK_Div1);//設置PLCK2=HCLK=72MHZ,的APB2分頻器=1
/* Select the PLL as system clock source */
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//設置了SYSCLK的提供者為PLL,頻率由上面算出=72MHZ
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_PLLRDY, DISABLE);//PLL中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_HSERDY,DISABLE);//HSE中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_HSIRDY, DISABLE); //HSI中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_LSERDY, DISABLE); //LSE中斷關閉
/* disable PLL Ready interrupt */
RCC_ITConfig(RCC_IT_LSIRDY, DISABLE); //LSI中斷關閉
/* PLL clock divided by 1.5 used as USB clock source */
RCC_USBCLKConfig(RCC_USBCLKSource_PLLCLK_1Div5);//設置USB的時鐘為=72、1.5=48mhz
/* Configure ADCCLK such as ADCCLK = PCLK2/2 */
RCC_ADCCLKConfig(RCC_PCLK2_Div2);//設置ADC時鐘=PCLK2/2= 36MHZ
/* disable the LSE */
RCC_LSEConfig(RCC_LSE_OFF);//外部低速晶振關閉
/*DISable the RTC clock */
RCC_RTCCLKCmd(DISABLE);
/* DISable the Clock Security System */
RCC_ClockSecuritySystemCmd(DISABLE);
/* Enable the PLL */
RCC_PLLCmd(ENABLE);//使能PLL
/* PLL ans system clock config */
}
else
{
/* Add here some code to deal with this error */
}
}
復制代碼
歡迎光臨 (http://www.zg4o1577.cn/bbs/)
Powered by Discuz! X3.1
主站蜘蛛池模板:
91成人免费看片
|
久久久做
|
久久青青
|
日韩精品一区在线
|
久久成人国产精品
|
免费黄色av网站
|
超碰在线播
|
国内精品久久久久
|
97久久精品
|
欧美h
|
色中文在线
|
欧美高清视频一区
|
91久久国产综合久久
|
91视频久久
|
亚洲精品中文字幕
|
a级免费观看视频
|
精品动漫一区
|
涩涩视频在线播放
|
亚洲精品中文字幕av
|
国产一区二区高清在线
|
日韩中文字幕区
|
九九免费在线视频
|
www.97zyz.com
|
精品欧美激情精品一区
|
亚洲综合一区二区三区
|
男人的天堂久久
|
欧美激情国产日韩精品一区18
|
91高清在线
|
亚洲网站在线播放
|
久久精品中文
|
精品国产色
|
国产三级
|
欧美日韩在线高清
|
国产成人福利视频
|
久久99久久久久
|
中文av电影
|
日一区二区
|
国产成人免费视频网站高清观看视频
|
欧美一区二区三区电影
|
国产精品美女久久久久久久网站
|
狠狠爱免费视频
|