mirror of
https://github.com/zeldaret/oot.git
synced 2025-08-13 02:10:57 +00:00
Decompile the last of libultra_code_O2 (#464)
* Decompile osPfsFileState, move guMtxL2F to asm/ * Remove asm * Add some prototypes to functions.h
This commit is contained in:
parent
af326f5b78
commit
92bb1fb210
8 changed files with 84 additions and 156 deletions
|
@ -1,4 +0,0 @@
|
|||
#include "ultra64.h"
|
||||
#include "global.h"
|
||||
|
||||
#pragma GLOBAL_ASM("asm/non_matchings/code/code_80102FA0/func_80102FA0.s")
|
|
@ -1,4 +0,0 @@
|
|||
#include "ultra64.h"
|
||||
#include "global.h"
|
||||
|
||||
#pragma GLOBAL_ASM("asm/non_matchings/code/code_80104D60/osPfsFileState.s")
|
57
src/libultra_code_O2/osPfsFileState.c
Normal file
57
src/libultra_code_O2/osPfsFileState.c
Normal file
|
@ -0,0 +1,57 @@
|
|||
#include "ultra64.h"
|
||||
#include "global.h"
|
||||
|
||||
s32 osPfsFileState(OSPfs* pfs, s32 fileNo, OSPfsState* state) {
|
||||
s32 ret;
|
||||
s32 pages;
|
||||
__OSInode inode;
|
||||
__OSDir dir;
|
||||
__OSInodeUnit page;
|
||||
u8 bank;
|
||||
|
||||
if (fileNo >= pfs->dir_size || fileNo < 0) {
|
||||
return PFS_ERR_INVALID;
|
||||
}
|
||||
if (!(pfs->status & PFS_INITIALIZED)) {
|
||||
return PFS_ERR_INVALID;
|
||||
}
|
||||
if ((ret = __osCheckId(pfs)) != 0) {
|
||||
return ret;
|
||||
}
|
||||
if (pfs->activebank != 0 && (ret = __osPfsSelectBank(pfs, 0)) != 0) {
|
||||
return ret;
|
||||
}
|
||||
if ((ret = __osContRamRead(pfs->queue, pfs->channel, pfs->dir_table + fileNo, &dir)) != 0) {
|
||||
return ret;
|
||||
}
|
||||
if (dir.company_code == 0 || dir.game_code == 0) {
|
||||
return PFS_ERR_INVALID;
|
||||
}
|
||||
|
||||
page = dir.start_page;
|
||||
pages = 0;
|
||||
bank = 0xFF;
|
||||
while (true) {
|
||||
if (page.ipage < pfs->inodeStartPage) {
|
||||
break;
|
||||
}
|
||||
if (page.inode_t.bank != bank) {
|
||||
bank = page.inode_t.bank;
|
||||
if ((ret = __osPfsRWInode(pfs, &inode, PFS_READ, bank)) != 0) {
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
pages++;
|
||||
page = inode.inodePage[page.inode_t.page];
|
||||
}
|
||||
if (page.ipage != PFS_EOF) {
|
||||
return PFS_ERR_INCONSISTENT;
|
||||
}
|
||||
|
||||
state->file_size = pages * PFS_ONE_PAGE * BLOCKSIZE;
|
||||
state->company_code = dir.company_code;
|
||||
state->game_code = dir.game_code;
|
||||
bcopy(&dir.game_name, state->game_name, PFS_FILE_NAME_LEN);
|
||||
bcopy(&dir.ext_name, state->ext_name, PFS_FILE_EXT_LEN);
|
||||
return __osPfsGetStatus(pfs->queue, pfs->channel);
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue