perfect_dark/src/game/pad.c

701 lines
22 KiB
C

#include <ultra64.h>
#include "constants.h"
#include "game/pad.h"
#include "bss.h"
#include "data.h"
#include "types.h"
struct padsfileheader *g_PadsFile;
u16 *g_PadOffsets;
u32 var800a2358;
u32 var800a235c;
u16 *g_CoverFlags;
s32 *g_CoverRooms;
struct covercandidate *g_CoverCandidates;
u16 g_NumSpecialCovers;
u16 *g_SpecialCoverNums;
GLOBAL_ASM(
glabel padUnpack
/* f115ab0: 3c0e800a */ lui $t6,%hi(g_PadOffsets)
/* f115ab4: 8dce2354 */ lw $t6,%lo(g_PadOffsets)($t6)
/* f115ab8: 00047840 */ sll $t7,$a0,0x1
/* f115abc: 3c19800a */ lui $t9,%hi(g_StageSetup+0x1c)
/* f115ac0: 01cfc021 */ addu $t8,$t6,$t7
/* f115ac4: 97020000 */ lhu $v0,0x0($t8)
/* f115ac8: 8f39d04c */ lw $t9,%lo(g_StageSetup+0x1c)($t9)
/* f115acc: 00a03825 */ or $a3,$a1,$zero
/* f115ad0: 30e80040 */ andi $t0,$a3,0x40
/* f115ad4: 03221821 */ addu $v1,$t9,$v0
/* f115ad8: 11000005 */ beqz $t0,.L0f115af0
/* f115adc: 00602825 */ or $a1,$v1,$zero
/* f115ae0: 8c690000 */ lw $t1,0x0($v1)
/* f115ae4: 00095480 */ sll $t2,$t1,0x12
/* f115ae8: 000a5d83 */ sra $t3,$t2,0x16
/* f115aec: accb0048 */ sw $t3,0x48($a2)
.L0f115af0:
/* f115af0: 30ec0100 */ andi $t4,$a3,0x100
/* f115af4: 11800004 */ beqz $t4,.L0f115b08
/* f115af8: 30f90002 */ andi $t9,$a3,0x2
/* f115afc: 8c6d0000 */ lw $t5,0x0($v1)
/* f115b00: 31ae000f */ andi $t6,$t5,0xf
/* f115b04: a0ce0050 */ sb $t6,0x50($a2)
.L0f115b08:
/* f115b08: 8ca20000 */ lw $v0,0x0($a1)
/* f115b0c: 24630004 */ addiu $v1,$v1,0x4
/* f115b10: 30ec0002 */ andi $t4,$a3,0x2
/* f115b14: 00027b82 */ srl $t7,$v0,0xe
/* f115b18: 31f80001 */ andi $t8,$t7,0x1
/* f115b1c: 13000017 */ beqz $t8,.L0f115b7c
/* f115b20: 01e01025 */ or $v0,$t7,$zero
/* f115b24: 13200013 */ beqz $t9,.L0f115b74
/* f115b28: 00000000 */ nop
/* f115b2c: 84680000 */ lh $t0,0x0($v1)
/* f115b30: 44882000 */ mtc1 $t0,$f4
/* f115b34: 00000000 */ nop
/* f115b38: 468021a0 */ cvt.s.w $f6,$f4
/* f115b3c: e4c60000 */ swc1 $f6,0x0($a2)
/* f115b40: 84690002 */ lh $t1,0x2($v1)
/* f115b44: 44894000 */ mtc1 $t1,$f8
/* f115b48: 00000000 */ nop
/* f115b4c: 468042a0 */ cvt.s.w $f10,$f8
/* f115b50: e4ca0004 */ swc1 $f10,0x4($a2)
/* f115b54: 846a0004 */ lh $t2,0x4($v1)
/* f115b58: 448a2000 */ mtc1 $t2,$f4
/* f115b5c: 00000000 */ nop
/* f115b60: 468021a0 */ cvt.s.w $f6,$f4
/* f115b64: e4c60008 */ swc1 $f6,0x8($a2)
/* f115b68: 8ca20000 */ lw $v0,0x0($a1)
/* f115b6c: 00025b82 */ srl $t3,$v0,0xe
/* f115b70: 01601025 */ or $v0,$t3,$zero
.L0f115b74:
/* f115b74: 1000000d */ b .L0f115bac
/* f115b78: 24630008 */ addiu $v1,$v1,0x8
.L0f115b7c:
/* f115b7c: 5180000b */ beqzl $t4,.L0f115bac
/* f115b80: 2463000c */ addiu $v1,$v1,0xc
/* f115b84: c4680000 */ lwc1 $f8,0x0($v1)
/* f115b88: e4c80000 */ swc1 $f8,0x0($a2)
/* f115b8c: c46a0004 */ lwc1 $f10,0x4($v1)
/* f115b90: e4ca0004 */ swc1 $f10,0x4($a2)
/* f115b94: c4640008 */ lwc1 $f4,0x8($v1)
/* f115b98: e4c40008 */ swc1 $f4,0x8($a2)
/* f115b9c: 8ca20000 */ lw $v0,0x0($a1)
/* f115ba0: 00026b82 */ srl $t5,$v0,0xe
/* f115ba4: 01a01025 */ or $v0,$t5,$zero
/* f115ba8: 2463000c */ addiu $v1,$v1,0xc
.L0f115bac:
/* f115bac: 304e000e */ andi $t6,$v0,0xe
/* f115bb0: 11c00049 */ beqz $t6,.L0f115cd8
/* f115bb4: 30e90018 */ andi $t1,$a3,0x18
/* f115bb8: 30ef0018 */ andi $t7,$a3,0x18
/* f115bbc: 11e00043 */ beqz $t7,.L0f115ccc
/* f115bc0: 30580002 */ andi $t8,$v0,0x2
/* f115bc4: 13000013 */ beqz $t8,.L0f115c14
/* f115bc8: 30490004 */ andi $t1,$v0,0x4
/* f115bcc: 30590010 */ andi $t9,$v0,0x10
/* f115bd0: 44800000 */ mtc1 $zero,$f0
/* f115bd4: 13200005 */ beqz $t9,.L0f115bec
/* f115bd8: 3c013f80 */ lui $at,0x3f80
/* f115bdc: 3c01bf80 */ lui $at,0xbf80
/* f115be0: 44813000 */ mtc1 $at,$f6
/* f115be4: 10000004 */ b .L0f115bf8
/* f115be8: e4c60018 */ swc1 $f6,0x18($a2)
.L0f115bec:
/* f115bec: 44814000 */ mtc1 $at,$f8
/* f115bf0: 00000000 */ nop
/* f115bf4: e4c80018 */ swc1 $f8,0x18($a2)
.L0f115bf8:
/* f115bf8: e4c0001c */ swc1 $f0,0x1c($a2)
/* f115bfc: e4c00020 */ swc1 $f0,0x20($a2)
/* f115c00: 8ca20000 */ lw $v0,0x0($a1)
/* f115c04: 44800000 */ mtc1 $zero,$f0
/* f115c08: 00024382 */ srl $t0,$v0,0xe
/* f115c0c: 1000003f */ b .L0f115d0c
/* f115c10: 01001025 */ or $v0,$t0,$zero
.L0f115c14:
/* f115c14: 51200017 */ beqzl $t1,.L0f115c74
/* f115c18: 44800000 */ mtc1 $zero,$f0
/* f115c1c: 44800000 */ mtc1 $zero,$f0
/* f115c20: 3c013f80 */ lui $at,0x3f80
/* f115c24: e4c00018 */ swc1 $f0,0x18($a2)
/* f115c28: 8caa0000 */ lw $t2,0x0($a1)
/* f115c2c: 000a5b82 */ srl $t3,$t2,0xe
/* f115c30: 316c0010 */ andi $t4,$t3,0x10
/* f115c34: 51800006 */ beqzl $t4,.L0f115c50
/* f115c38: 44812000 */ mtc1 $at,$f4
/* f115c3c: 3c01bf80 */ lui $at,0xbf80
/* f115c40: 44815000 */ mtc1 $at,$f10
/* f115c44: 10000004 */ b .L0f115c58
/* f115c48: e4ca001c */ swc1 $f10,0x1c($a2)
/* f115c4c: 44812000 */ mtc1 $at,$f4
.L0f115c50:
/* f115c50: 00000000 */ nop
/* f115c54: e4c4001c */ swc1 $f4,0x1c($a2)
.L0f115c58:
/* f115c58: e4c00020 */ swc1 $f0,0x20($a2)
/* f115c5c: 8ca20000 */ lw $v0,0x0($a1)
/* f115c60: 44800000 */ mtc1 $zero,$f0
/* f115c64: 00026b82 */ srl $t5,$v0,0xe
/* f115c68: 10000028 */ b .L0f115d0c
/* f115c6c: 01a01025 */ or $v0,$t5,$zero
/* f115c70: 44800000 */ mtc1 $zero,$f0
.L0f115c74:
/* f115c74: 3c013f80 */ lui $at,0x3f80
/* f115c78: e4c00018 */ swc1 $f0,0x18($a2)
/* f115c7c: e4c0001c */ swc1 $f0,0x1c($a2)
/* f115c80: 8cae0000 */ lw $t6,0x0($a1)
/* f115c84: 000e7b82 */ srl $t7,$t6,0xe
/* f115c88: 31f80010 */ andi $t8,$t7,0x10
/* f115c8c: 5300000a */ beqzl $t8,.L0f115cb8
/* f115c90: 44814000 */ mtc1 $at,$f8
/* f115c94: 3c01bf80 */ lui $at,0xbf80
/* f115c98: 44813000 */ mtc1 $at,$f6
/* f115c9c: 44800000 */ mtc1 $zero,$f0
/* f115ca0: e4c60020 */ swc1 $f6,0x20($a2)
/* f115ca4: 8ca20000 */ lw $v0,0x0($a1)
/* f115ca8: 0002cb82 */ srl $t9,$v0,0xe
/* f115cac: 10000017 */ b .L0f115d0c
/* f115cb0: 03201025 */ or $v0,$t9,$zero
/* f115cb4: 44814000 */ mtc1 $at,$f8
.L0f115cb8:
/* f115cb8: 00000000 */ nop
/* f115cbc: e4c80020 */ swc1 $f8,0x20($a2)
/* f115cc0: 8ca20000 */ lw $v0,0x0($a1)
/* f115cc4: 00024382 */ srl $t0,$v0,0xe
/* f115cc8: 01001025 */ or $v0,$t0,$zero
.L0f115ccc:
/* f115ccc: 44800000 */ mtc1 $zero,$f0
/* f115cd0: 1000000f */ b .L0f115d10
/* f115cd4: 304b00e0 */ andi $t3,$v0,0xe0
.L0f115cd8:
/* f115cd8: 5120000b */ beqzl $t1,.L0f115d08
/* f115cdc: 44800000 */ mtc1 $zero,$f0
/* f115ce0: c46a0000 */ lwc1 $f10,0x0($v1)
/* f115ce4: e4ca0018 */ swc1 $f10,0x18($a2)
/* f115ce8: c4640004 */ lwc1 $f4,0x4($v1)
/* f115cec: e4c4001c */ swc1 $f4,0x1c($a2)
/* f115cf0: c4660008 */ lwc1 $f6,0x8($v1)
/* f115cf4: e4c60020 */ swc1 $f6,0x20($a2)
/* f115cf8: 8ca20000 */ lw $v0,0x0($a1)
/* f115cfc: 00025382 */ srl $t2,$v0,0xe
/* f115d00: 01401025 */ or $v0,$t2,$zero
/* f115d04: 44800000 */ mtc1 $zero,$f0
.L0f115d08:
/* f115d08: 2463000c */ addiu $v1,$v1,0xc
.L0f115d0c:
/* f115d0c: 304b00e0 */ andi $t3,$v0,0xe0
.L0f115d10:
/* f115d10: 11600034 */ beqz $t3,.L0f115de4
/* f115d14: 30ec0014 */ andi $t4,$a3,0x14
/* f115d18: 30ec0014 */ andi $t4,$a3,0x14
/* f115d1c: 1180003a */ beqz $t4,.L0f115e08
/* f115d20: 304d0020 */ andi $t5,$v0,0x20
/* f115d24: 11a0000e */ beqz $t5,.L0f115d60
/* f115d28: 304f0040 */ andi $t7,$v0,0x40
/* f115d2c: 304e0100 */ andi $t6,$v0,0x100
/* f115d30: 11c00005 */ beqz $t6,.L0f115d48
/* f115d34: 3c013f80 */ lui $at,0x3f80
/* f115d38: 3c01bf80 */ lui $at,0xbf80
/* f115d3c: 44814000 */ mtc1 $at,$f8
/* f115d40: 10000004 */ b .L0f115d54
/* f115d44: e4c8000c */ swc1 $f8,0xc($a2)
.L0f115d48:
/* f115d48: 44815000 */ mtc1 $at,$f10
/* f115d4c: 00000000 */ nop
/* f115d50: e4ca000c */ swc1 $f10,0xc($a2)
.L0f115d54:
/* f115d54: e4c00010 */ swc1 $f0,0x10($a2)
/* f115d58: 1000002b */ b .L0f115e08
/* f115d5c: e4c00014 */ swc1 $f0,0x14($a2)
.L0f115d60:
/* f115d60: 51e00012 */ beqzl $t7,.L0f115dac
/* f115d64: e4c0000c */ swc1 $f0,0xc($a2)
/* f115d68: e4c0000c */ swc1 $f0,0xc($a2)
/* f115d6c: 8cb80000 */ lw $t8,0x0($a1)
/* f115d70: 3c013f80 */ lui $at,0x3f80
/* f115d74: 0018cb82 */ srl $t9,$t8,0xe
/* f115d78: 33280100 */ andi $t0,$t9,0x100
/* f115d7c: 51000006 */ beqzl $t0,.L0f115d98
/* f115d80: 44813000 */ mtc1 $at,$f6
/* f115d84: 3c01bf80 */ lui $at,0xbf80
/* f115d88: 44812000 */ mtc1 $at,$f4
/* f115d8c: 10000004 */ b .L0f115da0
/* f115d90: e4c40010 */ swc1 $f4,0x10($a2)
/* f115d94: 44813000 */ mtc1 $at,$f6
.L0f115d98:
/* f115d98: 00000000 */ nop
/* f115d9c: e4c60010 */ swc1 $f6,0x10($a2)
.L0f115da0:
/* f115da0: 10000019 */ b .L0f115e08
/* f115da4: e4c00014 */ swc1 $f0,0x14($a2)
/* f115da8: e4c0000c */ swc1 $f0,0xc($a2)
.L0f115dac:
/* f115dac: e4c00010 */ swc1 $f0,0x10($a2)
/* f115db0: 8ca90000 */ lw $t1,0x0($a1)
/* f115db4: 3c013f80 */ lui $at,0x3f80
/* f115db8: 00095382 */ srl $t2,$t1,0xe
/* f115dbc: 314b0100 */ andi $t3,$t2,0x100
/* f115dc0: 51600006 */ beqzl $t3,.L0f115ddc
/* f115dc4: 44815000 */ mtc1 $at,$f10
/* f115dc8: 3c01bf80 */ lui $at,0xbf80
/* f115dcc: 44814000 */ mtc1 $at,$f8
/* f115dd0: 1000000d */ b .L0f115e08
/* f115dd4: e4c80014 */ swc1 $f8,0x14($a2)
/* f115dd8: 44815000 */ mtc1 $at,$f10
.L0f115ddc:
/* f115ddc: 1000000a */ b .L0f115e08
/* f115de0: e4ca0014 */ swc1 $f10,0x14($a2)
.L0f115de4:
/* f115de4: 51800008 */ beqzl $t4,.L0f115e08
/* f115de8: 2463000c */ addiu $v1,$v1,0xc
/* f115dec: c4640000 */ lwc1 $f4,0x0($v1)
/* f115df0: e4c4000c */ swc1 $f4,0xc($a2)
/* f115df4: c4660004 */ lwc1 $f6,0x4($v1)
/* f115df8: e4c60010 */ swc1 $f6,0x10($a2)
/* f115dfc: c4680008 */ lwc1 $f8,0x8($v1)
/* f115e00: e4c80014 */ swc1 $f8,0x14($a2)
/* f115e04: 2463000c */ addiu $v1,$v1,0xc
.L0f115e08:
/* f115e08: 30ed0010 */ andi $t5,$a3,0x10
/* f115e0c: 11a00014 */ beqz $t5,.L0f115e60
/* f115e10: 30e90080 */ andi $t1,$a3,0x80
/* f115e14: c4c0001c */ lwc1 $f0,0x1c($a2)
/* f115e18: c4c20014 */ lwc1 $f2,0x14($a2)
/* f115e1c: c4cc0010 */ lwc1 $f12,0x10($a2)
/* f115e20: c4ce0020 */ lwc1 $f14,0x20($a2)
/* f115e24: 46020282 */ mul.s $f10,$f0,$f2
/* f115e28: c4d0000c */ lwc1 $f16,0xc($a2)
/* f115e2c: c4d20018 */ lwc1 $f18,0x18($a2)
/* f115e30: 460e6102 */ mul.s $f4,$f12,$f14
/* f115e34: 46045181 */ sub.s $f6,$f10,$f4
/* f115e38: 46107202 */ mul.s $f8,$f14,$f16
/* f115e3c: 00000000 */ nop
/* f115e40: 46121282 */ mul.s $f10,$f2,$f18
/* f115e44: e4c60024 */ swc1 $f6,0x24($a2)
/* f115e48: 460c9182 */ mul.s $f6,$f18,$f12
/* f115e4c: 460a4101 */ sub.s $f4,$f8,$f10
/* f115e50: 46008202 */ mul.s $f8,$f16,$f0
/* f115e54: e4c40028 */ swc1 $f4,0x28($a2)
/* f115e58: 46083281 */ sub.s $f10,$f6,$f8
/* f115e5c: e4ca002c */ swc1 $f10,0x2c($a2)
.L0f115e60:
/* f115e60: 8cae0000 */ lw $t6,0x0($a1)
/* f115e64: 30f90020 */ andi $t9,$a3,0x20
/* f115e68: 30e80020 */ andi $t0,$a3,0x20
/* f115e6c: 000e7b82 */ srl $t7,$t6,0xe
/* f115e70: 31f80200 */ andi $t8,$t7,0x200
/* f115e74: 13000010 */ beqz $t8,.L0f115eb8
/* f115e78: 00000000 */ nop
/* f115e7c: 13200019 */ beqz $t9,.L0f115ee4
/* f115e80: 00000000 */ nop
/* f115e84: c4640000 */ lwc1 $f4,0x0($v1)
/* f115e88: e4c40030 */ swc1 $f4,0x30($a2)
/* f115e8c: c4660004 */ lwc1 $f6,0x4($v1)
/* f115e90: e4c60034 */ swc1 $f6,0x34($a2)
/* f115e94: c4680008 */ lwc1 $f8,0x8($v1)
/* f115e98: e4c80038 */ swc1 $f8,0x38($a2)
/* f115e9c: c46a000c */ lwc1 $f10,0xc($v1)
/* f115ea0: e4ca003c */ swc1 $f10,0x3c($a2)
/* f115ea4: c4640010 */ lwc1 $f4,0x10($v1)
/* f115ea8: e4c40040 */ swc1 $f4,0x40($a2)
/* f115eac: c4660014 */ lwc1 $f6,0x14($v1)
/* f115eb0: 1000000c */ b .L0f115ee4
/* f115eb4: e4c60044 */ swc1 $f6,0x44($a2)
.L0f115eb8:
/* f115eb8: 1100000a */ beqz $t0,.L0f115ee4
/* f115ebc: 3c01c2c8 */ lui $at,0xc2c8
/* f115ec0: 44810000 */ mtc1 $at,$f0
/* f115ec4: 3c0142c8 */ lui $at,0x42c8
/* f115ec8: 44811000 */ mtc1 $at,$f2
/* f115ecc: e4c00030 */ swc1 $f0,0x30($a2)
/* f115ed0: e4c00038 */ swc1 $f0,0x38($a2)
/* f115ed4: e4c00040 */ swc1 $f0,0x40($a2)
/* f115ed8: e4c20034 */ swc1 $f2,0x34($a2)
/* f115edc: e4c2003c */ swc1 $f2,0x3c($a2)
/* f115ee0: e4c20044 */ swc1 $f2,0x44($a2)
.L0f115ee4:
/* f115ee4: 11200004 */ beqz $t1,.L0f115ef8
/* f115ee8: 00000000 */ nop
/* f115eec: 8caa0000 */ lw $t2,0x0($a1)
/* f115ef0: 000a5b82 */ srl $t3,$t2,0xe
/* f115ef4: accb004c */ sw $t3,0x4c($a2)
.L0f115ef8:
/* f115ef8: 03e00008 */ jr $ra
/* f115efc: 00000000 */ nop
);
// Mismatch because the ROM moves `fields` from a1 to a3 then uses a1 for other
// purposes, while the below just keeps a1 where it is.
//void padUnpack(s32 padnum, u32 fields, struct pad *pad)
//{
// u32 *ibuffer = (u32 *)&g_StageSetup.padfiledata[g_PadOffsets[padnum]];
// f32 *fbuffer = (f32 *)ibuffer;
//
// // flags, room and liftnum
// // ffffffff ffffffff ffrrrrrr rrrrllll
//
// if (fields & PADFIELD_ROOM) {
// pad->room = (s32)(*ibuffer << 18) >> 22;
// }
//
// if (fields & PADFIELD_LIFT) {
// pad->liftnum = *ibuffer & 0x0000000f;
// }
//
// fbuffer++;
//
// if ((*ibuffer >> 14) & PADFLAG_INTPOS) {
// if (fields & PADFIELD_POS) {
// s16 *sbuffer = (s16 *)fbuffer;
// pad->pos.x = sbuffer[0];
// pad->pos.y = sbuffer[1];
// pad->pos.z = sbuffer[2];
// }
// fbuffer += 2;
// } else {
// if (fields & PADFIELD_POS) {
// pad->pos.x = fbuffer[0];
// pad->pos.y = fbuffer[1];
// pad->pos.z = fbuffer[2];
// }
// fbuffer += 3;
// }
//
// if ((*ibuffer >> 14) & (PADFLAG_UPALIGNTOX | PADFLAG_UPALIGNTOY | PADFLAG_UPALIGNTOZ)) {
// if (fields & (PADFIELD_UP | PADFIELD_NORMAL)) {
// if ((*ibuffer >> 14) & PADFLAG_UPALIGNTOX) {
// pad->up.x = ((*ibuffer >> 14) & PADFLAG_UPALIGNINVERT) ? -1 : 1;
// pad->up.y = 0;
// pad->up.z = 0;
// } else if ((*ibuffer >> 14) & PADFLAG_UPALIGNTOY) {
// pad->up.x = 0;
// pad->up.y = ((*ibuffer >> 14) & PADFLAG_UPALIGNINVERT) ? -1 : 1;
// pad->up.z = 0;
// } else {
// pad->up.x = 0;
// pad->up.y = 0;
// pad->up.z = ((*ibuffer >> 14) & PADFLAG_UPALIGNINVERT) ? -1 : 1;
// }
// }
// } else {
// if (fields & (PADFIELD_UP | PADFIELD_NORMAL)) {
// pad->up.x = fbuffer[0];
// pad->up.y = fbuffer[1];
// pad->up.z = fbuffer[2];
// }
// fbuffer += 3;
// }
//
// if ((*ibuffer >> 14) & (PADFLAG_LOOKALIGNTOX | PADFLAG_LOOKALIGNTOY | PADFLAG_LOOKALIGNTOZ)) {
// if (fields & (PADFIELD_LOOK | PADFIELD_NORMAL)) {
// if ((*ibuffer >> 14) & PADFLAG_LOOKALIGNTOX) {
// pad->look.x = ((*ibuffer >> 14) & PADFLAG_LOOKALIGNINVERT) ? -1 : 1;
// pad->look.y = 0;
// pad->look.z = 0;
// } else if ((*ibuffer >> 14) & PADFLAG_LOOKALIGNTOY) {
// pad->look.x = 0;
// pad->look.y = ((*ibuffer >> 14) & PADFLAG_LOOKALIGNINVERT) ? -1 : 1;
// pad->look.z = 0;
// } else {
// pad->look.x = 0;
// pad->look.y = 0;
// pad->look.z = ((*ibuffer >> 14) & PADFLAG_LOOKALIGNINVERT) ? -1 : 1;
// }
// }
// } else {
// if (fields & (PADFIELD_LOOK | PADFIELD_NORMAL)) {
// pad->look.x = fbuffer[0];
// pad->look.y = fbuffer[1];
// pad->look.z = fbuffer[2];
// }
// fbuffer = fbuffer + 3;
// }
//
// if (fields & PADFIELD_NORMAL) {
// pad->normal.x = pad->up.y * pad->look.z - pad->look.y * pad->up.z;
// pad->normal.y = pad->up.z * pad->look.x - pad->look.z * pad->up.x;
// pad->normal.z = pad->up.x * pad->look.y - pad->look.x * pad->up.y;
// }
//
// if ((*ibuffer >> 14) & PADFLAG_HASBBOXDATA) {
// if (fields & PADFIELD_BBOX) {
// pad->bbox.xmin = fbuffer[0];
// pad->bbox.xmax = fbuffer[1];
// pad->bbox.ymin = fbuffer[2];
// pad->bbox.ymax = fbuffer[3];
// pad->bbox.zmin = fbuffer[4];
// pad->bbox.zmax = fbuffer[5];
// }
// } else {
// if (fields & PADFIELD_BBOX) {
// pad->bbox.xmin = -100;
// pad->bbox.ymin = -100;
// pad->bbox.zmin = -100;
// pad->bbox.xmax = 100;
// pad->bbox.ymax = 100;
// pad->bbox.zmax = 100;
// }
// }
//
// if (fields & PADFIELD_FLAGS) {
// pad->flags = (*ibuffer >> 14);
// }
//}
bool padHasBboxData(s32 padnum)
{
u32 offset = g_PadOffsets[padnum];
u32 *header = (u32 *)&g_StageSetup.padfiledata[offset];
return ((*header >> 14) & PADFLAG_HASBBOXDATA) != 0;
}
void padGetCentre(s32 padnum, struct coord *coord)
{
struct pad pad;
padUnpack(padnum, PADFIELD_POS | PADFIELD_LOOK | PADFIELD_UP | PADFIELD_NORMAL | PADFIELD_BBOX, &pad);
coord->x = pad.pos.f[0] + (
(pad.bbox.xmin + pad.bbox.xmax) * pad.normal.f[0] +
(pad.bbox.ymin + pad.bbox.ymax) * pad.up.f[0] +
(pad.bbox.zmin + pad.bbox.zmax) * pad.look.f[0]) * 0.5f;
coord->y = pad.pos.f[1] + (
(pad.bbox.xmin + pad.bbox.xmax) * pad.normal.f[1] +
(pad.bbox.ymin + pad.bbox.ymax) * pad.up.f[1] +
(pad.bbox.zmin + pad.bbox.zmax) * pad.look.f[1]) * 0.5f;
coord->z = pad.pos.f[2] + (
(pad.bbox.xmin + pad.bbox.xmax) * pad.normal.f[2] +
(pad.bbox.ymin + pad.bbox.ymax) * pad.up.f[2] +
(pad.bbox.zmin + pad.bbox.zmax) * pad.look.f[2]) * 0.5f;
}
/**
* Some door models are rotated weirdly - suspected to be designed using the
* wrong coordinate system, then the developers implemented a fix here in the
* code rather than fixing the models.
*
* When such a door is placed on a pad, this function is called. It adjusts the
* pad's orientation to compensate for the model.
*/
void padRotateForDoor(s32 padnum)
{
u32 stack;
u32 *ptr;
u32 *header;
struct coord *look;
struct coord *up;
f32 scale;
s32 offset;
offset = g_PadOffsets[padnum];
ptr = (u32 *) &g_StageSetup.padfiledata[offset];
header = ptr;
ptr++;
if ((*header >> 14) & PADFLAG_INTPOS) {
ptr += 2;
} else {
ptr += 3;
}
if (((*header >> 14) & (PADFLAG_UPALIGNTOX | PADFLAG_UPALIGNTOY | PADFLAG_UPALIGNTOZ)) == 0) {
up = (struct coord *) ptr;
up->y = 0;
scale = 1 / sqrtf(up->f[0] * up->f[0] + up->f[2] * up->f[2]);
up->x *= scale;
up->z *= scale;
ptr += 3;
}
if ((*header >> 14) & (PADFLAG_LOOKALIGNTOX | PADFLAG_LOOKALIGNTOY | PADFLAG_LOOKALIGNTOZ)) {
// Unset the LOOKALIGN flags, then set LOOKALIGNTOY
*header = *header ^ (((*header >> 14) ^ ((*header >> 14) & ~(PADFLAG_LOOKALIGNTOX | PADFLAG_LOOKALIGNTOY | PADFLAG_LOOKALIGNTOZ | PADFLAG_LOOKALIGNINVERT))) << 14);
*header = *header ^ (((*header >> 14) ^ ((*header >> 14) | PADFLAG_LOOKALIGNTOY)) << 14);
} else {
look = (struct coord *) ptr;
look->x = 0.0f;
look->y = 1.0f;
look->z = 0.0f;
}
}
void padCopyBboxFromPad(s32 padnum, struct pad *src)
{
u32 offset = g_PadOffsets[padnum];
f32 *fbuffer = (f32 *)&g_StageSetup.padfiledata[offset];
u32 *header = (u32 *)fbuffer;
if ((*header >> 14) & PADFLAG_HASBBOXDATA) {
fbuffer++;
if ((*header >> 14) & PADFLAG_INTPOS) {
fbuffer += 2;
} else {
fbuffer += 3;
}
if (((*header >> 14) & (PADFLAG_UPALIGNTOX | PADFLAG_UPALIGNTOY | PADFLAG_UPALIGNTOZ)) == 0) {
fbuffer += 3;
}
if (((*header >> 14) & (PADFLAG_LOOKALIGNTOX | PADFLAG_LOOKALIGNTOY | PADFLAG_LOOKALIGNTOZ)) == 0) {
fbuffer += 3;
}
fbuffer[0] = src->bbox.xmin;
fbuffer[1] = src->bbox.xmax;
fbuffer[2] = src->bbox.ymin;
fbuffer[3] = src->bbox.ymax;
fbuffer[4] = src->bbox.zmin;
fbuffer[5] = src->bbox.zmax;
}
}
void padSetFlag(s32 padnum, u32 flag)
{
u32 offset = g_PadOffsets[padnum];
u32 *header = (u32 *)&g_StageSetup.padfiledata[offset];
*header = *header ^ ((*header >> 14) ^ ((*header >> 14) | flag)) << 14;
}
void padUnsetFlag(s32 padnum, u32 flag)
{
u32 offset = g_PadOffsets[padnum];
u32 *header = (u32 *)&g_StageSetup.padfiledata[offset];
*header = *header ^ ((*header >> 14) ^ ((*header >> 14) & ~flag)) << 14;
}
bool func0f1162c4(s32 padnum, s32 arg1)
{
return padnum;
}
s32 coverGetCount(void)
{
return g_PadsFile->numcovers;
}
bool coverUnpack(s32 covernum, struct cover *cover)
{
struct coverdefinition *def;
if (covernum >= g_PadsFile->numcovers || covernum < 0 || !g_StageSetup.cover) {
return false;
}
// @bug: Cast to u8 means it loads the pos, look and flags
// from an incorrect cover if covernum is greater than 255.
def = g_StageSetup.cover;
def += (u8)covernum;
cover->pos = &def->pos;
cover->look = &def->look;
g_CoverFlags[covernum] |= def->flags;
cover->flags = g_CoverFlags[covernum];
cover->rooms[0] = g_CoverRooms[covernum];
cover->rooms[1] = -1;
return true;
}
u16 getNumSpecialCovers(void)
{
return g_NumSpecialCovers;
}
bool coverUnpackBySpecialNum(s32 index, struct cover *cover)
{
// Probable @bug: last check should be index >= g_NumSpecialCovers
// This function is never called though.
if (!g_SpecialCoverNums || index < 0 || index > g_NumSpecialCovers) {
return false;
}
if (coverUnpack(g_SpecialCoverNums[index], cover)) {
return true;
}
return false;
}
s32 coverGetNumBySpecialNum(s32 index)
{
// Probable @bug: last check should be index >= g_NumSpecialCovers
// This function is never called though.
if (!g_SpecialCoverNums || index < 0 || index > g_NumSpecialCovers) {
return -1;
}
return g_SpecialCoverNums[index];
}
s32 func0f116450(s32 arg0, s32 arg1)
{
return arg0;
}
bool coverIsInUse(s32 covernum)
{
// @bug: Second condition should be >=
if (covernum < 0 || covernum > g_PadsFile->numcovers) {
return false;
}
return g_CoverFlags[covernum] & COVERFLAG_INUSE;
}
void coverSetInUse(s32 covernum, bool enable)
{
if (covernum >= 0 && covernum < g_PadsFile->numcovers) {
if (enable) {
g_CoverFlags[covernum] |= COVERFLAG_INUSE;
} else {
g_CoverFlags[covernum] &= ~COVERFLAG_INUSE;
}
}
}
void coverSetFlag(s32 covernum, u32 flag)
{
g_CoverFlags[covernum] |= flag;
}
void coverUnsetFlag(s32 covernum, u32 flag)
{
g_CoverFlags[covernum] &= ~flag;
}
void coverSetFlag0001(s32 covernum, bool enable)
{
if (covernum >= 0 && covernum < g_PadsFile->numcovers) {
if (enable) {
g_CoverFlags[covernum] |= COVERFLAG_0001;
} else {
g_CoverFlags[covernum] &= ~COVERFLAG_0001;
}
}
}
bool coverIsSpecial(struct cover *cover)
{
return (cover->flags & (COVERFLAG_0080 | COVERFLAG_0040 | COVERFLAG_0020)) != 0;
}
s32 func0f1165c0(s32 arg0, s32 arg1)
{
return arg0;
}