DIY编程器网

标题: C8051F35X单片机内部Flash存储器的擦写方法 [打印本页]

作者: liyf    时间: 2012-1-16 16:26
标题: C8051F35X单片机内部Flash存储器的擦写方法
摘要:为避免在程序运行时向单片机内置的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)重新允许中断。4 Flash数据写入??? Flash存储器可一次写1个字节,也可一次写1组字节,寄存器PFEOCN中的FLBWE位为一次Flash写操作可写入1个或2个字节。当FLBWE清零时,每次Flash写操作写入1个字节;当FLBWE位置为“1”时,每次Flash写操作写入2个字节(块写)。块写时间与单字节写的时间相同,在向Flash存储器写入大量数据时可节省时间。在单字节写Flash时,分别写入字节数据,每个MOVX写指令执行一次Flash写操作。C805lF35X的Flash存储器写入程序代码如下:

5 Flash数据读取??? 由于Flash读操作采用MOVC指令实现,因此用于读操作的Flash指针必须是CODE类型。由于Flash写操作是用MOVX指令实现的,所以写入或擦除操作的Flash指针必须是XDATA类型。对于C8051F35X的Flash存储器读取数据程序代码如下:??


                          
                       
                          
                                6 实际应用??? C805lF35X内部Flash存储器的读写操作可应用于包装机控制器的参数存储。在开机运行时如果每次重新输入分装重量值、分装精度等参数会降低工作效率,这时需在系统上电后自行调用事先设置的参数以简化工作人员的操作步骤,提高生产效率。图2是包装机参数调用流程。开机上电后先初始化串口,如果按下设置键重新设置分装重量,内部Flash需保存新参数,先将事先保存在Flash内的数据删除后再写入新数据,使掉电时数据不丢失,可在下次开机时直接调用数据。此方法已成功运用于包装机控制器中。

7 结论??? C805lF系列的其他型号的单片机Flash的基本操作只需修改上述程序代码即可完成Flash存储器的相关操作。此外,在线写入C805lF35X单片机片内Flash时需注意:1)Flash读写或擦除地址超出用户代码空间引起系统复位;2)1个Flash位一旦清零,必须经擦除才能回到“1”状态,在重新写入之前,一般要将数据字节擦除(置为0XFF);3)为保证Flash内容的正确性,用户使用软件对Flash存储器进行写或擦除操作时,需先使能片内VDD监视器。
                          
                       
                          
                               




欢迎光临 DIY编程器网 (http://diybcq.com/) Powered by Discuz! X3.2