美文网首页
汇编笔记4(跳转)

汇编笔记4(跳转)

作者: AlunX | 来源:发表于2018-06-08 00:47 被阅读0次

第9章(转移指令):

8086转移指令:

无条件转移指令,条件转移指令,循环指令,过程,中断

offset(伪指令):取得标号偏移地址(也就是要配合标号使用))取得值相当于一个常数(不能直接给段寄存器)

jmp(无条件跳转):可以修改ip也可以修改cs和ip

       (基于偏移) jmp short 标号:修改ip机器指令不包含目的地址,包含偏移地址

                short 8位的转移(-128~127),near ptr 16位的转移(-32769~32767)

       (基于目的地址)jmp far ptr 标号

        (基于寄存器)jmp  16位寄存器(存有转移目的地址)

         (基于内存)jmp word ptr 内存单元地址(存有转移目的地址)

                 word段内转移 ,dword段间转移

jcxz(有条件跳转指令)(都是短转移(基于偏移(-127~128)))

         jcxz 标号(若cx=0则转移到标号处)

loop(短转移)循环cx次 loop会先对cx-1再判断cx与0的关系(基于偏移(-127~128))

短跳转越界会报错。

实际操作暴露的问题:

        1.32位方式cs在后,ip在前

         2.不同数据段偏移地址互不影响

        3.数据不能直接赋给内存

        4.实验8原理,标号代表的是偏移地址,在执行之前得到并转化,所以向上跳。

实验9(彩色打印):

B8000H~BFFFFH为显示缓冲区,分8页,默认显示第一页(B8000H~B8F9FH)

        一行共160个字节,两个字节表示一个字符(偶地址放ascii,奇地址放属性各1字节)(从0到159)

        属性:       |  7          |  6  |  5  |  4  |       3       |  2  |  1  |  0  |

                          BL              R    G     B         I          R     G   B

                        闪烁            背景                 高亮        前景

编程暴露的问题:1.ss,cs值不能直接改变,不能有像mov ss,ax这种

                  2.初始化应在入栈,循环(标号)前

                  3.注意一个字占两个内存单元,add bx,2而不是inc bx

第10章(call和ret):

ret指令:用栈中命令修改ip(出栈)(ip先正常加再被覆盖)

retf指令:依次出栈ip和cs

call指令:将当前ip(call指令下一个指令开始地址)或cs和ip入栈,转移(非短转移)

        基于标号: (段内)call 标号:ip入栈后到标号处执行

                            (段间)call far ptr 标号 :cs入栈,ip入栈后到标号处执行

         基于寄存器:(段内)      call 16位寄存器

        基于内存:(段内)call word ptr 内存单元地址(ip入栈后执行内存单元中的地址)

                           (段间)call dword ptr 内存单元地址(存放顺序cs ip)(csip入栈后执行内存单元中的地址)

call+ret实现子程序:call和ret配对

         call到mov ax,4c00h int 21h后,再用ret返回回来就可以实现子程序调用

             子程序参数和结果需要寄存器较少时存放在寄存器中(参数寄存器,结果寄存器)

                      参数和结果较多时将批量数据存在内存中或栈中,首地址放在寄存器中

发生寄存器冲突(不同操作依赖同一寄存器)使用栈push pop来避免冲突

mul:乘法命令(mul 寄存器;mul byte ptr 内存地址;mul word存在 ptr 内存地址)

                        8位*8位(结果放入ax)默认al*

                       16位*16位(结果放入dx+ax)默认ax*

实验代码不难,鱼c论坛上都有(判断0用cx+jcxz的方法)

检测点暴露的问题:1.sp和bp默认段寄存器都是ss

                            2.0B8000h部分是显卡地址是动态变化的,debug跟踪会有问题

                           3.子程序设计时开始入栈,ret出栈以提高通用性

相关文章

  • 汇编笔记4(跳转)

    第9章(转移指令): 8086转移指令: 无条件转移指令,条件转移指令,循环指令,过程,中断 offset(伪指令...

  • MachO与动态链接

    前置知识 符号 静态链接 汇编基础 虚拟内存 跳转指令的编码:PC相对地址与绝对地址 汇编跳转指令:直接跳转与间接...

  • 汇编语言 学习笔记(三)

    汇编语言学习笔记 四、汇编语言程序格式 语句基本格式 汇编语言程序中的语句由 4 项组成,格式如下: 名字(nam...

  • ARM64汇编学习笔记一(初始汇编)

    ARM64汇编学习笔记一(初始汇编)

  • 底层研究 - 对象的底层探索(上)

    前言 本文底层使用的是objc 4-838.1版本 汇编指令 b bl 跳转指令,函数的调用 ret 函数的返回...

  • ARM 64 常见汇编指令

    ARM64常用的汇编指令 运算指令 程序跳转指令

  • ARM 汇编指令学习:[2]ARM指令集

    ARM 汇编指令学习:[2]ARM指令集 一、跳转指令 1、 B(跳转指令)及BL(带返回跳转指令) 其中: L决...

  • iOS 绕过汇编反调试

    汇编反调试,符号断点断不到,也无法进行hook,只能更改底层汇编对应的 机器码。 在hopper中查看跳转逻辑,找...

  • arm汇编的跳转

    转移指令(branch)说明:无条件转移B,BAL举例: B LABEL ; LABEL为某个位置 条件转移说明:...

  • <安全攻防之switch>

    switch ① 当判断条件小于4时switch的汇编代码 ② 当条件大于4时switch执行default的汇编...

网友评论

      本文标题:汇编笔记4(跳转)

      本文链接:https://www.haomeiwen.com/subject/eotosftx.html