From 0f183b3a746f912307d13d6a241510d4ad093957 Mon Sep 17 00:00:00 2001 From: Torsten Ruger Date: Fri, 23 Mar 2018 20:02:17 +0200 Subject: [PATCH] fix value return and test slot load was wrong way around --- lib/mom/instruction/return_sequence.rb | 2 +- lib/risc/interpreter.rb | 2 +- test/risc/interpreter/test_return.rb | 47 +++++++++++--------------- test/support/risc.rb | 4 +-- 4 files changed, 23 insertions(+), 32 deletions(-) diff --git a/lib/mom/instruction/return_sequence.rb b/lib/mom/instruction/return_sequence.rb index 3a944073..248c433e 100644 --- a/lib/mom/instruction/return_sequence.rb +++ b/lib/mom/instruction/return_sequence.rb @@ -20,7 +20,7 @@ module Mom # class ReturnSequence < Instruction def to_risc(compiler) - return_move = SlotLoad.new( [:message ,:return_value] , [:message , :caller, :return_value],self) + return_move = SlotLoad.new( [:message , :caller,:return_value] , [:message , :return_value],self) moves = return_move.to_risc(compiler) return_address = compiler.use_reg(:int) compiler.reset_regs diff --git a/lib/risc/interpreter.rb b/lib/risc/interpreter.rb index cbb2f02b..8d6864cb 100644 --- a/lib/risc/interpreter.rb +++ b/lib/risc/interpreter.rb @@ -17,7 +17,7 @@ module Risc # fire events for changed pc and register contents include Eventable include Logging - log_level :debug + log_level :info attr_reader :instruction # current instruction or pc attr_reader :clock # current instruction or pc diff --git a/test/risc/interpreter/test_return.rb b/test/risc/interpreter/test_return.rb index 58292deb..9cb60ae9 100644 --- a/test/risc/interpreter/test_return.rb +++ b/test/risc/interpreter/test_return.rb @@ -11,46 +11,37 @@ module Risc def test_chain #show_ticks # get output of what is - check_chain [Branch, Label, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, RegToSlot, FunctionCall, Label, LoadConstant, - RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, - Transfer] + check_chain [Branch, Label, LoadConstant, SlotToReg, SlotToReg, + RegToSlot, LoadConstant, RegToSlot, FunctionCall, Label, + LoadConstant, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, FunctionReturn, Transfer, Syscall, + NilClass] + assert_equal 5 , get_return.value end def test_call_main - call_ins = ticks(8) + call_ins = ticks(9) assert_equal FunctionCall , call_ins.class assert :main , call_ins.method.name end def test_load_5 - load_ins = ticks 10 + load_ins = ticks 11 assert_equal LoadConstant , load_ins.class - assert_equal 5 , @interpreter.get_register(load_ins.register).value + assert_equal 5 , @interpreter.get_register(load_ins.register).value end - - def pest_call + def test_transfer + transfer = ticks(19) + assert_equal Transfer , transfer.class + end + def test_sys + sys = ticks(20) + assert_equal Syscall , sys.class + end + def test_return ret = ticks(18) assert_equal FunctionReturn , ret.class - - object = @interpreter.get_register( ret.register ) - link = object.get_internal_word( ret.index ) - + link = @interpreter.get_register( ret.register ) assert_equal Label , link.class end - def pest_adding - done_op = ticks(12) - assert_equal OperatorInstruction , done_op.class - left = @interpreter.get_register(done_op.left) - rr = done_op.right - right = @interpreter.get_register(rr) - assert_equal Fixnum , left.class - assert_equal Fixnum , right.class - assert_equal 7 , right - assert_equal 12 , left - done_tr = ticks(1) - assert_equal RegToSlot , done_tr.class - result = @interpreter.get_register(done_op.left) - assert_equal result , 12 - end end end diff --git a/test/support/risc.rb b/test/support/risc.rb index b6a9674a..ce38fd94 100644 --- a/test/support/risc.rb +++ b/test/support/risc.rb @@ -9,9 +9,9 @@ module Risc end end - def check_return( val ) + def get_return assert_equal Parfait::Message , @interpreter.get_register(:r0).class - assert_equal val , @interpreter.get_register(:r0).return_value + @interpreter.get_register(:r0).return_value end def ticks( num )