s3c2440 移值u-boot-2016.03 第4篇 支持NAND flash 识别

发布时间:2023-09-04  

1, /include/configs/smdk2440.h
中添加
#define CONFIG_CMD_NAND
编译
drivers/mtd/nand/built-in.o: In function `nand_init_chip':
/u-boot-2016.03/drivers/mtd/nand/nand.c:76: undefined reference to `board_nand_init'
发现是少了文件
/drivers/mtd/nand/s3c2410_nand.c 复制为
/drivers/mtd/nand/s3c2440_nand.c 打开 里面的 所有 2410 换为 2440

drivers/mtd/nand/Makefile
添加一行
obj-$(CONFIG_NAND_S3C2440) += s3c2440_nand.o

2, 重新编辑
编译通过了,应该是用不上,烧写试机
NAND: 0 MiB 虽然没有报错,但是未实别出来。

3, 修改代码支持 NAND FLASH
2410 和 2440 控制寄存器有些不同,可能是这些原因。
在 nand_scan() 中扫 NAND FLASH ,实别出来容量大小。
/drivers/mtd/nand/nand_base.c
ret = nand_scan_ident(mtd, maxchips, NULL);
if (!ret)
ret = nand_scan_tail(mtd);
return ret;

原理和 NOR FLASH 差不多,实别出来ID 比较就知道大小了

应该是对应 s3c2440_nand.c 里面的
int board_nand_init(struct nand_chip *nand)
{
初始化修改,尽量使用定义的方式,方便 后期修改
//cfg = S3C2440_NFCONF_EN; 取消 15位 用不上 2440 中是保留位

smdk2440.h 中添加定义
#define CONFIG_S3C24XX_CUSTOM_NAND_TIMING
#define CONFIG_S3C24XX_TACLS 1
#define CONFIG_S3C24XX_TWRPH0 2
#define CONFIG_S3C24XX_TWRPH1 1
去掉 硬件 ECC
#define CONFIG_SYS_S3C2440_NAND_HWECC

4, 添加 #define DEBUG 打开调试信息
NAND: board_nand_init()
end of nand_init
hwcontrol(): 0xff 0x83
hwcontrol(): 0xffffffff 0x81
dev_ready
hwcontrol(): 0x90 0x83
hwcontrol(): 0x00 0x85
hwcontrol(): 0xffffffff 0x81
dev_ready
hwcontrol(): 0x90 0x83
hwcontrol(): 0x00 0x85
hwcontrol(): 0xffffffff 0x81
dev_ready
hwcontrol(): 0x90 0x83
hwcontrol(): 0x40 0x85
hwcontrol(): 0xffffffff 0x81
dev_ready
hwcontrol(): 0xffffffff 0x80
0 MiB

0x81 最后一位是1表示选中
0x83 ..选中
0x85 ..选中
0x80 最后一位是0就是不选中

board_nand_init() 还应该是有问题的。
加上 启用 nfcont 控制器
/* 4 ECC
* 1 CE 先不选中,用的时候在选中
* 0 启动 flash controller
*/
writel(1<<4 | 1<<1 | 1, &nand_reg->nfcont);

修改选中 及 命令 地址 寄存器定义, 注意这里是 ! NCLE
s3c24x0_hwcontrol()
if (!(ctrl & NAND_CLE))
IO_ADDR_W |= S3C2440_ADDR_NCLE;
if (!(ctrl & NAND_ALE))
IO_ADDR_W |= S3C2440_ADDR_NALE;
对比 2410 和 2440 选中控制位不同,进行修改。
if (ctrl & NAND_NCE)
writel(readl(&nand->nfconf) & ~S3C2440_NFCONF_nFCE,
&nand->nfconf);
else
writel(readl(&nand->nfconf) | S3C2440_NFCONF_nFCE,
&nand->nfconf);

修改
#define S3C2440_NFCONF_nFCE (1<<1)
其它的也修改下 参照手册
#define S3C2440_NFCONF_EN (1<<15)
#define S3C2440_NFCONF_512BYTE (1<<14)
#define S3C2440_NFCONF_4STEP (1<<13)
#define S3C2440_NFCONF_INITECC (1<<12)
#define S3C2440_NFCONF_nFCE (1<<1)
#define S3C2440_NFCONF_TACLS(x) ((x)<<12)
#define S3C2440_NFCONF_TWRPH0(x) ((x)<<8)
#define S3C2440_NFCONF_TWRPH1(x) ((x)<<4)
#define S3C2440_ADDR_NALE 8
#define S3C2440_ADDR_NCLE 0xc



nane_base.c
这里看下,默认的 nand_base 中的 取消选中的功能
static void nand_select_chip(struct mtd_info *mtd, int chipnr)
{
struct nand_chip *chip = mtd->priv;

switch (chipnr) {
case -1:
chip->cmd_ctrl(mtd, NAND_CMD_NONE, 0 | NAND_CTRL_CHANGE);
break;
case 0:
break;

default:
BUG();
}

对应的 s3c2440_nand 中的就是 调用这里
writel(readl(&nand->nfcont) | S3C2440_NFCONF_nFCE, &nand->nfcont);

ps: 经过后期 试验,发现,不能 nand write ,改进方法,见 u-boot 最后一篇的 补丁。


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    刚入门STM32。 就不要去管什么代码风格,程序架构的东西了,能把功能实现就不错了。 第一步你得把功能试下吧,实现过程中肯定会踩坑,然后再去想为什么?怎么优化? 你只有经历了这个过程,你对......
    将平坦的硅片连接到非常平坦的主板上而言很重要),更坚硬(能够更好地容纳越来越多、越来越小的线),也更稳固。 除了在基本功能上表现得更好之外,玻璃基板还有望使互连密度和光互连集成度提高10倍,让未来的芯片可以更快地处理更多数据。 应对......
    基板还有望使互连密度和光互连集成度提高10倍,让未来的芯片可以更快地处理更多数据。 应对玻璃基板的技术挑战 技术开发并非易事,总会遇到很多未知的困难,用玻......
    更好地容纳越来越多、越来越小的线),也更稳固。 除了在基本功能上表现得更好之外,玻璃基板还有望使互连密度和光互连集成度提高10倍,让未来的芯片可以更快地处理更多数据。 应对玻璃基板的技术挑战 技术......
    更好地容纳越来越多、越来越小的线),也更稳固。除了在基本功能上表现得更好之外,玻璃基板还有望使互连密度和光互连集成度提高10倍,让未来的芯片可以更快地处理更多数据。应对玻璃基板的技术挑战技术开发并非易事,总会......
    、铣床、镗床、火花机、车床,这些数控机床上有许多电气元件需要配合动作,因此检修检测根据情况需要选择合适的仪器设备,比如测电压电流静态参数,用什么仪器设备?如果分析信号波形时序是否正常,又需要用什么仪器设备? ......
    消息称台积电研究新的先进芯片封装技术:矩形代替圆形晶圆;6 月 20 日消息,IT之家援引日经亚洲报道,台积电在研究一种新的先进芯片封装方法,使用矩形基板,而不是传统圆形晶圆,从而在每个晶圆上放置更多的芯片......
    消息称台积电研究新的先进芯片封装技术:矩形代替圆形晶圆;台积电在研究一种新的先进芯片封装方法,使用矩形基板,而不是传统圆形晶圆,从而在每个晶圆上放置更多的芯片。消息人士透露,矩形......
    消息称台积电研究新的先进芯片封装技术:矩形代替圆形晶圆;IT之家 6 月 20 日消息,IT之家援引日经亚洲报道,在研究一种新的先进芯片封装方法,使用矩形基板,而不是传统圆形,从而在每个上放置更多的芯片......
    被捕获并稳定显示在屏幕上。 三、为什么测试一个方波时,示波器会显示正弦波? 1、波器上查看方波的用户可能会查看相同频率的正弦波来代替方波,此情况不一定代表示波器发生故障,而是......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>