2017-01-19 09:02:29 +02:00
|
|
|
module Risc
|
2015-06-21 21:00:16 +03:00
|
|
|
|
2016-12-25 18:02:39 +02:00
|
|
|
# RegToSlot moves data into memory from a register.
|
2016-12-25 18:05:39 +02:00
|
|
|
# SlotToReg moves data into a register from memory.
|
2015-06-21 21:00:16 +03:00
|
|
|
# Both use a base memory (a register)
|
|
|
|
|
|
|
|
# This is because that is what cpu's can do. In programming terms this would be accessing
|
2016-12-25 18:02:39 +02:00
|
|
|
# an element in an array, in the case of RegToSlot setting the register in the array.
|
2015-06-21 21:00:16 +03:00
|
|
|
|
2018-03-21 15:48:04 +05:30
|
|
|
# btw: to move data between registers, use Transfer
|
2015-06-21 21:00:16 +03:00
|
|
|
|
2016-12-25 18:02:39 +02:00
|
|
|
class RegToSlot < Setter
|
2015-06-21 21:00:16 +03:00
|
|
|
|
2014-10-03 11:07:18 +03:00
|
|
|
end
|
2015-06-30 09:43:50 +03:00
|
|
|
|
2016-12-25 18:02:39 +02:00
|
|
|
# Produce a RegToSlot instruction.
|
2015-06-30 09:43:50 +03:00
|
|
|
# From and to are registers or symbols that can be transformed to a register by resolve_to_register
|
2018-03-17 21:15:38 +05:30
|
|
|
# (which are precisely the symbols :message or :new_message. or a register)
|
2016-12-28 18:16:39 +02:00
|
|
|
# index resolves with resolve_to_index.
|
2018-03-14 17:39:49 +05:30
|
|
|
def self.reg_to_slot( source , from_reg , to , index )
|
|
|
|
from = resolve_to_register from_reg
|
2016-12-28 18:16:39 +02:00
|
|
|
index = resolve_to_index( to , index)
|
2015-06-30 09:43:50 +03:00
|
|
|
to = resolve_to_register to
|
2016-12-25 18:02:39 +02:00
|
|
|
RegToSlot.new( source, from , to , index)
|
2015-06-30 09:43:50 +03:00
|
|
|
end
|
|
|
|
|
2014-10-03 11:07:18 +03:00
|
|
|
end
|