当前位置:  技术问答>linux和unix

2.6.24内核的compressed/head_32.S的问题

    来源: 互联网  发布时间:2017-04-11

    本文导语:  我在看2.6.24内核,linux/arch/x86/boot/compressed/head_32.S中,既然运行时被重定位了,那么连接时的标号地址就不准确了,怎么还能直接调用call decompress_kernel呢?相关代码如下: …… call 1f 1:        popl %ebp …… movl o...

我在看2.6.24内核,linux/arch/x86/boot/compressed/head_32.S中,既然运行时被重定位了,那么连接时的标号地址就不准确了,怎么还能直接调用call decompress_kernel呢?相关代码如下:
……
call 1f
1:        popl %ebp
……
movl output_len(%ebx), %eax
        pushl %eax
        pushl %ebp        # output address
        movl input_len(%ebx), %eax
        pushl %eax        # input_len
        leal input_data(%ebx), %eax
        pushl %eax        # input_data
        leal _end(%ebx), %eax
        pushl %eax        # end of the image as third argument
        pushl %esi        # real mode pointer as second arg
        call decompress_kernel
        addl $20, %esp
        popl %ecx
……

既然用了input_len(%ebx), 说明代码是从0地址开始链接的,并且通过寄存器进行了重定位寻址,那么decompress_kernel应该
也是相对于0始址的偏移量(head_32.S和misc_32.c是一起链接的),当压缩内核移到到0x100000+X的地址开始解压缩前夕,decompress_kernel的实际位置显然和链接位置不一致,怎么还能用call decomress_kernel呢(没有重定位)?前面的call 1f 可以看做是短调用(二进制代码中用相对位移,无需重定位),而call decomress_kernel显然不是。

|
call decomress_kernel类似于执行
push IP
jmp near ptr decomress_kernel

jmp near ptr做的事情就类似于:
IP=IP+16位位移
16位位移=标号decomress_kernel处的地址-jmp指令后的第一个字节的地址

所以其实IP偏移是个相对地址

    
 
 

您可能感兴趣的文章:

  • 内核栈~ 内核线程 ~用户线程 之间关系 问题
  • 把redhat9.0的2.4.20-8内核升级为2.4.22内核时遇到的问题
  • 新手的菜鸟问题:不同内核版本下编译的程序能否互相调用,是否需要在同一内核下重新编译.
  • 问一个小白问题,在交叉编译时,系统内核和开发板的内核有没有相关性?
  • Android 内核移植问题 要求识别SATA硬盘 请问内核的make menuconfig 要如何配置?求高手
  • 修改内核代码问题:如何编译修改的单个文件而不用重建整个内核?
  • 请教一个问题:程序在Linux 2.4.20内核上跑无问题。但在2.4.19内核上跑就出现段错误现象。查了一星期,毫无头绪,万望各位指点。
  • 内核版本问题 GCC版本问题
  • linux内核安装问题 , 有点疑惑~
  • 内核升级问题!!!!!
  • 内核问题
  • 问个编译内核的简单问题~~~
  • 内核重编译前的小白问题
  • 请教一个linux进程内核栈的问题
  • 升级linux内核时,2.6.21.5内核编译成功,但启动时出现panic,请看问题详细描述!
  • 菜鸟问题,内核编译以后,启动不了。系统提示内核文件文件找不到!
  • 关于如何使用内核函数的问题
  • 安装内核头文件问题
  • Linux 内核模块编程问题!!!!
  • linux 内核进程堆问题,大家指教
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux iis7站长之家
  • Fedora Core 2自带的内核升级程序下载下来内核后,要不要再编译一遍内核?
  • TCP协议四次断连过程介绍及Linux内核协议栈中相关设置项
  • 进程内核栈和操作系统内核栈的关系
  • CentOS 6内核升级:下载编译启用新内核版本详细过程
  • Linux中内核线程不访问内核态地址空间?
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • 2.6内核下编译2.4内核
  • linux内核中的likely宏和unlikely宏介绍及用法
  • 谁能提供kgdb内核补丁内核模块的下载
  • CentOS 6.5 下载地址及如何升级内核(kernel)版本到 3.10.28
  • 编译新内核后怎么进入原来内核
  • Linux下c/c++开发之程序崩溃(Segment fault)时内核转储文件(core dump)生成设置方法
  • 请问linux中如何判断内核是否已经启动。(在内核中写程序)
  • docker使用的技术之Container内核原理介绍
  • 内核模块跟内核版本不匹配????????
  • 请教:如何安装新内核(rpm包)而不同原来得内核冲突?? 在线等待!!
  • linux为什么要升级内核?升级内核有何作用?
  • 内核升级后,如何在新的内核中加载显卡驱动?
  • 内核源码和结果make过的内核源码有什么区别
  • 不重新编译内核能修改内核函数吗?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,