qileilove

blog已经转移至github,大家请访问 http://qaseven.github.io/

Linux内核移植问题总结

移植一个内核会涉及到很多东西,对想学arm的人来说还是挺有帮助的,会比直接拿别人移植好的内核来跑有趣的多。
  一、串口打印问题
  内核移植的第一步就是要有打印输出。看不到打印信息,都不知道内核有没有跑起来。我移植 linux-2.6.35编译完成后运行,启动一直停在starting kernel . . .,检查machine-type、cpu-id、时钟、入口地址等可能会导致问题的地方都没有问题,最后想到可能是串口使用的引脚和内核不一致,最后才发现板子使用的是串口2作为打印输出(也是我一开始没想到的,因为一般都会默认使用串口1,纠结)。讲启动参数改成串口2,mx5_loco.c 里面的init串口改成UART2_BASE_ADDR,可以输出信息了。
  二、文件系统
  1、自己编译一个busybox来制作一个文件系统其实还是挺麻烦的,只能制作一个很简单的文件系统,因为是在flash上加载,所以我最开始尝试的是cramfs,加载文件系统阶段一直出错
  List of all partitions:
  1f00          131072 mtdblock0  (driver?)
  No filesystem could mount root, tried:  cramfs
  Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(31,0)
  这里只读到了一个块设备,block0,显然flash的分区没有成功,修改nandflash的分区,文件系统正常加载,启动参数如下
  setenv bootargs root=/dev/mtdblock3 rootfstype=cramfs rw console=ttymxc1,115200 init=/linuxrc
  2、加载成功有时会出现Kernel panic - not syncing: Attempted to kill init!,这个很多人说要开
  Kernel Features  --->
  [*] Use the ARM EABI to compile the kernel
  [*]   Allow old ABI binaries to run with this kernel (EXPERIMENTAL)(NEW)
  我试过好像没什么效果,出现这个问题有可能是文件系统的inittab和rcS两个文件有问题。
  3、jffs2文件系统
  JFFS2 error: (1) jffs2_build_inode_pass1: child dir"alsa" (ino #1159) of dir ino #1074 appears to be a hard link  JFFS2 error: (1) jffs2_build_inode_pass1:child dir "l" (ino #1170) of dir ino #1075 appears to be a hard link
  原由 : flash没有erase彻底.,多 nand erase几次就好了
  还有就是jffs2文件系统会有很多警告信息,我在源码里面将打印都去掉还是不行

posted on 2014-06-03 09:52 顺其自然EVO 阅读(557) 评论(0)  编辑  收藏 所属分类: linux


只有注册用户登录后才能发表评论。


网站导航:
 
<2014年6月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

导航

统计

常用链接

留言簿(55)

随笔分类

随笔档案

文章分类

文章档案

搜索

最新评论

阅读排行榜

评论排行榜