Networks Business Online Việt Nam & International VH2

Cấu trúc bên trong của vi xử lí 8086 doc – Tài liệu text

Đăng ngày 08 November, 2022 bởi admin

Cấu trúc bên trong của vi xử lí 8086 doc

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (105.25 KB, 15 trang )

CHƯƠNG I
CẤU TRÚC BÊN TRONG CỦA VI XỬ LÝ 8086
___ oOo ___
Đây là bộ vi xử lý nổi tiếng một thời của hãng Intel, nó
được sử dụng trong nhiều lónh vực khác nhau, nhất là trong các
máy IBM PC/XT. Các bộ vi xử lý thuộc họ này sẽ còn được sử
dụng rộng rãi trong hàng chục năm nữa.

I. CẤU TẠO BÊN TRONG:
Bên trong gồm hai khối chính:
– Khối thực hiện EU (Execution Unit)
– Khối giap tiếp bus (Bus Interface Unit)
1 .Khối thực hiện EU
Ở hình 1.1 ta thấy trong khối EU ta thấy có một khối điều
khiền (Control Unit, CU) chính tại bền trong khối điều khiển
này có mạch giải mã lệnh. Mã lệnh đọc vào từ bộ nhớ đưa đến
đầu của bộ giải mã, các thông tin thu được từ đầu ra củc nó sẽ
được đưa đến mạch tạo xung điều khiển, kết quả là thu được các
dãy xung khác nhau (tùy theo mã lệnh) để điều khiển hoạt động
của các bộ phận bên trong và bên ngoài CPU. Trong khối EU
còn có khối số học và logic (Arithmetic and Logic Unit ALU)
dùng để thực hiện các thao tác khác nhau với các toán hạng cuả
lệnh. Tóm lại khi CPU hoạt động EU sẽ cung cấp thông tin về
điạ chỉ cho BIU để khối này đọc lệnh và dữ liệu, còn bản thân
nó thì giải mã lệnh và thực hiện lệnh
2. Khối phối ghép bus (Bus Interface Unit BIU)
Khối BIU có nhiệm vụ đưa ra điạ chỉ, đọc mã lệnh từ bộ
nhớ. Nói cách khác BIU chiu trách nhiệm đưa điạ chỉ ra bus và
trao đổi dữ liệu với bus.
Trong BIU còn có bộ nhớ đệm lệnh với dung lượng 4 byte
dùng để đưa các mã lệnh đọc được nằm sẵn sàng chờ EU xử lý

(trong tài liệu cuả Intel bộ lệnh này còn được gọi là hàng đợi
lệnh. Đây là một cấu trúc mới được đưa vào bộ VXL 8086/8088
cho việc Intel đưa chế độ xử lý xen kẽ liên tục dùng mã lệnh
vào ứng dụng vào trong các bộ VXL thế hệ mới.
3. Sơ đồ khối bền trongvà chức năng các khối cuả
VXL 8086:
Hàng
đợi
lệnh
Các cờ
AH AL
BH BL
CH CL
DH DL
BP
DI
SI
SP
CS
ES
SS
DS
IP
Điều khiển bus và
tạo đòa chỉ
6
5
4
3
2

1
Bus đòa chỉ
Bus dữ liệu
Các thanh
ghi đoạn
Arithmetic logic
unit (ALU)
Bus dữ liệu nội
Các bus hệ
thống
Excution Unit
(EU)
Bus Interface Unit
(BIU)

Hình 1.1:
Sơ đồ khối 8086

Bộ vi xử lý thực hiện các lệnh theo các bước sau:
– Lấy lệnh từ bộ nhớ.
– Đọc toán hạng (nếu lệnh yêu cầu).
– Thực hiện lệnh.
– Ghi kết quả.
3.1). Khối thực hiện:
Nhiệm vụ của khối thực hiện lệnh là thực hiện các lệnh của
chương trình. Nó gồm có khối số học – logic (ALU) cho phép
thực hiện các phép tính số học (+, -, *, /) và các phép logic
(AND, OR, NOT…). Trong khối thực hiện còn có một số ô nhớ
gọi là thanh ghi dùng để chứa dữ liệu cho các phép tính. Mỗi
thanh ghi giống như một ô nhớ ngoại trừ chúng được đặt tên thay

vì dùng số để chỉ đòa chỉ. EU (Execution Unit) có các thanh ghi
công dụng chung chia thành hai nhóm: nhóm thanh ghi dữ liệu
và nhóm thanh ghi chỉ số.
 Các thanh ghi dữ liệu (Data Register):
 Các thanh ghi chỉ số và con trỏ (Index & Pointer
Register):
AH AL
BH BL
CH CL
DH DL
AX (Accumulator)
BX (Base)
CX (Count)
DX (Data)
SP
BP
SI
DI
Con trỏ Stack (Stack Pointer)
Con trỏ nền (Base Pointer)
Chỉ số nguồn (Source Index)
Chỉ số đích (Destnation Index)
 Các thanh ghi đoạn (Segment Register):
 Các thanh ghi trạng thái và điều khiển (Status &
Control Register):
CS
DS
SS
ES
Đoạn mã (Code Segment)

Đoạn dữ liệu (Data Segment)
Đoạn Stack (Stack Segment)
Đoạn thêm (Extra Segment)
IP
Flag
Con trỏ lệnh (Intruction Pointer)
Cờ
 Các thanh ghi dữ liệu:
Có bốn thanh ghi dữ liệu ký hiệu lần lượt là: AX, BX, CX,
DX, được người lập trình sử dụng cho các thao tác với dữ liệu.
Mặc dù vi xử lý có thể thao tác với dữ liệu trong bộ nhớ, nhưng
một lệnh như vậy sẽ được thực hiện nhanh hơn trong thanh ghi
(cần ít chu kỳ đồng hồ hơn). Đó cũng là nguyên nhân tại sao các
bộ vi xử lý hiện đại có xu hướng nhiều thanh ghi.
Các byte cao và byte thấp trong thanh ghi được truy cập độc
lập: Byte cao của thanh ghi AX được gọi là AH và byte thấp
được gọi là AL. Tương tự như vậy cho các byte cao và byte thấp
của các thanh ghi BX, CX, DX lần lượt là BH & BL, CH & CL,
DH & DL. Nhờ điều này mà ta có nhiều thanh ghi hơn khi làm
việc với các số liệu có kích thước byte dài. Trong đa số lệnh các
thanh ghi dữ liệu được chọn tùy ý nhưng các thanh ghi này lại có
chức năng riêng cố đònh trong một số ít lệnh.
 Thanh ghi tích lũy AX (Accumulator):
Là thanh ghi được sử dụng nhiều nhất trong các lệnh số học
– logic và truyền dữ liệu bởi vì việc sử dụng thanh ghi này tạo
ra mã máy ngắn nhất.
Trong các thao tác nhân hoặc chia một trong các số hạn
tham gia phải chứa trong AH hoặc AL, các thao tác vào ra cũng
sử dụng thanh ghi AH hoặc AL.
 Thanh ghi cơ sở BX (Base):

Thanh ghi BX được dùng cho tính toán đòa chỉ trong phương
pháp đònh đòa chỉ gián tiếp.
 Thanh ghi đếm CX (Count):
Việc thực hiện các chương trình lập được thực hiện dễ dàng
nhờ thanh ghi CX, trong đó CX đóng vai trò là bộ đếm vòng lập.
Một thí dụ khác của việc sử dụng thanh ghi CX đó là lệnh REP
(Repeat) lệnh này điều khiển một lớp các lệnh chuyên về các
thao tác chuỗi. CL cũng được sử dụng là một biến đếm trong các
lệnh dòch hay quay các bit.
 Thanh ghi dữ liệu DX (Data):
DX dùng để đònh đòa chỉ gián tiếp trong các thao tác vào ra,
nó cũng còn được sử dụng chứa toán hạn, kết quả trong phép
nhân và chia.
 Thanh ghi con trỏ và chỉ số:
Các thanh ghi SP, BP, SI, DI thường trỏ tới các ô nhớ (tức là
chứa các đòa chỉ offset của các ô nhớ đó). Khác với thanh ghi
đoạn, các thanh ghi con trỏ và ngăn xếp được sử dụng trong các
thao tác số học và một số thao tác khác nhau.
 Thanh ghi con trỏ – ngăn xếp SP (Stack Pointer):
Di chuyển từ đòa chỉ cao đến đòa chỉ thấp, dùng để kết hợp
với thanh ghi đoạn Stack SS (Stack Segment)để lưu trử đòa chỉ
trở về hoặc dữ liệu vào trong ngăn xếp.
 Thanh ghi con trỏ cơ sở BP (Base Pointer):
Thanh ghi này được dùng để truy cập dữ liệu trong ngăn
xếp mà không làm thay đổi SP. Tuy nhiên, khác với SP thanh
ghi BP cũng còn được sử dụng đễ truy cập dữ liệu ở các đoạn
khác.
 Thanh ghi chỉ số nguồn SI (Source Index):
Thanh ghi SI được sử dụng để trỏ tới các ô nhớ trong đoạn
dữ liệu được đònh bởi thanh ghi đoạn dữ liệu DS (Data

Segment), có thể truy cập dễ dàng các ô nhớ liên tiếp bằng cách
tăng SI.
 Thanh ghi chỉ số đích DI (Destination Index):
Thanh ghi DI có chức năng tương tự như thanh ghi SI và
được dùng kết hợp với thanh ghi đoạn thêm ES (Extra Segment).
Cả hai DI và SI thích hợp trong các thao tác sao chép, di chuyển
hoặc so sánh các khối dữ liệu có dung lượng đến 64kB.
 Thanh ghi con trỏ lệnh IP (Intruction Pointer):
8086 không thực hiện lệnh trực tiếp trong bộ nhớ mà lệnh
được lấy ở hàng đợi lệnh có cấu tạo giống như một thanh ghi
dòch (FIFO: First In First Out: vào trước ra trước) chứa các mã
lệnh cung cấp bởi khối BIU. Thanh ghi IP chỉ đến lệnh tiếp theo
chưa được nhập vào hàng đợi lệnh và được dùng kết hợp với
thanh ghi CS. Thanh ghi IP được cập nhật mỗi khi có một lệnh
được thực hiện xong, khác với các thanh ghi khác, IP không bò
tác động trực tiếp bởi các lệnh.
 Thanh ghi cờ (Flag Register):
Thanh ghi cờ của 8086 có độ dài 16bit (2byte) byte thấp
chứa các bit trạng thái giống như trong 8085 phản ánh trạng thái
của vi xử lý, byte cao chứa 1 bit trạng thái đó là bit 11 và 3 bit
điều khiển dùng để điều khiển hoạt động của vi xử lý. Sau đây
là cấu tạo của thanh ghi cờ trong 8086:
15 8 7 0
O
D I T S Z A P C
Thanh ghi cờ của 8086
C: carry flag.
P: parity flag.
A: auxiliary flag.
Z: zero flag.

S: sign flag.
T: trap flag.
I: interrupt enable flag.
D: direction flag.
O: overflow flag.
+ Cờ nhớ CF :
Cờ nhớ CF được thiết lập khi có số nhớ từ bit MSB. Trong
phép cộng hoặc số thiếu trong phép trừ (MSB trong các lệnh
byte là bit 7 và trong các lệnh word là bit 15) cờ CF cũng bò ảnh
hưởng bởi các lệnh quay và dòch.
+ Cờ chẵn lẻ PF :
Sau các lệnh số học hoặc logic đối với các lệnh byte nếu số
lượng số ‘1’ trong byte kết quả là chẵn thì cờ PF được thiết lập
là ‘1’ ngược lại là ‘0’ nếu là lẻ, đối với các lệnh word chỉ xét
các byte thấp.
+ Cờ nhớ phụ AF:
Cờ nhớ phụ được thiết lập nếu có nhớ (cộng) hoặc có thiếu
(trừ) từ phân nửa dưới đến phân nửa trên của toán hạn (đối với
lệnh byte đó là bit 3 và đối với lệnh word là bit 7) cờ AF được
sử dụng trong các thao tác với số BCD.
+ Cờ zero ZF:
Cờ zero được thiết lập khi kết quả bằng 0.
+ Cờ dấu SF:
Cờ dấu là ‘1’ khi bit MSB của kết quả bằng ‘1’ tức là số
âm, đối với lệnh byte MSB là bit 7 và trong lệnh word là bit 15.
+ Cờ bẫy TF:
Tạo khả năng thực hiện chương trình theo từng bước, khi TF
bằng ‘1’ 8086 phát sinh ngắt loại 1 (ngắt cứng). Chương trình
DEBUG sử dụng khi thi hành lệnh T (trace) để chạy từng bước
một lệnh. Đầu tiên DEBUG thiết lập cờ TF rồi mới chuyển điều

khiển cho lệnh đó. Sau khi lệnh được thi hành vi xử lý sẽ phát
sinh một ngắt do TF được lập DEBUG sử dụng chính phục vụ
ngắt này để lấy quyền điều khiển từ vi xử lý.
+ Cờ ngắt IF:
Cờ ngắt được sử dụng để điều khiển các ngắt phần cứng
bên ngoài, nếu cờ này được thiết lập các ngắt phần cứng có thể
ngắt 8086. Khi xóa IF, các ngắt bên ngoài không còn tác dụng
nửa (bò che). Thực ra vẫn còn một ngắt cứng không che được
NMI (Non Maskable Interrupt).
Trước khi vi xử lý trao quyền điều khiển cho một phục ngắt
nó xóa cả IF và TF, như vậy phục ngắt đó sẽ không bò ngắt. Tất
nhiên một phục vụ ngắt có thể đổi cờ để cho phép ngắt khi nó
đang thi hành.
+ Cờ tràn OF:
Cờ tràn là ‘1’ khi có hiện tượng tràn và ngược lại nó bằng
‘0’. Hiện tượng tràn cho thấy một sự thật là phạm vi biểu diễn
các số trong máy tính là có giới hạn.
Phạm vi biểu diển các số có dấu trong một word từ –32768
đến +32767 và trong một byte từ –126 đến +127.
Đối với các số không dấu từ 0 đến 65535 cho một word và
từ 0 đến 255 cho một byte. Nếu kết quả của một phép tính vượt
ra ngoài phạm vi này thì hiện tượng tràn sẽ xảy ra và kết quả
nhận được bò cắt bớt sẽ không phải là kết quả đúng.
+ Cờ điều khiển DF:
Là một trong ba cờ điều khiển dùng điều khiển các thao tác
của vi xử lý công dụng của DF là dòch hướng cho các thao tác
chuỗi, các thao tác này được thực hiện bởi hai thanh ghi chỉ số
SI & DI, nội dung của hai thanh ghi này sẽ tự động tăng lên khi
DF = 0 và giảm xuống khi DF =1.
3.2). Khối giao tiếp (BIU):

Khối giao tiếp làm đơn giản việc liên lạc giữa EU và bộ nhớ
hoặc các vi mạch vào ra. Nó có nhiệm vụ gởi các đòa chỉ, số liệu
và tín hiệu điều khiển vào các bus, BUI & EU liên hệ với nhau
bằng các bus nội bộ, khi EU đang thi hành một lệnh, BIU nạp 6
byte mã lệnh tiếp theo vào và đặt chúng vào hàng đợi lệnh, mục
đích của việc này là làm tăng tốc độ của vi xử lý. Nếu EU cần
liên lạc với bộ nhớ hay thiết bò ngoại vi, BIU sẽ treo các lệnh
nhận trước và thực hiện thực hiện các thao tác cần thiết. BIU
cấu tạo gồm các thanh ghi đoạn và con trỏ lệnh dùng để chứa
đòa chỉ các ô nhớ.
a). Các thanh ghi đoạn:
Được dùng để lưu trử đòa chỉ của các lệnh và dữ liệu trong
bộ nhớ, vi xử lý dựa trên các giá trò này để truy cập bộ nhớ.
Bộ nhớ là tập hợp các byte ô nhớ, mỗi byte có một đòa chỉ
xác đònh bắt đầu từ 0. 8086 gán cho mỗi ô nhớ một đòa chỉ vật lý
20 bit. Như vậy, nó có thể đònh đòa chỉ đến byte (tương đương
1MB) ô nhớ, các byte đầu tiên của bộ nhớ có đòa chỉ như sau:
0000 0000 0000 0000 0000
0000 0000 0000 0000 0001
0000 0000 0000 0000 0010
0000 0000 0000 0000 0011
0000 0000 0000 0000 0100
Để đơn giản, các đòa chỉ trên thường được biểu diển bằng số
thập lục phân như sau:
00000H
00001H
00002H
………… H
và cứ tiếp tục cho đến giá trò lớn nhất là FFFFFH
Do các đòa chỉ quá lớn (20 bit) không thể chứa trong một

thanh ghi của 8086 (16 bit) nên 8086 chia bộ nhớ thành các đoạn
bộ nhớ (Memory Segment).
Một đoạn bộ nhớ là một khối gồm 2
16
(64K) ô nhớ liên tiếp
nhau, mỗi đoạn được xác đònh bằng một đòa chỉ đoạn bắt đầu từ
đòa chỉ 0, đòa chỉ đoạn là một số 16 bit nên đòa chỉ đoạn lớn nhất
là FFFF. Bên trong mỗi đoạn số ô nhớ được xác đònh bằng đòa
chỉ tương đối (offset), đó là số byte tính từ đầu đoạn, với một
đoạn 64K thì offset cũng là một số 16 bit, byte đầu tiên trong
đoạn có offset bằng 0 và byte cuối cùng bằng FFFF.
Một ô nhớ có thể được xác đònh bằng đòa chỉ đoạn:đòa chỉ
tương đối trong đoạn (segment:offset) và được gọi là đòa chỉ
logic.
Thí dụ: ô nhớ A4FB: 4872 có đòa chỉ đoạn là A4FB và đòa
chỉ offset là 4872. Để tìm đòa chỉ vật lý của ô nhớ trước tiên ta
dòch đòa chỉ đoạn về bên trái 4 bit và sau đó cộng với đòa chỉ
offset, như vậy đòa chỉ vật lý của ô nhớ A4FB:4872 được tính
như sau: A4FB0
4872
A9822
b). Sắp xếp đoạn:
Trong bộ nhớ đoạn 0 bắt đầu từ đòa chỉ 0000:0000 = 00000
và kết thúc ở 0000:FFFF = 0FFFF, đoạn 1 bắt đầu từ đòa chỉ
0001:0000 = 00010 và kết thúc ở đòa chỉ 0001:FFFF = 1000F.
Như vậy, có rất nhiều sự chồng nhau giữa các đoạn. Các đoạn
bắt đầu từ các đòa chỉ cách nhau 16byte và đòa chỉ đầu của mỗi
đoạn luôn kết thúc bằng các số 0. 16byte được gọi là một khúc
(Paragraph), các đòa chỉ chia hết cho 16 ( các đòa chỉ kết thúc
bằng 0) là các biên giới khúc (Paragraph Boundary)

c). Các đoạn của chương trình:
Mỗi đoạn chương trình ngôn ngữ máy bao gồm các lệnh và
dữ liệu, còn một vùng đặc biệt trong RAM gọi là ngăn xếp
(stack). Mã lệnh, dữ liệu và ngăn xếp của chương trình được nạp
vào các đoạn bộ nhớ khác nhau đó là đoạn mã (code segment),
đoạn dữ liệu (data segment), đoạn ngăn xếp (stack segment).
Để theo dõi các đoạn khác nhau của chương trình 8086 được
cung cấp 4 thanh ghi đoạn để chứa các đòa chỉ đoạn, các thanh
ghi CS, DS, SS lần lược chứa các đòa chỉ đoạn mã, đoạn dữ liệu,
và đoạn ngăn xếp. Nếu chương trình muốn truy cập đến một dữ
liệu thứ hai nó có thể sử dụng thanh ghi đoạn thêm ES (extra
segment).
Một chương trình không phải bao giờ cũng cần chiếm hết
một đoạn 64KB, do đặc điểm chồng nhau giữa các đoạn cho
phép các đoạn của một chương trình nhỏ hơn 64KB có thể đặt
gần lại với nhau. Tại một thời điểm, chỉ có các ô nhớ được đònh
đòa chỉ bởi 4 thanh ghi đoạn mới có thể truy cập, nghóa là chỉ có
4 đoạn bộ nhớ là tác động. Tuy nhiên nội dung của các thanh
ghi đoạn có thể thay đổi bởi chương trình để truy cập đến các
đoạn khác nhau.

d). Hàng đợi lệnh:
Như ta đã biết, để tăng tốc độ vi xử lý khối BIU tiếp nhận các
lệnh và đưa vào hàng đợi lệnh (Queue) trong khi đó khối EU
đang thi hành lệnh. Hàng đợi lệnh có thể nhận 6 byte mã lệnh,
các lệnh của 8086 có độ dài từ 1 đến 6 byte, nếu lệnh chưa vào
đầy đủ trong hàng đợi lệnh thì khối EU sẽ chờ cho đến khi lệnh
nạp hết vào hàng đợi lệnh.
( trong tài liệu của Intel bộ lệnh này còn được gọi là hàng đợilệnh. Đây là một cấu trúc mới được đưa vào bộ VXL 8086 / 8088 cho việc Intel đưa chính sách xử lý xen kẽ liên tục dùng mã lệnhvào ứng dụng vào trong những bộ VXL thế hệ mới. 3. Sơ đồ khối bền trongvà tính năng những khối cuảVXL 8086 : HàngđợilệnhCác cờAH ALBH BLCH CLDH DLBPDISISPCSESSSDSIPĐiều khiển bus vàtạo đòa chỉBus đòa chỉBus dữ liệuCác thanhghi đoạnArithmetic logicunit ( ALU ) Bus dữ liệu nộiCác bus hệthốngExcution Unit ( EU ) Bus Interface Unit ( BIU ) Hình 1.1 : Sơ đồ khối 8086B ộ vi xử lý triển khai những lệnh theo những bước sau : – Lấy lệnh từ bộ nhớ. – Đọc toán hạng ( nếu lệnh nhu yếu ). – Thực hiện lệnh. – Ghi hiệu quả. 3.1 ). Khối triển khai : Nhiệm vụ của khối triển khai lệnh là thực thi những lệnh củachương trình. Nó gồm có khối số học – logic ( ALU ) cho phépthực hiện những phép tính số học ( +, -, *, / ) và những phép logic ( AND, OR, NOT … ). Trong khối thực thi còn có 1 số ít ô nhớgọi là thanh ghi dùng để chứa tài liệu cho những phép tính. Mỗithanh ghi giống như một ô nhớ ngoại trừ chúng được đặt tên thayvì dùng số để chỉ đòa chỉ. EU ( Execution Unit ) có những thanh ghicông dụng chung chia thành hai nhóm : nhóm thanh ghi dữ liệuvà nhóm thanh ghi chỉ số.  Các thanh ghi tài liệu ( Data Register ) :  Các thanh ghi chỉ số và con trỏ ( Index và PointerRegister ) : AH ALBH BLCH CLDH DLAX ( Accumulator ) BX ( Base ) CX ( Count ) DX ( Data ) SPBPSIDICon trỏ Stack ( Stack Pointer ) Con trỏ nền ( Base Pointer ) Chỉ số nguồn ( Source Index ) Chỉ số đích ( Destnation Index )  Các thanh ghi đoạn ( Segment Register ) :  Các thanh ghi trạng thái và điều khiển và tinh chỉnh ( Status và Control Register ) : CSDSSSESĐoạn mã ( Code Segment ) Đoạn dữ liệu ( Data Segment ) Đoạn Stack ( Stack Segment ) Đoạn thêm ( Extra Segment ) IPFlagCon trỏ lệnh ( Intruction Pointer ) Cờ  Các thanh ghi tài liệu : Có bốn thanh ghi tài liệu ký hiệu lần lượt là : AX, BX, CX, DX, được người lập trình sử dụng cho những thao tác với tài liệu. Mặc dù vi xử lý có thể thao tác với tài liệu trong bộ nhớ, nhưngmột lệnh như vậy sẽ được triển khai nhanh hơn trong thanh ghi ( cần ít chu kỳ luân hồi đồng hồ đeo tay hơn ). Đó cũng là nguyên do tại sao cácbộ vi xử lý tân tiến có khuynh hướng nhiều thanh ghi. Các byte cao và byte thấp trong thanh ghi được truy vấn độclập : Byte cao của thanh ghi AX được gọi là AH và byte thấpđược gọi là AL. Tương tự như vậy cho những byte cao và byte thấpcủa những thanh ghi BX, CX, DX lần lượt là Bảo hành và BL, CH và CL, DH và DL. Nhờ điều này mà ta có nhiều thanh ghi hơn khi làmviệc với những số liệu có kích cỡ byte dài. Trong hầu hết lệnh cácthanh ghi tài liệu được chọn tùy ý nhưng những thanh ghi này lại cóchức năng riêng cố đònh trong một số ít ít lệnh.  Thanh ghi tích góp AX ( Accumulator ) : Là thanh ghi được sử dụng nhiều nhất trong những lệnh số học – logic và truyền dữ liệu chính do việc sử dụng thanh ghi này tạora mã máy ngắn nhất. Trong những thao tác nhân hoặc chia một trong những số hạntham gia phải chứa trong AH hoặc AL, những thao tác vào ra cũngsử dụng thanh ghi AH hoặc AL.  Thanh ghi cơ sở BX ( Base ) : Thanh ghi BX được dùng cho đo lường và thống kê đòa chỉ trong phươngpháp đònh đòa chỉ gián tiếp.  Thanh ghi đếm CX ( Count ) : Việc triển khai những chương trình lập được thực thi dễ dàngnhờ thanh ghi CX, trong đó CX đóng vai trò là bộ đếm vòng lập. Một thí dụ khác của việc sử dụng thanh ghi CX đó là lệnh REP ( Repeat ) lệnh này điều khiển và tinh chỉnh một lớp những lệnh chuyên về cácthao tác chuỗi. CL cũng được sử dụng là một biến đếm trong cáclệnh dòch hay quay những bit.  Thanh ghi tài liệu DX ( Data ) : DX dùng để đònh đòa chỉ gián tiếp trong những thao tác vào ra, nó cũng còn được sử dụng chứa toán hạn, hiệu quả trong phépnhân và chia.  Thanh ghi con trỏ và chỉ số : Các thanh ghi SP, BP, SI, DI thường trỏ tới những ô nhớ ( tức làchứa những đòa chỉ offset của những ô nhớ đó ). Khác với thanh ghiđoạn, những thanh ghi con trỏ và ngăn xếp được sử dụng trong cácthao tác số học và 1 số ít thao tác khác nhau.  Thanh ghi con trỏ – ngăn xếp SP ( Stack Pointer ) : Di chuyển từ đòa chỉ cao đến đòa chỉ thấp, dùng để kết hợpvới thanh ghi đoạn Stack SS ( Stack Segment ) để lưu trử đòa chỉtrở về hoặc tài liệu vào trong ngăn xếp.  Thanh ghi con trỏ cơ sở BP ( Base Pointer ) : Thanh ghi này được dùng để truy vấn tài liệu trong ngănxếp mà không làm biến hóa SP. Tuy nhiên, khác với SP thanhghi BP cũng còn được sử dụng đễ truy vấn tài liệu ở những đoạnkhác.  Thanh ghi chỉ số nguồn SI ( Source Index ) : Thanh ghi SI được sử dụng để trỏ tới những ô nhớ trong đoạndữ liệu được đònh bởi thanh ghi đoạn tài liệu DS ( DataSegment ), hoàn toàn có thể truy vấn thuận tiện những ô nhớ liên tục bằng cáchtăng SI.  Thanh ghi chỉ số đích DI ( Destination Index ) : Thanh ghi DI có tính năng tương tự như như thanh ghi SI vàđược dùng phối hợp với thanh ghi đoạn thêm ES ( Extra Segment ). Cả hai DI và SI thích hợp trong những thao tác sao chép, di chuyểnhoặc so sánh những khối tài liệu có dung tích đến 64 kB.  Thanh ghi con trỏ lệnh IP ( Intruction Pointer ) : 8086 không triển khai lệnh trực tiếp trong bộ nhớ mà lệnhđược lấy ở hàng đợi lệnh có cấu trúc giống như một thanh ghidòch ( FIFO : First In First Out : vào trước ra trước ) chứa những mãlệnh cung ứng bởi khối BIU. Thanh ghi IP chỉ đến lệnh tiếp theochưa được nhập vào hàng đợi lệnh và được dùng tích hợp vớithanh ghi CS. Thanh ghi IP được update mỗi khi có một lệnhđược thực thi xong, khác với những thanh ghi khác, IP không bòtác động trực tiếp bởi những lệnh.  Thanh ghi cờ ( Flag Register ) : Thanh ghi cờ của 8086 có độ dài 16 bit ( 2 byte ) byte thấpchứa những bit trạng thái giống như trong 8085 phản ánh trạng tháicủa vi xử lý, byte cao chứa 1 bit trạng thái đó là bit 11 và 3 bitđiều khiển dùng để điều khiển và tinh chỉnh hoạt động giải trí của vi xử lý. Sau đâylà cấu trúc của thanh ghi cờ trong 8086 : 15 8 7 0D I T S Z A P CThanh ghi cờ của 8086C : carry flag. P : parity flag. A : auxiliary flag. Z : zero flag. S : sign flag. T : trap flag. I : interrupt enable flag. D : direction flag. O : overflow flag. + Cờ nhớ CF : Cờ nhớ CF được thiết lập khi có số nhớ từ bit MSB. Trongphép cộng hoặc số thiếu trong phép trừ ( MSB trong những lệnhbyte là bit 7 và trong những lệnh word là bit 15 ) cờ CF cũng bò ảnhhưởng bởi những lệnh quay và dòch. + Cờ chẵn lẻ PF : Sau những lệnh số học hoặc logic so với những lệnh byte nếu sốlượng số ‘ 1 ’ trong byte hiệu quả là chẵn thì cờ PF được thiết lậplà ‘ 1 ’ ngược lại là ‘ 0 ’ nếu là lẻ, so với những lệnh word chỉ xétcác byte thấp. + Cờ nhớ phụ AF : Cờ nhớ phụ được thiết lập nếu có nhớ ( cộng ) hoặc có thiếu ( trừ ) từ phân nửa dưới đến phân nửa trên của toán hạn ( đối vớilệnh byte đó là bit 3 và so với lệnh word là bit 7 ) cờ AF đượcsử dụng trong những thao tác với số BCD. + Cờ zero ZF : Cờ zero được thiết lập khi tác dụng bằng 0. + Cờ dấu SF : Cờ dấu là ‘ 1 ’ khi bit MSB của hiệu quả bằng ‘ 1 ’ tức là sốâm, so với lệnh byte MSB là bit 7 và trong lệnh word là bit 15. + Cờ bẫy TF : Tạo năng lực thực thi chương trình theo từng bước, khi TFbằng ‘ 1 ’ 8086 phát sinh ngắt loại 1 ( ngắt cứng ). Chương trìnhDEBUG sử dụng khi thi hành lệnh T ( trace ) để chạy từng bướcmột lệnh. Đầu tiên DEBUG thiết lập cờ TF rồi mới chuyển điềukhiển cho lệnh đó. Sau khi lệnh được thi hành vi xử lý sẽ phátsinh một ngắt do TF được lập DEBUG sử dụng chính phục vụngắt này để lấy quyền tinh chỉnh và điều khiển từ vi xử lý. + Cờ ngắt IF : Cờ ngắt được sử dụng để điều khiển và tinh chỉnh những ngắt phần cứngbên ngoài, nếu cờ này được thiết lập những ngắt phần cứng có thểngắt 8086. Khi xóa IF, những ngắt bên ngoài không còn tác dụngnửa ( bò che ). Thực ra vẫn còn một ngắt cứng không che đượcNMI ( Non Maskable Interrupt ). Trước khi vi xử lý trao quyền điều khiển và tinh chỉnh cho một phục ngắtnó xóa cả IF và TF, như vậy phục ngắt đó sẽ không bò ngắt. Tấtnhiên một Giao hàng ngắt hoàn toàn có thể đổi cờ để cho phép ngắt khi nóđang thi hành. + Cờ tràn OF : Cờ tràn là ‘ 1 ’ khi có hiện tượng kỳ lạ tràn và ngược lại nó bằng ‘ 0 ’. Hiện tượng tràn cho thấy một thực sự là khoanh vùng phạm vi biểu diễncác số trong máy tính là có số lượng giới hạn. Phạm vi biểu diển những số có dấu trong một word từ – 32768 đến + 32767 và trong một byte từ – 126 đến + 127. Đối với những số không dấu từ 0 đến 65535 cho một word vàtừ 0 đến 255 cho một byte. Nếu hiệu quả của một phép tính vượtra ngoài khoanh vùng phạm vi này thì hiện tượng kỳ lạ tràn sẽ xảy ra và kết quảnhận được bò cắt bớt sẽ không phải là hiệu quả đúng. + Cờ điều khiển và tinh chỉnh DF : Là một trong ba cờ điều khiển và tinh chỉnh dùng điều khiển và tinh chỉnh những thao táccủa vi xử lý tác dụng của DF là dòch hướng cho những thao tácchuỗi, những thao tác này được thực thi bởi hai thanh ghi chỉ sốSI và DI, nội dung của hai thanh ghi này sẽ tự động hóa tăng lên khiDF = 0 và giảm xuống khi DF = 1.3.2 ). Khối tiếp xúc ( BIU ) : Khối tiếp xúc làm đơn thuần việc liên lạc giữa EU và bộ nhớhoặc những vi mạch vào ra. Nó có trách nhiệm gởi những đòa chỉ, số liệuvà tín hiệu tinh chỉnh và điều khiển vào những bus, BUI và EU liên hệ với nhaubằng những bus nội bộ, khi EU đang thi hành một lệnh, BIU nạp 6 byte mã lệnh tiếp theo vào và đặt chúng vào hàng đợi lệnh, mụcđích của việc này là làm tăng vận tốc của vi xử lý. Nếu EU cầnliên lạc với bộ nhớ hay thiết bò ngoại vi, BIU sẽ treo những lệnhnhận trước và thực thi triển khai những thao tác thiết yếu. BIUcấu tạo gồm những thanh ghi đoạn và con trỏ lệnh dùng để chứađòa chỉ những ô nhớ. a ). Các thanh ghi đoạn : Được dùng để lưu trử đòa chỉ của những lệnh và tài liệu trongbộ nhớ, vi xử lý dựa trên những giá trò này để truy vấn bộ nhớ. Bộ nhớ là tập hợp những byte ô nhớ, mỗi byte có một đòa chỉxác đònh mở màn từ 0. 8086 gán cho mỗi ô nhớ một đòa chỉ vật lý20 bit. Như vậy, nó hoàn toàn có thể đònh đòa chỉ đến byte ( tương đương1MB ) ô nhớ, những byte tiên phong của bộ nhớ có đòa chỉ như sau : 0000 0000 0000 0000 00000000 0000 0000 0000 00010000 0000 0000 0000 00100000 0000 0000 0000 00110000 0000 0000 0000 0100 Để đơn thuần, những đòa chỉ trên thường được biểu diển bằng sốthập lục phân như sau : 00000H00001 H00002H … … … … Hvà cứ liên tục cho đến giá trò lớn nhất là FFFFFHDo những đòa chỉ quá lớn ( 20 bit ) không hề chứa trong mộtthanh ghi của 8086 ( 16 bit ) nên 8086 chia bộ nhớ thành những đoạnbộ nhớ ( Memory Segment ). Một đoạn bộ nhớ là một khối gồm 216 ( 64K ) ô nhớ liên tiếpnhau, mỗi đoạn được xác đònh bằng một đòa chỉ đoạn mở màn từđòa chỉ 0, đòa chỉ đoạn là 1 số ít 16 bit nên đòa chỉ đoạn lớn nhấtlà FFFF. Bên trong mỗi đoạn số ô nhớ được xác đònh bằng đòachỉ tương đối ( offset ), đó là số byte tính từ đầu đoạn, với mộtđoạn 64K thì offset cũng là 1 số ít 16 bit, byte tiên phong trongđoạn có offset bằng 0 và byte sau cuối bằng FFFF.Một ô nhớ hoàn toàn có thể được xác đònh bằng đòa chỉ đoạn : đòa chỉtương đối trong đoạn ( segment : offset ) và được gọi là đòa chỉlogic. Thí dụ : ô nhớ A4FB : 4872 có đòa chỉ đoạn là A4FB và đòachỉ offset là 4872. Để tìm đòa chỉ vật lý của ô nhớ thứ nhất tadòch đòa chỉ đoạn về bên trái 4 bit và sau đó cộng với đòa chỉoffset, như vậy đòa chỉ vật lý của ô nhớ A4FB : 4872 được tínhnhư sau : A4FB04872A9822b ). Sắp xếp đoạn : Trong bộ nhớ đoạn 0 mở màn từ đòa chỉ 0000 : 0000 = 00000 và kết thúc ở 0000 : FFFF = 0FFFF, đoạn 1 khởi đầu từ đòa chỉ0001 : 0000 = 00010 và kết thúc ở đòa chỉ 0001 : FFFF = 1000F. Như vậy, có rất nhiều sự chồng nhau giữa những đoạn. Các đoạnbắt đầu từ những đòa chỉ cách nhau 16 byte và đòa chỉ đầu của mỗiđoạn luôn kết thúc bằng những số 0. 16 byte được gọi là một khúc ( Paragraph ), những đòa chỉ chia hết cho 16 ( những đòa chỉ kết thúcbằng 0 ) là những biên giới khúc ( Paragraph Boundary ) c ). Các đoạn của chương trình : Mỗi đoạn chương trình ngôn từ máy gồm có những lệnh vàdữ liệu, còn một vùng đặc biệt quan trọng trong RAM gọi là ngăn xếp ( stack ). Mã lệnh, tài liệu và ngăn xếp của chương trình được nạpvào những đoạn bộ nhớ khác nhau đó là đoạn mã ( code segment ), đoạn tài liệu ( data segment ), đoạn ngăn xếp ( stack segment ). Để theo dõi những đoạn khác nhau của chương trình 8086 đượccung cấp 4 thanh ghi đoạn để chứa những đòa chỉ đoạn, những thanhghi CS, DS, SS lần lược chứa những đòa chỉ đoạn mã, đoạn tài liệu, và đoạn ngăn xếp. Nếu chương trình muốn truy vấn đến một dữliệu thứ hai nó hoàn toàn có thể sử dụng thanh ghi đoạn thêm ES ( extrasegment ). Một chương trình không phải khi nào cũng cần chiếm hếtmột đoạn 64KB, do đặc thù chồng nhau giữa những đoạn chophép những đoạn của một chương trình nhỏ hơn 64KB hoàn toàn có thể đặtgần lại với nhau. Tại một thời gian, chỉ có những ô nhớ được đònhđòa chỉ bởi 4 thanh ghi đoạn mới hoàn toàn có thể truy vấn, nghóa là chỉ có4 đoạn bộ nhớ là ảnh hưởng tác động. Tuy nhiên nội dung của những thanhghi đoạn hoàn toàn có thể đổi khác bởi chương trình để truy vấn đến cácđoạn khác nhau. d ). Hàng đợi lệnh : Như ta đã biết, để tăng vận tốc vi xử lý khối BIU đảm nhiệm cáclệnh và đưa vào hàng đợi lệnh ( Queue ) trong khi đó khối EUđang thi hành lệnh. Hàng đợi lệnh hoàn toàn có thể nhận 6 byte mã lệnh, những lệnh của 8086 có độ dài từ 1 đến 6 byte, nếu lệnh chưa vàođầy đủ trong hàng đợi lệnh thì khối EU sẽ chờ cho đến khi lệnhnạp hết vào hàng đợi lệnh .

Source: https://vh2.com.vn
Category : Tin Học