- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
TX2440uboot移植
xg的 uboot在2440上移植(一)
我用的2440开发板,取名为TX2440。
make distclean
修改u-boot\cpu\arm920t\config.mk文件:
PLATFORM_RELFLAGS += -fno-strict-aliasing? -fno-common -ffixed-r8 \-msoft-float
注释掉 \ -msoft-float这一段,不使用软浮点编译。
?
解压U-BOOT-1.1.6,进入U-BOOT目录,修改Makefile:
在smdk2410_config :?????? unconfig??????? @$(MKCONFIG) $(@:_config=) arm arm920t smdk2410 NULL s3c24x0
加上
TX2440_config?:??? unconfig??????? @$(MKCONFIG) $(@:_config=) arm arm920t TX2440 NULL s3c24x0
各项的意思如下:arm: CPU的架构(ARCH)arm920t: CPU的类型(CPU),其对应于cpu/arm920t子目录。TX2440: 开发板的型号(BOARD),对应于board/TX2440目录。NULL: 开发者/或经销商(vender)。s3c24x0: 片上系统(SOC)。
?
在第128行:
ifeq ($(ARCH),arm)
CROSS_COMPILE = arm-linux-
指定交叉编译器,我使用的是3.4.1,这里也可以写绝对路径
?
修改完Makefile后,在board目录下,新建自己的开发板目录TX2440,把smdk2410目录下的所有文件拷到TX2440,把smdk2410.c改为TX2440.c。修改该目录下的Makefile,把smdk2410.o改为TX2410.o。
COBJS := TX2440.o flash.o
?
将board目录下所有文件夹全部删除,只留TX2440
?
在include/configs目录下创建板子的配置头文件,把smdk2410.h改名为TX2440.h,再把所有的文件全部删除,只留TX2440.h
?
测试能否编译成功:
执行make TX2440_config
出现make: execvp: …………/mkconfig: 权限不够
查看mkconfig的权限,发现没有可执行权限,用chmod 764 mkconfig加上权限
然后再make,成功后可出现 Configuring for TX2440 board.....
?
修改SDRAM配置,在board/TX2440/lowlevel_init.S中,检查
#define B6_BWSCON (DW32) 位宽为32
把B1_BWSCON 改为(DW16) B5_BWSCON 改为(DW8)
?
根据HCLK设置SDRAM?的刷新参数,主要是REFCNT寄存器,开发板HCLK为100M
将 #define REFCNT 0x1113 改为 #define REFCNT 0x4f4
(2)修改u-boot-1.1.6/include/configs/open24x0.h文件修改NAND FLASH MTD分区表:56 /*57 #define MTDPARTS_DEFAULT mtdparts=nandflash0:2m@0(kernel), \58???????????????????????????? 8m(jffs2), \59???????????????????????????? -(yaffs)60 */61 #define MTDPARTS_DEFAULT mtdparts=nandflash0: \ 62?????????????????????????? 256k@0(boot), \63?????????????????????????? 64k(env), \64?????????????????????????? 2m(kernel), \65?????????????????????????? -(yaffs)注:该分区表一定要与内核中的分区表一致,后面我会给出kernel中分区表的修改。
?
增加对S3C2440的支持,2440的时钟计算公式、NAND操作和2410不太一样。
对于2440开发板,将FCLK设为400MHz,分频比为FCLK:HCLK:PCLK=1:4:8。
?
修改board/TX2440/TX2440.c中的board_init函数
/* S3C2440: Mpll,Upll = (2*m
文档评论(0)