fix arm return bug

even had a fixme on it
This commit is contained in:
Torsten 2020-03-24 22:04:44 +02:00
parent 6d2ecf7ee6
commit b2dce92883
3 changed files with 9 additions and 6 deletions

View File

@ -66,8 +66,11 @@ module Arm
end end
def translate_FunctionReturn( code ) def translate_FunctionReturn( code )
# FIXME reduce the int first, register contains a ReturnAddress reduce = arm_index(Parfait::Integer.integer_index)
ArmMachine.mov( :pc , code.register) # reduce the int first, register contains a ReturnAddress
codes = ArmMachine.ldr( code.register , code.register , reduce )
codes << ArmMachine.mov( :pc , code.register)
codes
end end
def translate_DynamicJump(code) def translate_DynamicJump(code)
index = Parfait.object_space.get_type_by_class_name(:CallableMethod).variable_index(:binary) index = Parfait.object_space.get_type_by_class_name(:CallableMethod).variable_index(:binary)

View File

@ -40,9 +40,9 @@ module SlotMachine
builder = compiler.builder(self) builder = compiler.builder(self)
word = builder.load_object(Parfait.new_word(@name.to_s)) word = builder.load_object(Parfait.new_word(@name.to_s))
entry = builder.load_object(@cache_entry) entry = builder.load_object(@cache_entry)
while_start_label = Risc.label(to_s, "while_start_label_#{object_id}") while_start_label = Risc.label(to_s, "resolve_#{name}_#{object_id}")
ok_label = Risc.label(to_s, "ok_label_#{object_id}") ok_label = Risc.label(to_s, "ok_resolve_#{name}_#{object_id}")
exit_label = Risc.label(to_s, "exit_label_#{object_id}") exit_label = Risc.label(to_s, "exit_resolve_#{name}_#{object_id}")
builder.build do builder.build do
callable_method = entry[:cached_type][:methods].to_reg callable_method = entry[:cached_type][:methods].to_reg

View File

@ -87,7 +87,7 @@ module Sol
# if not, change and find method for the type (simple_call to resolve_method) # if not, change and find method for the type (simple_call to resolve_method)
# conceptually easy in ruby, but we have to compile that "easy" ruby # conceptually easy in ruby, but we have to compile that "easy" ruby
def cache_check(compiler) def cache_check(compiler)
ok = SlotMachine::Label.new(self,"cache_ok_#{self.object_id}") ok = SlotMachine::Label.new(self,"send_cache_#{@name}_ok_#{self.object_id}")
check = build_condition(ok, compiler) # if cached_type != current_type check = build_condition(ok, compiler) # if cached_type != current_type
check << SlotMachine::SlotLoad.new(self,[dynamic_call.cache_entry, :cached_type] , receiver_type_definition(compiler)) check << SlotMachine::SlotLoad.new(self,[dynamic_call.cache_entry, :cached_type] , receiver_type_definition(compiler))
check << SlotMachine::ResolveMethod.new(self, @name , dynamic_call.cache_entry ) check << SlotMachine::ResolveMethod.new(self, @name , dynamic_call.cache_entry )