新闻中心

EEPW首页>嵌入式系统>设计应用> MSP430F149的存储器结构及FLASH读写

MSP430F149的存储器结构及FLASH读写

作者: 时间:2016-11-27 来源:网络 收藏
1 概述

1.1 FLASH特点

本文引用地址://m.amcfsurvey.com/article/201611/322341.htm

写操作只能将1改写为0,不能将0改写成1。FLASH擦除后所有单元变为1,擦除操作只能针对整个段。FLASH在擦除前不能被改写。

1.2MSP430F149存储器编址方式

MSP430F149的ROM为60K+256B的FLASH,RAM为2K。MSP430存储器采用冯诺依曼结构,RAM和ROM合在一起编址。MSP430F149内部集成有FLASH控制器,可以简化对FLASH的操作。

64K的寻址空间分为RAM、FLASH。

RAM分两块:

1、寄存器(0000H-01FFH),存放特殊寄存器、设备寄存器、变量与堆栈。

2、数据RAM(01FFH-),存放各种变量、中间结果、堆栈。

FLASH分两块:

1、主FLASH 一般用于存放程序代码。

2、信息FLASH(InfoFlash)用作掉电后保存少量数据。分为InfoA(0X1080-0X10FF)和InfoB(0X1000-0X1080),每段各128B。

1.3 操作

三种操作:读取、擦除(只能针对段擦除)、写入(可以写入单个字节)。

2使用方法

2.1 程序架构

读取FLASH方法和读取RAM方法相同。写和擦除FLASH要进行如下配置:

配置寄存器

制定指针地址

写数据/复制数据

配置寄存器

2.2 参数配置

主要配置三个寄存器FCTL1,FCTL2,FCTL3。

1、配置FLASH控制器时钟。时钟要求控制在250-470Khz之间。

FCTL2 = FWKEY + FSSEL0 + FN0; //2分频

2、用指针指向地址Unsigned char *ptr= (unsigned char *) 0x1080;

3、进入写模式或擦除模式FCTL1=FWKEY+WRT;或FCTL1=FWKEY+ERASE

4、清除锁定位 FCTL3=FWKEY;

5、写数据 *ptr=0x30;或擦除*ptr=0;

6、退出写状态,恢复锁存

FCTL1=FWKEY;

FCTL3=FWKEY+LOCK;

2.3 说明

上电FLASH默认状态是读。为防止错误操作,FLASH的三个寄存器FCTLX都采用了密码核对机制FWKEY。

上电时FLASH的InfoFLASH区域值均为1,可直接进行写操作,但此后的写操作必须先擦除才能正确写入。

MSP430系列单片机FLASH擦写典型次数是10万次,最低保证1万次。产品设计初期要规划好FLASH的寿命,尽量不让某些需要频繁改动的数据保存在FLASH中,这些数据可保存在RAM中,在断电前才存入FLASH中。

3相关寄存器

1、FCTL2

FWKEY Bits

15-8

FCTLx password. Always read as 096h. Must be written as 0A5h or a PUC

will be generated.

FSSELx Bits

7−6

Flash controller clock source select

00 ACLK

01 MCLK

10 SMCLK

11 SMCLK

FNx Bits

5-0

Flash controller clock divider. These six bits select the divider for the flash

controller clock. The divisor value is FNx + 1. For example, when FNx=00h,

the divisor is 1. When FNx=03Fh the divisor is 64.

FCTL2 = FWKEY + FSSEL0 + FN0;

2、FCTL1

FWKEY

Bits

15-8

FCTLx password. Always read as 096h. Must be written as 0A5h or a PUC

will be generated.

MERAS

ERASE

Bit 2

Bit 1

Mass erase and erase. These bits are used together to select the erase mode.

MERAS and ERASE are automatically reset when EMEX is set.

MERAS ERASE Erase Cycle

0 0 No erase

0 1 Erase individual segment only

1 0 Erase all main memory segments

1 1 Erase all main and information memory segments

WRT Bit 6 Write. This bit is used to select any write mode. WRT is automatically reset

when EMEX is set.

0 Write mode is off

1 Write mode is on

3、FCTL3

FWKEYx Bits

15-8

FCTLx password. Always read as 096h. Must be written as 0A5h or a PUC

will be generated.

LOCK Bit 4 Lock. This bit unlocks the flash memory for writing or erasing. The LOCK bit

can be set anytime during a byte/word write or erase operation and the

operation will complete normally. In the block write mode if the LOCK bit is set

while BLKWRT=WAIT=1, then BLKWRT and WAIT are reset and the mode

ends normally.

0 Unlocked

1 Locked

4 实例

4.1 上电后向InfoFLASH某单元写入一个字节数据

1、配置FLASH控制器时钟。时钟要求控制在250-470Khz之间。

FCTL2 = FWKEY + FSSEL0 + FN0; //2分频

2、用指针指向地址Unsigned char *ptr= (unsigned char *) 0x1080;

3、进入写模式FCTL1=FWKEY+WRT;

4、清除锁定位 FCTL3=FWKEY;

5、写数据 *ptr=0x30;

6、退出写状态,恢复锁存

注意FLASH操作期间不允许中断,所以写FLASH时要对全局中断允许进行操作。

代码如下:

WDTCTL = WDTPW + WDTHOLD; // Stop watchdog timer

FCTL2 = FWKEY + FSSEL0 + FN0; // MCLK/2 for Flash Timing Generator

unsigned char *ptr=(unsigned char *)0x1080;

FCTL1=FWKEY+WRT;

FCTL3=FWKEY;

_DINT();

*ptr=0x30;

while(FCTL3&BUSY);

_EINT();

FCTL1=FWKEY;

FCTL3=FWKEY+LOCK;

4.2 向FLASH的InfoA中连续写入128B数据

说明:通过FCTL1将FLASH设为段擦除模式后,只要向某个段内任何存储单元写入0即可进行擦除操作。

void write_SegA (char value)

{

char *Flash_ptr; // Flash pointer

unsigned int i;

Flash_ptr = (char *) 0x1080; // Initialize Flash pointer

FCTL1 = FWKEY + ERASE; // Set Erase bit

FCTL3 = FWKEY; // Clear Lock bit

*Flash_ptr = 0; // Dummy write to erase Flash segment

FCTL1 = FWKEY + WRT; // Set WRT bit for write operation

for (i=0; i<128; i++)

{

*Flash_ptr++ = value; // Write value to flash

}

FCTL1 = FWKEY; // Clear WRT bit

FCTL3 = FWKEY + LOCK; // Set LOCK bit

}



评论


技术专区

关闭