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

Write a program in MIPS assembly language to convert an ASCII number string containing positive and negative integer decimal strings, to an integer. Your program should expect register \(a0 to hold the address of a null-terminated string containing some combination of the digits 0 through 9. Your program should compute the integer value equivalent to this string of digits, then place the number in register \)v0. If a non-digit character appears anywhere in the string, your program should stop with the value -1 in register \(v0. For example, if register \)a0 points to a sequence of three bytes 50ten, 52ten, 0ten (the null-terminating string “24”), then when the program stops, register $v0 should contain the value 24ten.

Short Answer

Expert verified

The MIPS program to convert an ASCII number string containing positive and negative integer decimal strings to an integer is as follows:

MAIN: add $sp, $sp, -4

sw $ra, ($sp)

add $t6, $0, 0x30 # ‘0’

add $t7,$0, 0x39 # ‘9’

add $s0, $0, $0

add $t0, $a0, $0

LOOP: lb $t1, ($t0)

slt $t2, $t1, $t6

bne $t2, $0, DONE

sub $t1, $t1, $t6

beq $s0, 0, FIRST

mul $s0, $s0, 10

FIRST: add $s0,$s0,$t1

addi $t0, $t0, 1

j LOOP

DONE: add $v0, $s0, $0

lw $ra, ($sp)

addi $sp, $sp, 4

jr $ra

Step by step solution

01

Determine the MIPS assembly language and registers.

MIPS architecture has 32 registers. Registers $t0-$t7 map registers 8 to 15, $s0-$s7 map onto 16-23 registers. These registers are used in storing and accessing the values by the instructions for any operations. $a0-$a3 are the argument register that is used in a procedure to pass parameters. Registers $v0 and $v1 are used to return values. $ra register will return address register to the origin point.

02

Determine the program in MIPS assembly language to convert an ASCII number string containing positive and negative integer decimal strings, to an integer.

The aim of the program is to convert the positive and negative integers in the ASCII string into an integer.

Given that $a0 should hold the address of a null-terminated string containing the combination of the digits 0 through 9. The integer result must be placed in register $v0. If a non-digit character appears, then the program should stop with -1 value in register $v0.

The MIPS program is as follows:

MAIN: add $sp, $sp, -4

sw $ra, ($sp)

add $t6, $0, 0x30 # ‘0’

add $t7,$0, 0x39 # ‘9’

add $s0, $0, $0

add $t0, $a0, $0

LOOP: lb $t1, ($t0)

slt $t2, $t1, $t6

bne $t2, $0, DONE

sub $t1, $t1, $t6

beq $s0, 0, FIRST

mul $s0, $s0, 10

FIRST: add $s0,$s0,$t1

addi $t0, $t0, 1

j LOOP

DONE: add $v0, $s0, $0

lw $ra, ($sp)

addi $sp, $sp, 4

jr $ra

Explanation:

Instructions

Description

MAIN:add $sp, $sp, -4

MAIN is the name of the Procedure. The stack is allocated with the space for a word.

sw $ra, ($sp)

$ra is push onto the stack.

add $t6, $0, 0x30 # ‘0’

Intialize $t6 with 0

add $t7,$0, 0x39 # ‘9’

Intialzie $t7 with 9

add $s0, $0, $0

Assign 0 to $s0

add $t0, $a0, $0

The passed argument from $a0 will be stored at $t0.

LOOP:lb $t1, ($t0)

LOOP is the procedure that performs loop operation. The load byte instruction will transfer one byte from the address of $t0 to the $t1.

slt $t2, $t1, $t6

$t6 =0, $t1=1 byte from memory, If($t1<$t6), $t2=1 else $ $t2=0

bne $t2, $0, DONE

If($t2!= $0) go to DONE.

sub $t1, $t1, $t6

Subtract $t1 and $t6 , and store the result in $t1.

beq $s0, 0, FIRST

If ($s0=0) go to FIRST

mul $s0, $s0, 10

Multiply by 10 and save at $s0

FIRST:add $s0,$s0,$t1

add $t1 and $s0

addi $t0, $t0, 1

Add immediate 1 to $t0, point to next character

j LOOP

jump to the LOOP procedure.

DONE:add $v0, $s0, $0

assign 0 to $v0

lw $ra, ($sp)

The word of the current stack pointer will be loaded to $ra

addi $sp, $sp, 4

Pop the data from the stack

jr $ra

return the integer value.

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

Question: For the following MIPS assembly instructions above, what is a corresponding C statement?

add f, g, h

add f, i, f

Question: Using your code from Exercise 2.43 as an example, explain what happens when two processors begin to execute this critical section at the same time, assuming that each processor executed exactly one instruction per cycle.

Question: Write a program in MIPS assembly language to convert an ASCII number string containing positive and negative integer decimal strings, to an integer. Your program should expect register \(a0 to hold the address of a null-terminated string containing some combination of the digits 0 through 9. Your program should compute the integer value equivalent to this string of digits, then place the number in register \)v0. If a non-digit character appears anywhere in the string, your program should stop with the value -1 in register \(v0. For example, if register \)a0 points to a sequence of three bytes 50ten, 52ten, 0ten (the null-terminating string “24”), then when the program stops, register $v0 should contain the value 24ten .

Question: If the current value of the PC is 0x00000600, can you use a single jump instruction to get to the PC address as shown in Exercise 2.39?

Question: For each MIPS instruction, show the value of the opcode(OP), source register(RS), and target register(RT) fields. For the I-type instructions, show the value of the immediate field, and for the R-type instructions, show the value of the destination register(RD) field.

addi \(t0,\)s6,4

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

sw \)t1, 0(\(t0)

lw \)t0,0(\(t0)

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

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