Kiến trúc máy tính và hệ điều hành

* Cấu trúc tuần tự: 3.1.1. Tuần tự Von Neumann và Pipeline CHƯƠNG 3: KỸ THUẬT PIPELINING + Thực hiện các lệnh một cách tuần tự. + 5 khâu : - IF (Instruction Fetch) : Nhận lệnh - ID (Instruction Decode) : Giải mã lệnh - DF (Data Fetch) : Nhận dữ liệu - EX (Execution) : Thực hiện lệnh - DS (Data Save) : Lưu kết quả

pdf23 trang | Chia sẻ: tlsuongmuoi | Lượt xem: 2249 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Kiến trúc máy tính và hệ điều hành, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
KIẾN TRÚC MÁY  TÍNH VÀ HỆ ĐIỀU  HÀNH 3.1. K  thu t Pipeliningỹ ậ 3.2.  i u khi n PipeliningĐ ề ể CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ 3.1. K  thu t Pipeliningỹ ậ * C u trúc tu n t :ấ ầ ự 3.1.1. Tu n t  Von Neumann và Pipelineầ ự CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Th c hi nự ệ các l nh m t cách tu n t .ệ ộ ầ ự + 5 khâu : - IF (Instruction Fetch) : Nh n l nhậ ệ - ID (Instruction Decode) : Gi i mã l nhả ệ - DF (Data Fetch) : Nh n d li uậ ữ ệ - EX (Execution) : Th c hi n l nhự ệ ệ - DS (Data Save) : L u k t quư ế ả 3.1. K  thu t Pipeliningỹ ậ * C u trúc tu n t :ấ ầ ự 3.1.1. Tu n t  Von Neumann và Pipelineầ ự CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Ví d :ụ - Gi s m i l nh th c hi n trong 1 chu kì ả ử ỗ ệ ự ệ τ - V i n l nh :ớ ệ Ttu n t ầ ự= τ *n - M i khâu th c hi n trong th i gian ỗ ự ệ ờ τ /5 3.1. K  thu t Pipeliningỹ ậ * C u trúc tu n t :ấ ầ ự 3.1.1. Tu n t  Von Neumann và Pipelineầ ự CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + H n ch :ạ ế - Các l nh đ c th c hi n liên ti p nhauệ ượ ự ệ ế - Xu t hi n kho ng th i gian r i (stall) gi a các khâuấ ệ ả ờ ỗ ữ - L nh tr c th c hi n xong m i đ n l nh sauệ ướ ự ệ ớ ế ệ K thu t pipeline đ c đ a ra đ t n d ng nh ng ỹ ậ ượ ư ể ậ ụ ữ stall này, t đó tăng t c đ cho vi x lýừ ố ộ ử 3.1. K  thu t Pipeliningỹ ậ * C u trúc Pipeline:ấ 3.1.1. Tu n t  Von Neumann và Pipelineầ ự CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + 5 khâu c a m t l nh trong ủ ộ ệ MIPS (Microprocessor without Interlocked Pipeline Stages) 1. F (Fetch) : Nh n l nh.ậ ệ 2. D (Decode) : Gi i mã l nh.ả ệ 3. X (Execution) : Th c hi n l nh.ự ệ ệ 4. M (Memory Access) : Truy nh p b nh .ậ ộ ớ 5. W (Result Write Back) : Ghi k t quế ả 3.1. K  thu t Pipeliningỹ ậ * C u trúc Pipeline:ấ 3.1.1. Tu n t  Von Neumann và Pipelineầ ự CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Mô hình Pipeline lý t ng: thông l ng trung bình là 1 ưở ượ CPI (Clock Cycle per Instruction) 3.1. K  thu t Pipeliningỹ ậ * C u trúc Pipeline:ấ 3.1.1. Tu n t  Von Neumann và Pipelineầ ự CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ - Tính toán: Th i gian đ th c hi n 1 công đo n là ờ ể ự ệ ạ τ /5. Th i gian đ th c hi n 1 l nh là ờ ể ự ệ ệ τ Th i gian đ th c hi n 2 l nh là ờ ể ự ệ ệ τ + τ /5 Th i gian đ th c hi n 3 l nh là ờ ể ự ệ ệ τ + τ *2/5 … Th i gian đ th c hi n n l nh là ờ ể ự ệ ệ τ + τ *(n-1)/5 + Mô hình Pipeline lý t ng:ưở Tpipeline = τ + τ * (n-1)/m 3.1. K  thu t Pipeliningỹ ậ * Đ nh nghĩa Pipelining:ị 3.1.1. Tu n t  Von Neumann và Pipelineầ ự CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + K thu t th c hi n l nh trong đó các l nh đ c th c ỹ ậ ự ệ ệ ệ ượ ự hi n theo ki u g i đ u nh m t n d ng nh ng kho ng ệ ể ố ầ ằ ậ ụ ữ ả th i gian r i (stalls) gi a các công đo n (stages), qua đó ờ ỗ ữ ạ làm tăng t c đ th c hi n l nh c a vi x lí (VXL).ố ộ ự ệ ệ ủ ử + Trong tr ng h p không có xung đ t có th tăng t c ườ ợ ộ ể ố đ vi x lý lên 400%.ộ ử 3.1. K  thu t Pipeliningỹ ậ * Xung đ t c u trúc (Structural Hazard)ộ ấ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ * Xung đ t d li u (Data Hazard)ộ ữ ệ * Xung đ t đi u khi n (Control Hazard)ộ ề ể 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t c u trúc: ộ ấ x y ra khi có 2 l nh cùng c ả ệ ố g ng s d ng cùng 1 ngu n t i cùng 1 th i đi mắ ử ụ ồ ạ ờ ể - Khi 2 l nh cùng ghi k t qu vào 1 thanh ghi:ệ ế ả ADD R1, R2, R3 SUB R1, R4, R5 - Khi c 2 l nh cùng truy c p vào 1 ô nh t i cùng ả ệ ậ ớ ạ m t th i đi m.ộ ờ ể - Khi c 2 l nh cùng yêu c u m t b tính toán s ả ệ ầ ộ ộ ố h c (b c ng, b nhân, b chia).ọ ộ ộ ộ ộ 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t c u trúc: ộ ấ - Xung đ t x y ra khi ộ ả vi c n p l nh và đ c ệ ạ ệ ọ d li u t b nh ữ ệ ừ ộ ớ di n ra cùng lúcễ - Nh ng kí hi u “o” chèn vào t ng tr ng cho chu kì tr ữ ệ ượ ư ễ (stall cycles) s đ c s d ng n u ta s d ng b nh đ n ẽ ượ ử ụ ế ử ụ ộ ớ ơ l u tr c l nh vào d li uư ữ ả ệ ữ ệ 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t c u trúc: ộ ấ - Khi c stage X và D đ u yêu c u b c ng, mà ch có 1 ả ề ầ ộ ộ ỉ b c ng trong VXLộ ộ 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t d li u: ộ ữ ệ - RAW (Read after Write): Instruction 1: ADD R2, R1, R3 R2 <- R1 + R3 Instruction 2: ADD R4, R2, R3 R4 <- R2 + R3 I1 F D X M W I2 F D X M W 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t d li u: ộ ữ ệ - WAR (Write after Read): Instruction 1: ADD R1, R2, R3 R1 <- R2 + R3 Instruction 2: ADD R3, R4, R5 R3 <- R4 + R5 I1 F D X M W I2 F D X M W 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t d li u: ộ ữ ệ - WAW (Write after Write) Instruction 1: ADD R2, R1, R3 R2 <- R1 + R3 Instruction 2: ADD R2, R4, R7 R2 <- R4 + R7 I1 F D X M W I2 F D X M W 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t đi u khi n: ộ ề ể -Control Hazard x y ra khi có l nh r nhánhả ệ ẽ -Khi l nh r nhánh đ c yêu c u th c hi n, con tr ệ ẽ ượ ầ ự ệ ỏ b đ m ch ng trình (PC) s chuy n t i đ a ch đích ộ ế ươ ẽ ể ớ ị ỉ b ng cách c ng thêm 4ằ ộ  Nh y t i đúng đ a ch đích: r nhánh ả ớ ị ỉ ẽ Taken  Tr ng h p ng c l i g i là nhánh ườ ợ ượ ạ ọ Untaken. -Khi l nh i có nhánh taken thì PC s không thay đ i ệ ẽ ổ nh bình th ng t i h t khâu M (memory access)ư ườ ớ ế 3.1. K  thu t Pipeliningỹ ậ 3.1.2. Xung  t (Hazard)độ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t đi u khi n: ộ ề ể -Ph ng pháp đ n gi n nh t đ kh c ph c control ươ ơ ả ấ ể ắ ụ hazard là gây tr k p th i trên pipeline đ phát hi n nhánh ễ ị ờ ể ệ cho đ n khâu M, s d ng giá tr m i c a PC.ế ử ụ ị ớ ủ L nh nhánhệ F D X M W Nhánh k th aế ừ F Stall Stall F D X M W Nhánh k th a +1ế ừ F D X M W Nhánh k th a +2ế ừ F D X M W Nhánh k th a +3ế ừ F D X M Nhánh k th a +4ế ừ F D X Nhánh k th a +5ế ừ F D 3.2.  i u khi n PipeliningĐ ề ể CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Xung đ t (Hazard) là m t y u t quan tr ng nh h ng ộ ộ ế ố ọ ả ưở tr c ti p t i t c đ c a VXL trong k thu t Pipelineự ế ớ ố ộ ủ ỹ ậ + M t s k thu t gi i quy t xung đ t ch y u:ộ ố ỹ ậ ả ế ộ ủ ế - Chèn trễ - T ch c l i các l nhổ ứ ạ ệ - S d ng đ ng d li u n i đ c bi tử ụ ườ ữ ệ ộ ặ ệ - Tomasulo - Đ nh bi uị ể 3.2.  i u khi n PipeliningĐ ề ể 3.2.1. Chèn trễ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + K thu t chèn tr đ c s d ng khá h u hi u đ gi i ỹ ậ ễ ượ ử ụ ữ ệ ể ả quy t các xung đ t v c u trúc cũng nh v d li u:ế ộ ề ấ ư ề ữ ệ + Ví d :ụ + Xung đ t d li u x y ra khi l nh 1 ch a l u k t qu vào ộ ữ ệ ả ệ ư ư ế ả R1 thì l nh 2 đã th c hi n tr R1 cho R5 (RAW)ệ ự ệ ừ 3.2.  i u khi n PipeliningĐ ề ể 3.2.1. Chèn trễ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Chèn tr :ễ + K thu t chèn tr này ho t đ ng khá n đ nh, tuy nhiên ỹ ậ ễ ạ ộ ổ ị v n còn ch a t n d ng đ c nhi u chu kỳ nhàn r i c a ẫ ư ậ ụ ượ ề ỗ ủ máy, do đó hi u su t ch a cao.ệ ấ ư 3.2.  i u khi n PipeliningĐ ề ể 3.2.2. T  ch c l i các l nhổ ứ ạ ệ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + K thu t này đòi h i trình d ch ph i d đoán đ c s ỹ ậ ỏ ị ả ự ượ ự ph thu c d li u gi a các l nh, qua đó thay đ i tr t t ụ ộ ữ ệ ữ ệ ổ ậ ự th c hi n l nhự ệ ệ 3.2.  i u khi n PipeliningĐ ề ể 3.2.3. S  d ng  ng d  li u n i  c bi tử ụ đườ ữ ệ ộ đặ ệ CH NG ƯƠ 3: K  THU T PIPELININGỸ Ậ + Giá tr c a bi n s đ c c p nh p r t s m nh s d ng ị ủ ế ẽ ượ ậ ậ ấ ớ ờ ử ụ đ ng d li u n i đ c bi t. Đi u này làm gi m s chu kỳ ườ ữ ệ ộ ặ ệ ề ả ố nhàn r i trong pipeline và tăng t c đ VXLỗ ố ộ

Các file đính kèm theo tài liệu này:

  • pdfKiến trúc máy tính và hệ điều hành.pdf
Tài liệu liên quan