linux ld 链接器学习笔记

ld链接器笔记

1. 首先编写一段汇编代码

这里的汇编语法时 AT&T语法,是gcc原生支持的语法,底层使用 gas(gnu assembler) 完成汇编,相较于 Intel x86语法, AT&T 语法要更加古老,因此大多数人更加偏向于使用 Intel 的语法. nasm 编译器支持x86语法.自从2.10版本,Intel语法可以通过使用.intel_syntax指令增加支持

asm 复制代码
.global _start
    .text
_start:
    mov $1,%eax # 将立即数1放到eax寄存器中
    mov $2,%ebx # 将立即数2放到 ebx 寄存器中
    add %ebx,%eax # 将 ebx 与 eax相加,结果放到 eax 中
loop:
    jmp loop # 循环

2. 使用 gcc 命令进行编译

Makefile 文件内容:

makefile 复制代码
main.o: main.s
    gcc -m32 -c $< -o $@
# -m32 编译为32位代码
# -c 执行编译和汇编,但不执行链接
# -o 指定输出文件名称
# -E 执行预处理,但不执行编译,汇编和链接
# -S 只执行编译,但不执行汇编和链接
#  -shared 创建一个共享库,格式.so

3. 使用 ld 执行链接

makefile 复制代码
main: main.o
    ld -m elf_i386 main.o
# -m elf_i386 指定链接格式,这里指定为 elf 格式(linux中二进制格式)
# -o 指定输出文件名称
# ld 可以指定配置文件 map.lds,按照规格进行配置可以

4. 使用 gdb 执行输出

sh 复制代码
gdb main
# 开启图形界面
tui enable
# 打开汇编窗口
lay asm
# 打开寄存器窗口
lay reg
# 开始执行程序
starti
# 步进执行程序
si
# 之后可以通过回车执行上一步执行的命令

汇编代码-栈学习

栈的使用主要是 push 和pop 指令,其中 push 指令会将指定数据写入内存

asm 复制代码
push %ebp # 将 ebp 寄存器中的值压入栈中
push $0xa # 将 0xa 值压入栈中

还有 pop 指令,从栈顶弹出一个值到指定寄存器中

asm 复制代码
pop 
asm 复制代码
.global _start
    .text
_start:
    push %ebp
    mov %esp,%ebp

    push $0xa
    push $0xb
    pop %eax
    push $4
    pop %eax
    pop %ebx
loop:
    jmp loop

参考资料

xv6操作系统实践

相关推荐
文青小兵2 分钟前
Linux云计算——docker compose haibor elfk (四)
linux·服务器·docker·云计算
IronMurphy5 分钟前
AI Agent学习day6 从 MCP 到 RAG 记忆:AI Agent 项目中的三块核心基础
人工智能·学习
思麟呀7 分钟前
C++11并发编程:互斥锁
linux·开发语言·c++·windows
li星野10 分钟前
RAG优化系列:基于用户反馈的检索权重调整(Feedback Loop)——让系统越用越聪明
python·学习
顺风尿一寸10 分钟前
深度解析 Linux touch 命令:从用户输入到磁盘 Inode 的完整旅程
linux
GNG13 分钟前
《10x Is Easier Than 2x》读书笔记
笔记·学习
半导体守望者13 分钟前
ADTEC AX-1000Ⅱ电源 RF电源等离子电源操作指南RF PLASMA GENERATOR
学习·机器人·自动化·制造·模块测试
Pluchon18 分钟前
萌萌技术分享笔记——Java综合项目
java·开发语言·笔记·git·github·mybatis·postman
j_xxx404_19 分钟前
Linux 线程日志系统设计:从策略模式、RAII 到 pthread 线程安全与内核写入路径|附源码
linux·运维·服务器·开发语言·c++·人工智能·策略模式
明天…ling21 分钟前
CentOS 7 安装 Docker 踩坑全记录(含 sudo 权限、yum 源失效、命令报错解决方案)
linux·docker·centos