mirror of
https://github.com/wheremyfoodat/Panda3DS.git
synced 2025-08-26 12:15:39 +00:00
Stub GetProgramInfos
This commit is contained in:
parent
6571ca1b91
commit
02ce71882b
2 changed files with 18 additions and 0 deletions
|
@ -13,6 +13,7 @@ class AMService {
|
||||||
// Service commands
|
// Service commands
|
||||||
void getDLCTitleInfo(u32 messagePointer);
|
void getDLCTitleInfo(u32 messagePointer);
|
||||||
void getPatchTitleInfo(u32 messagePointer);
|
void getPatchTitleInfo(u32 messagePointer);
|
||||||
|
void getProgramInfos(u32 messagePointer);
|
||||||
void listTitleInfo(u32 messagePointer);
|
void listTitleInfo(u32 messagePointer);
|
||||||
void needsCleanup(u32 messagePointer);
|
void needsCleanup(u32 messagePointer);
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
namespace AMCommands {
|
namespace AMCommands {
|
||||||
enum : u32 {
|
enum : u32 {
|
||||||
|
GetProgramInfos = 0x00030084,
|
||||||
NeedsCleanup = 0x00130040,
|
NeedsCleanup = 0x00130040,
|
||||||
GetDLCTitleInfo = 0x10050084,
|
GetDLCTitleInfo = 0x10050084,
|
||||||
ListTitleInfo = 0x10070102,
|
ListTitleInfo = 0x10070102,
|
||||||
|
@ -17,6 +18,7 @@ void AMService::handleSyncRequest(u32 messagePointer) {
|
||||||
switch (command) {
|
switch (command) {
|
||||||
case AMCommands::GetPatchTitleInfo: getPatchTitleInfo(messagePointer); break;
|
case AMCommands::GetPatchTitleInfo: getPatchTitleInfo(messagePointer); break;
|
||||||
case AMCommands::GetDLCTitleInfo: getDLCTitleInfo(messagePointer); break;
|
case AMCommands::GetDLCTitleInfo: getDLCTitleInfo(messagePointer); break;
|
||||||
|
case AMCommands::GetProgramInfos: getProgramInfos(messagePointer); break;
|
||||||
case AMCommands::ListTitleInfo: listTitleInfo(messagePointer); break;
|
case AMCommands::ListTitleInfo: listTitleInfo(messagePointer); break;
|
||||||
case AMCommands::NeedsCleanup: needsCleanup(messagePointer); break;
|
case AMCommands::NeedsCleanup: needsCleanup(messagePointer); break;
|
||||||
default: Helpers::panic("AM service requested. Command: %08X\n", command);
|
default: Helpers::panic("AM service requested. Command: %08X\n", command);
|
||||||
|
@ -68,3 +70,18 @@ void AMService::needsCleanup(u32 messagePointer) {
|
||||||
mem.write32(messagePointer + 4, Result::Success);
|
mem.write32(messagePointer + 4, Result::Success);
|
||||||
mem.write8(messagePointer + 8, 0); // Doesn't need cleanup
|
mem.write8(messagePointer + 8, 0); // Doesn't need cleanup
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AMService::getProgramInfos(u32 messagePointer) {
|
||||||
|
const u8 mediaType = mem.read8(messagePointer + 4);
|
||||||
|
const u32 titleCount = mem.read32(messagePointer + 8);
|
||||||
|
const u32 titleIDs = mem.read32(messagePointer + 16);
|
||||||
|
const u32 titleInfos = mem.read32(messagePointer + 24);
|
||||||
|
log("AM::GetProgramInfos (media type = %X, title count = %X, title IDs pointer = %X, title infos pointer = %X) (Stubbed)\n", mediaType, titleCount, titleIDs, titleInfos);
|
||||||
|
|
||||||
|
mem.write32(messagePointer, IPC::responseHeader(0x3, 1, 4));
|
||||||
|
mem.write32(messagePointer + 4, Result::Success);
|
||||||
|
mem.write32(messagePointer + 8, IPC::pointerHeader(0, sizeof(u64) * titleCount, IPC::BufferType::Send));
|
||||||
|
mem.write32(messagePointer + 12, 0xC0DEC0DE);
|
||||||
|
mem.write32(messagePointer + 16, IPC::pointerHeader(1, sizeof(u32) * titleCount, IPC::BufferType::Receive));
|
||||||
|
mem.write32(messagePointer + 20, 0xC0DEC0DE);
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue