内核基础---AT&T汇编与x86汇编的区别

时间:2021-11-14 03:40:20

1、深入Linux内核的前提

  因为以前学习过intel的x86汇编语言,所以本文就不在讲述汇编的基本语法了;

  内核绝大部分的代码都是用C和汇编语言实现的,要理解内核,C语言大部分的人都已经掌握了,接下来就得首先掌握汇编知识,以便深入理解Linux内核知识!!!


2、学习Linux内核的线路

  首先内核有基础部分和深入的部分,我认为应该从一个全局的角度去解读Linux内核,以便我们达到一个更加深刻的认识,从内核的整体架构--->内核源码的解读,并且在这个的过程中不断的去修改代码,编程调试是至关重要的!!!


3、AT&T汇编的不同之处

  (1)、寄存器的引用

  在AT&T汇编的格式下,寄存器的前面要加上:%, %eax;

  (2)、操作数的顺序

  mov %eax(源), %ebx(目的)

  (3)、常数/立即数的格式

  使用立即数,要在数的前面加上$, mov $4;

  (4)、操作数的长度

  操作数的长度用加在指令后的符号表示

  b(byte), w(word), l(long), movw %ax, %bx;

  (5)、转移指令

  ljump和lcall,在Intel中的格式为:jmp far 和 call far;

  (6)、寻址方式

  偏移量移到了前面了,


4、嵌入式在C语言-->嵌入式汇编

  _asm_代表了嵌入式汇编的语句;

  a, b, c, d 分别代表寄存器eax、ebx、ecx、edx;

  S、D 表示寄存器esi edi;

  r 表示任何寄存器;


阅读内核代码有可能出现嵌入式汇编语句,的牢牢的掌握!!!




本文出自 “wait0804” 博客,请务必保留此出处http://wait0804.blog.51cto.com/11586096/1885420