NASM学习(一)——Helloworld
学习NASM的目的:通过学习一门汇编语言,来加深自己对x86体系架构以及ELF可执行文件等等的理解
使用汇编实现功能,主要是通过系统调用实现的。
在Linux中,系统调用是通过0x80
号中断进行调用的
EAX
的值,就是要调用的服务编号
如果有要求,那么,其他寄存器的值就是调用的参数
要打印Helloworld,就需要在屏幕输出字符串的调用
该调用为第4号调用,需要三个参数:
EDX
载入字符长度
ECX
载入字符地址
EBX
载入输出的地方
这个东西不用去记,知道原理、会查表就行了
首先,在数据段的位置定义一个变量,并给它赋值为我们想输出的字符串
然后,声明全局标签_start
,告诉内核,我们的程序从哪个地方开始
最后,调用系统调用
section .data ; .data段
msg db 'hello, world!', 0x0a ; 0x0a意为'\n'
section .text
global _start ; 声明全局标号
_start:
mov edx, 14 ; 字符串长度14
mov ecx, msg ; 字符串地址
mov ebx, 1 ; 输出到STDOUT
mov eax, 4 ; 4号服务
int 0x80 ; 通过中断触发服务
我写了一个Makefile来简化编译