Write a subprogram that accepts 4 values from the argument registers $a0 through $a3 and returns to the caller programme the largest value and the average of $v0 and $v1. The programme must be set up in the following manner: Subprogram largestAndAverage($a1, $a2, $a3, $a4) {  int var0 = $a0, var1 = $a1, var2 = $a2, var3 = $a3;  $s0 = getLarger($a1, $a2);  $s0 = getLarger($s0, $a3);  $v0 = getLarager(s0, $a4); // Largest is in $v0  $v1 = (var0 + var1 + var2 + var3)/ 4; // Aversge is in $v1  return; } Subprogram getLarger($a0, $a1) {  $v0 = $a0  if ($a1 > $a0)  $v0 = $a1  return; } Take note of how var0...var3 are used. The values of $a0 and $a1 (at least) must be placed on the stack since they are not immediately available when needed to compute the average because they are modified during the call to getLarger. You must use the getLarger subprogram displayed above to compute the greatest value for this issue, and it must be called before the average calculation. This indicates that $a0 and $a1 must be kept on the stack at the very least, however I would advise all four be stack variables as shown here. It is possible to create a solution which does not require the use of the stack variables, for example by simply calculating the average first. Such solutions do not answer the issue of how to handle variables that change using the stack, and are thus incorrect.

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

1) Write a subprogram that accepts 4 values from the argument registers $a0 through $a3 and returns to the caller programme the largest value and the average of $v0 and $v1. The programme must be set up in the following manner:

Subprogram largestAndAverage($a1, $a2, $a3, $a4)

{

 int var0 = $a0, var1 = $a1, var2 = $a2, var3 = $a3;
 $s0 = getLarger($a1, $a2);
 $s0 = getLarger($s0, $a3);
 $v0 = getLarager(s0, $a4); // Largest is in $v0

 $v1 = (var0 + var1 + var2 + var3)/ 4; // Aversge is in $v1
 return;
}
Subprogram getLarger($a0, $a1) {
 $v0 = $a0
 if ($a1 > $a0)
 $v0 = $a1
 return;
}
Take note of how var0...var3 are used. The values of $a0 and $a1 (at least) must be placed on the stack since they are not immediately available when needed to compute the average because they are modified during the call to getLarger. You must use the getLarger subprogram displayed above to compute the greatest value for this issue, and it must be called before the average calculation. This indicates that $a0 and $a1 must be kept on the stack at the very least, however I would advise all four be stack variables as shown here.
It is possible to create a solution which does not require the use of the stack variables, for
example by simply calculating the average first. Such solutions do not answer the issue of
how to handle variables that change using the stack, and are thus incorrect.

Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 3 steps with 1 images

Blurred answer
Knowledge Booster
Concept of memory addresses in pointers
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education