于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设计很差。

以上三点理由让我不会再选择友善的产品!

最新文章

  1. DNS 中的协议字段详细定义
  2. grabcut
  3. js对象4-js原型--杂志
  4. C++11外部模板
  5. NGUI UIGrid 动态刷新布局 && BUG FIX
  6. UI进阶 数据加密
  7. [转]StructLayout特性
  8. Assigning Host USB device to a Guest VM
  9. 【JS】Intermediate1:The DOM
  10. 安装xdebug后var_dump输出没有格式化的问题
  11. Django_xadmin后台全局设置
  12. 微信小程序 project.config.json 配置
  13. 解决spring多线程不共享事务的问题
  14. Python——管道通信
  15. 79、iOS 的Cocoa框架、Foundation框架以及UIKit框架
  16. SpringMVC整合Thymeleaf
  17. SQL左外连接
  18. The user survey(用户调查)
  19. STL源码剖析——hashtable
  20. R语言中的Apriori关联规则的使用

热门文章

  1. Windows7 配置两个版本的java环境,可自由切换
  2. Lorenzo Von Matterhorn(STL_map的应用)
  3. 九度OJ 1201:二叉排序树 (二叉树)
  4. 学习Sharding JDBC 从入门到出门-02:源码揣测
  5. Orthogonal Least Squares Learning Algorithm for Radial Basis Function Networks
  6. spring 事物管理
  7. 2.Django命令行工具搭建项目(django-admin.py & manage.py)
  8. 电脑Svchost.exe 进程占CPU100% 的解决办法
  9. READ_TEXT
  10. 如何禁止eclipse对js文件的校验(building validate)