移植一个内核会涉及到很多东西,对想学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文件系统会有很多警告信息,我在源码里面将打印都去掉还是不行