123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- #include "sam4l_hal.h"
- #define OSC_MODE_EXTERNAL 0
- #define SYSCLK_SRC_OSC0 1
- void sysclk_init(void);
- void sysclk_priv_enable_module(uint32_t bus_id, uint32_t module_index);
- static inline void sysclk_enable_pba_divmask(uint32_t mask);
- void sysclk_priv_enable_module(uint32_t bus_id, uint32_t module_index)
- {
-
- uint32_t mask;
-
-
-
- mask = *(&PM->PM_CPUMASK + bus_id);
- mask |= 1U << module_index;
- PM->PM_UNLOCK = PM_UNLOCK_KEY(0xAAu) |
- BPM_UNLOCK_ADDR(((uint32_t)&PM->PM_CPUMASK - (uint32_t)PM) + (4 * bus_id));
- *(&PM->PM_CPUMASK + bus_id) = mask;
-
- }
- static inline void sysclk_enable_pba_divmask(uint32_t mask)
- {
- uint32_t temp_mask;
- temp_mask = PM->PM_PBADIVMASK;
- temp_mask |= mask;
- PM->PM_UNLOCK = PM_UNLOCK_KEY(0xAAu)
- | PM_UNLOCK_ADDR((uint32_t)&PM->PM_PBADIVMASK - (uint32_t)PM);
- PM->PM_PBADIVMASK = temp_mask;
- }
- #define PM_CLK_GRP_CPU 0
- #define PM_CLK_GRP_HSB 1
- #define PM_CLK_GRP_PBA 2
- #define PM_CLK_GRP_PBB 3
- #define PM_CLK_GRP_PBC 4
- #define PM_CLK_GRP_PBD 5
- #define SYSCLK_OCD 0
- #define SYSCLK_PDCA_HSB 0
- #define SYSCLK_HFLASHC_DATA 1
- #define SYSCLK_HRAMC1_DATA 2
- #define SYSCLK_USBC_DATA 3
- #define SYSCLK_CRCCU_DATA 4
- #define SYSCLK_PBA_BRIDGE 5
- #define SYSCLK_PBB_BRIDGE 6
- #define SYSCLK_PBC_BRIDGE 7
- #define SYSCLK_PBD_BRIDGE 8
- #define SYSCLK_AESA_HSB 9
- #define PBA_DIVMASK_CLK_USART (1u << 2)
- #define SYSCLK_USART0 8
- void periclk_usart0_init(void)
- {
- if (PM->PM_PBAMASK == 0) {
- sysclk_priv_enable_module(PM_CLK_GRP_HSB, SYSCLK_PBA_BRIDGE);
- }
-
- sysclk_priv_enable_module(PM_CLK_GRP_PBA, SYSCLK_USART0);
- sysclk_enable_pba_divmask(PBA_DIVMASK_CLK_USART);
- }
- void periclk_aesa_init(void)
- {
-
- sysclk_priv_enable_module(PM_CLK_GRP_HSB, SYSCLK_AESA_HSB);
- }
- void sysclk_init(void)
- {
-
-
-
- SCIF->SCIF_UNLOCK = SCIF_UNLOCK_KEY(0xAAu) | SCIF_UNLOCK_ADDR((uint32_t)&SCIF->SCIF_OSCCTRL0 - (uint32_t)SCIF);
- SCIF->SCIF_OSCCTRL0 = SCIF_OSCCTRL0_STARTUP(2) | OSC_MODE_EXTERNAL | SCIF_OSCCTRL0_OSCEN;
-
-
- while((SCIF->SCIF_PCLKSR & SCIF_PCLKSR_OSC0RDY) == 0);
-
-
- PM->PM_UNLOCK = PM_UNLOCK_KEY(0xAAu)| PM_UNLOCK_ADDR((uint32_t)&PM->PM_MCCTRL - (uint32_t)PM);
- PM->PM_MCCTRL = SYSCLK_SRC_OSC0;
- }
- void platform_init(void)
- {
- sysclk_init();
- }
|