2018-03-27 20:47:41 +03:00
|
|
|
module Risc
|
|
|
|
# Little glue class to get the assembled binary from the Arm Instructions into
|
|
|
|
# the BinaryCode instances. Arm code originally uses io, but slightly modified
|
|
|
|
# really only uses write_unsigned_int_32 , which converts
|
|
|
|
# to an set_internal_word on the BinaryCode
|
|
|
|
#
|
|
|
|
# Machine instantiates and the writer reads from the arm Instructions
|
|
|
|
# and writes to the BinaryCode
|
|
|
|
class BinaryWriter
|
|
|
|
def initialize( code )
|
|
|
|
@code = code
|
|
|
|
end
|
|
|
|
|
2018-03-28 19:49:16 +03:00
|
|
|
# Go through and assemble all instructions.
|
|
|
|
# Assembly may cause LinkException, which is caught by caller
|
2018-05-01 19:48:11 +03:00
|
|
|
def assemble( instruction )
|
2018-03-28 19:49:16 +03:00
|
|
|
@index = 1
|
|
|
|
while(instruction)
|
|
|
|
instruction.assemble(self)
|
2018-03-27 20:47:41 +03:00
|
|
|
instruction = instruction.next
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def write_unsigned_int_32( bin )
|
|
|
|
@code.set_word( @index , bin )
|
|
|
|
@index += 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-03-28 19:49:16 +03:00
|
|
|
# A LinkException is raised when the arm code can't fit a constant into _one_
|
|
|
|
# instruction. This is kind of unavoidable with arm.
|
|
|
|
#
|
|
|
|
# Off course the problem could be fixed without the exception, but the exception
|
|
|
|
# means all subsequent Instructions, including labels/jump targets move.
|
|
|
|
# Thus changing jump instructions to those labels.
|
|
|
|
# So the whole method has to be reassembled and (at least) the instructions beyond
|
|
|
|
# repositioned. Ie a non-local problem, and so the Exception.
|
|
|
|
#
|
|
|
|
# Note: In the future i hope to have a more flexible system, possibly with position
|
|
|
|
# listeners and change events. Because positions chaning is normal, not exceptional.
|
|
|
|
#
|
|
|
|
class LinkException < Exception
|
|
|
|
end
|
|
|
|
|
2018-03-27 20:47:41 +03:00
|
|
|
end
|