在看vivi时遇到的问题,请各位帮帮忙,bootloader
这是vivi中的一个函数,是把copy_kernel_img中调用的一个函数,具体如下:
int
nand_read_ll(unsigned char *buf, unsigned long start_addr, int size)
{
int i, j;
if ((start_addr & NAND_BLOCK_MASK) || (size & NAND_BLOCK_MASK)) {
return -1; /* invalid alignment */
}
/* chip Enable */
NFCONF &= ~0x800;
for(i=0; i<10; i++);
for(i=start_addr; i < (start_addr + size) {
/* READ0 */
NFCMD = 0;
/* Write Address */
NFADDR = i & 0xff;
NFADDR = (i >> 9) & 0xff;
NFADDR = (i >> 17) & 0xff;
NFADDR = (i >> 25) & 0xff;
wait_idle();
for(j=0; j < NAND_SECTOR_SIZE; j++, i++) {
*buf = (NFDATA & 0xff);
buf++;
}
}
/* chip Disable */
NFCONF |= 0x800; /* chip disable */
return 0;
}
遇到了几个问题,请各位大虾帮解答:
1 NFADDR = i & 0xff;
NFADDR = (i >> 9) & 0xff;
NFADDR = (i >> 17) & 0xff;
NFADDR = (i >> 25) & 0xff;
这里,四句到底那个生效,就是说NFADDR到底=什么?
2 NFADDR = (i >> 9) & 0xff;这句,为什么是右移9位啊,FLASH是8位的话也不是右移9位啊.
3 这里有3个for语句,第三个for语句怎么是嵌套在第二个for里面的?什么作用?
问题菜,还是希望各位帮帮忙.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
你先把nandflash的硬件原理搞清楚,那么这些问题也会想清楚了。
第一、第二个问题:关键字nandflash IO宽度8位,寄存器宽度32位,所以要写四次地址给寄存器。
第三个问题:当读出Nandflash的地址后,然后将该地址的数据读到指定的存储空间。第一个for是延迟100ns。
nandflash的最小的操作单元是块(=528字节,数据512+OOB16),所以第二个for事实使得循环了512次。NAND_SECTOR_SIZE一般等于512。
手册是说15位 设1是enable吗?
/* chip Enable */
NFCONF &= ~0x800;
这个是什么意思?