rewrite MultiBootWaitCycles as naked function

Before, when compiling MultiBootWaitCycles with O3 and MODERN=1, you
might have run into problems during optimizations when the compiler tried
to optimize the function, even if declared NOINLINE.

When rewriting this function as NAKED function, this no longer happens
as the optimizer will treat it as black box and compilation will resume.
This commit is contained in:
Michael Panzlaff 2020-10-02 12:12:31 +02:00
parent 5259898325
commit 187c96d6e5

View file

@ -1,3 +1,4 @@
#include "global.h"
#include "gba/gba.h" #include "gba/gba.h"
#include "multiboot.h" #include "multiboot.h"
@ -435,23 +436,23 @@ static int MultiBootHandShake(struct MultiBootParam *mp)
#undef must_data #undef must_data
} }
static NOINLINE void MultiBootWaitCycles(u32 cycles) NAKED
static void MultiBootWaitCycles(u32 cycles)
{ {
asm("mov r2, pc"); asm_unified("\
asm("lsr r2, #24"); mov r2, pc\n\
asm("mov r1, #12"); lsrs r2, 24\n\
asm("cmp r2, #0x02"); movs r1, 12\n\
asm("beq MultiBootWaitCyclesLoop"); cmp r2, 2\n\
beq MultiBootWaitCyclesLoop\n\
asm("mov r1, #13"); movs r1, 13\n\
asm("cmp r2, #0x08"); cmp r2, 8\n\
asm("beq MultiBootWaitCyclesLoop"); beq MultiBootWaitCyclesLoop\n\
movs r1, 4\n\
asm("mov r1, #4"); MultiBootWaitCyclesLoop:\n\
subs r0, r1\n\
asm("MultiBootWaitCyclesLoop:"); bgt MultiBootWaitCyclesLoop\n\
asm("sub r0, r1"); bx lr\n");
asm("bgt MultiBootWaitCyclesLoop");
} }
static void MultiBootWaitSendDone(void) static void MultiBootWaitSendDone(void)