seperate position create and register

many test fixes
This commit is contained in:
Torsten Ruger
2018-06-15 22:00:49 +03:00
parent 9c93b38b8f
commit 698c845297
16 changed files with 75 additions and 55 deletions

View File

@ -103,7 +103,7 @@ module Risc
end
previous = nil
sorted.each do |objekt|
next if objekt.is_a?( Parfait::BinaryCode) or objekt.is_a?( Risc::Label )
next unless Position.is_object(objekt)
before = at
unless( Position.set?(objekt))
raise objekt.class

View File

@ -45,7 +45,7 @@ module Risc
translator = Risc.machine.platform.translator
cpu_jump = translator.translate(jump)
pos = at + code.padded_length - cpu_jump.byte_length
Position.new(cpu_jump , pos)
Position.create(cpu_jump).set(pos)
cpu_jump.assemble(JumpWriter.new(code))
end
@ -55,7 +55,7 @@ module Risc
first = nil
while code
raise "Not Binary Code #{code.class}" unless code.is_a?(Parfait::BinaryCode)
position = Position.new(code , -1)
position = Position.get_or_create(code)
first = position unless first
position.position_listener(CodeListener.new)
code = code.next

View File

@ -69,7 +69,7 @@ module Risc
# - trigger change for this (fake) to set position of inserted
def position_inserted(position)
inserted = position.object.next
new_pos = Position.new(inserted , -1)
new_pos = Position.get_or_create(inserted)
new_pos.position_listener(InstructionListener.new(@binary))
position.trigger_changing(position.at)
@ -89,13 +89,13 @@ module Risc
raise "Must init with instruction, not nil" unless instruction
first = nil
while(instruction)
position = Position.new(instruction , -1)
position = Position.get_or_create(instruction)
first = position unless first
il = InstructionListener.new( code )
position.position_listener(il)
if instruction.respond_to?(:branch)
# label_pos = Position.get(instruction.branch)
# label_pos.position_listener( BranchListener.new(il))
# label_pos.position_listener( BranchListener.new(il))
end
instruction = instruction.next
end

View File

@ -20,18 +20,19 @@ module Risc
include Util::Logging
log_level :info
INVALID = -1
include Util::Eventable
attr_reader :at , :object
# initialize with a given object, first parameter
# The object ill be the key in global position map
# Give an integer as the actual position, where -1
# which means no legal position known
def initialize(object , pos )
@at = pos
# The object will be the key in global position map
#
# The actual position starts as -1 (invalid)
def initialize(object)
@at = INVALID
@object = object
Position.set_to(self , pos)
end
# utility to register events of type :position_changed
@ -62,7 +63,7 @@ module Risc
end
def valid?
@at != -1
@at != INVALID
end
def set(int)
@ -71,7 +72,7 @@ module Risc
Position.set_to(self , int)
@at = int
trigger_changed
int
self
end
# helper to fire the event that the position is about to change
@ -164,6 +165,23 @@ module Risc
pos
end
# creating means instantiating and caching
def self.create(object)
pos = Position.new(object)
self.positions[object] = pos
log.debug "Initialize for #{object.class} #{object.object_id.to_s(16)}"
pos
end
def self.get_or_create(object)
if self.positions.has_key?(object)
pos = self.get(object)
else
pos = self.create(object)
end
return pos
end
# populate the position caches (forward and revese) with the given position
# forward caches object -> position
# reverse caches position.at > position
@ -178,13 +196,26 @@ module Risc
end
self.positions[position.object] = position
@reverse_cache[to] = position unless position.object.is_a?(Label)
if to == -1
log.debug "Initialize for #{position.object.class} #{position.object.object_id.to_s(16)}"
if to == INVALID
raise "Old style, change code"
else
log.debug "Set #{position} to 0x#{to.to_s(16)} for #{position.object.class} #{position.object.object_id.to_s(16)}"
end
position
end
def self.is_object(object)
case object
when Risc::Label , Parfait::BinaryCode
return false
when Parfait::Object , Symbol
return true
when Arm::Instruction , Risc::Branch
return false
else
raise "Class #{object.class}"
end
end
end
end
require_relative "position_listener"

View File

@ -50,22 +50,10 @@ module Risc
# Write all the objects in the order that they have been positioed
def write_objects
sorted_objects.each do |objekt|
next unless is_object(objekt)
next unless Position.is_object(objekt)
write_any( objekt )
end
end
def is_object(object)
case object
when Risc::Label , Parfait::BinaryCode
return false
when Parfait::Object , Symbol
return true
when Arm::Instruction
return false
else
raise "Class #{object.class}"
end
end
# Write the BinaryCode objects of all methods to stream.
# Really like any other object, it's just about the ordering