2017-01-19 09:02:29 +02:00
|
|
|
module Risc
|
2016-12-11 14:12:35 +02:00
|
|
|
|
2016-12-25 18:11:58 +02:00
|
|
|
# Getter is a base class for get instructions (SlotToReg and ByteToReg , possibly more coming)
|
2016-12-11 14:12:35 +02:00
|
|
|
#
|
|
|
|
# The instruction that is modelled is loading data from an array into a register
|
|
|
|
#
|
|
|
|
# Getter has a
|
|
|
|
# - an array where the data comes from
|
|
|
|
# - and (array) index
|
2017-01-19 09:02:29 +02:00
|
|
|
# - Risc that the data is moved to
|
2016-12-11 14:12:35 +02:00
|
|
|
|
|
|
|
# Getter and Setter api follow the pattern from -> to
|
|
|
|
|
|
|
|
class Getter < Instruction
|
|
|
|
|
|
|
|
# If you had a c array and index offset
|
|
|
|
# the instruction would do register = array[index]
|
|
|
|
# The arguments are in the order that makes sense for the Instruction name
|
2016-12-25 18:05:39 +02:00
|
|
|
# So SlotToReg means the slot (array and index) moves to the register (last argument)
|
2016-12-11 14:12:35 +02:00
|
|
|
def initialize source , array , index , register
|
|
|
|
super(source)
|
|
|
|
@array = array
|
|
|
|
@index = index
|
|
|
|
@register = register
|
|
|
|
raise "index 0 " if index == 0
|
2017-01-19 09:02:29 +02:00
|
|
|
raise "Not integer or reg #{index}" unless index.is_a?(Numeric) or RiscValue.look_like_reg(index)
|
|
|
|
raise "Not register #{register}" unless RiscValue.look_like_reg(register)
|
|
|
|
raise "Not register #{array}" unless RiscValue.look_like_reg(array)
|
2016-12-11 14:12:35 +02:00
|
|
|
end
|
|
|
|
attr_accessor :array , :index , :register
|
|
|
|
|
2016-12-16 00:30:26 +02:00
|
|
|
def to_s
|
2016-12-28 21:10:14 +02:00
|
|
|
"#{self.class.name.split("::").last}: #{array}[#{index}] -> #{register}"
|
2016-12-16 00:30:26 +02:00
|
|
|
end
|
|
|
|
|
2016-12-11 14:12:35 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|