2017-01-19 08:02:29 +01:00
|
|
|
module Risc
|
2016-12-11 13:12:35 +01:00
|
|
|
|
2016-12-25 17:11:58 +01:00
|
|
|
# Getter is a base class for get instructions (SlotToReg and ByteToReg , possibly more coming)
|
2016-12-11 13:12:35 +01: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
|
2018-03-14 13:09:49 +01:00
|
|
|
# - an (array) index
|
|
|
|
# - Register that the data is moved to
|
2016-12-11 13:12:35 +01: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 17:05:39 +01:00
|
|
|
# So SlotToReg means the slot (array and index) moves to the register (last argument)
|
2018-03-14 13:09:49 +01:00
|
|
|
def initialize( source , array , index , register )
|
2016-12-11 13:12:35 +01:00
|
|
|
super(source)
|
|
|
|
@array = array
|
|
|
|
@index = index
|
|
|
|
@register = register
|
2018-05-14 19:50:52 +02:00
|
|
|
raise "index #{index}" if index.is_a?(Numeric) and index < 0
|
2017-01-19 08:02:29 +01: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 13:12:35 +01:00
|
|
|
end
|
|
|
|
attr_accessor :array , :index , :register
|
|
|
|
|
2016-12-15 23:30:26 +01:00
|
|
|
def to_s
|
2018-03-22 17:38:19 +01:00
|
|
|
class_source "#{array}[#{index}] -> #{register}"
|
2016-12-15 23:30:26 +01:00
|
|
|
end
|
|
|
|
|
2016-12-11 13:12:35 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|