8086 汇编例程

8086 汇编例程
8086 汇编例程

汇编语言(应用)程序(80X86/Pentium)

设计:乐金松

广东工业大学电子与信息工程学院

;This program for:R0R1-R2R3=R4R5

;---------------------------------------------------------------- ;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;define data segment

DATA SEGMENT

R0 DW (?)

R1 DW (?)

R2 DW (?)

R3 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

DATA ENDS

;define code segment

NDWSUB SEGMENT

;

MAIN PROC FAR

ASSUME CS:NDWSUB,DS:DATA,SS:STACK

;

START: PUSH DS ;return DOS standard program

MOV AX,0

PUSH AX

MOV AX,DATA ;set DS

MOV DS,AX

MOV AX,R1

SUB AX,R3

MOV R5,AX

MOV AX,R0

SBB AX,R2

MOV R4,AX

RET

MAIN ENDP

NDWSUB ENDS

END START

;This program for:R0R1+R2R3=R4R5

;---------------------------------------------------------------- ;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;define data segment

DATA SEGMENT

R0 DW (?)

R1 DW (?)

R2 DW (?)

R3 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

DATA ENDS

;define code segment

NDWADD SEGMENT

;

MAIN PROC FAR

ASSUME CS:NDWADD,DS:DATA,SS:STACK

;

START: PUSH DS ;return DOS standard program

MOV AX,0

PUSH AX

MOV AX,DATA

MOV DS,AX

MOV AX,R1

ADD AX,R3

MOV R5,AX

MOV AX,R0

ADC AX,R2

MOV R4,AX

RET

MAIN ENDP ;end process NDWADD ENDS ;end segment

END START

三、无符号二进制32位乘32位,结果为64位乘法子程序

;This program for:R2R3*R6R7=R4R5R6R7

;----------------------------------------------------------- ;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;define data segment

DATA SEGMENT

BWORD EQU THIS BYTE

R0 DW (?)

R1 DW (?)

R2 DW (?)

R3 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

DATA ENDS

;define code segment

NBMUL SEGMENT

;

MAIN PROC FAR

ASSUME CS:NBMUL,DS:DATA,SS:STACK

;

START: PUSH DS ;return DOS standard program

MOV AX,0

PUSH AX

MOV AX,DATA ;set DS

MOV DS,AX

MOV AX,R3

MUL R7 ;R3*R7=DXAX

XCHG AX,R7

MOV R5,DX

MUL R2 ;R2*R7=DXAX

ADD AX,R5

MOV R4,AX

MOV AX,0

ADC AX,DX ;DC+Cy+0 to R5

MOV R5,AX

MOV AX,R6

MUL R3

ADD AX,R4

XCHG AX,R6

ADC R5,DX

PUSHF ;Save Cy to stack MUL R2

ADD R5,AX

MOV AX,0

ADC DX,AX ;DX+Cy+0=DX

POPF

ADC DX,AX

MOV R4,AX

RET

MAIN ENDP

NBMUL ENDS

END START

四、无符号二进制64位除32位,结果为32位除法子程序

注意几个问题:

1、判断够减或不够减的方法

2、够减时的处理方法

3、不够减时的处理方法

4、商上1的位置和方法

5、商上零的方法

;This program for:R4R5R6R7/R2R3=R6R7 ;Remainder=(R4R5)

;---------------------------------------------------------------- ;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;define data segment

DATA SEGMENT

BWORD EQU THIS BYTE ;注意这条伪指令的用法 R0 DW (?)

R1 DW (?)

R2 DW (?)

R3 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

DATA ENDS

;define code segment

NBDIV SEGMENT

;

MAIN PROC FAR

ASSUME CS:NBDIV,DS:DATA,SS:STACK

;

START: PUSH DS ;return DOS standard program

MOV AX,0

PUSH AX

MOV AX,DATA ;set DS

MOV DS,AX

MOV AX,R5

SUB AX,R3

MOV AX,R4

SBB AX,R2

JNC DIV4 ;Over process

MOV CX,32 ;32次循环的目的?DIV1: CLC

RCL R7,1

RCL R6,1

RCL R5,1

RCL R4,1

PUSHF

POP R0 ;Store RF to R0

MOV AX,R5

SUB AX,R3

MOV R1,AX

MOV AX,R4

SBB AX,R2

PUSHF

TEST BYTE PTR R0,01H

JNZ DIV21

POPF

JNC DIV2

JMP DIV3

DIV21: POPF

DIV2: MOV R4,AX

MOV AX,R1

MOV R5,AX

INC R7

DIV3: LOOP DIV1

STC

DIV4: RET

MAIN ENDP

NBDIV ENDS

END START

五、10位非压缩BCD码转化成32位二进制数子程序(十翻二子程序)

思考:1、结果乘10怎样乘?

2、加下一位怎样加?

3、将程序改成16位10进制数转换成48位二进制数,怎样修改程序?

;This program for:buffer0-buffer9 BCD code convert into Binary

;input=buffer0--buffer9 (10 Byte Type no compressible BCD code) ;output=R1R0 (Word Type binary)

;---------------------------------------------------------------- ;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;define data segment

DATA SEGMENT

BWORD EQU THIS BYTE

R0 DW (?)

R1 DW (?)

R2 DW (?)

R3 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

buffer0 DB (?)

buffer1 DB (?)

buffer2 DB (?)

buffer3 DB (?)

buffer4 DB (?)

buffer5 DB (?)

buffer6 DB (?)

buffer7 DB (?)

buffer8 DB (?)

buffer9 DB (?)

DATA ENDS

;define code segment

DCTB SEGMENT

;

MAIN PROC FAR

ASSUME CS:DCTB,DS:DATA,SS:STACK

;

START: PUSH DS ;return DOS standard program MOV AX,0

PUSH AX

MOV AX,DATA ;set DS

MOV DS,AX

LEA BX,buffer9

MOV R0,0

MOV R1,0

MOV CX,10

DO_LOOP: MOV AX,R0

MOV R7,10

MUL R7

MOV R0,AX

XCHG DX,R1

MOV AX,DX

MUL R7

ADD R1,AX

MOV AL,[BX]

MOV AH,0

ADD R0,AX

ADC R1,0

DEC BX

LOOP DO_LOOP

RET

MAIN ENDP

DCTB ENDS

END START

六、48位二进制数转换成十进制数子程序

思考:1、结果乘二怎样乘?

2、加下一位怎样加?在哪里加?

3、用什么方法转化成10进制,如果无调整指令该怎么做?

4、将程序改成32位二进制转化成十进制数怎么转化

;This program for:R5R6R7 binanry data convert into BCD

;of compressible code

;input=R5R6R7

;output=buffer0--buffer7

;---------------------------------------------------------------- ;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;define data segment

DATA SEGMENT

BWORD EQU THIS BYTE

R0 DW (?)

R1 DW (?)

R2 DW (?)

R3 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

buffer0 DB (?)

buffer1 DB (?)

buffer2 DB (?)

buffer3 DB (?)

buffer4 DB (?)

buffer6 DB (?)

buffer7 DB (?)

DATA ENDS

;define code segment

BCTD SEGMENT

MAIN PROC FAR

ASSUME CS:BCTD,DS:DATA,SS:STACK

START: PUSH DS ;return DOS standard program MOV AX,0

PUSH AX

MOV AX,DATA ;set DS

MOV DS,AX

MOV CX,8

LEA BX,[buffer0]

CLR_BUFFER: MOV BYTE PTR [BX],0

INC BX

LOOP CLR_BUFFER

MOV CX,48

DO_LOOP: CLC

RCL R7,1

RCL R6,1

RCL R5,1

MOV AL,buffer0

ADC AL,AL

DAA

MOV buffer0,AL

MOV AL,buffer1

ADC AL,AL

DAA

MOV buffer1,AL

MOV AL,buffer2

ADC AL,AL

DAA

MOV buffer2,AL

MOV AL,buffer3

ADC AL,AL

DAA

MOV buffer3,AL

MOV AL,buffer4

ADC AL,AL

DAA

MOV AL,buffer5

ADC AL,AL

DAA

MOV buffer5,AL

MOV AL,buffer6

ADC AL,AL

DAA

MOV buffer6,AL

MOV AL,buffer7

ADC AL,AL

DAA

MOV buffer7,AL

LOOP DO_LOOP

RET

MAIN ENDP

BCTD ENDS

END START

七、键盘读入子程序

功能:读入一个按键,并显示字符,,按“ESC”退出程序,其中调用字符显示程序

思考: 1、如何判断有无按键按下?

2、如何读取按键的键值?

3、如何显示一个字符?

;This program for:sample program of key input

;----------------------------------------------------------------

;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;------------------------------------

;define data segment

DATA SEGMENT

BWORD EQU THIS BYTE

R0 DW (?)

R1 DW (?)

R2 DW (?)

R3 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

ROW_REG DB (?) ;ROW*COL

COL_REG DB (?)

DATA ENDS

;------------------------------------

;define es segment

VIDEO SEGMENT AT 0B800H

WD_BUFFER LABEL WORD

V_BUFF DB 25*80*2 DUP (?)

VIDEO ENDS

;------------------------------------

;define code segment

PROGRAM SEGMENT

MAIN PROC FAR

ASSUME CS:PROGRAM,DS:DATA,SS:STACK,ES:VIDEO

;

START: PUSH DS ;return DOS standard program MOV AX,0

PUSH AX

MOV AX,DATA ;set DS

MOV DS,AX

MOV AX,VIDEO ;set ES

MOV ES,AX

MOV ROW_REG,10

MOV COL_REG,20

MOV R0,0000H ;clr screen

MOV R1,184FH

MOV BH,0FH ;set background color

CALL CLR_SCREEN

;---------------------------------------

SCAN_KEY: MOV AH,1

INT 16H ;Test Key

JZ SCAN_KEY

YES_KEY: MOV AH,0

INT 16H ;Read key

CMP AL,1BH ;test "esc=1bh" key

JNZ KEY_PROCESS

JMP EXIT ;if "ESC" Key go to EXIT

KEY_PROCESS: MOV AH,5FH ;Set symbol color

MOV CL,COL_REG ;Set locat of symbol

MOV CH,ROW_REG

CALL DISPLAY

INC COL_REG

CMP COL_REG,61

JNE KEY_PROCESS1

MOV COL_REG,20

INC ROW_REG

CMP ROW_REG,16

JNE KEY_PROCESS1

MOV ROW_REG,15

MOV COL_REG,60

KEY_PROCESS1: MOV AH,02H ;Set arrow location

MOV DH,ROW_REG

MOV DL,COL_REG

MOV BH,0

INT 10H

JMP SCAN_KEY

EXIT: MOV R0,0000H

MOV R1,184FH

MOV BH,0FH ;set background color

CALL CLR_SCREEN

RET

MAIN ENDP

;*************************************************************** ;bellow is a some proc near program

;-----------------------------------

;display a symbol

;input: symbol=al ;字符的ASCII码

; color=ah ;颜色属性

; row=ch ;行坐标

; col=cl ;列坐标

;use reg:AX,BX,CX

DISPLAY PROC NEAR ;address of display

;buffer=row*80*2+col*2

PUSH BX

PUSH CX

PUSH AX

MOV AL,160

MUL CH ;ROW*80*2(160)=AX

MOV BL,CL

MOV BH,0

ADD BX,AX

POP AX

MOV ES:[WD_BUFFER+BX],AX

POP CX

POP BX

RET

DISPLAY ENDP

;-------------------------------------------------------------- CLR_SCREEN PROC NEAR ;清除屏幕

MOV AH,06H

MOV CX,R0

MOV DX,R1

INT 10H

MOV AH,02H

MOV DH,ROW_REG

MOV DL,COL_REG

MOV BH,0

INT 10H

RET

CLR_SCREEN ENDP

;-------------------------------------------------------------- PROGRAM ENDS

END START

八、显示日期和时间程序

思考:1、怎样读取日期,和时间

2、怎样在屏幕上定位显示坐标?

3、怎样显示日期和时间

4、其中调用哪些系统程序?

;This program for:display date and time

;---------------------------------------------------------------- ;define stack segment

STACK SEGMENT STACK 'STACK'

DB 1024 DUP (0)

STACK ENDS

;define data segment

DATA SEGMENT

BWORD EQU THIS BYTE

R0 DW (?)

R1 DW (?)

R2 DW (?)

R4 DW (?)

R5 DW (?)

R6 DW (?)

R7 DW (?)

;-------------------------------------------------- TEMP1 DW (?)

TEMP2 DW (?)

TEMP3 DW (?)

TEMP4 DW (?)

;-------------------------------------------------- LED1 DB (?)

LED2 DB (?)

LED3 DB (?)

LED4 DB (?)

LED5 DB (?)

LED6 DB (?)

LED7 DB (?)

LED8 DB (?)

LED9 DB (?)

LED10 DB (?)

LED11 DB (?)

LED12 DB (?)

LED13 DB (?)

LED14 DB (?)

LED15 DB (?)

LED16 DB (?)

LED17 DB (?)

LED18 DB (?)

LED19 DB (?)

;------------------------------------

YEAR_REG DB (?)

MOTH_REG DB (?)

DATE_REG DB (?)

S_REG DB (?)

M_REG DB (?)

H_REG DB (?)

;----------------

DATA ENDS

;------------------------------------

;define es segment

VIDEO SEGMENT AT 0B800H

WD_BUFFER LABEL WORD

V_BUFF DB 25*80*2 DUP (?)

VIDEO ENDS

;------------------------------------

;define code segment

PROGRAM SEGMENT

;

MAIN PROC FAR

ASSUME CS:PROGRAM,DS:DATA,SS:STACK,ES:VIDEO

;

START: PUSH DS ;return DOS standard program MOV AX,0

PUSH AX

MOV AX,DATA ;set DS

MOV DS,AX

MOV AX,VIDEO ;set ES

MOV ES,AX

MOV TEMP1,0000H ;clr screen

MOV TEMP2,184FH

MOV BH,0FH ;set background color

CALL CLR_SCREEN

;---------------------------------------

DO_WAIT: MOV AH,1

INT 16H ;Test Key

JZ NO_KEY

YES_KEY: MOV AH,0

INT 16H ;Read key

CMP AL,1BH ;test "esc=1bh" key

JNZ NO_KEY

JMP EXIT ;if "ESC" Key go to EXIT

NO_KEY: CALL READ_TIME

CALL READ_DATE

CALL CONVERT_ASCII

CALL DISPLAY_TIME

CALL DISPLAY_DATE

JMP DO_WAIT

EXIT: MOV TEMP1,0000H

MOV TEMP2,184FH

MOV BH,0FH ;set background color

CALL CLR_SCREEN

RET

MAIN ENDP

;*************************************************************** ;bellow is a some proc near program

;-----------------------------------

;read time

;input=no

;out= H_REG,M_REG,S_REG ,all data is BCD code

READ_TIME PROC NEAR

MOV AH,02H ;read time,ah=02h

INT 1AH ;out=ch(h),cl(m),dh(s)

MOV H_REG,CH

MOV M_REG,CL

MOV S_REG,DH

RET

READ_TIME ENDP

;--------------------------------------

;read date

;input=on

;out=YEAR_REG,MOTH_REG,DATE_REG,all data is BCD code

READ_DATE PROC NEAR

MOV AH,04H ;read time,ah=02h

INT 1AH ;out=ch(h),cl(m),dh(s)

MOV YEAR_REG,CL

MOV MOTH_REG,DH

MOV DATE_REG,DL

RET

;------------------------------------------

;convert time and data into ASCII code and store to display buffer CONVERT_ASCII PROC NEAR

MOV AL,H_REG ;process time

AND AL,0F0H

MOV CL,4

ROR AL,CL

ADD AL,30H ;Convert ASCII

MOV LED1,AL

MOV AL,H_REG

AND AL,0FH

ADD AL,30H ; Convert ASCII

MOV LED2,AL

MOV AL,M_REG

AND AL,0F0H

MOV CL,4

ADD AL,30H ; Convert ASCII MOV LED4,AL

MOV AL,M_REG

AND AL,0FH

ADD AL,30H ; Convert ASCII MOV LED5,AL

MOV AL,S_REG

AND AL,0F0H

MOV CL,4

ROR AL,CL

ADD AL,30H ; Convert ASCII MOV LED7,AL

MOV AL,S_REG

AND AL,0FH

ADD AL,30H ; Convert ASCII MOV LED8,AL

MOV LED3,3AH ;set ":"

MOV LED6,3AH ;set ":"

;----------------------------------------------------

MOV AL,YEAR_REG ;process date AND AL,0F0H

MOV CL,4

ROR AL,CL

ADD AL,30H ; Convert ASCII MOV LED12,AL

MOV AL,YEAR_REG

AND AL,0FH

ADD AL,30H ; Convert ASCII MOV LED13,AL

MOV AL,MOTH_REG

AND AL,0F0H

MOV CL,4

ROR AL,CL

ADD AL,30H ; Convert ASCII MOV LED15,AL

MOV AL,MOTH_REG

AND AL,0FH

ADD AL,30H ; Convert ASCII

MOV LED16,AL

MOV AL,DATE_REG

MOV CL,4

ROR AL,CL

ADD AL,30H ; Convert ASCII

MOV LED18,AL

MOV AL,DATE_REG

AND AL,0FH

ADD AL,30H ; Convert ASCII

MOV LED19,AL

MOV LED10,32H ;"2"

MOV LED11,30H ;"0"

MOV LED14,2DH ;"-"

MOV LED17,2DH ;"-"

RET

CONVERT_ASCII ENDP

;-------------------------------------------------------

;display a symbol

;input: symbol=al

; color=ah

; row=ch

; col=cl

;use reg:AX,BX,CX

DISPLAY PROC NEAR ;address of display

;buffer=row*80*2+col*2

PUSH BX

PUSH CX

PUSH AX

MOV AL,160

MUL CH ;ROW*80*2(160)=AX

MOV BL,CL

ROL BL,1 ;BL*2

MOV BH,0

ADD BX,AX

POP AX

MOV ES:[WD_BUFFER+BX],AX

POP CX

POP BX

RET

DISPLAY ENDP

;-------------------------------------------------------------- ;display time,send led1-led8 data to screen

DISPLAY_TIME PROC NEAR

MOV R0,8

8086汇编语言程序设计

实验1 简单汇编语言程序设计 一、实验目的与要求 1.熟悉汇编语言运行、调试环境及方法。 2.掌握简单汇编语言程序的设计方法。 3.熟悉调试工具DEBUG,并运用DEBUG 工具调试程序。 二、实验内容 根据下列要求,编写汇编源程序,汇编连接汇编源程序,并利用DEBUG 工具调试程序,验证程序的正确性。 1. 若X、Y、R、W 是存放8 位带符号数字节单元的地址,Z 是16 位字单元的 地址。试编写汇编程序,完成Z←((W-X) ÷5-Y)?(R+ 2) 。 2.试编写一个程序,测试某数是否是奇数。如该数是奇数,则把DL 的第0 位置1,否则将该位置0。 三、实验报告要求 1.程序算法流程图。 2.源程序清单。 3.程序运行结果。 4.调试过程中遇到的问题和解决的方法。

实验2 分支及循环程序设计 一、实验目的与要求 1.熟悉汇编语言运行、调试环境及方法。 2.掌握分支程序和循环程序的设计方法。 3.熟悉调试工具DEBUG,并运用DEBUG工具调试程序。 二、实验内容 根据下列要求,编写汇编源程序,汇编连接汇编源程序,并利用DEBUG工具调试程序,验证程序的正确性。 1.编写汇编程序,统计某存储区若干个数据中英文字母的个数,并将结果在屏幕上显示。 2.从键盘任意输入一组字符数据,请编写汇编程序将该组数据加密后在屏幕上显示。参考加密方法是:每个数乘以2。(说明:本题的加密方法,同学们可以自己拟定) 三、实验报告要求 1.程序算法流程图。 2.源程序清单。 3.程序运行结果。 4.调试过程中遇到的问题和解决的方法。

实验3 子程序程序设计 一、实验目的与要求 1.熟悉汇编语言运行、调试环境及方法。 2.掌握子程序的设计方法。 3.熟悉调试工具DEBUG,并运用DEBUG工具调试程序。 二、实验内容 根据下列要求,编写汇编源程序,并利用DEBUG工具调试程序,验证程序的正确性。 1.编程以十进制形式和十六进制形式显示AX的内容,并把两个显示功能分别封装成子程序dispDEC和dispHEX。 2.设在以EXAMSCORE为首地址的数据缓冲区依次存放某班10名同学5门功课的成绩,现要统计各位同学的总分,并将总分放在该学生单科成绩后的单元,并调用第1个程序封装好的子程序,以十进制方式显示统计情况,显示格式自行设计。请编程完成此功能。数据缓冲区参考数据定义如下: EXAMSCORE DB 01 ;学号 DB 89,76,54,77,99 ;单科成绩 DW ? ;该学生的总分 DB 02 ;学号 DB 79,88,64,97,92 ;单科成绩 DW ? ;该学生的总分 三、实验报告要求 1.程序算法流程图。 2.源程序清单。 3.程序运行结果。 4.调试过程中遇到的问题和解决的方法。

x86汇编指令集

x86汇编指令集 数据传输指令它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据. 1. 通用数据传送指令. MOV 传送字或字节. MOVSX 先符号扩展,再传送. MOVZX 先零扩展,再传送. MOVSX reg16,r/m8 ; o16 0F BE /r [386] MOVSX reg32,r/m8 ; o32 0F BE /r [386] MOVSX reg32,r/m16 ; o32 0F BF /r [386] MOVZX reg16,r/m8 ; o16 0F B6 /r [386] MOVZX reg32,r/m8 ; o32 0F B6 /r [386] MOVZX reg32,r/m16 ; o32 0F B7 /r [386] PUSH 把字压入堆栈. POP 把字弹出堆栈. PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈. POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.

PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈. POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈. BSWAP 交换32位寄存器里字节的顺序 XCHG 交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数) CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX ) XADD 先交换再累加.( 结果在第一个操作数里) XLAT 字节查表转换. ── BX 指向一张256 字节的表的起点, AL 为表的索引值(0-255,即 0-FFH); 返回AL 为查表结果. ( [BX+AL]->AL ) 2. 输入输出端口传送指令. IN I/O端口输入. ( 语法: IN 累加器, {端口号│DX} ) OUT I/O端口输出. ( 语法: OUT {端口号│DX},累加器) 输入输出端口由立即方式指定时, 其范围是0-255; 由寄存器DX 指定时, 其范围是0-65535. 3. 目的地址传送指令. LEA 装入有效地址. 例: LEA DX,string ;把偏移地址存到DX. LDS 传送目标指针,把指针内容装入DS. 例: LDS SI,string ;把段地址:偏移地址存到DS:SI. LES 传送目标指针,把指针内容装入ES. 例: LES DI,string ;把段地址:偏移地址存到ES:DI. LFS 传送目标指针,把指针内容装入FS.

嵌入式简单汇编程序实例

ARM实验报告 姓名:郭健傧学号:L2101898 1.实验目的 (1)了解ADS1.2集成开发环境及ARMulator软件仿真; (2)熟悉ARM的乘法指令和逻辑指令; (3)结合ARM处理器硬件特性,比较处理函数的特性; 2.实验设备 硬件:pc机一台; 软件:Windowsxp系统,ADS1.2集成开发环境; 3.实验内容 (1)建立一个新的工程; (2)建立一个汇编文件,并添加到工程; (3)根据所给的两个C语言函数编写相应的汇编程序,并比较一下代码中fact1和fact2两个函数的特性; 4.实验步骤 (1)启动ADS1.2IDE集成开发环境,使用ARM Executable Image 工程模块建立一个工程heiye。 (2)建立汇编源文件test.s,编写程序实验,并添加到工程heiye中。 (3)设置工程连接地址Ro Base为0x40000000,RWBase为0x40003000。设置调试入口地址Image entry point为0x40000000。 (4)编译链接工程,并启动AXD进行软件仿真调试。 5.编写程序如下: C程序源代码: int fact1(int limit) { int fact=1; for(i=1;i

8086汇编指令手册

8086汇编指令手册 一、数据传输指令 它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据. 1. 通用数据传送指令. MOV 传送字或字节. MOVSX 先符号扩展,再传送. MOVZX 先零扩展,再传送. PUSH 把字压入堆栈. POP 把字弹出堆栈. PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈. POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈. PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈. POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈. BSWAP 交换32位寄存器里字节的顺序 XCHG 交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数) CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX ) XADD 先交换再累加.( 结果在第一个操作数里) XLAT 字节查表转换. —— BX 指向一张256 字节的表的起点, AL 为表的索引值(0-255,即 0-FFH); 返回AL 为查表结果. ( [BX+AL]->AL ) 2. 输入输出端口传送指令. IN I/O端口输入. ( 语法: IN 累加器, {端口号│DX} ) OUT I/O端口输出. ( 语法: OUT {端口号│DX},累加器) 输入输出端口由立即方式指定时, 其范围是0-255; 由寄存器DX 指定时, 其范围是0-65535. 3. 目的地址传送指令. LEA 装入有效地址. 例: LEA DX,string ;把偏移地址存到DX. LDS 传送目标指针,把指针内容装入DS. 例: LDS SI,string ;把段地址:偏移地址存到DS:SI. LES 传送目标指针,把指针内容装入ES. 例: LES DI,string ;把段地址:偏移地址存到ES:DI. LFS 传送目标指针,把指针内容装入FS. 例: LFS DI,string ;把段地址:偏移地址存到FS:DI. LGS 传送目标指针,把指针内容装入GS. 例: LGS DI,string ;把段地址:偏移地址存到GS:DI. LSS 传送目标指针,把指针内容装入SS. 例: LSS DI,string ;把段地址:偏移地址存到SS:DI. 4. 标志传送指令. LAHF 标志寄存器传送,把标志装入AH. SAHF 标志寄存器传送,把AH内容装入标志寄存器.

汇编语言程序设计教学大纲

《汇编语言程序设计》课程教学大纲 二、课程简介 汇编语言是计算机能够提供给用户使用的最快最有效的语言,也是能够利用计算机所有硬件特性并能直接控制硬件的唯一语言,因而,对程序的空间和时间要求很高的场合及需要直接控制硬件的应用场合,汇编语言的应用是必不可少三、课程目标 汇编语言课程是计算机专业的一门专业选修课。通过本课程的学习,应使学 生系统地了解计算机组成原理与内部的运行机理,掌握汇编语言程序设计及相关 知识,为学习本专业后继课程和进行与硬件有关的技术工作打下良好基础。通过 上机实验,使学生受到软硬件实验的初步训练,并培养学生分析问题和解决问题 的能力。 四、教学内容及要求 第一章基础知识 1.教学内容 (1) 为什么要用汇编语言编写程序 (2) 进位计数制与不同基数的数之间的转换 (3) 二进制数和十六进制数运算 (4) 计算机中数和字符的表示 (5) 几种基本的逻辑运算 2.基本要求 了解机器指令、代码指令、机器语言、汇编指令、汇编语言、汇编语言源程 序、汇编程序、汇编等概念;掌握进位计数制与不同基数的数之间的转换及

运算;计算机中数和字符的表示;“与”、“或”、“非”、“异或”等几种基本的逻辑运算; 第二章80X86计算机组织 1.教学内容 计算机系统概述、存储器、中央处理机和外部设备。 2.基本要求 理解计算机的硬件和软件系统及其关系。掌握计算机的基本结构及总线;存储器的内容、地址及存储器的分段;中央处理机的组成、80X86系列CPU工作寄存器构成和功能,特别是段寄存器和标志寄存器;外设接口、端口和8086/8088的端口地址范围和访问方法。 第三章80X86的指令系统 1.教学内容(重点内容) IBM PC机的寻址方式、IBM PC机的指令系统。 2.基本要求 熟练掌握IBM PC机寻址方式及物理地址的计算;数据传送、算术、逻辑、串处理、控制转移和处理机控制指令六组中的所有指令的格式、操作、及影响的标志位。了解机器语言的指令组成; 第四章汇编语言程序格式 1.教学内容 汇编程序功能、伪操作、汇编语言程序格式、汇编语言程序的上机过程。 2.基本要求 掌握DEBUG程序和命令及能用DEBUG 程序调试和运行简单小程序;汇编语言上机步骤、汇编程序的功能;数据定义及存储器分配、表达式赋值“EQU”和“=”、段定义、程序开始和结束、对准、基数控制等六类伪操作;汇编语言程序格式中的名字、操作、操作数和注释等项。 第五章循环与分支程序设计 1.教学内容 程序设计的一般步骤和基本结构、循环程序设计和分支程序设计 2.基本要求 掌握汇编语言程序的编制步骤和结构化程序设计的三种基本结构;循环的设计方法和多层循环的设计;分支程序的设计方法,并能编制相应的程序。第六章子程序结构 1.教学内容 子程序的设计方法、嵌套与递归子程序、子程序举例和DOS系统功能调用

汇编语言知识大全

第一章基础知识: 一.机器码:1.计算机只认识0,1两种状态。而机器码只能由0,1组成。故机器码相当难认,故产生了汇编语言。 2.其中汇编由三类指令形成:汇编指令(有机器码对应),伪指令,其他符号(编译的时候有用)。 每一总CPU都有自己的指令集;注意学习的侧重点。 二.存储器:1.存储单元中数据和指令没任何差别。 2.存储单元:Eg:128个储存单元(0~127)128byte。 线: 1.地址总线:寻址用,参数(宽度)为N根,则可以寻到2^N个内存单元。 据总线:传送数据用,参数为N根,一次可以传送N/8个存储单元。 3.控制总线:cpu对元器件的控制能力。越多控制力越强。 四.内存地址空间:1.由地址总线决定大小。 2.主板:cpu和核心器件(或接口卡)用地址总线,数据总线,控制总 线连接起来。 3.接口卡:由于cpu不能直接控制外设,需通过接口卡间接控制。

4.各类存储器芯片:RAM,BIOS(主板,各芯片)的ROM,接卡槽的 RAM CPU在操控他们的时候,把他们都当作内存来对待,把他们总的看作一个由 若干个存储单元组成的逻辑存储器,即我们所说的内存地址空间。 自己的一点理解:CPU对内存的操作是一样的,但是在cpu,内存,芯片之间的硬件本身所牵扯的线是不同的。所以一些地址的功能是对应一些芯片的。 第二章寄存器 引入:CPU中含有运算器,寄存器,控制器(由内部总线连接)。而寄存器是可以用来指令读写的部件。8086有14个寄存器(都是16位,2个存储空间)。 一.通用寄存器(ax,bx,cx,dx),16位,可以分为高低位 注意1.范围:16位的2^16-1,8位的2^8-1 2.进行数据传送或运算时要注意位数对应,否则会报错 二.字:1. 1个字==2个字节。 2. 在寄存器中的存储:0x高位字节低位字节;单元认定的是低单元 数制,16进制h,2进制b

8086汇编指令大全.

标志寄存器:9个有效位,分 6个状态寄存器和 3个控制寄存器 CF 当执行一个加法(减法使最高位产生进位(借位时 CF=1 否则 CF=0 PF 指令执行的结果低 8位有偶数个一时, CF=1 否则 CF=0 AF 当执行一个加法(减法使运算结果低 4位向高 4位有进位(借位时 AF=1 否则 AF+0 ZF 当前运算结果为零, ZF=1 否则 ZF=0 SF 符号标志位 OF 溢出标志位 DF 方向标志位 IF 中断允许位 IF=1时响应外部中断

TF 跟踪标志位 操作数:[目的操作数(OPD ,源操作数(OPS ] ;立即操作数,寄存器操作数,存储器操作数。寻址方式: 1 寄存器寻址例:INC AX ; MOV AX , BX 2 寄存器间接寻址 (寄存器只能是 BX , DI , SI , BP ; [PA=(BX 、 DI 、 SI +DS》 4 或 BP+SS》4] 3 寄存器相对寻址 4 基址变址寻址 5 相对基址变址寻址 6 直接寻址 7 立即数寻址 i. 立即数寻址立即数寻址不能用在单操作数指令中 ii. 在双操作数中,立即数寻址方式不能用于目的操作数字段 指令系统: 1 数据传送指令 mov 注意: 不允许在两个存储单元之间直接传送数据

不允许在两个段寄存器之间传送数据 不允许用立即数直接为段寄存器赋值 不影响标志位 不允许寄存器或存储单元到除 CS 外的段寄存器 2 入栈(出栈指令 PUSH (POP 注意: PUSH 操作数不能是“立即数” POP 操作数不能是段寄存器 CS 不影响标志位 先进后出 单操作符 3 交换指令 XCHG 注意:

基础的汇编语言小程序

基础的汇编语言小程序 1.1 Hello World !程序(完整段) (注:所有的标点符号以及空格回车均为英文输入法状态下的,否则报错!) DATAS SEGMENT STRING DB ‘Hello World !’,13,10,’$’ DATAS ENDS CODES SEGMENT ASSUME CS:CODES,DS:DATAS START: MOV AX,DATAS MOV DS,AX LEA DX,STRING MOV AH,9 INT 21H MOV AH,4CH INT 21H CODES ENDS END START 1.2 Hello World !程序(简化段) .MODEL SMALL .DATA

STRING DB’Hello World !’,13,10,’$’ .STACK .CODE .STARTUP LEA DX,STRING MOV AH,9 INT 21H .EXIT END 2.1完整段的求3+5的和 DATA SEGMENT FIVE DB 5 DATAS ENDS STACKS SEGMENT DB 128 DUP(?) STACKS ENDS CODES SEGMENT ASSUME CD:CODES,DS:DATAS,SS:STACKS START: MOV AX,DATAS MOV DS,AX MOV AL,FIVE

ADD AL,3 ADD AL,30H MOV DL,AL MOV AH,2 MOV AH,4CH INT 21H CODES ENDS END START 2.2;简化段的求3+5的和.MODEL SMALL .DATA FIVE DB 5 .STACK DB 128 DUP (?) .CODE .STARTUP MOV AL,FIVE ADD AL,3 ADD AL,30H MOV DL,AL MOV AH,2 INT 21H

常用8086汇编指令(彩色版)

8086/8088指令系统 一、数据传送指令 1.通用数据传送指令 MOV(Move)传送 PUSH(Push onto the stack)进栈 POP(Pop from the stack)出栈 XCHG(Exchange)交换 .MOV指令 格式为:MOV DST,SRC 执行的操作:(DST)<-(SRC) .PUSH进栈指令 格式为:PUSH SRC 执行的操作:(SP)<-(SP)-2 ((SP)+1,(SP))<-(SRC) .POP出栈指令 格式为:POP DST 执行的操作:(DST)<-((SP+1),(SP)) (SP)<-(SP)+2 .XCHG交换指令 格式为:XCHG OPR1,OPR2 执行的操作:(OPR1)<-->(OPR2) 2.累加器专用传送指令 IN(Input)输入 OUT(Output)输出 XLAT(Translate)换码 这组指令只限于使用累加器AX或AL传送信息. .IN输入指令 长格式为:IN AL,PORT(字节) IN AX,PORT(字) 执行的操作:(AL)<-(PORT)(字节) (AX)<-(PORT+1,PORT)(字) 短格式为:IN AL,DX(字节) IN AX,DX(字) 执行的操作:AL<-((DX))(字节) AX<-((DX)+1,DX)(字) .OUT输出指令 长格式为:OUT PORT,AL(字节) OUT PORT,AX(字)

执行的操作:(PORT)<-(AL)(字节) (PORT+1,PORT)<-(AX)(字) 短格式为:OUT DX,AL(字节) OUT DX,AX(字) 执行的操作:((DX))<-(AL)(字节) ((DX)+1,(DX))<-AX(字) 在IBM-PC机里,外部设备最多可有65536个I/O端口,端口(即外设的端口地址)为0000~FFFFH.其中前256个端口(0~FFH)可以直接在指令中指定,这就是长格式中的PORT,此时机器指令用二个字节表示,第二个字节就是端口号.所以用长格式时可以在指定中直接指定端口号,但只限于前256个端口.当端口号>=256时,只能使用短格式,此时,必须先把端口号放到DX寄存器中(端口号可以从0000到0FFFFH),然后再用IN或OUT指令来传送信息. .XLAT换码指令 格式为:XLAT OPR 或:XLAT 执行的操作:(AL)<-((BX)+(AL)) 3.有效地址送寄存器指令 LEA(Load effective address)有效地址送寄存器 LDS(Load DS with Pointer)指针送寄存器和DS LES(Load ES with Pointer)指针送寄存器和ES .LEA有效地址送寄存器 格式为:LEA REG,SRC 执行的操作:(REG)<-SRC 指令把源操作数的有效地址送到指定的寄存器中. .LDS指针送寄存器和DS指令 格式为:LDS REG,SRC 执行的操作:(REG)<-(SRC) (DS)<-(SRC+2) 把源操作数指定的4个相继字节送到由指令指定的寄存器及DS寄存器中.该指令常指定SI寄存器. .LES指针送寄存器和ES指令 格式为:LES REG,SRC 执行的操作:(REG)<-(SRC) (ES)<-(SRC+2) 把源操作数指定的4个相继字节送到由指令指定的寄存器及ES寄存器中.该指令常指定DI寄存器. 4.标志寄存器传送指令 LAHF(Load AH with flags)标志送AH SAHF(store AH into flags)AH送标志寄存器 PUSHF(push the flags)标志进栈 POPF(pop the flags)标志出栈 .LAHF标志送AH

新版汇编语言程序设计习题答案(钱晓捷主编)电子教案

新版汇编语言程序设计习题答案(钱晓捷主 编)

新版汇编语言程序设计习题答案(钱晓捷主编) 第一章汇编语言基础知识 1.1、简述计算机系统的硬件组成及各部分作用 1.2、明确下列概念或符号: 主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB 1.3、什么是汇编语言源程序、汇编程序、目标程序? 1.4、汇编语言与高级语言相比有什么优缺点? 1.5、将下列十六进制数转换为二进制和十进制表示 (1)FFH (2)0H (3)5EH (4)EFH (5)2EH (6)10H (7)1FH (8)ABH 1.6、将下列十进制数转换为BCD码表示 (1)12 (2)24 (3)68 (4)127 (5)128 (6)255 (7)1234 (8)2458 1.7、将下列BCD码转换为十进制数 (1)10010001 (2)10001001 (3)00110110 (4)10010000 (5)00001000 (6)10010111 (7)10000001 (8)00000010 1.8、将下列十进制数分别用8位二进制数的原码、反码和补码表示 (1)0 (2)-127 (3)127 (4)-57 (5)126 (6)-126 (7)-128 (8)68 1.9、完成下列二进制数的运算 (1)1011+1001 (2)1011-1001 (3)1011×1001 (4)10111000÷1001 (5)1011 ∧~1011 (8)1011 ⊕ 1001 1001(6)1011 ∨1001(7) 1.10 数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符? 1.11、计算机中有一个“01100001”编码,如果把它认为是无符号数,它是10进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符? 1.12、简述Intel 80x86系列微处理器在指令集方面的发展。 1.13、什么是DOS和ROM-BIOS? 1.14、简述PC机最低1MB主存空间的使用情况。 1.15、罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用。 1.16、什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义。

8086汇编语言指令的寻址方式有哪几类

1. 8086汇编语言指令的寻址方式有哪几类?用哪一种寻址方式的指令执行速度最快? 寄存器寻址最快 7. 下面这些指令哪些是正确的?哪些是错误的?如是错误的,请说明原因。 XCHG CS , AX ;不能修改CS MOV [BX] , [1000] ;不能在两个内存单元之间直接进行数据传送 XCHG BX , IP ;不能用名字直接访问IP PUSH CS POP CS ;不允许直接修改CS值 IN BX , DX ;输入数据必须使用累加器AL或AX MOV BYTE [BX] , 1000 ;格式错误,且超范围,应为MOV word PTR [BX],1000 MOV CS , [1000];不允许直接修改CS值 20.带参数的返回指令用在什么场合?设栈顶地址为3000H,当执行RET 0006后,SP的值为多少? 利用堆栈传递参数时使用;对于近调用SP=3008H,对于远调用SP=300AH 27.设当前SS=2010H,SP=FE00H,BX=3457H,计算当前栈顶地址为多少?当执行 PUSH BX指令后,栈顶地址和栈顶2个字节的内容分别是什么? 栈顶地址:SS:SP,物理地址为:2FF00H;PUSH 完以后栈顶地址为:SS:SP=2010:FDFEH,即物理地址为:2FEFEH,内容为:57H 34H(由低地址到高地址) B P7 5. 设(DS)=3000H,(BX)=1100H,(CS)=0062H,(S1)=0002H,(31100H)=52H, (31101H)=8FH,(31162H)=6BH,(31163H)=99H,(31103H)=F6H, (32200H)=AAH,(32201H)=B6H,(32800H)=55H,(32801H)=77H,给出下列各指令执行后AX寄存器的内容: (1) MOV AX,BX (2) MOV AX,[BX] (3) MOV AX,4200H (4) MOV AX,[2800H] (5) MOV AX,1100H[BX] (6) MOV AX,[1160H+SI] 9. 分别执行下列各指令组,写出AX的内容: (1) MOV AX,93A4H NEG AX 73A4-8c5c,e689-1977 (AX)=6C5CH (2) XY DW "AB" MOV AX,XY (AX)=4142H (3) MOV AX,2B7EH MOV CX,4DB5H ADD AX,CX (AX)=7933H (4) XA DW 0BD57H MOV AX,0FBCDH AND AX,XA (AX)=B945H (5) STC MOV BX, 0B69FH MOV AX, 43A2H SBB AX, BX

8086 汇编语言中断程序设计

汇编语言程序设计实验报告 学院:计算机科学与技术专业:计算机科学与技术班级:计科131

LEA DX,FNAME MOV CX,0 ;语句1 INT 21H JC EXIT MOV FNUM,AX MOV BX,AX ;语句2 MOV CX,100 MOV AH,40H LEA DX ,BUF INT 21H MOV BX,FNUM MOV AH,3EH INT 21H EXIT: MOV AH,4CH INT 21H CODE ENDS END START 使用相应的文本编辑器建立文件LAB7.asm,内容如上所示。 2.汇编并运行此程序后,在当前目录建立的文件名是什么?其内容是什么? 1>汇编: C:\masm> masm lab7; 2>连接: C:\masm> link lab7; 3>运行: C:\masm> lab7 3.若将语句1 改为mov cx,1,则运行情况与前面会有什么区别? 4.若将语句1 改为mov cx,2,则运行结果同上会有什么不同?并简要说明此语句的作用. 5.若将语句2 改为mov bx,1,则运行结果会有什么不同?简要说明则语句的作用. 实验二:编写0 号中断的处理程序,使得在除法溢出发生时,在屏幕中间显示字符串“divide error!”,然后返回到DOS。源程序下: assume cs:code code segment start: mov ax,cs mov ds,ax

mov si,offset do mov ax,0 mov es,ax mov di,200h mov cx,offset doend-offset do ;安装中断例程cld rep movsb mov word ptr es:[0],200h mov word ptr es:[2],0 ;设置中断向量表 mov dx,0ffffh mov bx,1 ;测试一下 div bx mov ax,4c00h int 21h do:jmp short dostart db 'divide error!' dostart: mov ax,0 mov ds,ax mov si,202h mov ax,0b800h mov es,ax mov di,160*12+60 mov cx,13 s: mov al,ds:[si] mov ah,15 mov es:[di],ax inc si inc di inc di loop s mov ax,4c00h int 21h doend:nop code ends end start

Windows汇编语言程序设计基础

第1章Windows汇编语言程序设计基础 Windows汇编语言程序分为控制台编程和图形界面编程两种,控制台编程相对简单一些。为了由浅入深,本书从控制台编程开始讲解。 读者总希望用最快的速度掌握书中的概貌,为此从一个最简单的程序开始。一些汇编语言语法也结合程序进行讲解,有些指令和语法用注解的方法说明。 1.1 第一个完整的Windows汇编语言程序 Windows汇编语言程序有自己的编程规范,它的编程规范比Visual C要简单得多,调试也很方便。更重要的是系统把重要的东西都呈现给读者,使读者更能掌握其中的本质。 用一条一条的汇编语言指令很难写出大程序,Windows汇编语言程序也是调用系统提供的API来写程序。因而,用Windows汇编语言同样可写出大程序。以下是一个最简单的Windows程序。 ;程序功能:显示一个信息框。 ;ex1.asm(e:\masm\base) ;程序名 ;编译链接方法: ;ml /c /coff ex1.asm ;link /subsystem:console ex1.obj .386 ;指明指令集 .model flat,stdcall ;程序工作模式,flat为Windows程序使用的模式(代码和数据 ;使用同一个4GB段),stdcall为API调用时右边的参数先入栈option casemap:none ;指明大小写敏感 include windows.inc include user32.inc includelib user32.lib include kernel32.inc includelib kernel32.lib .data ;数据段 szCaption db '抬头串',0 szText db 'Hello!',0 .code ;代码段 start:

STC12系列单片机的PWM输出汇编语言示例程序

STC12系列单片机的PWM输出汇编语言示例程序

对于以下程序我的理解是:equ是一个符号定义伪指令pulse_width_max equ 0f0HMOV A,#pulse_width_max 它的意思是:将pulse_width_max里的值作为数值赋到寄存器A里.MOV A,pulse_width_max 它的意思是:将pulse_width_max里的值作为地址赋到寄存器A里. 相关帖子>>>: ?我的8个PWM给你参考(2774字)coody[63次]2006-8-29 15:01:43 ;************************************************************** ?;************************************************************** ?T0interrupt: ;max 53T ? PUSH PSW ? PUSH ACC ? ?;*************************** 30T *********************************** ? MOV P1,PWM_TEMP ? ? INC PWM_DUTY ? MOV A,PWM_DUTY ? JNZ L_PWM ? MOV PWM_TEMP,PWM_TEMP1 ? SJMP L_QuitPWM ?

?L_PWM: ? CJNE A,PWM0,L_NotClearPWM0 ? SETB B_PWM0 ?L_NotClearPWM0: ? ? CJNE A,PWM1,L_NotClearPWM1 ? SETB B_PWM1 ?L_NotClearPWM1: ? ? CJNE A,PWM2,L_NotClearPWM2 ? SETB B_PWM2 ?L_NotClearPWM2: ? ? CJNE A,PWM3,L_NotClearPWM3 ? SETB B_PWM3 ?L_NotClearPWM3: ? ? CJNE A,PWM4,L_NotClearPWM4 ? SETB B_PWM4 ?L_NotClearPWM4: ? ? CJNE A,PWM5,L_NotClearPWM5 ? SETB B_PWM5 ?L_NotClearPWM5: ? ? CJNE A,PWM6,L_NotClearPWM6 ? SETB B_PWM6 ?L_NotClearPWM6: ? ? CJNE A,PWM7,L_NotClearPWM7 ? SETB B_PWM7 ?L_NotClearPWM7: ?L_QuitPWM: ?;************************************************************** ? ?L_QuitT0Interrupt: ? POP ACC ? POP PSW

8086汇编指令表

8086汇编指令表

MOV MOV DST,SRC DST≠CS、IP和imm 不影响 标志位 MOV [9AF0H],AL MOVS MOVS mem, mem MOVSB/W 不影响 标志位 字符串传送ES:DI←(DS:SI) SI←(SI)(+/-)1 DI←(DI)(+/-)1 MOVS ES:BYTE PTR[DI], DS:[SI] MUL MUL r/m8 设置CF OF S Z A P无法预 测 无符号乘法:AX←AL*r/m8 MUL CL MUL r/m16 无符号乘法:DX:AX←AX*r/m16 MUL CX NEG NEG reg/mem CF OF SF ZF AF PF 求补:取反加一 0-(DST) NEG CL NOP NOP 不影响空操作NOP NOT NOT reg/mem 不影响按位取反NOT CL OR 同AND PF SF ZF CF=OF=0 逻辑或 OR AL,0FH (不变\置1) OUT OUT imm8,AL/AX/EAX 不影响 标志位 将AL/AX/EAX输出到imm8指定端 口 OUT 0FFH,AL OUT DX,AL/AX/EAX 将AL/AX/EAX输出到DX指定的端口OUT DX,AL POP POP DST DST!=imm & CS 不影响 标志位 DST←((SP)+1,(SP)) SP←(SP)+2 POP WORD Ptr [87EAH] POPF POPF 设置所有标志位从堆栈中弹出16位标志寄存器POPF PUSH PUSH SRC 8086 SRC!=imm 不影响 标志位 SP<--(SP)-2 ((SP)+1,(SP))←(SRC) [SP循 环] PUSH WORD Ptr [87EAH] PUSHF PUSHF 不影响压栈16位标志寄存器PUSHF RCL 同SHL 同ROL 带进位循环左移 RCL AL,1 RCR 同SHL 同ROL 带进位循环右移 RCR AL,1 ROL 同SHL 移一位后符号位 改变则OF=1 循环左移: ROL AL,1 ROR 同SHL 同ROL 循环右移: ROR AL,1 REP REP String operation 不影响 标志位 CX=0则终止---CX←(CX)-1 ---串操作---SI/DI增量 REPZ REPE REPE String operation AF CF OF PF SF ZF CX=0||ZF=0则终止 ---CX←(CX)-1 ---串比较---SI/DI增量 REPNZ REPNE REPNE String operation AF CF OF PF SF ZF CX=0||ZF=1则终止--- CX←(CX)-1 ---串比较---SI/DI增量 RET RET 恢复压栈标志位 POP IP[CS] 子过程返回(Near)/(Far) RET RET imm16 子过程返回后SP←(SP)+imm16 RET 08

微机实验一 汇编语言程序调试基础训练

实验一汇编语言程序调试基础训练 实验目的: 1、学习、掌握汇编程序的编辑、编译、链接的方法 2、学习常用的DEBUG命令,掌握汇编程序调试方法 3、通过调试程序,弄清汇编指令和机器码的关系 4、弄清代码段、数据段、堆栈段中的段地址和偏移量的形成 实验内容: 1、源程序的编辑 2、源程序的编译、链接 3、汇编程序调试,完成相关数据的记录和分析 实验步骤: 一、源程序的编辑、编译、链接 1、在E盘建立L8086文件夹,将L8086文件全部拷入该目录 2、用EDIT或写字板编辑器,将例程BBADD.ASM输入计算机,以 BBADD.ASM文件名保存程序 3、用MASM.EXE工具将源程序编译成BBADD.OBJ文件 4、用LINK.EXE工具将目标文件链接成BBADD.EXE可执行文件 二、程序载入和退出 1、进入DOS命令提示符界面 2、将路径切换至:E>L8086> 3、输入DEBUG BBADD.EXE 回车,此时程序载入到DEBUG调试 状态 4、按Q回车,则退出调试状态返回到操作系统 三、程序的调试 1、在DEBUG调试状态,输入U回车,显示

此时可以看到源程序经编译后,载入到计算机内存中每一条指令所对应的机器码;可以看到指令在代码段中所处的段地址和偏移量等信息。对照源程序填写以下信息: 程序起始地址:[ :] 程序结尾地址:[ :] 用户数据段地址:[ ] 变量R0分得的地址:[ ] 变量R2分得的地址:[ ] 变量R3分得的地址:[ ] 变量R4分得的地址:[ ] 以上信息说明:U命令可以显示反汇编信息 2、输入R回车,显示以下的信息: 这是CPU内所有寄存器信息,注意观察和记录 (1)段地址信息:CS= DS= SS= ES= (2)通用寄存器信息: AX= BX= CX= DX= SI= DI= BP=

8086汇编语言上机调试步骤

8086汇编语言上机调试步骤 1、在网络课堂-微机原理与接口技术-实验指导-汇编工具下载,下载汇编工具并解压,文件夹名为“masm”。 2、用鼠标点击“masm”文件夹。进入该文件夹后将看到 MASM.EXE, LINK.EXE , DEBUG.EXE3个文件进行复制操作。 3、用鼠标点击“我的电脑”再点击D: 盘,并在 D: 盘上建立新的“ MASM”文件夹,最后将上面的3个文件全部复制到该文件夹中。(注意实验所有的文件都放在该文件夹内) 4、用文本编辑软件UltraEdit-32、WINDOWS 中的记事本或其它的文本编辑器输入汇编语言程序, 注意在最后一行的 END输入完后要按一次回车键,保存的源 文件的扩展各一定要是“.asm”如: example.asm 。(建议用记事本输入源程序,另存时,保持类型选择“所有文件”如图所示) 5、进入MS-DOS方式 ( 从开始>程序>附件>命令提示符) 或者(从程序 > 运行输入“cmd”回车,进入MS-DOS环境。

6、进入D:>MASM文件夹 7、显示MASM文件夹内所有文件“dir”命令 8、在 DOS 提示符下进行汇编、连接、动态调试等操作。 例如: 对源文件 example.asm 进行的操作

D:\MASM\MASM example.asm;汇编源程序操作 D:\MASM\LINK example.dbj;连接并生成扩展名为 .EXE 的可执行文件 D:\MASM\DEBUG example.exe;对可执行文件进行调试 9、要求掌握的调试命令(在 DEBUG 中使用的命令) a: U - 反汇编命令 用法: -U 代码段地址:起始偏移地址如:-U CS:100 b: D - 显示内存中的数据命令 用法: -D 数据段地址:存放数据的偏移地址如:-D DS:00 20 c: T - 单步执行程序命令 用法: -T 要执行的指令条数如:-T 3 d: G - 连续执行程序命令 用法: -G=代码段地址:指令的起始偏移地址指令的结束偏移地址如: -G=CS:100 106 注意: 结束地址一定要是操作码的所在地址 e: R - 查看和修改寄存器数据命令 用法: -R 回车如:-R AX f: F - 对内存单元填充数据命令 用法: -F 数据段地址:偏移首地址偏移未地址填入的数据 如: -F DS:100 120 ff g: Q - 退出”DEBUG“应用程序命令 10、应用例子 ;二进制到BCD转换(a.asm) ;将给定的一个二进制数,转换成二十进制(BCD)码 DATA SEGMENT RESULT DB 3 DUP(?) DATA ENDS CODE SEGMENT

汇编语言小程序

16进制转化为10进制STACK SEGMENT STACK'STACK' DW100H DUP(?) TOP LABEL WORD STACK ENDS DATA SEGMENT KEYBUFFER DB100 ;DB ? ;DB 100 DUP(?) DECIMAL DB 5 DUP(?) STRING1 DB'PLEASE INPUT DECIMAL DATA:$' DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA,CS:STACK START: MOV AX,DATA MOV DS,AX MOV ES,AX MOV SS,AX LEA SP,TOP LEA DX,STRING1 MOV AH,09H INT 21H MOV AH,0AH LEA DX,KEYBUFFER ;MOV AX,23456 INT 21H ;LEA SI,KEYBUFFER MOV AX,DX LEA DI,DECIMAL CALL DISPAX MOV AH,4CH MOV AL,0 INT 21H DISPAX PROC NEAR PUSH AX PUSH BX PUSH CX PUSH DX PUSH DI LEA DI,DECIMAL

CALL TRANS16TO10 MOV CX,5 LEA DI,DECIMAL+4 MOV AH,2 DISPAXD: MOV DL,[DI] ADD DL,30H DEC DI INT 21H LOOP DISPAXD POP DI POP DX POP CX POP BX POP AX RET DISPAX ENDP TRANS16TO10 PROC NEAR PUSH AX PUSH BX PUSH CX PUSH DX PUSH DI MOV BX,10 MOV CX,5 LOOP1: XOR DX,DX DIV BX MOV[DI],DX INC DI LOOP LOOP1 LEA DX,DECIMAL MOV AH,09H INT 21H POP DI POP DX POP CX POP BX POP AX RET TRANS16TO10 ENDP

相关文档
最新文档