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: 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

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