diff options
| author | Damien George <damien.p.george@gmail.com> | 2016-11-28 09:24:50 +1100 |
|---|---|---|
| committer | Damien George <damien.p.george@gmail.com> | 2016-11-28 09:24:50 +1100 |
| commit | 612599587bef71e1deca9a77a8e2e16e69b045de (patch) | |
| tree | ea4dc739dbff37bc65a5e522411c0e472cdc11a4 /py/asmarm.h | |
| parent | 21e1703d37a645548aff6b833a49dfdfb3543c70 (diff) | |
py: Factor out common code from assemblers into asmbase.[ch].
All assemblers should "derive" from mp_asm_base_t.
Diffstat (limited to 'py/asmarm.h')
| -rw-r--r-- | py/asmarm.h | 20 |
1 files changed, 6 insertions, 14 deletions
diff --git a/py/asmarm.h b/py/asmarm.h index 15e7a047b..263721057 100644 --- a/py/asmarm.h +++ b/py/asmarm.h @@ -28,9 +28,7 @@ #define __MICROPY_INCLUDED_PY_ASMARM_H__ #include "py/misc.h" - -#define ASM_ARM_PASS_COMPUTE (1) -#define ASM_ARM_PASS_EMIT (2) +#include "py/asmbase.h" #define ASM_ARM_REG_R0 (0) #define ASM_ARM_REG_R1 (1) @@ -68,22 +66,16 @@ #define ASM_ARM_CC_LE (0xd << 28) #define ASM_ARM_CC_AL (0xe << 28) -typedef struct _asm_arm_t asm_arm_t; +typedef struct _asm_arm_t { + mp_asm_base_t base; + uint push_reglist; + uint stack_adjust; +} asm_arm_t; -asm_arm_t *asm_arm_new(uint max_num_labels); -void asm_arm_free(asm_arm_t *as, bool free_code); -void asm_arm_start_pass(asm_arm_t *as, uint pass); void asm_arm_end_pass(asm_arm_t *as); -uint asm_arm_get_code_pos(asm_arm_t *as); -uint asm_arm_get_code_size(asm_arm_t *as); -void *asm_arm_get_code(asm_arm_t *as); void asm_arm_entry(asm_arm_t *as, int num_locals); void asm_arm_exit(asm_arm_t *as); -void asm_arm_label_assign(asm_arm_t *as, uint label); - -void asm_arm_align(asm_arm_t* as, uint align); -void asm_arm_data(asm_arm_t* as, uint bytesize, uint val); void asm_arm_bkpt(asm_arm_t *as); |
