adjust program tests to new syntax, hello world works there too -)
This commit is contained in:
parent
c7d203f523
commit
f7f0eee31a
@ -30,7 +30,7 @@ module Arm
|
|||||||
@operand = op_with_rot
|
@operand = op_with_rot
|
||||||
@i = 1
|
@i = 1
|
||||||
else
|
else
|
||||||
raise "cannot fit numeric literal argument in operand #{arg}"
|
raise "cannot fit numeric literal argument in operand #{arg.inspect}"
|
||||||
end
|
end
|
||||||
elsif (arg.is_a?(Symbol))
|
elsif (arg.is_a?(Symbol))
|
||||||
@operand = arg
|
@operand = arg
|
||||||
|
@ -65,6 +65,16 @@ module Vm
|
|||||||
@next = block
|
@next = block
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# sugar to create instructions easily. Any method with one arg is sent to the machine and the result
|
||||||
|
# (hopefully an instruction) added as code
|
||||||
|
def method_missing(meth, *args, &block)
|
||||||
|
if args.length == 1
|
||||||
|
add_code Machine.instance.send(meth , *args)
|
||||||
|
else
|
||||||
|
super
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
@ -30,7 +30,7 @@ module Vm
|
|||||||
@functions = []
|
@functions = []
|
||||||
@entry = Core::Kernel::main_start
|
@entry = Core::Kernel::main_start
|
||||||
#main gets executed between entry and exit
|
#main gets executed between entry and exit
|
||||||
@main = nil
|
@main = Block.new("main")
|
||||||
@exit = Core::Kernel::main_exit
|
@exit = Core::Kernel::main_exit
|
||||||
end
|
end
|
||||||
attr_reader :context , :main , :functions
|
attr_reader :context , :main , :functions
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
require_relative "test_asm"
|
require_relative "test_arm"
|
||||||
require_relative "test_small_program"
|
require_relative "test_small_program"
|
||||||
#require_relative "test_runner"
|
#require_relative "test_runner"
|
||||||
require_relative "parser/test_all"
|
require_relative "parser/test_all"
|
||||||
|
@ -9,16 +9,16 @@ require_relative 'helper'
|
|||||||
class TestSmallProg < MiniTest::Test
|
class TestSmallProg < MiniTest::Test
|
||||||
# need a code generator, for arm
|
# need a code generator, for arm
|
||||||
def setup
|
def setup
|
||||||
@program = Asm::Assembler.new
|
@program = Vm::Program.new "Arm"
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_loop
|
def test_loop
|
||||||
@program.main do
|
@program.main.instance_eval do
|
||||||
mov r0, 5 #1
|
mov :r0, 5 #1
|
||||||
start do
|
start do
|
||||||
subs r0, r0, 1 #2
|
subs :r0, :r0, 1 #2
|
||||||
bne :start #3
|
bne :start #3
|
||||||
mov r7, 1 #4
|
mov :r7, 1 #4
|
||||||
swi 0 #5 5 instructions
|
swi 0 #5 5 instructions
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -26,23 +26,25 @@ class TestSmallProg < MiniTest::Test
|
|||||||
end
|
end
|
||||||
|
|
||||||
def test_hello
|
def test_hello
|
||||||
hello = "Hello Raisa\n"
|
hello = Vm::StringLiteral.new "Hello Raisa\n"
|
||||||
@program.main do
|
@program.add_object hello
|
||||||
mov r7, 4 # 4 == write
|
@program.main.instance_eval do
|
||||||
mov r0 , 1 # stdout
|
mov :left =>:r7, :right => 4 # 4 == write
|
||||||
add r1 , pc , hello # address of "hello Raisa"
|
mov :left =>:r0 , :right => 1 # stdout
|
||||||
mov r2 , hello.length
|
add :left =>:r1 , :extra => hello # address of "hello Raisa"
|
||||||
swi 0 #software interupt, ie kernel syscall
|
mov :left =>:r2 , :right => hello.length
|
||||||
mov r7, 1 # 1 == exit
|
swi :left => 0 #software interupt, ie kernel syscall
|
||||||
swi 0
|
mov :left => :r7, :right => 1 # 1 == exit
|
||||||
|
swi :left => 0
|
||||||
end
|
end
|
||||||
write(7 + hello.length/4 + 1 , 'hello')
|
write(9 + hello.length/4 + 1 , 'hello')
|
||||||
end
|
end
|
||||||
|
|
||||||
#helper to write the file
|
#helper to write the file
|
||||||
def write len ,name
|
def write len ,name
|
||||||
writer = Elf::ObjectWriter.new(Elf::Constants::TARGET_ARM)
|
writer = Elf::ObjectWriter.new(Elf::Constants::TARGET_ARM)
|
||||||
assembly = @program.assemble_to_string
|
io = @program.assemble(StringIO.new)
|
||||||
|
assembly = io.string
|
||||||
assert_equal len * 4 , assembly.length
|
assert_equal len * 4 , assembly.length
|
||||||
writer.set_text assembly
|
writer.set_text assembly
|
||||||
writer.save("#{name}_test.o")
|
writer.save("#{name}_test.o")
|
||||||
|
Loading…
Reference in New Issue
Block a user