在全志V3/V3s和索智S3/S3L上调试32MB NorFlash
选取MX25L25635F作为调试对象,其他型号的NorFlash开发调试原理基本一致。为了使V3/V3s/S3/S3L识别32MB NorFlash并正常工作,主要针对以下三个部分进行开发和调试。下文将针对这三个部分的开发进行说明。
- U-Boot
- Linux Kernel
- System Configuration
第一部分,U-boot
原始的SDK包支持3线模式,但没有支持4线模式,因此,必须在引导过程中加入4线模式。简单解释一下,3线模式是指NorFlash支持3x8位地址线,可以访问的地址空间是16MB(2^24/1024/1024),4线模式支持4x8位地址线,可以访问比16MB大的地址空间。找到源码文件drivers/spinor/sunxi_spinor.c,增加4线模式的使能函数。
static void spinor_enter_4bytes_addr(int enable)
{
int command = ;
if(spinor_4bytes_addr_mode == && enable == )
command = 0xB7;
else if(spinor_4bytes_addr_mode == && enable == )
command = 0xE9;
else
return ;
#ifdef CONFIG_ARCH_SUN8IW8P1
spic_config_dual_mode(, , , );
#endif
spic_rw(, (void*)&command, , );
return;
}
需要注意的是,0xB7和0xE9不代码所有32MB NorFlash的4线模式进入/退出命令,应从datasheet中获取相应的命令值。接下来,找到spinor_init函数,回复flash size大于16MB的处理。
if(spi_size > **/)
{
spinor_4bytes_addr_mode = ;
spinor_enter_4bytes_addr(ENABLE_4BYTES);
}
找到NorFlash读写函数__spinor_pp和__spinor_sector_normal_read,增加4线模式的数据读写代码片段。
------------写
if(spinor_4bytes_addr_mode == )
{
txnum = len+;
sdata[] = SPINOR_PP;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = page_addr & 0xff;
memcpy((void *)(sdata+), buf, len);
}
else if(spinor_4bytes_addr_mode == )
{
txnum = len+;
sdata[] = SPINOR_PP;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = page_addr & 0xff;
memcpy((void *)(sdata+), buf, len);
}
------------读
if(spinor_4bytes_addr_mode == )
{
txnum = ;
sdata[] = SPINOR_READ;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = page_addr & 0xff;
}
else if(spinor_4bytes_addr_mode == )
{
txnum = ;
sdata[] = SPINOR_READ;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = (page_addr >> ) & 0xff;
sdata[] = page_addr & 0xff;
}
最后需要在spinor_datafinish_card函数最后退出4线模式,这样做,刷机结束后,系统启动时才可以正确得到boot0,否则会重复刷机。
第二部分,Linux Kernel
内核部分的修改比较简单,在NorFlash设备驱动drivers/mtd/devices/m25p80.c中加入针对MX25L25635F这款32MB NorFlash的支持,如下:
--- a/drivers/mtd/devices/m25p80.c
+++ b/drivers/mtd/devices/m25p80.c
@@ -, +, @@ static const struct spi_device_id m25p_ids[] = {
{ "mx25l1606e", INFO(0xc22015, , * , , SECT_4K) },
{ "mx25l3205d", INFO(0xc22016, , * , , ) },
{ "mx25l6405d", INFO(0xc22017, , * , , ) },
- { "mx25l12805d", INFO(0xc22018, , * , , ) },
+ { "mx25l12805f", INFO(0xc22018, , * , , ) },
{ "mx25l12855e", INFO(0xc22618, , * , , ) },
{ "mx25l25635e", INFO(0xc22019, , * , , ) },
{ "mx25l25655e", INFO(0xc22619, , * , , ) },
@@ -, +, @@ static int __devexit m25p_remove(struct spi_device *spi)
} +static int m25p_shutdown(struct spi_device *spi)
+{
+ struct m25p *flash = dev_get_drvdata(&spi->dev);
+ const struct spi_device_id *id = spi_get_device_id(spi);
+ struct flash_info *info;
+ printk("m25p: spinor shutdown\n");
+
+ if(flash->addr_width == )
+ {
+ info = (void *)id->driver_data;
+ set_4byte(flash, info->jedec_id, );
+ }
+ return ;
+}
+
+
static struct spi_driver m25p80_driver = {
.driver = {
.name = "m25p80",
@@ -, +, @@ static struct spi_driver m25p80_driver = {
.id_table = m25p_ids,
.probe = m25p_probe,
.remove = __devexit_p(m25p_remove),
+ .shutdown = m25p_shutdown, /* REVISIT: many of these chips have deep power-down modes, which
* should clearly be entered on suspend() to minimize power use.
第三部分,System Configuration
V3/V3s/S3/S3L这4个平台的SDK里面,U-Boot和Kernel都会调用sys_config.fex的Nor配置,需要将Nor Flash的大小修改成32,意思是32MB。
@@ -, +, @@ max_speed_hz =
bus_num =
chip_select =
mode =
-sflash_size =
+sflash_size =
完成上述三个环节的修改以后,依次编译U-Boot,Linux Kernel,最后打包Firmware,烧录到设备。
在全志V3/V3s和索智S3/S3L上调试32MB NorFlash的更多相关文章
- 将日志备份推送到s3存储上
1.将日志备份推送到s3存储上 #!/bin/sh # 此脚本实现将/usr/local/netqin/boss/netqin/logs/BOSS_ContentServer/BOSS_AD_SDK ...
- aws s3文件上传设置accesskey、secretkey、sessiontoken
背景: 最近跟进的项目会封装aws S3资源管理细节,对外提供获取文件上传凭证的API,业务方使用获取到的凭证信息直接请求aws进行文件上传.因此,测试过程需要验证S3文件上传的有效性.aws官网有提 ...
- 亚马逊S3下载上传文件
引用网址: http://www.jxtobo.com/27697.html 下载 CloudBerry Explorer http://www.cloudberrylab.com/download- ...
- .NET快速信息化系统开发框架 V3.2->Web版本新增“文件管理中心”集上传、下载、文件共享等一身,非常实用的功能
文件中心是3.2版本开始新增的一个非常实用功能,可以归档自己平时所需要的文件,也可以把文件分享给别人,更像一个知识中心.文件中心主界面如下图所示,左侧“我的网盘”展示了用户对文件的分类,只能自己看到, ...
- AWS S3 递归上传文件和递归下载文件, 以及S3之间拷贝文件夹
1. 递归上传文件: aws s3 cp 本地文件夹 s3://bucket-name -- recursive --region us-east-1 2. 递归下载S3上的文件夹: cd 本地下载 ...
- Java连接S3并上传Redis
package com.shinho.bigdatalake.redis; import com.amazonaws.regions.Region; import com.amazonaws.regi ...
- storj白皮书v3最全面解读,Docker创始人的加入能否扳倒AWS S3
Storj新发了白皮书v3,地址是:https://storj.io/storjv3.pdf. 这次白皮书一共有90页,看完还真要费不少时间.如果你没有时间看,可以看一下我这篇快速技术解读. 上次St ...
- 小白自制Linux开发板(第二季 V3s篇) 一. 换个核心再来一次
1.前言 大家心心念念(个人认为)的小白自制开发板全新系列正式来了,之前我们使用全志的F1C200s芯片制作了一个小电脑,众所周知,调试很艰难,坑也很多,以至于墨云到现在还是没找到对应的补救方案,为了 ...
- NetworkComms V3 之同步收发数据
NetworkComms网络通信框架序言 NetworkComms通信框架,是一款来自英国的c#语言编写的通信框架,历时6年研发,成熟稳定,性能可靠. NetworkComms v3的核心功能在一定程 ...
随机推荐
- CentOS随笔 - 3.CentOS7安装Oracle 11g xe
前言 转帖请注明出处: http://www.cnblogs.com/Troy-Lv5/ 由于手上很多项目都是采用Oracle在进行开发, 所以安装Oracle成为必然. 当然有朋友会想为什么不安装1 ...
- C#多个线程同时执行一个任务示例
注意:如果电脑是单核单线程的,这么做是没有意义的. 这里直接贴一下主要代码 using System; using System.Collections.Generic; using System.T ...
- [翻译] LTInfiniteScrollView
LTInfiniteScrollView 效果: Usage - 使用 Create the scroll view by: 通过以下方式来创建出scroll view self.scrollView ...
- Linux下打包压缩war、解压war包和jar命令
情景:把project_a文件夹下的文件打包成project.war 1. 打包 jar -cvf project.war /project_a 说明: -c 创建war包 -v 显示过程信息 -f ...
- PHP根据图片制作缩略图
php中制作缩略图的方法也很简单,是用imagecopyresampled方法根据源图制作一个小一点的图片,来看代码check_image_addthumbs.php <?php //修改图片效 ...
- 请问在JAVA编程中什么叫耦合?什么又叫解藕? 悬赏分:0 - 解决时间:2008-3-8 12:55
模块一的实现依赖于模块二,更改模块二后,模块一也得更改,那么二者就有耦合.修改程序,使得更改模块二后,模块一不受影响,那么就叫解藕 请问<java编程思想>中的“完全解藕”如何理解,和实现 ...
- [Codeup 25481] swan
莫名其妙还找到了另一个铟炔锶烃的OJ : Codeup墓地 25481: swan 时间限制: 1 Sec 内存限制: 128 MB献花: 86 解决: 13[献花][花圈][TK题库] 题目描述 ...
- 四级菜单实现(Python)
menu_dict = { '山东' : { '青岛' : { '四方':{'兴隆路','平安路','杭州路'}, '黄岛':{}, '崂山':{} }, '济南' : { '历城':{}, '槐荫' ...
- Django中的CBV和FBV
Django中的CBV和FBV 一. CBV CBV是采用面向对象的方法写视图文件. CBV的执行流程: 浏览器向服务器端发送请求,服务器端的urls.py根据请求匹配url,找到要执行的视图类,执 ...
- spring整合mongo及调用
spring整合mongo(maven工程下): 1.web.xml文件中配置需要加载的配置文件: <listener> <listener-class>org.springf ...