diff options
author | red031000 <rubenru09@aol.com> | 2021-07-23 01:11:15 +0100 |
---|---|---|
committer | red031000 <rubenru09@aol.com> | 2021-07-23 01:12:27 +0100 |
commit | 5bf13c7f48fe91c7902ce50250bc1a5a2398a2ae (patch) | |
tree | 2e91e60bdb7a9174b16d8ca1b532809d4ae2e5b6 /arm9/lib/src/GX_g3x.c | |
parent | c2d91a2d997afd01fa4f40e1e16d5ee85557c9a8 (diff) |
separate out libs to libc, libnns and NitroSDK
Diffstat (limited to 'arm9/lib/src/GX_g3x.c')
-rw-r--r-- | arm9/lib/src/GX_g3x.c | 235 |
1 files changed, 0 insertions, 235 deletions
diff --git a/arm9/lib/src/GX_g3x.c b/arm9/lib/src/GX_g3x.c deleted file mode 100644 index 9954c4cb..00000000 --- a/arm9/lib/src/GX_g3x.c +++ /dev/null @@ -1,235 +0,0 @@ -#include "global.h" -#include "main.h" -#include "gx.h" - -extern u32 GXi_DmaId; - -ARM_FUNC asm void GXi_NopClearFifo128_(void *reg){ - mov r1, #0x0 - mov r2, #0x0 - mov r3, #0x0 - mov r12, #0x0 - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - stmia r0, {r1-r3,r12} - bx lr -} - -ARM_FUNC void G3X_Init(){ - G3X_ClearFifo(); - reg_G3_END_VTXS = 0x0; - while (reg_G3X_GXSTAT & 0x8000000) {} //wait for geometry engine to not be busy - reg_G3X_DISP3DCNT = 0x0; - reg_G3X_GXSTAT = 0x0; - reg_G2_BG0OFS = 0x0; - reg_G3X_DISP3DCNT |= 0x2000; - reg_G3X_DISP3DCNT |= 0x1000; - reg_G3X_DISP3DCNT &= ~0x3002; - reg_G3X_DISP3DCNT = (u16)((reg_G3X_DISP3DCNT & ~0x3000) | 0x10); - reg_G3X_DISP3DCNT = (u16)(reg_G3X_DISP3DCNT & (u16)~0x3004); - reg_G3X_GXSTAT |= 0x8000; - reg_G3X_GXSTAT = (reg_G3X_GXSTAT & ~0xC0000000) | 0x80000000; - G3X_InitMtxStack(); - reg_G3X_CLEAR_COLOR = 0x0; - reg_G3X_CLEAR_DEPTH = 0x7FFF; - reg_G3X_CLRIMAGE_OFFSET = 0x0; - reg_G3X_FOG_COLOR = 0x0; - reg_G3X_FOG_OFFSET = 0x0; - reg_G2_BG0CNT &= ~0x3; - G3X_InitTable(); - reg_G3_POLYGON_ATTR = 0x1F0080; - reg_G3_TEXIMAGE_PARAM = 0x0; - reg_G3_TEXPLTT_BASE = 0x0; -} - -ARM_FUNC void G3X_ResetMtxStack(){ - while (reg_G3X_GXSTAT & 0x8000000) {} - reg_G3X_GXSTAT |= 0x8000; - reg_G3X_DISP3DCNT |= 0x2000; - reg_G3X_DISP3DCNT |= 0x1000; - G3X_ResetMtxStack_2(); - reg_G3_POLYGON_ATTR = 0x1F0080; - reg_G3_TEXIMAGE_PARAM = 0x0; - reg_G3_TEXPLTT_BASE = 0x0; -} - -ARM_FUNC void G3X_ClearFifo(){ - GXi_NopClearFifo128_((void *)®_G3X_GXFIFO); - while (reg_G3X_GXSTAT & 0x8000000) {} -} - -ARM_FUNC void G3X_InitMtxStack(){ - u32 PV_level, PJ_level; - reg_G3X_GXSTAT |= 0x8000; - while (G3X_GetMtxStackLevelPV(&PV_level)) {} - while (G3X_GetMtxStackLevelPJ(&PJ_level)) {} - reg_G3_MTX_MODE = 0x3; - reg_G3_MTX_IDENTITY = 0x0; - reg_G3_MTX_MODE = 0x0; - if (PJ_level) - { - reg_G3_MTX_POP = PJ_level; - } - reg_G3_MTX_IDENTITY = 0x0; - reg_G3_MTX_MODE = 0x2; - reg_G3_MTX_POP = PV_level; - reg_G3_MTX_IDENTITY = 0x0; -} - -ARM_FUNC void G3X_ResetMtxStack_2(){ - u32 PV_level, PJ_level; - reg_G3X_GXSTAT |= 0x8000; - while (G3X_GetMtxStackLevelPV(&PV_level)) {} - while (G3X_GetMtxStackLevelPJ(&PJ_level)) {} - reg_G3_MTX_MODE = 0x3; - reg_G3_MTX_IDENTITY = 0x0; - reg_G3_MTX_MODE = 0x0; - if (PJ_level) - { - reg_G3_MTX_POP = PJ_level; - } - - reg_G3_MTX_MODE = 0x2; - reg_G3_MTX_POP = PV_level; - reg_G3_MTX_IDENTITY = 0x0; - -} - -ARM_FUNC void G3X_SetFog(u32 enable, u32 alphamode, u32 depth, s32 offset){ - if (enable) - { - reg_G3X_FOG_OFFSET = (u16)offset; - reg_G3X_DISP3DCNT = (u16)((reg_G3X_DISP3DCNT &~0x3f40) | (((depth << 0x8)| (alphamode << 0x6)|0x80 ))); - - } - else - { - reg_G3X_DISP3DCNT = (u16)(reg_G3X_DISP3DCNT & (u16)~0x3080); - } -} - -ARM_FUNC u32 G3X_GetClipMtx(struct Mtx44 *dst){ - if (reg_G3X_GXSTAT & 0x8000000) - { - return (u32)-1; - } - else - { - MI_Copy64B((void *)®_G3X_CLIPMTX_RESULT_0, dst); - return 0; - } -} - -ARM_FUNC u32 G3X_GetVectorMtx(struct Mtx33 *dst){ - if (reg_G3X_GXSTAT & 0x8000000) - { - return (u32)-1; - } - else - { - MI_Copy36B((void *)®_G3X_VECMTX_RESULT_0, dst); - return 0; - } -} - -ARM_FUNC void G3X_SetEdgeColorTable(void *tbl_ptr){ - MIi_CpuCopy16(tbl_ptr, (void *)®_G3X_EDGE_COLOR_0, 0x10); -} - -ARM_FUNC void G3X_SetFogTable(void *tbl_ptr){ - MI_Copy32B(tbl_ptr, (void *)®_G3X_FOG_TABLE_0); -} - -ARM_FUNC void G3X_SetClearColor(u32 col, u32 alpha, u32 depth, u32 polygon_id, u32 enable_fog){ - u32 temp = col | (alpha << 0x10) | (polygon_id << 0x18); - if (enable_fog) - temp |= 0x8000; - reg_G3X_CLEAR_COLOR = temp; - reg_G3X_CLEAR_DEPTH = (u16)depth; -} - -ARM_FUNC void G3X_InitTable(){ - if (GXi_DmaId != -1) - { - MI_DmaFill32Async(GXi_DmaId, (void *)®_G3X_EDGE_COLOR_0, 0x0, 0x10, 0x0, 0x0); - MI_DmaFill32(GXi_DmaId, (void *)®_G3X_FOG_TABLE_0, 0x0, 0x60); - } - else - { - MIi_CpuClear32(0x0, (void *)®_G3X_EDGE_COLOR_0, 0x10); - MIi_CpuClear32(0x0, (void *)®_G3X_FOG_TABLE_0, 0x60); - } - for (int i = 0; i < 0x20; i++) - { - reg_G3_SHININESS = 0x0; - } -} - -ARM_FUNC u32 G3X_GetMtxStackLevelPV(u32 *level){ - if (reg_G3X_GXSTAT & 0x4000) - { - return (u32)-1; - } - else - { - *level = (reg_G3X_GXSTAT & 0x1F00) >> 0x8; - return 0; - } -} - -ARM_FUNC u32 G3X_GetMtxStackLevelPJ(u32 *level){ - if (reg_G3X_GXSTAT & 0x4000) - { - return (u32)-1; - } - else - { - *level = (reg_G3X_GXSTAT & 0x2000) >> 0xD; - return 0; - } -} - -ARM_FUNC u32 G3X_GetBoxTestResult(u32 *result){ - if (reg_G3X_GXSTAT & 0x1) - { - return (u32)-1; - } - else - { - *result = (reg_G3X_GXSTAT & 0x2); - return 0; - } -} - -ARM_FUNC void G3X_SetHOffset(u32 offset){ - reg_G2_BG0OFS = offset; -} |