写给新手的汇编入门教程

2007年11月14日 星期三 16:01

废话: 看见 し掰搿嬲讎雠 写的改壳文章 估计很多人 是看得云里雾里 那是要有汇编基础才能看明白的.

其实本人汇编也是不很好了 只是能看懂大部分代码    不过还是菜鸟... - - 忘大家一起学习讨论

文章为原创   参考书籍《汇编语言程序设计》

继续的废话: 为什么学汇编 相信大家知道珊瑚虫QQ 但是腾讯并没有公开代码 所以只有通过汇编语言 来逆向分析程序 揣摩程序代码 来写出 跟QQ 工作方式一样的非官方客户端 汇编也是写外挂的 必修课程 汇编还可以用来分析程序是否有后门 病毒程序行为等

我分三部讲 第一部为 硬件部分 二部为指令部分 然后是些建议大家去学习的地方

intel 80x86 处理器

8086 处理器 1978年推出 内外数据总线16bit 地址总线20BIT 寻址范围1MB 主频5MHZ
8088 处理器 1979 年推出 外部数据总线8BIT 其余基本相同 (著名的IBM PC 最早运用的CPU)
8086 处理器 被称为准16位CPU

80186 XX器 增强了 8086的功能 但作为计算机的CPU没有被使用过 只作用某些板卡的控制器
80286 XX器 1982年推出 内外数据总线16BIT 地址总线 24bit 寻址范围 16MB 主频 5MHZ - 20MHZ
PS:80286 支持量种工作方式:实模式 和保护模式(实模式相当于快速的 8086)
保护模式: 提供虚拟存储管理和多任务的硬件控制 物理寻址范围 16MB 虚拟存储器寻址范围可达1GB 指令除包含8086 /80186 命令集 之外 新增15条保护方式指令

80386 XX器(32bit 的 CPU 就是现在常说的 I386 即 intel 386) 1985年推出内外数据总线 32位 地址总线32位 物理寻址范围 4GB 虚拟存储器寻址范围可达64TB 16/25/33MHZ

386 除支持 286 的两种工作方式外 新增虚拟8086 模式
虚拟特点 有保护模式 实现在多任务 新增多条指令 全面升级32 位指令

80486    XX器
1:将高速缓存 协处理器于 CPU 集成在一个芯片上 (以前的 CPU 是 将高速缓存和 协处理器分开的 现在486 做在一起了)
2 :部分采用RISC 技术
3:采用指令流水线技术
4:大幅提高了 CPU 主频 可达 100MHZ

PS: RISC 技术 : 精简指令系统计算机技术 RISC微处理器不仅精简了指令系统,采用超标量和朝流水线结构;它们的指令数目只有几十条,却大大增强了并行处理能力。如:1987年Sun Microsystem公司推出的SPARC芯片就是一种超标量结构的RISC处理器。而SGI公司推出的MIPS处理器则采用超流水线结构,这些 RISC处理器在构建并行精简指令系统多处理机中起着核心的作用。

PS:流水线技术 : http://baike.baidu.com/view/61745.html?wtp=tt

奔腾(PENTIUM)/MMX 32位
奔腾 1993年推出 内部数据总线32位 外部数据总线64位 主频 60 MHZ~200MHZ ; 采用超标量技术。
MMX 奔腾 96年推出 主频最高 233MHZ; 新增 57条多媒体指令 提高了多媒体软件执行速度


奔腾 pro/ 奔2/奔3 /奔4
奔腾 pro 95年推出 主要用于服务器
奔腾2 97年推出 在 奔腾PRO 基础上增加了MMX 指令
奔腾3 99年推出 在奔2 的基础上增加了 70条 SSE 指令
奔腾4 2000年推出 新增 76条 SSE2 指令

另外 从 奔腾2 开始 intel 为了占领 低端市场 推出了 Celeron (赛扬处理器)

学习汇编语言需要的软件
1 编辑程序 如 cmd 下的 edit 或者 OD
2 汇编程序 MASM 7 8 | MASM32 9 等
3 连接程序 LINK
4 调试程序 debug

CPU 内部结构



8086 寄存器 8个通用寄存器 4个段寄存器 1个指令指针寄存器 1个标志寄存器 以上都为16BIT 寄存器
通用寄存器
1 AX-累加器
2 BX-基地址寄存器
3 CX-计数寄存器
4 DX-数据寄存器
5 SI- 源变址寄存器
6 DI- 目的变址寄存器
7 BP- 栈基地址寄存器
8 SP-栈顶针 (控制堆栈操作 专用)
9 IP-指令指针寄存器 (专用寄存器)

标志寄存器

 

 

标志寄存器 又称作 程序状态字 即 PSW 共16位

位 DO 表示CF 表示 借位 和退位 的运算
9个标志位

CF- 进位标志
ZF- 零标志
SF-符号标志
OF-溢出标志 (设置 与CF 的区别)
PF-奇偶标志 (底8位 偶数时为1)
AF-辅助进位标志

控制标志位
TF-单步中断准许标志
IF-外部可屏蔽中断准许标志
DF-方向标志

段寄存器
http://baike.baidu.com/view/364403.html?wtp=tt

 

 

8086 汇编指令速查手册

http://hi.baidu.com/redhatd/blog/item/beb31d38d92fa6f1b311c73b.html


 

7种寻址方式:
http://www.bcu.edu.cn/zt/jpkc/dpjyl/cw/chapt3.ppt

 

 

练功总结:
看雪学院
http://WWW.pediy.com/ 主要研究 应用汇编实行 加密 破解 软件等。
CSDN
http://www.csdn.com 中国最大的IT 技术讨论社区

其实反正跟任何一门语言一样 多练 多看 多写

尝试用OD 看看 你常使用的程序并说出指令的意思吧

汇编教程 非常详细 说明的非常清楚 学汇编很好的教程 课程介绍 第1章 预备知识  1.1 汇编语言的由来及其特点   1 机器语言   2 汇编语言   3 汇编程序   4 汇编语言的主要特点   5 汇编语言的使用领域  1.2 数据的表示和类型   1 数值数据的表示   2 非数值数据的表示   3 基本的数据类型  1.3 习题 第2章 CPU资源和存储器  2.1 寄存器组   1 寄存器组   2 通用寄存器的作用   3 专用寄存器的作用  2.2 存储器的管理模式   1 16位微机的内存管理模式   2 32位微机的内存管理模式  2.3 习题 第3章 操作数的寻址方式  3.1 立即寻址方式  3.2 寄存器寻址方式  3.3 直接寻址方式  3.4 寄存器间接寻址方式  3.5 寄存器相对寻址方式  3.6 基址加变址寻址方式  3.7 相对基址加变址寻址方式  3.8 32位地址的寻址方式  3.9 操作数寻址方式的小结  3.10 习题 第4章 标识符和表达式  4.1 标识符  4.2 简单内存变量的定义   1 内存变量定义的一般形式   2 字节变量   3 字变量   4 双字变量   5 六字节变量   6 八字节变量   7 十字节变量  4.3 调整偏移量伪指令   1 偶对齐伪指令   2 对齐伪指令   3 调整偏移量伪指令   4 偏移量计数器的值  4.4 复合内存变量的定义   1 重复说明符   2 结构类型的定义   3 联合类型的定义   4 记录类型的定义   5 数据类型的自定义  4.5 标号  4.6 内存变量和标号的属性   1 段属性操作符   2 偏移量属性操作符   3 类型属性操作符   4 长度属性操作符   5 容量属性操作符   6 强制属性操作符   7 存储单元别名操作符  4.7 表达式   1 进制伪指令   2 数值表达式   3 地址表达式  4.8 符号定义语句   1 等价语句   2 等号语句   3 符号名定义语句  4.9 习题 第5章 微机CPU的指令系统  5.1 汇编语言指令格式   1 指令格式   2 了解指令的几个方面  5.2 指令系统   1 数据传送指令   2 标志位操作指令   3 算术运算指令   4 逻辑运算指令   5 移位操作指令   6 位操作指令   7 比较运算指令   8 循环指令   9 转移指令   10 条件设置字节指令   11 字符串操作指令   12 ASCII-BCD码调整指令   13 处理器指令  5.3 习题 第6章 程序的基本结构  6.1 程序的基本组成   1 段的定义   2 段寄存器的说明语句   3 堆栈段的说明   4 源程序的结构  6.2 程序的基本结构   1 顺序结构   2 分支结构   3 循环结构  6.3 段的基本属性   1 对齐类型   2 组合类型   3 类别   4 段组  6.4 简化的段定义   1 存储模型说明伪指令   2 简化段定义伪指令   3 简化段段名的引用  6.5 源程序的辅助说明伪指令   1 模块名定义伪指令   2 页面定义伪指令   3 标题定义伪指令   4 子标题定义伪指令  6.6 习题 第7章 子程序和库  7.1 子程序的定义  7.2 子程序的调用和返回指令   1 调用指令   2 返回指令  7.3 子程序的参数传递   1 寄存器传递参数   2 存储单元传递参数   3 堆栈传递参数  7.4 寄存器的保护与恢复  7.5 子程序的完全定义   1 子程序完全定义格式   2 子程序的位距   3 子程序的语言类型   4 子程序的可见性   5 子程序的起始和结束操作   6 寄存器的保护和恢复   7 子程序的参数传递   8 子程序的原型说明   9 子程序的调用伪指令   10 局部变量的定义  7.6 子程序库   1 建立库文件命令   2 建立库文件举例   3 库文件的应用   4 库文件的好处  7.7 习题 第8章 输入输出和中断  8.1 输入输出的基本概念   1 I/O端口地址   2 I/O指令  8.2 中断   1 中断的基本概念   2 中断指令   3 中断返回指令   4 中断和子程序  8.3 中断的分类   1 键盘输入的中断功能   2 屏幕显示的中断功能   3 打印输出的中断功能   4 串行通信口的中断功能   5 鼠标的中断功能   6 目录和文件的中断功能   7 内存管理的中断功能   8 读取和设置中断向量  8.4 习题 第9章 宏  9.1 宏的定义和引用   1 宏的定义   2 宏的引用   3 宏的参数传递方式   4 宏的嵌套定义   5 宏与子程序的区别  9.2 宏参数的特殊运算符   1 连接运算符   2 字符串整体传递运算符   3 字符转义运算符   4 计算表达式运算符  9.3 与宏有关的伪指令   1 局部标号伪指令   2 取消宏定义伪指令   3 中止宏扩展伪指令  9.4 重复汇编伪指令   1 伪指令REPT   2 伪指令IRP   3 伪指令IRPC  9.5 条件汇编伪指令   1 条件汇编伪指令的功能   2 条件汇编伪指令的举例  9.6 宏的扩充   1 宏定义形式   2 重复伪指令REPEAT   3 循环伪指令WHILE   4 循环伪指令FOR   5 循环伪指令FORC   6 转移伪指令GOTO   7 宏扩充的举例   8 系统定义的宏  9.7 习题 第10章 应用程序的设计  10.1 字符串的处理程序  10.2 数据的分类统计程序  10.3 数据转换程序  10.4 文件操作程序  10.5 动态数据的编程  10.6 COM文件的编程  10.7 驻留程序  10.8 程序段前缀及其应用   1 程序段前缀的字段含义   2 程序段前缀的应用  10.9 习题 第11章 数值运算协处理器  11.1 协处理器的数据格式   1 有符号整数   2 BCD码数据   3 浮点数  11.2 协处理器的结构  11.3 协处理器的指令系统   1 操作符的命名规则   2 数据传送指令   3 数学运算指令   4 比较运算指令   5 超越函数运算指令   6 常数操作指令   7 协处理器控制指令  11.4 协处理器的编程举例  11.5 习题 第12章 汇编语言和C语言  12.1 汇编语言的嵌入  12.2 C语言程序的汇编输出  12.3 一个具体的例子  12.4 习题 附录
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值