| 下面的分享是 来自公司一款成熟产品的BUG,它生产有6年左右了,最近改用GD32的对应型,有GD32F(M3)和GD32E(M4),我们产品在STM32和GD32E通过PA0进入睡眠,再通过PA0唤 醒起来,能正常工作并测试良好! 但是在GD32F上,发现能进入睡眠,但是PA0唤醒不了CPU,为此用GD的固件库,独立测试 一下这个功能,      部份代码如下: /*【--利用PA0,唤醒GD32的测试--】
 Firmware_Library_V2.1.2\Firmware\CMSIS下少文件,
 可在之前的版本复制过来,进行使用
     GD32发布的固件库V2.1.2有少文件现象,无语了!!!
 */
 #include "main.h"
 int main(void)
 {
 gd_eval_com_init(USART0); //初始化串口0
 printf("\r\n\r\n\r\nWAKEup PA0 TEST!\r\n");  //测试信息
 
 gd_eval_key_init(KEY_TAMPER, KEY_MODE_GPIO); // PA0初化为普通按键KEY功能
 led_config();   /*  LED灯配置,RB8灯 */
 
 long cont;//计数器
 while(1){
 
 if(SET == gpio_input_bit_get(TAMPER_KEY_GPIO_PORT, TAMPER_KEY_PIN))// PA0为高电平,进入待机模式
 {
 printf("sleep\r\n");
 gd_eval_led_off(LED2); // RB8灯灭
 gd_eval_key_init(KEY_WAKEUP, KEY_MODE_EXTI);/* PA0脚重新初始化为PMU,外部中断唤醒功能 */
 rcu_periph_clock_enable(RCU_PMU);           /* 启用外围设备PMU时钟 */
 
 pmu_wakeup_pin_enable();                    /* 使能PA0唤醒 */
 pmu_to_standbymode(WFI_CMD);                /* 进入待机模式,等待PA0出现上升沿,程序会从MAIN()处执行 */
 }
 else//PA0为低电平时,正常工作模式
 {
 cont=0x1000000;
 while(cont--);
 gd_eval_led_on(LED2); // RB8灯亮
 printf("RUNing\r\n");
 }
 }// while()
 }// main()
 这份代码在开发板上没有问题,但在产品上是有问题的,这肯定是一些硬件参数偏向临界值
 ,导致只在GD32F出现异常,或者GD32F就是容错性差一点. 最后找到问题了,PA0引脚的上升沿电平不是90度上升的,上升沿信号有斜坡,通过减小PA0脚上 的电容,减小上接电阻,已OK. 看来MCU的阻抗大小和电气兼容性,是换MCU要面对的重要问题。 
 |