STM8S_ 007_片内FLASH和EEPROM编程

发布者:EternalSunset最新更新时间:2020-07-13 来源: 51hei关键字:STM8S  片内FLASH  EEPROM编程 手机看文章 扫描二维码
随时随地手机看文章

我们都知道FLASH和EEPROM这两种存储器,但是大部分人了解的都是专门的FLASH和EEPROM芯片,如:W25Q16和ATAT24C08(外部)储存芯片。


外部存储芯片和本文说的内部FLASH和EEPROM最大的区别就是在于:内部FLASH和EEPROM是不需要SPI、I2C等进行操作,也就是说同等情况下,内部FLASH和EEPROM的读写要快一点。


STM8的FLASH除了储存程序代码之外,就是用于用户编程(存储数据),不像之前的51芯片不能利用内部储存代码的FLASH。


为方便大家阅读,本文内容已经整理成PDF文件:

http://pan.baidu.com/s/1i5uWhJR

片内FLASH和EEPROM基础知识 Ⅱ

STM8内部的FLASH程序存储器和数据EEPROM由一组通用寄存器来控制。用户可以使用这些寄存器来编程或擦除存储器的内容、设置写保护、或者配置特定的低功耗模式。用户也可以对器件的选项字节(Option byte)进行编程。


1.关于存储的名词

块(BLOCK):一个块是指可由一个简单编程操作编程或擦除的一组字节。块级的操作非常快,是标准的编程和擦除操作。请参考表4来了解块的大小。


页(PAGE):一页由一组块组成。 STM8S 器件拥有启动代码,程序代码和数据EEPROM,这些区域都由特定的结构所保护。通过对特定的选项字节进行操作,这些区域的大小能够以页为单位来进行调整。


2.主要特性

● STM8S分为两个存储器阵列:

─ 最多至 128K字节的FLASH程序存储器,不同的器件容量有所不同。

─ 最多至 2K字节的数据EEPROM(包括option byte-选择字节),不同的器件容量有所不同。

● 编程模式

─ 字节编程和自动快速字节编程(没有擦除操作)

─ 字编程

─ 块编程和快速块编程(没有擦除操作)

─ 在编程/擦除操作结束时和发生非法编程操作时产生中断

● 读同时写(RWW)功能。该特性并不是所有STM8S器件都拥有。请参考具体的数据手册了解更多细节。

● 在应用编程(IAP)和在线编程(ICP)能力。

● 保护特性

─ 存储器读保护(ROP)

─ 基于存储器存取安全系统(MASS 密钥)的程序存储器写保护

─ 基于存储器存取安全系统(MASS 密钥)的数据存储器写保护

─ 可编程的用户启动代码区域(UBC)写保护

● 在待机(Halt)模式和活跃待机(Active-halt)模式下,存储器可配置为运行状态和掉电状态。


3.存储器组织结构

STM8S的EEPROM以32位字长(每字4字节)为基础组织起来。根据不同的器件,存储器组织机构有所不同:

●小容量STM8S器件

─ 8K FLASH 程序存储器,每页 64 字节,共 128 页

─ 640 字节数据 EEPROM,每页 64 字节,共 10 页。数据 EEPROM 包括一页的选项字节(64字节)。

●中容量STM8S器件

─ 从 16K 到 32K FLASH 程序存储器,每页 512 字节,最多64页

─ 1K 字节数据 EEPROM,每页 512 字节,共 2 页。数据 EEPROM 包括一页的选项字节(512 字节)。

●大容量STM8S器件

─ 从 64K 到 128K FLASH 程序存储器,每页 512 字节,最多256页

─ 从 1K 到 2K 字节数据 EEPROM,每页 512 字节,共 4 页。数据 EEPROM 包括一页的选项字节(512 字节)。


4.存储器编程

在尝试执行任何编程操作之前,必须对主程序存储器FLASH和DATA区域解锁。

编程分类:字节编程、字编程、块编程和选项字节编程。

字节编程

可以对主程序存储器和DATA区域逐字节地编程。要对一个字节编程,应用程序可直接向目标地址写入数据。

● 在主程序存储器中

当字节编程操作执行时,应用程序停止运行。

● 在DATA区域中

─ 有 RWW 功能的器件:在 IAP 模式下,应用程序不停止运行,字节编程进行操作。

─ 无 RWW 功能的器件:当字节编程操作执行时,应用程序停止运行。

要擦除一个字节,向对应的字节简单写入’0x00即可。

应用程序可以通过读FLASH_IAPSR寄存器来校验编程或擦除操作是否已被正确执行:

● 在一次成功的编程操作后EOP位被置1。

● 当软件试图对一个被保护的页进行写操作时WP_PG_DIS位被置1。在这种情况下,写操作不会被执行。

如果FLASH_CR1中的IE位已经被预先使能,则只要这些标志位(EOP/WP_PG_DIS)中有一个被置位就会产生一个中断。

字编程

字写入操作允许一次对整个4字节的字进行编程,从而将编程时间缩短。

主程序存储器和DATA EEPROM都可以进行字操作。在一些STM8S器件中,也拥有当EEPROM在进行写操作时同时具备RWW功能。

块编程

块编程比字节编程和字编程都要快。在块编程操作中,整个块的编程或擦除在一个编程周期就可以完成。

在主程序存储器FLASH和DATA区域都可以执行块操作。

● 在主程序存储器中

用于块编程的代码必须全部在RAM中执行。

● 在DATA区域中

─ 有RWW功能的器件: DATA 块操作可在主程序存储器中执行,然而数据装载阶段必须在RAM中执行。

─ 无RWW功能的器件:用于块编程的代码必须全部在RAM中执行。

一共有三种可能的块操作:

● 块编程(也叫标准块编程):整个块在编程前被自动擦除。

● 快速块编程:在编程前没有预先的块擦除操作。

● 块擦除。

在块编程时,中断被硬件自动屏蔽。

标准块编程

块编程操作允许一次对整个块进行编程,整个块在编程前被自动擦除。

快速块编程

快速块编程允许不擦除存储器内容就对块进行编程,因此快速块编程的编程速度是标准块编程的两倍。

警告: 在执行快速块编程之前如果这个块不是空的话,不能保证写入的数据无误。

选项字节(Option byte)编程

对选项字节编程和对DATA EEPROM区域编程非常相似。

应用程序可直接向目标地址进行写操作。利用STM8的RWW功能,在对选项字节写操作的同时程序不必停下来。


软件工程源代码 Ⅲ

1、关于工程

本文提供的工程代码是基于前面软件工程“STM8S-A04_UART基本收发数据”增加FLASH修改而来。初学的朋友可以参看我前面对应的基础文章,那些文章讲的比较详细。

工程源代码主要实现功能:写入FLASH或EEPROM并读取写入的数据,通过UART打印来观察读取的数据是否和写入的一直。

提供两个工程:STM8S-A07_内部FLASH编程和STM8S-A07_内部EEPROM编程

这两个工程需要注意读写操作的地址不同,见下图:

本文重点的函数接口:

FLASH_WriteNByte:FLASH写N字节

FLASH_ReadNByte: FLASH读N字节

EEPROM_WriteNByte:EEPROM写N字节

EEPROM_ReadNByte:EEPROM读N字节

2.代码分析说明

A.FLASH_WriteNByte:FLASH写N字节

void FLASH_WriteNByte(uint8_t* pBuffer, uint32_t WriteAddr, uint16_t nByte)

{

FLASH_Unlock(FLASH_MEMTYPE_PROG);

while(FLASH_GetFlagStatus(FLASH_FLAG_PUL) == RESET);

while(nByte--)

{

FLASH_ProgramByte(WriteAddr, *pBuffer);

WriteAddr++;

pBuffer++;

FLASH_WaitForLastOperation(FLASH_MEMTYPE_PROG);

}

FLASH_Lock(FLASH_MEMTYPE_PROG);

}

这里需要注意:1.写之前解锁,写完需要上锁;2.我们提供的代码是字节操作,因此,每次操作需要“等待上次写操作完成”。

B.FLASH_ReadNByte:FLASH读N字节

void FLASH_ReadNByte(uint8_t* pBuffer, uint32_t ReadAddr, uint16_t nByte)

{

while(nByte--)

{

*pBuffer = FLASH_ReadByte(ReadAddr);

ReadAddr++;

pBuffer++;

}

}


读操作一般都很简单,不管是读FLASH还是EEPROM,基本上操作都类似。为什么我们买的U盘读取速度远大于写的速度,原因就在这里。

C.EEPROM_WriteNByte:EEPROM写N字节

void EEPROM_WriteNByte(uint8_t* pBuffer, uint32_t WriteAddr, uint16_t nByte)

{

FLASH_Unlock(FLASH_MEMTYPE_DATA);

while(FLASH_GetFlagStatus(FLASH_FLAG_DUL) == RESET);

while(nByte--)

{

FLASH_ProgramByte(WriteAddr, *pBuffer);

WriteAddr++;

pBuffer++;

FLASH_WaitForLastOperation(FLASH_MEMTYPE_DATA);

}

FLASH_Lock(FLASH_MEMTYPE_DATA);

}

和FLASH的写对比,可以看得出来,他们之间的差别在于参数:FLASH_MEMTYPE_DATA.

D.EEPROM_ReadNByte:EEPROM读N字节

void EEPROM_ReadNByte(uint8_t* pBuffer, uint32_t ReadAddr, uint16_t nByte)

{

while(nByte--)

{

*pBuffer = FLASH_ReadByte(ReadAddr);

ReadAddr++;

pBuffer++;

}

}

E.main函数读写验证

FLASH_WriteNByte(WriteBuf, FLASH_ADDR, BUF_SIZE);

TIMDelay_Nms(500);

FLASH_ReadNByte(ReadBuf, FLASH_ADDR, BUF_SIZE);

UART1_SendNByte(ReadBuf, BUF_SIZE);

通过UART打印“读BUF”的数据,可以看得出来,我们从FLASH中写入的数据是否正确。

两个工程代码实现功能都一样,注意地址。


打印数据如下:

00 00 00 00 00 00 00 00 00 00(打印未读写操作之前的“读BUF”数据)

41 31 42 32 43 33 44 34 45 35(十六进制显示)

A1B2C3D4E5(字符形式显示)


下载 Ⅳ

STM8S资料:

http://pan.baidu.com/s/1o7Tb9Yq

软件源代码工程(STM8S-A07_内部xxx编程):

http://pan.baidu.com/s/1c2EcRo0


关键字:STM8S  片内FLASH  EEPROM编程 引用地址:STM8S_ 007_片内FLASH和EEPROM编程

上一篇:STM8S_ 006_AWU自动唤醒
下一篇:浅谈STM8S_008_WDG独立看门狗和窗口看门狗

推荐阅读最新更新时间:2024-11-01 14:00

基于IAR开发环境的STM8S模拟IIC代码
基于IAR STM8 2.10开发环境,STM8S005K6单片机,模拟IIC方式读写AT24C16或AT24C32,已验证可以正常对AT24C32进行读写数据,只是有个疑问,对于单片机接SDA脚的IO口进行方向控制反而引起时序不正常而读写不了数据,例程中是将此IO口始终设置为输出,不知道会不会有隐患,有待测试... 以下是代码,完整代码请下载附件,包含完整工程! #include 24Cxx.h #include stm8s.h #include stm8s_gpio.h #define AT24C32_SETSDAIN GPIO_Init(AT24C32_SDA_PORT, GPIO_PIN_6,
[单片机]
STM8S汇编代码分析
br data-filtered= filtered 其中.asm文件是汇编代码的源文件,.inc文件是包含文件,类似于 a class= replace_word title= C语言知识库 href= http://lib.csdn.net/base/c target= _blank C语言 /a 当在的.c文件和.h文件。接下来让我们来分析一下这三个文件。(分析汇编代码最好也要对STM8单片机的启动流程有所了解,可以看我的另一篇博文 a href= http://blog.csdn.net/u010093140/article/details/49982879 http://blog.csdn.net/u01009314
[单片机]
<font color='red'>STM8S</font>汇编代码分析
STM8S学习笔记-关于时钟安全系统
关于时钟安全系统: 1. 问题:执行下面的程序后,程序为什么会进入时钟中断服务函数? 程序复位后,开始执行下面程序。 CLK_HSECmd(ENABLE); flag= CLK_GetFlagStatus(CLK_FLAG_HSERDY); while(!CLK_ClockSwitchConfig(CLK_SWITCHMODE_MANUAL, CLK_SOURCE_HSE, DISABLE, DISABLE)); //HSI切换到HSE。 CLK- CSSR |= CLK_CSSR_CSSEN; //时钟安全系统使能。 CLK_ITConfig(CLK_IT_CSSD, ENABLE); //打开时钟检测中
[单片机]
STM8S 硬件SPI驱动74HC595
简介:一直对STM8S的硬件SPI感兴趣,但没有真正使用过,以往都是用IO口模拟,这次刚好有个板子上有两个595驱动的8位LED数码管,就在上面试了一把,把过程记录一下。 硬件接线图: 595是数据接收器件,所以MCU只用了3条线与之相连,分别是MOSI接SER,SCK接CLK,NSS接RCK。其实这里RCK可以用其他的IO口的。 相关的代码: LOCAL uint8 DISP_BUF ={0,1,2,3,4,5,6,7}; //显示缓冲区 PUBLIC uint8 DISP_TAB = //显示码表 { 0x14,0xD7,0x4C,0x45,0x87,0x25,0x24,0x57,0x04,0x05,0x06,
[单片机]
<font color='red'>STM8S</font> 硬件SPI驱动74HC595
STM8S 使用IAR在线调试配置
STM8S103单片机使用IAR进行程序开发和调试 1.在程序调试没有错误后 选择 “Options” 进行配置 2.选择配套的单片机型号 3.配置库文件路径、宏定义头文件 4.选择“Debugger”选项“ST-LINK” 5.选择其中一个进行在线调试 注:两种调试模式的区别 Flash调试和RAM调试 1)Debug with Downloading: Downloads the application and starts C-SPY so that you can debug the project object file. If necessary, a make will be perf
[单片机]
<font color='red'>STM8S</font> 使用IAR在线调试配置
解决stm8s配置timer2中断时间不准
问题描述: 项目工程基于stm8s003芯片,以定时器2为例,定时器初始化后,发现第一次进入中断的时间不是设定的值,似乎是立即进入了中断。后面的中断时间就正常了。实际首次进入中断时间可以通过设置GPIO电平变化,用示波器测量得到。项目中由于在处理超声波测距时使用定时器来计数定时中断,初始化过程中偷偷的触发了中断导致第一次测距出现了误差。 问题分析: 软件规避:配置定时器时,先关闭更新中断,死等中断标志,清除标志后再开中断即可,跳过第一次的中断发生。 根本原因:当然是翻官方datasheet,查看timer2相关配置参数定位为配置定时器的分频值未生效。 手册章节18.4.1 Time base unit中关于Prescale
[单片机]
解决<font color='red'>stm8s</font>配置timer2中断时间不准
STM8s外部时钟晶振失效时钟安全系统CSS启动演示
使用的最小系统晶振是8m的。 这里说下配置过程: 时钟自动切换,开启切换中断 在中断里面清除中断标志,使能CSS并开启CSS中断 CSS中断发生,清除CSS中断标志,将HSI二分频,即16M/2=8M,与外部晶振相同,这样不会影响串口波特率 窗口输出配置信息: 用手触碰PA1、PA2引脚使外部晶振失效 串口输出CSS中断
[单片机]
<font color='red'>STM8s</font>外部时钟晶振失效时钟安全系统CSS启动演示
STM8S 三种时钟源的配置HSE\HSI\LSI的配置
1. 关于HSE的时钟配置为主时钟 static void CLK_Config(void) { CLK_DeInit(); // 初始化 CLK_HSECmd(ENABLE); //使能HSE CLK_ClockSwitchConfig(CLK_SWITCHMODE_AUTO, CLK_SOURCE_HSE, DISABLE, CLK_CURRENTCLOCKSTATE_DISABLE); //切换HSE 并关闭其他时钟 为自动模式 /*Enable CSS interrupt */ CLK_ITConfig(CLK_IT_CSSD, ENABLE); /* Enab
[单片机]
<font color='red'>STM8S</font> 三种时钟源的配置HSE\HSI\LSI的配置
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved