目录:/u-boot_hi3515/board/hi3515v100

OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm") //输出可执行文件是elf格式,32位ARM指令,小端

OUTPUT_ARCH(arm)      //输出可执行文件的运行环境,是 arm 平台的

ENTRY(_start)       //指定输出可执行文件的起始代码段为_start(在start.S中定义)

SECTIONS          //section 命令用来设置段

{

   . = 0x00000000;  //将当前地址定位到 0x00000000 处,操作符用来表示当前地址

   . = ALIGN(4);    //代码以4字节对齐

   .text :          // 定义 .text 段

   {

//段由start.o,libhi3515v100.a,dlmalloc.o,console.o,nand_boot.o等中的.text段所有段组成

     cpu/arm926ejs/start.o (.text)  //代码的第一个代码部分

board/hi3515v100/libhi3515v100.a (.text)

     common/dlmalloc.o (.text)

     common/console.o (.text)

     common/nand_boot.o (.text)

     drivers/mtd/libmtd.a (.text)

     drivers/mtd/nand/libnand.a (.text)

     lib_generic/libgeneric.a (.text)

     cpu/arm926ejs/libarm926ejs.a (.text)

     cpu/arm926ejs/hi3515v100/libhi3515v100.a (.text)

     lib_arm/libarm.a (.text)

     drivers/serial/libserial.a (.text)

   }

   . = ALIGN(4);

   .rodata : { *(.rodata) }  //指定.rodata段(只读数据段)由所有输入文件的.rodata段组成

   . = ALIGN(4);

   .data : { *(.data) }    //指定.data段(读/写数据段)由所有输入文件的.rodata段组成



   . = ALIGN(4);

   .got : { *(.got) }      //.got段由所有输入文件的. got段组成(got段式是uboot自定义的一个段, 非标准段)

   . = ALIGN(4);

   .text1 :                //指定其他代码段

   {

     *(.text)

   }

   . = ALIGN(4);

   . = .;                //指定定位器为当前值(即为该语句相对段首偏移)

   __u_boot_cmd_start = .;  //__u_boot_cmd_start的值被设置为了当前地址

   .u_boot_cmd : { *(.u_boot_cmd) }  //.u_boot_cmd段由所有文件的.u_boot_cmd段组成

   __u_boot_cmd_end = .;             //__u_boot_cmd_end变量的值被赋值为了当前地址

   __img_end = .;

. = _start + 0x100000;    //指定定位器为开始地址+0x100000(偏移)处

   . = ALIGN(32);           //定位器当前地址,32位对齐

   __bss_start = .;      //把__bss_start赋值为当前位置,即bss段的开始位置

    .bss1 (NOLOAD) : {*(.bss)}  //.bss段由所有输入文件的.bss段组成

    _end = .;                 //把_end赋值为当前位置,即bss段的结束位置

}

a.out 的头部根据 unix 版本的不同而略有变化, BSD 中的格式如下

int   a_magic ;        // 幻数

int    a_text;                        // 文本段的大小

int   a_data;                       // 初始化的数据段的大小

int   a_bss;                         // 未初始化的数据段的大小

int  a_syms;                     // 符号表的大小

int   a_entry;                     // 入口点

int   a_trsize;                     // 文本重定位段的大小

int   a_drsize;                    // 数据重定位段的大小

text section:    存放程序代码

Data section:   存放数据

Bss section :   存放未初始化的数据,在镜像文件中,是不为 bss 段分配空间的,所以如果你开一个很大的全局的未初始化的数组,镜像文件的大小不会相应的变大。而只是在加载器将镜像加载进内存时,才会为 bss 段分配空间

链接器:把各个目标文件的各种段进行重新组合.

u-boot.lds 链接脚本分析(hi3515)的更多相关文章

  1. makefile使用.lds链接脚本以及 $@ ,$^, $,< 解析

    先来分析一个简单的.lds链接脚本 例1,假如现在有head.c init.c nand.c main.c这4个文件: 1.1 首先创建链接脚本nand.lds: SECTIONS { firtst ...

  2. 裸板驱动总结(makefile+lds链接脚本+裸板调试)

    在裸板2440中,当我们使用nand启动时,2440会自动将前4k字节复制到内部sram中,如下图所示: 然而此时的SDRAM.nandflash的控制时序等都还没初始化,所以我们就只能使用前0~40 ...

  3. arm裸板驱动总结(makefile+lds链接脚本+裸板调试)

    在裸板2440中,当我们使用nand启动时,2440会自动将前4k字节复制到内部sram中,如下图所示: 然而此时的SDRAM.nandflash的控制时序等都还没初始化,所以我们就只能使用前0~40 ...

  4. makefile使用.lds链接脚本以及 $@ ,$^, $,< 解析【转】

    转自:http://www.cnblogs.com/lifexy/p/7089873.html 先来分析一个简单的.lds链接脚本 例1,假如现在有head.c init.c nand.c main. ...

  5. Linux下的lds链接脚本详解

    1. 概论2. 基本概念3. 脚本格式4. 简单例子5. 简单脚本命令6. 对符号的赋值7. SECTIONS命令8. MEMORY命令9. PHDRS命令10. VERSION命令11. 脚本内的表 ...

  6. [转]Linux下的lds链接脚本详解

    转载自:http://linux.chinaunix.net/techdoc/beginner/2009/08/12/1129972.shtml     一. 概论 每一个链接过程都由链接脚本(lin ...

  7. Linux下的lds链接脚本简介

    转载:http://hubingforever.blog.163.com/blog/static/171040579201192472552886/   一. 概论 每一个链接过程都由链接脚本(lin ...

  8. Linux下的lds链接脚本详解【转】

    转自:http://www.cnblogs.com/li-hao/p/4107964.html 转载自:http://linux.chinaunix.net/techdoc/beginner/2009 ...

  9. Linux下的lds链接脚本简介(二)

    七. SECTIONS命令 SECTIONS命令告诉ld如何把输入文件的sections映射到输出文件的各个section: 如何将输入section合为输出section; 如何把输出section ...

随机推荐

  1. 调整图像的尺寸 - cvResize() 函数实现

    前言 有时会碰到一张图片太大了,想将它缩小.本文将讲解一个很好用的函数解决这个问题. 图像尺寸调整函数 cvResize() // 图像尺寸调整函数 void Resize ( const CvArr ...

  2. 再说WCF Data Contract KnownTypeAttribute

    WCF 中的序列化是用DataContractSerializer,所有被[DataContract]和[DataMemeber]标记的类和属性会被DataContractSerializer序列化. ...

  3. programming review (c++): (3)graph, binary search

    I.graph #include <iostream> #include <vector> using namespace std; vector<vector<, ...

  4. Python爬虫-- selenium库

    selenium库 selenium 是一套完整的web应用程序测试系统,包含了测试的录制(selenium IDE),编写及运行(Selenium Remote Control)和测试的并行处理(S ...

  5. python cookbook第三版学习笔记三:列表以及字符串

    过滤序列元素: 有一个序列,想从其中过滤出想要的元素.最常用的办法就是列表过滤:比如下面的形式:这个表达式的意义是从1000个随机数中选出大于400的数据 test=[] for i in range ...

  6. CUDA: 流

    1. 页锁定主机内存 c库函数malloc()分配标准的,可分页(Pagable)的内存,cudaHostAlloc()分配页锁定的主机内存.页锁定内存也称为固定内存(Pinned Memory)或者 ...

  7. pinpoint本地开发-web模块

    web模块中的前端依赖会导致工程很难打包成功,对于这些,我们可以直接注释掉 比如: <plugin> <groupId>com.github.eirslett</grou ...

  8. Vue:实践学习笔记(6)——使用SLOT分发内容

    Vue:实践学习笔记(6)——使用SLOT分发内容 Slot Slot是什么 Slot是父子组件的通讯方式,可以将父组件的内容显示到子组件之中. 使用SLOT前 比如我在定义组件的时候,在里面输入了X ...

  9. ubuntu16.04下安装wordpress

    安装过程 http://blog.topspeedsnail.com/archives/4635 http://blog.topspeedsnail.com/archives/4646 碰到的问题 1 ...

  10. koa-bodyparser返回413状态码的问题

    413 Request Entity Too Large(请求实体太大) 数日前,我用 node.js 写的一个日志服务抛出了这个状态码-- 自己写的服务抛出了一个自己都不认识的状态码,这是最气的!( ...