Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống
1
/ 19 trang
THÔNG TIN TÀI LIỆU
Thông tin cơ bản
Định dạng
Số trang
19
Dung lượng
0,96 MB
Nội dung
Ki ế n trúcHarvard Linhlg8593@gmail.com Mục lục Trang 1. Vị trí của đề tài trong môn Kiếntrúc máy tính……………2 2. Kiếntrúc Harvard. 2.1 Lịch sử………………………………………………2 2.2 Định nghĩa………………………………………… 5 2.3 Đặc điểm…………………………………………….7 2.4 Ứng dụng……………………………………………12 2.4.1 Vi điều khiển PIC………………………… 13 2.4.2 Vi điều khiển AVR…………………………15 2.4.3 Vi điều khiển 8031…………………………17 3. Tài liệu tham khảo………………………………………….19 1 Ki ế n trúcHarvard Linhlg8593@gmail.com I. Vị trí của đề tài trong môn Kiến trúc máy tính Kiếntrúc máy tính: 1. Khái niệm chung về Hệ thống máy tính 2. Lịch sử phát triển: 4 thế hệ máy tính 3. Phân loại: 3.1. Phân loại theo kích thước, tốc độ… 3.2. Phân loại theo kiếntrúc • SISD (single instruction - single data) • SIMD (Single Instruction Multiple Data) • MIMD (Multiple Instruction Multiple Data) • Hai kiếntrúc phổbiến Von neumann CPU <-> Bộnhớ<-> Ngoại vi BộnhớCT <-> CPU <-> Bộnhớdữliệu <-> Ngoại vi II. Kiếntrúc Harvard. 1. Lịch sử. KiếntrúcHarvard bắt đầu với máy tính Harvard Mark I, nó cho phép các lệnh được đặt trong các tape đục lỗ (với 24 bit) và dữ liệu thì được chứa trong các thẻ (với 23 ký tự). Những máy tính đầu tiên này rất 2 Harvard Ki ế n trúcHarvard Linhlg8593@gmail.com giới hạn dung lượng dữ liệu, nó được chứa hoàn toàn trong bộ xử lý trung tâm (CPU), và không cho phép truy cập vào khu vực chứa lệnh (chương trình) như với dữ liệu (làm cho việc tạo, load, sửa chữa, v.v. toàn bộ chương trình phải được thực hiện offline). Hình 1: Harvard Mark-I in use, 1944 Vào năm 1939, người ta bắt đầu chế tạo chiếc máy Ha rvard Mark I tại phòng thí nghiệm Endicott của IBM. Được biết đến chính thức với tên gọi Automatic Sequence Controlled Calculator (Máy tính được điều khiển bằng chuỗi tự động), Mark I là một máy tính cơ-điện đa năng được chế tạo bằng tiền bạc và sự hỗ trợ nhân lực từ IBM, dưới sự hướng dẫn của nhà toán học Howard Aiken của trường Harvard. Bản thiết kế của nó ảnh hưởng từ Máy phân tích của Babbage, sử dụng số thập phân và bánh xe lưu trữ cùng với công tắc 3 Ki ế n trúcHarvard Linhlg8593@gmail.com xoay kèm với rờ-le điện từ. Nó có thể lập trình được nhờ cuộn giấy đục lỗ, và có thể cùng lúc tính toán vài đơn vị song song. Các phiên bản sau đó có vài bộ đọc cuộn giấy và nó có thể thay đổi giữa các bộ đọc dựa trên một điều kiện nào đó. Tuy nhiên, chiếc máy không hoàn toàn là máy Turing đầy đủ. Mark I được chuyển đến Đại học Harvard và bắt đầu được đưa vào hoạt động vào tháng 5 năm 1944. Máy nặng 5 tấn, kết hợp 500 dặm của dây kim loại, cao 8 feet và 51 feet dài, và có một trục 50 ft quay chạy chiều dài của nó, quay bởi một động cơ điện 5 mã lực, chạy không ngừng trong 15 năm, âm thanh giống như hàng chục phụ nữ đan. Để đánh giá cao quy mô của máy này lưu ý bốn máy đánh chữ ở mặt trước của bức ảnh sau. Hình 2: Harvard Mark I- một máy tính cơ điện 4 Ki ế n trúcHarvard Linhlg8593@gmail.com Một vài hình ảnh khác: Hình 3 Hình 4 2. Định nghĩa. Cụm từ kiếntrúcHarvard được dùng để chỉ những kiến trúc máy tính mà trong đó phân biệt rõ ràng bộ nhớ dữ liệu và bộ nhớ 5 Ki ế n trúcHarvard Linhlg8593@gmail.com chương trình, chúng có những đường truyền (bus) riêng để truy cập vào bộ nhớ dữ liệu và bộ nhớ chương trình (ngược lại, kiếntrúc von Neumann có bộ nhớ và bộ nhớ chương trình chung). Hình 5: Sơ đồ kiếntrúcHarvard Mô hình: 6 Ki ế n trúcHarvard Linhlg8593@gmail.com Hình 6: Mô phỏng hoạt động bên trong Tổng quát, để hình dung rõ hơn ta có sơ đồ: Hình 7: Khái quát sơ đồ 3. Đặc điểm. Để làm rõ đặc điểm của kiếntrúc Harvard, ta so sánh nó với kiếntrúc von Neumann. Ta có sơ đồ sau: 7 Ki ế n trúcHarvard Linhlg8593@gmail.com Hình 8: So sánh mô hình kiếntrúcHarvard và kiếntrúc von Neumann Trong kiếntrúc von Neumann không phân biệt vùng chứa dữ liệu và mã chương trình. Cả chương trình và dữ liệu đều được truy nhập theo cùng một đường. Điều này cho phép đưa dữ liệu vào vùng mã chương trình ROM, và cũng có thể lưu mã chương trình vào vùng dữ liệu RAM và thực hiện từ đó. CPU có thể đọc một lệnh, hoặc đọc/ghi dữ liệu từ bộ nhớ. Tuy vậy, cả hai quá trình tương tác với lệnh hoặc với dữ liệu, không thể thực hiện cùng lúc, vì nó sử dụng chung một đường truyền và bộ nhớ. Trong một máy tính kiếntrúc Harvard, CPU có thể vừa đọc một lệnh, vừa truy cập dữ liệu từ bộ nhớ cùng lúc, do Kiến 8 Ki ế n trúcHarvard Linhlg8593@gmail.com trúc Havard tách/phân biệt vùng lưu mã chương trình và dữ liệu. Mã chương trình chỉ có thể được lưu và thực hiện trong vùng chứa ROM và dữ liệu cũng chỉ có thể lưu và trao đổi trong vùng RAM: Hình 9: Quá trình đọc lệnh ở kiếntrúcHarvard và kiếntrúc von Neumann Hầu hết các vi xử lý nhúng ngày nay sử dụng kiếntrúc bộ nhớ Havard hoặc kiếntrúc Havard mở rộng (tức là bộ nhớ chương trình và dữ liệu tách biệt nhưng vẫn cho phép khả năng hạn chế để lấy dữ liệu ra từ vùng mã chương trình). Trong kiếntrúc bộ nhớ Havard mở rộng thường sử dụng một số lượng nhỏ các con trỏ để lấy dữ liệu từ vùng mã chương trình theo cách nhúng vào trong các lệnh tức thời. Một số Chip vi điều khiển nhúng tiêu biểu hiện nay sử dụng cấu trúc Havard là 8031, PIC, Atmel AVR90S. Nếu sử dụng Chip 8031 chúng ta sẽ nhận thấy điều này thông qua việc truy nhập lấy dữ liệu ra từ vùng dữ liệu RAM hoặc từ vùng mã chương trình. Chúng ta có một vài con trỏ được sử dụng để lấy dữ liệu ra từ bộ nhớ dữ liệu RAM, nhưng chỉ có 9 Ki ế n trúcHarvard Linhlg8593@gmail.com duy nhất một con trỏ DPTR có thể được sử dụng để lấy dữ liệu ra từ vùng mã chương trình. Ưu điểm nổi bật của cấu trúc bộ nhớ Harvard so với kiếntrúc von Neumann là có hai kênh tách biệt để truy nhập vào vùng bộ nhớ mã chương trình và dữ liệu nhờ vậy mà mã chương trình và dữ liệu có thể được truy nhập đồng thời và làm tăng tốc độ luồng trao đổi với bộ xử lý, có thể thực hiện ngay lệnh tiếp theo khi vừa kết thúc lệnh trước đó . Nên một máy tính kiếntrúcHarvard có thể chạy nhanh hơn: Hình 10: Mô hình Bus hệ thống ở Harvard và von Neumann Tuy nhiên tốc độ được tăng lên nhưng phải trả giá bằng sự thiết kế phần cứng phức tạp hơn (cụ thể nhất mà chúng ta thấy, đó là việc phải thiết kế 2 bus khác nhau cho dữ liệu và chương trình): 10 [...]... tìmhiểu thêm Ngoài ra, KiếntrúcHarvard còn được ứng dụng cho thiết kế rất nhiều thiết bị khác, nhưng nhóm 8 xin phép được trình bày 1 số nội 17 KiếntrúcHarvard Linhlg8593@gmail.com dung trên, mong thầy và các bạn theo dõi và cho ý kiến bổ sung cho đề tài Xin cảm ơn!!!!!! 18 KiếntrúcHarvard Linhlg8593@gmail.com Tài liệu tham khảo www.wattpad.com www.slideshare.net vi.wikipedia.org/wiki /Kiến_ trúc_ Harvard. .. tìmhiểu một vài vi điều khiển có sử dụng kiếntrúcHarvard như sau: 12 KiếntrúcHarvard Linhlg8593@gmail.com 4.1 Vi điều khiển PIC : PIC có bus dữ liệu 8-bit (phụ thuộc vào dòng PIC), nhưng bus chương trình có thể là 12-bit, 14-bit hoặc 16-bit word Điều này cho phép mỗi một lệnh đơn có đủ chỗ chứa cho một giá trị hằng PIC được tổ chức phần cứng theo kiếntrúc Harvard, và tập lệnh RISC (reduced instruction... lệnh giản lược) Trong kiếntrúc Harvard, bộ nhớ dữ liệu và bộ nhớ chương trình nằm riêng biệt, do đó CPU có thể làm việc trực tiếp với cả hai bộ nhớ dữ liệu và bộ nhớ chương trình cùng một lúc, làm cho tốc độ xử lý nhanh hơn Hình 12: Mô hình tổng thể Vi điều khiển PIC kiếntrúcHarvard Việc bộ nhớ chương trình và bộ nhớ dữ liệu được tách riêng, do đó, tập lệnh trong kiếntrúcHarvard có thể được tối... đó, tập lệnh trong kiếntrúcHarvard có thể được tối ưu tùy theo yêu cầu kiếntrúc của vi điều khiển Bằng chứng, độ dài lệnh của dòng PIC16 luôn luôn là 14 bit Trong khi đó, độ dài lệnh của các vi điều khiển kiếntrúc von-Neumann là bội số của 1 byte: 13 KiếntrúcHarvard Linhlg8593@gmail.com Hình 13: Mô hình vi điều khiển kiếntrúc von-Neumann PIC là một Vi điều khiển RISC, tập lệnh của PIC chỉ có... phải thay đổi và lấy dữ liệu từ bộ nhớ chính 11 Kiến trúc Harvard Linhlg8593@gmail.com đưa vào Việc điều chỉnh cache là một vấn đề quan trọng trong việc thiết kế máy tính Những thiết kế chip CPU tốc độ cao ngày này thường kết hợp hai kiến trúc Harvard và von Neumann Bộ nhớ cache trên chip được phân thành cache chương trình và cache dữ liệu Kiến trúc Harvard được dùng khi CPU truy cập vào cache Tuy... không được chia thành vùng nhớ chương trình và vùng nhớ dữ liệu Như vậy, kiếntrúc von Neumann được dùng ở tầm vực truy cập bộ nhớ chính KiếntrúcHarvard cũng thường được dùng trong một số DSP chuyên dụng, thường dùng trong các sản phẩm xử lý âm thanh, hình ảnh Ví dụ như vi xử lý Blackfin của Analog Devices Inc dùng kiếntrúcHarvard Thêm vào đó, hầu hết các vi điều khiển thông dụng được dùng trong... dựa trên kiếntrúcHarvard Những vi xử lý này có đặc tính là có lượng bộ nhớ dữ liệu và bộ nhớ chương trình nhỏ, rất phù hợp với kiếntrúcHarvard và tập lệnh RISC để đảm bảo hầu hết các lệnh được thực hiện trong 1 chu kỳ máy Việc phân chia bộ nhớ ra thành bộ nhớ chương trình và bộ nhớ dữ liệu có thể làm cho bus dữ liệu và bus chương trình có kích thước băng truyền khác nhau Ta có thể đi tìmhiểu một... vi, với register file Trong khi đó program memory bus có độ rộng 16 bits và chỉ phục vụ cho instruction registers Hình sau mô tả cấu trúc bộ nhớ của AVR Hình 14: Cấu trúc bộ nhớ của AVR Cấu trong bên trong của 1 AVR: 15 KiếntrúcHarvard Linhlg8593@gmail.com Hình 15 Cấu trúc bên trong AVR Bạn thấy rằng 32 thanh ghi trong Register File được kết nối trực tiếp với Arithmetic Logic Unit -ALU (ALU cũng được... CPU RISC khác, ví dụ như ARM, thường cần ít nhất 2 lệnh để load một hằng số đủ kích thước 4.2 AVR: có cấu trúc Harvard, trong đó đường truyền cho bộ nhớ dữ liệu (data memory bus) và đường truyền cho bộ nhớ chương trình (program memory bus) được tách riêng Data memory bus chỉ có 8 bit 14 KiếntrúcHarvard Linhlg8593@gmail.com và được kết nối với hầu hết các thiết bị ngoại vi, với register file Trong khi.. .Kiến trúcHarvard Linhlg8593@gmail.com 4 Hình 11: Nhược điểm của Harvard so với von Neumann Ứng dụng: Thực tế, Những năm gần đây, tốc độ CPU tăng lên rất nhiều lần so với tốc độ truy cập vào bộ nhớ chính Người ta cần quan tâm đến việc . độ… 3.2. Phân loại theo kiến trúc • SISD (single instruction - single data) • SIMD (Single Instruction Multiple Data) • MIMD (Multiple Instruction Multiple Data) • Hai kiến trúc phổbiến Von. <-> CPU <-> Bộnhớdữliệu <-> Ngoại vi II. Kiến trúc Harvard. 1. Lịch sử. Kiến trúc Harvard bắt đầu với máy tính Harvard Mark I, nó cho phép các lệnh được đặt trong các tape đục. bức ảnh sau. Hình 2: Harvard Mark I- một máy tính cơ điện 4 Ki ế n trúc Harvard Linhlg8593@gmail.com Một vài hình ảnh khác: Hình 3 Hình 4 2. Định nghĩa. Cụm từ kiến trúc Harvard được dùng để