summaryrefslogtreecommitdiff
path: root/agbx
diff options
context:
space:
mode:
Diffstat (limited to 'agbx')
-rw-r--r--agbx/source/bs/done.c29
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"