view python/target/armtarget.py @ 323:e9fe6988497c

Used burg for generating expressions
author Windel Bouwman
date Thu, 30 Jan 2014 19:03:24 +0100
parents 44f336460c2a
children 6f4753202b9a
line wrap: on
line source

import struct
from .basetarget import Register, Instruction, Target, Label, LabelRef
from .basetarget import Imm32, Imm8, Imm7, Imm3
from .arminstructions import allins, Reg8Op, ArmRegister
from .arminstructions import Dcd, B
from .arminstructions import R0, R1, R2, R3, R4, R5, R6, R7, LR, PC, SP

from .armframe import ArmFrame
from .arminstructionselector import ArmInstructionSelector

""" ARM target description. """

# TODO: encode this in DSL (domain specific language)
# TBD: is this required?
# TODO: make a difference between armv7 and armv5?


class ArmTarget(Target):
    def __init__(self):
        super().__init__('arm')
        for i in allins:
            self.addInstruction(i)
            # TODO: fix this nicer?
            #setattr(self, i.__name__, i)
        self.check()
        self.ins_sel = ArmInstructionSelector()
        self.FrameClass = ArmFrame

    def startCode(self, outs):
        """ Emit some startup code in the output stream """
        outs.selectSection('code')
        # assembly glue to make it work:
        # TODO: this must be in source code, not in compiler
        outs.emit(Dcd(Imm32(0x20000678)))   # initial SP
        outs.emit(Dcd(Imm32(0x08000009)))   # reset vector
        outs.emit(B(LabelRef('main')))