glibc源码分析之进程启动(start.S)

本文详细分析了glibc源码中的启动代码,特别是汇编文件start.S的内容。启动代码负责初始化进程环境,调用main函数,启动进程的运行。在i386架构的elf格式下,start.S通过清理栈帧、处理命令行参数、压栈共享库函数地址和main函数地址等方式,为进程执行做好准备。最后,通过调用__libc_start_main函数,进程正式开始执行。
摘要由CSDN通过智能技术生成

启动代码

顾名思义,启动代码就是使进程启动的代码。它包含了进程运行的第一条指令。
每个程序都有一段启动代码。启动代码初始化进程环境,调用main函数,使程序正式开始运行。
glibc为我们提供了进程的启动代码,本文将详细讲解glibc提供的启动代码。(基于glibc2.7)

启动代码的实现

接下来,我们将详细讲解启动代码的实现。
让我们来看一下glibc源代码中启动代码的实现。
glibc的启动代码包含在一个汇编文件和几个c语言文件中。这些文件将在本文中详细讲解。

start.S
首先是汇编文件start.S文件。该文件位于sysdeps/i386/elf/start.S。

    .text
    .globl _start
    .type _start,@function

_start:
    xorl %ebp, %ebp

    popl %esi       
    movl %esp, %ecx

    andl $0xfffffff0, %esp

    pushl 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值