Bài giảng Kiến trúc máy tính - Bài 5: Các chip bổ trợ - Phan Thanh Toàn

5.1.2. LẬP TRÌNH CHO PIC 8259A 8259 là vi mạch khả trình. • Việc lập trình cho PIC 8259 gồm 2 công đoạn:  Thiết lập chế độ làm việc của PIC 8259;  Lập trình truyền tin qua 8259. • 8259 có 4 từ điều khiển khởi động: ICW1 – ICW4 và 3 từ điều khiển hoạt động OCW1 – OCW3. • Các thanh ghi của PIC 8259 được truy cập qua địa chỉ: 020h và 021h. 5.1.2. LẬP TRÌNH CHO PIC 8259A • Khởi động PIC cùng PC theo lưu đồ sau:  VXL: Viết từ điều khiển khởi động ICW1.  VXL: Viết từ điều khiển khởi động ICW2.  Nếu có ghép tầng VXL ghi tiếp ICW3.  Nếu có đòi hỏi ICW4 thì sẽ viết tiếp từ điều khiển khởi động ICW4.

pdf52 trang | Chia sẻ: thanhle95 | Lượt xem: 653 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Bài giảng Kiến trúc máy tính - Bài 5: Các chip bổ trợ - Phan Thanh Toàn, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
1 v1.0014103212 KIẾN TRÚC MÁY TÍNH Giảng viên: ThS. Phan Thanh Toàn 2 v1.0014103212 BÀI 5 CÁC CHIP BỔ TRỢ Giảng viên: ThS. Phan Thanh Toàn 3 v1.0014103212 • Liệt kê được các chip bổ trợ trong máy vi tính. • Liệt kê được các công dụng của các chip bổ trợ trong máy tính. • Mô tả được cấu tạo và nguyên tắc hoạt động của các chip bổ trợ như: 8259, 8255, MỤC TIÊU BÀI HỌC 4 v1.0014103212 Để hiểu rõ bài này, yêu cầu sinh viên cần có các kiến thức cơ bản liên quan đến các môn học sau: • Kỹ thuật số; • Kỹ thuật điện tử số. CÁC KIẾN THỨC CẦN CÓ 5 v1.0014103212 • Đọc tài liệu và tóm tắt những nội dung chính của từng bài. • Luôn liên hệ và lấy ví dụ thực tế khi học đến từng vấn đề̀ và khái niệm. • Sử dụng các ngôn ngữ lập trình cơ bản như Pascal, C, • Làm bài tập và luyện thi trắc nghiệm theo yêu cầu từng bài. HƯỚNG DẪN HỌC 6 v1.0014103212 5.1. Chip điều khiển ngắt 8259 5.2. Chip ghép nối ngoại vi khả trình PPI-8255A 5.3. Chip định thời PIT-8253 5.4. Chip điều khiển truy nhập bộ nhớ trực tiếp DMA-8237A CẤU TRÚC NỘI DUNG 7 v1.0014103212 5.1.1. Cấu tạo và nguyên tắc hoạt động 5.1.2. Lập trình cho PIC 8259A 5.1. CHIP ĐIỀU KHIỂN NGẮT 8259A 8 v1.0014103212 • Hệ thống máy tính có nhiều loại ngắt và nhiều ngắt. • Mỗi ngắt có một mức ưu tiên khác nhau. • VXL có 2 lối vào cho ngắt là: INTR, NMI. • Cần bộ điều khiển ưu tiên ngắt để đưa các tín hiệu ngắt vào 2 chân INTR, NMI. Hình 1: Sơ đồ khối PIC 8259 A 5.1.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG 9 v1.0014103212 5.1.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG • Các thanh ghi IRR, ISR, IMR: 8 bit. • Tín hiệu yêu cầu ngắt: IR0, IR1, , IR7. • Thanh ghi che ngắt (IMR – Interrupt Mask Register): Cấm/cho phép ngắt. • IRR: Thanh ghi yêu cầu ngắt. • IR: Thanh ghi ngắt được phục vụ. • PR: Mạch logic giải quyết ưu tiên ngắt. 10 v1.0014103212 5.1.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG Hình 2: Sơ đồ phối ghép 8259 với bộ VXL 11 v1.0014103212 5.1.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG (tiếp theo) 12 v1.0014103212 • 8259 là vi mạch khả trình. • Việc lập trình cho PIC 8259 gồm 2 công đoạn:  Thiết lập chế độ làm việc của PIC 8259;  Lập trình truyền tin qua 8259. • 8259 có 4 từ điều khiển khởi động: ICW1 – ICW4 và 3 từ điều khiển hoạt động OCW1 – OCW3. • Các thanh ghi của PIC 8259 được truy cập qua địa chỉ: 020h và 021h. 5.1.2. LẬP TRÌNH CHO PIC 8259A 13 v1.0014103212 5.1.2. LẬP TRÌNH CHO PIC 8259A Không • Khởi động PIC cùng PC theo lưu đồ sau:  VXL: Viết từ điều khiển khởi động ICW1.  VXL: Viết từ điều khiển khởi động ICW2.  Nếu có ghép tầng VXL ghi tiếp ICW3.  Nếu có đòi hỏi ICW4 thì sẽ viết tiếp từ điều khiển khởi động ICW4. Ghép PIC? Viết từ ICW1 Viết từ ICW1 Viết từ ICW3 Yêu cầu ICW4 Viết từ ICW4 Không Có Có 14 v1.0014103212 Có 4 từ điều khiển khởi tạo A0 Khởi tạo 0 0 ICW1 0 1 ICW2, ICW3, ICW4 1 X Không chọn 8259 CS 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) 15 v1.0014103212 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) Cấu trúc các từ điều khiển ICW1 – ICW4 16 v1.0014103212 • ICW2: Xác định số hiệu ngắt 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) 17 v1.0014103212 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) • ICW3: Làm việc ở chế độ chủ và khách 18 v1.0014103212 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) • ICW4 19 v1.0014103212 • Định dạng các thanh ghi điều khiển hoạt động OCW1-OCW3  OCW1: Thanh ghi thiết lập và đọc trạng thái yêu cầu ngắt 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) 20 v1.0014103212 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo)  OCW2: Xác định việc xử lí các yêu cầu ngắt của 8259 21 v1.0014103212  OCW3  Chọn các thanh ghi để đọc;  Thăm dò trạng thái yêu cầu ngắt;  Thao tác với thanh ghi mặt nạ. D0D1D2D3D4D5D6D7A0 RISRRP10SMMESMM00 Đọc thanh ghi IRR ở lần sau Đọc thanh ghi IRR ở lần sau Không làm gì 1100 1010 Đăt mặt nạ đặc biệt Xóa mặt nạ đặc biệt Không làm gì 1100 1010 1 = thăm dò yêu cầu ngắt 0 = Không thăm dò 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) 22 v1.0014103212 5.1.2. LẬP TRÌNH CHO PIC 8259A (tiếp theo) • Các chế độ ngắt: Có 4 chế độ Chế độ Chức năng, Ý nghĩa Ưu tiên cố định Mỗi ngắt được gán 1 mức ưu tiên cố định. Mức 0 là cao nhất, mức 7 là thấp nhất. Ưu tiên vòng tự động Ưu tiên đồng đều, mỗi mức sau khi được phục vụ trở thành mức thấp nhất cho đến khi có ngắt tiếp theo xảy ra. Ưu tiên vòng theo quy định Phần mềm của hệ quy định mức ưu tiên thấp nhất. Thứ tự ưu tiên được lập dựa trên cơ sở quy định này. Thăm dò ngắt Phần mềm của hệ đọc thanh ghi trạng thái của 8259, từ đó xác định nguồn ngắt và quyết định phục vụ ngắt. 23 v1.0014103212 5.2.1. Cấu tạo và nguyên tắc hoạt động của 8255A 5.2.2 Lập trình với 8255A 5.2. CHIP GHÉP NỐI NGOẠI VI KHẢ TRÌNH PPI-8255A 24 v1.0014103212 • PPI-8255A (Programmable Peripheral Interface)  Là chip vào/ra lập trình được;  Truyền dữ liệu theo phương thức song song. Hình 3: Sơ đồ khối và các chân của 8255A 5.2.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG CỦA 8255A 25 v1.0014103212 5.2.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG CỦA 8255A • 24 chân cho 3 cổng vào/ra. • PA0-PA7: 8 chân cho cổng A. • PB0-PB7: 8 chân cho cổng B. • PC0-PC7: 8 chân cho cổng C. • Nhóm A: Gồm cổng A và 4 bit cao của cổng C. • Nhóm B: Gồm cổng B và 4 bit thấp của cổng C. • 8255 có thể hoạt động ở 3 chế độ (0,1,2). 26 v1.0014103212 • Chân chọn chip 8255A để làm việc cùng với bộ xử lý. • Chân : Đọc dữ liệu từ 8255A. • Chân : Ghi dữ liệu vào 8255A. • Hai chân A0, A1 kết hợp với tín hiệu , và cho phép truy cập 1 trong 3 cổng PA, PB, PC hoặc thanh ghi từ điều khiển. CS RD WR RD WR A1 A0 Ý nghĩa 0 0 0 1 Đọc cổng A vào bus dữ liệu 0 1 0 1 Đọc cổng B vào bus dữ liệu 1 0 0 1 Đọc cổng C vào bus dữ liệu 1 1 0 1 Đọc từ điều khiển vào bus dữ liệu 0 0 1 0 Viết từ bus dữ liệu vào cổng A 0 1 1 0 Viết từ bus dữ liệu vào cổng B 1 0 1 0 Viết từ bus dữ liệu vào cổng C 1 1 1 0 Viết từ bus dữ liệu vào từ điều khiển RD WR 5.2.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG CỦA 8255A (tiếp theo) 27 v1.0014103212 5.2.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG CỦA 8255A (tiếp theo) • Chọn chế độ hoạt động cho 8255A  8255A có thể hoạt động ở 3 chế độ: Chế độ 0, 1, 2.  Tất cả các cổng của 8255A đều làm việc như cổng vào.  Để chọn chế độ cho 8255A ta ghi dữ liệu vào từ điều khiển của 8255A. 28 v1.0014103212 • Đặt/xóa các bit của cổng C Các bit của cổng C có thể được đặt/xóa thông qua việc viết từ điều khiển với bit D7=0. 5.2.2. LẬP TRÌNH VỚI 8255A (tiếp theo) 29 v1.0014103212 5.2.2. LẬP TRÌNH VỚI 8255A (tiếp theo) • Các chế độ hoạt động của 8255A  Chế độ 0: Vào/ra một chiều không có móc nối  Vi mạch gồm 2 cổng 8 bit;  Các cổng có thể là cổng vào/ra;  Các tín hiệu ra được chốt;  Các tín hiệu vào không được chốt;  8255 có 16 cấu hình hoạt động vào/ra nhờ sử dụng từ điều khiển. 30 v1.0014103212 • Các chế độ hoạt động của 8255A  Chế độ 1: Vào/ra hai chiều có móc nối qua các bit cao của cổng C  Vi mạch hoạt động gồm 2 nhóm: Nhóm A và B;  Mỗi nhóm có 1 cổng 8 bit và 1 cổng điều khiển 4 bit;  Cổng 8 bit có thể là cổng vào/ra, chốt dữ liệu. 5.2.2. LẬP TRÌNH VỚI 8255A (tiếp theo) 31 v1.0014103212 5.2.2. LẬP TRÌNH VỚI 8255A (tiếp theo) • Các chế độ hoạt động của 8255A  Chế độ 3: Vào/ra hai chiều qua cổng A có móc nối qua các bit cao của cổng C  Vi mạch chỉ có nhóm A hoạt động;  Cổng A là cổng vào/ra hai chiều 8 bit;  Các tín hiệu vào/ra đều được chốt lại;  5 bit của cổng C được sử dụng làm cổng điều khiển, trạng thái cho cổng A. 32 v1.0014103212 5.3.1. Cấu tạo và nguyên tắc hoạt động 5.3.2 Lập trình với 8253 5.3. CHIP ĐỊNH THỜI KHẢ TRÌNH PIT-8253 33 v1.0014103212 5.3.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG 34 v1.0014103212 5.3.1. CẤU TẠO VÀ NGUYÊN TẮC HOẠT ĐỘNG • 3 bộ đếm C0, C1, C2: Các bộ đếm lùi, 16 bit. • Bộ đệm số liệu: 8 bit, sử dụng để phối ghép với bus hệ thống của bộ VXL. • Chân : Cho phép đọc dữ liệu từ 8253. • Chân : Cho phép ghi dữ liệu vào 8253. • Chân : Chọn chip 8253 RD WR CS A1 A0 Ý nghĩa 0 0 0 1 Đọc bộ đếm 0 0 1 0 1 Đọc bộ đếm 1 1 0 0 1 Đọc bộ đếm 2 1 1 0 1 Đọc từ điều khiển 0 0 1 0 Viết vào bộ đếm 0 0 1 1 0 Viết vào bộ đếm 1 1 0 1 0 Viết vào bộ đếm 2 1 1 1 0 Viết từ điều khiển vào thanh ghi điều khiển RD WR 35 v1.0014103212 • Địa chỉ các thanh ghi và định dạng từ điều khiển Địa chỉ các cổng của PIT như sau: Cổng 1 Cổng 2 Thanh ghi Hoạt động 040h 048h Bộ đếm 0 Đọc/viết 041h 049h Bộ đếm 1 Đọc/viết 042h 04ah Bộ đếm 2 Đọc/viết 043h 04bh Điều khiển Đọc/viết 5.3.2. LẬP TRÌNH CHO 8253 36 v1.0014103212 5.3.2. LẬP TRÌNH CHO 8253 • Địa chỉ các thanh ghi và định dạng từ điều khiển  Định dạng từ điều khiển  SC0, SC1: Chọn bộ đếm, 00: bộ đếm 0, 01: bộ đếm 1, 10: bộ đếm 2.  RW0, RW1: Phương thức đọc/ghi 00: Lệnh chốt bộ đếm; 01: Chỉ đọc/viết byte thấp; 10: Chỉ đọc/viết byte cao; 11: Đọc/viết byte thấp trước, byte cao sau. SC1 SC0 RW1 RW0 M2 M1 M0 BCD D0D1D2D3D4D5D6D7 37 v1.0014103212 • Các chế độ đếm  Chế độ 0: Phát ra tại một sườn xung lên khi kết thúc đếm. Hình 5: Chế độ đếm 0 với số đếm là 4 5.3.2. LẬP TRÌNH CHO 8253 (tiếp theo) 38 v1.0014103212 5.3.2. LẬP TRÌNH CHO 8253 (tiếp theo)  Chế độ 1: Phát ra một xung đơn với thời gian tồn tại xung biến đổi được. Hình 6: Chế độ đếm 1 với số đếm là 4 39 v1.0014103212 5.3.2. LẬP TRÌNH CHO 8253 (tiếp theo)  Chế độ 2: Các xung nhịp đưa vào bộ đếm được chia bởi giá trị nạp trong thanh ghi bộ đếm. Hình 7: Chế độ đếm 2 với số đếm là 4 40 v1.0014103212 5.3.2. LẬP TRÌNH CHO 8253 (tiếp theo)  Chế độ 3: Phát ra sóng hình vuông. Hình 8: Chế độ đếm 3 với số đếm là 4  Chế độ 4: Tạo xung bằng phần mềm.  Chế độ 5: Tạo xung bằng xung của cửa GATE, giống như chế độ 2. 41 v1.0014103212 • Viết bộ đếm  Viết từ điều khiển để xác lập chế độ làm việc.  Nạp số đếm ban đầu.  Ví dụ sử dụng bộ đếm 2, phát xung hình vuông (chế độ 3), tần số 10KHz, tần số Clock: 1.19318MHz, hệ số chia viết vào bộ đếm 2 là: 119. MOV AL, 1001 0110 b; nạp từ điều khiển vào AL. OUT 43h, AL; viết từ điều khiển qua cổng 43h vào thanh ghi điều khiển. MOV AL, 119; nạp byte thấp vào AL. OUT 42h, AL; viết giá trị đếm vào bộ đếm C2. 5.3.2. LẬP TRÌNH CHO 8253 (tiếp theo) 42 v1.0014103212 5.3.2. LẬP TRÌNH CHO 8253 (tiếp theo) • Đọc bộ đếm  Nếu cần đọc giá trị tức thời của bộ đếm khi quá trình đếm chưa kết thúc thì phải sử dụng các lệnh chốt bộ đếm hoặc lệnh đọc thanh ghi từ điều khiển.  Tại thời điểm lệnh chốt bộ đếm được viết vào thanh ghi từ điều khiển, giá trị đếm được chốt vào thanh ghi đệm ra của PIT 8253.  SC1, SC0: 2 bit chọn bộ đếm được chốt.  00: Bộ đếm 0 được chọn.  01: Bộ đếm 1 được chọn.  10: Bộ đếm 2 được chọn.  X: Không có nghĩa. SC1 SC0 0 0 x x x x D0D1D2D3D4D5D6D7 43 v1.0014103212 5.3.2. LẬP TRÌNH CHO 8253 (tiếp theo) • Các chức năng của bộ đếm trong máy vi tính  Cập nhật đồng hồ hệ thống:  Bộ đếm hoạt động ở chế độ 2;  Lối vào có xung nhịp: 1.19318MHz;  Lối vào cổng Gate đặt ở mức logic 1;  Giá trị ban đầu là 0 hoặc 65535.  Làm tươi bộ nhớ RAM;  Phát sóng âm với tần số biến đổi ra loa. 44 v1.0014103212 5.4.1. Phương pháp truy nhập bộ nhớ trực tiếp 5.4.2. Chip điều khiển DMAC 5.4. CHIP TRUY NHẬP BỘ NHỚ TRỰC TIẾP DMA-8237 45 v1.0014103212 • Phương pháp vào/ra bằng ngắt đảm bảo thời gian vào/ra số liệu ngắn, nhưng phải thực hiện bằng phần mềm  Cần sự tham gia của bộ VXL. • Khi cần chuyển lượng dữ liệu nhiều  Không đủ nhanh để đáp ứng. • Sử dụng một mạch phần cứng thực hiện việc truyền dữ liệu giữa bộ nhớ và các TBNV không cần qua bộ VXL  Gọi là phương pháp truy nhập bộ nhớ trực tiếp (DMA – Direct MemoryAccess). Hình 9: Các đường liên hệ trực tiếp trong quá trình DMA Không gian vào/ra Vi xử lý Không gian bộ nhớ DMAC 5.4.1. PHƯƠNG PHÁP TRUY NHẬP BỘ NHỚ TRỰC TIẾP 46 v1.0014103212 5.4.1. PHƯƠNG PHÁP TRUY NHẬP BỘ NHỚ TRỰC TIẾP • DMAC chia sẻ thời gian sử dụng các bus dữ liệu, địa chỉ và điều khiển. Hình 10: Sơ đồ phối ghép DMAC với bộ nhớ, TBNV, và bộ VXL Thiết bị I/O CPU DMAC HRQ HACK DRQ DACK DRQ DACK HOLD HLDA Bộ nhớ 47 v1.0014103212 • Sơ đồ nguyên lý của DMAC 5.4.2. CHIP ĐIỀU KHIỂN DMAC 48 v1.0014103212 5.4.2. CHIP ĐIỀU KHIỂN DMAC • DMAC gồm 3 khối chính  Timing Control: Sinh ra các tín hiệu định thời bên trong và tín hiệu điều khiển bên ngoài 8237.  Program Command Control  Giải mã các lệnh gửi tới 8237 trước khi phục vụ yêu cầu DMA.  Giải mã từ điều khiển chế độ xác định kiểu DMA trong khi phục vụ yêu cầu DMA.  Priority Encoder: Giải quyết xung đột yêu cầu DMA đồng thời. 49 v1.0014103212 • Các chân tín hiệu của DMAC  : DMAC đang đọc tín hiệu từ thiết bị ngoại vi;  : DMAC đang viết dữ liệu ra thiết bị ngoại vi;  : Dữ liệu được đọc từ bộ nhớ chính;  : Dữ liệu được ghi vào bộ nhớ chính;  READY: Tín hiệu vào từ bộ nhớ hoặc thiết bị ngoại vi;  HLDA: CPU báo cho DMAC biết CPU đã rời khỏi bus, trao bus cho DMAC;  ADSTB: Nhận byte cao và chốt địa chỉ ngoài của DMA;  AEN: Kích hoạt chốt địa chỉ của DMA;  HRQ: Tín hiệu yêu cầu DMA từ chip 8237. MEMW MEMR IOW IOR 5.4.2. CHIP ĐIỀU KHIỂN DMAC (tiếp theo) 50 v1.0014103212 5.4.2. CHIP ĐIỀU KHIỂN DMAC (tiếp theo) • Các chân tín hiệu của DMAC:  : Tín hiệu chọn chip;  CLK: Lối vào xung đồng hồ;  RESET: Khởi động lại chip;  : Chấp nhận DMA;  DREQ0-DREQ3: Đòi hỏi DMA từ TBNV;  DB0-DB7: Bus dữ liệu 2 chiều;  A0-A7: Tín hiệu địa chỉ;  : Kết thúc xử lí DMA. CS EOP DACK 0 – DACK 3 51 v1.0014103212 5.4.2. CHIP ĐIỀU KHIỂN DMAC (tiếp theo) • Hoạt động của 8237: Bao gồm 2 chu kỳ hoạt động  Chu kỳ rỗi  Kiểm tra các tín hiệu DREQ xem có thiết bị nào yêu cầu DMA;  Kiểm tra CS nếu CPU có yêu cầu đọc/ghi các thanh ghi bên trong.  Chu kỳ hoạt động  Diễn ra khi có yêu cầu DREQ từ thiết bị ngoại vi;  Gửi tín hiệu HRQ tới CPU;  Hoạt động 1 trong 4 chế độ: Chế độ chuyển từng từ, chế độ chuyển mảng, chế độ chuyển theo nhu cầu, chế độ ghép tầng. 52 v1.0014103212 Trong bài này chúng ta đã tìm hiểu các nội dung sau: • Các chip bổ trợ trong hệ thống máy tính; • Cấu tạo và nguyên tắc hoạt động của các chip bổ trợ cơ bản như: 8255, 8259, 8237, TÓM LƯỢC CUỐI BÀI
Tài liệu liên quan