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

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];

Short Answer

Expert verified

MIPS code:

sll $t0,$s1,2

add $t0,$t0,$s7

lw $t0, 0($t0)

addi $t0,$t0,1

sll $t0, $t0,2

lw $s0,0($t0)

Step by step solution

01

Define MIPS assembly language.

The MIPS assembly language is the instruction-based programming language. MIPS assembly language uses multiple instructions to perform an operation.

MIPS has operands for 32 registers and in MIPS data must be in registers to perform operations on them.

Some example instructions are as follows:

add $s1,$s2,$s3

The above instruction will add the values in the registers s2 and s3. The result will be stored in the s1 register.

Likewise, MIPS performs all the operations through the registers and memory locations.

02

Determine the MIPS code for the given C statement

The given C statement:

The registers, $s0, $s1, $s2, $s3, and $s4 are assigned with f, g, h, i, and j respectively.

The base address of the arrays A and B are stored in the registers $s6 and $s7. The elements of the arrays are 4 byte words.

With above information, the MIPS code for the given C statement is as follows:

sll $t0,$s1,2

add $t0,$t0,$s7

lw $t0, 0($t0)

addi $t0,$t0,1

sll $t0, $t0,2

lw $s0,0($t0)

Instruction

Explanation

sll $t0,$s1,2

Shift left logical instruction will shift 4 spaces in $s1 register that is g.

$t0ß-4*g

add $t0,$t0,$s7

The values of $t0 and $s7 will be added and the result will be stored in $t0.The $t0 will have the address of array B with value g.

$t0ßAddress of B[g]

lw $t0,0($t0)

Now, the value of B[g] will be loaded to $t0.

$t0ßB[g]

addi $t0,$t0,1

The value of B[g] will be added with the immediate 1.

$t0ßB[g]+1

sll $t0,$t0,2

Now the logical shift of 4 will be pointed to B[g]+1 and the address of B[g]+1 will be assigned.

lw $s0,0($t0)

The f will be assigned with the value of A[B[g]+1]

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

Translate the following MIPS code to C. 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.

addi \)t0, \(s6, 4

add \)t1, \(s6, \)0

sw \(t1, 0(\)t0)

lw \(t0, 0(\)t0)

add \(s0, \)t1, $t0

For the following C statement, what is the corresponding MIPS assembly code? 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.

B8=Ai-j;

For the MIPS assembly instructions in Exercise 2.4, rewrite the assembly code to minimize the number if MIPS instructions (if possible) needed to carry out the same function.

[5] Assume for a given processor the CPI of arithmetic instructions is 1, the CPI of load/store instructions is 10, and the CPI of branch instructions is 3.

Assume a program has the following instruction breakdowns: 500 million arithmetic instructions, 300 million load/store instructions, 100 million branch instructions.

2.46.1 [5] <§2.19> Suppose that new, more powerful arithmetic instructions are added to the instruction set. On average, through the use of these more powerful arithmetic instructions, we can reduce the number of arithmetic instructions needed to execute a program by 25%, and the cost of increasing the clock cycle time by only 10%. Is this a good design choice? Why?

2.46.2 [5] <§2.19> Suppose that we find a way to double the performance of arithmetic instructions. What is the overall speedup of our machine? What if we find a way to improve the performance of arithmetic instructions by 10 times?

Question: Repeat Exercise 2.43, but this time use ll/sc to perform an atomic update of the shvar variable directly, without using lock() and unlock(). Note that in this problem there is no variable lk.

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