如何让linux内核make uImage时Entry Point(入口地址)自动偏移64个字节

2024-05-09 02:18

本文主要是介绍如何让linux内核make uImage时Entry Point(入口地址)自动偏移64个字节,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自:http://blog.csdn.net/hunhunzi/article/details/6262244



这两天在移植u-boot-1.3.4到s3c2440,期间还遇到不少事,首先是u-boot的mach_type和kernel的mach_type不一致导致内核正常解压完后,终端就不动了,停在了那里,改了mach_type之后内核可以正常拷贝和解压了。

现在又遇到make uImage编译内核自动生成uImage时,Entry Point入口地址和Load Address加载地址总是相同,都是Load Address: 30008000,Entry Point:  30008000,这样一来,内核解压完后,bootm之后就会crash掉了,因为uImage前面64个字节是u-boot参数,不能作为内核启动入口地址。如果手动的用mkimage命令生成uImage就可以正常启动:

mkimage -n 'linux-2.6.32' -A arm -O linux -T kernel -C none -a 0x30008000 -e 0x30008040 -n "My2440" -d zImage uImage

这样做毕竟麻烦,还是让make uImage自动生成正确的uImage最方便。

打开arch/arm/boot/Makefile,62~78行就是利用mkimage生成uImage的相关命令。注意到73~78行,就是Entry Point入口地址的赋值:

 

[python] view plain copy
  1. ifeq ($(CONFIG_THUMB2_KERNEL),y)  
  2. # Set bit 0 to 1 so that "mov pc, rx" switches to Thumb-2 mode  
  3. $(obj)/uImage: STARTADDR=$(shell echo $(LOADADDR) | sed -e "s/.$/1/")  
  4. else  
  5. $(obj)/uImage: STARTADDR=$(LOADADDR)  
  6. endif  
 

2440是ARM920t,显然执行的是第78行,直接把加载地址赋给了入口地址。因些,只要把第77行改进一下就可以了,修改如下。

 

$(obj)/uImage: STARTADDR=$(shell echo $(LOADADDR) | sed -e "s/..$$/40/")

 

 

其中,sed -e "s/..$$/40/"的意思是,把输出的字符串的最后两个字符删掉,并且用40来补充,也可以理解为,把字符串最后两个字符用40来替换。这样,原来的入口地址0x30008000就改成了0x30008040,多了0x40,即64个字节。

 

执行make uImage重新生成u-boot镜像文件,内核可以正常启动!


这篇关于如何让linux内核make uImage时Entry Point(入口地址)自动偏移64个字节的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/972107

相关文章

Linux命令学习之二

每日一结 ​               命令置换:是将一个命令的输出作为另一个命令的参数,命令格式如下: commond1 `command2` 其中,命令command2的输出将作为命令command1的参数,需要注意的是, 命令置换的单引号为ESC键下方的 ` 其意思就是说,先运行单引号内的命令,再将其命令作为

Linux命令学习之一

每日一结                                                                                        注:当用户不确定一个软件包的类型时, 可使用file命令查看文件类型

Linux文件I/O之一

每日一结(标准I/O)   一  库    本质 :一组实现函数接口 [printf,scanf,strcpy,strlen]   使用标准库好处:屏蔽底层细节,向上层提供统一的接口,提高程序的可移植性   windows 库 : *.dll  linux   库 : *.so    二 系统调用接口    本

Linux网络编程之五

每日一结 组播: ​ 网络地址: 一些特殊的组播地址:   一 组播包收和发 1.发送方 (1)创建用户数据报套接字 (2)填充组播地址和端口  (3)发送数据到组播地址 2.接收方  (1)创建用户数据报套接字 (2)加入组播组  struct ip_mreq mreq; mreq.imr_m

Linux网络编程之四

每日一结 一 UDP并发  核心思想:父进程接收到客户端的数据,就创建子进程,在子进程中创建一个新的套接字  和客户端交互  int do_client(接受客户端地址,数据,数据长度) { 1.创建用户数据报套接字  2.自动分配地址  3.处理数据[例如:输出数据内容] 4.通过新创建的套接字将数据回发给客户端  w

Linux网络编程之三

每日一结 Tftp服务器的实现: server.c ​       client.c     代码分析如下:     一 Linux IO模型  (1)阻塞IO  (2)非阻塞IO  非阻塞IO

Linux网络编程之二

每日一结   一 TCP 函数接口  int listen(int sockfd, int backlog); 功能:设置流式套接字为监听模式  参数: @sockfd    流式套接字的fd  @backlog   请求队列的长度,最大128  返回值: 成功返回0,失败返回-1    int accept(i

Linux网络编程之一

每日一结 一 网络基础知识 (一)IP地址 1.IP   :网络中一台主机唯一标识  2.组成 :网络号 + 主机号  3.IP 分类 最高位    第一个字节 A  1 + 3     0        [0-127]     B  2 + 2    10        [128-191]

Linux进程与线程之五

每日一结 一 共享内存 :内核空间预留出来的一块内存,用于进程间通信  (1)int shmget(key_t key, size_t size, int shmflg); 功能:获取共享内存段的ID  参数: @key    IPC_PRIVATE  或 ftok()  @size   申请的共享内存段大小 [4k的倍

Linux进程与线程之四

每日一结 一 传统的进程间通信  1.信号 : 异步进程间通信方式    信号是对中断机制的一种模拟  进程对信号处理方式: (1)忽略信号  SIGKILL ,SIGSTOP 不能忽略  (2)捕捉 : 信号到达的时候,执行信号处理函数  (3)缺省操作 : 系统默认的操作  大部分信号默认的操作都是杀死进程,SIGCHLD 进