trying to fix the darn jump over object header

This commit is contained in:
Torsten Ruger 2018-05-25 19:03:46 +03:00
parent 8d8cc4b016
commit ddd408e245
3 changed files with 33 additions and 9 deletions

View File

@ -26,4 +26,14 @@ module Risc
end end
end end
#even less glue to get that last jump in there.
# So instructions don't run into the BinaryCode object header
class JumpWriter
def initialize( code )
@code = code
end
def write_unsigned_int_32( bin )
@code.set_word( 14 , bin )
end
end
end end

View File

@ -18,10 +18,12 @@ module Risc
@method = method @method = method
raise "Method nil" unless method raise "Method nil" unless method
end end
def init(at) def init(at , method)
raise "No no" unless method.name == @method.name
next_pos = at + code.padded_length next_pos = at + code.padded_length
if code.next if code.next
Position.set(code.next , next_pos, method) Position.set(code.next , next_pos, method)
set_jump(at)
else else
next_meth = next_method next_meth = next_method
return unless next_meth return unless next_meth
@ -30,11 +32,22 @@ module Risc
Position.set( next_meth.cpu_instructions, next_cpu_pos , next_meth.binary) Position.set( next_meth.cpu_instructions, next_cpu_pos , next_meth.binary)
end end
end end
def reset_to(pos) def reset_to(pos , ignored)
init(pos) super(pos, ignored)
super(pos) init(pos , ignored)
Position.log.debug "ResetCode (#{pos.to_s(16)}) #{code}" Position.log.debug "ResetCode (#{pos.to_s(16)}) #{code}"
end end
# insert a jump to the next instruction, at the last instruction
# thus hopping over the object header
def set_jump(at)
jump = Branch.new("BinaryCode #{at.to_s(16)}" , code.next)
translator = Risc.machine.platform.translator
cpu_jump = translator.translate(jump)
pos = at + code.padded_length - cpu_jump.byte_length
Position.set( cpu_jump , pos , code)
cpu_jump.assemble(JumpWriter.new(code))
end
def next_method def next_method
next_m = @method.next_method next_m = @method.next_method
return next_m if next_m return next_m if next_m

View File

@ -22,14 +22,15 @@ module Risc
@instruction = instruction @instruction = instruction
@binary = binary @binary = binary
end end
def init(at) def init(at, binary)
return if at == 0 and binary.nil? return if at == 0 and binary.nil?
return unless @instruction.next return unless @instruction.next
@binary = binary
nekst = at + @instruction.byte_length nekst = at + @instruction.byte_length
diff = nekst - Position.get(@binary).at diff = nekst - Position.get(@binary).at
Position.log.debug "Diff: #{diff.to_s(16)} , next #{nekst.to_s(16)} , binary #{Position.get(@binary)}" Position.log.debug "Diff: #{diff.to_s(16)} , next #{nekst.to_s(16)} , binary #{Position.get(@binary)}"
raise "Invalid position #{diff.to_s(16)} , next #{nekst.to_s(16)} #{self}" if diff < 8 raise "Invalid position #{diff.to_s(16)} , next #{nekst.to_s(16)} #{self}" if diff < 8
if( (diff % @binary.padded_length ) == 0 ) if( (diff % (@binary.padded_length - @instruction.byte_length)) == 0 )
@binary.extend_one unless @binary.next @binary.extend_one unless @binary.next
@binary = @binary.next @binary = @binary.next
raise "end of line " unless @binary raise "end of line " unless @binary
@ -39,9 +40,9 @@ module Risc
Position.set(@instruction.next, nekst , @binary) Position.set(@instruction.next, nekst , @binary)
end end
def reset_to(pos) def reset_to(pos , binary)
init(pos) super(pos , binary)
super(pos) init(pos , binary)
Position.log.debug "ResetInstruction (#{pos.to_s(16)}) #{instruction}" Position.log.debug "ResetInstruction (#{pos.to_s(16)}) #{instruction}"
end end
end end