MSP430F149 FLASH存储模块MSP430F149 FLASH存储模块.pdf

MSP430F149 FLASH存储模块MSP430F149 FLASH存储模块.pdf

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MSP430F149 FLASH存储模块MSP430F149 FLASH存储模块

MSP430F149 的存储器结构及FLASH 读写 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 操作 三种操作:读取、擦除(只能针对段擦除)、写入(可以写入 单个字节)。 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

文档评论(0)

vshoulrengb3 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档