139 lines
2.9 KiB
NASM
139 lines
2.9 KiB
NASM
|
# All program code is placed after the
|
||
|
# .text assembler directive
|
||
|
.text
|
||
|
|
||
|
# Declare main as a global function
|
||
|
.globl main
|
||
|
|
||
|
j main
|
||
|
|
||
|
# code for add
|
||
|
add:
|
||
|
# Entering a new scope.
|
||
|
# Symbols in symbol table:
|
||
|
# println
|
||
|
# x
|
||
|
# i
|
||
|
# y
|
||
|
# return
|
||
|
# Update the stack pointer.
|
||
|
addi $sp $sp -0
|
||
|
# println
|
||
|
# Get x's offset from $sp from the symbol table and initialize x's address with it. We'll add $sp later.
|
||
|
li $t1 -4
|
||
|
# Add the stack pointer address to the offset.
|
||
|
add $t1 $t1 $sp
|
||
|
# Load the value of x.
|
||
|
lw $t0 0($t1)
|
||
|
# Get y's offset from $sp from the symbol table and initialize y's address with it. We'll add $sp later.
|
||
|
li $t2 -8
|
||
|
# Add the stack pointer address to the offset.
|
||
|
add $t2 $t2 $sp
|
||
|
# Load the value of y.
|
||
|
lw $t1 0($t2)
|
||
|
add $t0 $t0 $t1
|
||
|
move $a0 $t0
|
||
|
li $v0 1
|
||
|
syscall
|
||
|
la $a0 newline
|
||
|
li $v0 4
|
||
|
syscall
|
||
|
# Exiting scope.
|
||
|
addi $sp $sp 0
|
||
|
jr $ra
|
||
|
|
||
|
# code for main
|
||
|
main:
|
||
|
# Entering a new scope.
|
||
|
# Symbols in symbol table:
|
||
|
# a
|
||
|
# println
|
||
|
# b
|
||
|
# return
|
||
|
# Update the stack pointer.
|
||
|
addi $sp $sp -0
|
||
|
# println
|
||
|
la $a0 datalabel0
|
||
|
li $v0 4
|
||
|
syscall
|
||
|
la $a0 newline
|
||
|
li $v0 4
|
||
|
syscall
|
||
|
# Calling function add
|
||
|
# Save $ra to a register
|
||
|
move $t0 $ra
|
||
|
# Save $t0-9 registers
|
||
|
sw $t0 -12($sp)
|
||
|
# Evaluate parameters and save to stack
|
||
|
li $t1 3
|
||
|
sw $t1 -16($sp)
|
||
|
li $t1 4
|
||
|
sw $t1 -20($sp)
|
||
|
# Update the stack pointer
|
||
|
add $sp $sp -12
|
||
|
# Call the function
|
||
|
jal add
|
||
|
# Restore the stack pointer
|
||
|
add $sp $sp 12
|
||
|
# Restore $t0-9 registers
|
||
|
lw $t0 -12($sp)
|
||
|
# Restore $ra
|
||
|
move $ra $t0
|
||
|
# Get a's offset from $sp from the symbol table and initialize a's address with it. We'll add $sp later.
|
||
|
li $t0 -4
|
||
|
# Add the stack pointer address to the offset.
|
||
|
add $t0 $t0 $sp
|
||
|
# Compute rhs for assignment =
|
||
|
li $t1 5
|
||
|
# complete assignment statement with store
|
||
|
sw $t1 0($t0)
|
||
|
# Get b's offset from $sp from the symbol table and initialize b's address with it. We'll add $sp later.
|
||
|
li $t0 -8
|
||
|
# Add the stack pointer address to the offset.
|
||
|
add $t0 $t0 $sp
|
||
|
# Compute rhs for assignment =
|
||
|
li $t1 2
|
||
|
# complete assignment statement with store
|
||
|
sw $t1 0($t0)
|
||
|
# Calling function add
|
||
|
# Save $ra to a register
|
||
|
move $t0 $ra
|
||
|
# Save $t0-9 registers
|
||
|
sw $t0 -12($sp)
|
||
|
# Evaluate parameters and save to stack
|
||
|
# Get a's offset from $sp from the symbol table and initialize a's address with it. We'll add $sp later.
|
||
|
li $t2 -4
|
||
|
# Add the stack pointer address to the offset.
|
||
|
add $t2 $t2 $sp
|
||
|
# Load the value of a.
|
||
|
lw $t1 0($t2)
|
||
|
sw $t1 -16($sp)
|
||
|
# Get b's offset from $sp from the symbol table and initialize b's address with it. We'll add $sp later.
|
||
|
li $t2 -8
|
||
|
# Add the stack pointer address to the offset.
|
||
|
add $t2 $t2 $sp
|
||
|
# Load the value of b.
|
||
|
lw $t1 0($t2)
|
||
|
sw $t1 -20($sp)
|
||
|
# Update the stack pointer
|
||
|
add $sp $sp -12
|
||
|
# Call the function
|
||
|
jal add
|
||
|
# Restore the stack pointer
|
||
|
add $sp $sp 12
|
||
|
# Restore $t0-9 registers
|
||
|
lw $t0 -12($sp)
|
||
|
# Restore $ra
|
||
|
move $ra $t0
|
||
|
# Exiting scope.
|
||
|
addi $sp $sp 0
|
||
|
li $v0 10
|
||
|
syscall
|
||
|
|
||
|
# All memory structures are placed after the
|
||
|
# .data assembler directive
|
||
|
.data
|
||
|
|
||
|
newline: .asciiz "\n"
|
||
|
datalabel0: .asciiz "This program prints 7 7"
|