汇编中段的使用

段与段不能重合使用!!!

下面这种做法很不安全,如果在程序中出现这种程序代码,将CS段地址直接赋值给SS段使用,有可能导致灾难性后果。因为在段初始化时,会将几个寄存器值放到段内,随着PUSH操作的进行,这些值将会向低地址方向作整体移动,此时会覆盖CS段内开始定义的8个字的数据。

assume cs:codesg

codesg segment
	dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
	dw 0,0,0,0,0,0,0,0
start:	mov ax,cs
	mov ss,ax            #将CS段地址直接赋给SS段
	mov sp,30h
		
	mov bx,0
	mov cx,8
s:	push cs:[bx]
	add bx,2
	loop s
		
	mov bx,0
	mov cx,8
s0:	pop cs:[bx]
	add bx,2
	loop s0
		
	mov ax,4c00h
	int 21h
		
codesg ends
end start

程序运行前,内存状态:

汇编中段的使用_第1张图片

第1次push操作后,内存状态:

汇编中段的使用_第2张图片

第3次push操作后,内存状态:

汇编中段的使用_第3张图片

push操作结束后,内存状态:

汇编中段的使用_第4张图片

可以看到,在push操作的后期,对原始定义的数据进行了覆盖或者修改,导致最后脱离了控制。

所以,在一个程序中若使用多个段,应对多个段进行单独定义。如下代码。独立定义使用段空间后,进行PUSH/POP操作也不会影响其它段内的数据。

assume cs:code

a segment
	dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0ch,0eh,0fh,0ffh
a ends

b segment                            #多个段独立定义使用
	dw 0,0,0,0,0,0,0,0
b ends

code segment
start:	mov ax,a
	mov ds,ax
		
	mov ax,b
	mov ss,ax
	mov sp,16
	
	mov bx,0
	mov cx,8
s:	push ds:[bx]
	add bx,2
	loop s
		
	mov ax,4c00h
	int 21h

code ends
end start

程序运行前,内存状态:

汇编中段的使用_第5张图片

第1次push操作后,内存状态:

汇编中段的使用_第6张图片

第4次push操作后,内存状态:

汇编中段的使用_第7张图片

push操作结束后,内存状态:

汇编中段的使用_第8张图片

由此可见,对多个段进行独立定义使用,可以很好地保护相邻的内存数据。

你可能感兴趣的:(汇编补课,Linux内核学习,汇编)