The assembler in SPIM automatically assembles code starting at address 0x10000000.
x
?
0x10000000poly
?
0x10000004Here is what this part of the SPIM simulation looks like:
Here is an important addition to the program. Decide on the registers you need and what they are used for. Then write down your decisions! This is crucial for getting things correct.
A register where a value is built up after several calculations is called an accumulator. (Some old processors have a single, special register that is used for this purpose. But MIPS has many general purpose registers for this).
Remember that data loaded from memory is not
available to the instruction following the load.
The instruction after a
lw
,
in the "load delay slot",
should not try to use the loaded data.
Fill in the blanks.
Look at the previous answer to help with
the lui
instruction.
Use it to load the upper half of the base register with
the upper half of the first data address.