diff options
author | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2015-05-07 23:08:09 +0300 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2015-05-08 22:35:34 +0100 |
commit | 351424e71900d8d03d1a98a3fe8d2fa6561c0da8 (patch) | |
tree | 141365708268da7a3c68ff62176d1e095cbdfcda /py/asmarm.h | |
parent | d792d9e49ea89aa8a742f57d70e5b59c9d68939e (diff) |
emitnative: Revamp ARM codegen compile after full-arg support refactors.
The code was apparently broken after 9988618e0e0f5c319e31b135d993e22efb593093
"py: Implement full func arg passing for native emitter.". This attempts to
propagate those changes to ARM emitter.
Diffstat (limited to 'py/asmarm.h')
-rw-r--r-- | py/asmarm.h | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/py/asmarm.h b/py/asmarm.h index c9819cdab..20be84b97 100644 --- a/py/asmarm.h +++ b/py/asmarm.h @@ -74,6 +74,7 @@ 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); @@ -108,10 +109,10 @@ void asm_arm_lsl_reg_reg(asm_arm_t *as, uint rd, uint rs); void asm_arm_asr_reg_reg(asm_arm_t *as, uint rd, uint rs); // memory -void asm_arm_ldr_reg_reg(asm_arm_t *as, uint rd, uint rn); +void asm_arm_ldr_reg_reg(asm_arm_t *as, uint rd, uint rn, uint byte_offset); void asm_arm_ldrh_reg_reg(asm_arm_t *as, uint rd, uint rn); void asm_arm_ldrb_reg_reg(asm_arm_t *as, uint rd, uint rn); -void asm_arm_str_reg_reg(asm_arm_t *as, uint rd, uint rm); +void asm_arm_str_reg_reg(asm_arm_t *as, uint rd, uint rm, uint byte_offset); void asm_arm_strh_reg_reg(asm_arm_t *as, uint rd, uint rm); void asm_arm_strb_reg_reg(asm_arm_t *as, uint rd, uint rm); // store to array @@ -119,6 +120,10 @@ void asm_arm_str_reg_reg_reg(asm_arm_t *as, uint rd, uint rm, uint rn); void asm_arm_strh_reg_reg_reg(asm_arm_t *as, uint rd, uint rm, uint rn); void asm_arm_strb_reg_reg_reg(asm_arm_t *as, uint rd, uint rm, uint rn); +// stack +void asm_arm_push(asm_arm_t *as, uint reglist); +void asm_arm_pop(asm_arm_t *as, uint reglist); + // control flow void asm_arm_bcc_label(asm_arm_t *as, int cond, uint label); void asm_arm_b_label(asm_arm_t *as, uint label); |