diff options
Diffstat (limited to 'agbx')
-rw-r--r-- | agbx/source/bs/done.c | 29 |
1 files changed, 16 insertions, 13 deletions
diff --git a/agbx/source/bs/done.c b/agbx/source/bs/done.c index 6d56cb0..be8f423 100644 --- a/agbx/source/bs/done.c +++ b/agbx/source/bs/done.c @@ -16,20 +16,23 @@ void agbx_done(agbx_err const _err) { __builtin_unreachable(); } /* Display the barcode-like error message: */ - agbx_set10(0x400'0000u,0x403u); - agbx_i10 err[0x8u]; - for (agbx_i8 pos = 0x0u;pos != 0x8u;++pos) {err[pos] = (agbx_i8)_err >> pos & 0x1u ? 0x19u : 0x0u;} + agbx_set10(0x400'0000u,0x404u); + agbx_set10(0x500'0000u,0x0u); + agbx_set10(0x500'0002u,0x19u); + agbx_i8 err[0x8u]; + for (agbx_i8 pos = 0x0u;pos != 0x8u;++pos) {err[pos] = (agbx_i8)_err >> pos & 0x1u;} for (agbx_i10 pos = 0x0u;pos != 0x9600u;pos += 0xF0u) { - agbx_setpx2(0x600'0000u,pos, err[0x0u]); - agbx_setpx2(0x600'0000u,pos + 0x1u,err[0x1u]); - agbx_setpx2(0x600'0000u,pos + 0x2u,err[0x2u]); - agbx_setpx2(0x600'0000u,pos + 0x3u,err[0x3u]); - agbx_setpx2(0x600'0000u,pos + 0x4u,err[0x4u]); - agbx_setpx2(0x600'0000u,pos + 0x5u,err[0x5u]); - agbx_setpx2(0x600'0000u,pos + 0x6u,err[0x6u]); - agbx_setpx2(0x600'0000u,pos + 0x7u,err[0x7u]); - agbx_setpx2(0x600'0000u,pos + 0x8u,0x0u); - agbx_setpx2(0x600'0000u,pos + 0x9u,0x19u); + agbx_setpx1(0x600'0000u,pos, err[0x0u]); + agbx_setpx1(0x600'0000u,pos + 0x1u,err[0x1u]); + agbx_setpx1(0x600'0000u,pos + 0x2u,err[0x2u]); + agbx_setpx1(0x600'0000u,pos + 0x3u,err[0x3u]); + agbx_setpx1(0x600'0000u,pos + 0x4u,err[0x4u]); + agbx_setpx1(0x600'0000u,pos + 0x5u,err[0x5u]); + agbx_setpx1(0x600'0000u,pos + 0x6u,err[0x6u]); + agbx_setpx1(0x600'0000u,pos + 0x7u,err[0x7u]); + agbx_setpx1(0x600'0000u,pos + 0x8u,0x0u); + agbx_setpx1(0x600'0000u,pos + 0x9u,0x1u); + agbx_setpx1(0x600'0000u,pos + 0xAu,0x0u); } __asm__ ( "swi 0x2\n" |