CW32L083不同主频功耗测试

cathy的头像
cathy 发布于:周二, 06/27/2023 - 14:00 ,关键词:

本文主要介绍CWL083VCT6芯片在不同主频下的功耗测试方法和测试结果。

1.HSIOSC时钟

HSIOSC 时钟由内部 RC 振荡器产生,不需要外部电路,比 HSE 时钟的成本低,启动速度快。HSIOSC 时钟频率固定为 48MHz,频率精度低于 HSE 时钟。RC 振荡器输出时钟的频率受芯片加工过程、工作电压、环境温度等因素影响,CW32L083 提供了 HSIOSC 时钟频率校准功能,用户可通过设置内置高频时钟控制寄存器 SYSCTRL_HSI 的 TRIM 位域值来校准 HSIOSC 时钟频率,HSIOSC 内部高速 RC 振荡器在芯片上电后,默认处于开启状态,用户可通过设置系统控制寄存器的 SYSCTRL_CR1 的HSIEN 位域为 0 来关闭。如用户停止并重新启动了 HSIOSC 振荡器,可通过内置高频时钟控制寄存器 SYSCTRL_HSI的 STABLE 标志位来确定 HSI 时钟是否稳定,STABLE 标志为 1 表示 HSIOSC 时钟已稳定,为 0 则表示 HSIOSC 时钟还未稳定。

HSIOSC 时钟经过分频后输出 HSI 时钟,分频系数通过内置高频时钟控制寄存器 SYSCTRL_HSI 的 DIV 位域设置,有效分频系数为 1、2、4、6、8、10、12、14、16,上电后默认值为 6,所以 HSI 时钟默认频率为 8MHz。

2.PLL时钟

CW32L083 内部集成锁相环 PLL 电路,可对输入时钟源进行锁相倍频输出 PLL 时钟。用户可通过内置锁相环控制寄存器 SYSCTRL_PLL 的 SOURCE 位域选择 PLL 的输入参考时钟源,如下表所示

1.png

锁相环倍频系数通过内置锁相环控制寄存器 SYSCTRL_PLL 的 MUL 位域进行设置,可设置范围为 2 ~ 12,默认值 为 8。为保证锁相环的锁定收敛速度及输出时钟相噪性能,用户需根据实际的输入参考时钟频率和输出时钟频率分别设置 SYSCTRL_PLL.FREQIN 和 SYSCTRL_PLL.FREQOUT 位域的值。

2.png

3.png

PLL 默认处于关闭状态,通过设置系统控制寄存器 SYSCTRL_CR1 的 PLLEN 位域为 1 来启动。PLL 启动后,芯片 内部时钟监控模块检测到一定数量的 PLL 时钟信号,则认为 PLL 时钟已稳定。检测时钟数量可通过内置锁相环控制寄存器 SYSCTRL_PLL 的 WAITCYCLE 位域进行设置,通过内置锁相环控制寄存器 SYSCTRL_PLL 的 STABLE 标志位,可确定 PLL 时钟是否稳定,STABLE 标志为 1 表 示 PLL 时钟已稳定,为 0 则表示 PLL 时钟还未稳定。

修改 PLL 参数流程如下: 

步骤 1:设置 SYSCTRL_CR1.PLLEN 为 0,关闭 PLL; 

步骤 2:等待 SYSCTRL_PLL.STABLE 标志被系统硬件清零; 

步骤 3:更改 PLL 的参数; 

步骤 4:设置 SYSCTRL_CR1.PLLEN 为 1,启动 PLL; 

步骤 5:等待 SYSCTRL_PLL.STABLE 标志被系统硬件置 1,标识 PLL 时钟已稳定。

3.实例演示

通过按键KEY1中断调节运行主频(4M/12M/24M/48M/64M),LCD显示对应数字。

(1)初始化GPIO

void GPIO_Configuration(void) 
{ 
    GPIO_InitTypeDef GPIO_InitStruct = {0}; 
    __RCC_GPIOA_CLK_ENABLE(); 
    GPIO_InitStruct.IT = GPIO_IT_FALLING; //KEY1 -- PA04 
    GPIO_InitStruct.Mode = GPIO_MODE_INPUT; 
    GPIO_InitStruct.Pins = GPIO_PIN_4; 
    GPIO_Init(CW_GPIOA, &GPIO_InitStruct); 
    GPIO_ConfigFilter(CW_GPIOA, bv4, GPIO_FLTCLK_LSI); 
}

(2)GPIO中断控制函数

void GPIOA_IRQHandlerCallback(void) 
{ 
    if(CW_GPIOA->ISR_f.PIN4) 
    { 
        GPIOA_INTFLAG_CLR(bv4); 
        Key1Count++; 
        switch(Key1Count) 
        { 
            case 1: 
            CW_LCD->RAM0 = 0x0603;//4 
            RCC_HSI_Enable(RCC_HSIOSC_DIV12); 
            RCC_SysClk_Switch(RCC_SYSCLKSRC_HSI); //切换系统时钟到HSI 4MHz 
            RCC_PLL_Disable(); //关闭PLL 
            break; 
            case 2: 
            CW_LCD->RAM0 = 0x030e0005;//12 RCC_HSI_Enable(RCC_HSIOSC_DIV4); 
            break; 
            case 3: 
            CW_LCD->RAM0 = 0x0603030e;//24 RCC_HSI_Enable(RCC_HSIOSC_DIV2); 
            break; 
            case 4: 
            CW_LCD->RAM0 = 0x0f0f0603;//48 
            RCC_HSI_Enable(RCC_HSIOSC_DIV6); 
            RCC_SysClk_Switch(RCC_SYSCLKSRC_HSI); //切换系统时钟到HSI 8MHz 
            RCC_PLL_Disable(); //关闭PLL 
            FLASH_SetLatency(FLASH_Latency_2); 
            //频率大于24M需要配置FlashWait=2 
            CW_SYSCTRL->AHBEN_f.FLASH = 0; //关闭FLASH时钟 
            RCC_HSI_Enable(RCC_HSIOSC_DIV1); 
            RCC_SysClk_Switch(RCC_SYSCLKSRC_HSI); //切换系统时钟到HSI 48MHz 
            break; 
            case 5: 
            CW_LCD->RAM0 = 0x0603050f;//64 
            RCC_HSI_Enable(RCC_HSIOSC_DIV6); 
            RCC_PLL_Enable(RCC_PLLSOURCE_HSI, 8000000, RCC_PLL_MUL_8); 
            //开启PLL,PLL源为HSI 8MHz 
            FLASH_SetLatency(FLASH_Latency_3); 
            //频率大于48M需要配置FlashWait=3 
            CW_SYSCTRL->AHBEN_f.FLASH = 0; //关闭FLASH时钟 
            RCC_SysClk_Switch(RCC_SYSCLKSRC_PLL); //切换系统时钟到PLL 
            break; 
            case 6: 
            CW_LCD->RAM0 = 0; 
            CW_LCD->RAM1 = 0; 
            CW_LCD->RAM8 = 0; 
            CW_LCD->RAM9 = 0; 
            Key1Count = 0; break; 
        } 
    } 
}

(3)初始化LCD

void LCD_Configuration(void) 
{ 
    LCD_InitTypeDef LCD_InitStruct = {0}; 
    LCD_InitStruct.LCD_Bias = LCD_Bias_1_3; 
    LCD_InitStruct.LCD_ClockSource = LCD_CLOCK_SOURCE_LSI; 
    LCD_InitStruct.LCD_Duty = LCD_Duty_1_4; 
    LCD_InitStruct.LCD_ScanFreq = LCD_SCAN_FREQ_256HZ; 
    LCD_InitStruct.LCD_VoltageSource = LCD_VoltageSource_Internal;
     __RCC_LCD_CLK_ENABLE(); 
     RCC_LSI_Enable(); //启动LSI为LCD提供时钟 
     LCD_Init(&LCD_InitStruct); //基本配置 
     LCD_COMConfig(LCD_COM0 | LCD_COM1 | LCD_COM2 | LCD_COM3, ENABLE); //SEG 
     LCD_SEG0to23Config(LCD_SEG0 | LCD_SEG1 | LCD_SEG2 | LCD_SEG3 | LCD_SEG4 | 
     LCD_SEG5 | LCD_SEG6 | LCD_SEG7, ENABLE); 
     LCD_SEG32to55Config(LCD_SEG32 | LCD_SEG33 | LCD_SEG34 | LCD_SEG35 | LCD_SEG36 | 
     LCD_SEG37 | LCD_SEG38 | LCD_SEG39, ENABLE); 
     LCD_ContrastConfig(LCD_Contrast_Level_2); //显示对比度,仅内部电阻模式时有效 
     LCD_DriveVoltageConfig(LCD_INRS_LEVEL_0); //功耗最小 
     CW_LCD->RAM0 = 0x0f0f; 
     LCD_Cmd(ENABLE); 
}

(4)配置嵌套的矢量中断控制器

void NVIC_Configuration(void) 
{ 
    __disable_irq(); 
    NVIC_SetPriority(GPIOA_IRQn, 0); 
    NVIC_EnableIRQ(GPIOA_IRQn); 
    __enable_irq(); 
}

(5)主函数

int32_t main(void) 
{
    RCC_HSI_Enable(RCC_HSIOSC_DIV6); 
    GPIO_Configuration(); 
    LCD_Configuration(); 
    NVIC_Configuration(); 
    while(1){} 
}

4.测试结果

将电流表串接在单板J23跳线上,单板上电,默认主频为8MHz然后通过KEY1按键,控制主频在4 MHz -12 MHz -24 MHz -48 MHz -64 MHz之间进行切换,记录不同主频下的电流值,如下:

4.png

来源:武汉芯源半导体

免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理(联系邮箱:cathy@eetrend.com)。

围观 37