2017-01-19 09:02:29 +02:00
|
|
|
module Risc
|
2015-11-19 10:07:27 +02:00
|
|
|
|
2016-12-25 18:11:58 +02:00
|
|
|
# ByteToReg moves a single byte into a register from memory.
|
2015-11-19 10:07:27 +02:00
|
|
|
|
|
|
|
# indexes are 1 based (as for slots) , which means we sacrifice a byte of every word
|
|
|
|
# for our sanity
|
|
|
|
|
2016-12-25 18:11:58 +02:00
|
|
|
class ByteToReg < Getter
|
2015-11-19 10:07:27 +02:00
|
|
|
|
|
|
|
end
|
|
|
|
|
2016-12-25 18:11:58 +02:00
|
|
|
# Produce a ByteToReg instruction.
|
2015-11-19 10:07:27 +02:00
|
|
|
# from and to are translated (from symbol to register if neccessary)
|
|
|
|
# but index is left as is.
|
2016-12-28 19:01:58 +02:00
|
|
|
def self.byte_to_reg( source , array , index , to)
|
|
|
|
array = resolve_to_register( array)
|
|
|
|
to = resolve_to_register( to)
|
|
|
|
ByteToReg.new( source , array , index , to)
|
|
|
|
end
|
2015-11-19 10:07:27 +02:00
|
|
|
end
|