新增:首次提交
首次提交,上传Launcher工程
This commit is contained in:
40
User/includes.h
Normal file
40
User/includes.h
Normal file
@@ -0,0 +1,40 @@
|
||||
/*
|
||||
* includes.h
|
||||
*
|
||||
* Created on: May 14, 2025
|
||||
* Author: cc
|
||||
*/
|
||||
|
||||
#ifndef USER_INCLUDES_H_
|
||||
#define USER_INCLUDES_H_
|
||||
|
||||
#include <bootload_fun.h>
|
||||
#include "ch564.h"
|
||||
#include "system_ch564.h"
|
||||
|
||||
#include "debug.h"
|
||||
#include "uart.h"
|
||||
#include "led.h"
|
||||
#include "timer.h"
|
||||
#include "spi_sram.h"
|
||||
#include "spi_flash.h"
|
||||
#include "rw_logging.h"
|
||||
#include "log_api.h"
|
||||
#include "sram_mem_addr.h"
|
||||
#include "flash_mem_addr.h"
|
||||
#include "rtc.h"
|
||||
#include "mcu_flash.h"
|
||||
|
||||
/*<2A><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƽ<EFBFBD><C6BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>汾<EFBFBD><E6B1BE>
|
||||
<20>˶<EFBFBD><CBB6><EFBFBD><EFBFBD><EFBFBD>ÿ<EFBFBD><C3BF><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><D0B1>붨<EFBFBD>壬<EFBFBD><E5A3AC><EFBFBD><EFBFBD>ʶ<EFBFBD><CAB6><EFBFBD><EFBFBD>ǰ<EFBFBD><C7B0><EFBFBD>̶<EFBFBD>Ӧ<EFBFBD>Ļ<EFBFBD><C4BB><EFBFBD>
|
||||
Boot<6F>л<EFBFBD>ͨ<EFBFBD><CDA8><EFBFBD><EFBFBD>ȡEEPROM<4F>б<EFBFBD><D0B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>豸<EFBFBD><E8B1B8>Ϣ<EFBFBD><CFA2><EFBFBD>жϵ<D0B6>ǰ<EFBFBD><C7B0>ʲô<CAB2><C3B4><EFBFBD><EFBFBD>
|
||||
<20><><EFBFBD><EFBFBD>EEPROM <20><>û<EFBFBD>б<EFBFBD><D0B1><EFBFBD><EFBFBD>豸<EFBFBD><E8B1B8>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD>ô<EFBFBD><C3B4>ǰ<EFBFBD><C7B0><EFBFBD><EFBFBD>Boot<6F><74><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>豸<EFBFBD><E8B1B8>ַΪ0x00<30><30><EFBFBD>豸<EFBFBD><E8B1B8><EFBFBD><EFBFBD>Ϊ0x00
|
||||
*/
|
||||
#define Project_Area 0x01 //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ΪBoot<6F><74><EFBFBD><EFBFBD> 0x01:Boot<6F><74><EFBFBD><EFBFBD><EFBFBD><EFBFBD>0x02:APP<50><50><EFBFBD><EFBFBD>
|
||||
#define Peoject_Name "BLV_C1P_Bootload" //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
#define Project_FW_Version 0x01 //<2F><><EFBFBD>̶<EFBFBD>Ӧ<EFBFBD><D3A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>汾<EFBFBD><E6B1BE>
|
||||
#define Project_Type 0x00 //<2F><><EFBFBD>̶<EFBFBD>Ӧ<EFBFBD><D3A6><EFBFBD>豸<EFBFBD><E8B1B8><EFBFBD><EFBFBD> BootĬ<74><C4AC><EFBFBD>豸<EFBFBD><E8B1B8><EFBFBD><EFBFBD>
|
||||
|
||||
|
||||
|
||||
#endif /* USER_INCLUDES_H_ */
|
||||
185
User/main.c
Normal file
185
User/main.c
Normal file
@@ -0,0 +1,185 @@
|
||||
/********************************** (C) COPYRIGHT *******************************
|
||||
* File Name : main.c
|
||||
* Author : WCH
|
||||
* Version : V1.0.0
|
||||
* Date : 2024/05/05
|
||||
* Description : Main program body.
|
||||
*********************************************************************************
|
||||
* Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd.
|
||||
* Attention: This software (modified or not) and binary are used for
|
||||
* microcontroller manufactured by Nanjing Qinheng Microelectronics.
|
||||
*******************************************************************************/
|
||||
|
||||
#include "includes.h"
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
uint32_t test_tick = 0;
|
||||
|
||||
/*********************************************************************
|
||||
* @fn main
|
||||
*
|
||||
* @brief Main program.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
int main(void)
|
||||
{
|
||||
uint8_t sys_reset = 0;
|
||||
uint32_t wdt_reste_tick = 0;
|
||||
unsigned char Buffer;
|
||||
|
||||
unsigned long DATA_ROM_ADDR;
|
||||
|
||||
SystemCoreClockUpdate(); //ϵͳ<CFB5><CDB3>ʼ<EFBFBD><CABC>
|
||||
Systick_Init();
|
||||
|
||||
UARTx_Init(UART_0,512000);
|
||||
UARTx_Init(UART_1,512000);
|
||||
UARTx_Init(UART_2,512000);
|
||||
UARTx_Init(UART_3,512000);
|
||||
|
||||
SYS_LED_Init();
|
||||
|
||||
SPI_SRAM_Init();
|
||||
|
||||
SPI_FLASH_Init();
|
||||
|
||||
Get_Flash_Size(&Buffer);
|
||||
|
||||
if(Buffer){
|
||||
DATA_ROM_ADDR = 0x70000;
|
||||
}else {
|
||||
DATA_ROM_ADDR = 0x30000;
|
||||
}
|
||||
|
||||
DBG_SYS_Printf("RTC_Init \r\n");
|
||||
|
||||
RTC_Init();
|
||||
|
||||
DBG_SYS_Printf("EEPROM_Init - DATA_ROM_ADDR:%x\r\n",DATA_ROM_ADDR);
|
||||
|
||||
EEPROM_Init();
|
||||
|
||||
DBG_SYS_Printf("G PARA \r\n");
|
||||
|
||||
memset((uint8_t *)&g_app_feature,0,sizeof(G_SYS_FEATURE_T));
|
||||
memset((uint8_t *)&g_mcu_app_feature,0,sizeof(G_SYS_FEATURE_T));
|
||||
memset((uint8_t *)&g_update_recode,0,sizeof(UPDATE_RECORD_T));
|
||||
|
||||
DBG_SYS_Printf("G_SYS_FEATURE_T : %d \r\n",sizeof(G_SYS_FEATURE_T));
|
||||
|
||||
sys_reset = RCC_GET_GLOB_RST_KEEP();
|
||||
if(sys_reset == 0x00)
|
||||
{
|
||||
DBG_SYS_Printf("<EFBFBD>ϵ縴λ \r\n");
|
||||
}else if(sys_reset == 0x02){
|
||||
|
||||
DBG_SYS_Printf("<EFBFBD><EFBFBD><EFBFBD>Ź<EFBFBD><EFBFBD><EFBFBD>λ \r\n");
|
||||
}else {
|
||||
DBG_SYS_Printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>λ \r\n");
|
||||
}
|
||||
|
||||
RCC_SET_GLOB_RST_KEEP(0x01);
|
||||
g_jump_flag = Read_APP_Feature();
|
||||
|
||||
//<2F><><EFBFBD><EFBFBD>ʹ<EFBFBD>õ<EFBFBD> - <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>״̬
|
||||
if(g_jump_flag == 2) {
|
||||
MCU_APP_Write(); //MCU<43><55>Ҫд<D2AA><D0B4>
|
||||
g_jump_flag = 0;
|
||||
|
||||
// printf("Jump APP 1\r\n");
|
||||
//
|
||||
// Delay_Ms(1000);
|
||||
//
|
||||
// __disable_irq();
|
||||
// Jump_APP(g_mcu_app_feature.app_start_addr);
|
||||
|
||||
NVIC_EnableIRQ( Software_IRQn );
|
||||
Delay_Ms( 20 );
|
||||
NVIC_SetPendingIRQ( Software_IRQn );
|
||||
}
|
||||
|
||||
while (1)
|
||||
{
|
||||
SYS_LED_Task();
|
||||
|
||||
Uart0_Task();
|
||||
|
||||
UART1_RECEIVE();
|
||||
UART2_RECEIVE();
|
||||
UART3_RECEIVE();
|
||||
|
||||
RTC_TASK();
|
||||
|
||||
//<2F><><EFBFBD><EFBFBD>ʹ<EFBFBD>õ<EFBFBD> - <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>״̬
|
||||
if(SysTick_1ms - g_Boot_Tick >= 5000)
|
||||
{
|
||||
g_Boot_Tick = SysTick_1ms;
|
||||
|
||||
if(g_jump_flag == 0x00) //APP У<><D0A3><EFBFBD>ɹ<EFBFBD><C9B9><EFBFBD><EFBFBD><EFBFBD>תAPP
|
||||
{
|
||||
printf("Jump APP 2\r\n");
|
||||
|
||||
Delay_Ms(1000);
|
||||
|
||||
NVIC_EnableIRQ( Software_IRQn );
|
||||
Delay_Ms( 20 );
|
||||
NVIC_SetPendingIRQ( Software_IRQn );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void NMI_Handler(void) __attribute__((interrupt("WCH-Interrupt-fast")));
|
||||
void HardFault_Handler(void) __attribute__((interrupt("WCH-Interrupt-fast")));
|
||||
|
||||
/*********************************************************************
|
||||
* @fn NMI_Handler
|
||||
*
|
||||
* @brief This function handles NMI exception.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
void NMI_Handler(void)
|
||||
{
|
||||
while (1)
|
||||
{
|
||||
}
|
||||
}
|
||||
|
||||
/*********************************************************************
|
||||
* @fn HardFault_Handler
|
||||
*
|
||||
* @brief This function handles Hard Fault exception.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
void HardFault_Handler(void)
|
||||
{
|
||||
/* MRS_<53><5F><EFBFBD><EFBFBD>HardFault<6C><74><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˼· : https://www.cnblogs.com/wchmcu/p/17545931.html */
|
||||
uint32_t v_mepc,v_mcause,v_mtval;
|
||||
//Dbg_Println(DBG_BIT_SYS_STATUS_bit,"hardfault\n");
|
||||
|
||||
v_mepc = __get_MEPC();
|
||||
v_mcause = __get_MCAUSE();
|
||||
v_mtval = __get_MTVAL();
|
||||
|
||||
printf("boot mepc:%x\n",v_mepc);
|
||||
printf("boot mcause:%x\n",v_mcause);
|
||||
printf("boot mtval:%x\n",v_mtval);
|
||||
|
||||
while(1);
|
||||
}
|
||||
|
||||
void SW_Handler(void) {
|
||||
printf("SW_Handler Jump App\r\n");
|
||||
Delay_Ms( 100 );
|
||||
|
||||
__disable_irq();
|
||||
__asm volatile("li a6, 0x07000");
|
||||
__asm volatile("jr a6");
|
||||
while(1);
|
||||
|
||||
}
|
||||
|
||||
420
User/system_ch564.c
Normal file
420
User/system_ch564.c
Normal file
@@ -0,0 +1,420 @@
|
||||
/********************************** (C) COPYRIGHT *******************************
|
||||
* File Name : system_ch564.c
|
||||
* Author : WCH
|
||||
* Version : V1.0.0
|
||||
* Date : 2024/05/05
|
||||
* Description : CH564 Device Peripheral Access Layer System Source File.
|
||||
*********************************************************************************
|
||||
* Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd.
|
||||
* Attention: This software (modified or not) and binary are used for
|
||||
* microcontroller manufactured by Nanjing Qinheng Microelectronics.
|
||||
*******************************************************************************/
|
||||
|
||||
#include "ch564.h"
|
||||
#include "debug.h"
|
||||
|
||||
/*
|
||||
* Uncomment the line corresponding to the desired System clock (SYSCLK)
|
||||
* frequency (after reset the HSI is used as SYSCLK source).
|
||||
*/
|
||||
|
||||
#define SYSCLK_FREQ_120MHz_HSI 120000000
|
||||
//#define SYSCLK_FREQ_80MHz_HSI 80000000
|
||||
//#define SYSCLK_FREQ_60MHz_HSI 60000000
|
||||
//#define SYSCLK_FREQ_40MHz_HSI 40000000
|
||||
//#define SYSCLK_FREQ_20MHz_HSI HSI_VALUE
|
||||
//#define SYSCLK_FREQ_120MHz_HSE 120000000
|
||||
//#define SYSCLK_FREQ_80MHz_HSE 80000000
|
||||
//#define SYSCLK_FREQ_60MHz_HSE 60000000
|
||||
//#define SYSCLK_FREQ_40MHz_HSE 40000000
|
||||
//#define SYSCLK_FREQ_25MHz_HSE HSE_VALUE
|
||||
|
||||
/* Clock Definitions */
|
||||
#ifdef SYSCLK_FREQ_120MHz_HSI
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_120MHz_HSI; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSI
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_80MHz_HSI; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSI
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_60MHz_HSI; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSI
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_40MHz_HSI; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_20MHz_HSI
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_20MHz_HSI; /* System Clock Frequency (Core Clock) */
|
||||
|
||||
#elif defined SYSCLK_FREQ_120MHz_HSE
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_120MHz_HSE; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSE
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_80MHz_HSE; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSE
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_60MHz_HSE; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSE
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_40MHz_HSE; /* System Clock Frequency (Core Clock) */
|
||||
#elif defined SYSCLK_FREQ_25MHz_HSE
|
||||
uint32_t SystemCoreClock = SYSCLK_FREQ_25MHz_HSE; /* System Clock Frequency (Core Clock) */
|
||||
#endif
|
||||
|
||||
/* system_private_function_proto_types */
|
||||
static void SetSysClock(void);
|
||||
|
||||
#ifdef SYSCLK_FREQ_120MHz_HSI
|
||||
static void SetSysClockTo120_HSI(void);
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSI
|
||||
static void SetSysClockTo80_HSI(void);
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSI
|
||||
static void SetSysClockTo60_HSI(void);
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSI
|
||||
static void SetSysClockTo40_HSI(void);
|
||||
#elif defined SYSCLK_FREQ_20MHz_HSI
|
||||
static void SetSysClockTo20_HSI(void);
|
||||
#elif defined SYSCLK_FREQ_120MHz_HSE
|
||||
static void SetSysClockTo120_HSE(void);
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSE
|
||||
static void SetSysClockTo80_HSE(void);
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSE
|
||||
static void SetSysClockTo60_HSE(void);
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSE
|
||||
static void SetSysClockTo40_HSE(void);
|
||||
#elif defined SYSCLK_FREQ_25MHz_HSE
|
||||
static void SetSysClockTo25_HSE(void);
|
||||
#endif
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SystemInit
|
||||
*
|
||||
* @brief Setup the microcontroller system Initialize the Embedded Flash
|
||||
* Interface, update the SystemCoreClock variable.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
void SystemInit(void)
|
||||
{
|
||||
if ( SystemCoreClock >= 60000000 )
|
||||
{
|
||||
RCC_UNLOCK_SAFE_ACCESS();
|
||||
BITS_CFG( R32_EXTEN_CTLR0 , RB_FLASH_PRE_EN , ENABLE );
|
||||
BITS_CFG( R32_EXTEN_CTLR0 , RB_SW_CFG , DISABLE );
|
||||
RCC_LOCK_SAFE_ACCESS();
|
||||
}
|
||||
else
|
||||
{
|
||||
RCC_UNLOCK_SAFE_ACCESS();
|
||||
BITS_CFG( R32_EXTEN_CTLR0 , RB_FLASH_PRE_EN , DISABLE );
|
||||
BITS_CFG( R32_EXTEN_CTLR0 , RB_SW_CFG , DISABLE );
|
||||
RCC_LOCK_SAFE_ACCESS();
|
||||
}
|
||||
|
||||
SystemCoreClockUpdate();
|
||||
|
||||
HSI_ON();
|
||||
|
||||
/* Close ETH PHY */
|
||||
RCC_SlpWakeCtrl( RB_SLP_ETH_PWR_DN , DISABLE );
|
||||
Delay_Us( PLL_STARTUP_TIME );
|
||||
ETH->PHY_CR |= ( 1 << 31 );
|
||||
ETH->PHY_CR &= ~( 1 << 30 );
|
||||
ETH->PHY_CR |= ( 1 << 30 );
|
||||
Delay_Us( HSI_STARTUP_TIME );
|
||||
RCC_SlpWakeCtrl( RB_SLP_ETH_PWR_DN , ENABLE );
|
||||
|
||||
CLKSEL_HSI();
|
||||
SYSCLK_SOURCE_SELECT( SYSCLK_SOURCE_HSI_HSE );
|
||||
USB_PLL_OFF();
|
||||
SetSysClock();
|
||||
}
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SystemCoreClockUpdate
|
||||
*
|
||||
* @brief Update SystemCoreClock variable according to Clock Register Values.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
void SystemCoreClockUpdate(void)
|
||||
{
|
||||
uint32_t tmp = 0;
|
||||
|
||||
if ( R32_EXTEN_CTLR0 & RB_SW )
|
||||
{
|
||||
if ( R32_EXTEN_CTLR1 & RB_CLKSEL )
|
||||
{
|
||||
tmp = HSE_Value;
|
||||
}
|
||||
else
|
||||
{
|
||||
tmp = HSI_Value;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
switch ( R32_EXTEN_CTLR0 & RB_USBPLLSRC )
|
||||
{
|
||||
case 0x60:
|
||||
tmp = HSI_Value;
|
||||
break;
|
||||
case 0x20:
|
||||
tmp = HSE_Value;
|
||||
break;
|
||||
default:
|
||||
tmp = HSE_Value * 20 / 25;
|
||||
break;
|
||||
}
|
||||
|
||||
switch ( R32_EXTEN_CTLR0 & RB_USBPLLCLK )
|
||||
{
|
||||
case 0x0:
|
||||
tmp *= 24;
|
||||
break;
|
||||
case 0x4000:
|
||||
tmp *= 20;
|
||||
break;
|
||||
case 0x8000:
|
||||
tmp *= 16;
|
||||
break;
|
||||
case 0xC000:
|
||||
tmp *= 15;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
tmp /= ( R8_PLL_OUT_DIV >> 4 ) + 1;
|
||||
}
|
||||
|
||||
SystemCoreClock = tmp;
|
||||
}
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClock
|
||||
*
|
||||
* @brief Configures the System clock frequency, HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClock(void)
|
||||
{
|
||||
SystemCoreClockUpdate();
|
||||
GPIO_IPD_Unused();
|
||||
|
||||
#ifdef SYSCLK_FREQ_120MHz_HSI
|
||||
SetSysClockTo120_HSI();
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSI
|
||||
SetSysClockTo80_HSI();
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSI
|
||||
SetSysClockTo60_HSI();
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSI
|
||||
SetSysClockTo40_HSI();
|
||||
#elif defined SYSCLK_FREQ_20MHz_HSI
|
||||
SetSysClockTo20_HSI();
|
||||
#elif defined SYSCLK_FREQ_120MHz_HSE
|
||||
SetSysClockTo120_HSE();
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSE
|
||||
SetSysClockTo80_HSE();
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSE
|
||||
SetSysClockTo60_HSE();
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSE
|
||||
SetSysClockTo40_HSE();
|
||||
#elif defined SYSCLK_FREQ_25MHz_HSE
|
||||
SetSysClockTo25_HSE();
|
||||
#endif
|
||||
}
|
||||
|
||||
#ifdef SYSCLK_FREQ_120MHz_HSI
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo120_HSI
|
||||
*
|
||||
* @brief Sets System clock frequency to 120MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo120_HSI(void)
|
||||
{
|
||||
RCC_SET_PLL_SYS_OUT_DIV( 0x3 );
|
||||
USB_PLL_MUL_SELECT( USB_PLL_MUL_24 );
|
||||
USB_PLL_SOURCE_SELECT( USB_PLL_SOURCE_HSI );
|
||||
USB_PLL_ON();
|
||||
Delay_Us( PLL_STARTUP_TIME );
|
||||
SYSCLK_SOURCE_SELECT( SYSCLK_SOURCE_USBPLL );
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSI
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo80_HSI
|
||||
*
|
||||
* @brief Sets System clock frequency to 80MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo80_HSI(void)
|
||||
{
|
||||
RCC_SET_PLL_SYS_OUT_DIV(0x5);
|
||||
USB_PLL_MUL_SELECT(USB_PLL_MUL_24);
|
||||
USB_PLL_SOURCE_SELECT(USB_PLL_SOURCE_HSI);
|
||||
USB_PLL_ON();
|
||||
Delay_Us(PLL_STARTUP_TIME);
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_USBPLL);
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSI
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo60_HSI
|
||||
*
|
||||
* @brief Sets System clock frequency to 60MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo60_HSI(void)
|
||||
{
|
||||
RCC_SET_PLL_SYS_OUT_DIV(0x7);
|
||||
USB_PLL_MUL_SELECT(USB_PLL_MUL_24);
|
||||
USB_PLL_SOURCE_SELECT(USB_PLL_SOURCE_HSI);
|
||||
USB_PLL_ON();
|
||||
Delay_Us(PLL_STARTUP_TIME);
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_USBPLL);
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSI
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo8_HSI
|
||||
*
|
||||
* @brief Sets System clock frequency to 40MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo40_HSI(void)
|
||||
{
|
||||
RCC_SET_PLL_SYS_OUT_DIV( 0xB );
|
||||
USB_PLL_MUL_SELECT( USB_PLL_MUL_24 );
|
||||
USB_PLL_SOURCE_SELECT( USB_PLL_SOURCE_HSI );
|
||||
USB_PLL_ON();
|
||||
Delay_Us( PLL_STARTUP_TIME );
|
||||
SYSCLK_SOURCE_SELECT( SYSCLK_SOURCE_USBPLL );
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_20MHz_HSI
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo20_HSI
|
||||
*
|
||||
* @brief Sets System clock frequency to 20MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo20_HSI(void)
|
||||
{
|
||||
CLKSEL_HSI();
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_HSI_HSE);
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_120MHz_HSE
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo120_HSE
|
||||
*
|
||||
* @brief Sets System clock frequency to 24MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo120_HSE(void)
|
||||
{
|
||||
HSE_ON();
|
||||
Delay_Us(HSE_STARTUP_TIME);
|
||||
RCC_SlpWakeCtrl(RB_SLP_ETH_PWR_DN, DISABLE);
|
||||
RCC_SET_PLL_SYS_OUT_DIV(0x3);
|
||||
USB_PLL_SOURCE_SELECT(USB_PLL_SOURCE_ETH_PLL_OUT);
|
||||
USB_PLL_MUL_SELECT(USB_PLL_MUL_24);
|
||||
USB_PLL_ON();
|
||||
Delay_Us(PLL_STARTUP_TIME);
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_USBPLL);
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_80MHz_HSE
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo80_HSE
|
||||
*
|
||||
* @brief Sets System clock frequency to 80MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo80_HSE(void)
|
||||
{
|
||||
HSE_ON();
|
||||
Delay_Us(HSE_STARTUP_TIME);
|
||||
RCC_SlpWakeCtrl(RB_SLP_ETH_PWR_DN, DISABLE);
|
||||
RCC_SET_PLL_SYS_OUT_DIV(0x5);
|
||||
USB_PLL_SOURCE_SELECT(USB_PLL_SOURCE_ETH_PLL_OUT);
|
||||
USB_PLL_MUL_SELECT(USB_PLL_MUL_24);
|
||||
USB_PLL_ON();
|
||||
Delay_Us(PLL_STARTUP_TIME);
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_USBPLL);
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_60MHz_HSE
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo60_HSE
|
||||
*
|
||||
* @brief Sets System clock frequency to 60MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo60_HSE(void)
|
||||
{
|
||||
HSE_ON();
|
||||
Delay_Us(HSE_STARTUP_TIME);
|
||||
RCC_SlpWakeCtrl(RB_SLP_ETH_PWR_DN, DISABLE);
|
||||
RCC_SET_PLL_SYS_OUT_DIV(0x7);
|
||||
USB_PLL_SOURCE_SELECT(USB_PLL_SOURCE_ETH_PLL_OUT);
|
||||
USB_PLL_MUL_SELECT(USB_PLL_MUL_24);
|
||||
USB_PLL_ON();
|
||||
Delay_Us(PLL_STARTUP_TIME);
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_USBPLL);
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_40MHz_HSE
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo40_HSE
|
||||
*
|
||||
* @brief Sets System clock frequency to 40MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo40_HSE(void)
|
||||
{
|
||||
HSE_ON();
|
||||
Delay_Us(HSE_STARTUP_TIME);
|
||||
RCC_SlpWakeCtrl(RB_SLP_ETH_PWR_DN, DISABLE);
|
||||
RCC_SET_PLL_SYS_OUT_DIV(0xB);
|
||||
USB_PLL_SOURCE_SELECT(USB_PLL_SOURCE_ETH_PLL_OUT);
|
||||
USB_PLL_MUL_SELECT(USB_PLL_MUL_24);
|
||||
USB_PLL_ON();
|
||||
Delay_Us(PLL_STARTUP_TIME);
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_USBPLL);
|
||||
}
|
||||
|
||||
#elif defined SYSCLK_FREQ_25MHz_HSE
|
||||
|
||||
/*********************************************************************
|
||||
* @fn SetSysClockTo25_HSE
|
||||
*
|
||||
* @brief Sets System clock frequency to 25MHz and configure HCLK prescalers.
|
||||
*
|
||||
* @return none
|
||||
*/
|
||||
static void SetSysClockTo25_HSE(void)
|
||||
{
|
||||
HSE_ON();
|
||||
Delay_Us(HSE_STARTUP_TIME);
|
||||
CLKSEL_HSE();
|
||||
SystemCoreClock = HSE_VALUE;
|
||||
Delay_Init();
|
||||
Delay_Us(PLL_STARTUP_TIME);
|
||||
SYSCLK_SOURCE_SELECT(SYSCLK_SOURCE_HSI_HSE);
|
||||
|
||||
}
|
||||
|
||||
#endif
|
||||
30
User/system_ch564.h
Normal file
30
User/system_ch564.h
Normal file
@@ -0,0 +1,30 @@
|
||||
/********************************** (C) COPYRIGHT *******************************
|
||||
* File Name : system_ch564.h
|
||||
* Author : WCH
|
||||
* Version : V1.0.0
|
||||
* Date : 2024/05/05
|
||||
* Description : CH564 Device Peripheral Access Layer System Header File.
|
||||
*********************************************************************************
|
||||
* Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd.
|
||||
* Attention: This software (modified or not) and binary are used for
|
||||
* microcontroller manufactured by Nanjing Qinheng Microelectronics.
|
||||
*******************************************************************************/
|
||||
#ifndef __SYSTEM_CH564_H
|
||||
#define __SYSTEM_CH564_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern uint32_t SystemCoreClock; /* System Clock Frequency (Core Clock) */
|
||||
|
||||
/* System_Exported_Functions */
|
||||
extern void SystemInit(void);
|
||||
extern void SystemCoreClockUpdate(void);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user