mirror of https://github.com/PrimeDecomp/prime.git
parent
73cd98d1f8
commit
c8d021edb4
|
@ -3,8 +3,8 @@
|
||||||
.section .data
|
.section .data
|
||||||
.balign 8
|
.balign 8
|
||||||
|
|
||||||
.global lbl_803EE3D8
|
.global "__vt__31TObjOwnerParam<P12IObjectStore>"
|
||||||
lbl_803EE3D8:
|
"__vt__31TObjOwnerParam<P12IObjectStore>":
|
||||||
# ROM: 0x3EB3D8
|
# ROM: 0x3EB3D8
|
||||||
.4byte 0
|
.4byte 0
|
||||||
.4byte 0
|
.4byte 0
|
||||||
|
@ -36,12 +36,12 @@ lbl_803EE3E4:
|
||||||
/* 8033FA54 0033C9B4 93 E1 00 0C */ stw r31, 0xc(r1)
|
/* 8033FA54 0033C9B4 93 E1 00 0C */ stw r31, 0xc(r1)
|
||||||
/* 8033FA58 0033C9B8 7C 7F 1B 79 */ or. r31, r3, r3
|
/* 8033FA58 0033C9B8 7C 7F 1B 79 */ or. r31, r3, r3
|
||||||
/* 8033FA5C 0033C9BC 41 82 00 40 */ beq lbl_8033FA9C
|
/* 8033FA5C 0033C9BC 41 82 00 40 */ beq lbl_8033FA9C
|
||||||
/* 8033FA60 0033C9C0 3C 60 80 3F */ lis r3, lbl_803EE3D8@ha
|
/* 8033FA60 0033C9C0 3C 60 80 3F */ lis r3, "__vt__31TObjOwnerParam<P12IObjectStore>"@ha
|
||||||
/* 8033FA64 0033C9C4 38 03 E3 D8 */ addi r0, r3, lbl_803EE3D8@l
|
/* 8033FA64 0033C9C4 38 03 E3 D8 */ addi r0, r3, "__vt__31TObjOwnerParam<P12IObjectStore>"@l
|
||||||
/* 8033FA68 0033C9C8 90 1F 00 00 */ stw r0, 0(r31)
|
/* 8033FA68 0033C9C8 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
/* 8033FA6C 0033C9CC 41 82 00 20 */ beq lbl_8033FA8C
|
/* 8033FA6C 0033C9CC 41 82 00 20 */ beq lbl_8033FA8C
|
||||||
/* 8033FA70 0033C9D0 3C 60 80 3E */ lis r3, lbl_803D9C44@ha
|
/* 8033FA70 0033C9D0 3C 60 80 3E */ lis r3, __vt__10IVParamObj@ha
|
||||||
/* 8033FA74 0033C9D4 38 03 9C 44 */ addi r0, r3, lbl_803D9C44@l
|
/* 8033FA74 0033C9D4 38 03 9C 44 */ addi r0, r3, __vt__10IVParamObj@l
|
||||||
/* 8033FA78 0033C9D8 90 1F 00 00 */ stw r0, 0(r31)
|
/* 8033FA78 0033C9D8 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
/* 8033FA7C 0033C9DC 41 82 00 10 */ beq lbl_8033FA8C
|
/* 8033FA7C 0033C9DC 41 82 00 10 */ beq lbl_8033FA8C
|
||||||
/* 8033FA80 0033C9E0 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
/* 8033FA80 0033C9E0 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
||||||
|
|
|
@ -718,12 +718,12 @@ __ct__11CSimplePoolFR8IFactory:
|
||||||
/* 8034086C 0033D7CC 7C 7E 1B 79 */ or. r30, r3, r3
|
/* 8034086C 0033D7CC 7C 7E 1B 79 */ or. r30, r3, r3
|
||||||
/* 80340870 0033D7D0 41 82 00 2C */ beq lbl_8034089C
|
/* 80340870 0033D7D0 41 82 00 2C */ beq lbl_8034089C
|
||||||
/* 80340874 0033D7D4 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
/* 80340874 0033D7D4 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
||||||
/* 80340878 0033D7D8 3C 80 80 3E */ lis r4, lbl_803D9C44@ha
|
/* 80340878 0033D7D8 3C 80 80 3E */ lis r4, __vt__10IVParamObj@ha
|
||||||
/* 8034087C 0033D7DC 38 03 8D 6C */ addi r0, r3, __vt__4IObj@l
|
/* 8034087C 0033D7DC 38 03 8D 6C */ addi r0, r3, __vt__4IObj@l
|
||||||
/* 80340880 0033D7E0 3C 60 80 3F */ lis r3, lbl_803EE3D8@ha
|
/* 80340880 0033D7E0 3C 60 80 3F */ lis r3, "__vt__31TObjOwnerParam<P12IObjectStore>"@ha
|
||||||
/* 80340884 0033D7E4 90 1E 00 00 */ stw r0, 0(r30)
|
/* 80340884 0033D7E4 90 1E 00 00 */ stw r0, 0(r30)
|
||||||
/* 80340888 0033D7E8 38 84 9C 44 */ addi r4, r4, lbl_803D9C44@l
|
/* 80340888 0033D7E8 38 84 9C 44 */ addi r4, r4, __vt__10IVParamObj@l
|
||||||
/* 8034088C 0033D7EC 38 03 E3 D8 */ addi r0, r3, lbl_803EE3D8@l
|
/* 8034088C 0033D7EC 38 03 E3 D8 */ addi r0, r3, "__vt__31TObjOwnerParam<P12IObjectStore>"@l
|
||||||
/* 80340890 0033D7F0 90 9E 00 00 */ stw r4, 0(r30)
|
/* 80340890 0033D7F0 90 9E 00 00 */ stw r4, 0(r30)
|
||||||
/* 80340894 0033D7F4 90 1E 00 00 */ stw r0, 0(r30)
|
/* 80340894 0033D7F4 90 1E 00 00 */ stw r0, 0(r30)
|
||||||
/* 80340898 0033D7F8 93 FE 00 04 */ stw r31, 4(r30)
|
/* 80340898 0033D7F8 93 FE 00 04 */ stw r31, 4(r30)
|
||||||
|
|
|
@ -82,8 +82,8 @@ lbl_803D9C38:
|
||||||
.4byte 0
|
.4byte 0
|
||||||
.4byte sub_80034228
|
.4byte sub_80034228
|
||||||
|
|
||||||
.global lbl_803D9C44
|
.global __vt__10IVParamObj
|
||||||
lbl_803D9C44:
|
__vt__10IVParamObj:
|
||||||
# ROM: 0x3D6C44
|
# ROM: 0x3D6C44
|
||||||
.4byte 0
|
.4byte 0
|
||||||
.4byte 0
|
.4byte 0
|
||||||
|
@ -829,11 +829,11 @@ sub_80032344:
|
||||||
/* 800323AC 0002F30C 7C 7F 1B 79 */ or. r31, r3, r3
|
/* 800323AC 0002F30C 7C 7F 1B 79 */ or. r31, r3, r3
|
||||||
/* 800323B0 0002F310 41 82 00 2C */ beq lbl_800323DC
|
/* 800323B0 0002F310 41 82 00 2C */ beq lbl_800323DC
|
||||||
/* 800323B4 0002F314 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
/* 800323B4 0002F314 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
||||||
/* 800323B8 0002F318 3C 80 80 3E */ lis r4, lbl_803D9C44@ha
|
/* 800323B8 0002F318 3C 80 80 3E */ lis r4, __vt__10IVParamObj@ha
|
||||||
/* 800323BC 0002F31C 38 03 8D 6C */ addi r0, r3, __vt__4IObj@l
|
/* 800323BC 0002F31C 38 03 8D 6C */ addi r0, r3, __vt__4IObj@l
|
||||||
/* 800323C0 0002F320 3C 60 80 3E */ lis r3, lbl_803D9C38@ha
|
/* 800323C0 0002F320 3C 60 80 3E */ lis r3, lbl_803D9C38@ha
|
||||||
/* 800323C4 0002F324 90 1F 00 00 */ stw r0, 0(r31)
|
/* 800323C4 0002F324 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
/* 800323C8 0002F328 38 84 9C 44 */ addi r4, r4, lbl_803D9C44@l
|
/* 800323C8 0002F328 38 84 9C 44 */ addi r4, r4, __vt__10IVParamObj@l
|
||||||
/* 800323CC 0002F32C 38 03 9C 38 */ addi r0, r3, lbl_803D9C38@l
|
/* 800323CC 0002F32C 38 03 9C 38 */ addi r0, r3, lbl_803D9C38@l
|
||||||
/* 800323D0 0002F330 90 9F 00 00 */ stw r4, 0(r31)
|
/* 800323D0 0002F330 90 9F 00 00 */ stw r4, 0(r31)
|
||||||
/* 800323D4 0002F334 90 1F 00 00 */ stw r0, 0(r31)
|
/* 800323D4 0002F334 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
|
@ -886,11 +886,11 @@ lbl_80032404:
|
||||||
/* 80032488 0002F3E8 7C 7F 1B 79 */ or. r31, r3, r3
|
/* 80032488 0002F3E8 7C 7F 1B 79 */ or. r31, r3, r3
|
||||||
/* 8003248C 0002F3EC 41 82 00 2C */ beq lbl_800324B8
|
/* 8003248C 0002F3EC 41 82 00 2C */ beq lbl_800324B8
|
||||||
/* 80032490 0002F3F0 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
/* 80032490 0002F3F0 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
||||||
/* 80032494 0002F3F4 3C 80 80 3E */ lis r4, lbl_803D9C44@ha
|
/* 80032494 0002F3F4 3C 80 80 3E */ lis r4, __vt__10IVParamObj@ha
|
||||||
/* 80032498 0002F3F8 38 03 8D 6C */ addi r0, r3, __vt__4IObj@l
|
/* 80032498 0002F3F8 38 03 8D 6C */ addi r0, r3, __vt__4IObj@l
|
||||||
/* 8003249C 0002F3FC 3C 60 80 3E */ lis r3, lbl_803D9C38@ha
|
/* 8003249C 0002F3FC 3C 60 80 3E */ lis r3, lbl_803D9C38@ha
|
||||||
/* 800324A0 0002F400 90 1F 00 00 */ stw r0, 0(r31)
|
/* 800324A0 0002F400 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
/* 800324A4 0002F404 38 84 9C 44 */ addi r4, r4, lbl_803D9C44@l
|
/* 800324A4 0002F404 38 84 9C 44 */ addi r4, r4, __vt__10IVParamObj@l
|
||||||
/* 800324A8 0002F408 38 03 9C 38 */ addi r0, r3, lbl_803D9C38@l
|
/* 800324A8 0002F408 38 03 9C 38 */ addi r0, r3, lbl_803D9C38@l
|
||||||
/* 800324AC 0002F40C 90 9F 00 00 */ stw r4, 0(r31)
|
/* 800324AC 0002F40C 90 9F 00 00 */ stw r4, 0(r31)
|
||||||
/* 800324B0 0002F410 90 1F 00 00 */ stw r0, 0(r31)
|
/* 800324B0 0002F410 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
|
@ -1035,8 +1035,8 @@ sub_800326a0:
|
||||||
/* 800326AC 0002F60C 93 E1 00 0C */ stw r31, 0xc(r1)
|
/* 800326AC 0002F60C 93 E1 00 0C */ stw r31, 0xc(r1)
|
||||||
/* 800326B0 0002F610 7C 7F 1B 79 */ or. r31, r3, r3
|
/* 800326B0 0002F610 7C 7F 1B 79 */ or. r31, r3, r3
|
||||||
/* 800326B4 0002F614 41 82 00 30 */ beq lbl_800326E4
|
/* 800326B4 0002F614 41 82 00 30 */ beq lbl_800326E4
|
||||||
/* 800326B8 0002F618 3C 60 80 3E */ lis r3, lbl_803D9C44@ha
|
/* 800326B8 0002F618 3C 60 80 3E */ lis r3, __vt__10IVParamObj@ha
|
||||||
/* 800326BC 0002F61C 38 03 9C 44 */ addi r0, r3, lbl_803D9C44@l
|
/* 800326BC 0002F61C 38 03 9C 44 */ addi r0, r3, __vt__10IVParamObj@l
|
||||||
/* 800326C0 0002F620 90 1F 00 00 */ stw r0, 0(r31)
|
/* 800326C0 0002F620 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
/* 800326C4 0002F624 41 82 00 10 */ beq lbl_800326D4
|
/* 800326C4 0002F624 41 82 00 10 */ beq lbl_800326D4
|
||||||
/* 800326C8 0002F628 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
/* 800326C8 0002F628 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
||||||
|
@ -3011,8 +3011,8 @@ sub_80034228:
|
||||||
/* 80034244 000311A4 38 03 9C 38 */ addi r0, r3, lbl_803D9C38@l
|
/* 80034244 000311A4 38 03 9C 38 */ addi r0, r3, lbl_803D9C38@l
|
||||||
/* 80034248 000311A8 90 1F 00 00 */ stw r0, 0(r31)
|
/* 80034248 000311A8 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
/* 8003424C 000311AC 41 82 00 20 */ beq lbl_8003426C
|
/* 8003424C 000311AC 41 82 00 20 */ beq lbl_8003426C
|
||||||
/* 80034250 000311B0 3C 60 80 3E */ lis r3, lbl_803D9C44@ha
|
/* 80034250 000311B0 3C 60 80 3E */ lis r3, __vt__10IVParamObj@ha
|
||||||
/* 80034254 000311B4 38 03 9C 44 */ addi r0, r3, lbl_803D9C44@l
|
/* 80034254 000311B4 38 03 9C 44 */ addi r0, r3, __vt__10IVParamObj@l
|
||||||
/* 80034258 000311B8 90 1F 00 00 */ stw r0, 0(r31)
|
/* 80034258 000311B8 90 1F 00 00 */ stw r0, 0(r31)
|
||||||
/* 8003425C 000311BC 41 82 00 10 */ beq lbl_8003426C
|
/* 8003425C 000311BC 41 82 00 10 */ beq lbl_8003426C
|
||||||
/* 80034260 000311C0 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
/* 80034260 000311C0 3C 60 80 3E */ lis r3, __vt__4IObj@ha
|
||||||
|
|
|
@ -610,7 +610,7 @@ LIBS = [
|
||||||
["Kyoto/Streams/CZipInputStream", True],
|
["Kyoto/Streams/CZipInputStream", True],
|
||||||
["Kyoto/Streams/CZipOutputStream", True],
|
["Kyoto/Streams/CZipOutputStream", True],
|
||||||
["Kyoto/Streams/CZipSupport", True],
|
["Kyoto/Streams/CZipSupport", True],
|
||||||
"Kyoto/CFactoryStore",
|
["Kyoto/CFactoryStore", False],
|
||||||
["Kyoto/CObjectReference", True],
|
["Kyoto/CObjectReference", True],
|
||||||
"Kyoto/CSimplePool",
|
"Kyoto/CSimplePool",
|
||||||
["Kyoto/CToken", True],
|
["Kyoto/CToken", True],
|
||||||
|
|
|
@ -17,7 +17,9 @@ public:
|
||||||
static bool FileExists(const char*);
|
static bool FileExists(const char*);
|
||||||
|
|
||||||
static void DVDARAMXferCallback(long, DVDFileInfo*);
|
static void DVDARAMXferCallback(long, DVDFileInfo*);
|
||||||
|
static void ARAMARAMXferCallback(u32 addr);
|
||||||
void HandleDVDInterrupt();
|
void HandleDVDInterrupt();
|
||||||
|
void HandleARAMInterrupt();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
uchar pad[0x14];
|
uchar pad[0x14];
|
||||||
|
|
|
@ -10,12 +10,6 @@ class IObjectStore;
|
||||||
class CObjectReference {
|
class CObjectReference {
|
||||||
public:
|
public:
|
||||||
CObjectReference(const rstl::auto_ptr< IObj >& obj);
|
CObjectReference(const rstl::auto_ptr< IObj >& obj);
|
||||||
// : x0_refCount(0)
|
|
||||||
// , x2_locked(false)
|
|
||||||
// , x2_lockCount(0)
|
|
||||||
// , xc_objectStore(nullptr)
|
|
||||||
// , x10_object(obj.release())
|
|
||||||
// , x14_params(CVParamTransfer::Null()) {}
|
|
||||||
~CObjectReference();
|
~CObjectReference();
|
||||||
CObjectReference(IObjectStore& store, const rstl::auto_ptr< IObj >& obj, const SObjectTag& tag,
|
CObjectReference(IObjectStore& store, const rstl::auto_ptr< IObj >& obj, const SObjectTag& tag,
|
||||||
CVParamTransfer xfer);
|
CVParamTransfer xfer);
|
||||||
|
|
|
@ -1,16 +1,30 @@
|
||||||
#ifndef _CVPARAMTRANSFER
|
#ifndef _CVPARAMTRANSFER
|
||||||
#define _CVPARAMTRANSFER
|
#define _CVPARAMTRANSFER
|
||||||
|
|
||||||
|
#include "Kyoto/IObj.hpp"
|
||||||
#include <rstl/rc_ptr.hpp>
|
#include <rstl/rc_ptr.hpp>
|
||||||
|
|
||||||
class IObj;
|
class IVParamObj : public IObj {};
|
||||||
|
|
||||||
|
template < typename T >
|
||||||
|
class TObjOwnerParam : public IVParamObj {
|
||||||
|
public:
|
||||||
|
T* GetData() const { return static_cast<T*>(x4_data); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
T* x4_data;
|
||||||
|
};
|
||||||
|
|
||||||
class CVParamTransfer {
|
class CVParamTransfer {
|
||||||
public:
|
public:
|
||||||
|
template < typename T >
|
||||||
|
CVParamTransfer(TObjOwnerParam< T >* obj) : x0_obj(obj) {}
|
||||||
static CVParamTransfer Null();
|
static CVParamTransfer Null();
|
||||||
|
|
||||||
|
const IVParamObj& operator*() const { return *x0_obj; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
rstl::rc_ptr< unkptr > x0_;
|
rstl::rc_ptr< IVParamObj > x0_obj;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // _CVPARAMTRANSFER
|
#endif // _CVPARAMTRANSFER
|
||||||
|
|
|
@ -9,6 +9,20 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
typedef struct ARQRequest ARQRequest;
|
||||||
|
typedef void (*ARQCallback)(u32 pointerToARQRequest);
|
||||||
|
|
||||||
|
struct ARQRequest {
|
||||||
|
ARQRequest* next;
|
||||||
|
u32 owner;
|
||||||
|
u32 type;
|
||||||
|
u32 priority;
|
||||||
|
u32 source;
|
||||||
|
u32 dest;
|
||||||
|
u32 length;
|
||||||
|
ARQCallback callback;
|
||||||
|
};
|
||||||
|
|
||||||
void ARQInit(void);
|
void ARQInit(void);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
#include "Kyoto/IObjectStore.hpp"
|
||||||
|
#include "Kyoto/Alloc/CMemory.hpp"
|
||||||
|
#include "Kyoto/CObjectReference.hpp"
|
||||||
|
|
||||||
|
TObjOwnerParam<IObjectStore*> tmp;
|
|
@ -1,8 +1,21 @@
|
||||||
#include "Kyoto/CDvdFile.hpp"
|
#include "Kyoto/CDvdFile.hpp"
|
||||||
#include "dolphin/dvd.h"
|
#include "dolphin/dvd.h"
|
||||||
|
#include "dolphin/arq.h"
|
||||||
|
#include "dolphin/os.h"
|
||||||
|
|
||||||
#include "string.h"
|
#include "string.h"
|
||||||
|
|
||||||
|
const char* tmp = "??(??)";
|
||||||
|
|
||||||
|
struct SDvdFileInfo : DVDFileInfo {
|
||||||
|
CDvdFile* x3c_file;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct SAramCallback {
|
||||||
|
char data[0x5c];
|
||||||
|
CDvdFile* x5c_file;
|
||||||
|
};
|
||||||
|
|
||||||
const char* DecodeARAMFile(const char* filename) {
|
const char* DecodeARAMFile(const char* filename) {
|
||||||
if (!strncmp(filename, "aram:", 5)) {
|
if (!strncmp(filename, "aram:", 5)) {
|
||||||
return filename + 5;
|
return filename + 5;
|
||||||
|
@ -13,5 +26,21 @@ const char* DecodeARAMFile(const char* filename) {
|
||||||
|
|
||||||
void CDvdFile::DVDARAMXferCallback(s32 result, DVDFileInfo* info) {
|
void CDvdFile::DVDARAMXferCallback(s32 result, DVDFileInfo* info) {
|
||||||
DVDClose(info);
|
DVDClose(info);
|
||||||
reinterpret_cast<CDvdFile*>(info->cb.userData)->HandleDVDInterrupt();
|
reinterpret_cast< SDvdFileInfo* >(info)->x3c_file->HandleDVDInterrupt();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CDvdFile::ARAMARAMXferCallback(u32 addr) {
|
||||||
|
reinterpret_cast< SAramCallback* >(addr)->x5c_file->HandleARAMInterrupt();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CDvdFile::HandleARAMInterrupt() {
|
||||||
|
BOOL enabled = OSDisableInterrupts();
|
||||||
|
|
||||||
|
OSRestoreInterrupts(enabled);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CDvdFile::HandleDVDInterrupt() {
|
||||||
|
BOOL enabled = OSDisableInterrupts();
|
||||||
|
|
||||||
|
OSRestoreInterrupts(enabled);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue