汇编工具理解

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

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位汇编 字符串扫描 | 码农家园

相关推荐
南玖yy1 天前
硬盘寻址全解析:从 CHS 三维迷宫到 LBA 线性王国
汇编·硬件架构·lba模式·chs模式
染指11102 天前
35.x64汇编写法(二)
汇编·windows·x64游戏·x64汇编·游戏攻防
Jacen.L4 天前
逆向工程开篇(连载中)
汇编
薛定谔的猫_C8T64 天前
程序人生-Hello’s P2P
c语言·汇编·程序人生·shell·二进制·计算机系统·hello
God_archer4 天前
程序人生-hello’s P2P
linux·c语言·汇编·程序人生
南玖yy4 天前
x86 汇编逻辑运算全解析:从【位操作】到实际应用(AND,OR,NOT,XOR,TEST)
开发语言·汇编·arm开发·后端·架构·策略模式
南玖yy5 天前
深入理解 x86 汇编中的重复前缀:REP、REPZ/REPE、REPNZ/REPNE(进阶详解版)
开发语言·网络·汇编·后端·算法·bochs
Jacen.L5 天前
四、函数调用包含单个参数之Double类型-mmword,movsd,mulsd,addsd指令,总结汇编的数据类型
汇编
网安INF5 天前
深入理解汇编语言中的顺序与分支结构
开发语言·汇编·编程
染指11107 天前
34.x64汇编写法(一)
汇编·x64汇编