rename objects to value sin assembler
This commit is contained in:
@ -3,7 +3,7 @@ module Asm
|
||||
|
||||
# TODO actually find the closest somehow (DROPPED for now)
|
||||
def self.closest_addrtable(as)
|
||||
as.objects.find do |obj|
|
||||
as.values.find do |obj|
|
||||
obj.is_a?(Asm::Arm::AddrTableObject)
|
||||
end || (raise Asm::AssemblyError.new('could not find addrtable to use', nil))
|
||||
end
|
||||
|
@ -13,10 +13,6 @@ module Asm
|
||||
|
||||
class ArmAssembler < Asm::Assembler
|
||||
|
||||
def add_data(str)
|
||||
add_object Asm::DataObject.new(str)
|
||||
end
|
||||
|
||||
%w(r0 r1 r2 r3 r4 r5 r6 r7 r8 r9 r10 r11 r12
|
||||
r13 r14 r15 a1 a2 a3 a4 v1 v2 v3 v4 v5 v6
|
||||
rfp sl fp ip sp lr pc
|
||||
@ -36,6 +32,8 @@ module Asm
|
||||
node.args << arg
|
||||
elsif (arg.is_a?(Integer))
|
||||
node.args << Asm::NumLiteralNode.new(arg)
|
||||
elsif (arg.is_a?(String))
|
||||
node.args << add_string(arg)
|
||||
elsif (arg.is_a?(Symbol))
|
||||
node.args << Asm::LabelRefNode.new(arg.to_s)
|
||||
elsif (arg.is_a?(Asm::Arm::GeneratorLabel) or arg.is_a?(Asm::Arm::GeneratorExternLabel))
|
||||
@ -45,7 +43,7 @@ module Asm
|
||||
end
|
||||
}
|
||||
|
||||
add_object Asm::Arm::Instruction.new(node)
|
||||
add_value Asm::Arm::Instruction.new(node)
|
||||
end
|
||||
|
||||
%w(adc add and bic eor orr rsb rsc sbc sub mov mvn cmn cmp teq tst b bl bx
|
||||
@ -68,23 +66,13 @@ module Asm
|
||||
}
|
||||
}
|
||||
|
||||
def label
|
||||
Asm::Arm::GeneratorLabel.new(self)
|
||||
end
|
||||
|
||||
def label!
|
||||
lbl = Asm::Arm::GeneratorLabel.new(self)
|
||||
lbl.set!
|
||||
lbl
|
||||
end
|
||||
|
||||
#externs dropped for now
|
||||
def extern(sym)
|
||||
if (lbl = @externs.find { |extern| extern.name == sym })
|
||||
lbl
|
||||
else
|
||||
@externs << lbl = Asm::Arm::GeneratorExternLabel.new(sym)
|
||||
add_object lbl
|
||||
add_value lbl
|
||||
lbl
|
||||
end
|
||||
end
|
||||
|
@ -11,7 +11,8 @@ class Asm::Arm::GeneratorLabel < Asm::LabelObject
|
||||
0
|
||||
end
|
||||
def set!
|
||||
@asm.add_object self
|
||||
@asm.add_value self
|
||||
self
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -84,7 +84,7 @@ module Asm
|
||||
|
||||
@operand = rm_ref | (shift_op << 4) | (shift_imm << 4+3)
|
||||
else
|
||||
raise Asm::AssemblyError.new(Asm::ERRSTR_INVALID_ARG, arg)
|
||||
raise Asm::AssemblyError.new(Asm::ERRSTR_INVALID_ARG + " " + arg.inspect, arg)
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -5,22 +5,44 @@ module Asm
|
||||
|
||||
class Assembler
|
||||
def initialize
|
||||
@objects = []
|
||||
@values = []
|
||||
@position = -1 # marks not set
|
||||
@label_objects = []
|
||||
@labels = []
|
||||
@string_table = {}
|
||||
#@relocations = []
|
||||
end
|
||||
attr_reader :relocations, :objects , :position
|
||||
attr_reader :relocations, :values , :position
|
||||
|
||||
def add_object(obj)
|
||||
obj.at(@position)
|
||||
@position += obj.length
|
||||
@objects << obj
|
||||
def add_string str
|
||||
value = @string_table[str]
|
||||
return value if value
|
||||
data = Asm::DataObject.new(str)
|
||||
add_value data
|
||||
@string_table[str] = data
|
||||
end
|
||||
|
||||
def strings
|
||||
@string_table.values
|
||||
end
|
||||
|
||||
def add_value(val)
|
||||
val.at(@position)
|
||||
@position += val.length
|
||||
@values << val
|
||||
end
|
||||
|
||||
def label
|
||||
label = Asm::Arm::GeneratorLabel.new(self)
|
||||
@labels << label
|
||||
label
|
||||
end
|
||||
|
||||
def label!
|
||||
label.set!
|
||||
end
|
||||
|
||||
def assemble(io)
|
||||
@objects.each do |obj|
|
||||
@values.each do |obj|
|
||||
obj.assemble io, self
|
||||
end
|
||||
end
|
||||
@ -38,7 +60,7 @@ module Asm
|
||||
|
||||
#old assemble function
|
||||
#def assemble(io)
|
||||
# @objects.each do |obj|
|
||||
# @values.each do |obj|
|
||||
# obj.assemble io, self
|
||||
# end
|
||||
# @relocations.delete_if do |reloc|
|
||||
|
Reference in New Issue
Block a user