summaryrefslogtreecommitdiff
path: root/py/asmxtensa.c
diff options
context:
space:
mode:
authorDamien George <damien@micropython.org>2024-03-18 12:30:09 +1100
committerDamien George <damien@micropython.org>2024-03-19 10:31:36 +1100
commitb50efbd0e319764dab3f49b64519cfea5f2c2bab (patch)
tree38ae2eb32880c40b616628e633a879def62b65db /py/asmxtensa.c
parentf52b0d0ff1788225fd61a748e0786aa90e953481 (diff)
py/asmxtensa: Optimise asm_xtensa_mov_reg_i32_optimised() for tiny ints.
Signed-off-by: Damien George <damien@micropython.org>
Diffstat (limited to 'py/asmxtensa.c')
-rw-r--r--py/asmxtensa.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/py/asmxtensa.c b/py/asmxtensa.c
index 84018402f..0fbe351dc 100644
--- a/py/asmxtensa.c
+++ b/py/asmxtensa.c
@@ -185,7 +185,9 @@ size_t asm_xtensa_mov_reg_i32(asm_xtensa_t *as, uint reg_dest, uint32_t i32) {
}
void asm_xtensa_mov_reg_i32_optimised(asm_xtensa_t *as, uint reg_dest, uint32_t i32) {
- if (SIGNED_FIT12(i32)) {
+ if (-32 <= (int)i32 && (int)i32 <= 95) {
+ asm_xtensa_op_movi_n(as, reg_dest, i32);
+ } else if (SIGNED_FIT12(i32)) {
asm_xtensa_op_movi(as, reg_dest, i32);
} else {
asm_xtensa_mov_reg_i32(as, reg_dest, i32);