4 #include "FreeRTOSConfig.h"
5 #include "protected_io/ccp.h"
7 #if ( configCPU_CLOCK_HZ == 24000000 )
9 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_24M_gc);
11 #elif ( configCPU_CLOCK_HZ == 20000000 )
13 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_20M_gc);
15 #elif ( configCPU_CLOCK_HZ == 16000000 )
17 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_16M_gc);
19 #elif ( configCPU_CLOCK_HZ == 12000000 )
21 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_12M_gc);
23 #elif ( configCPU_CLOCK_HZ == 10000000 )
25 #define CLK_init() { \
26 ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_20M_gc); \
27 ccp_write_io((void *)&(CLKCTRL.MCLKCTRLB), CLKCTRL_PDIV_2X_gc | CLKCTRL_PEN_bm); \
30 #elif ( configCPU_CLOCK_HZ == 8000000 )
32 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_8M_gc);
34 #elif ( configCPU_CLOCK_HZ == 6000000 )
36 #define CLK_init() { \
37 ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_12M_gc); \
38 ccp_write_io((void *)&(CLKCTRL.MCLKCTRLB), CLKCTRL_PDIV_2X_gc | CLKCTRL_PEN_bm); \
41 #elif ( configCPU_CLOCK_HZ == 5000000 )
43 #define CLK_init() { \
44 ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_20M_gc); \
45 ccp_write_io((void *)&(CLKCTRL.MCLKCTRLB), CLKCTRL_PDIV_4X_gc | CLKCTRL_PEN_bm); \
48 #elif ( configCPU_CLOCK_HZ == 4000000 )
50 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_4M_gc);
52 #elif ( configCPU_CLOCK_HZ == 3000000 )
54 #define CLK_init() { \
55 ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_12M_gc); \
56 ccp_write_io((void *)&(CLKCTRL.MCLKCTRLB), CLKCTRL_PDIV_4X_gc | CLKCTRL_PEN_bm); \
59 #elif ( configCPU_CLOCK_HZ == 2000000 )
61 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_2M_gc);
63 #elif ( configCPU_CLOCK_HZ == 1000000 )
65 #define CLK_init() ccp_write_io((void *)&(CLKCTRL.OSCHFCTRLA), CLKCTRL_FREQSEL_1M_gc);
69 #error The selected clock frequency is not supported. Choose a value from the NOTE in FreeRTOSConfig.h.
73 #endif /* CLK_CONFIG_H_ */