must pass registers to slot_to_reg and reg_to_slot
as they are typed, those functions don't resolve on Risc, but the register type miscother changes from previous commits
This commit is contained in:
parent
f31d22d901
commit
3bc85805a4
@ -66,8 +66,7 @@ module Mom
|
|||||||
left = left.resolve_and_add( slot , const , compiler)
|
left = left.resolve_and_add( slot , const , compiler)
|
||||||
slot = left_slots.shift
|
slot = left_slots.shift
|
||||||
end
|
end
|
||||||
left_index = left.resolve_index( slot )
|
const << Risc.reg_to_slot(original_source, const.register , left, slot)
|
||||||
const << Risc.reg_to_slot(original_source, const.register , left, left_index)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -108,7 +108,7 @@ module Risc
|
|||||||
# Load the first argument, assumed to be integer
|
# Load the first argument, assumed to be integer
|
||||||
def load_int_arg_at( source , at)
|
def load_int_arg_at( source , at)
|
||||||
int_arg = compiler.use_reg :Integer
|
int_arg = compiler.use_reg :Integer
|
||||||
add_slot_to_reg(source , :message , :arguments , int_arg )
|
add_slot_to_reg(source , Risc.message_reg , :arguments , int_arg )
|
||||||
add_slot_to_reg(source , int_arg , at + 1, int_arg ) #1 for type
|
add_slot_to_reg(source , int_arg , at + 1, int_arg ) #1 for type
|
||||||
return int_arg
|
return int_arg
|
||||||
end
|
end
|
||||||
@ -135,8 +135,10 @@ module Risc
|
|||||||
def add_known(name)
|
def add_known(name)
|
||||||
case name
|
case name
|
||||||
when :receiver
|
when :receiver
|
||||||
ret = compiler.use_reg compiler.resolve_type(:receiver)
|
message = Risc.message_reg
|
||||||
add_slot_to_reg(" load self" , :message , :receiver , ret )
|
ret_type = message.resolve_new_type(:receiver, compiler)
|
||||||
|
ret = compiler.use_reg( ret_type )
|
||||||
|
add_slot_to_reg(" load self" , message , :receiver , ret )
|
||||||
return ret
|
return ret
|
||||||
when :space
|
when :space
|
||||||
space = Parfait.object_space
|
space = Parfait.object_space
|
||||||
|
@ -7,10 +7,11 @@ module Risc
|
|||||||
def putstring( context)
|
def putstring( context)
|
||||||
compiler = compiler_for(:Word , :putstring ,{})
|
compiler = compiler_for(:Word , :putstring ,{})
|
||||||
builder = compiler.compiler_builder(compiler.source)
|
builder = compiler.compiler_builder(compiler.source)
|
||||||
builder.add_slot_to_reg( "putstring" , :message , :receiver , :new_message )
|
new_message = Risc.message_reg.get_new_left(:receiver , compiler)
|
||||||
|
builder.add_slot_to_reg( "putstring" , Risc.message_reg , :receiver , new_message )
|
||||||
index = Parfait::Word.get_length_index
|
index = Parfait::Word.get_length_index
|
||||||
reg = RegisterValue.new(:r2 , :Integer)
|
index_reg = RegisterValue.new(:r2 , :Integer)
|
||||||
builder.add_slot_to_reg( "putstring" , :new_message , index , reg )
|
builder.add_slot_to_reg( "putstring" , new_message , index , index_reg )
|
||||||
Risc::Builtin::Object.emit_syscall( builder , :putstring )
|
Risc::Builtin::Object.emit_syscall( builder , :putstring )
|
||||||
compiler.add_mom( Mom::ReturnSequence.new)
|
compiler.add_mom( Mom::ReturnSequence.new)
|
||||||
compiler
|
compiler
|
||||||
@ -28,7 +29,7 @@ module Risc
|
|||||||
builder.add_byte_to_reg( source , me , index , me)
|
builder.add_byte_to_reg( source , me , index , me)
|
||||||
builder.add_new_int(source, me , index)
|
builder.add_new_int(source, me , index)
|
||||||
# and put it back into the return value
|
# and put it back into the return value
|
||||||
builder.add_reg_to_slot( source , index , :message , :return_value)
|
builder.add_reg_to_slot( source , index , Risc.message_reg , :return_value)
|
||||||
compiler.add_mom( Mom::ReturnSequence.new)
|
compiler.add_mom( Mom::ReturnSequence.new)
|
||||||
return compiler
|
return compiler
|
||||||
end
|
end
|
||||||
@ -46,7 +47,7 @@ module Risc
|
|||||||
builder.reduce_int( source + " fix arg", index )
|
builder.reduce_int( source + " fix arg", index )
|
||||||
builder.add_reg_to_byte( source , value , me , index)
|
builder.add_reg_to_byte( source , value , me , index)
|
||||||
value = builder.load_int_arg_at(source , 1 )
|
value = builder.load_int_arg_at(source , 1 )
|
||||||
builder.add_reg_to_slot( source , value , :message , :return_value)
|
builder.add_reg_to_slot( source , value , Risc.message_reg , :return_value)
|
||||||
compiler.add_mom( Mom::ReturnSequence.new)
|
compiler.add_mom( Mom::ReturnSequence.new)
|
||||||
return compiler
|
return compiler
|
||||||
end
|
end
|
||||||
|
@ -14,13 +14,11 @@ module Risc
|
|||||||
end
|
end
|
||||||
|
|
||||||
# Produce a RegToSlot instruction.
|
# Produce a RegToSlot instruction.
|
||||||
# From and to are registers or symbols that can be transformed to a register by resolve_to_register
|
# From and to are registers
|
||||||
# (which are precisely the symbols :message or :new_message. or a register)
|
# index may be a Symbol in which case is resolves with resolve_index.
|
||||||
# index resolves with resolve_to_index.
|
def self.reg_to_slot( source , from , to , index )
|
||||||
def self.reg_to_slot( source , from_reg , to , index )
|
raise "Not register #{to}" unless RegisterValue.look_like_reg(to)
|
||||||
from = resolve_to_register from_reg
|
index = to.resolve_index(index) if index.is_a?(Symbol)
|
||||||
index = resolve_to_index( to , index)
|
|
||||||
to = resolve_to_register to
|
|
||||||
RegToSlot.new( source, from , to , index)
|
RegToSlot.new( source, from , to , index)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -14,12 +14,11 @@ module Risc
|
|||||||
end
|
end
|
||||||
|
|
||||||
# Produce a SlotToReg instruction.
|
# Produce a SlotToReg instruction.
|
||||||
# Array and to are registers or symbols that can be transformed to a register by resolve_to_register
|
# Array and to are registers
|
||||||
# index resolves with resolve_to_index.
|
# index may be a Symbol in which case is resolves with resolve_index.
|
||||||
def self.slot_to_reg( source , array , index , to)
|
def self.slot_to_reg( source , array , index , to)
|
||||||
index = resolve_to_index( array , index)
|
raise "Not register #{array}" unless RegisterValue.look_like_reg(array)
|
||||||
array = resolve_to_register( array )
|
index = array.resolve_index(index) if index.is_a?(Symbol)
|
||||||
to = resolve_to_register( to )
|
|
||||||
SlotToReg.new( source , array , index , to)
|
SlotToReg.new( source , array , index , to)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -41,7 +41,7 @@ module Risc
|
|||||||
def test_load_args
|
def test_load_args
|
||||||
produced = produce_body
|
produced = produce_body
|
||||||
assert_equal SlotToReg , produced.next(base+2).class
|
assert_equal SlotToReg , produced.next(base+2).class
|
||||||
assert_equal :r3 , produced.next(base+2).register.symbol
|
assert_equal :r2 , produced.next(base+2).register.symbol
|
||||||
assert_equal :r2 , produced.next(base+2).array.symbol
|
assert_equal :r2 , produced.next(base+2).array.symbol
|
||||||
assert_equal 8 , produced.next(base+2).index
|
assert_equal 8 , produced.next(base+2).index
|
||||||
end
|
end
|
||||||
@ -49,7 +49,7 @@ module Risc
|
|||||||
produced = produce_body
|
produced = produce_body
|
||||||
assert_equal RegToSlot , produced.next(base+3).class
|
assert_equal RegToSlot , produced.next(base+3).class
|
||||||
assert_equal :r1 , produced.next(base+3).register.symbol
|
assert_equal :r1 , produced.next(base+3).register.symbol
|
||||||
assert_equal :r3 , produced.next(base+3).array.symbol
|
assert_equal :r2 , produced.next(base+3).array.symbol
|
||||||
assert_equal 1 , produced.next(base+3).index , "first arg must have index 1"
|
assert_equal 1 , produced.next(base+3).index , "first arg must have index 1"
|
||||||
end
|
end
|
||||||
def test_load_label
|
def test_load_label
|
||||||
|
@ -45,8 +45,8 @@ module Risc
|
|||||||
sl = main_ticks(29)
|
sl = main_ticks(29)
|
||||||
assert_equal Transfer , sl.class
|
assert_equal Transfer , sl.class
|
||||||
assert_equal :r0 , sl.from.symbol
|
assert_equal :r0 , sl.from.symbol
|
||||||
assert_equal :r1 , sl.to.symbol
|
assert_equal :r2 , sl.to.symbol
|
||||||
assert_equal 11 , @interpreter.get_register(:r1)
|
assert_equal 11 , @interpreter.get_register(:r2)
|
||||||
end
|
end
|
||||||
def test_restore_message
|
def test_restore_message
|
||||||
sl = main_ticks(30)
|
sl = main_ticks(30)
|
||||||
@ -58,8 +58,8 @@ module Risc
|
|||||||
def test_save_sys_return
|
def test_save_sys_return
|
||||||
sl = main_ticks(35)
|
sl = main_ticks(35)
|
||||||
assert_equal RegToSlot , sl.class
|
assert_equal RegToSlot , sl.class
|
||||||
assert_equal :r1 , sl.register.symbol #return
|
assert_equal :r2 , sl.register.symbol #return
|
||||||
assert_equal :r2 , sl.array.symbol #parfait integer
|
assert_equal :r3 , sl.array.symbol #parfait integer
|
||||||
assert_equal 2 , sl.index
|
assert_equal 2 , sl.index
|
||||||
end
|
end
|
||||||
def test_return
|
def test_return
|
||||||
|
Loading…
Reference in New Issue
Block a user