use hex for labels
idea was to be able to compare to positions (but they are different positions)
This commit is contained in:
parent
06f51da8f1
commit
1c52ab6b67
@ -35,8 +35,8 @@ module Risc
|
|||||||
compiler = compiler_for(:Integer, operator ,{other: :Integer})
|
compiler = compiler_for(:Integer, operator ,{other: :Integer})
|
||||||
builder = compiler.builder(true, compiler.method)
|
builder = compiler.builder(true, compiler.method)
|
||||||
me , other = builder.self_and_int_arg("#{operator} load receiver and arg")
|
me , other = builder.self_and_int_arg("#{operator} load receiver and arg")
|
||||||
false_label = Risc.label(compiler.method , "false_label_#{builder.object_id}")
|
false_label = Risc.label(compiler.method , "false_label_#{builder.object_id.to_s(16)}")
|
||||||
merge_label = Risc.label(compiler.method , "merge_label_#{builder.object_id}")
|
merge_label = Risc.label(compiler.method , "merge_label_#{builder.object_id.to_s(16)}")
|
||||||
builder.reduce_int( "#{operator} fix me", me )
|
builder.reduce_int( "#{operator} fix me", me )
|
||||||
builder.reduce_int( "#{operator} fix arg", other )
|
builder.reduce_int( "#{operator} fix arg", other )
|
||||||
if(operator.to_s.start_with?('<') )
|
if(operator.to_s.start_with?('<') )
|
||||||
|
@ -15,8 +15,7 @@ module Risc
|
|||||||
|
|
||||||
def initialize( machine)
|
def initialize( machine)
|
||||||
@machine = machine
|
@machine = machine
|
||||||
@objects = machine.objects
|
@load_at = 0x10054 # this is linux/arm
|
||||||
@load_at = 0x8054 # this is linux/arm
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# objects must be written in same order as positioned by the machine, namely
|
# objects must be written in same order as positioned by the machine, namely
|
||||||
@ -35,7 +34,7 @@ module Risc
|
|||||||
|
|
||||||
# debugging loop to write out positions (in debug)
|
# debugging loop to write out positions (in debug)
|
||||||
def write_debug
|
def write_debug
|
||||||
@objects.each do |id , objekt|
|
@machine.objects.each do |id , objekt|
|
||||||
next if objekt.is_a?(Risc::Label)
|
next if objekt.is_a?(Risc::Label)
|
||||||
log.debug "Linked #{objekt.class}:0x#{objekt.object_id.to_s(16)} at 0x#{Positioned.position(objekt).to_s(16)} / 0x#{objekt.padded_length.to_s(16)}"
|
log.debug "Linked #{objekt.class}:0x#{objekt.object_id.to_s(16)} at 0x#{Positioned.position(objekt).to_s(16)} / 0x#{objekt.padded_length.to_s(16)}"
|
||||||
end
|
end
|
||||||
@ -44,7 +43,7 @@ module Risc
|
|||||||
# Write all the objects
|
# Write all the objects
|
||||||
def write_objects
|
def write_objects
|
||||||
# then the objects , not code yet
|
# then the objects , not code yet
|
||||||
@objects.each do | id, objekt|
|
@machine.objects.each do | id, objekt|
|
||||||
next if objekt.is_a? Parfait::BinaryCode
|
next if objekt.is_a? Parfait::BinaryCode
|
||||||
next if objekt.is_a? Risc::Label # ignore
|
next if objekt.is_a? Risc::Label # ignore
|
||||||
write_any( objekt )
|
write_any( objekt )
|
||||||
@ -54,7 +53,7 @@ module Risc
|
|||||||
# Write the BinaryCode objects of all methods to stream.
|
# Write the BinaryCode objects of all methods to stream.
|
||||||
# Really like any other object, it's just about the ordering
|
# Really like any other object, it's just about the ordering
|
||||||
def write_code
|
def write_code
|
||||||
@objects.each do |id, method|
|
@machine.objects.each do |id, method|
|
||||||
next unless method.is_a? Parfait::TypedMethod
|
next unless method.is_a? Parfait::TypedMethod
|
||||||
binary = method.binary
|
binary = method.binary
|
||||||
while(binary) do
|
while(binary) do
|
||||||
@ -155,7 +154,7 @@ module Risc
|
|||||||
write_ref_for( code.next )
|
write_ref_for( code.next )
|
||||||
write_ref_for( code.get_type )
|
write_ref_for( code.get_type )
|
||||||
@stream.write_signed_int_32( MARKER )
|
@stream.write_signed_int_32( MARKER )
|
||||||
log.debug "Code16 witten stream 0x#{@stream.length.to_s(16)}"
|
log.debug "Init witten stream 0x#{@stream.length.to_s(16)}"
|
||||||
end
|
end
|
||||||
|
|
||||||
def write_BinaryCode( code )
|
def write_BinaryCode( code )
|
||||||
|
@ -25,8 +25,8 @@ module Vool
|
|||||||
end
|
end
|
||||||
|
|
||||||
def simple_if(method)
|
def simple_if(method)
|
||||||
true_label = Mom::Label.new( "true_label_#{object_id}")
|
true_label = Mom::Label.new( "true_label_#{object_id.to_s(16)}")
|
||||||
merge_label = Mom::Label.new( "merge_label_#{object_id}")
|
merge_label = Mom::Label.new( "merge_label_#{object_id.to_s(16)}")
|
||||||
|
|
||||||
head = Mom::TruthCheck.new(condition.slot_definition(method) , merge_label)
|
head = Mom::TruthCheck.new(condition.slot_definition(method) , merge_label)
|
||||||
head << true_label
|
head << true_label
|
||||||
@ -35,9 +35,9 @@ module Vool
|
|||||||
end
|
end
|
||||||
|
|
||||||
def full_if(method)
|
def full_if(method)
|
||||||
true_label = Mom::Label.new( "true_label_#{object_id}")
|
true_label = Mom::Label.new( "true_label_#{object_id.to_s(16)}")
|
||||||
false_label = Mom::Label.new( "false_label_#{object_id}")
|
false_label = Mom::Label.new( "false_label_#{object_id.to_s(16)}")
|
||||||
merge_label = Mom::Label.new( "merge_label_#{object_id}")
|
merge_label = Mom::Label.new( "merge_label_#{object_id.to_s(16)}")
|
||||||
|
|
||||||
head = Mom::TruthCheck.new(condition.slot_definition(method) , false_label)
|
head = Mom::TruthCheck.new(condition.slot_definition(method) , false_label)
|
||||||
head << true_label
|
head << true_label
|
||||||
|
@ -17,8 +17,8 @@ module Vool
|
|||||||
end
|
end
|
||||||
|
|
||||||
def to_mom( method )
|
def to_mom( method )
|
||||||
merge_label = Mom::Label.new( "merge_label_#{object_id}")
|
merge_label = Mom::Label.new( "merge_label_#{object_id.to_s(16)}")
|
||||||
cond_label = Mom::Label.new( "cond_label_#{object_id}")
|
cond_label = Mom::Label.new( "cond_label_#{object_id.to_s(16)}")
|
||||||
codes = cond_label
|
codes = cond_label
|
||||||
codes << @hoisted.to_mom(method) if @hoisted
|
codes << @hoisted.to_mom(method) if @hoisted
|
||||||
codes << Mom::TruthCheck.new(condition.slot_definition(method) , merge_label)
|
codes << Mom::TruthCheck.new(condition.slot_definition(method) , merge_label)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user