Ôn tập vi xử lý

Khi học về lập trình hợp ngữ thì chủ yếu thao tác trên các thanh ghi và bộ nhớ stack, nên các anh chị phải nắm rõ chức năng của từng thanh ghi để có thể hiểu mà sử dụng các lệnh

doc25 trang | Chia sẻ: longpd | Lượt xem: 2205 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Ôn tập vi xử lý, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Ôn tập Vi Xử Lý Phần 1 – Lý thuyết Khi học về lập trình hợp ngữ thì chủ yếu thao tác trên các thanh ghi và bộ nhớ stack, nên các anh chị phải nắm rõ chức năng của từng thanh ghi để có thể hiểu mà sử dụng các lệnh  1. Tập thanh ghi: 4 thanh ghi đoạn: CS (Code Segment): thanh ghi đoạn lệnh DS (Data Segment): thanh ghi đoạn dữ liệu SS (Stack Segment): thanh ghi đoạn ngăn xếp ES (Extra Segment): thanh ghi đoạn dữ liệu phụ 3 thanh ghi con trỏ: IP (Instruction Pointer): thanh ghi con trỏ lệnh SP (Stack Pointer): con trỏ ngăn xếp BP (Base Pointer): thanh ghi con trỏ cơ sở 4 thanh ghi dữ liệu: AX (Accumulator): thanh chứa - thanh ghi tích lũy BX (Base): thanh ghi cơ sở CX (Count): thanh ghi đếm DX (Data): thanh ghi dữ liệu Mỗi thanh ghi này đều có thể được chia ra thành 2 nửa có khả năng sử dụng độc lập. Thanh ghi cờ  2. Các bước lập trình Các bước lập trình hợp ngữ cũng giống như các bước lập trình trong ngôn ngữ bậc cao, cũng gồm những bước như sau: Bước 1: Phát biểu bài toán Bước 2: Xây dựng thuật giải Bước 3: Viết mã chương trình Bước 4: Dịch và sửa lỗi cú pháp Bước 5: Chạy thử và hiệu chỉnh chương trình  3. Cấu trúc chung của lập trình hợp ngữ .MODEL small .STACK 100h .DATA ; Khai báo các biến ở đây .CODE ; Các lệnh chương trình ghi ở đây END    4. Các lệnh cơ bản trong lập trình hợp ngữ 4.1. Lệnh MOV - Cú pháp: MOV , - Ý nghĩa: lệnh này dùng để sao chép dữ liệu từ toán hạng nguồn vào toán hạng đích - Lưu ý: toán hạng đích phải đủ để nhận dữ liệu không được sao chép hằng vào thanh ghi đoạn 2 toán hạng không đồng thời là vùng nhớ hoặc thanh ghi đoạn - Ví dụ: MOV AX,vungnho ; AX , - Ý nghĩa: lệnh này dùng để hoán chuyển dữ liệu của 2 toán hạng đích và nguồn. - Lưu ý: hai toán hạng có thể là thanh ghi hay vùng nhớ cùng kích thước không được sao chép hằng vào thanh ghi đoạn 2 toán hạng không đồng thời là vùng nhớ - Ví dụ: XCHG AX,vungnho ; AX vungnho XCHG AL,BH ; AL BH 4.3. Lệnh ADD và SUB - Cú pháp: ADD , SUB , - Ý nghĩa: 2 lệnh này dùng để thêm/bớt nội dung trong toán hạng đích với toán hạng nguồn - Lưu ý: kết quả chứa trong toán hạng đích toán hạng nguồn có thể là hằng, thanh ghi hoặc vùng nhớ toán hạng đích có thể là thanh ghi hoặc vùng nhớ 2 toán hạng không đồng thời là vùng nhớ 2 toán hạng có thể có dấu (bù 2) hoặc không dấu - Ví dụ: ADD AX,BX ; AX DEC - Ý nghĩa: 2 lệnh này dùng để tăng/giảm nội dung trong toán hạng đích - Lưu ý: toán hạng đích có thể là thanh ghi hoặc vùng nhớ - Ví dụ: INC AX ; AX - Ý nghĩa: lệnh này dùng để đổi dấu (dương thành âm, âm thành dương) của toán hạng đích - Lưu ý: toán hạng đích có thể là thanh ghi hoặc vùng nhớ nếu toán hạn đích là giá trị âm nhỏ nhất (-128 hay -32768) thì sau lệnh này sẽ không thay đổi giá trị - Ví dụ: NEG AX ; AX <- (-AX) NEG vungnho ; vungnho <- (-vungnho) MOV AX,-32768 ; AX <- (-32768) NEG AX ; AX <- (-32768) MOV DL,-128 ; DL <- (-128) NEG DL ; DL <- (-128) 4.6. Lệnh INT 21h - Lệnh này là một trình con của hệ điều hành. Trình con này có nhiều chức năng khác nhau tuỳ theo trị của thanh ghi AH. Sau đây là một số chức năng (hàm) thông dụng. AH = 1 : ngắt 21h thực hiện nhập một ký tự từ bàn phím, mã ASCII ký tự nhận được (hoặc 0 nếu là phím điều khiển) chứa trong AL. Nếu ký tự thông thường được gõ vào thì sẽ hiển thị trên màn hình. Lệnh viết như sau: MOV AH,1 ; chọn chức năng 1 INT 21h ; chờ người sử dụng nhập vào 1 ký tự và lưu vào AL AH = 2 : ngắt 21h thực hiện xuất ký tự chứa trong thanh ghi DL ra màn hình MOV AH,2 ; chọn chức năng 2 MOV DL,'A' ; chọn ký tự hiển thị là A INT 21h ; hiển thị ký tự AH = 9 : ngắt 21h thực hiện xuất chuỗi ký tự có địa chỉ ô chứa trong thanh ghi DX (và địa chỉ đoạn chứa trong DS) ra màn hình. Chú ý chuỗi ký tự phải kết thúc bằng ký tự $ .Data MSG DB "Chuoi can hien thi$" .Code ; Dua dia chi doan du lieu vao DS MOV AX,@Data MOV DS,AX ; Hien thi cau chao MOV AH,9 LEA DX,AX INT 21h AH = 4Ch : ngắt 21h thực hiện việc kết thúc chương trình và trả điều khiển về cho hệ điều hành. Lệnh viết như sau: MOV AH,4Ch ; chon chuc nang 4Ch INT 21h ; ket thuc chuong trinh 4.6. Lệnh INT 10h Lệnh này dùng để xoá màn hình MOV AX,3 INT 10h Bài tập Phần 1 - Bài tập của phần này gồm có 2 phần: Lý thuyết Bài tập  I. Lý thuyết 1. Tính địa chỉ tuyệt đối tương ứng với địa chỉ tương đối A51h:CD90h Gỉai: - Địa chỉ tương đối có dạng: : - Muốn đổi từ địa chỉ tương đối sang địa chỉ tuyệt đối thì ta áp dụng công thức: Địa chỉ tuyệt đối = địa chỉ đoạn * F + địa chỉ ô Vậy địa chỉ tuyệt đối = A51h * 16 + CD90h = A510h + CD90h = 172A0h 2. Tính địa chỉ tương đối tương ứng với địa chỉ tương đối A25h:CD09h Gỉai: tương tự cách tính trên. 3. Với địa chỉ tuyệt đối 4A37Bh, hãy tính: a. Địa chỉ ô tương ứng với đoạn 40FFh b. Địa chỉ đoạn tương ứng với ô 123Bh Gỉai: Cũng áp dụng công thức trên a. địa chỉ ô = địa chỉ tuyệt đối - địa chỉ đoạn * 16 = 4A37Bh - 40FFh * 16 = 938Bh b. địa chỉ đoạn = (địa chỉ tuyệt đối - địa chỉ ô) / 16 = (4A37Bh - 123Bh) / 16 = 4914h 4. Gỉa sử các byte ở địa chỉ từ 0 đến 4 có trị (thập lục) là AB, CD, EF, 01, 23. Hãy cho biết trị của từ ở địa chỉ 2 Gỉai: Ta có hình ảnh sau:  Như vậy ta kết luận ở địa chỉ 2 ta có nội dung là EF 5. Gỉa sử chuỗi "12A45" được lưu trữ trong bộ nhớ từ địa chỉ 0 đến 4. Hãy cho biết nội dung của vùng nhớ (dạng thập lục) từ địa chỉ 0 đến 4 Gỉai: tương tự như câu 4: 05h, 04h, 0Ah, 02h, 01h 6. Viết lệnh định nghĩa từ WORDV có trị -1 Gỉai: WORDV DB FFd 7. Viết lệnh định nghĩa hằng MSG có trị là 'DAY LÀ THONG BAO' Gỉai: MSG EQU 'DAY LA THONG BAO' 8. Viết nhóm lệnh tương đương với các lệnh gán như sau: a. B = B - A - 1 b. A = B c. A = 10 - A d. A = B - A * 2 e. C = 2 * B - 3 * A Gỉai: a. B = B - A - 1 MOV AX,A ; AX <- A DEC AX ; AX <- A - 1 SUB B,AX ; B <- B - A - 1  b. A = B MOV AX,B ; AX <- B MOV A,AX ; A <- B  c. A = 10 - A NEG A ; A <- (-A) ADD A,10 ; A <- (-A) + 10   d. A = B - A * 2 MOV AX,A ; AX <- A NEG AX ; AX <- (-A) SUB AX,AX ; AX <- (-A) - A ADD AX,B ; AX <- (-2A) + B MOV A,AX ; A <- (-2A) + B  e. C = 2 * B - 3 * A MOV AX,B ; AX <- B ADD AX,AX ; AX <- B + B MOV C,AX ; C <- 2B MOV AX,A ; AX <- A ADD AX,AX ; AX <- A + A ADD AX,AX ; AX <- 2A + A NEG AX ; AX <- (-3A) ADD C,AX ; C <- 2B + (-3A)     II. Thực hành 1. Viết chương trình hiển thị câu chào sau trên màn hình: Cha`o ba.n! Gỉai: Code: ;================================================================================= ; Noi dung: Viet chuong trinh hien thi cau chao sau len man hinh: Cha`o ba.n! ; Ten file: bt01.asm ; Ngay tao: 17/03/2009 - 00:15 ;================================================================================= .model small .stack 100h .data    ; Khai bao cac bien tai day    CR EQU 13    LF EQU 10    Mess db 'Cha`o ba.n!',CR,LF,'$' .code main proc    ; Dua du lieu vao thanh ghi DS    mov ax,@data    mov ds,ax    ; Hien thi Mess    mov ah,9    lea dx,Mess    int 21h    ; Exit to DOS    mov ah,4ch    int 21h main endp end main 2. Viết chương trình hiển thị 3 câu chào sau trên màn hình: Hello, world! Hello, solar system! Hello, universe! Gỉai: Code: ;================================================================================= ; Noi dung: Viết chương trình hiển thị 3 câu chào sau trên màn hình: ;              Hello, world! ;              Hello, solar system! ;              Hello, universe! ; Ten file: bt02.asm ; Ngay tao: 17/03/2009 - 00:25 ;================================================================================= .model small .stack 100h .data    ; Khai bao cac bien tai day    CR EQU 13    LF EQU 10    Mess db CR,LF,'Hello, world!'               db CR,LF,'Hello, solar system!'               db CR,LF,'Hello, universe!$' .code main proc    ; Dua du lieu vao thanh ghi DS    mov ax,@data    mov ds,ax    ; Hien thi Mess    mov ah,9    lea dx,Mess    int 21h    ; Exit to DOS    mov ah,4ch    int 21h main endp end main 3. Viết chương trình nhập một ký tự và hiển thị ở dòng kế tiếp. Kết quả có dạng: Hay nhap mot ky tu: A Ky tu da nhap : A Code: ;=================================================================================== ; Noi dung: Viet chuong trinh nhap vao mot ky tu va hien thi lai o dong tiep theo. Ket qua co dang: ;      Hay nhap mot ky tu: A ;      Ky tu da nhap    : A ; Ten file: bt03.asm ; Ngay tao: 17/03/2009 - 00:31 ; Huong dan: ;   1. Khai bao du lieu: ;      TBao1 db 13,10,'Hay nhap mot ky tu: $' ;      Tbao2 db 13,10,'Ky tu da nhap        : $' ;   2. Thuat giai: ;      - Hien thi TBao1 ;      - Nhap mot ky tu ;      - Dua gia tri vao thanh ghi bl ;      - Hien thi TBao2 ;      - Hien thi KyTu ;=================================================================================== .model small .stack 100h .data    ; Khai bao cac bien tai day    CR EQU 13    LF EQU 10    TBao1 db CR,LF,'Hay nhap mot ky tu: $'    TBao2 db CR,LF,'Ky tu da nhap    : $' .code main proc    ; Dua du lieu vao thanh ghi DS    mov ax,@data    mov ds,ax    ; Hien thi TBao1    mov ah,9    lea dx,TBao1    int 21h    ; Nhap vao mot ky tu    mov ah,1    int 21h    ; Dua ky tu vao thanh ghi bl    mov bl,al    ; Hien thi TBao2    mov ah,9    lea dx,TBao2    int 21h    ; Hien thi KyTu    mov ah,2    mov dl,bl    int 21h    ; Exit to DOS    mov ah,4ch    int 21h main endp end main 4. Viết chương trình nhập một ký tự và hiển thị ký tự đứng trước, đứng sau theo thứ tự mã ASCII. Kết quả có dạng: Hay nhap mot ky tu: B Ky tu dung truoc : A Ky tu dung sau : C Gỉai Code: ;=================================================================================== ; Noi dung: Viet chuong trinh nhap vao mot ky tu va hien thi ky tu dung truoc, ; dung sau theo thu tu ma ASCII. Ket qua co dang: ;   Hay nhap mot ky tu: B ;   Ky tu dung truoc  : A ;      Ky tu dung sau    : C ; Ten file: bt04.asm ; Ngay tao: 17/03/2009 - 08:37 ; Huong dan: ;   1. Khai bao du lieu: ;      TBao1 db 13,10,'Hay nhap mot ky tu: $' ;      Tbao2 db 13,10,'Ky tu dung truoc  : $' ;      TBao3 db 13,10,'Ky tu dung sau    : $' ;   2. Thuat giai: ;      - Hien thi TBao1 ;      - Nhap mot ky tu ;      - Dua gia tri vao thanh ghi bl ;      - Hien thi TBao2 ;      - Giam 1 gia tri ;      - Hien thi TBao3 ;      - Tang 2 gia tri ;=================================================================================== .model small .stack 100h .data    ; Khai bao cac bien tai day    CR EQU 13    LF EQU 10    TBao1 db CR,LF,'Hay nhap mot ky tu: $'    TBao2 db CR,LF,'Ky tu dung truoc  : $'    TBao3 db CR,LF,'Ky tu dung sau    : $' .code main proc    ; Dua du lieu vao thanh ghi DS    mov ax,@data    mov ds,ax    ; Hien thi TBao1    mov ah,9    lea dx,TBao1    int 21h    ; Nhap vao mot ky tu    mov ah,1    int 21h    ; Dua ky tu vao thanh ghi bl    mov bl,al    ; Hien thi TBao2    mov ah,9    lea dx,TBao2    int 21h    ; Hien ky tu va giam 1 gia tri    mov ah,2    mov dl,bl    dec dl    int 21h    ; Hien thi TBao3    mov ah,9    lea dx,TBao3    int 21h    ; Hien ky tu va tang 1 gia tri    mov ah,2    mov dl,bl    inc dl    int 21h    ; Exit to DOS    mov ah,4ch    int 21h main endp end main 5. Viết chương trình nhập hai ký tự và hiển thị ký tự thứ ba có mã ASCII là tổng của mã hai ký tự đã nhập. Kết quả có dạng: Nhap ky tu thu nhat: 2 Nhap ky tu thu hai : 3 Ky tu tong : e Phần 2 – Lý Thuyết Trong phần này các anh chị sẽ nhận biết kiểu định vị của địa chỉ và giới thiệu các thanh ghi cờ Kiểu định vị hoặc chế độ định vị (addressing mode) là cách thức xác định dữ liệu trong lệnh. Có tất cả 7 chế độ định vị chuẩn, đó là Thanh ghi (register) Lấy ngay (immediate) Trực tiếp (direct) Gían tiếp thanh ghi (register indirect) Chỉ số (indexed) Cơ sở (based) Chỉ số cơ sở (based indexed)  1. Định vị thanh ghi - Trong chế độ định vị thanh ghi, các tác tố là thanh ghi, tức dữ liệu chứa trong thanh ghi. Khi tác tố là thanh ghi thì lệnh sẽ được thực hiện nhanh hơn vì không mất thời gian truy cập vào bộ nhớ. - Ví dụ: MOV AL,BL ; AL : DS:[7000h] - Cả hai cách ghi đều như nhau, cách thứ nhất nếu không ghi địa chỉ đoạn nào thì ngầm hiểu là lấy đoạn DS làm chuẩn 4. Định vị gián tiếp thanh ghi - Trong chế độ định vị này, địa chỉ ô của các tác tố chứa trong các thanh ghi BX, BP, SI hoặc DI (địa chỉ đoạn chứa trong DS tương ứng với BX, SI, DI và SS tương ứng với BP). Nói cách khác địa chỉ tác tố không chứa trực tiếp trong lệnh mà gián tiếp thông qua một thanh ghi. - Ví dụ lệnh sau trừ nội dung DX với vùng nhớ có địa chỉ chứa trong DS:BX SUB DX,[BX] SUB DX,BX ; lưu ý này trên sẽ khác với lệnh trên - Vì lệnh đầu tiên lấy dữ liệu từ vùng nhớ (định vị gián tiếp thanh ghi), lệnh thứ hai lấy dữ liệu từ thanh ghi (định vị thanh ghi). - Gỉa sử ta có nội dung các thanh ghi và vùng nhớ như sau: Thanh ghi  Nội dung thanh ghi  Nội dung vùng nhớ  Địa chỉ vùng nhớ   BX  1000  1BAC  DS:1000   SI  2000  20FE  DS:2000   DI  3000  031D  DS:3000   Với các lệnh sau, ta được kết quả sau: MOV BX,[BX] ; BX <- 1BAC MOV CX,[SI] ; CX <- 20FE MOV BX,[AX] ; tác tố nguồn không hợp lệ ADD [SI],[DI] ; lệnh này không hợp lệ MOV DL,[DI] ; DL <- 1D 5. Định vị chỉ số - Trong chế độ này, dữ liệu chứa trong bộ nhớ, và địa chỉ tác tố là tổng của nội dung thanh ghi chỉ số SI và DI (là một địa chỉ) với một số bù 2 có dấu 8 hoặc 16 bit gọi là độ dời (offset) - Ví dụ: MOV AX,[SI+4] MOV AX,[4+SI] MOV 4[SI],AX MOV [SI]4,AX ADD [DI-6],CX ADD [-6+DI],CX ADD -6[DI],CX ADD [DI]-6,CX MOV [SI+ACCOUNT],AX MOV [ACCOUNT+SI],AX MOV ACCOUNT[SI],AX MOV [SI]ACCOUNT,AX MOV ACCOUNT+SI,AX 6. Định vị cơ sở Cách định vị này tương tự như cách định vị chỉ số, nhưng dùng thanh ghi cơ sở BX hoặc BP thay vì DI hoặc SI. Gỉa sử ta có nội dung các thanh ghi và vùng nhớ như sau: Thanh ghi  Nội dung thanh ghi  Nội dung vùng nhớ  Địa chỉ vùng nhớ   BX  2  1084  DS:0002   SI  4  2BAC  DS:0004   DI  1     - Với khai báo: ALPHA DW 0123h,0456h,0789h,0ABCh và với các lệnh sau, ta có kết quả: MOV AX,[ALPHA+BX] ; AX <- 0456h MOV BX,[BX+2] ; BX <- 2BACh MOV CX,ALPHA[SI] ; CX <- 0789h MOV AX,-2[SI] ; AX <- 1084h MOV BX,[ALPHA+3+DI] ; BX <- 0789h ADD BX,[ALPHA+AX] ; thanh ghi nguồn không hợp lệ 7. Định vị chỉ số cơ sở - Trong cách định vị này, địa chỉ tác tố được xác định bằng cách cộng nội dung thanh ghi cơ sở với nội dung thanh ghi chỉ số và có thể cộng với một trị có dấu 8 hoặc 16 bit - Ví dụ: MOV AX,[BX+DI] MOV [BX+SI+2],AX MOV AX,[BX+SI+2] MOV AX,[SI+BX+2] MOV AX,[SI][BX+2] MOV AX,[BX][SI+2] MOV AX,2[BX][SI] MOV AX,W[BX][SI] ADD AL,[BP+DI-50] MOV ES:[BX+DI+4],AX  Thanh ghi cờ - Thanh ghi cờ là một trong các thanh ghi của CPU dài 16 hoặc 32 bit (từ CPU 80386 về sau) ghi nhận các thông tin điều khiển, trạng thái của CPU và kết quả thực hiện lệnh sau cùng. - Mỗi bit gọi là một cờ, cờ có thể có trị 1 (gọi là đặt - set) hoặc 0 (gọi là xoá - clear), 16 bit phần cao dùng cho chế độ bảo vệ, 16 bit phần thấp gồm 2 nhóm: cờ điều khiển và cờ trạng thái. Có 2 dạng cờ: Cờ điều khiển: IF (interrupt enable flag), DF (direction flag) và TF (trap flag) Cờ trạng thái: CF (carry flag), PF (parity flag), AF (auxiliary flag), ZF (zero flag), SF (sign flag), OF (overflow flag), NT (nested flag), IOPL (input/output privilege level) - Vị trí của các cờ như sau: 15  14  13  12  11  10  9  8  7  6  5  4  3  2  1  0    NT  IOPL  OF  DF  IF  TF  SF  ZF   AF   PF   CF   - Sau đây là phần diễn giải một số cờ thông dụng. Cờ  Đặt  Xoá  Ý nghĩa   OF  OV  NV  Tràn/Không tràn (Overflow/Not overflow)   DF  DN  UP  Xuống/Lên (Down/Up)   IF  EI  DI  Cho ngắt/Cấm ngắt (Enable/Disable)   SF  NG  PL  Âm/Dương (Negative/Plus)   ZF  ZR  NZ  Không/Khác không (Zero/Not zero)   AF  AC  NA  Gởi phụ/Không gởi phụ (Axiliary Carry/Not Axiliary Carry)   PF  PE  PO  Chẵn/Lẻ (Parity Even/Parity Odd)   CF  CY  NC  Gởi/Không gởi (Carry Yes/Not Carry)   a. Cờ gởi (CF) - Có trị 1 khi có nhớ hoặc mượn từ bit MSB (bit cao nhất của dãy số nhị phân), tức bit 7 hoặc 15 hặc 31 trong phép tính cộng và trừ (còn gọi là tràn không dấu), ngược lại là 0. Cờ này có thể thay đổi theo lệnh dịch và quay. Nói cách khác, cờ CF có 2 giá trị: CF = 1 , khi thực hiện phép tính cộng hay trừ không dấu mà có tràn CF = 0 , ngược lại - Ngoài ra ta còn có 3 lệnh liên quan đến cờ CF Lệnh CLC (Clear Carry flag): xoá 0 CF Lệnh STC (Set Carry flag): đặt 1 cho CF Lệnh CMC (Complement Carry flag): đảo trị của CF - Ví dụ: CLC MOV BL,0FEh ; BL <- 0FEh , CF = 0 ADD BL,1 ; BL <- FFh , CF = 0 ADD BL,1 ; BL <- 00h , CF = 0 b. Cờ chẵn lẻ (PF) - Có trị 1 khi byte thấp của kết quả là chẵn, có trị 0 khi byte thấp là lẻ. Một từ gọi là chẵn lẽ khi số bit 1 của từ đó là chẵn/lẽ. - Ví dụ sau khi thực hiện một lệnh cho kết quả chứa trong AL là 11010010b (bốn bit 1) thì PF = 1 c. Cờ gởi phụ (AF) - Có trị 1 khi có nhớ hoặc mượn từ bit 3 (tức là nhớ hoặc mượn từ 4 bit thấp), ngược lại là 0. Cờ này thường dùng trong các lệnh với số BCD - Ví dụ: MOV BL,0FEh ; BL <- 0FEh ADD BL,1 ; BL <- FFh , AF = 0 ADD BL,1 ; BL <- 00h , AF = 1 d. Cờ không (ZF) - Có trị 1 khi kết quả là 0, trị 0 khi kết quả khác 0 - Ví dụ: MOV AL,1 ; AL <- 1 SUB AL,1 ; AL <- 0 , ZF = 1 ADD AL,1 ; AL <- 1 , ZF = 0 e. Cờ dấu (SF) - Có trị 1 khi kết quả là âm, trị 0 khi kết quả là dương (MSB là 0) - Ví dụ: MOV AL,0 ; AL = 0 SUB AL,1 ; AL = -1 ; SF = 1 ADD AL,1 ; AL = 0 ; SF = 0 f. Cờ tràn (OF) - Cờ tràn có trị 1 khi xảy ra trạng thái tràn tức thì (có dấu) của kết quả vượt quá phạm vi giá trị cho phép. Ví dụ một từ 2 bytes có thể chứa trị từ khoảng từ -32768 đến 32767 (có dấu), nếu vượt quá phạm vi này sẽ xảy ra tràn, lúc đó cờ OF = 1 - Ví dụ: MOV AL,1 ; AL <- 1 SUB AL,1 ; AL <- 0 , ZF = 1 ADD AL,1 ; AL <- 1 , ZF = 0 Bài tập Phần 2 Phần bài tập của chương này thì gồm có 2 phần: - Phần xác định dạng chế độ định vị của các câu lệnh - Các bài tập xác định cờ  Phần 1: Xác định các chế độ định vị của các câu lệnh 1. Xác định kiểu định vị nguồn và đích trong các lệnh sau: a. MOV AX,BX ; b. MOV AH,7 ; c. MOV [DI],AL ; d. MOV AX,[BP] ; e. MOV AL,[SI+6] Gỉai: a. MOV AX,BX ; định vị thanh ghi b. MOV AH,7 ; định vị lấy ngay c. MOV [DI],AL ; định vị gián tiếp thanh ghi d. MOV AX,[BP] ; định vị gián tiếp thanh ghi e. MOV AL,[SI+6] ; định vị chỉ số 2. Gỉa sử AX = 0500h ; BX = 1000h ; SI = 1500h ; DI = 2000h ; [DS] = 0100h ; [DS] = 0150h ; [DS] = 0200h ; [DS] = 0250h ; [DS] = 0300h và BETA là biến từ nằm ở địa chỉ ô 1000h. Trong các lệnh sau đây, nếu hợp lệ (nếu không hợp lệ, giải thích tại sao), hãy cho biết địa chỉ ô của các tác tố nguồn hoặc thanh ghi và kết quả lưu trong tác tố đích. a. MOV DL,SI ; b. MOV DI,[DI] ; c. ADD AX,[SI] ; d. SUB BX,[DI] ; e. LEA BX,BETA[BX] ; f. ADD [SI],[DI] ; g. ADD BH,[BL] ; h. ADD AH,[SI] ; i. MOV AX,[BX+DI+BETA] Gỉai: a. MOV DL,SI ; DL <- 1500h b. MOV DI,[DI] ; DI <- 0200h c. ADD AX,[SI] ; AX <- 0650h d. SUB BX,[DI] ; BX <- 0800h e. LEA BX,BETA[BX] ; BX <- 0100h f. ADD [SI],[DI] ; không hợp lệ (vì 2 tác tố đều là vùng nhớ) g. ADD BH,[BL] ; BH <- 10h h. ADD AH,[SI] ; AH <- 0155h i. MOV AX,[BX+DI+BETA] ; AX <- 3100h 3. Xác định chế độ địa chỉ và tính địa chỉ vật lý của các câu lệnh sau: CS = DCBAh ; SS = EA98h ; BP = SP = 0957h DS = ES = DDE8h ; BX = 1234h ; SI = DI = 3412h a. MOV [1234h],AL b. MOV BL,[BX+DI] c. MOV [BP+15],BL d. MOV BH,[DI+10] e. MOV AL,[BP+DI] + 110b Giaỉ: a. MOV [1234h],AL ; định vị trực tiếp địa chỉ tuyết đối = DS * 16 + 1234h = DF0B4h b. MOV BL,[BX+DI] ; định vị chỉ số cơ sở địa chỉ tuyết đối = DS * 16 + BX + DI = E24C6h c. MOV [BP+15],BL ; định vị cơ sở địa chỉ tuyết đối = DS * 16 + BP + Fh = DE7F6h d. MOV BH,[DI+10] ; định vị chỉ số địa chỉ tuyết đối = DS * 16 + DI + Ah = E129Ch e. MOV AL,[BP+DI]+110b