fix rebooting by clearing our main

This commit is contained in:
Torsten Ruger 2015-07-18 16:12:50 +03:00
parent b83f50c57c
commit 3d8fc8819c
2 changed files with 17 additions and 4 deletions

View File

@ -117,7 +117,10 @@ module Virtual
end end
def boot def boot
return self if @booted if @booted
self.space.get_main.clear_source
return self
end
boot_parfait! boot_parfait!
@init = Block.new("init",nil) @init = Block.new("init",nil)
@init.add_code Virtual::VirtualMain.new( self.space.get_init ) @init.add_code Virtual::VirtualMain.new( self.space.get_init )
@ -154,4 +157,13 @@ module Virtual
end end
Parfait::Method.class_eval do
# for testing we need to reuse the main function (or do we?)
# so remove the code that is there
def clear_source
self.source.send :initialize , self
end
end
require_relative "boot" require_relative "boot"

View File

@ -132,9 +132,9 @@ module Virtual
# mov and add will be called on Machine and generate Instructions that are then added # mov and add will be called on Machine and generate Instructions that are then added
# to the current block # to the current block
# also symbols are supported and wrapped as register usages (for bare metal programming) # also symbols are supported and wrapped as register usages (for bare metal programming)
def method_missing(meth, *arg_names, &block) # def method_missing(meth, *arg_names, &block)
add_code ::Arm::ArmMachine.send(meth , *arg_names) # add_code ::Arm::ArmMachine.send(meth , *arg_names)
end # end
def byte_length def byte_length
@blocks.inject(0) { |c , block| c += block.byte_length } @blocks.inject(0) { |c , block| c += block.byte_length }
@ -148,6 +148,7 @@ module Virtual
at = at + block.byte_length at = at + block.byte_length
end end
end end
end end
end end