- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
NOR Flash 编程
NOR Flash 编程//**************************************************************************************************//*** norflash操作原理:假设现在讨论的norflash连接在cpu的地址空间的0x0C000000位置的intel L18F256 32MB norflash(块大小为128KB)/*intel E28F128J3A150 16MB 16bit norflash 和bf561相连的接法为 :bf561 = E28F128J3A150A[23:1] = A[23:1] //bf561给norflash的地址信号D[15:0] = D[15:0] //bf561给norflash的数据信号/AMS0 = /CE //bf561给norflash的片选信号/AOE = /OE //bf561给norflash的读信号/AWE = /WE //bf561给norflash的写信号/BYTE //上拉为高 VPEN //上拉为高/RP //上拉为高*/1.norflash读取生产ID和设备ID的步骤:1)执行相应的命令序列:=向norflash的基地址发送命*(0x0C000000 + 0x5555) = 0x00AA;*(0x0C000000 + 0x2AAA) = 0x0055;*(0x0C000000 + 0x5555) = 0x0090;2)开始读取生产ID:(u16)mnfID=*(0x0C000000+0x0);3)开始读取设备ID:(u16)devID=*(0x0C000000+0x2);2.以块为单位擦除norflash的步骤:(假设擦除uboot所在分区:0x0C100000)1)禁止flash的写保护: //设置EMIFS_CONFIG寄存器的最低位为1(即让wp引脚输出为高)2)Block unlock *((short*)0x0C100000) = 0x0060; //块对齐地址*((short*)0x0C100000) = 0x00D0; //块对齐地址while(!(*((short*)0x0C100000) 0x0080)); //块对齐地址*((short*)0x0C100000) = 0x00FF; //设置norflash为read array模式3)执行擦除命令序列:=向要操作的块地址发送命令*((short*)0x0C100000) = 0x0020; //块对齐地址,INTEL_ERASE_CMD0*((short*)0x0C100000) = 0x00D0; //块对齐地址,INTEL_ERASE_CMD1while (!(*((short*)0x0C100000) 0x0080)); //块对齐地址,等待直到擦除结束 5)设置norflash为read array模式*((short*)0x0C100000) = 0x00FF; //让norflash重新进入read array模式6)使能flash的写保护://设置EMIFS_CONFIG寄存器的最低位为0(即让wp引脚输出为低)3.以块为单位写norflash的步骤:(假设写uboot所在分区:0x0C100000)/*发送写命令(0xE8)-发送数据-发送确认写命令(0xD0)-确认状态寄存器命令(0x70)-清掉状态寄存器命令(0x50)块对齐 字对齐 块对齐 字对齐 字对齐*/1)禁止flash的写保护://设置EMIFS_CONFIG寄存器的最低位为1(即让wp引脚输出为高)2)发送写命令: //块对齐地址*((short*)0x0C100000)=0x00E8; //块对齐地址,program setup commandwhile(!(*0x0C100000 0x0080)); //块对齐地址3)开始发送要写到flash的数据 =(这些数据会在norflash芯片内部的buffer中锁存起来) =每次2个字节,因为数据总线宽度为16位(short *)ulData = 0=SDRAM的地址(long *)psAddress = 0x0C000000 =Norflash的地址for(i=0; i15; i++){*psAddress = ulData[i];psAddress++;}4)通知norflash将存在自己buffer中的数据写到norflash的介质上:*((short*)0x0C100000)=0x00D0; //块对齐地址5)读状态寄存
您可能关注的文档
- 仁爱版八年级Unit 3Topic3归纳及配套练习.doc
- 北京大学15秋《大学英语2》作业4.doc
- 2012届高考英语知识点复习教案 第一册Unit 7 Cuitural relics.doc
- rrr名著名译选读精华段落.doc
- 巴诺书店第四季度净亏1.19亿美元 同比亏损扩大.doc
- 山西省三区八校2016届九年级中考适应性模拟考试(一)英语试题.doc
- 保护海洋生物多样性的原因.doc
- 共济会操控世界 美国总统历任只有两位不是其成员.docx
- 电子书市场资料.doc
- 2012年6月英语六级真题答案详解.doc
- 中国国家标准 GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- 《GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计》.pdf
- 中国国家标准 GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- 《GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置》.pdf
- 中国国家标准 GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- GB/T 17889.4-2024梯子 第4部分:铰链梯.pdf
- 《GB/T 17889.4-2024梯子 第4部分:铰链梯》.pdf
最近下载
- 企业存货管理问题研究——以森马服饰为例.doc
- 2012年数学建模竞赛答案之一 葡萄酒.pdf VIP
- 手机游戏的营销策略分析以《明日方舟》为例.docx VIP
- 急诊POCT专项测试卷附答案.doc
- 2023年全国数学建模竞赛D题的答案.doc VIP
- 100m3每天医疗污水处理方案.docx VIP
- PreSonus 普瑞声纳 Temblor T10EN,CN T10 OwnersManual 04272021说明书用户手册.pdf
- 2021年全国数学建模竞赛D题的答案.pdf VIP
- PreSonus 普瑞声纳 Eris E44EN,CN Eris E44 and E66 OwnersManual EN V3 01112021.说明书用户手册.pdf
- 2003全国大学生数学建模竞赛b题参考答案.docx
文档评论(0)