在 Linux 内核混,不碰到汇编是不可能的,使用汇编是因为其有着高级语言(如 C)无法替代的优势:
1.直接访问硬件里的存储器或 I/O 口;
2.对生成的二进制代码进行控制,不受编译器优化处理;
3.对关键代码精准控制,避免多线程同时访问或设备资源共享所引起的死锁;
4.对特定操作的代码最优化,提高最终运行效率和速度;
5.最大限度发挥硬件的性能。
当然其也有如下一些缺点:
1.代码易读性差,不利于维护;
2.只能针对特定平台和处理器进行优化,不便移植;
3.开发效率低,易产生 BUG,调试难度高。
在Linux 环境下 GCC 编译可以让我们对汇编进行两种形式的支持:全汇编代码和嵌入 C 语言的内联汇编。下面将会对这两种形式进行说明,但在说明前还是要了解下 Linux 下常用的AT&T 格式与 Windows 下 Intel 格式的区别:
1.在使用 AT&T 的寄存器寻址时,需要在寄存器名前加%号,而 Intel 则不需要;
2.在使用 AT&T 的立即数时,需要在立即数前加$号,而 Intel 则不需要;
3.AT&T 的源操作数在左,目标操作数在右,与 Intel 刚好相反;
4.AT&T 的每个操作指令后都有标识操作数字长的后缀‘b’、‘w’、‘l’(分别代表字节byte,8bit
06-04
5553
01-19
240
09-08
1200
09-08
503