在看vivi时遇到的问题,请各位帮帮忙,bootloader

发布于 2022-09-29 13:32:15 字数 2166 浏览 19 评论 0

这是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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

丑丑阿 2022-10-06 13:32:15

你先把nandflash的硬件原理搞清楚,那么这些问题也会想清楚了。

贱贱哒 2022-10-06 13:32:15

第一、第二个问题:关键字nandflash IO宽度8位,寄存器宽度32位,所以要写四次地址给寄存器。
第三个问题:当读出Nandflash的地址后,然后将该地址的数据读到指定的存储空间。第一个for是延迟100ns。
nandflash的最小的操作单元是块(=528字节,数据512+OOB16),所以第二个for事实使得循环了512次。NAND_SECTOR_SIZE一般等于512。

葮薆情 2022-10-06 13:32:15

手册是说15位 设1是enable吗?
    /* chip Enable */
    NFCONF &= ~0x800;
这个是什么意思?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文