历史上的今天
今天是:2025年04月26日(星期六)
2019年04月26日 | 关于S3C2440NAND操作中s3c2440_write_addr_lp函数地址变换说明
2019-04-26 来源:eefocus
源程序
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++);
}
本人试验内容为:从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】=0x0002
NAND存储结构图如下:

Column Address:列地址:进行页内寻址(一页2K+64Byte,A0-A10共2^11=2048(2K),A11用于OOB地址寻址,一般不用,为LOW;共12根地址线)
Row Address:行地址:页寻址(A12-A28)
史海拾趣
|
Chrome渲染引擎同Safari 正开发Linux和MAC版 北京时间9月2日消息:据国外媒体报道,Google周一通过漫画宣布,将推出网络浏览器 Chrome。目前,有关Chrome的技术内容也逐渐出现在了网上。 据悉,Chrome浏览器使用了开源的网页渲染引擎WebKit,这个引擎也被使用在了苹果公司的Safari浏览器中, ...… 查看全部问答> |
|
本人有个带驱动器的步进电机,型号为BL55S-M01是三星打印机上的,上面带一个10针的插座分别为:1.24V 2. 24V 3.GND 4.GND 5.BK 6.5V(NC) 7.ST/SP 8.RD 9.CLK 10.CW /CCW。哪位高手能否介绍一下那些管脚的作用?… 查看全部问答> |
|
我用的是友善mini2440,Nand Flash型号是K9F1G08,现在是裸机学习; 我在进行读操作时,读出的第一个字节总是 30,然后才是真正的数据; 我的写操作写不进去。 请大家指点下。谢谢! … 查看全部问答> |
|
请教;以前在在ST Visual Develop环境下完成的程序现在移植到IAR环境编译报如下错误:不知问题出在哪?? Building configuration: stm8lianfang - Debug Updating build tree... Linking Error[Lp011]: section placement failed: una ...… 查看全部问答> |




