1. Trang chủ
  2. » Giáo án - Bài giảng

kiến trúc máy tính trương văn cường ôn thi cuối kỳ sinhvienzone com

31 104 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 31
Dung lượng 1,19 MB

Các công cụ chuyển đổi và chỉnh sửa cho tài liệu này

Nội dung

PIPELINED PROCESSORChapter 4 — The Processo r — 15 Structure Hazards • Xung đột do việc sự dụng nguồn tài nguyên • MIPS pipeline với một single memory • Load/store yêu cầu truy xuất dữ

Trang 1

COMPUTER ARCHITECTURE

Trang 2

Nội dung

• Số floating point

• Bộ xử lý (The Processor)

• Đường dữ liệu

• Đường điều khiển

• Pipelined Datapath and Control

• Hazards

• Structural Hazards

• Data Hazards

• Control Hazards

Trang 3

PIPELINED PROCESSOR

IEEE Floating-Point Format

• S: bit dấu (0 số khôn âm, 1 số âm)

• Chuẩn hóa phần lẻ (F): 1.0 ≤ |significand| < 2.0

• Phần mũ: phần mũ thực + Bias

• Chắc chắn số mũ là không dấu ( ex: 2 -1 = 2 126-127 , F = 126 thay vì F= -1)

• Chính xác đơn: Bias = 127; Chính xác kép: Bias = 1023

single: 8 bits double: 11 bits single: 23 bitsdouble: 52 bits

Bias) (Exponent

S

2 Fraction)

(1 1)

( x

Trang 7

PIPELINED PROCESSOR

MIPS Pipeline

• Chia làm 5 tầng, mỗi bước 1 tầng

1 IF: Instruction fetch from memory (Nạp lệnh)

2 ID: Instruction decode & register read (Giải mã lệnh &

đọc thanh ghi)

3 EX: Execute operation or calculate address (Thực thi

phép toán hoặc tính địa chỉ)

4 MEM: Access memory operand (truy xuất toán hạng

bộ nhớ)

5 WB: Write result back to register (ghi kết quả vào

thanh ghi)

Trang 8

PIPELINED PROCESSOR

The Five Stages of Load Instruction

• IF: Nạp lệnh và cập nhật PC

• Dec: Nạp các thanh ghi và giải mã lệnh

• Exec: Tính toán địa chỉ bộ nhớ

• Mem: đọc dữ liệu từ bộ nhớ

• WB: ghi dữ liệu đọc được vào thanh ghi

Cycle 1 Cycle 2 Cycle 3 Cycle 4 Cycle 5

lw

Trang 9

MemWrite MemRead

Main Decoder

Controller

MIPS Processor

Data Memory

Instruction Memory

32 32 32

ReadData

RD

RD ADDR Instr

ALUOut WriteData PC

Trang 10

R-type Instruction Data/Control Flow

Read Address Instr[31-0]

Instruction Memory Add

PC

4

Write Data

Read Addr 1 Read Addr 2 Write Addr

Register File

Read Data 1

Read Data 2

MemtoReg

ALUSrc

Shift left 2

Add

PCSrc

RegDst

ALU control

1

1 1

0

0

0

0 1

Control Unit

Instr[31-26]

Branch

Trang 11

Load Word Instruction Data/Control Flow

Read Address Instr[31-0]

Instruction Memory Add

PC

4

Write Data

Read Addr 1 Read Addr 2 Write Addr

Register File

Read Data 1

Read Data 2

MemtoReg

ALUSrc

Shift left 2

Add

PCSrc

RegDst

ALU control

1

1 1

0

0

0

0 1

Control Unit

Instr[31-26]

Branch

Trang 12

Store Word Instruction Data/Control Flow

Read Address Instr[31-0]

Instruction Memory Add

PC

4

Write Data

Read Addr 1 Read Addr 2 Write Addr

Register File

Read Data 1

Read Data 2

MemtoReg

ALUSrc

Shift left 2

Add

PCSrc

RegDst

ALU control

1

1 1

0

0

0

0 1

Control Unit

Instr[31-26]

Branch

Trang 13

Adding the Jump Operation

Read Address Instr[31-0]

Instruction Memory Add

PC

4

Write Data

Read Addr 1 Read Addr 2 Write Addr

Register File

Read Data 1

Read Data 2

MemtoReg

ALUSrc

Shift left 2

Add

PCSrc

RegDst

ALU control

1

1 1

0

0

0

0 1

Control Unit

Instr[31-26]

Branch

Shift left 2

0 1

Trang 14

PIPELINED PROCESSOR

Pipeline Control

• IF Stage: read Instr Memory (always asserted) and write PC (on System Clock)

• ID Stage: no optional control signals to set

Reg

Dst

ALU Op1

ALU Op0

ALU Src

Brch Mem

Read

Mem Write

Reg Write

Mem toReg

Trang 15

PIPELINED PROCESSOR

Chapter 4

— The Processo

r — 15

Structure Hazards

• Xung đột do việc sự dụng nguồn tài nguyên

• MIPS pipeline với một single memory

• Load/store yêu cầu truy xuất dữ liệu

• Nạp lệnh có thể phải stall cho chu kỳ đó

• Would cause a pipeline “bubble”

• Vì vậy, pipelined datapaths bộ nhớ độc lậpinstruction/data

• Hoặc instruction/data caches

Trang 16

Mem Reg Mem Reg

A Single Memory Would Be a

Structural Hazard

Reading data from memory

Reading instruction from memory

 Fix with separate instr and data memories (I$ and D$)

Trang 17

PIPELINED PROCESSOR

Data Hazards

• Một lệnh phụ thuộc vào việc hoàn thành truy xuất

dữ liệu bởi một lệnh trước đó

• add $s0 , $t0, $t1

sub $t2, $s0 , $t3

Trang 18

CSE431 Chapter 4B.18 Irwin, PSU, 2008

Trang 19

CSE431 Chapter 4B.20 Irwin, PSU, 2008

Another Way to “Fix” a Data Hazard

they are available

to where they are

Trang 20

CSE431 Chapter 4B.21 Irwin, PSU, 2008

Xung đột dữ liệu

Tóm lại, với kỹ thuật forwarding có:

ALU-ALU forwarding hay EX-EX forwarding (hình 1)

MEM-ALU forwarding hay MEM-EX forwarding (hình 2)

Hình 1.

Hình 2.

Trang 21

Cho chuỗi lệnh như sau :

lw $1, 40($6)

add $6, $2, $2

sw $6, 50($1)

1 Trong trường hợp pipeline 5 tầng và không dùng

kỹ thuật nhìn trước (no forwarding), sử dụng lệnh

‘nop’ để giải quyết xung đột xảy ra (nếu có) trong

chuỗi lệnh trên

2 Trong trường hợp pipeline 5 tầng và có kỹ thuật nhìn trước (forwarding), sử dụng lệnh ‘nop’ để giải quyết xung đột xảy ra (nếu có) trong chuỗi lệnh trên

Trang 22

PIPELINED PROCESSOR

Control Hazards

Xung đột điều khiển

Một số lệnh nhảy có điều kiện và không điều kiện trong MIPS (branches, jump) tạo ra xung đột điều kiển này

Ví dụ xét đoạn chương trình sau: add $1, $5, $6

beq $1, $2, label

lw $3, 300($s0)

Nếu áp dụng pipeline thông thường, tại chu kỳ thứ ba của pipeline,

khi beq đang thực thi công đoạn ID thì lệnh lw sẽ được nạp vào Nhưng nếu điều kiện bằng của lệnh beq xảy ra thì lệnh thực hiệp tiếp sau đó không phải là lw mà là lệnh được gán nhãn ‘label’, lúc

này xảy ra xung đột điều khiên.

Trang 25

CSE431 Chapter 4B.26 Irwin, PSU, 2008

Datapath Branch and Jump Hardware

Register File

Read Data 1

Read Data 2

ALU

Data Memory

Address Write Data

Read Data

IF/ID

Sign Extend

EX/MEM

MEM/WB

Control

ALU cntrl

Forward Unit

Branch PCSrc

Shift left 2

Add

Shift left 2

Jump

PC+4[31-28]

Trang 26

PIPELINED PROCESSOR

Summary

• All modern day processors use pipelining

• Potential speedup: a CPI of 1 and fast a CC

• Unbalanced pipe stages makes for inefficiencies

• The time to “ fill ” pipeline and time to “ drain ” it can impact speedup for deep pipelines and short code runs

• Must detect and resolve hazards

• Stalling negatively affects CPI (makes CPI less than the ideal

of 1)

Trang 27

PIPELINED PROCESSOR

Assignments

• Trong bài tập này, chúng ta khảo sát pipeline ảnh

hưởng như thế nào tới chu kỳ xung clock (clock

cycle time) của processor Giả sử rằng mỗi công

đoạn (stage) trong pipeline có thời gian thực hiện

2 Thời gian cần thiết để thực hiện lệnh lw, sw, add, beq cho trường hợp processor

có pipeline và không pipeline có thể là bao nhiêu

Trang 28

PIPELINED PROCESSOR

Assignments

• Giả sử rằng các lệnh được thực thi trong

processor được phân rã như sau (áp dụng cho câu

3 và 4)

3 Giả sử rằng không có khoảng thời gian rỗi (stalls) hoặc xung đột (hazards), phần truy xuất bộ nhớ (MEM) và phần truy xuất ghi trên tập thanh ghi (WB) sử dụng bao nhiêu % chu kỳ của toàn chương trình

Trang 29

PIPELINED PROCESSOR

Assignments

• Giả sử rằng các lệnh được thực thi trong

processor được phân rã như sau (áp dụng cho câu

3 và 4)

4 Giả sử có thiết kế mới như sau: mỗi lệnh chỉ sử dụng đúng các giai đoạn cần có của

nó, có thể lấy nhiều chu kỳ để hoàn thành, nhưng một lệnh phải hoàn thành xong thì những lệnh khác mới được nạp vào Thiết kế này tạm gọi là thiết kế đa chu kỳ.

Theo kiểu này, mỗi lệnh chỉ đi qua những công đoạn mà nó thực sự cần (ví dụ, sw chỉ

sử dụng 4 công đoạn, không có công đoạn WB) Tính chu kỳ xung clock, so sánh thời gian thực thi của thiết kế đa chu kỳ này với thiết kế đơn chu kỳ (single cycle design) và pipeline.

(Chú ý: lw: sử dụng 5 stage; sw: 4 stage (không WB); ALU: 4 stage (không MEM), beq 4 stage (không WB))

Trang 30

PIPELINED PROCESSOR

Assignments

• The pipelined MIPS processor is running the following program Which registers are being written, and which are being read on the fifth cycle?

Trang 31

Using a diagram similar to above Figure show the

forwarding and stalls needed to execute the following instructions on the pipelined MIPS processor

add $t0, $s0, $s1

sub $t0, $t0, $s2

lw $t1, 60($t0)

and $t2, $t1, $t0

Ngày đăng: 28/01/2020, 23:15

TỪ KHÓA LIÊN QUAN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

🧩 Sản phẩm bạn có thể quan tâm