forked from SZV10X_Software/SZV103_FM33A0xxEV_SiZhu

wujiazhi
2024-06-13 72def895431ad7a08e635b11f3da738e2b2c4618
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
#include "define_all.h"
#include "gpio.h"
 
#define RCLP_TRIM (uint8_t)(*(uint32_t *)0X1FFFFB20UL)
 
// Ð£Ñé¼Ä´æÆ÷
unsigned char CheckSysReg(__IO uint32_t *RegAddr, uint32_t Value)
{
  if (*RegAddr != Value)
  {
    *RegAddr = Value;
    return 1;
  }
  else
  {
    return 0;
  }
}
 
// ²éѯNVIC¼Ä´æÆ÷¶ÔÓ¦ÏòÁ¿ºÅÖжÏÊÇ·ñ´ò¿ª
// 1 ´ò¿ª
// 0 ¹Ø±Õ
unsigned char CheckNvicIrqEn(IRQn_Type IRQn)
{
  if (0 == (NVIC->ISER[0U] & ((uint32_t)(1UL << (((uint32_t)(int32_t)IRQn) & 0x1FUL)))))
    return 0;
  else
    return 1;
}
 
void IWDT_Clr(void)
{
  IWDT->SERV = 0x12345A5A;
}
 
void IWDT_Init(void)
{
  CMU_PERCLK_SetableEx(IWDTCLK, ENABLE);
  IWDT->CFGR = 0x06; // ÖÜÆÚ2S£¬ÐÝÃß2S
  IWDT_Clr();        // Çåϵͳ¿´ÃŹ·
}
 
// ÏµÍ³Ê±ÖÓÅäÖÃ
// Ê¹ÓÃXTHF×öÖ÷ʱÖÓ,define_all.h ÖÐSYSCLKdefºê¿ØÖÆÏµÍ³Ê±ÖÓÆµÂÊ
void Init_SysClk(void)
{
  uint32_t i = 0;
  CMU_SYSCLK_InitTypeDef SYSCLK_InitStruct;
 
  CMU_PERCLK_SetableEx(PADCLK, ENABLE); // PADʱÖÓ£¨GPIO£©Ê¹Äܺ¯Êý
  AnalogIO(GPIOF, GPIO_Pin_1);          // ¸ù¾ÝÊÖ²á9.4¿É֪ʹÄÜXTHF֮ǰÐ轫PF1ºÍPF2ÉèÖÃΪģÄ⹦ÄÜ
  AnalogIO(GPIOF, GPIO_Pin_2);
 
  // Ê¹ÄÜXTHF
  CMU_XTHFCR_XTHFEN_Setable(ENABLE);                // Ê¹ÄÜXTHF
  CMU_XTHFCR_XTHF_CFG_Set(CMU_XTHFCR_XTHF_CFG_MAX); // Õñµ´Ç¿¶ÈÑ¡Ôñ×îÇ¿
  delay_ms(5);                                      // ÆðÕñÐèҪʱ¼ä
 
  //    /*ϵͳʱÖÓ³¬¹ý24MºóÐèÒª´ò¿ªwait*/
  //    FLS_RDCR_WAIT_Set(FLS_RDCR_WAIT_2CYCLE);
  //    IWDT_Clr();
  CMU_IER_HFDET_IE_Setable(ENABLE); // Æô¶¯XTHFÍ£Õ𱨾¯ÖжÏ
  // ÏµÍ³Ê±ÖÓÖ±½ÓʹÓÃXTHF
  while (!CMU_ISR_HFDETO_Chk())
  {
    if (i >= 6400) // ³¬Ê±Éè¼Æ£¬¸ù¾ÝÖ÷ʱÖÓÑ¡Ôñ²»Í¬Öµ£¬Àý³ÌÊÇ8M
    {
      break;
    }
    i++;
  }
 
  SYSCLK_InitStruct.SYSCLKSEL = CMU_SYSCLKCR_SYSCLKSEL_XTHF; // Ñ¡ÔñXTHF×öÖ÷ʱÖÓ£¨Íⲿ¸ßËÙ12Mhz£©
  SYSCLK_InitStruct.AHBPRES = CMU_SYSCLKCR_AHBPRES_DIV1;     // AHB²»·ÖƵ
  SYSCLK_InitStruct.APBPRES = CMU_SYSCLKCR_APBPRES_DIV1;     // APB1²»·ÖƵ
  SYSCLK_InitStruct.SLP_ENEXTI = ENABLE;                     // ÐÝÃßģʽʹÄÜÍⲿÖжϲÉÑù
  CMU_SysClk_Init(&SYSCLK_InitStruct);
  delay_init(SYSCLOCK_U);
}
 
void Init_RCHF(void)
{
  CMU_RCHF_InitTypeDef RCHF_InitStruct;
 
  RCHF_InitStruct.FSEL = SYSCLKdef; // define_all.h ÖÐSYSCLKdefºê¿ØÖÆÏµÍ³Ê±ÖÓÆµÂÊ
  RCHF_InitStruct.RCHFEN = ENABLE;  // ´ò¿ªRCHF
 
  CMU_RCHF_Init(&RCHF_InitStruct);
 
  CMU_Init_RCHF_Trim(clkmode); // RCHFÕñµ´Æ÷Ð£×¼ÖµÔØÈë(оƬ¸´Î»ºó×Ô¶¯ÔØÈë8MµÄУ׼ֵ)£¬Ö»Êǵ÷УRCHF³£Î¾«¶È
}
 
void Init_RCLP(void)
{
  CDIF->CR = 0X0A;
  VRTC->RCLPTR = RCLP_TRIM;
  CDIF->CR = 0X05;
}
 
void Init_SysClk_Gen(void) // Ê±ÖÓÑ¡ÔñÏà¹Ø
{
  /*ϵͳʱÖÓ³¬¹ý24MºóÐèÒª´ò¿ªwait*/
  if (RCHFCLKCFG > 24)
  {
    FLS_RDCR_WAIT_Set(FLS_RDCR_WAIT_1CYCLE);
    if (RCHFCLKCFG > 48)
    {
      FLS_RDCR_WAIT_Set(FLS_RDCR_WAIT_2CYCLE);
    }
  }
  else
  {
    FLS_RDCR_WAIT_Set(FLS_RDCR_WAIT_0CYCLE);
  }
 
  Init_RCHF();
  Init_RCLP();
  /*ϵͳʱÖÓÅäÖÃ*/
  Init_SysClk();
}
 
void CMU_IRQHandler(void)
{
  // uint8_t i = 0;
}
 
void SysWakeUp_ClockCfg(void)
{
  uint32_t i = 0;
  CMU_SYSCLK_InitTypeDef SYSCLK_InitStruct;
  // Ê¹ÄÜXTHF
  CMU_XTHFCR_XTHFEN_Setable(ENABLE);                // Ê¹ÄÜXTHF
  CMU_XTHFCR_XTHF_CFG_Set(CMU_XTHFCR_XTHF_CFG_MAX); // Õñµ´Ç¿¶ÈÑ¡Ôñ×îÇ¿
  delay_ms(3);                                      // ÆðÕñÐèҪʱ¼ä
 
  //    /*ϵͳʱÖÓ³¬¹ý24MºóÐèÒª´ò¿ªwait*/
  //    FLS_RDCR_WAIT_Set(FLS_RDCR_WAIT_2CYCLE);
  //    IWDT_Clr();
  CMU_IER_HFDET_IE_Setable(ENABLE); // Æô¶¯XTHFÍ£Õ𱨾¯ÖжÏ
  // ÏµÍ³Ê±ÖÓÖ±½ÓʹÓÃXTHF
  while (!CMU_ISR_HFDETO_Chk())
  {
    if (i >= 6400) // ³¬Ê±Éè¼Æ£¬¸ù¾ÝÖ÷ʱÖÓÑ¡Ôñ²»Í¬Öµ£¬Àý³ÌÊÇ8M
    {
      break;
    }
    i++;
  }
 
  SYSCLK_InitStruct.SYSCLKSEL = CMU_SYSCLKCR_SYSCLKSEL_XTHF; // Ñ¡ÔñXTHF×öÖ÷ʱÖÓ£¨Íⲿ¸ßËÙ12Mhz£©
  SYSCLK_InitStruct.AHBPRES = CMU_SYSCLKCR_AHBPRES_DIV1;     // AHB²»·ÖƵ
  SYSCLK_InitStruct.APBPRES = CMU_SYSCLKCR_APBPRES_DIV1;     // APB1²»·ÖƵ
  SYSCLK_InitStruct.SLP_ENEXTI = ENABLE;                     // ÐÝÃßģʽʹÄÜÍⲿÖжϲÉÑù
  CMU_SysClk_Init(&SYSCLK_InitStruct);
  delay_init(SYSCLOCK_U);
}