当前位置:网站首页>Assembly language learning (4)
Assembly language learning (4)
2022-08-09 14:51:00 【The goal is a tech house】
This part mainly includes Wang Shuang《汇编语言》第9The entire contents of the chapter and the 10Chapters except for experiments.
第9The chapter mainly introduces a variety ofjmp指令,Some of these instructions are branched based on displacement.It needs to be understood and masteredTransfer according to displacement的意义.
而第10章主要介绍了call和ret指令,由call和retForms the framework of subroutines.call和retStacks are also used.需要理解call和ret对栈段带来的变化.
1.jmp
1.jmp指令的分类
jmp short s
in the machine code,No labels are includeds的地址,而是包含了The displacement of the transfer.
由于CPUThe process of executing the instruction is:
1.从CS:IP指向的内存单元读取指令,读取的指令进入指令缓冲器
2.(IP)=(IP)+所取指令的长度,从而指向下一条指令
3.执行指令,转到1,重复这个过程.
所以The magnitude of the transfer displacement is equal to = displacement at the label - jmpThe address of the first byte after the instruction
According to the meaning of displacement transfer:
Easy to programFloating allocation in memory.If the instruction contains the branch destination address,Then the offset address of the program segment in memory is strictly limited.
转移指令 | 特点 | 功能 |
---|---|---|
jmp short 标号 | 段内短转移:Based on displacement进行转移 | (IP)=(IP)+8位位移 |
jmp near ptr 标号 | 段内近转移:Based on displacement进行转移 | (IP)=(IP)+16位位移 |
jmp far ptr 标号 | 段间(远)转移:The branch destination address is in the instruction | (CS:IP)The label is the address in the segment |
jmp 16位reg | Add the register after | (IP)=(16位reg) |
jmp word ptr 内存单元地址 | 段内转移:followed by the memory unit address | (IP)Equal to memory cell data |
jmp dword ptr 内存单元地址 | 段间转移:followed by the memory unit address | (CS:IP)Equal to memory cell data |
jcxz 标号 | 短转移,Based on displacement,cx不为0向下执行 | cx=0,则(IP)=(IP)+8位位移 |
loop 标号 | 短转移,Based on displacement进行转移 | cx减1,cxNon-zero jumps to the label to execute |
2.检测点:若使jmp指令执行后,CS:IP指向程序的第一条指令,在dataThe segment should define what data?
assume cs:code,ds:data
data segment
db 0,0,0 ;Note that it should be of byte type,jmpWhen taking the second and third zero asIP的值
data ends
code segment
code ends
start: mov ax,data
mov ds,ax
mov bx,0
jmp word ptr [bx+1]
end start
3.实验8 Analyze a strange program,Think about why this is the result?
assume cs:codesg
codesg segment
mov ax,4C00h
int 21h
start:mov ax,0
s: nop
nop
mov di,offset s
mov si,offset s2
mov ax,cs:[si]
mov cs:[di],ax
s0: jmp short s
s1: mov ax,0
int 21h
mov ax,0
s2: jmp short s1
nop
codesg ends
end start
可以看出,The order in which the program is executed is:
s -> s0 -> s -> mov ax,4C00h
分析程序可知,s的前两个nop
The machine code of the instruction is s2的jmp short s1
The machine code of the instruction is replaced.The reason appears fromsJump up to the end of the programmov ax,4C00h
,instead of jumping tos1
处,是由于jmp short s1
Instructions are not stored in the machine codes1
的位置,Instead, it is stored from s2至s1
的相对位移,With this relative displacement,sJumped to the end of the program.
4.实验9 根据材料编程
原理:内存地址空间中,B8000H~BFFFFH共32KB的空间,为80*25彩色字符模式的显示缓冲区.向这个地址空间写入数据,写入的内容将立即出现在显示器上.
显示缓冲区分为8页,每页4KB,显示器可以显示任意一页的内容.一般情况下,显示器显示第0页的内容.
一行中,一个字符占两个字节的存储空间,低位字节存储字符的ASCII码,高位字节存储字符的属性.
属性字节的格式:
7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
---|---|---|---|---|---|---|---|
BL | R | G | B | I | R | G | B |
闪烁 | 背景红 | 背景绿 | 背景蓝 | 高亮 | 前景红 | 前景绿 | 前景蓝 |
The black background corresponds to the background color000,white background is111.
The flickering effect is only there全屏方式下才能看到.
输入过程中:
输入结束后:(The screenshot does not show flickering)
Write in code as follows:
assume cs:code,ds:data,ss:stack
data segment
db 'Welcome to masm!'
db 8Ah,0CCh,0F9h
data ends
stack segment
dw 8 dup (0)
stack ends
code segment
start: mov ax,data
mov ds,ax
mov ax,stack
mov ss,ax
mov sp,16
mov ax,0B872h
mov es,ax
mov cx,3
mov si,0 ;ds:[16+si]
s: push cx
mov bx,0 ;ds:[bx+idata]
mov di,0 ;es:[di+idata]
mov cx,16
s1: mov al,ds:[bx]
mov es:[di],al
add di,2
add bx,1
loop s1 ;填ASCII码
mov cx,16
mov di,1
s2: mov al,ds:10h[si]
mov es:[di],al
add di,2
loop s2 ;Fill in character attributes
mov ax,es
add ax,0Ah
mov es,ax
add si,1
pop cx
loop s ;三行
mov ax,4C00h
int 21h
code ends
end start
2.call和ret
1.基本语法
call和ret | 特点 | Functions like assembly instructions |
---|---|---|
ret | Modify with the data on the stackIP,近转移 | pop IP |
retf | Modify with the data on the stackCS和IP,远转移 | pop IP | pop CS |
call 标号 | 转到标号处执行,Shift based on displacement | push IP | jmp near ptr 标号 |
call far ptr 标号 | 转到标号处执行,实现段间转移 | push CS|push IP|jump far ptr 标号 |
call 16位reg | The branch address is in a register | push IP | jump 16位reg |
call word ptr 内存地址 | The transfer address is in memory | push IP|jump word ptr 内存 |
call dword ptr 内存地址 | The transfer address is in memory | push CS|push IP|jmp dword ptr 内存 |
2.检测点:下面的程序执行后,ax中的数值为多少?
assume cs:code,ss:stack
stack segment
dw 8 dup (0)
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,16
mov ds,ax
mov ax,0
call WORD ptr ds:[0EH]
inc ax
inc ax
inc ax
mov ax,4C00h
int 21h
code ends
end start
Analyze the execution steps of the program:
1.Execute in order tocall word ptr ds:[0EH]
处.已知条件是ds
与ss
相等,而且ss:[0EH]
处值为0.
首先CPULoad this instruction,IP指向下一条指令inc ax
,接着CPU执行call指令,将inc ax
的IPThe address is put on the stack,IP被修改为0.
所以目前CS:IP指向start:mov ax,stack
2.Continue the sequence to call word ptr ds:[0EH]
处.已知条件是ds
与ss
相等,但是ss:[0EH]
处值为inc ax
的IP地址.
CPU加载指令,IP指向下一条指令inc ax
,接着CPU执行call指令,将inc ax
的IPThe address is put on the stack,IPModified to point to the next sentenceinc ax
.
3.顺序执行,得到(ax) = 3
.
An error-prone place in the analysis of the execution steps:
1.未注意ds
与ss
相等,Unable to proceed further analysis.
2.未考虑callThe instruction will be the next sentenceIP地址push到栈中,Take it out and use it directly next time.
3.模块化程序设计
利用call和ret指令,Multiple interconnections can be achieved、Function-independent subroutines.为使:
1.When writing a program that calls a subroutine, you don't have to worry about which registers are used by the subroutine.
2.编写子程序时不必关心调用者使用了哪些寄存器.
3.不会发生寄存器冲突.
A standard framework for writing subroutines has been established:
子程序开始:子程序使用的寄存器入栈
子程序内容
子程序使用的寄存器出栈
返回(ret、retf)
边栏推荐
- 使用 compose 的 Canvas 自定义绘制实现 LCD 显示数字效果
- dpkg:错误:无法新建文件 ‘/var/lib/dpkg/info/format-new’: 没
- apt-cache command
- dpkg: error: cannot new file '/var/lib/dpkg/info/format-new': no
- *1-5 OJ 642 Russian Multiplication
- RHCE Course Summary
- *1-5 OJ 642 俄式乘法
- #25-1 OJ 78 Calculate birthday day of the week
- Dry+Bean+Dataset R language data analysis, report in English
- 测试研发的人数科学比例
猜你喜欢
随机推荐
Assembly language learning (7)
How to develop small programs?should focus on features
RHCE Course Summary
C语言 一维数组和二维数组的定义及使用
阿里巴巴云原生大数据运维平台 SREWorks 正式开源
汇编语言学习(四)
【ICDE 2022】阿里发布稀疏模型训练框架HybridBackend,单位成本下训练吞吐提升至5倍
【ClickHouse】 日志清理方法(query_log、query_thread_log)
The code implementation of chess
C语言 猜数字游戏 (含代码并详细注释)
Simulate the realization of strcpy function (including multiple optimization ideas)
RHCE Course Summary
Assembly language learning (2)
iptables之SNAT与DNAT
RHCE课程总结
小程序模板制作流程,小程序模板制作方便快捷
同步锁synchronized追本溯源
Thinking about oracle financial data authority
C语言 求一个整数存储在内存中的二进制中1的个数(多种方法详解)
测试研发的人数科学比例