【汇编代码】
extern:EXTERN 伪操作告诉编译器当前的符号不是在本源文件中定义的,而是在其他源文件中定义的,在本源文件中可能引用该符号。如果本源文件没有实际引用该符号,该符号将不会被加入到本源文件的符号表中。
global:关键字,把符号导出到其他模块中。global是extern的对立面,如果一个模块声明一个extern的符号,然后引用它,为了防止链接错误,另外某一个模块必须确实定义了该符号,然后把它声明为global。
1.由于在bar.c中用到函数myprint(),所以要用关键字global将其导出
2.由于用到本文件外定义的函数choose(),所以要用关键字extern声明
3.myprint()和choose()遵循的都是C调用约定,后面的参数先入栈,并由调用者清理堆栈
equ:表达式赋值操作符,在某些时候程序中多次出现同一个表达式,为方便起见,用赋值伪操作给表达式赋予一个名字。
int 0x80:系统调用是一个软中断,中断号是0x80,它是上层应用程序与Linux系统内核进行交互通信的唯一接口。通过int 0x80,就可使用内核资源。系统调用是通过int 0x80来实现的,eax寄存器中为调用的功能号,ebx、ecx、edx、esi等等寄存器则依次为参数,exit的功能号_NR_exit为1,write(_NR_write)功能号为4,ebx为文件描述符,stdout的文件描述符为1,ecx则为buffer的内存地址,edx为buffer长度。ebx为0表示返回0。
系统调用的参数传递规则:http://blog.youkuaiyun.com/m2o2o2d/article/details/21648777
org:orihin缩写,表示起始地址,源。在汇编语言源程序的开始通常都用一条ORG伪指令来实现规定程序的起始地址。如果不用ORG规定则汇编得到的目标程序将从0000H开始。
mov:数据传送指令,把源位置一个字节、字或双字的操作数复制到目的位置。可以是立即数到通用寄存器,也可以是通用寄存器和通用寄存器、主存、段寄存器之间的互相传送。
e.g mov eax,050ah; 把十六进制数050a传送到通用寄存器eax中。
call:call指令不能实现短转移,除此之外与jmp指令实现转移的原理相同。
CPU执行call指令时,进行两步操作:
1.将当前的IP或CS和IP压入栈中;
2.转移;