2014-04-14 20:53:29 +02:00
|
|
|
require_relative 'helper'
|
|
|
|
require "asm/arm/code_generator"
|
2014-04-14 14:58:59 +02:00
|
|
|
|
2014-04-14 20:53:29 +02:00
|
|
|
# try to test that the generation of basic instructions works
|
2014-04-17 13:43:52 +02:00
|
|
|
# one instruction at a time, reverse testing from objdump --demangle -Sfghxp
|
|
|
|
# tests are named as per assembler code, ie test_mov testing mov instruction
|
2014-04-17 14:35:55 +02:00
|
|
|
# adc add and bic eor orr rsb rsc sbc sub mov mvn cmn cmp teq tst b bl bx swi strb
|
2014-04-17 13:43:52 +02:00
|
|
|
|
|
|
|
class TestArmAsm < MiniTest::Test
|
|
|
|
# need a code generator, for arm
|
2014-04-14 20:53:29 +02:00
|
|
|
def setup
|
|
|
|
@generator = Asm::Arm::CodeGenerator.new
|
|
|
|
end
|
|
|
|
|
2014-04-17 13:43:52 +02:00
|
|
|
# code is what the generator spits out, at least one instruction worth (.first)
|
|
|
|
# the op code is wat was witten as assembler in the first place and the binary result
|
|
|
|
# is reversed and in 4 bytes as ruby can only do 31 bits and so we can't test with just one int (?)
|
2014-04-17 14:35:55 +02:00
|
|
|
def assert_code code , op , should , status = false
|
2014-04-17 13:43:52 +02:00
|
|
|
assert_equal op , code.opcode
|
2014-04-14 20:53:29 +02:00
|
|
|
binary = @generator.assemble
|
|
|
|
assert_equal 4 , binary.length
|
|
|
|
index = 0
|
|
|
|
binary.each_byte do |byte |
|
2014-04-17 11:54:51 +02:00
|
|
|
assert_equal should[index] , byte
|
|
|
|
index += 1
|
|
|
|
end
|
2014-04-17 14:35:55 +02:00
|
|
|
assert code.affect_status if status #no s at the end, silly for mov anyway
|
|
|
|
end
|
|
|
|
def test_adc
|
|
|
|
code = @generator.instance_eval { adc r1, r3, r5}.first
|
|
|
|
assert_code code , :adc , [0x05,0x10,0xa3,0xe0]
|
2014-04-17 11:54:51 +02:00
|
|
|
end
|
2014-04-17 13:43:52 +02:00
|
|
|
def test_mov
|
|
|
|
code = @generator.instance_eval { mov r0, 5 }.first
|
|
|
|
assert_code code , :mov , [0x05,0x00,0xa0,0xe3]
|
|
|
|
end
|
2014-04-17 14:35:55 +02:00
|
|
|
def test_subs
|
2014-04-17 13:43:52 +02:00
|
|
|
code = @generator.instance_eval { subs r2, r0, 1 }.first
|
2014-04-17 14:35:55 +02:00
|
|
|
assert_code code, :sub , [0x01,0x20,0x50,0xe2] , true
|
2014-04-14 20:53:29 +02:00
|
|
|
end
|
|
|
|
def saved_other
|
|
|
|
@generator.instance_eval do
|
|
|
|
mov r0, 5
|
2014-04-17 14:35:55 +02:00
|
|
|
loop_start = label!
|
2014-04-14 20:53:29 +02:00
|
|
|
subs r0, r0, 1
|
|
|
|
bne loop_start
|
|
|
|
bx lr
|
|
|
|
end
|
2014-04-14 14:58:59 +02:00
|
|
|
end
|
|
|
|
end
|