diff options
author | Damien George <damien.p.george@gmail.com> | 2014-04-08 18:28:33 +0100 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2014-04-08 18:28:33 +0100 |
commit | 47e1b85d9c2e87aad8396da8b2c492157deaaf3a (patch) | |
tree | e5d755758e105044fe60b888c80c6ed0def6dc1a /py/asmthumb.h | |
parent | 495d781a36381927bcf0c1d03a055a2e3a3284bf (diff) |
py: Improve inline assembler; add a few more opcodes.
Diffstat (limited to 'py/asmthumb.h')
-rw-r--r-- | py/asmthumb.h | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/py/asmthumb.h b/py/asmthumb.h index dcd9c2e3a..60a86ea50 100644 --- a/py/asmthumb.h +++ b/py/asmthumb.h @@ -62,8 +62,11 @@ void asm_thumb_movs_rlo_i8(asm_thumb_t *as, uint rlo_dest, int i8_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_reg(asm_thumb_t *as, uint reg_dest, uint reg_src); +void asm_thumb_add_reg_reg_reg(asm_thumb_t *as, uint rlo_dest, uint rlo_src_a, uint rlo_src_b); void asm_thumb_subs_rlo_rlo_i3(asm_thumb_t *as, uint rlo_dest, uint rlo_src, int i3_src); +void asm_thumb_cmp_reg_reg(asm_thumb_t *as, uint rlo_a, uint rlo_b); void asm_thumb_cmp_rlo_i8(asm_thumb_t *as, uint rlo, int i8); +void asm_thumb_ite_ge(asm_thumb_t *as); void asm_thumb_b_n(asm_thumb_t *as, int label); void asm_thumb_bcc_n(asm_thumb_t *as, int cond, int label); @@ -73,10 +76,6 @@ void asm_thumb_mov_local_reg(asm_thumb_t *as, int local_num_dest, uint rlo_src); void asm_thumb_mov_reg_local(asm_thumb_t *as, uint rlo_dest, int local_num); // convenience void asm_thumb_mov_reg_local_addr(asm_thumb_t *as, uint rlo_dest, int local_num); // convenience -void asm_thumb_add_reg_reg_reg(asm_thumb_t *as, uint rlo_dest, uint rlo_src_a, uint rlo_src_b); // convenience ? -void asm_thumb_cmp_reg_reg(asm_thumb_t *as, uint rlo_a, uint rlo_b); // convenience ? -void asm_thumb_ite_ge(asm_thumb_t *as); // convenience ? - void asm_thumb_b_label(asm_thumb_t *as, int label); // convenience ? void asm_thumb_bcc_label(asm_thumb_t *as, int cc, int label); // convenience: picks narrow or wide branch void asm_thumb_bl_ind(asm_thumb_t *as, void *fun_ptr, uint fun_id, uint reg_temp); // convenience ? |