网站大量收购独家精品文档,联系QQ:2885784924

天祥T2440对uboot的移植.docx

  1. 1、本文档共19页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
uboot 在2440上移植(一) - xg日志 - 网易博客 2011-06-22 15:51 6611人阅读 评论(5) 收藏 举报 网易 asynchronousmakefilecdelayflash 以前一直在用 vivi,很精简很方便,源码很好懂,想改什么就改什么,但是功能差了点,所以移植个uboot 来跑跑,uboot 很好很强大,但是想搞清它的机制有点困难,先移植个最简单的试试,还没有增加对 yaffs 的支持和 usb 下载, 遇到一些小问题也都解决了。 我用的2440开发板,取名为 TX2440。 解压 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 增加对 S3C2440的支持,2440的时钟计算公式、NAND 操作和2410不太一样。 对于2440开发板,将 FCLK 设为400MHz,分频比为 FCLK:HCLK:PCLK=1:4:8。 修改 board/TX2440/TX2440.c 中的 board_init 函数 /* S3C2440: Mpll,Upll = (2*m * Fin) / (p * 2^s) * m = M (the value for divider M)+ 8, p = P (the value for divider P) + 2 */ #define S3C2440_MPLL_400MHZ ((0x7f12)|(0x024)|(0x01)) #define S3C2440_UPLL_48MHZ ((0x3812)|(0x024)|(0x02)) #define S3C2440_CLKDIV 0x05 /* FCLK:HCLK:PCLK = 1:4:8 */ /* S3C2410: Mpll,Upll = (m * Fin) / (p * 2^s) * m = M (the value for divider M)+ 8, p = P (the value for divider P) + 2 */ #define S3C2410_MPLL_200MHZ ((0x5c12)|(0x044)|(0x00)

您可能关注的文档

文档评论(0)

tianya189 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体阳新县融易互联网技术工作室
IP属地湖北
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档