Move the Main instruction from register to virtual

also needs a branch in register.
This way the register level is self sufficient
(noticed while writing debugger)
This commit is contained in:
Torsten Ruger 2015-07-17 13:21:57 +03:00
parent 60d09ab057
commit 50da6a40f2
11 changed files with 55 additions and 24 deletions

View File

@ -112,6 +112,7 @@ module Arm
end end
Arm::ArmMachine.init Arm::ArmMachine.init
require_relative "passes/call_implementation" require_relative "passes/call_implementation"
require_relative "passes/branch_implementation"
require_relative "passes/syscall_implementation" require_relative "passes/syscall_implementation"
require_relative "passes/save_implementation" require_relative "passes/save_implementation"
require_relative "passes/transfer_implementation" require_relative "passes/transfer_implementation"
@ -119,4 +120,3 @@ require_relative "passes/get_implementation"
require_relative "passes/set_implementation" require_relative "passes/set_implementation"
require_relative "passes/return_implementation" require_relative "passes/return_implementation"
require_relative "passes/constant_implementation" require_relative "passes/constant_implementation"
require_relative "passes/main_implementation"

View File

@ -0,0 +1,17 @@
module Arm
# This implements branch logic, which is simply assembler branch
#
# The only target for a call is a Block, so we just need to get the address for the code
# and branch to it.
#
class BranchImplementation
def run block
block.codes.dup.each do |code|
next unless code.is_a? Register::Branch
br = ArmMachine.b( code.block )
block.replace(code , br )
end
end
end
Virtual.machine.add_pass "Arm::BranchImplementation"
end

View File

@ -1,17 +0,0 @@
module Arm
# "Boot" the register machine at the function given
# meaning jump to that function currently. Maybe better to do some machine setup
# and possibly some cleanup/exit has to tie in, but that is not this day
class MainImplementation
def run block
block.codes.dup.each do |code|
next unless code.is_a? Register::RegisterMain
call = ArmMachine.b( code.method )
block.replace(code , call )
end
end
end
Virtual.machine.add_pass "Arm::MainImplementation"
end

View File

@ -23,7 +23,7 @@ module Elf
# for debug add labels to the block positions # for debug add labels to the block positions
@object_machine.space.classes.values.each do |clazz| @object_machine.space.classes.values.each do |clazz|
clazz.instance_methods.each do |f| clazz.instance_methods.each do |f|
f.info.blocks.each do |b| f.source.blocks.each do |b|
add_symbol "#{clazz.name}::#{f.name}:#{b.name}" , b.position add_symbol "#{clazz.name}::#{f.name}:#{b.name}" , b.position
end end
end end

View File

@ -43,4 +43,4 @@ require_relative "instructions/function_call"
require_relative "instructions/function_return" require_relative "instructions/function_return"
require_relative "instructions/save_return" require_relative "instructions/save_return"
require_relative "instructions/register_transfer" require_relative "instructions/register_transfer"
require_relative "instructions/register_main" require_relative "instructions/branch"

View File

@ -0,0 +1,12 @@
module Register
# a branch must branch to a block.
class Branch < Instruction
def initialize to
raise "No block" unless to
@block = to
end
attr_reader :block
end
end

View File

@ -0,0 +1,17 @@
module Register
# "Boot" the virtual machine at the function given
# meaning jump to that function currently. Maybe better to do some machine setup
# and possibly some cleanup/exit has to tie in, but that is not this day
class MainImplementation
def run block
block.codes.dup.each do |code|
next unless code.is_a? Virtual::VirtualMain
branch = Register::Branch.new( code.method.source.blocks.first )
block.replace(code , branch )
end
end
end
Virtual.machine.add_pass "Register::MainImplementation"
end

View File

@ -1,6 +1,7 @@
require_relative "instruction" require_relative "instruction"
require_relative "register_reference" require_relative "register_reference"
require_relative "assembler" require_relative "assembler"
require_relative "passes/main_implementation"
require_relative "passes/frame_implementation" require_relative "passes/frame_implementation"
require_relative "passes/message_implementation" require_relative "passes/message_implementation"
require_relative "passes/set_implementation" require_relative "passes/set_implementation"

View File

@ -26,3 +26,4 @@ require_relative "instructions/method_return"
require_relative "instructions/new_frame" require_relative "instructions/new_frame"
require_relative "instructions/new_message" require_relative "instructions/new_message"
require_relative "instructions/set" require_relative "instructions/set"
require_relative "instructions/virtual_main"

View File

@ -1,11 +1,11 @@
module Register module Virtual
# This starts the register machine machine at the given function. # This starts the Virtual machine machine at the given function.
# The implementation is most likely a jump/branch , but since we have the extra layer # The implementation is most likely a jump/branch , but since we have the extra layer
# we make good use of it, ie give things descriptive names (what they do, not how) # we make good use of it, ie give things descriptive names (what they do, not how)
class RegisterMain < Instruction class VirtualMain < Instruction
include Positioned include Positioned
def initialize method def initialize method

View File

@ -124,7 +124,7 @@ module Virtual
return if @booted return if @booted
boot_parfait! boot_parfait!
@init = Block.new("init",nil) @init = Block.new("init",nil)
@init.add_code Register::RegisterMain.new( self.space.get_init ) @init.add_code Virtual::VirtualMain.new( self.space.get_init )
@booted = true @booted = true
end end