打印
[MCU]

MSP430F149的存储器结构及FLASH读写

[复制链接]
428|3
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
deadtime|  楼主 | 2019-5-20 20:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
1      概述
1.1 FLASH特点
    写操作只能将1改写为0,不能将0改写成1。FLASH擦除后所有单元变为1,擦除操作只能针对整个段。FLASH在擦除前不能被改写。
1.2 MSP430F149存储器编址方式
    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 操作
  三种操作:读取、擦除(只能针对段擦除)、写入(可以写入单个字节)。

使用特权

评论回复

相关帖子

沙发
deadtime|  楼主 | 2019-5-20 20:21 | 只看该作者
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中。

使用特权

评论回复
板凳
deadtime|  楼主 | 2019-5-20 20:21 | 只看该作者
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

使用特权

评论回复
地板
deadtime|  楼主 | 2019-5-20 20:22 | 只看该作者
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

}

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

44

主题

470

帖子

2

粉丝