tiny4412sdk-1506原生uboot卡死
于16年2月多购买了tiny4412sdk-1506,用友善之臂(以下简称友善)的superboot是可以进入linux,而用三星原始的uboot_tiny4412-20130729则不可以。出现现象是卡在“OK”,偶尔能继续跑下去。根据以往开发的经验,可以知道这绝对是ddr3配置的问题,查看“Tiny4412-1306-Schematic”是4颗ddr3@16bit,用到一个控制器两个片选(chip0,chip1),而“Tiny4412-1412-Schematic”(对应我购买的PCB)是2颗ddr3@16bit,只需要一个控制器一个片选(chip0)。
(1306版本最好是两个控制器一个片选,能把ddr3带宽提升到64bit,可能技术/成本原因没实现)
以下是我做的补丁包,代码如下:
diff -uNrp uboot_tiny4412/board/samsung/tiny4412/mem_init_tiny4412.S uboot_tiny4412_kevin/board/samsung/tiny4412/mem_init_tiny4412.S
--- uboot_tiny4412/board/samsung/tiny4412/mem_init_tiny4412.S -- ::03.511480729 +
+++ uboot_tiny4412_kevin/board/samsung/tiny4412/mem_init_tiny4412.S -- ::09.950628589 +
@@ -, +, @@ mem_ctrl_asm_init: ldr r1, =0x0FFF301A
str r1, [r0, #DMC_CONCONTROL]
- ldr r1, =0x00312640
+ ldr r1, =0x00302640 @这里只有一个chip0
str r1, [r0, #DMC_MEMCONTROL] - ldr r1, =0x40e01323
+ ldr r1, =0x40C01333 @Row是15bit,偏移地址是0x3FFFFFFF(1GB)
str r1, [r0, #DMC_MEMCONFIG0]
- ldr r1, =0x60e01323
+ ldr r1, =0x80C01333 @可以不修改,这里只为了说明控制器0地址到达0x7FFFFFFF
str r1, [r0, #DMC_MEMCONFIG1] #ifdef CONFIG_IV_SIZE
@@ -, +, @@ mem_ctrl_asm_init:
str r1, [r0, #DMC_TIMINGPOWER]
#endif
#ifdef MCLK_400
- ldr r1, =0x4046654f
+ ldr r1, =0x6946654f @根据ddr3颗粒规格书微调参数
str r1, [r0, #DMC_TIMINGROW] @TimingRow
- ldr r1, =0x46400506
+ ldr r1, =0x46460506 @根据ddr3颗粒规格书微调参数
str r1, [r0, #DMC_TIMINGDATA] @TimingData
- ldr r1, =0x52000a3c
+ ldr r1, =0x5200183c @根据ddr3颗粒规格书微调参数
str r1, [r0, #DMC_TIMINGPOWER] @TimingPower
#endif @@ -, +, @@ mem_ctrl_asm_init:
: subs r2, r2, #
bne 4b -#if 1
+#if 0 @去掉chip1代码
/* chip 1 */
ldr r1, =0x07100000
str r1, [r0, #DMC_DIRECTCMD]
@@ -, +, @@ mem_ctrl_asm_init: ldr r1, =0x0FFF301A
str r1, [r0, #DMC_CONCONTROL]
- ldr r1, =0x00312640
+ ldr r1, =0x00302640
str r1, [r0, #DMC_MEMCONTROL] - ldr r1, =0x40e01323 @Interleaved?
+ ldr r1, =0x40c01333 @Interleaved?
str r1, [r0, #DMC_MEMCONFIG0]
- ldr r1, =0x60e01323
+ ldr r1, =0x80C01323
str r1, [r0, #DMC_MEMCONFIG1] #ifdef CONFIG_IV_SIZE
@@ -, +, @@ mem_ctrl_asm_init:
str r1, [r0, #DMC_TIMINGPOWER]
#endif
#ifdef MCLK_400
- ldr r1, =0x4046654f
+ ldr r1, =0x6946654f @根据ddr3颗粒规格书微调参数
str r1, [r0, #DMC_TIMINGROW] @TimingRow
- ldr r1, =0x46400506
+ ldr r1, =0x46460506 @根据ddr3颗粒规格书微调参数
str r1, [r0, #DMC_TIMINGDATA] @TimingData
- ldr r1, =0x52000a3c
+ ldr r1, =0x5200183c @根据ddr3颗粒规格书微调参数
str r1, [r0, #DMC_TIMINGPOWER] @TimingPower
#endif @@ -, +, @@ mem_ctrl_asm_init:
: subs r2, r2, #
bne 4b -#if 1
+#if 0 @去掉chip1代码
/* chip 1 */
ldr r1, =0x07100000
str r1, [r0, #DMC_DIRECTCMD]
diff -uNrp uboot_tiny4412/board/samsung/tiny4412/tiny4412.c uboot_tiny4412_kevin/board/samsung/tiny4412/tiny4412.c
--- uboot_tiny4412/board/samsung/tiny4412/tiny4412.c -- ::03.511480729 +
+++ uboot_tiny4412_kevin/board/samsung/tiny4412/tiny4412.c -- ::21.071493254 +
@@ -, +, @@ void dram_init_banksize(void)
gd->bd->bi_dram[].size = PHYS_SDRAM_3_SIZE;
gd->bd->bi_dram[].start = PHYS_SDRAM_4;
gd->bd->bi_dram[].size = PHYS_SDRAM_4_SIZE;
+ gd->bd->bi_dram[].start = PHYS_SDRAM_5; //BANK数量改变
+ gd->bd->bi_dram[].size = PHYS_SDRAM_5_SIZE;
+ gd->bd->bi_dram[].start = PHYS_SDRAM_6;
+ gd->bd->bi_dram[].size = PHYS_SDRAM_6_SIZE;
+ gd->bd->bi_dram[].start = PHYS_SDRAM_7;
+ gd->bd->bi_dram[].size = PHYS_SDRAM_7_SIZE;
+ gd->bd->bi_dram[].start = PHYS_SDRAM_8;
+ gd->bd->bi_dram[].size = PHYS_SDRAM_8_SIZE; #ifdef CONFIG_TRUSTZONE
gd->bd->bi_dram[nr_dram_banks - ].size -= CONFIG_TRUSTZONE_RESERVED_DRAM;
diff -uNrp uboot_tiny4412/drivers/mmc/mmc.c uboot_tiny4412_kevin/drivers/mmc/mmc.c
--- uboot_tiny4412/drivers/mmc/mmc.c -- ::04.479480708 +
+++ uboot_tiny4412_kevin/drivers/mmc/mmc.c -- ::42.119732762 +
@@ -, +, @@ static int mmc_read_ext_csd(struct mmc *
ext_csd_struct = ext_csd[EXT_CSD_REV];
host->ext_csd.boot_size_multi = ext_csd[BOOT_SIZE_MULTI]; - if (ext_csd_struct > ) {
+ if (ext_csd_struct > ) { //若不修改,进入uboot会提示无法识别版本,原因是友善用的emmc颗粒版本较高
printf("unrecognised EXT_CSD structure "
"version %d\n", ext_csd_struct);
err = -;
diff -uNrp uboot_tiny4412/include/configs/tiny4412.h uboot_tiny4412_kevin/include/configs/tiny4412.h
--- uboot_tiny4412/include/configs/tiny4412.h -- ::03.834845777 +
+++ uboot_tiny4412_kevin/include/configs/tiny4412.h -- ::01.719191442 +
@@ -, +, @@
#ifdef CONFIG_EVT0_STABLE
#define CONFIG_NR_DRAM_BANKS 2
#else
-#define CONFIG_NR_DRAM_BANKS 4
+#define CONFIG_NR_DRAM_BANKS 8 //BANK提高到8
#endif
-#define SDRAM_BANK_SIZE 0x10000000 /* 256 MB */
+#define SDRAM_BANK_SIZE 0x08000000 /* 128 MB */ //每个BANK容量减小
#define PHYS_SDRAM_1 CONFIG_SYS_SDRAM_BASE /* SDRAM Bank #1 */
#define PHYS_SDRAM_1_SIZE SDRAM_BANK_SIZE
#define PHYS_SDRAM_2 (CONFIG_SYS_SDRAM_BASE + SDRAM_BANK_SIZE) /* SDRAM Bank #2 */
@@ -, +, @@
*/
/* Fastboot variables */
#define CFG_FASTBOOT_TRANSFER_BUFFER (0x48000000)
-#define CFG_FASTBOOT_TRANSFER_BUFFER_SIZE (0x18000000) /* 384MB */
+#define CFG_FASTBOOT_TRANSFER_BUFFER_SIZE (0x30000000) /* 768MB */ //当初为了调原生uboot启动android5.0修改,这里跟uboot启动无关
#define CFG_FASTBOOT_ADDR_KERNEL (0x40008000)
#define CFG_FASTBOOT_ADDR_RAMDISK (0x41000000)
#define CFG_FASTBOOT_PAGESIZE (2048) // Page size of booting device
以上的注释都是patch之后后续加上,只为了方便阅读。修改后的uboot启动android 4.2是可以正常启动,但无法运行android 5.0(启动一段时间后自动跑飞),问了其他人均表示此现象。
询问友善说是uboot问题。应该是superboot做了其他处理,这里没有能力继续研究下去。
1:友善的售后做的很差,把客户当傻X;
2:开源力度相当低;
3:硬件&PCB设计很差。
以上三点理由让我不会再选择友善的产品!
tiny4412sdk-1506原生uboot卡死的更多相关文章
- 基于tiny4412原生uboot修改制作SD启动并烧写到emmc
最近入手tiny4412的标准板,底板SDK型号为1506.但是因为友善之臂提供的superboot不能进入boot菜单,此时我就不能通过tftp下载内核和通过nfs挂载根文件系统,于是想自己做个ub ...
- X-007 FriendlyARM tiny4412 u-boot移植之内存初始化
<<<<<<<<<<<<<<<<<<<<<<<<< ...
- tiny4412 --Uboot移植(5) DDR3内存
开发环境:win10 64位 + VMware12 + Ubuntu14.04 32位 工具链:linaro提供的gcc-linaro-6.1.1-2016.08-x86_64_arm-linux-g ...
- tiny210——uboot移植Makefile文章分析
这东西已经写,我们没有时间发布,如今,终于有时间稍微长送记录汇总uboot学习过程.具体了.以后忘了也能够再温习回来嘛有些特殊字符显示得乱掉了 Makefile追踪技巧: 技巧1:能够先从编译目标開始 ...
- 海思uboot启动流程详细分析(二)
1. 第二个start.S 从start_armboot开始,在startup.c中有包含#include <config.h> 在config.h中: /* Automatically ...
- 原生 table css实现操作按钮固定右侧及底部滚动 IE不会卡死
需求的表格比较复杂(各种合并新增删除),elementUi的table组件无法满足需求,故而写了原生table,且与其他用了table组件的表格保持一致. 贴一下简单的代码,只实现操作按钮固定右侧以及 ...
- 嵌入式系统烧写uboot/bootloader/kernel的一般方法
嵌入式系统烧写uboot/bootloader/kernel的一般方法 本文介绍了在嵌入式系统中烧写uboot/bootloader/kernel 的一般方法,以及如果uboot或者内核出现错误, ...
- X-008 FriendlyARM tiny4412 uboot移植之copy u-boot到DDR内存
<<<<<<<<<<<<<<<<<<<<<<<<< ...
- X-006 FriendlyARM tiny4412 u-boot移植之Debug串口用起来
<<<<<<<<<<<<<<<<<<<<<<<<< ...
随机推荐
- JS 创建对象(常见的几种方法)
贴个代码先: function O(user,pwd){ //use constructor this.user=user; this.pwd=pwd; this.get=get; return th ...
- 【BZOJ3105】[cqoi2013]新Nim游戏 贪心+线性基
[BZOJ3105][cqoi2013]新Nim游戏 Description 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作,每次可以选一个 ...
- 小团队Git协作流程
git和svn 最大的差异在于git是分布式的管理方式而svn是集中式的管理方式. 集中式 集中式代码管理的核心是服务器,所有开发者在开始coding之前必须从服务器获取代码,然后开发,最后解决冲突, ...
- 2017-2018-1 20179209《Linux内核原理与分析》第八周作业
Linux内核如何装载和启动一个可执行程 一.实验 1.1理解编译链接的过程和ELF可执行文件格式. 1.1.1编译链接过程 能用图说明的问题,就少用文字描述: 1.1.2ELF可执行文件 ELF可执 ...
- js实现粘贴板复制
<a href = '#' onclick ='javascript:window.clipboardData.setData('text','${form.param}');alert('クリ ...
- Data Structure Linked List: Merge Sort for Linked Lists
http://www.geeksforgeeks.org/merge-sort-for-linked-list/ #include <iostream> #include <vect ...
- js常用方法(。。。。不完整)
lastIndexOf();substring();split();slice();splice(); var s="http://www.baidu.com"; var unit ...
- Android蓝牙串口通讯【转】
本文转载自:http://blog.sina.com.cn/s/blog_631e3f2601012ixi.html Android蓝牙串口通讯 闲着无聊玩起了Android蓝牙模块与单片机蓝牙模块的 ...
- RabbitMQ之Exchange
交换机的作用: 生产者发送消息不会向传统方式直接将消息投递到队列中,而是先将消息投递到交换机中,在由交换机转发到具体的队列,队列在将消息以推送或者拉取方式给消费者进行消费,这和我们之前学习Nginx有 ...
- Zookeeper简单配置
1.配置zookeeper 解压tar包后,在conf目录下,有一个zoo_sample.cfg,拷贝一份并命名为zoo.cfg cp zoo_sample.cfg zoo.cfg 编辑修改数据路径, ...