Bài 1: Làm quen với trình dich hợp ngữ ASSEMBLER và cách gọi ngắt trong ASM
Mục đích:
• Biết cách chuyển một chương trình hợp ngữ (Assembler) ra dạng mã máy, qua đó giúp sinh viên hiểu rõ hơn cơ chế hoạt động của các lệnh, cách trao đổi số liệu.
• Biết cách nhập chương trình vào bộ nhớ và chạy chương trình
113 trang |
Chia sẻ: vietpd | Lượt xem: 5103 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Bài giảng Kỹ thuật vi xử lý, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ĐỀ CƯƠNG CHI TIẾT MÔN HỌC
Tên môn học: Kỹ thuật vi xử lý.
Phân bố thời gian:
45 tiết ( 3 trình ).
Môn tiên quyết:
Kỹ thuật vi xử lý là môn học quan trọng trong việc nghiên cứu phần cứng máy tính. Các kiến thức môn học cần có để phục vụ cho môn học này bao gồm:
Kỹ thuật điện tử số (2 mức: 0, 1, bộ nhớ).
Kiến trúc máy tính.
Đối tượng học:
Sinh viên ngành Kỹ thuật máy tính, Điều khiển tự động, Điện tử viễn thông, Kỹ thuật điện tử, Công nghệ thông tin.
Mô tả môn học:
Trang bị cho sinh viên những kiến thức cơ bản nhất có tính chất hệ thống liên quan đến kỹ thuật VXL. Trang bị cho sinh viên khả năng tư duy trong nghiên cứu, tiếp cận với các hệ VXL tiên tiến, hiện đại hơn. Ngoài ra học phần còn giúp cho sinh viên dễ dàng hơn trong việc xây dựng các chương trình điều khiển thiết bị ghép nối với máy tính.
Nội dụng cụ thể bao gồm các phần cơ bản sau:
Khái niệm, cấu trúc và nguyên lý hoạt động của một hệ VXL.
Bộ VXL 8088/8086.
Các ghép nối cơ bản của 8088/8086 với thiết bị ngoại vi.
Các phương thức đièu khiển vào ra dữ liệu trong kỹ thuật VXL.
Nhiệm vụ của sinh viên:
Sinh viên phải tham gia đủ trên 80% giờ trên lớp. Phải hoàn thành đầy đủ bài tập và các bài thực hành trong chương trình.
Nội dung giảng dậy
Chương 1 Hệ vi xử lý
Vi xử lý là gì?
Các thế hệ của bộ vi xử lý
Thế hệ 1 (1971 đến 1973)
Thế hệ 2 (1974 đến 1977)
Thế hệ 3 (1978 đến 1982)
Thế hệ 4 (1983 đến nay)
Giới thiệu cấu trúc của hệ vi xử lý
CPU - Bộ xử lý trung tâm
Bộ nhớ bán dẫn (ROM, RAM)
Hệ thống vào ra (I/O)
Liên hệ giữa các khối
Chương 2 Bộ vi xử lý 8088 của Intel
Giới thiệu hoạt động của bộ vi xử lý 8088
Giới thiệu chung
Cấu trúc và hoạt động của bộ VXL 8088
Chế độ địa chỉ của 8088
Chế độ địa chỉ thanh ghi
Chế độ địa chỉ tức thì
Chế độ địa chỉ tực tiếp
Chế độ địa chỉ gián tiếp qua thanh ghi
Chế độ địa chỉ tương đối cơ sở
Chế độ địa chỉ tương đối chỉ số
Chế độ địa chỉ tương đối chỉ số cơ sở
Mô tả tập lệnh của 8088
Nhóm lệnh chuyển dữ liệu
Nhóm lệnh số học
Nhóm lệnh logic, dịch và quay
Nhóm lệnh so sánh
Nhóm lệnh rẽ nhánh (nhảy), lặp
Nhóm các lệnh đặc biệt
Chương 3 Lập trình bằng hợp ngữ cho 8088 trên máy tính IBM PC và các máy tương thích IBM PC
Giới thiệu chung
Giới thiệu khung chương trình
Cấu trúc của một lệnh hợp ngữ
Dữ liệu cho chương trình hợp ngữ
Biến và hằng
Khung của một chương trình hợp ngữ
Cách tạo và cho chạy một chương trình hợp ngữ
Các cấu trúc lập trình cơ bản trong assembly
Cấu trúc tuần tự
Cấu trúc lựa chọn
Cấu trúc lặp
Truyền tham số
Một số ngắt của DOS và của BIOS
Chương 4 Ghép 8088 với bộ nhớ và tổ chức vào ra dữ liệu
Giới thiệu tín hiệu chân của 8088 và các mạch phụ trợ
Bảy nhóm tín hiệu
Phân kênh để tách thông tin và đệm bus
Mạch tạo xung nhịp 8284
Mạch điều khiển bus 8288
Biều đồ thời gian của các lệnh đọc/ghi
Phối ghép 8088 với bộ nhớ
Bộ nhớ bán dẫn
Giải mã địa chỉ cho bộ nhớ
Phối ghép 8088 với bộ nhớ
Phối ghép 8088 với thiết bị ngoại vi
Các kiểu phối ghép vào ra
Giải mã địa chỉ cho thiết vị vào/ra
Các mạch cổng đơn giản
Mạch phối ghép vào/ra song song lập trình được PPI 8255
Chương 5 Vào ra dữ liệu bằng cách thăm dò
Giới thiệu chung về các phương pháp điều khiển vào/ra dữ liệu
Vào/ra dữ liệu bằng cách thăm dò trạng thái sẵn sàng của thiết bị ngoại vi
Chương 6 Ngắt và xử lý ngắt trong hệ vi xử lý 8088
Sự cần thiết phải ngắt CPU
Ngắt trong vi xử lý 8088
Các loại ngắt trong hệ 8088
Đáp ứng của CPU khi có yêu cầu ngắt
Xử lý ưu tiên ngắt
Mạch điều khiển ngắt ưu tiên PPI 8259A
Chương 7 Vào ra dữ liệu bằng DMA
Nguyên tắc của việc trao đổi dữ liệu với thiết bị ngoại vi bằng cách thâm nhập trực tiếp vào bộ nhớ (DMA)
DMAC 8237-5 trong hệ vi xử lý 8088
Tín hiệu HOLD và HLDA trong CPU 8088
Mạch DMAC 8237-5 của Intel
Nội dung các bài thực hành ( gồm có 6 bài thực hành - 5tiết/bài)
Bài 1: Làm quen với trình dich hợp ngữ ASSEMBLER và cách gọi ngắt trong ASM
Mục đích:
Biết cách chuyển một chương trình hợp ngữ (Assembler) ra dạng mã máy, qua đó giúp sinh viên hiểu rõ hơn cơ chế hoạt động của các lệnh, cách trao đổi số liệu.
Biết cách nhập chương trình vào bộ nhớ và chạy chương trình
Hiểu, biết cách gọi và truyền tham số khi gọi ngắt (Chủ yếu là ngát 21h của DOS, với các hàm hiển thị và nhập ký tự. Nhằm phục vụ cho việc kiểm tra kết qua cho những bài thí nghiệm sau)
Bài 2: Trao đổi dữ liệu và thực hiện các phép tính số học.
Mục đích:
Giúp sinh viên làm quen với việc nạp và trao đổi dữ liệu giữa các thanh ghi, giữa thanh ghi với bộ nhớ và các phép tính số học cơ bản. Qua đó thấy được ý nghĩa và tác dụng của các thanh ghi và bộ nhớ trong quá trình lưu trữ và xử lý số liệu.
Bài 3: So sánh và kiểm tra dữ liệu.
Mục đích:
Giúp sinh viên làm quen với các cấu trúc lập trình cơ bản bằng hợp ngữ.
Biết cách so sánh và kiểm tra dữ liệu thông qua các cờ.
Bài 4: Các thao tác Logic.
Mục đích:
Giúp sinh viên làm quen với các cấu trúc lập trình cơ bản bằng hợp ngữ.
Giúp sinh viên khảo sát các thao tác đại số BOOLEAN theo phương thức mà chúng tác động trên các thanh ghi và dữ liệu trong bộ nhớ.
Bài 5: Chương trình con và truyền tham số.
Mục đích:
Giúp sinh viên làm quen với các cấu trúc lập trình cơ bản bằng hợp ngữ.
Giúp sinh viên làm quen với cấu trúc lập trình theo chương trình con, truyền tham số cho chương trình con.
Bài 6: Vào ra dữ liệu với các cổng.
Mục đích:
Giúp sinh viên làm quen với các kiểu giao tiếp giữa vi xử lý với các thiết bị ngoài.
Biết cách lập trình đặt các chế độ làm việc cho các cổng giao tiếp của bộ điều khiển ghép nối.
Tài liệu tham khảo:
Văn Thế Minh, Kỹ thuật vi xử lý, NXB Giáo Dục, 1997.
Đỗ Xuân Thụ & Hồ Khánh Lâm, Kỹ thuật vi xử lý và máy vi tính, ...
Đỗ Xuân Tiến, Kỹ thuật lập trình điều khiển hệ thống, ...
Lê Văn Doanh & Phạm Khắc Chương, Kỹ thuật vi điều khiển, ...
Biên Dịch: Nguyễn Minh San - Hoàng Đức Hải, Cẩm nang lập trình hệ thống, ...
Nguyễn Đình Việt, Kiến trúc máy tính, ...
Trần Quang Vinh, Cấu trúc máy vi tính, NXB Giáo Dục, 1998.
Ytha Yu & Charles Marut, Lập trình hợp ngữ (Assembly) và máy vi tính IBM-PC, NXB Giáo Dục, 1996.
PTS. Nguyễn Quang Tấn, Vũ Thanh Hiền, Lập trình với Hợp Ngữ, NXB Thống Kê, 1997.
Trần Bá Thái, Điều khiển và ghép nối các thiết bị ngoại vi, NXB thống kê, 1987.
Computer Organization and Assembly Language Programming For IBM PC and Compatibles Michael Thorne - The Benjamin-Cummings Publishing Company, Inc. 1991.
Microprocessors and microcomputer-based system design Mohamed Rafiquzzaman - CRC Press, 1995.
NỘI DUNG CHI TIẾT
Chương 1
HỆ VI XỬ LÝ
Vi xử lý là gì?
Ngày nay xu hướng số hoá mọi dạng tín hiệu càng được khẳng định rõ nét trong nhiều lĩnh vực: Điện tử, tin học, viễn thông, công nghệ thông tin, kỹ thuật điều khiển tự động ... vì tín hiệu số có cấu trúc đơn giản, dễ tính toán, xử lý và gia công ...
Việc xử lý, tính toán, điều khiển được thực hiện chủ yếu trên các máy tính PC (Hay hệ vi xử lý nói chung). Các hệ vi xử lý này thường được ghép nối và giao tiếp với nhiều thiết bị ngoại vi khác nhau. Mỗi thiết bị làm việc ở môi trường khác nhau cũng như chức năng, nhiệm vụ khác nhau.
Môi trường của thiết bị có thể là:
Điện, điện tử.
Cơ, cơ điện.
Quang điện tử, ...
Chức năng, nhiệm vụ của thiết bị như:
Thông tin vô tuyến, hữu tuyến.
Kỹ thuật viễn thông.
Robốt, máy công cụ, dây truyền sản xuất tự động.
Các hệ thống làm nhiệm vụ xử lý và điều khiển nói chung luôn có một thành phần làm nhiệm vụ xử lý được chế tạo bằng công nghệ vi điện tử với độ tích hợp cao và rất cao, chúng thường được gọi là các bộ vi xử lý (MicroProcessor). Các bộ vi xử lý hoạt động (làm việc) theo chương trình, dùng để tính toán và điều khiển mọi hoạt động của hệ thống.
Việc xây dựng các chương trình điều khiển các thiết bị cho chúng làm việc chính xác, đồng bộ là rất phức tạp. Các hệ thống càng thông minh thì vai trò của bộ vi xử lý càng quan trọng.
Các thế hệ của bộ vi xử lý
Thế hệ 1 (1971 đến 1973)
Năm 1971 Intel cho ra đời bộ vi xử lý (VXL) 4004 (dùng cho các máy tính cầm tay) được chế tạo bằng công nghệ PMOS. Đây là bộ VXL 4 bit dữ liệu, 12 bit địa chỉ và có 2250 Transitor.
Tiếp theo, Intel cho ra đời bộ VXL 4040 là bộ VXL được cải tiến từ VXL 4004. Trong thời gian này, Intel tiếp tục cho ra đời bộ VXL 8008 là bộ VXL 8 bit dữ liệu.
Đặc điểm của các bộ vi xử lý trong khoảng thời gian này là:
Tốc độ thực hiện: 10 ¸ 60 (ms/lệnh).
Tần số đồng hồ: fCLK = 0,1 ¸ 0,8 MHz.
Cần nhiều mạch phụ trợ để tạo nên một hệ vi xử lý hoàn chỉnh.
Thế hệ 2 (1974 đến 1977)
Trong thời gian này Intel lần lượt cho ra đời bộ VXL 8080, 8085. Motorola có các bộ VXL 6800, 6809. Zilog có bộ VXL Z80 và Signetics có bộ VXL 6520.
Đặc điểm của các bộ vi xử lý trong khoảng thời gian này là:
Tập lệnh phong phú hơn.
Là các bộ vi xử lý 8 bit dữ liệu.
Khả năng phân biệt địa chỉ bộ nhớ lên tới 64 KB (16 bit địa chỉ).
Khả năng phân biệt địa cổng là 256 cổng cho thiết bị ngoại vi (sử dụng 8 bit để đánh địa chỉ cho các cổng).
Tốc độ 1 ¸ 8 (ms/lệnh).
Tần số đồng hồ: fCLK = 1 ¸ 5 MHz.
Ứng dụng:
Điều khiển các hệ thống trong công nghiệp.
Chế tạo các máy tính 8 bit như Apple II.
Thế hệ 3 (1978 đến 1982)
Trong khoảng thời gian này Intel lần lượt cho ra đời các bộ VXL 8086, 8088, 80186, 80286. Motorola có các bộ VXL 68000, 68010
Đặc điểm của các bộ vi xử lý trong khoảng thời gian này là:
Là các bộ vi xử lý 16 bit dữ liệu.
Tập lệnh đầy đủ hơn.
Khả năng phân biệt địa chỉ bộ nhớ từ 1 MB đến 16 MB.
Khả năng phân biệt địa chỉ cổng là 64 K cổng cho thiết bị ngoại vi (đối với các bộ VXL của Intel).
Tốc độ 0,1 ¸ 1 (ms/lệnh).
Tần số đồng hồ: fCLK = 5 ¸ 10 MHz.
Ứng dụng:
Chế tạo các máy tính IBM PC, PC/XT, PC/AT và máy tính Macintosh của Apple.
Thế hệ 4 (1983 đến nay)
Trong thời gian này Intel thể hiện sức mạnh vượt trội các hãng khác trong việc chế tạo bộ vi xử lý. Intel liện tục cho ra đời các bộ VXL 80386, 80486 là các bộ VXL 32 bit dữ liệu, có bên trong đơn vị quản lý bộ nhớ (MMU) cho phép chạy trong chế độ bộ nhớ ảo và đa nhiệm. Tiếp theo là các bộ VXL Pentium, Pentium II, Pentium III, Pentium IV là các bộ VXL 64 bit dữ liệu.
Motorola có các bộ VXL 68020, 68030, 68040, 68060.
Đặc điểm của các bộ vi xử lý trong khoảng thời gian này là:
32 bit địa chỉ, nên trong chế độ thực thì khả năng phân biệt địa chỉ bộ nhớ là 4 GB. Trong chế độ bộ nhớ ảo thì chúng có khả năng quản lý không gian nhớ lên tới 64 TB (Teta Byte).
Cơ chế xử lý xen kẽ dòng mã lệnh (Pipline).
Bộ nhớ ẩn (Cache).
Có bộ quản lý bộ nhớ (MMU), bộ đồng xử lý toán học được tích hợp bên trong.
Tốc độ 6 ¸ 112 (triệu lệnh/ms).
Tần số đồng hồ: fCLK = 10 ¸ 100 MHz và cao hơn nữa.
Ứng dụng:
Chế tạo các máy tính có tốc độ cao, các máy chủ đáp ứng cho các xử lý lớn như thống kê hàng ngày tại các ngân hàng, khí tượng thuỷ văn, mô phỏng các quá trình, lĩnh vực quân sự ...
Các máy tính hiện nay.
Giới thiệu cấu trúc của hệ vi xử lý
CPU
Memory
ROM
RAM
I/O
Interfacing
Thiết bị vào
Thiết bị ra
Address bus
Control bus
Data bus
Hình vẽ: Hệ vi xử lý
Chúng ta đã được tìm hiểu qua về sự ra đời và vị trí của các bộ vi xử lý. Bộ VXL là thành phần cơ bản (trái tim) của máy tính, nó được kết hợp với các bộ phận mạch điện tử khác như bộ nhớ (bộ nhớ bán dẫn), bộ phối ghép vào ra để tạo nên hệ vi xử lý nói chung mà máy tính là một trường hợp ứng dụng của thể của hệ vi xử lý.
CPU (Central Processing Unit) - Bộ xử lý trung tâm.
Memory: Bộ nhớ bán dẫn.
I/O (Input/Output): Khối phối ghép với thiết bị ngoại vi.
Bus là tập các đường dây truyền thông tin, tín hiệu gồm:
Data bus.
Control bus.
Address bus.
CPU - Bộ xử lý trung tâm
Là mạch điện tử có độ tích hợp cao (là trái tim của hệ vi xử lý). Ngày nay thường là các vi mạch có độ tích hợp VLSI.
Chức năng:
Điều khiển mọi hoạt động của hệ vi xử lý (hoạt động tính toán).
Thực hiện lệnh, xử lý dữ liệu.
Nguyên tắc hoạt động
Hoạt động theo chương trình nằm trong bộ nhớ. Nó nhận lần lượt nhận từng lệnh từ bộ nhớ, các lệnh được ghi dưới dạng các bit 0, 1 sau đó giải mã lệnh thành các xung điều khiển tương ứng các thao tác của lệnh để điều khiển các khối chức năng thực hiện các thao tác đó. Quá trình thực hiện trên bao gồm cả trao đổi dữ liệu với bộ nhớ. Để thực hiện được như trên, bên trong CPU có thanh ghi lưu địa chỉ của lệnh chuẩn bị được thực hiện, gọi là thanh ghi con trỏ lệnh (Instruction Pointer - PC), hay còn được gọi là bộ đếm chương trình (Program Counter - PC).
Các thành phần cơ bản của bộ vi xử lý:
Đơn vị điều khiển (Control Unit - CU): điều khiển hoạt động chính của CPU và các thành phần khác của hệ theo chương trình đã định (dãy các lệnh) bằng các xung điều khiển.
Đơn vị số học và logic (Arithmetic and Logic Unit - ALU): thực hiện chức năng xử lý dữ liệu (tính toán) như cộng, trừ, nhân, chia, NOT, AND, OR ...
Tập thanh ghi (Registers Set): là các ngăn nhớ đặc biệt nằm ngay trong CPU để tăng tốc độ trao đổi dữ liệu. Một số thanh ghi lưu trữ thông tin tạm thời phục vụ cho việc thực hiện chương trình.
Bus bên trong (Internal Bus): Hệ thống bus trong CPU là tập các đường dây làm nhiệm vụ kết nối, vận chuyển thông tin (tín hiệu) giữa các thành phần với nhau.
Bộ nhớ bán dẫn (ROM, RAM)
Là bộ phận quan trọng trong hệ vi xử lý. Nó có nhiệm vụ lưu trữ chương trình và dữ liệu. Bộ nhớ trong bao gồm bộ nhớ chính và bộ nhớ ẩn (cache L1, L2). Khi khởi động máy, chương trình điều khiển được chứa trong ROM sẽ điều khiển hoạt động toàn hệ. Các chương trình ứng dụng, một phần chương trình điều khiển, kết quả chạy chương trình được để ở RAM. Ngoài ra còn có bộ nhớ ngoài (ổ đĩa từ, quang ...) lưu trữ lâu dài chương trình và dữ liệu, là các thiết bị ngoại vi.
Hệ thống vào ra (I/O)
Chức năng
Giao tiếp, trao đổi thông tin giữa hệ vi xử lý với thế giới bên ngoài.
Các thành phần cơ bản
Thiết bị ngoại vi: Bàn phím, màn hình, chuột, máy in, ổ đĩa từ, ổ đĩa quang ... các bộ chuyển đổi ADC, DAC ..., chuyển đổi thông tin dưới dạng nào đó thành dạng phù hợp với máy tính và ngược lại rồi liên hệ với máy tính thông qua khối phối ghép vào/ra.
Mạch phối ghép vào/ra dùng ghép nối thiết bị ngoại vi với hệ vi xử lý (máy tính). Trong mạch phối ghép vào/ra có bộ phận phối ghép cụ thể giữa hệ thống bus với thế giới bên ngoài gọi là các cổng vào ra (I/O port). Mỗi cổng có địa chỉ xác định. I/O port vào: nhận thông tin từ bên ngoài vào hệ thống, I/O port ra: đưa thông tin từ hệ ra thế giới bên ngoài.
Liên hệ giữa các khối
Hệ thống bus là tập các đường dây dùng để kết nối, trao đổi thông tin từ các phần mạch này tới các thành phần khác (các khối) trong phạm vi một máy tính (1 hệ vi xử lý).
Độ rộng bus là số bit thông tin được vận chuyển đồng thời trong một chu kỳ bus.
Bus địa chỉ
Theo sự phát triển các bộ vi xử lý, độ rộng bus địa chỉ tăng từ 16, 20, 24 và 32 bit. Bus địa chỉ dùng để vận chuyển địa chỉ từ CPU đến bộ nhớ hay mạch phối ghép vào/ra để tìm ra ngăn hay nhớ cổng vào/ra cần trao đổi dữ liệu.
Khả năng phân biệt địa chỉ của CPU phụ thuộc độ rộng bus địa chỉ.
Bus địa chỉ gồm An-1 ¸ A0 (n bit) Æ có thể quản lý được 2n địa chỉ.
Độ rộng bus địa chỉ cho biết khả năng phân biệt và quản lý không gian nhớ.
Bus dữ liệu
Độ rộng bus dữ liệu thường là 8, 16, 32 và 64 tuỳ theo các bộ vi xử lý. Ngày nay các bộ vi xử lý thường làm việc với bus dữ liệu có độ rộng 64 bit, thậm chí là 128 bit. Độ rộng bus dữ liệu quyết định số bit dữ liệu mà CPU có khả năng nhận hay gửi (đọc/ghi) hay xử lý cùng lúc.
Bus dữ liệu là bus 2 chiều, dữ liệu có thể được truyền từ CPU đến bộ nhớ hay cổng vào/ra hoặc ngược lại.
Bus điều khiển
Độ rộng bus điều khiển thường nhỏ hơn độ rộng bus địa chỉ và bus dữ liệu. Mỗi tín hiệu điều khiển có một chiều nhất định. CPU có thể gửi các tín hiệu điều khiển tới các khối đồng thời nó cũng nhận tín hiệu điều khiển từ các khối gửi đến. Trong chừng mực nào đó có thể coi bus điều khiển là 2 chiều. Tính 2 chiều không phải của một tín hiệu điều khiển cụ thể nào mà là của một nhóm tín hiệu.
Các tín hiệu phát ra từ CPU: MEMR (tín hiệu điều khiển đọc bộ nhớ), MEMW (tín hiệu điều khiển ghi bộ nhớ), IOR (tín hiệu điều khiển đọc cổng vào ra), IOW (tín hiệu điểu khiển ghi cổng vào ra).
Tín hiệu điều khiển ngắt: INTR.
Tín hiệu điều khiển chuyển nhượng bus (HOLD, HLDA).
Clock (CLK): Xung nhịp phát ra từ bộ dao động cấp cho CPU và các thành phần khác để hệ thống hoạt động đồng bộ.
Chương 2
BỘ VI XỬ LÝ 8088 CỦA INTEL
Giới thiệu hoạt động của bộ vi xử lý 8088
Giới thiệu chung
Bộ vi xử lý 8088 thuộc họ vi xử lý của Intel.
Điển hình: 8085 là bộ vi xử lý 8 bit.
8086 là bộ vi xử lý 16 bit hoàn chỉnh.
8088 là bộ vi xử lý 16 bit trong/ 8 bit ngoài.
Các đặc tính kỹ thuật chủ yếu:
Số thanh ghi: 14 thanhg ghi 16 bit.
Bus địa chỉ: 20 bit.
Bus dữ liệu: 16 (8086) và 8 (8088).
Tập lệnh: 115 (là số lệnh được công bố trong nhiều tài liệu).
Tốc độ chuẩn: 4.77 MHz.
Số chân của bộ vi xử lý: 40.
Bộ vi xử lý 8086 của Intel được phát triển từ năm 1978 vào đưa vào thị trường từ năm 1980. Đây là bộ vi xử lý 16 bit bán hoàn chỉnh, các thanh ghi bên trong là 16 bit và nó xử lý 16 bit dữ liệu cùng một lúc, 8086 liên hệ với kênh số liệu bên ngoài bằng bus dữ liệu 16 bit và bus địa chỉ là 20 bit.
Bộ vi xử lý 8088 ra đời sau 8086, nó có cấu trúc bên trong và tập lệnh hoàn toàn giống của 8086, chỉ khác 8086 ở kênh truyền dữ liệu với bên ngoài. 8088 sử dụng kênh dữ liệu 8 bit nên việc truyền dữ liệu giữa các thanh ghi trong nó với bộ nhớ chậm hơn so với 8086. Đây là một bước lùi về kỹ thuật nhưng đem lại nhiều lợi ích về kinh tế. Tại thời điểm lịch sử đó, bus DataMaster 8 bit đang được sử dụng rộng rãi trên thị trường, nhiều loại card mở rộng và các chip hỗ trợ có sẵn trên thị trường là loại 8 bit nên giá thấp hơn loại 16 bit tương ứng. Việc sử dụng bus dữ liệu 8 bit giúp cho người sử dụng khi nâng cấp máy có thể tận dụng được các card 8 bit trong các máy cũ cũng như chỉ phải mua mới với giá thấp. Đồng thời cũng giúp cho các nhà sản xuất các máy tương thích với IBM PC có thêm nhiều cơ hội lựa chọn sản phẩm của các hãng khác nhau. Chiến lược phát triển có tính kế thừa như vậy đã góp phần làm cho khách hàng của IBM ngày một gia tăng.
Chọn bộ vi xử lý 8088 để nghiên cứu vì:
Tập lệnh chung cho các bộ vi xử lý nói trên.
Tính phức tạp vừa phải, phù hợp với những người mới tìm hiểu.
Cấu trúc và hoạt động của bộ VXL 8088
Sự hoạt động của bộ vi xử lý 8088/8086 thực sự là việc thực hiện lặp đi lặp lại 3 thao tác chính là lấy lệnh (fetch), giải mã lệnh (decode) và thực hiện (execute). Sơ đồ khối của bộ vi xử lý 8088/8086 như hình vẽ với 2 đơn vị chính:
EU (Execution Unit): Đơn vị (khối) thực hiện lệnh.
BIU (Bus Interface Unit): Đơn vị giao tiếp bus (khối tương thích bus) để điều khiển bus hiệu quả hơn.
EU
Đơn vị EU của 8088 và 8086 giống nhau, bao gồm ALU, thanh ghi cờ, các thanh ghi đệm và các thanh ghi đa năng. Các bus dữ liệu bên trong của EU đều là 16 bit. EU không nối trực tiếp với bên ngoài, nó nhận lệnh từ hàng đợi lệnh bên trong BUI. Nếu là lệnh cần truy nhập bộ nhớ hoặc cổng vào/ra (I/O port - thiết bị ngoại vi) thì EU yêu cầu BIU lấy hoặc gửi dữ liệu. Tất cả các địa chỉ mà EU thao tác đều là 16 bit, khi gửi sang BIU thì BIU sẽ thực hiện tính toán để tạo địa chỉ vật lý 20 bit và phát ra các chân địa chỉ của chip.
các thanh ghi tạm
thanh ghi cờ
Logic
điều khiển BUS
AX
BX
CX
DX
SP
BP
SI
DI
Khối
điều khiển của EU
Đệm lệnh (hàng đợi lệnh)
(6 byte cho 8086)
BUS ngoài
Bus địa chỉ (20 bit)
các thanh ghi
đa năng
các thanh ghi đoạn
và con trỏ lệnh
các thanh ghi
con trỏ
và chỉ số
Bus dữ liệu
ALU(16bit)
Bus dữ liệu
(8 bit)
Bus trong
8 bit dữ liệu
20 bit địa chỉ
EU
BIU
CS
DS
SS
ES
IP
Các thanh ghi trong
Có 8 thanh ghi, là thành phần nhớ có tốc độ truy nhập rất cao. Bao gồm các thanh ghi đa năng Ax, Bx, Cx, Dx. Mỗi thanh ghi 16 bit có thể được phân chia thành 2 thanh ghi 8 bit làm việc độc lập nhau.
AX (Accumulator, Acc): Thanh chứa, chứa tạm thời dữ liệu (toán hạng, kết quả phép toán như nhân, chia và được coi là Acc). AX có thể được phân chia thành AH (Phần cao) và AL (Phần thấp).
BX (Base): Thanh ghi cơ sở, thường được dùng để chứa địa chỉ cơ sở cần truy nhập trong lệnh XLAT. BX có thể được