关于S3C2440NAND操作中s3c2440_write_addr_lp函数地址变换说明
2018-02-26 11:10
411 查看
源程序static void s3c2440_write_addr_lp(unsigned int addr)
{
int i;
volatile unsigned char *p = (volatile unsigned char *)&s3c2440nand->NFADDR;
int col, page;
col = addr & NAND_BLOCK_MASK_LP;
page = addr / NAND_SECTOR_SIZE_LP;
*p = col & 0xff; /* Column Address A0~A7 */
for(i=0; i<10; i++);
*p = (col >> 8) & 0x0f; /* Column Address A8~A11 */
for(i=0; i<10; i++);
*p = page & 0xff; /* Row Address A12~A19 */
for(i=0; i<10; i++);
*p = (page >> 8) & 0xff; /* Row Address A20~A27 */
for(i=0; i<10; i++);
*p = (page >> 16) & 0x03; /* Row Address A28~A29 */
for(i=0; i<10; i++);
}
Column Address:列地址:进行页内寻址(一页2K+64Byte,A0-A10共2^11=2048(2K),A11用于OOB地址寻址,一般不用,为LOW;共12根地址线)
http://bbs.csdn.net/topics/360034390
{
int i;
volatile unsigned char *p = (volatile unsigned char *)&s3c2440nand->NFADDR;
int col, page;
col = addr & NAND_BLOCK_MASK_LP;
page = addr / NAND_SECTOR_SIZE_LP;
*p = col & 0xff; /* Column Address A0~A7 */
for(i=0; i<10; i++);
*p = (col >> 8) & 0x0f; /* Column Address A8~A11 */
for(i=0; i<10; i++);
*p = page & 0xff; /* Row Address A12~A19 */
for(i=0; i<10; i++);
*p = (page >> 8) & 0xff; /* Row Address A20~A27 */
for(i=0; i<10; i++);
*p = (page >> 16) & 0x03; /* Row Address A28~A29 */
for(i=0; i<10; i++);
}
本人试验内容为:从nand的4096地址读取2K大小的数据到SDRAM,发送的地址为:0x1000,对应以上顺序为 0x00 0x00 0x02 0x00 0x00,如果直接按照数据手册里面的对应关系是对应不上的,其中对应关系查下列资料得知:A0-A10为column address(页内部寻址2048<大页>),A11为spare(校验区域 spare area)寻址,A12-A28才为页地址寻址,比如4096处位于第2页(从第0页开始算),则对应页地址为2,A12【0】 A13【1】 A14【0】...A28【0】=0x0002NAND存储结构图如下:
Column Address:列地址:进行页内寻址(一页2K+64Byte,A0-A10共2^11=2048(2K),A11用于OOB地址寻址,一般不用,为LOW;共12根地址线)
Row Address:行地址:页寻址(A12-A28)参考链接:http://www.360doc.com/content/16/1026/07/30098124_601411050.shtml(存在一些问题解释错误)
http://bbs.csdn.net/topics/360034390
相关文章推荐
- 关于字符串操作的一些函数简单说明与应用
- Thinkphp3.2 关于快捷函数 模板引擎换为smarty时 地址跳转函数U()的使用修改及说明
- 关于序列切片的一些操作说明
- OpenGL累积缓存的操作函数详细说明
- 关于距离变换函数distanceTransform使用注意事项
- 关于输入输出函数的几点说明
- 关于虚函数和 Qt 的 Event 函数的简单说明
- 蓝牙4.0协议关于广播地址的说明
- 关于Linux驱动文件的加载以及相关符号的地址说明
- 关于“幽灵架构”的补充说明2:Struct以及Copy - on -Write
- 关于ThinkPHP5.0*的软删除delete_time的引用和部分时间函数where(),whereTime()连贯操作的问题
- Java+Jsp:关于日期时间操作函数类全解
- Pcomm.dll(串口通讯库)中流控函数操作的说明手册
- 关于WriteFile函数的lpNumberOfBytesWritten在Win8开始的不同
- java中关于时间日期操作的常用函数(转摘)
- 关于宗函数f(t)下的一对单边函数的拉普拉斯的正反变换中左,右边函数的相关求法,证明及相关定义,补充Z变换的同理求法
- android中关于SD卡的常用操作函数
- c语言关于文件操作的常用函数(新手入门看)
- linux文件操作函数(open、write、read、close)
- 名字与地址转换的函数,gethostbyname()、gethostbyaddr()函数