移植三星版本uboot_s5pv210
2017-02-15 19:13
204 查看
我自己来移植的步骤:
1.移植前工作
重新编译的sd_fusing。原版是在64位下编译的用file查看,需要cd sd_fusing ; make clean ; make生成x64文件。
检查主Makefile中的交叉编译工具链的路径是否相同,vi打开,/CROSS_COPILE搜索。
*********疑问:TEXT_BASE和CFG_PHY_UBOOT_BASE的区别。。不都是同一个链接地址么?一个是虚拟地址,一个是物理地址??定义为33E00000确实为物理地址。
2.
1).先看根目录下的Makefile,找到配置的目标。决定的make config的东西以及使用的配置头文件。搜索210找到smdkv210single.h,所以make distclean ;make smdkv210single_config ;make -j4
2).编译烧录发现开发板置锁,串口无输出只有一句SD checksum erro。
3.
在lowlevel_init.S中屏蔽PMIC_InitIp,即可启动uboot,去第二阶段了。
首先发现在打印信息中DDR信息错误。在init_sequence中的DDR相关的宏以修改打印信息。
**但是还要修改lowlevel中初始DDR用到的参数DMC0_MEMCONFIG_0
修改了这里的后,第二阶段不能启动。可能是和内存或地址映射相关。
**修改virt_to_phy中的宏的函数的基地址。修改后仍如上图。修改mmu_table让0xc00-0xd00映射到0x300开头的地址。又重新启动。用md等命令试一下。
4.
/*创立CFG_NO_FLASH宏(注意没有值的宏就和没有一样)并修改相应的makefile(drivers/mtd下的 Makefile有norflash相关代码)。实际上注释掉宏CONFIG_FLASH_CFI_LEGACY就行。*/但是有一系列问题出现,跳过
5.
解决SD/MMC问题。信息打印unrecognised EXT_CSD structure version 6,在source insight中搜索EXT_CSD,发现问题所在。但是在这里只能根据老师讲的记忆,改一下版本兼容将5改为8,但其他的并看不懂。先编译烧录看一下。
6.网卡驱动移植。
1).关键在于init_board函数中又调用的dm9000_pre_init()。驱动部分不需要修改。
修改内容需要根据底板图的连接方法,网卡芯片是接到srom(SRAM/ROM)中的。
2).CSn1表示接到bank1上,基址为0x88000000,看user_manu的section1的memory map.将其中若干的左移20位改为左移4位即可。(改了三个寄存器)
3).
修改部分宏
#define CONFIG_DM9000_BASE (0x88000300) //本来应该是0x88000000但是似乎这个网卡内部有偏移量300
#define DM9000_DATA (CONFIG_DM9000_BASE+4) //CMD连接在addr2上,高时为数据传输。4即为0x100
1.移植前工作
重新编译的sd_fusing。原版是在64位下编译的用file查看,需要cd sd_fusing ; make clean ; make生成x64文件。
检查主Makefile中的交叉编译工具链的路径是否相同,vi打开,/CROSS_COPILE搜索。
*********疑问:TEXT_BASE和CFG_PHY_UBOOT_BASE的区别。。不都是同一个链接地址么?一个是虚拟地址,一个是物理地址??定义为33E00000确实为物理地址。
2.
1).先看根目录下的Makefile,找到配置的目标。决定的make config的东西以及使用的配置头文件。搜索210找到smdkv210single.h,所以make distclean ;make smdkv210single_config ;make -j4
2).编译烧录发现开发板置锁,串口无输出只有一句SD checksum erro。
3.
在lowlevel_init.S中屏蔽PMIC_InitIp,即可启动uboot,去第二阶段了。
首先发现在打印信息中DDR信息错误。在init_sequence中的DDR相关的宏以修改打印信息。
**但是还要修改lowlevel中初始DDR用到的参数DMC0_MEMCONFIG_0
修改了这里的后,第二阶段不能启动。可能是和内存或地址映射相关。
**修改virt_to_phy中的宏的函数的基地址。修改后仍如上图。修改mmu_table让0xc00-0xd00映射到0x300开头的地址。又重新启动。用md等命令试一下。
4.
/*创立CFG_NO_FLASH宏(注意没有值的宏就和没有一样)并修改相应的makefile(drivers/mtd下的 Makefile有norflash相关代码)。实际上注释掉宏CONFIG_FLASH_CFI_LEGACY就行。*/但是有一系列问题出现,跳过
5.
解决SD/MMC问题。信息打印unrecognised EXT_CSD structure version 6,在source insight中搜索EXT_CSD,发现问题所在。但是在这里只能根据老师讲的记忆,改一下版本兼容将5改为8,但其他的并看不懂。先编译烧录看一下。
6.网卡驱动移植。
1).关键在于init_board函数中又调用的dm9000_pre_init()。驱动部分不需要修改。
修改内容需要根据底板图的连接方法,网卡芯片是接到srom(SRAM/ROM)中的。
2).CSn1表示接到bank1上,基址为0x88000000,看user_manu的section1的memory map.将其中若干的左移20位改为左移4位即可。(改了三个寄存器)
3).
修改部分宏
#define CONFIG_DM9000_BASE (0x88000300) //本来应该是0x88000000但是似乎这个网卡内部有偏移量300
#define DM9000_DATA (CONFIG_DM9000_BASE+4) //CMD连接在addr2上,高时为数据传输。4即为0x100
相关文章推荐
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——NAND 8位硬件ECC
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot-spl.bin(时钟初始化)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——配置过程(一)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植NAND FLASH
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot-spl.bin(核心初始化)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——NAND 8位硬件ECC
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——编译过程
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot-spl.bin(内存初始化)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——NAND 启动
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——SPL
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——命令补全和历史命令
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——NAND 启动
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot-spl.bin(点亮led灯)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot.bin(内存布局)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot.bin(内存布局)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot.bin(修改显示信息)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植开始
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot.bin(打印串口控制台)
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——命令补全和历史命令
- tiny210(s5pv210)移植u-boot(基于 2014.4 版本)——移植u-boot-spl.bin(核心初始化)