register reference creation got more complicated
This commit is contained in:
@ -77,7 +77,7 @@ module Arm
|
||||
options = {} if options == nil
|
||||
options.merge defaults
|
||||
options[:opcode] = inst
|
||||
first = Register::RegisterReference.new(first) if first.is_a? Symbol
|
||||
first = Register::RegisterReference.convert(first)
|
||||
clazz.new(first , options)
|
||||
end
|
||||
end
|
||||
@ -88,8 +88,8 @@ module Arm
|
||||
create_method(inst) do |left ,right , options = nil|
|
||||
options = {} if options == nil
|
||||
options.merge defaults
|
||||
left = Register::RegisterReference.new(left) if left.is_a? Symbol
|
||||
right = Register::RegisterReference.new(right) if right.is_a? Symbol
|
||||
left = Register::RegisterReference.convert(left)
|
||||
right = Register::RegisterReference.convert(right)
|
||||
options[:opcode] = inst
|
||||
clazz.new(left , right ,options)
|
||||
end
|
||||
@ -102,9 +102,9 @@ module Arm
|
||||
options = {} if options == nil
|
||||
options.merge defaults
|
||||
options[:opcode] = inst
|
||||
result = Register::RegisterReference.new(result) if result.is_a? Symbol
|
||||
left = Register::RegisterReference.new(left) if left.is_a? Symbol
|
||||
right = Register::RegisterReference.new(right) if right.is_a? Symbol
|
||||
result = Register::RegisterReference.convert(result)
|
||||
left = Register::RegisterReference.convert(left)
|
||||
right = Register::RegisterReference.convert(right)
|
||||
clazz.new(result, left , right ,options)
|
||||
end
|
||||
end
|
||||
|
@ -26,7 +26,11 @@ module Arm
|
||||
arg = @left
|
||||
arg = arg.symbol if( arg.is_a? ::Register::RegisterReference )
|
||||
#str / ldr are _serious instructions. With BIG possibilities not half are implemented
|
||||
if (arg.is_a?(Symbol) or arg.is_a?(::Register::RegisterReference)) #symbol is register
|
||||
is_reg = arg.is_a?(::Register::RegisterReference)
|
||||
if( arg.is_a?(Symbol) and not is_reg)
|
||||
is_reg = (arg.to_s[0] == "r")
|
||||
end
|
||||
if (is_reg ) #symbol is register
|
||||
rn = arg
|
||||
if @right
|
||||
operand = @right
|
||||
@ -46,7 +50,7 @@ module Arm
|
||||
end
|
||||
end
|
||||
end
|
||||
elsif (arg.is_a?(Parfait::Object) ) #use pc relative
|
||||
elsif (arg.is_a?(Parfait::Object) or arg.is_a? Symbol ) #use pc relative
|
||||
rn = :pc
|
||||
operand = arg.position - self.position - 8 #stringtable is after code
|
||||
add_offset = 1
|
||||
|
Reference in New Issue
Block a user