Flash_WaitCycle

时间: 2023-06-23 21:52:34 浏览: 115
Flash_WaitCycle函数是用来设置FLASH读取等待周期的函数,可以通过该函数设置FLASH读取的等待周期,来提高FLASH读取的稳定性和可靠性。在进行FLASH读取操作时,系统需要等待一定的时间,以确保FLASH读取操作的正确性。Flash_WaitCycle函数就是用来设置这个等待时间的。 Flash_WaitCycle函数的原型如下: ```c void Flash_WaitCycle(uint8_t u8WaitCycle); ``` 参数u8WaitCycle表示FLASH读取等待周期,取值范围为0-15,表示等待0-15个系统时钟周期。 在使用Flash_WaitCycle函数时,需要注意以下几点: 1. FLASH读取等待周期的设置需要根据具体的系统时钟频率和FLASH的访问速度来确定,需要进行实际测试和验证。 2. FLASH读取等待周期的设置应该尽量小,以提高系统的执行效率和响应速度。 3. 在设置FLASH读取等待周期之前,需要先使能FLASH时钟。 4. 设置FLASH读取等待周期的操作应该在程序初始化阶段完成,不应该在程序运行时动态修改。 下面是一个Flash_WaitCycle函数的示例: ```c #include "hc32f003_flash.h" #include "hc32f003_sysctrl.h" void Flash_Init(void) { Sysctrl_SetPeripheralGate(SysctrlPeripheralFlash, TRUE); Flash_WaitCycle(5); } ``` 这个Flash_Init函数用来初始化FLASH,其中设置FLASH读取等待周期为5个系统时钟周期。

相关推荐

以下代码功能#include "ddl.h" #include "uart.h" #include "gpio.h" #include "flash.h" #include "sysctrl.h" #define T1_PORT (3) #define T1_PIN (3) volatile static uint8_t u8RxData; volatile static uint8_t u8TxCnt = 0; volatile static uint8_t u8RxCnt = 0; void App_UartCfg(void); void App_PortInit(void); void App_ClkCfg(void); int32 t main (void) { App_ClkCfg () ; App_PortInit () ; App_UartCfg(); while (1) { if(u8RxCnt>=1) { u8RxCnt = 0; Uart_SendDataIt(MOP_UART1, ~u8RxData); } } } void App_ClkCfg(void) { stc_sysctrl_clk_cfg_t sysctrl_clk_cfg; Sysctrl_SetPeripheralGate(SysctrlPeripheralFlash, TRUE); Flash_WaitCycle(FlashWaitCycle0); sysctrl_SetRCHTrim(SysctrlRchFreq8MHz); sysctrl_clk_cfg.enClkSrc = SysctrlClkRCH; sysctrl_clk_cfg.enHClkDiv = SysctrlHclkDiv1; sysctrl_clk_cfg.enPClkDiv = SysctrlPclkDiv1; Sysctrl_ClkInit(&sysctrl_clk_cfg); } void Uart1_IRQHandler(void) { if(Uart_GetStatue(M0P_UART1, UartRC)) { Uart_ClrStatus(M0P_UART1, UartRC); u8RxData = Uart_ReceiveData(M0P_UART1); u8RxCnt++; } if(Uart_GetStatus(M0P_UART1, UartTC)) { Uart_ClrStatus(M0P_UART1, UartTC); u8TxCnt++; } } void App_PortInit(void) { stc_gpio_cfg_t stcGpioCfg; DDL_ZERO_STRUCT(stcGpioCfg); Sysctrl_SetPeripheralGate(SysctrlPeripheralGpio, TRUE); stcGpioCfg.enDir = GpioDirOut; Gpio_Init(GpioPortA, GpioPin2, &stcGpioCfg); Gpio_SetAFMode(GpioPortA, GpioPin2, GpioAf1); stcGpioCfg.enDir = GpioDirIn; Gpio_Init(GpioPortA, GpioPin3, &stcGpioCfg); Gpio_SetAFMode(GpioPortA, GpioPin3, GpioAf1); } void App_UartCfg(void) { stc_uart_cfg_t stcCfg; DDL_ZERO_STRUCT(stcCfg); Sysctrl_SetPeripheralGate(SysctrlPeripheralUart1, TRUE); stcCfg.enRunMode = UartMskMode3; stcCfg.enStopBit = UartMsk1bit; stcCfg.enMmdorCk = UartMskEven; stcCfg.stcBaud.u32Baud = 9600; stcCfg.stcBaud.enClkDiv = UartMsk8Or16Div; stcCfg.stcBaud.u32Pclk = Sysctrl_GetPClkFreq(); Uart_Init(M0P_UART1, &stcCfg); Uart_ClrStatus(M0P_UART1, UartRC); Uart_ClrStatus(M0P_UART1, UartTC); Uart_EnableIrq(M0P_UART1, UartRxIrq); Uart_EnableIrq(M0P_UART1, UartTxIrq); EnableNvic(UART1_IRQn, IrqLevel3, TRUE); }

最新推荐

recommend-type

Flash_AS_3.0

Flash_AS_3.0我在网上找了好久,用FLASH做动画的朋友享福了,本人感觉这个写的还是比较全,给大家分享一下哈!
recommend-type

B27A_Fortis_Flash_512Gb_1Tb_2Tb_4Tb_Async_Sync_NAND_Datasheet.pdf

B27A_Fortis_Flash_512Gb_1Tb_2Tb_4Tb_Async_Sync_NAND_Datasheet
recommend-type

关于STM32的flash读写数据和HardFault_Handler的问题

今天调试程序的时候需要把掉电前的数据存储到flash中之后等待下次初始化的时候把数据读进来。刚刚开始的时候去找了一些stm32的flash的操作,真的是废话连篇的真正能用到的没几句话,这里我把自己调试好的flash读写...
recommend-type

flash_cs5简体中文帮助教程

第 1 章 Adobe Flash Professional CS5 的新功能 新功能. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ...
recommend-type

flash_as3.0_常用代码

flash_as3.0_常用代码,个人总结的一些代码,免费的,随便看看吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解答下列问题:S—>S;T|T;T—>a 构造任意项目集规范族,构造LR(0)分析表,并分析a;a

对于这个文法,我们可以构造以下项目集规范族: I0: S -> .S S -> .T T -> .a I1: S -> S. [$ T -> T. [$ I2: S -> T. I3: S -> S.;S S -> S.;T T -> T.;a 其中,点(.)表示已经被扫描过的符号,;$表示输入串的结束符号。 根据项目集规范族,我们可以构造出LR(0)分析表: 状态 | a | $ ---- | - | - I0 | s3| I1 | |acc I2 | | 其中s3表示移进到状态3,acc表示接受。在分析字符串a;a时,我们可以按照以下步骤进行
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。