diff options
| author | Damien George <damien.p.george@gmail.com> | 2015-02-24 16:32:52 +0000 | 
|---|---|---|
| committer | Damien George <damien.p.george@gmail.com> | 2015-02-24 16:32:52 +0000 | 
| commit | e41b21c01ef0bf23d14a1e6277d7d89d80a9a394 (patch) | |
| tree | 9e1aec4a5a724f1c0cb6de23db3639cb2421afe1 /py/asmthumb.h | |
| parent | 8f7976ba0dd237e88200f7518fa235552a76281d (diff) | |
py: Make more asmthumb functions inline to reduce code size.
Diffstat (limited to 'py/asmthumb.h')
| -rw-r--r-- | py/asmthumb.h | 29 | 
1 files changed, 24 insertions, 5 deletions
| diff --git a/py/asmthumb.h b/py/asmthumb.h index 83a7dc270..8d413322f 100644 --- a/py/asmthumb.h +++ b/py/asmthumb.h @@ -111,7 +111,14 @@ static inline void asm_thumb_it_cc(asm_thumb_t *as, uint cc, uint mask)  #define ASM_THUMB_FORMAT_2_REG_OPERAND (0x0000)  #define ASM_THUMB_FORMAT_2_IMM_OPERAND (0x0400) -void asm_thumb_format_2(asm_thumb_t *as, uint op, uint rlo_dest, uint rlo_src, int src_b); +#define ASM_THUMB_FORMAT_2_ENCODE(op, rlo_dest, rlo_src, src_b) \ +    ((op) | ((src_b) << 6) | ((rlo_src) << 3) | (rlo_dest)) + +static inline void asm_thumb_format_2(asm_thumb_t *as, uint op, uint rlo_dest, uint rlo_src, int src_b) { +    assert(rlo_dest < ASM_THUMB_REG_R8); +    assert(rlo_src < ASM_THUMB_REG_R8); +    asm_thumb_op16(as, ASM_THUMB_FORMAT_2_ENCODE(op, rlo_dest, rlo_src, src_b)); +}  static inline void asm_thumb_add_rlo_rlo_rlo(asm_thumb_t *as, uint rlo_dest, uint rlo_src_a, uint rlo_src_b)      { asm_thumb_format_2(as, ASM_THUMB_FORMAT_2_ADD | ASM_THUMB_FORMAT_2_REG_OPERAND, rlo_dest, rlo_src_a, rlo_src_b); } @@ -130,7 +137,12 @@ static inline void asm_thumb_sub_rlo_rlo_i3(asm_thumb_t *as, uint rlo_dest, uint  #define ASM_THUMB_FORMAT_3_ADD (0x3000)  #define ASM_THUMB_FORMAT_3_SUB (0x3800) -void asm_thumb_format_3(asm_thumb_t *as, uint op, uint rlo, int i8); +#define ASM_THUMB_FORMAT_3_ENCODE(op, rlo, i8) ((op) | ((rlo) << 8) | (i8)) + +static inline void asm_thumb_format_3(asm_thumb_t *as, uint op, uint rlo, int i8) { +    assert(rlo < ASM_THUMB_REG_R8); +    asm_thumb_op16(as, ASM_THUMB_FORMAT_3_ENCODE(op, rlo, i8)); +}  static inline void asm_thumb_mov_rlo_i8(asm_thumb_t *as, uint rlo, int i8) { asm_thumb_format_3(as, ASM_THUMB_FORMAT_3_MOV, rlo, i8); }  static inline void asm_thumb_cmp_rlo_i8(asm_thumb_t *as, uint rlo, int i8) { asm_thumb_format_3(as, ASM_THUMB_FORMAT_3_CMP, rlo, i8); } @@ -175,7 +187,11 @@ static inline void asm_thumb_cmp_rlo_rlo(asm_thumb_t *as, uint rlo_dest, uint rl  #define ASM_THUMB_FORMAT_10_STRH (0x8000)  #define ASM_THUMB_FORMAT_10_LDRH (0x8800) -void asm_thumb_format_9_10(asm_thumb_t *as, uint op, uint rlo_dest, uint rlo_base, uint offset); +#define ASM_THUMB_FORMAT_9_10_ENCODE(op, rlo_dest, rlo_base, offset) \ +    ((op) | (((offset) << 6) & 0x07c0) | ((rlo_base) << 3) | (rlo_dest)) + +static inline void asm_thumb_format_9_10(asm_thumb_t *as, uint op, uint rlo_dest, uint rlo_base, uint offset) +    { asm_thumb_op16(as, ASM_THUMB_FORMAT_9_10_ENCODE(op, rlo_dest, rlo_base, offset)); }  static inline void asm_thumb_str_rlo_rlo_i5(asm_thumb_t *as, uint rlo_src, uint rlo_base, uint word_offset)      { asm_thumb_format_9_10(as, ASM_THUMB_FORMAT_9_STR | ASM_THUMB_FORMAT_9_WORD_TRANSFER, rlo_src, rlo_base, word_offset); } @@ -192,9 +208,12 @@ static inline void asm_thumb_ldrh_rlo_rlo_i5(asm_thumb_t *as, uint rlo_dest, uin  // TODO convert these to above format style +#define ASM_THUMB_OP_MOVW (0xf240) +#define ASM_THUMB_OP_MOVT (0xf2c0) +  void asm_thumb_mov_reg_reg(asm_thumb_t *as, uint reg_dest, uint reg_src); -void asm_thumb_movw_reg_i16(asm_thumb_t *as, uint reg_dest, int i16_src); -void asm_thumb_movt_reg_i16(asm_thumb_t *as, uint reg_dest, int i16_src); +void asm_thumb_mov_reg_i16(asm_thumb_t *as, uint mov_op, uint reg_dest, int i16_src); +  void asm_thumb_b_n(asm_thumb_t *as, uint label);  void asm_thumb_bcc_n(asm_thumb_t *as, int cond, uint label); | 
