Answered You can hire a professional tutor to get the answer.

QUESTION

Paste the code into MIPS Next, please comment each line of code in the .text section. Please do this FIRST! It will make tracing through the code much easier. Once you understand what the code is doin

Paste the code into MIPS

Next, please comment each line of code in the .text section. Please do this FIRST! It will make tracing through the code much easier.

Once you understand what the code is doing, you’ll notice there is a ‘print_a’ function that is not reachable through the execution path of the code as it’s written. Your job is to devise an input that overflows the call stack and overwrites the $ra register causing the program to execute the ‘print_a’ function. Please provide the successful input that triggers the overflow, a screenshot of the successful execution of your attack that prints the A message, and a detailed description of how you figured out how to exploit the buffer overflow and how you devised the proper input.

Code used for the assignment above

.data

str: .asciiz "You've earned an A !"

buffer: .space 28

.text

li $v0,8

la $a0, buffer

li $a1, 28

move $t0,$a0

syscall

move $a0, $t0

jal print

li $v0, 10

syscall

print:

addi $sp, $sp, -20

sw $ra, 16($sp)

sw $a0, 12($sp)

addi $t4, $sp, 0

la $t1, ($a0)

load_str:

lbu $t2, ($t1)

slti $t3, $t2, 1

beq $t2, 48, null

resume:

sb $t2, 0($t4)

addi $t4, $t4, 1

addi $t1, $t1, 1

bne $t3, 1, load_str

li $v0, 4

syscall

lw $ra 16($sp)

lw $a0 12($sp)

jr $ra

null:

addi $t2, $t2, -48

j resume

print_a:

li $v0, 4

la $a0, str

syscall

Link to the code as well: https://github.com/jkovba/jhu_sp20_comporg/blob/master/overflow.s

Show more
LEARN MORE EFFECTIVELY AND GET BETTER GRADES!
Ask a Question