2018-05-12 18:32:10 +03:00
|
|
|
module Risc
|
|
|
|
# A platform is (or will be) something like the linux tripple
|
|
|
|
#
|
|
|
|
# Currently it just provides a Translator and binary start point
|
|
|
|
#
|
|
|
|
class Platform
|
|
|
|
|
|
|
|
# return the translator instance that traslates risc intructions into
|
|
|
|
# platform specific ones
|
|
|
|
def translator
|
2020-03-19 18:18:22 +02:00
|
|
|
raise "not implemented in #{self.class}"
|
2018-05-12 18:32:10 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
# return an integer where the binary is loaded
|
|
|
|
def loaded_at
|
2020-03-19 18:18:22 +02:00
|
|
|
raise "not implemented in #{self.class}"
|
2018-05-12 18:32:10 +03:00
|
|
|
end
|
2020-02-26 19:01:01 +02:00
|
|
|
|
2020-03-19 18:18:22 +02:00
|
|
|
# return an array of register names that should be used by the allocator
|
|
|
|
# does not include :message
|
|
|
|
# could be in interpreter and arm, but here for now
|
|
|
|
def register_names
|
2020-03-22 11:29:56 +02:00
|
|
|
(0 .. 12).collect{|i| "r#{i}".to_sym }
|
2020-03-18 15:27:40 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
# return the Allocator for the platform
|
|
|
|
# stanrard implementation return StandardAllocator, which uses
|
|
|
|
# num_registers and assumes rXX naming (ie arm + interpreter)
|
|
|
|
#
|
|
|
|
# Possibility to override and implemented different schemes
|
|
|
|
def allocator(compiler)
|
|
|
|
StandardAllocator.new(compiler , self )
|
2020-02-26 19:01:01 +02:00
|
|
|
end
|
2020-03-13 20:18:34 +02:00
|
|
|
|
2020-03-19 18:18:22 +02:00
|
|
|
def assign_reg?(name)
|
|
|
|
case name
|
|
|
|
when :message
|
2020-03-22 11:29:56 +02:00
|
|
|
:r13
|
2020-03-19 18:18:22 +02:00
|
|
|
when :syscall_1
|
|
|
|
:r0
|
|
|
|
when :syscall_2
|
|
|
|
:r1
|
2020-03-25 18:58:10 +02:00
|
|
|
when :syscall_3
|
|
|
|
:r2
|
2020-03-22 10:42:50 +02:00
|
|
|
when :saved_message
|
2020-03-22 11:29:56 +02:00
|
|
|
:r14
|
2020-03-19 18:18:22 +02:00
|
|
|
else
|
|
|
|
nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-05-12 18:32:10 +03:00
|
|
|
# Factory method to create a Platform object according to the platform
|
|
|
|
# string given.
|
2018-05-17 09:31:36 +03:00
|
|
|
# Currently only "Arm" and "Interpreter"
|
2018-05-12 18:32:10 +03:00
|
|
|
def self.for( name )
|
2018-07-02 09:36:29 +03:00
|
|
|
return name if name.is_a?(Platform)
|
|
|
|
name = name.to_s.capitalize
|
2018-05-12 18:32:10 +03:00
|
|
|
case name
|
|
|
|
when "Arm"
|
|
|
|
return Arm::ArmPlatform.new
|
2018-05-17 09:31:36 +03:00
|
|
|
when "Interpreter"
|
|
|
|
return Risc::InterpreterPlatform.new
|
2018-05-12 18:32:10 +03:00
|
|
|
else
|
2018-07-01 11:57:17 +03:00
|
|
|
raise "not recognized platform #{name.class}:#{name}"
|
2018-05-12 18:32:10 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-05-17 09:31:36 +03:00
|
|
|
require_relative "interpreter_platform"
|