S3C2440移植uboot之支持NANDFLASH操作

S3C2440移植uboot之支持NANDFLASH操作上一节我们移植了uboot,S3C2440移植uboot之支持NORFLASH。这节我们继续移植,支持NANDFLASH。之前由于nand部分报错,直接注释了 u-boot-2012.04.01\include\configs\smdk2440.h中的#defineCONFIG_CMD_NAND。现在我们去掉注释,重新编译。报错如下是我们没有定义CONFIG_S3C2410导致的可以…

大家好,又见面了,我是你们的朋友全栈君。

  上一节我们移植了uboot,S3C2440移植uboot之支持NORFLASH。这节我们继续移植,支持NANDFLASH。

移植Uboot其他文章链接:

S3C2440移植uboot之编译烧写uboot

S3C2440移植uboot之新建单板_时钟_SDRAM_串口

S3C2440移植uboot之启动过程概述

S3C2440移植uboot之支持NAND启动

S3C2440移植uboot之支持NORFLASH

S3C2440移植uboot之支持NANDFLASH操作

S3C2440移植uboot之支持DM9000

S3C2440移植uboot之裁剪和修改默认参数

S3C2440移植uboot之支持烧写yaffs映像及制作补丁

编译报错

  之前由于nand部分报错,直接注释了 u-boot-
2012.04.01\include\configs\smdk2440.h 中的#define CONFIG_CMD_NAND。现在我们去掉注释,重新编译。报错如下
在这里插入图片描述
  我们没有定义CONFIG_S3C2410导致的
在这里插入图片描述
  可以看到下面有2440的NAND结构体
在这里插入图片描述

拷贝s3c2410_nand.c,修改宏定义支持SC32440

  所以我们可以拷贝一份s3c2410_nand.c给2440使用2410的NandFlash位于drivers/mtd/nand/s3c2410_nand.c,首先复制s3c2410_nand.c,改为s3c2440_nand.c,改Makefile,如下图所示:
在这里插入图片描述
  在上一章分析过CONFIG_NAND_S3C2410宏,位于include/configs/smdk2440.h:
在这里插入图片描述
在这里插入图片描述

  如上图所示,其中CONFIG_CMD_NAND宏:表示uboot是否支持nand,在上章里,我们把它屏蔽了,接下来便取消屏蔽CONFIG_CMD_NAND宏。
继续添加对CONFIG_NAND_S3C2440宏的支持,将:

#ifdef CONFIG_CMD_NAND
#define CONFIG_NAND_S3C2410
#define CONFIG_SYS_S3C2410_NAND_HWECC
#define CONFIG_SYS_MAX_NAND_DEVICE 1
#define CONFIG_SYS_NAND_BASE 0x4E000000
#endif

改为

#ifdef CONFIG_CMD_NAND

 
#ifdef CONFIG_S3C2410 
#define CONFIG_NAND_S3C2410
#define CONFIG_SYS_S3C2410_NAND_HWECC
#else // CONFIG_S3C2440 
#define CONFIG_NAND_S3C2440 
#define CONFIG_SYS_S3C2440_NAND_HWECC
#endif

#define CONFIG_SYS_MAX_NAND_DEVICE 1
#define CONFIG_SYS_NAND_BASE 0x4E000000
#endif

  由于smdk2410.h中定义的是CONFIG_S3C2410,而smdk2440.h中定义的是CONFIG_S3C2440,所以便会根据上面的#ifdef来动态定义宏

修改s3c2440_nand.c 中的NFCONF,NFCONT,支持S3C2440

  往下看代码发现原来的NFCONF设置并不能匹配我们的2440
在这里插入图片描述

在这里插入图片描述
  2440的NFCONF的15位是保留的
在这里插入图片描述
  所以注释掉这部分代码
在这里插入图片描述
  2410 NFCONF的其他位设置也不匹配我们的2440
在这里插入图片描述
  2440NFCONF 时序参数设置
在这里插入图片描述
  s3c2440_hwcontrol中使能选中
在这里插入图片描述

在这里插入图片描述

  对照2440手册修改为支持2440的
在这里插入图片描述
  修改为

/*2440的NAND时序设置*/
	cfg = ((tacls-1)<<12)|((twrph0-1)<<8)|((twrph1-1)<<4);

	nand_reg->nfcont=(1<<1)|(1<<0); // bit1:关闭片选(), bit0:开启nand flash 控制器
	nand_reg->nfconf = (tacls<<12) | (twrph0<<8) | (twrph1<<4); //设置时序

	writel(cfg, &nand_reg->nfconf);
	/* 使能NAND Flash控制器, 初始化ECC, 禁止片选 */
	writel((1<<4)|(1<<1)|(1<<0), &nand_reg->nfcont);
	
	/* initialize nand_chip data structure */
	nand->IO_ADDR_R= (void *)&nand_reg->nfdata;
	nand->IO_ADDR_W = (void *)&nand_reg->nfdata;

	nand->select_chip = s3c2440_select_chip;             //设置CE ;

修改s3c2440_hwcontrol区分命令和地址

/*ctrl:表示做什么,选中芯片/取消选中,发命令还是发地址 * cmd :命令值或者地址值 */
static void s3c2440_hwcontrol(struct mtd_info *mtd, int dat, unsigned int ctrl)
{ 
   
	struct nand_chip *chip = mtd->priv;        
    struct s3c2440_nand *nand = s3c2440_get_base_nand();   //获取nand寄存器地址
     
    if (ctrl & NAND_CLE)  
		 // 传输的是命令 
       writeb(dat,&nand->nfcmd);  
    else if (ctrl & NAND_ALE)     
		 // 传输的是地址
       writeb(dat,&nand->nfaddr);  
}

  修改完成

添加选中芯片函数

  修改选中芯片函数

nand->select_chip = NULL;             //设置CE ;

  改为

nand->select_chip = s3c2440_select_chip;             //设置CE ;

  选中芯片函数如下

static void s3c2440_select_chip(struct mtd_info *mtd, int chipnr)
{ 
   
	struct s3c2440_nand *nand = s3c2440_get_base_nand();

	switch (chipnr) { 
   
	case -1:
		/*取消选中*/
		nand->nfcont |=(1<<1);
		break;
	case 0:
		/*选中*/
		nand->nfcont &=~(1<<1);
		break;

	default:
		BUG();
	}
}

  编译烧写
  如下图所示,可以看到已支持Nand Flash:
在这里插入图片描述

  试验nand是否能读写:

nand erase 0 2000                      //擦除
mw.b 30000000 0x55 2000               //向30000000 写入0x55,长度为2000
nand write 30000000 0 2000        //将0x55写入nand,
nand dump 0 2000        //打印

  如下图所示, 可以看到读写nand都没问题
在这里插入图片描述
  下一节S3C2440移植uboot之支持DM9000我们将移植DM9000网卡程序。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136695.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • netty 释放bytebuf_python高性能框架

    netty 释放bytebuf_python高性能框架目录一、ByteBuf介绍二、分配方式堆缓冲区直接缓冲区ByteBufAllocatorUnpooled缓冲区三、ByteBuf的操作可丢弃字节可读字节可写字节索引管理查找操作派生缓冲区引用计数工具类资源释放一、ByteBuf介绍网络数据的基本单位总是字节。JavaNIO提供了ByteBuffer作为它的字节容器…

    2022年9月19日
    0
  • 花指令_cmp指令

    花指令_cmp指令本文作者:sodme本文出处:http://blog.csdn.net/sodme声明:本文能够不经作者允许随意转载、复制、引用。但不论什么对本文的引用,均须注明本文的作者、出处以及本行声明信息。可能

    2022年8月2日
    4
  • jmeter安装及使用基本教程「建议收藏」

    jmeter安装及使用基本教程「建议收藏」一、安装1.安装jdk,配置环境变量附:JRE(JavaRuntimeEnvironment)Java运行环境,用来运行JAVA程序的。JDK(JavaDevelopmentKit)Java开发工具包,包含JRE。因此只需要下载安装JDK即可中。JDK是SunMicrosystems针对Java开发员的产品,JSP运行环境需要JDK的支持。JDK是整个Java的核心,…

    2022年5月17日
    35
  • jsonArray字符串转List

    jsonArray字符串转ListjsonArray字符串转List&lt;Map&lt;String,String&gt;&gt;StringjsonStr="[{user:{name:\"张三\",age:\"20\"}},{score:{yuwen:\"80\",shuxue:\"90\"}}]";List&lt;Map&lt;Stri

    2022年5月14日
    107
  • rpm安装和卸载[通俗易懂]

    rpm安装和卸载[通俗易懂]一安装RPM是RedHat公司随RedhatLinux推出了一个软件包管理器,通过它能够更加轻松容易地实现软件的安装。  1.安装软件:执行rpm-ivhrpm包名,如:  #rpm-ivhapache-1.3.6.i386.rpm  2.升级软件:执行rpm-Uvhrpm包名。  3.反安装:执行rpm-erpm包名。  4.查询软件包的详细信息:执行r

    2022年5月22日
    87
  • pycharm激活码永久破解[最新免费获取]

    (pycharm激活码永久破解)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~S32PGH0SQB-eyJsaWNlbnNlSWQiOi…

    2022年3月26日
    158

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号