STM32学习手记(5):数据的保存与毁灭!(二)
数: RCC_GetFlagStatus(RCC_FLAG_PORRST) 其中RCC_FLAG_PORRST也可以被替代成以下的一些符号,以检测不同的内容: ************************************************************************** 5. 如果必须要人为地令备份域复位(所有数据都被清零),那么有两种方法: a) 软件复位(操作RCC_BDCR中的BDRST位产生。);以下是RCC_BDCR中相关的内容: 6.3.9 备份域控制寄存器 (RCC_BDCR) b) VDD和VBAT均掉电,那么在VDD或都VBAT上电时将引发备分域复位(这是为了保护数据的完整性?) 6. 数据寄存器究竟是哪些呢? 那么在STM32提供的库里又是如何来用这些寄存器的呢?我们找一找,在stm 32f10x_bkp.c中,代码如下: /** * @brief Writes user data to the specified Data Backup Register. * @param BKP_DR: specifies the Data Backup Register. * This parameter can be BKP_DRx where x:[1, 42] * @param Data: data to write * @retval None */ void BKP_WriteBackupRegister(uint16_t BKP_DR, uint16_t Data) { __IO uint32_t tmp = 0; /* Check the parameters */ assert_param(IS_BKP_DR(BKP_DR)); tmp = (uint32_t)BKP_BASE; tmp += BKP_DR; *(__IO uint32_t *) tmp = Data; } 即只需要提供两个参数,第一个是BKP地址,第二个是数据,两个都是16位的数据。第二个参数没有问题,第一个参数如何提供呢?看例子中的代码: /** * @brief Writes data Backup DRx registers. * @param FirstBackupData: data to be written to Backup data registers. * @retval None */ void WriteToBackupReg(uint16_t FirstBackupData) { uint32_t index = 0; for (index = 0; index 《 BKP_DR_NUMBER; index++) { BKP_WriteBackupRegister(BKPDataReg[index], FirstBackupData + (index * 0x 5A)); } } 从上面的代码可以看到,第一个参数是用 BKPDataReg[index] 来提供的,这个又是什么东西呢?再找: uint16_t BKPDataReg[BKP_DR_NUMBER] = { BKP_DR1, BKP_DR2, BKP_DR3, BKP_DR4, BKP_DR5, BKP_DR6, BKP_DR7, BKP_DR8, BKP_DR9, BKP_DR10, BKP_DR11, BKP_DR12, BKP_DR13, BKP_DR14, BKP_DR15, BKP_DR16, BKP_DR17, BKP_DR18, BKP_DR19, BKP_DR20, BKP_DR21, BKP_DR22, BKP_DR23, BKP_DR24, BKP_DR25, BKP_DR26, BKP_DR27, BKP_DR28, BKP_DR29, BKP_DR30, BKP_DR31, BKP_DR32, BKP_DR33, BKP_DR34, BKP_DR35, BKP_DR36, BKP_DR37, BKP_DR38, BKP_DR39, BKP_DR40, BKP_DR41, BKP_DR42 }; 原来最终还是用BKP_DR**这样的格式来用的,其中的**代表的序号。即 5.4.1中的x。 7.复位后,对备份寄存器和RTC的访问被禁止,并且备份域被保护以防止可能存在的意外的写操作。执行以下操作可以使能对备份寄存器和RTC的访问。 ● 通过设置寄存器RCC_APB1ENR的PWREN和BKPEN位来打开电源和后备接口的时钟 以下是相关代码: RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE); 这个没有什么可说的,关于打开时钟,前面已多次涉及到。 ● 电源控制寄存器(PWR_CR)的DBP位来使能对后备寄存器和RTC的访问。 以下是相关代码: PWR_BackupAccessCmd(ENABLE); 代码本身相当简洁,不过我们还是再深入一点点。 这个PWR_BackupAccessCmd代码如下:(在stm 32f10x_pwr.c文件中) /** * @brief Enables or disables access to the RTC and backup registers. * @param NewState: new state of the access to the RTC and backup registers. * This parameter can be: ENABLE or DISABLE. * @retval None */ void PWR_BackupAccessCmd(FunctionalState NewState) { /* Check the parameters */ assert_param(IS_FUNCTIONAL_STATE(NewState)); *(__IO uint32_t *) CR_DBP_BB = (uint32_t)NewState; } 而CR_DBP_BB在这里(stm 32f10x_pwr.c文件中): /* Alias word address of DBP bit */ #define CR_OFFSET (PWR_OFFSET + 0x00) #define DBP_BitNumber 0x08 #define CR_DBP_BB (PERIPH_BB_BASE + (CR_OFFSET * 32) + (DBP_BitNumber * 4)) 8.一番探索,暂告一段落。由于我的板子与EVAL板略有不同,4个发光管分别接GPIOD的8,9,10和11引脚,所以在程序中做了如下改动(stm3210e_eval.h文件中): #define LEDn 4 #define LED1_GPIO_PORT GPIOD #define LED1_GPIO_CLK RCC_APB2Periph_GPIOD #define LED1_GPIO_PIN GPIO_Pin_8 #define LED2_GPIO_PORT GPIOD #
- AT240C02中EEPROM保存数据(12-01)
- linux环境变量设置及保存地点(09-12)
- STM32学习手记(5):数据的保存与毁灭!(一)(01-18)
- 基于Windows CE的注册表在线修改及保存(08-27)
- 现场总线控制系统功能块实例化(08-10)
- SOPC系统中如何利用Flash来保存用户程序(04-18)