转载自:http://linux.chinaunix.net/techdoc/install/2009/04/13/1107608.shtml

发信人: armlinux (armlinux), 信区: Embedded
标  题: 关于Embedded Linux启动的经典问题
发信站: 哈工大紫丁香 (Sun Aug 31 20:14:46 2003)
On Sat 06 Apr, Arts Thibaut wrote:
> due to compiling problem, i try to understand the boot sequence. I know
> the main points for i386 architecture.
> > i assume that the entry point of Linux is the
> ~/arch/armnommu/boot/compressed/head.S file written by Russel King.
> This function call (after uncompressing the kernel) the "start_kernel"
> function.
> > i wish to know:
> > * what is the real boot sequence? (if i am wrong)
> * what exactly do the head.S file? (or where is documentation about it?)
I've been collecting info with intent to write this up properly. I haven't
done it yet, but I might soon.
Here is the collected info, totally unedited, and largely from posts to this
list. It should help you get the general idea:
Startup
-------

bootloader:


Linux needs almost nothing. Basically Linux just needs a boot loader to


get the kernel from some storage medium into RAM by some method, set up


a couple of registers and call it at its entry point. No MMU setup is


required.


After the bootloader finishes, it calls bootLinux(), which jumps to


the kernel. However, since the kernel is compressed, the first


entry point is in arch/arm/boot/compressed/head.s. This calls


decompress_kernel(), which is located in /arch/arm/boot/compressed/misc.c.


This calls setup_sa1100(), which initializes the UART and GPIO, and then


calls gunzip() after printing "Uncompressing Linux".


Boot code:


> ./boot/compressed/head.S


> ./boot/compressed/head-sa1100.S


> ./boot/compressed/setup-sa1100.S


This is startup code for decompressing and locating the kernel image. The


kernel is stored in compressed form to save space and make bootstrapping


simpler and easier. This code is discarded once the kernel begins


executing. This code is called by the bootloader program or whatever is


used to initialize the machine following a hard reset, after the bootloader


has loaded the compressed kernel image to a specified location in system


memory.


> ./kernel/head-armo.S


> ./kernel/head-armv.S


This is the entry point for the kernel itself, which is entered following


the decompression and relocation of the kernel image to its final


destination area in system memory.It uses the machine number in R1 to find a


table built by the linker containing vital info like where the RAM is, how


much of it there is etc.

----from RMK:--
On Tue, Jul 17, 2001 at 08:45:15PM -0700, Yang, Neil L wrote:
> I'm interested in finding out more about the arm boot sequence. One of the
> questions I had was where decompress_kernel() is called from.
arch/arm/boot/compressed/head.S
> Also, when is the MACHINE_START macro called?
Not every macro is a piece of executable code. This particular one builds
a data structure.
On Wed, Jul 18, 2001 at 09:49:57AM -0700, Chivukula, Sandeep wrote:
> >> Also, when is the MACHINE_START macro called?
> >Not every macro is a piece of executable code. This particular one builds
> >a data structure.
> > So when in the boot process does this data structure get created and by
> whom ? i.e. which function makes it initially
No function makes it. I'll explain more clearly.

The MACHINE_START macro expands to a statically built data structure, ie one


that is there when the compiler builds the file. It expands to:


const struct machine_desc __mach_desc_(type)


__attribute__((__section__(".arch.info"))) = {


nr: MACH_TYPE_(type),


name: (name)


The various other definitions set various machine_desc structure members


using named initialisers, and finally MACHINE_END provides the closing


brace for the structure initialiser. (see include/asm-arm/mach/arch.h)


Note that above, (type) is the first argument passed to the MACHINE_START


macro, and (name) is the second.


All of these machine_desc structures are collected up by the linker into


the .arch.info ELF section on final link, which is bounded by two symbols,


__arch_info_begin, __arch_info_end. These symbols do not contain pointers


into the .arch.info section, but their address are within that section.

I hope this is enough information.
-----------
This code calls start_kernel
-------From: Ray L -----on linux-arm-kernel list
> Is there a way
> to figure out where everything is placed in the kernel zImage, by looking
> at the setup of the makefiles and ld?
yes, look at the ldscripts (*.lds.* under linux/arch/arm/)
> Where are the variables _text,
> _etext, _edata, and _end defined.
in one of the ldscript files, eg: linux/arch/arm/vmlinux.lds
this script also defines a few tables, including:
proc.info is an array of structs collected from places like the end of
linux/arch/arm/mm/proc-arm720.S. these structs hold processor-specific info.
arch.info is an array of 'struct machine_desc' collected from the
MACHINE_START() macros, in places like linux/arch/arm/mach-clps711x/p720t.c.
these structs hold machine-specific info.
> Specifically, I would like to know the actual trace of the boot
> sequence of the kernel on an arm processor, not an x86.

ok, assume you're on a P720T.


- assume the uncompressor has done its thing, and we have, in RAM, a vmlinux


image ready to go


- according to linux/arch/arm/vmlinux.lds, the ENTRY() is at 'stext', so go


to linux/arch/arm/head-armv.S and find the stext symbol


- you're not on a netwinder or L7200 so skip down to __entry


- disable interrupts and make sure we're in supervisor mode


- call lookup_processor_type, which will query the cpu for it's id, then


lookup that id in .proc.info table. if it finds the struct, r10 will point


to it. this struct comes from the end of linux/arch/arm/mm/proc-arm720.S.


- if we didn;t find the struct, print out 'Error: p' on uart2 and die.


- the bootloader has arranged for r1 to hold a special integer, selected from


the list in linux/arch/arm/tools/mach-types. this will be 24 for the P720T


- call lookup_architecture_type, which will lookup r1 in the arch.info


table. this is a 'struct machine_desc' created in MACHINE_START() in


linux/arch/arm/mach-clps711x/p720t.c.


- if we didn;t find the struct, print out 'Error: a' on uart2 and die.


- call __create_page_tables to map in ram, uarts, etc


- set up lr with __ret. next time we return from a subroutine, we'll return


to __ret, which is a few lines down.


- set pc = [r10 + 12]. in other words, jump to the address in the fourth


slot of the P720T proc.info struct, which is __arm720_setup in


linux/arch/arm/mm/proc-arm720.S.


- __arm720_setup sets up MMU and returns to __ret in head-armv.S


- at __ret, set up lr with __mmap_switched (via __switch_data)


- turn on the MMU, wait for the pipeline to clear, and return to


__mmap_switched a few lines down


- __mmap_switched loads up the info from __switch_data. this, among other


things, set up stack pointer to inittask + 8192.


- clear out BSS


- jump to start_kernel

hopefully i got all that correct :-) it's not the easiest thing to follow,
but pretty straightforward once you know where the tricky jumps and linker
tables are.
--------endsnip
Wookey

【转载】关于Embedded Linux启动的经典问题的更多相关文章

  1. [转载] Linux启动过程详解-《别怕Linux编程》之八

    本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket.为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. = ...

  2. 【转载】在Linux系统下用dd命令制作ISO镜像U盘启动盘

    #### 将U盘插入USB接口 #umount /dev/sdb* #dd if=/iso存放路径/XXX.iso of=/dev/sdb bs=1M ##### [转载]在Linux系统下用dd命令 ...

  3. Linux启动流程详解【转载】

    在BIOS阶段,计算机的行为基本上被写死了,可以做的事情并不多:一般就是通电.BIOS.主引导记录.操作系统这四步.所以我们一般认为加载内核是linux启动流程的第一步. 第一步.加载内核 操作系统接 ...

  4. 【转载】Linux启动初始化配置文件浅析(解决source /etc/profile重启后就失效?)

    1)/etc/profile   登录时,会执行. 全局(公有)配置,不管是哪个用户,登录时都会读取该文件. (2)/ect/bashrc   Ubuntu没有此文件,与之对应的是/ect/bash. ...

  5. [转载]嵌入式linux启动时运行的inittab文件

    源地址:https://www.cnblogs.com/yfz0/p/5853826.html 嵌入式系统下的linux启动配置文件,不同与普通的PC linux启动配置,启动相关文件与文件的内容也要 ...

  6. 构建自己的embedded linux系统

    [教程]使用buildroot完全自定义自己的embedded linux系统(nand)http://www.eeboard.com/bbs/thread-38377-1-1.html [教程] [ ...

  7. Linux 启动过程分析

    本文仅简单介绍Linux的启动过程,在此基础上做简要的分析.对于Linux启动过程中内部详细的函数调用不做介绍,只是希望本文能给新手起到一个抛砖引玉的作用,以便深入研究Linux的启动过程.下图基本展 ...

  8. Linux启动流程详解

    在BIOS阶段,计算机的行为基本上被写死了,可以做的事情并不多:一般就是通电.BIOS.主引导记录.操作系统这四步.所以我们一般认为加载内核是linux启动流程的第一步. 第一步.加载内核 操作系统接 ...

  9. Linux 启动参数介绍

    Linux 启动参数介绍 取自2.6.18 kernel Documentation/i386/boot.txt 文件中介绍 vga= 这里的不是一个整数(在C语言表示法中,应是十进制,八进制或者十六 ...

随机推荐

  1. Android的消息机制: Message/MessageQueue/Handler/Looper

    概览   * Message:消息.消息里面可包含简单数据.Object和Bundle,还可以包含一个Runnable(实际上可看做回调). * MessageQueue:消息队列,供Looper线程 ...

  2. db2 表授权语句

    grant insert/update/delete on table schema.table_name to user user_name;

  3. Javascript - 栈 和 单链表

    最近在重温数据结构,于是写了一些代码玩玩,都是很初级的,表喷各位.... function Stack() { this.dataStore = []; this.top = 0; } Stack.p ...

  4. 关于SpeedButton中使用下划线快捷键不响应的问题

    在Windows应用程序,很多都有快捷键功能,这个Delphi也有,就是一个按钮上面有一个比如剪切(&X),这个时候剪切的快捷键就是Alt+X,这个功能有时候还是挺好用的,最近,公司中有同事, ...

  5. EF 5.0 帮助类

    EF 5.0 帮助类 加入命名空间: using System; using System.Data; using System.Data.Entity; using System.Data.Enti ...

  6. HL AsySocket 服务开发框架 - 一般性测试1

    一 概述 Socket服务器性能要好就要经过无数次的测试,来保证,以下是记录一次的测试经过. 机器配置:Inter(R) Core(TM) i3-2310m CPU 2.10GHz RAM 6.00G ...

  7. android studio 编译加速

    1. http://www.52codes.net/article/658.html 2.http://my.oschina.net/sammy1990/blog/388846 3.http://st ...

  8. JS表单设置值

    //表单设置值 $.fn.setForm = function(jsonValue) { var obj = this; $.each(jsonValue, function (name, ival) ...

  9. josephus Problem 中级(使用数组模拟链表,提升效率)

    问题描写叙述: 在<josephus Problem 0基础(使用数组)>中.我们提出了一种最简单直接的解决方式. 可是,细致审视代码之后.发现此种方案的效率并不高,详细体如今.当有人出局 ...

  10. 【cocos2d-x 手游研发小技巧(8)通讯的数据压缩与解压 】

    今天说一下手机游戏通讯协议中的数据问题,大量的数据将给服务器端和客户端带来很大的压力,一般来说. 转载请注明出处:http://www.cnblogs.com/zisou/p/cocos2dxJQ-8 ...