今天用主线Linux内核移植到MINI6410,主线内核2.6.37.1基本已经支持了MINI6410的板子,所以移植到能够启动起来的阶段很简单,但是在移植的时候还是出现了一个比较常见的问题:

  1. MINI6410 # bootm 0x50008000
  2. ## Booting kernel from Legacy Image at 50008000 ...
  3. Image Name: Linux-2.6.37.1
  4. Image Type: ARM Linux Kernel Image (uncompressed)
  5. Data Size: 3800644 Bytes = 3.6 MiB
  6. Load Address: 50008000
  7. Entry Point: 50008040
  8. Verifying Checksum ... OK
  9. XIP Kernel Image ... OK
  10. OK
  11. Starting kernel ...
  12. Uncompressing Linux... done, booting the kernel.
  13. 停住不动了~~~~
这种问题比较常见,由于输出的信息有限,不是很好找原因,如果去代码中追踪的话也比较麻烦。在查找原因解决这个问题的时候,我找到了一些可能出现的原因,在这里总结一下:
 
1、machine type    不匹配
在内核自解压完成以后内核会首先会进入 bl        __lookup_machine_type函数(在arch/arm/kernel/head.S中),检查machine_type是否匹配,如果不匹配会跳入__error_a函数(在arch/arm/kernel/head-common.S中),导致启动失败。

例如arch/arm/mach-s3c64xx/mach-mini6410.c    查看下面这个结构体:

  1. MACHINE_START(MINI6410, "MINI6410")
  2. /* Maintainer:     Darius Augulis <augulis.darius@gmail.com> */
  3. .boot_params    = S3C64XX_PA_SDRAM + 0x100,
  4. .init_irq    = s3c6410_init_irq,
  5. .map_io        = mini6410_map_io,
  6. .init_machine    = mini6410_machine_init,
  7. .timer        = &s3c24xx_timer,
  8. MACHINE_END
这个宏的定义在arch/arm/include/asm/mach/arch.h
  1. /*
  2. * Set of macros to define architecture features. This is built     into
  3. * a table by the linker.
  4. */
  5. #define MACHINE_START(_type,_name)            \
  6. static const struct machine_desc __mach_desc_##_type    \
  7. __used                            \
  8. __attribute__((__section__(".arch.info.init"))) = {    \
  9. .nr        =     MACH_TYPE_##_type,        \
  10. .name        = _name,
  11. #define     MACHINE_END                \
  12. };

这个宏定义扩展之后的machine type 就成了    MACHINE_TYPE_MIN6410。

MACHINE_TYPE_MIN6410这个宏定义在include/generated/mach-types.h
    1. #define MACH_TYPE_MINI6410  2520
machine type在u-boot

的配置在board/samsung/mini6410/mini6410.c

    1. /*
    2. * Miscellaneous platform dependent initialisations
    3. */
    4. int board_init(void)
    5. {
    6. s3c64xx_gpio * const     gpio = s3c64xx_get_base_gpio();
    7. .....
    8. gd->bd->bi_arch_number = MACH_TYPE;
    9. gd->bd->bi_boot_params = PHYS_SDRAM_1 + 0x100;
    10. return     0;
    11. }
这个宏的定义在:include/configs/mini6410.h
    1. /*
    2. * Architecture magic and machine type
    3. */
    4. #define     MACH_TYPE        2520
只要这两个数对上就可以了。
 
2、串口驱动没有编译入内核

在弄MINI6410的时候我就犯了这个错误,因为还没有MINI6410的默认配置文件,所有这个要自己选上的。位置在Device  Drivers->Character devices->Serial drivers中

  1. <*> Samsung SoC serial support 
  2. [*] Support for console on Samsung SoC serial port  
  3. <*> Samsung S3C6400/S3C6410/S5P6440/S5P6450/S5PC100 Serial port   support

3、内核启动参数设置错误   

内核的启动参数的错误也可以造成同样的错误,但是这种错误可能有几种:

(1)控制台串口配置字符串不匹配

比如有一个配置是:

  1. noinitrd root=/dev/mtdblock4 rootfstype=jffs2 rw console=ttySAC0,115200   init=/linuxrc mem=64M

关键是在console=ttySAC0,115200上,如果ttySAC0弄错了,或者波特率不对就会出问题。

不同的CPU的console有可能不一样,比如:

有的可能是ttyS0,

三星的CPU一般是ttySAC0,

早期TI  ARM 处理器的一般是ttyS2,

后来TI  Omap系列的高版本内核变成了ttyO2。把“S”变成了“  O”,代表Omap。自恋阿~~~~

    (2)内存大小配置错误
     如果在“mem=64M”这个参数上配置出现了问题,比如配置过大了,也会出现同样的现象。
   请注意你的系统内存和这个值的匹配关系。
 
 
     4、在bootloader中开启并配置了外部总线(GPMC)   
    在移植TI  Omap系列的内核时,发现如果在uboot中开启并配置了GPMC的某个bank,可能导致无法启动,也是这个现象。这个可能和Linux内核中对于启动时的GPMC寄存器读取和设置有关,暂时还没有去分析过代码。
     解决的办法是在bootloader用完外部总线,将控制权交给内核前,关闭外部总线,让内核自己去配置。或者干脆就别开。
 

Uncompressing Linux___ done, booting the kernel_tekkamanninja-ChinaUnix博客的更多相关文章

  1. MYSQL 博客

    DavidYang的博客 - CSDN.NET DimitriK's (dim) Weblog Xaprb · Stay Curious! 飞鸿无痕的博客 - ChinaUnix博客 何登成的技术博客 ...

  2. 我的Android进阶之旅------>经典的大牛博客推荐(排名不分先后)!!

    本文来自:http://blog.csdn.net/ouyang_peng/article/details/11358405 今天看到一篇文章,收藏了很多大牛的博客,在这里分享一下 谦虚的天下 柳志超 ...

  3. MYSQL 名人博客

    : DavidYang的博客 - CSDN.NET DimitriK's (dim) Weblog Xaprb · Stay Curious! 飞鸿无痕的博客 - ChinaUnix博客 何登成的技术 ...

  4. 原博客地址http://blog.chinaunix.net/uid/20656672.html弃用

    原博客地址http://blog.chinaunix.net/uid/20656672.html弃用

  5. 原博客地址http://blog.chinaunix.net/uid/20656672.html不再维护(10年前数百篇oracle/teradata性能优化、故障处理案例)

    原博客地址http://blog.chinaunix.net/uid/20656672.html不再维护(数百篇oracle/teradata性能优化.故障处理原创文章) 858871 top 500 ...

  6. 以前写的关于Linux C/C++的博客

    以前在CU写的关于Linux C/C++的博客 http://blog.chinaunix.net/uid/25909722/cid-24318-list-1.html

  7. MetaWeblog 同时管理51cto,csdn,sina,163,oschina,cnblogs等博客

    我们技术人一般都会有自己的一个博客,用于记录一些技术笔记,也期望自己的笔记文章可以让更多人知道. 如何让更多人知道自己的博客? 搜索引擎收录,用户通过关键词搜索可能会进入 内容运营,但是一般技术人为了 ...

  8. [转载]关于CSDN, cnblog, iteye和51cto四个博客网站的比较与分析

    CSDN:http://blog.csdn.net/ cnblog: http://www.cnblogs.com/ iteye: http://www.iteye.com/blogs/ 51cto: ...

  9. Qt学习博客推荐

    附录C Qt资源 C.1 Qt 官方资源 全 球各大公司以及独立开发人员每天都在加入 Qt 的开发社区.他们已经认识到了Qt 的架构本身便可加快应用程序开发进度.这些开发人员,无论是想开发单平台软件. ...

随机推荐

  1. 利用servlet技术实现验证码功能

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8" ...

  2. Ubuntu 12.04安装PPTP

    1.安装软件 sudo apt-get install pptpd ufw 2.编辑/etc/ppp/pptpd-options 找到 refuse-pap refuse-chap refuse-ms ...

  3. Use excel Macro export data from database

    Sub DownLoadMacro() '定义过程名称 Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量:sht 为excel工作表 ...

  4. 《Think in Java》读书笔记一:对象

    一.抽象过程 Alan Kay曾经总结了第一个成功的面向对象语言.同时也是Java所基于的语言之一的SmallTalk的五个基本特性,这些特性表现了一种纯粹的面向对象程序设计方式: 1.万物皆为对象. ...

  5. C++ Union妙用(将列表初始化用于数组元素)

    Union是个不被注意的关键字,意为联合体,这是个诡异的名字.若不是为了继承C语言,它也不会出现在C++中(虽说,union在C++中得到了扩充,完成了接近类的功能).它的作用主要是节省内存空间,在嵌 ...

  6. java新手笔记18 类比较

    1.Shap类 package com.yfs.javase; public class Shape /*extends Object */{ //默认继承object object方法全部继承 // ...

  7. java新手笔记15 多态

    1.Animal类 package com.yfs.javase; public class Animal { public void cry() { System.out.println(" ...

  8. Codevs 2843 拯救炜哥

    2843 拯救炜哥 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 有一天,炜哥和欧能干一起去大魔王家里做(dao)客(luan), ...

  9. Codevs 1702 素数判定 2(Fermat定理)

    1702 素数判定 2 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 一个数,他是素数么? 设他为P满足(P< ...

  10. (转)怎么去掉Xcode工程中的某种类型的警告 Implicit conversion loses integer precision: 'NSInteger' (aka 'long') to 'int32

    问题描述  在我们的项目中,通常使用了大量的第三方代码,这些代码可能很复杂,我们不敢改动他们,可是作者已经停止更新了,当sdk升级或者是编译器升级后,这些遗留的代码可能会出现许许多多的警告,那么我们有 ...