汇编工具理解

当百度读取键盘敲入字符等得到的代码,譬如如下

bash 复制代码
section .data
    input_buffer db 1   ; 保存输入字符的变量
 
section .text
global _start
 
_start:
    mov eax, 3          ; 设置文件描述符为0 (stdin)
    xor ebx, ebx        ; 清空ebx寄存器
    mov edx, 1          ; 要读取的字节数
    lea ecx, [input_buffer]     ; 目标地址
    int 0x80            ; 调用系统调用
 
    cmp al, -1          ; 判断是否成功读取了字符
    jz exit             ; 如果返回值为-1则表示没有更多字符可供读取,结束程序
 
    ; 这里可以对读取到的字符进行处理
    ; ...
 
exit:
    mov eax, 1          ; 设置系统调用号为1 (exit)
    xor ebx, ebx        ; 清空ebx寄存器
    int 0x80            ; 调用系统调用

as 不支持其语法

bash 复制代码
as -32 3.s -o 3.o

nasm可支持

bash 复制代码
nasm -f elf32 -o 3.o 3.s

但ld时无法链接到C库函数

bash 复制代码
ld -m elf_i386 -o 3 3.o -lc -verbose

gcc 编一个32位程序也会因为stdio.h内部缺失导致编译失败

ld可链接32位程序可运行,前提不引用其他

编译64位及链接方法

bash 复制代码
as -g -o scastest.o scastest.s

ld -o scastest scastest.o -lc -I /lib64/ld-linux-x86-64.so.2

参考

第25部分- Linux x86 64位汇编 字符串扫描 | 码农家园

相关推荐
myloveasuka19 小时前
寻址方式笔记
汇编·笔记·计算机组成原理
请输入蚊子20 小时前
《操作系统真象还原》 第六章 完善内核
linux·汇编·操作系统·bochs·操作系统真像还原
myloveasuka1 天前
指令格式举例
汇编·笔记·计算机组成原理
我在人间贩卖青春2 天前
汇编之分支跳转指令
汇编·arm·分支跳转
我在人间贩卖青春2 天前
汇编之加载存储指令
汇编·arm·寄存器加载存储
我在人间贩卖青春2 天前
汇编之状态寄存器访问指令
汇编·arm·状态寄存器
我在人间贩卖青春2 天前
汇编之软中断指令和协处理指令
汇编·arm·软中断·协处理
我在人间贩卖青春2 天前
汇编之数据处理指令
汇编·arm·数据处理指令
白太岁3 天前
操作系统开发:(11) RTOS 与 GPOS 的分界线:MMU
c语言·开发语言·汇编·arm开发·系统架构
枷锁—sha3 天前
【pwn系列】Pwndbg 汇编调试实操教程
网络·汇编·笔记·安全·网络安全