S3C2440裸机------NandFlash编程_芯片id读取

2024-08-30 23:08

本文主要是介绍S3C2440裸机------NandFlash编程_芯片id读取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.芯片id读取时序图

 2.使能芯片

3.发送命令函数

4.发送地址函数

5.读数据函数

 6.完整代码


1.芯片id读取时序图

我们先看一下NandFlash芯片手册中读取id的时序图,后面我们要根据这个时序图去写代码。

 2.使能芯片

从前面的时序图我们可以看出,我们首先要发出片选信号,我们通过设置下图寄存器的Reg_nCE位来进行设置,

void nand_select(void)
{/*使能片选*/NFCONT &=~(1<<1);
}void nand_deselect(void)
{/*禁止片选*/NFCONT |= (1<<1);
}

3.发送命令函数

我们从最前面的时序图可以看到,要想读取设备id,首先要向NandFlash发送90命令,然后相应的CLE和WE信号要使能,这里的时序不需要我们管,我们只需要往命令寄存器写值即可,NandFlash控制器会为我们做好相应的时序。

void nand_cmd(unsigned char cmd)
{volatile int i;NFCCMD = cmd;for(i=0; i<10; i++);
}

4.发送地址函数

void nand_addr_byte(unsigned char addr)
{volatile int i;NFADDR = addr;for(i=0; i<10; i++);
}

5.读数据函数

unsigned char nand_data(void)
{return	NFDATA;
}

 6.完整代码

#include "s3c2440_soc.h"
#include "my_printf.h"void nand_init(void)
{
#define  TACLS   0
#define  TWRPH0  1
#define  TWRPH1  0/*设置NAND FLASH的时序*/NFCONF = (TACLS<<12) | (TWRPH0<<8) | (TWRPH1<<4);/*使能NAND FLASH控制器,初始化ECC,禁止片选*/NFCONT = (1<<4) | (1<<1) | (1<<0);
}void nand_select(void)
{/*使能片选*/NFCONT &=~(1<<1);
}void nand_deselect(void)
{/*禁止片选*/NFCONT |= (1<<1);
}void nand_cmd(unsigned char cmd)
{volatile int i;NFCCMD = cmd;for(i=0; i<10; i++);
}void nand_addr_byte(unsigned char addr)
{volatile int i;NFADDR = addr;for(i=0; i<10; i++);
}unsigned char nand_data(void)
{return	NFDATA;
}void nand_chip_id(void)
{ unsigned char buf[5]={0};nand_select(); nand_cmd(0x90);nand_addr_byte(0x00);buf[0] = nand_data();buf[1] = nand_data();	buf[2] = nand_data();buf[3] = nand_data();buf[4] = nand_data();	nand_deselect(); 	printf("maker   id  = 0x%x\n\r",buf[0]);printf("device  id  = 0x%x\n\r",buf[1]);	printf("3rd byte    = 0x%x\n\r",buf[2]);		printf("4th byte    = 0x%x\n\r",buf[3]);			printf("page  size  = %d kb\n\r",1  <<  (buf[3] & 0x03));	printf("block size  = %d kb\n\r",64 << ((buf[3] >> 4) & 0x03));	printf("5th byte    = 0x%x\n\r",buf[4]);}void nand_flash_test(void)
{char c;while (1){/* 打印菜单, 供我们选择测试内容 */printf("[s] Scan nand flash\n\r");printf("[e] Erase nand flash\n\r");printf("[w] Write nand flash\n\r");printf("[r] Read nand flash\n\r");printf("[q] quit\n\r");printf("Enter selection: ");c = getchar();printf("%c\n\r", c);/* 测试内容:* 1. 识别nand flash* 2. 擦除nand flash某个扇区* 3. 编写某个地址* 4. 读某个地址*/switch (c)		 {case 'q':case 'Q':return;break;case 's':case 'S':nand_chip_id();break;case 'e':case 'E':break;case 'w':case 'W':break;case 'r':case 'R':break;default:break;}}
}

这篇关于S3C2440裸机------NandFlash编程_芯片id读取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1122193

相关文章

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

解决Java中基于GeoTools的Shapefile读取乱码的问题

《解决Java中基于GeoTools的Shapefile读取乱码的问题》本文主要讨论了在使用Java编程语言进行地理信息数据解析时遇到的Shapefile属性信息乱码问题,以及根据不同的编码设置进行属... 目录前言1、Shapefile属性字段编码的情况:一、Shp文件常见的字符集编码1、System编码

利用Python实现添加或读取Excel公式

《利用Python实现添加或读取Excel公式》Excel公式是数据处理的核心工具,从简单的加减运算到复杂的逻辑判断,掌握基础语法是高效工作的起点,下面我们就来看看如何使用Python进行Excel公... 目录python Excel 库安装Python 在 Excel 中添加公式/函数Python 读取

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言