1. Trang chủ
  2. » Giáo Dục - Đào Tạo

Bài tập assembly kiến trúc máy tính uit có đáp án

11 146 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 11
Dung lượng 245,28 KB

Nội dung

Khoa Kỹ thuật Máy tính – Đại học Cơng Nghệ Thông Tin 2015 Bài Tập Chương -oOo Các tập chương trích dẫn dịch lại từ: Computer Organization and Design: The Hardware/Software Interface, Patterson, D A., and J L Hennessy, Morgan Kaufman, Revised Fourth Edition, 2011 -Lưu ý: Các mảng sử dụng chương mảng mà phần tử chứa word/từ nhớ, từ nhớ chứa bytes -Bài Phần a) f = g + h + i + j; b) f = g + (h + 5); g, h, i, j số nguyên 32-bit 1.1 Hãy tìm mã hợp ngữ MIPS tương đương lệnh C 1.2 Có lệnh MIPS để thực lệnh C 1.3 Nếu biên f, g, h, i j có giá trị tương ứng 1, 2, 3, 4, giá trị f bao nhiêu? Phần a add f, g, h b addi f, f, add f, g, h 1.4 Tìm lệnh C tương đương với lệnh hợp ngữ MIPS 1.5 Nếu giá trị f, g, h i có giá trị tương ứng 1, 2, giá trị cuối f bao nhiêu? Trả lời: Phần 1.1 a add f, g, h add f, f, i add f, f, j b Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Công Nghệ Thông Tin 2015 addi f, h, add f, f, g 1.2 a b 1.3 a 14 b 10 Phần 1.4 a f = g + h b   addi f,  f, f = f + add f, g, h f = g + h Cuối f = g + h 1.5 a b Bài Phần a f = g + h + B[4]; b f = g – A[B[4]]; f, g, h, i, j lưu ghi $s0, $s1, $s2, $s3, $s4 Địa sở/nền (base address) mảng A B lưu ghi $s6, $s7 Mỗi phần 2.1 Hãy chuyển câu lệnh C bên sang dạng hợp ngữ MIPS 2.2 Cần lệnh hợp ngữ MIPS để có chức tương đương với câu lệnh C? 2.3 Có ghi khác dùng cho câu lệnh C bên Phần a add $s0, $s0, $s1 add $s0, $s0, $s2 add $s0, $s0, $s3 add $s0, $s0, $s4 b lw $s0, 4($s6) 2.4 Hãy tìm câu lệnh C tương đương với câu lệnh hợp ngữ MIPS bên 2.5 Hãy thử rút gọn số lượng lệnh hợp ngữ MIPS 2.6 Có ghi sử dụng đoạn hợp ngữ trên? Nếu ta rút gọn số lệnh ta cần ghi? Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Cơng Nghệ Thơng Tin 2015 Trả lời: 2.1 Lệnh hợp ngữ MIPS tương ứng: a) f = g + h + B [ ] ; lw $s0, 16($s7)# Bởi MIPS định địa theo byte word chứa byte a d d $ s 0, $ s 0, $ s a d d $ s 0, $ s 0, $ s b) f = g – A[B[4]]; lw $t0, 16($s7) sll $t0, $t0, add $t0, $t0, $s6 lw $s0, 0($t0) sub $s0, $s1, $s0 # $t0=B[4] # $t0=B[4] * # $t0=&A[B[4]] 2.2 a) b) tron g than h ghi $s6 byte Nếu xem nội dung than h ghi $s6 địa mản g A, lệnh đọc nội dung phần tử thứ mản g, tức phần tử A[1] ) 2.5 a) 2.3 a) b) 2.4 Tìm lệnh C tương đương với chuỗi lệnh hợp ngữ:  f=f+h  add $s0, $s0, $s2 f=f+h+g add $s0, $s0, $s1 add $s0, $s0, $s3 a) b)  f=f+h+g+i  add $s0, $s0, $s4 f=f+h+g+i+j f = f+g+h+i+j; f = A[1]; (lw $s0, 4($s6): Lệnh đọc liệu từ nhớ cách địa chứa b) K h ô n g đ ổ i K h ô n g đ ổ i 2.6 a) Có ghi (khơng thể rút gọn nhỏ hơn) b) Có ghi (không thể rút gọn nhỏ hơn) Bài a f = -g + h + B[1]; b f = A[B[g] + 1]; f, g, h, i, j lưu ghi $s0, $s1, $s2, $s3, $s4 Địa sở hai chuỗi A B lưu ghi $s6, $s7 3.1 Hãy tìm lệnh hợp ngữ MIPS tương đương với câu lệnh C bên Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Công Nghệ Thông Tin 2015 3.2 Cần lệnh hợp ngữ MIPS để có chức tương đương với câu lệnh C? 3.3 Có ghi khác dùng cho câu lệnh C bên Trả lời: 3.1 a f = -g + h + B[1]; lw $s0, 4($s7) sub $s0, $s0, $s1 add $s0, $s0, $s2 b f = A[B[g] + 1]; # tìm B[g] sll $t0, $s1, add $t0, $t0, $s7 lw $t0, 0($t0) # tính B[g] + addi $t0, $t0, # tìm A[B[g] + 1] sll $t0, $t0, add $t0, $t0, $s6 lw $s0, 0($t0) # $t0 = B[g] # $t0 = B[g] +  Có thể viết gọn với lệnh MIPS khơng? Có thể sử dụng ghi không? Bài Các câu hỏi liên quan đến mở rộng dấu tràn Thanh ghi $s0 $s1 lưu giá trị bảng bên Hãy trả lời câu hỏi liên quan đến lệnh hợp ngữ MIPS bên tính tốn kết a $s0 = 0x70000000; $s1 = 0x0FFFFFFF b $s0 = 0x40000000; $s1 = 0x40000000 Ghi chú: Khi 0x trước giá trị giá trị biểu diễn hệ 16 4.1 Tính kết $t0 sau thực câu lệnh: add $t0, $s0, $s1 Kết ghi $t0 mong muốn phép tốn chưa? Có xảy tràn khơng? 4.2 Tính kết $t0 sau thực câu lệnh: sub $t0, $s0, $s1 Kết ghi $t0 mong muốn phép tốn chưa? Có xảy tràn khơng? 4.3 Tính kết $t0 sau chạy chuỗi lệnh: Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Công Nghệ Thông Tin 2015 add $t0, $s0, $s1 add $t0, $t0, $s0 Kết ghi $t0 mong muốn phép toán chưa? Có xảy tràn khơng? Trả lời: 4.1 a $s0 = 0x70000000; $s1 = 0x0FFFFFFF; add $t0, $s0, $s1 Sau thực câu lệnh trên, $t0 = 0x7FFFFFFF Kết mong muốn, không tràn b $s0 = 0x40000000; $s1 = 0x40000000; add $t0, $s0, $s1 Sau thực câu lệnh trên, $t0 = 0x80000000 Phép tốn add thực số có dấu (dùng bù hai) Phép cộng thực cộng hai số dương, kết 0x80000000 rõ ràng số âm 4.2 sub $t0, $s0, $s1 a) $t0 = 0x60000001, không tràn b) $t0 = 0, khơng tràn  phép tồn bị tràn 4.3 add $t0, $s0, $s1 add $t0, $t0, $s0 a) $t0 = 0x70000000 + (0x70000000 + 0x0FFFFFFF) = 0xEFFFFFFF Tràn, cộng hai số dương bit dấu kết lại âm, không b) $t0 = 0x40000000 + (0x40000000 + 0x40000000) = 0xC0000000 Tràn, cộng hai số dương bit dấu kết lại âm, không Bài Chuyển mã máy sau sang dạng hợp ngữ MIPS 5.1 & 5.2 Từ giá trị binary bảng trên, xác định chuỗi nhị phân thể lệnh gì? Xác định lệnh thuộc kiểu lệnh (I-type, R-type, J-type) Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Công Nghệ Thông Tin 2015 Chú ý: Tham khảo “MIPS reference data” (trang 2, sách tham khảo) để dị tìm opcode lệnh 5.3 Nếu chuỗi nhị phân liệu đơn Hãy chuyển chúng sang dạng mã HEX 5.4 & 5.5 Hãy dịch lệnh sau sang dạng mã máy a) add $t0, $t0, $zero b) lw $t1, 4($s3) 5.6 Hãy trình bày dạng mã HEX trường opcode, Rs Rt lệnh Đối với lệnh kiểu R, trình bày dạng mã HEX trường Rd funct Đối với lệnh kiểu I, trình bày dạng mã HEX trường trực tiếp (immediate field) Answer: 5.1 & 5.2  a) op = 101011(2) = 2B(hex) khảo)  Lệnh sw (tra bảng “MIPS reference data”, trang 2, sách tham dạng I-type rs = 10000(2) = 16(10): địa lưu ghi thứ 16, ghi $s0 rt = 01011(2) = 11(10): ghi thứ 11, ghi $t3 Immediate(16 bit) = 100(2) = 4(10)  Lệnh assembly là: sw $t3, 4($s0) b) op = 100011(2) = 23(10)  Lệnh lw type instruction  I- rs = 01000(2) = 8(10): ghi thứ 8, ghi $t0 rt = 01000(2) = 8(10): ghi thứ 8, ghi $t0 Immediate (16 bit) = 1000000(2) = 64(10) =>Lệnh assembly: lw $t0, 64($t0) 5.3 a) 0xAE0B0004 b) 0x8D080040 5.4 & 5.5 a) add $t0, $t0, $zero add: R-type format opcode = 0hex rs = 8ten ($t0 ghi thứ 8/ $t0 ghi có số 8) Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Cơng Nghệ Thơng Tin 2015 rt = 0ten ($zero ghi thứ 0) rd = 8ten ($t0 ghi thứ 8) shamt = 0ten (không sử dụng) func = 20hex 1= 00000(2)  Machine code: 0000 0001 0000 0000 0100 0000 0010 0000bin = 01004020hex b) lw: I-type format opcode = 23hex rs = 19ten = 10011bin ($s3 ghi thứ 19) rt = 9ten ($t1 ghi thứ 9) immediate = 4ten  Machine code: 1000 1110 0110 1001 0000 0000 0000 0100bin = 8E690004hex 5.6 a) op=0x0; rs=0x8; rt=0x0; rd=0x8; shamt=0x0; func=0x20 b) op=0x23; rs=0x13; rt=0x9; imm=0x4 Bài Cho giá trị ghi sau: 6.1 Hãy cho biết giá trị ghi $t2 sau chạy lệnh sau: sll $t2, $t0, or $t2, $t2, $t1 6.2 Hãy cho biết giá trị ghi $t2 sau chạy lệnh sau: srl $t2, $t0, andi $t2, $t2, 0xFFEF Trả lời: 6.1 Tìm giá trị $t2 a) 0x57755778 b) 0xFEFFFEDE 6.2 Tìm giá trị $t2 a) 0x0000AAAA b) 0x0000BFCD Bài Giá trị ghi $t0 cho bảng bên 7.1 Giả sử ghi $t0 chứa giá trị bảng $t1 có giá trị Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Cơng Nghệ Thông Tin 2015 Hãy cho biết giá trị $t2 sau chạy lệnh # set on less than # go to ELSE if $t2=0 # go to DONE # $t2 = 0+2 7.2 Giả sử ghi $t0 chứa giá trị bảng so sánh với giá trị X lệnh MIPS bên Hãy ý cấu trúc lệnh slti Tìm giá trị X (nếu có) để $t2 có giá trị slti $t2, $t0, X 7.3 Giả sử trỏ PC có giá trị 0x0000 0020 Ta sử dụng lệnh nhảy hợp ngữ MIPS (lệnh j) để nhảy đến địa có giá trị bảng hay khơng Tương tự, ta sử dụng lệnh nhảy-nếu-bằng (lệnh beq) để nhảy đến địa có bảng hay khơng Answer: 7.1 a “slt” làm việc vơí số có dấu: Nếu ghi $t0 nhỏ nhon ghi $t1 ghi $t2 nhận giá trị 1; ngược lại $t2 nhận giá trị $t0 = 1010 1101 0001 0000 0000 0000 0000 0010(2) $t1 = 0011 1111 1111 1000 0000 0000 0000 0000 Rõ ràng $t0 số âm, ghi $t1 số dương, $t0 < $t1  beq điều kiện không xảy tự $t2=1   $t2 = lệnh “j DONE” thực  $t2 = b Tương 7.2 a) $t0 = 1010 1101 0001 0000 0000 0000 0000 0010(2)  $t0 = - 1,391,460,350 Xét lệnh: slti $t2, $t0, X Nếu $t0 < X $t2 nhận giá trị 1; ngược lại $t2 nhận giá trị Vậy theo yêu cầu đề bài, để sau lệnh này, giá trị ghi $t2 = X phải có giá trị lớn $t0 Mặt khác, X có biểu diễn tối đa 16 bits, có dấu theo bù 2, nên giá trị 15 khơng thể vượt q -1 = 32767 b)  Vậy X từ -1,391,460,349 tới 32767 Tương tự, X từ tới 32767 7.3 PC = 0x0000 0020  Ta sử dụng lệnh nhảy j hợp ngữ MIPS để trỏ PC trỏ tới địa ghi bảng khơng? Giải thích? a) Không Dịch: Nguyễn Hữu Nhân & Trần Thị Như Nguyệt Trang Khoa Kỹ thuật Máy tính – Đại học Công Nghệ Thông Tin 2015 b) Không Lệnh Jump (j) thuộc kiểu lệnh J nên trường địa (address) có 26 bit Địa mà lệnh j nhảy tới, tức địa gán cho trỏ PC tính cách: JumpAddr = { PC+4[31:28], address, 2’b0 } (Xem bảng trang sách tham khảo) Tức vùng address mã máy lệnh j lấy ra, dịch trái bit; sau gán thêm bit cao lấy từ bit cao (từ 28 tới 31) PC +  PC 0x0000 0020 PC + = 0x00000024 bit từ 28 tới 31 PC + = 0000(2)  PC mới, nơi mà lệnh j nhảy tới có giá trị: bit từ 28 tới 31 (PC + 4) 26 bits trường address mã máy j Vậy bit cao PC với lệnh j phải có 0000 Những giá trị cho bảng có giá trị lớn 0000 Vì khơng thể sử dụng lệnh j để nhảy tới địa bảng  Ta sử dụng lệnh “nhảy bằng” (beq) hợp ngữ MIPS để PC trỏ tới địa cho bảng khơng? Giải thích? a) Khơng b) Khơng Lệnh beq thuộc kiểu I-type Ví dụ lệnh beq $t0, $t1, Thì lưu vào trường immediate Khi beq thực lệnh nhảy, giá trị gán cho PC = PC + + (immediate x 4) Hay: PC = PC + + (immediate

Ngày đăng: 20/10/2021, 09:39

TỪ KHÓA LIÊN QUAN

w