我来发个PLL配置代码吧,全是参照Datasheet上写的。
时钟源使用HSI。启用PLL (x18倍)。HSI / 2 * 18 = 72MHz
在GD32F150上测试过,可以正常工作。
- void System_Init (void)
- {
- /* [31:26] Reserved.
- [25] r PLLSTB PLL稳定标志, 0表示未稳定。
- [24] rw PLLEN = 0, PLL开关。
- [23:20] Reserved.
- [19] rw CKMEN = 0, 关闭外部时钟(HSE) monitor.
- [18] rw HSEBPS = 0, Bypass HSE.
- [17] r HSESTB 外部时钟(HSE)稳定标志, 0表示未稳定
- [16] rw HSEEN = 0, 关闭外部时钟(HSE).
- [15:8] r HSICALIB
- [7:3] rw HSIADJ
- [2] Reserved.
- [1] r HSISTB 内部时钟(HSI)稳定标志, 0表示未稳定。
- [0] rw HSIEN 打开外部时钟(HSE).
- */
- RCC->GCCR = RCC_GCCR_HSIEN; // 启用内部8MHz RC oscillator。
- while (!(RCC->GCCR & RCC_GCCR_HSISTB)); // 等待直到内部RC oscillator稳定。
- /* [31] rw PLLDV = 0, CK_OUT的输入分频系数CK_PLL divide by 2.
- [30:28] rw CKOUTDIV = 0, CK_OUT的输出分频系数。
- [26:24] rw CKOUTSRC = 0, CKOUT时钟输出PIN的输出频率(No clock selected).
- [23:22] rw USBPS = 0, USB时钟等于CK_PLL / 1.5
- [27,21:18]rw PLLMF = 0x12, PLL倍频系数是18x.
- [17] rw PLLPREDV = 0, PLL时钟源选用HSE时钟(PLLSEL=1时有效).
- [16] rw PLLSEL = 0, PLL时钟源等于HSI时钟除2(8MHz / 2)
- [15:14] rw ADCPS = 0, ADC时钟等于CK_APB2 / 2.
- [13:11] rw APB2PS = 0, APB2时钟等于CK_AHB.
- [10:8] rw APB1PS = 0, APB1时钟等于CK_AHB.
- [7:4] rw AHBPS = 0, AHB时钟等于CK_SYS.
- [3:2] r SCSS System clock switch status(Read only).
- [1:0] rw SCS = 0, CK_SYS时钟来自CK_HSI
- */
- RCC->GCFGR = 0x808000C;
- RCC->GCCR |= RCC_GCCR_PLLEN; // 启用PLL。
- while(!(RCC->GCCR & RCC_GCCR_PLLSTB)); // 等待PLL稳定。
- RCC->GCFGR |= RCC_GCFGR_SCS_PLL; // 切换CK_SYS时钟为CK_PLL
- while ((RCC->GCFGR & RCC_GCFGR_SCSS) != RCC_GCFGR_SCSS_PLL); // 等待切换完成。
- }
我是新手,写得不太好,请勿见笑:lol。
|