From 472b1a638a7eef3eed7db75e6c7054112b56c5d1 Mon Sep 17 00:00:00 2001 From: Torsten Ruger Date: Fri, 23 Mar 2018 18:56:38 +0200 Subject: [PATCH] add register logging and fix function return return semantics used to be different, now only register is given --- lib/risc/interpreter.rb | 35 ++++++++++++++++++++++++++--------- 1 file changed, 26 insertions(+), 9 deletions(-) diff --git a/lib/risc/interpreter.rb b/lib/risc/interpreter.rb index 349a53f9..cbb2f02b 100644 --- a/lib/risc/interpreter.rb +++ b/lib/risc/interpreter.rb @@ -28,7 +28,7 @@ module Risc attr_reader :flags # somewhat like the lags on a cpu, hash sym => bool (zero .. . ) #start in state :stopped and set registers to unknown - def initialize + def initialize() @state = :stopped @stdout = "" @registers = {} @@ -40,21 +40,21 @@ module Risc end end - def start instruction + def start( instruction ) initialize set_state(:running) set_instruction instruction end - def set_state state + def set_state( state ) old = @state return if state == old @state = state trigger(:state_changed , old , state ) end - def set_instruction i - return if @instruction == i + def set_instruction( i ) + raise "set to same instruction #{i}" if @instruction == i old = @instruction @instruction = i trigger(:instruction_changed, old , i) @@ -67,7 +67,7 @@ module Risc @registers[reg] end - def set_register reg , val + def set_register( reg , val ) old = get_register( reg ) # also ensures format if val.is_a? Fixnum @flags[:zero] = (val == 0) @@ -90,6 +90,7 @@ module Risc name = @instruction.class.name.split("::").last log.debug "#{@clock.to_s}: #{@instruction.to_s}" fetch = send "execute_#{name}" + log.debug register_dump return unless fetch set_instruction @instruction.next end @@ -133,9 +134,12 @@ module Risc else index = get_register(@instruction.index) end - if object.is_a?(Symbol) + case object + when Symbol raise "Must convert symbol to word:#{object}" unless( index == 2 ) value = object.to_s.length + when nil + raise "error #{@instruction} retrieves nil" else value = object.get_internal_word( index ) end @@ -196,8 +200,8 @@ module Risc end def execute_FunctionReturn - object = get_register( @instruction.register ) - link = object.get_internal_word( @instruction.index ) + link = get_register( @instruction.register ) + log.debug "Return to #{link}" @instruction = link # we jump back to the call instruction. so it is as if the call never happened and we continue true @@ -272,5 +276,18 @@ module Risc raise "unimplemented '#{@instruction.operator}' #{@instruction}" end end + + def register_dump + (0..7).collect do |reg| + value = @registers["r#{reg}".to_sym] + str = "#{reg}-" + + case value + when String + value[0..10] + else + value.class.name.split("::").last + end + end.join("|") + end end end