#include "sys_type.h" #include "sys_api.h" ////////////////////////////////////////////////////////////////////////////////// //本程序只供学习使用,未经作者许可,不得用于其它任何用途 //ALIENTEK STM32H7开发板 //系统时钟初始化 //正点原子@ALIENTEK //技术论坛:www.openedv.com //创建日期:2017/6/8 //版本:V1.0 //版权所有,盗版必究。 //Copyright(C) 广州市星翼电子科技有限公司 2014-2024 //All rights reserved //******************************************************************************** //修改说明 //无 ////////////////////////////////////////////////////////////////////////////////// //使能CPU的L1-Cache void Cache_Enable(void) { SCB_EnableICache();//使能I-Cache SCB_EnableDCache();//使能D-Cache SCB->CACR|=1<<2; //强制D-Cache透写,如不开启,实际使用中可能遇到各种问题 } //时钟设置函数 //Fvco=Fs*(plln/pllm); //Fsys=Fvco/pllp=Fs*(plln/(pllm*pllp)); //Fq=Fvco/pllq=Fs*(plln/(pllm*pllq)); //Fvco:VCO频率 //Fsys:系统时钟频率,也是PLL1的p分频输出时钟频率 //Fq:PLL1的q分频输出时钟频率 //Fs:PLL输入时钟频率,可以是HSI,CSI,HSE等. //plln:PLL1倍频系数(PLL倍频),取值范围:4~512. //pllm:PLL1预分频系数(进PLL之前的分频),取值范围:2~63. //pllp:PLL1的p分频系数(PLL之后的分频),分频后作为系统时钟,取值范围:2~128.(且必须是2的倍数) //pllq:PLL1的q分频系数(PLL之后的分频),取值范围:1~128. //CPU频率(rcc_c_ck)=sys_d1cpre_ck=400Mhz //rcc_aclk=rcc_hclk3=200Mhz //AHB1/2/3/4(rcc_hclk1/2/3/4)=200Mhz //APB1/2/3/4(rcc_pclk1/2/3/4)=100Mhz //FMC时钟频率=pll2_r_ck=((25/25)*512/2)=256Mhz //外部晶振为25M的时候,推荐值:plln=160,pllm=5,pllp=2,pllq=2. //得到:Fvco=25*(160/5)=800Mhz // Fsys=800/2=400Mhz // Fq=800/2=400Mhz //返回值:0,成功;1,失败。 #ifdef USE_FULL_ASSERT //当编译提示出错的时候此函数用来报告错误的文件和所在行 //file:指向源文件 //line:指向在文件中的行数 void assert_failed(uint8_t* file, uint32_t line) { while (1) { } } #endif //判断I_Cache是否打开 //返回值:0 关闭,1 打开 u8 Get_ICahceSta(void) { u8 sta; sta=((SCB->CCR)>>17)&0X01; return sta; } //判断I_Dache是否打开 //返回值:0 关闭,1 打开 u8 Get_DCahceSta(void) { u8 sta; sta=((SCB->CCR)>>16)&0X01; return sta; } #if defined(__clang__) //使用V6编译器(clang) //THUMB指令不支持汇编内联 //采用如下方法实现执行汇编指令WFI void __attribute__((noinline)) WFI_SET(void) { __asm__("wfi"); } //关闭所有中断(但是不包括fault和NMI中断) void __attribute__((noinline)) INTX_DISABLE(void) { __asm__("cpsid i \t\n" "bx lr"); } //开启所有中断 void __attribute__((noinline)) INTX_ENABLE(void) { __asm__("cpsie i \t\n" "bx lr"); } //设置栈顶地址 //addr:栈顶地址 void __attribute__((noinline)) MSR_MSP(u32 addr) { __asm__("msr msp, r0 \t\n" "bx r14"); } #elif defined (__CC_ARM) //使用V5编译器(ARMCC) //THUMB指令不支持汇编内联 //采用如下方法实现执行汇编指令WFI __asm void WFI_SET(void) { WFI; } //关闭所有中断(但是不包括fault和NMI中断) __asm void INTX_DISABLE(void) { CPSID I BX LR } //开启所有中断 __asm void INTX_ENABLE(void) { CPSIE I BX LR } //设置栈顶地址 //addr:栈顶地址 __asm void MSR_MSP(u32 addr) { MSR MSP, r0 //set Main Stack value BX r14 } #endif