• 易迪拓培训,专注于微波、射频、天线设计工程师的培养
首页 > 无线通信 > 技术文章 > C8051F35X单片机内部Flash存储器的擦写方法

C8051F35X单片机内部Flash存储器的擦写方法

录入:edatop.com     点击:

摘要:为避免在程序运行时向单片机内置的Flash写入数据导致复位,采用调用锁定与关键码的操作方法对C2805lF35X型单片机的Flash进行擦除、写入和读取操作,并提供程序范例。该方法无需任何接口电路,使用方便,成本低且安全可靠。此方法已应用于包装机控制器,实现包装参数的保存和修改,效果良好。

关键词:C805lF35X;Flash;单片机;包装机

C805lF35X是Cygnal公司推出的混合信号片上系统型单片机MCU,采用CIP-5l内核可大大提升指令运行速度,另外该器件内部还具有一个完整而先进的时钟系统和片内调试电路,其内置的Flash代替ROM和EPROM,不仅为用户的存储提供方便,还大大简化电路。这里给出使用C80-5lF35X单片机内部Flash存储器的擦除、写入和读取操作方法。

1 存储器结构

C805lF35X单片机内部含有2个独立的存储器:程序存储器和数据存储器。程序存储器中包含8 KB可在系统编程的Flash存储器。C8051-F35X通过设置程序存储写允许位(PSCTL.0)采用MOVX指令对程序存储器写入。如图l所示。

这8 KB的Flash存储器在一个连续的存储器块内(地址范围为OX0000~OXlDFF,OXlE00以上的地址保留),其通过硬件接口或采用MOVX指令对Flash存储器在系统编程。

为了保证操作正确,写入和擦除操作由硬件自动定时,无需数据查询判断写/擦除操作何时结束。程序在Flash写入/擦除操作时停止执行。

2 Flash存储器的锁定与解锁

在Flash操作之前,必须按顺序向Flash锁定和关键码寄存器(FLKEY)写入正确的关键码,该关键码禁止对知识产权信息(以程序或常数形式存储在Flash中)进行未经授权访问或防止用户无意修改程序代码以及因系统条件异常导致代码改变。写关键码时必须按顺序写,否则Flash写入或擦除操作被禁止,直到下一次系统复位。存储在Flash用户空间的最后一个字节的安全锁定字节保护Flash存储器,使其不被非保护代码或通过硬件接口读写或擦除。使用安全锁定字节时有以下关键点:1)将Flash安全字节中的位设置为0,保护Flash存储器不通过JTAG接口被访问;2)采用软件设置一个软件读访问限制,保护存储器不被读取;3)已被软件访问保护的Flash存储器也应用Flash安全字节进行保护。使其不通过JTAG接口访问;4)在保护Flash时,包含Flash安全字节的Flash页也应保护;5)如果最终用户无需访问Flash,可通过简单锁定整个Flash存储器保护其不通过JTAG访问。

3 Flash数据擦除

采用软件MOVX指令对Flash存储器编程,在使用MOVX指令前,先允许Flash写操作,其过程为:1)将程序存储写允许位PSWE(PSCTL.0)设置为逻辑"1",这将使MOVX操作指向目标Flash存储器;2)按顺序向Flash锁定寄存器(FLKEY)写入Flash关键码,PSWE位将保持置位状态,直到被软件清除。

在采用软件修改Flash内容前,PSWE必须置为逻辑"l";而在软件擦除Flash存储器前,PSWE位和PSEE位都必须置为逻辑"1"。写入Flash存储器操作可清除数据位,但不能使数据位置"1",只有擦除操作能将Flash中的数据位置为"l"。所以在写入新值前,必须先擦除待编程地址。Flash存储器是以512字节的扇区为单位构成的,一次擦除操作将擦除整个扇区(将扇区内的所有字节置为OXFF)。

擦除一个扇区的步骤如下:1)禁止中断;2)置"l"程序存储器擦除允许位(PSCTL中的PSEE),以允许Flash扇区移除:3)置"1"程序存储器写允许位(PSCTL中的PSWE),允许Flash写入;4)向FLKEY写第1个关键码:0XA5;5)向FLKEY写第2个关键码:0XFl;6)用MOVx指令向待擦除页内的任何一个地址写入1个数据字节;7)清除PSWE和PSEE位;8)重新允许中断。

作者:陈富安 张 莹 河南工业大学 来源:电子设计工程

上一篇:基于FPGA的双口RAM实现及应用
下一篇:IPv6应用技术之RFID与IPv6结合

手机天线设计培训教程详情>>

手机天线设计培训教程 国内最全面、系统、专业的手机天线设计培训课程,没有之一;是您学习手机天线设计的最佳选择...【More..

射频和天线工程师培训课程详情>>

  网站地图