S3C2440移植uboot之支持NANDFLASH操作

news/2025/2/23 15:30:40

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

文章目录

  • 编译报错
  • 拷贝s3c2410_nand.c,修改宏定义支持SC32440
  • 修改s3c2440_nand.c 中的NFCONF,NFCONT,支持S3C2440
  • 修改s3c2440_hwcontrol区分命令和地址
  • 添加选中芯片函数

移植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_nandc_NFCONFNFCONTS3C2440_67">修改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_105">修改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网卡程序。


http://www.niftyadmin.cn/n/1315421.html

相关文章

Hadoop2.8.5 MapReduce计算框架

Hadoop 中 YARN 子系统的使命是为用户提供大数据的计算框架。早期的Hadoop ,甚至早期的 YARN 都只提供一种计算框架,那就是 MapReduce。 Hadoop 后来有了一些新的发展,除 MapReduce 外又提供了称为 Chain 和 Stream 的计算框架,一来使用户不必非得用 Java 编程;二来更允许用户利…

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

上一节S3C2440移植uboot之支持DM9000移植uboot支持了网卡驱动&#xff0c;这节裁剪和修改uboot默认参数 文章目录uboot的环境参数修改uboot的默认环境变量查看 default_environment[]裁剪uboot解决rtc_xxx&#xff0c;cmd_date.c 错误设置分区设置save相关宏设置mtdparts命令测…

javascript时间个性化格式

/* 1. < 60s, 显示为“刚刚” 2. > 1min && < 60 min, 显示与当前时间差“XX分钟前” 3. > 60min && < 1day, 显示与当前时间差“今天 XX:XX” 4. > 1day && < 1year, 显示日期“XX月XX日 XX:XX” 5. > 1year, 显示具体日期“…

Atitit.软件兼容性原理与实践 v3 q326.docx

Atitit.软件兼容性原理与实践 v3 q326.docx 1. 架构兼容性1 2. Api兼容性1 2.1. 新api vs 修改旧的api1 3. Web方面的兼容性&#xff08;js&#xff0c;html&#xff09;1 3.1. Threadlocal2 4. 数据库表兼容性2 4.1. 2. 扩展表模式2 5. 兼容性策略2 5.1. Atitit.兼容性的“一…

Hadoop2.8.5 MapReduce计算流程

上一篇我们从宏观的角度从作业认领到分发考察了MapReduce框架。今天我们来探究其内部&#xff0c;从宏观上说, MR 框架主要就是 Map 和 Reduce 这两个阶段。但是实际上远不是那么简单,这两个宏观的阶段都进一步划分成好几个更微观的阶段&#xff0c;前面提到过的排序(Sort )阶段…

Hadoop2.8.5 分布式文件系统HDFS

Hadoop的两大系统之一“HDFS”。所谓分布,是说整个文件系统的内容并非集中存储在一台或几台“文件服务器上”,而是分散在集群的不同节点上。理想的情景是集群内的每一台机器都承担着一些内容的存储。HDFS 是 Hadoop 集群的文件系统,这是一种分布( distributed )、容错( faultto…

软件项目成功之要素

我们在不断探寻更好的软件开发方法&#xff0c;希望能找到适合自己和团队的好办法。不过&#xff0c;基于既有的教条&#xff0c;关于各种开发方法孰优孰劣的讨论最终总会演变成激烈的争吵。字典中教条的定义是“一种权威性观点&#xff0c;但并没有充分的依据”。我们经常会看…

Hadoop2.8.5 数据节点 DataNode

数据节点 DataNode 在 HDFS 文件系统中处于从属的地位, 但是其结构却比处于主导地位的查名节点 NameNode 更复杂。这是因为:虽然 NameNode 起着目录的作用,但是文件的内容却是存储在 DataNode 上的,读写文件时一旦知道了哪一个块在什么节点上,或者指定存放在什么节点上,下面就不…