Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Question: Right before your function f from Exercise 2.34 returns, what do we know about contents of registers \(t5, \)s3, \(ra, and \)sp? Keep in mind that we know what the entire function f looks like, but for function func, we only know its declaration.

Short Answer

Expert verified

The register ‘$ra’ returns the address of the variable. There will be no change in the value of ‘$sp,’ ‘$s3’. The register ‘$t5’ contains some random values.

Step by step solution

01

MIPS language

The language MIPS was started by John L. Hennessy, the tenth president of Stanford University, who worked in the electrical engineering and computer science department. He is the co-founder of the MIPS computer systems now known as MIPS technologies. They developed one of the first commercial RISC microprocessors. Every processor performs a different type of operation like arithmetic, and these instructions can be easily expressed by the MIPS notation. Some of the operations performed by the processors are arithmetic, data transfer, logical, conditional, and unconditional branches.

02

Contents of the registers

The function from exercise 2.34 is as follows:

int f(int a, int b, int c, int d)

{

return func(func(a,b),c+d);

}

The above function calls another function “func” inside of it, bypassing the argument, and the return value is an integer type.

Here the register ‘$ra,’ which is m, means to return the address for the variable inwhich the function is called. The registers ‘$sp’ and ‘$s3’ will have the same values they contain when the function f is called. Register ‘$t5’ contains the random value. Because the function f is not modifying the ‘$t5’but the function “func“ has permission to change it, we cannot predict the values of the register “$t5,” and the function “func” is called inside the function “f.”

The “ra” in the MIPS instruction is an instruction that means to return the address.

The “sp” in the MIPS instruction is an instruction that means the top of the stack pointer.

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Most popular questions from this chapter

Rewrite the loop from Exercise 2.29 to reduce the number of MIPS instructions executed

Question: Find the shortest sequence of MIPS instructions that extracts bits 16 down to 11 from register \(t0 and uses the value of this field to replace bits 31 down to 26 in register \)t1 without changing the other 26 bits of register $t1.

Translate the following loop into C. Assume that the C-level integer i is held in register \(t1, \)s2 holds the C-level integer called result, and \(s0 holds the base address of the integer MemArray.

addi \)t1, \(0, \)0

LOOP: lw \(s1, 0(\)s0)

add \(s2, \)s2, \(s1

addi \)s0, \(s0, 4

addi \)t1, \(t1, 1

slti \)t2, \(t1, 100

bne \)t2, $s0, LOOP

Question 2.4 [5] For the MIPS assembly instructions below, what is the corresponding C statement? Assume that the variables f, g, h, i, and j are assigned to registers \(s0, \)s1, \(s2, \)s3, and \(s4, respectively. Assume that the base address of the arrays A and B are in registers \)s6 and \(s7, respectively.

sll \)t0, \(s0, 2 # \)t0 = f * 4

add \(t0, \)s6, \(t0 # \)t0 = &A[f]

sll \(t1, \)s1, 2 # \(t1 = g * 4

add \)t1, \(s7, \)t1 # \(t1 = &B[g]

lw \)s0, 0(\(t0) # f = A[f]

addi \)t2, \(t0, 4

lw \)t0, 0(\(t2)

add \)t0, \(t0, \)s0

sw \(t0, 0(\)t1)

Question: Translate the following C code to MIPS. Assume that the variables f, g, h, i , and j are assigned to registers \(s0,\)s1,\(s2,\)s3, and \(s4, respectively. Assume that the base address of the arrays A and B are in registers \)s6 and $s7 respectively. Assume that the elements of the arrays A and B are 4 byte words:

B[8]=A[i]+A[j];

See all solutions

Recommended explanations on Computer Science Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free