rubyx/lib/risc/builtin/integer.rb

105 lines
4.0 KiB
Ruby
Raw Normal View History

#integer related kernel functions
module Risc
module Builtin
module Integer
module ClassMethods
include CompileHelper
2015-08-07 15:46:55 +02:00
def mod4(context)
source = "mod4"
compiler = compiler_for(:Integer,:mod4 ,{})
me = compiler.add_known( :receiver )
compiler.reduce_int( source , me )
two = compiler.use_reg :fixnum , 2
compiler.add_load_data( source , 2 , two )
compiler.add_code Risc.op( source , :>> , me , two)
compiler.add_new_int(me , two)
compiler.add_reg_to_slot( source , two , :message , :return_value)
compiler.add_mom( Mom::ReturnSequence.new)
return compiler.method
2015-08-05 17:49:37 +02:00
end
def putint(context)
compiler = compiler_for(:Integer,:putint ,{})
return compiler.method
2015-08-05 17:49:37 +02:00
end
def +( context )
source = "plus"
2018-03-31 18:17:55 +02:00
compiler = compiler_for(:Integer,:+ ,{other: :Integer})
me , other = compiler.self_and_int_arg(source + "1")
compiler.reduce_int( source + "2", me )
compiler.reduce_int( source + "3", other )
2018-03-30 17:05:38 +02:00
compiler.add_code Risc.op( source + "4", :+ , me , other)
2018-04-01 13:01:17 +02:00
compiler.add_new_int(me , other)
2018-03-31 19:21:27 +02:00
compiler.add_reg_to_slot( source + "5" , other , :message , :return_value)
compiler.add_mom( Mom::ReturnSequence.new)
return compiler.method
end
def div10( context )
s = "div_10 "
compiler = compiler_for(:Integer,:div10 ,{})
#FIX: this could load receiver once, reduce and then transfer twice
me = compiler.add_known( :receiver )
tmp = compiler.add_known( :receiver )
q = compiler.add_known( :receiver )
compiler.reduce_int( s , me )
compiler.reduce_int( s , tmp )
compiler.reduce_int( s , q )
const = compiler.use_reg :fixnum , 1
compiler.add_load_data( s , 1 , const )
# int tmp = self >> 1
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :>> , tmp , const)
# int q = self >> 2
compiler.add_load_data( s , 2 , const)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :>> , q , const)
# q = q + tmp
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :+ , q , tmp )
# tmp = q >> 4
compiler.add_load_data( s , 4 , const)
compiler.add_transfer( s, q , tmp)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :>> , tmp , const)
# q = q + tmp
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :+ , q , tmp )
# tmp = q >> 8
compiler.add_load_data( s , 8 , const)
compiler.add_transfer( s, q , tmp)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :>> , tmp , const)
# q = q + tmp
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :+ , q , tmp )
# tmp = q >> 16
compiler.add_load_data( s , 16 , const)
compiler.add_transfer( s, q , tmp)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :>> , tmp , const)
# q = q + tmp
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :+ , q , tmp )
# q = q >> 3
compiler.add_load_data( s , 3 , const)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :>> , q , const)
# tmp = q * 10
compiler.add_load_data( s , 10 , const)
compiler.add_transfer( s, q , tmp)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :* , tmp , const)
# tmp = self - tmp
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :- , me , tmp )
compiler.add_transfer( s , me , tmp)
# tmp = tmp + 6
compiler.add_load_data( s , 6 , const)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :+ , tmp , const )
# tmp = tmp >> 4
compiler.add_load_data( s , 4 , const)
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :>> , tmp , const )
# return q + tmp
2018-03-24 16:53:27 +01:00
compiler.add_code Risc.op( s , :+ , q , tmp )
2018-04-01 13:01:17 +02:00
compiler.add_new_int(q , tmp)
compiler.add_reg_to_slot( s , tmp , :message , :return_value)
2018-04-01 13:01:17 +02:00
compiler.add_mom( Mom::ReturnSequence.new)
return compiler.method
end
end
extend ClassMethods
end
end
end