2015-06-12 00:12:16 +02:00
|
|
|
// Copyright 2015 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
2017-01-04 17:48:29 +01:00
|
|
|
#include <cinttypes>
|
2017-06-06 10:29:46 +02:00
|
|
|
#include "common/logging/log.h"
|
|
|
|
#include "core/hle/ipc.h"
|
|
|
|
#include "core/hle/result.h"
|
2015-06-12 00:12:16 +02:00
|
|
|
#include "core/hle/service/boss/boss.h"
|
|
|
|
#include "core/hle/service/boss/boss_p.h"
|
|
|
|
#include "core/hle/service/boss/boss_u.h"
|
2016-09-18 02:38:01 +02:00
|
|
|
#include "core/hle/service/service.h"
|
2015-06-12 00:12:16 +02:00
|
|
|
|
|
|
|
namespace Service {
|
|
|
|
namespace BOSS {
|
|
|
|
|
2016-10-02 09:45:58 +02:00
|
|
|
static u32 new_arrival_flag;
|
|
|
|
static u32 ns_data_new_flag;
|
|
|
|
static u32 output_flag;
|
|
|
|
|
|
|
|
void InitializeSession(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u64 unk_param = ((u64)cmd_buff[1] | ((u64)cmd_buff[2] << 32));
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
|
|
|
|
if (translation != IPC::CallingPidDesc()) {
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0, 0x1, 0); // 0x40
|
2017-05-21 09:11:36 +02:00
|
|
|
cmd_buff[1] = IPC::ERR_INVALID_BUFFER_DESCRIPTOR.raw;
|
2016-10-02 09:45:58 +02:00
|
|
|
LOG_ERROR(Service_BOSS, "The translation was invalid, translation=0x%08X", translation);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x1, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
2017-01-04 17:48:29 +01:00
|
|
|
LOG_WARNING(Service_BOSS,
|
|
|
|
"(STUBBED) unk_param=0x%016" PRIX64 ", translation=0x%08X, unk_param4=0x%08X",
|
2016-10-02 09:45:58 +02:00
|
|
|
unk_param, translation, unk_param4);
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegisterStorage(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_flag = cmd_buff[4] & 0xFF;
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x2, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(
|
|
|
|
Service_BOSS,
|
|
|
|
"(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, unk_flag=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
void UnregisterStorage(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x3, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) called");
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetStorageInfo(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x4, 0x2, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) called");
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegisterPrivateRootCa(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x5, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) translation=0x%08X, buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegisterPrivateClientCert(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 translation1 = cmd_buff[3];
|
|
|
|
u32 buff1_addr = cmd_buff[4];
|
|
|
|
u32 buff1_size = (translation1 >> 4);
|
|
|
|
u32 translation2 = cmd_buff[5];
|
|
|
|
u32 buff2_addr = cmd_buff[6];
|
|
|
|
u32 buff2_size = (translation2 >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x6, 0x1, 0x4);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff1_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff1_addr;
|
|
|
|
cmd_buff[2] = (buff2_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff2_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation1=0x%08X, buff1_addr=0x%08X, buff1_size=0x%08X, "
|
|
|
|
"translation2=0x%08X, buff2_addr=0x%08X, buff2_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation1, buff1_addr, buff1_size, translation2,
|
|
|
|
buff2_addr, buff2_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNewArrivalFlag(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x7, 0x2, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = new_arrival_flag;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) new_arrival_flag=%u", new_arrival_flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegisterNewArrivalEvent(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x8, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X", unk_param1,
|
|
|
|
unk_param2);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetOptoutFlag(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
output_flag = cmd_buff[1] & 0xFF;
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x9, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "output_flag=%u", output_flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetOptoutFlag(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0xA, 0x2, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = output_flag;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "output_flag=%u", output_flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegisterTask(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 unk_param3 = cmd_buff[3] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[4];
|
|
|
|
u32 buff_addr = cmd_buff[5];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0xB, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void UnregisterTask(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0xC, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ReconfigureTask(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0xD, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskIdList(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0xE, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) called");
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetStepIdList(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0xF, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) translation=0x%08X, buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNsDataIdList(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
u32 translation = cmd_buff[5];
|
|
|
|
u32 buff_addr = cmd_buff[6];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x10, 0x3, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[4] = (buff_size << 4 | 0xC);
|
|
|
|
cmd_buff[5] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"unk_param4=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_param4, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetOwnNsDataIdList(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
u32 translation = cmd_buff[5];
|
|
|
|
u32 buff_addr = cmd_buff[6];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x11, 0x3, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[4] = (buff_size << 4 | 0xC);
|
|
|
|
cmd_buff[5] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"unk_param4=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_param4, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNewDataNsDataIdList(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
u32 translation = cmd_buff[5];
|
|
|
|
u32 buff_addr = cmd_buff[6];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x12, 0x3, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[4] = (buff_size << 4 | 0xC);
|
|
|
|
cmd_buff[5] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"unk_param4=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_param4, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetOwnNewDataNsDataIdList(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
u32 translation = cmd_buff[5];
|
|
|
|
u32 buff_addr = cmd_buff[6];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x13, 0x3, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (16 bit value)
|
|
|
|
cmd_buff[4] = (buff_size << 4 | 0xC);
|
|
|
|
cmd_buff[5] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"unk_param4=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_param4, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SendProperty(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x14, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SendPropertyHandle(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x15, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ReceiveProperty(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 buff_size = cmd_buff[2];
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x16, 0x2, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32 bit value)
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xC);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, buff_size=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X",
|
|
|
|
unk_param1, buff_size, translation, buff_addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void UpdateTaskInterval(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x17, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void UpdateTaskCount(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 buff_size = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x18, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) buff_size=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X",
|
|
|
|
buff_size, unk_param2, translation, buff_addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskInterval(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 unk_param1 = cmd_buff[1]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x19, 0x2, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 ( 32bit value)
|
|
|
|
cmd_buff[3] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[4] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskCount(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 unk_param1 = cmd_buff[1]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x1A, 0x2, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 ( 32bit value)
|
|
|
|
cmd_buff[3] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[4] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskServiceStatus(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 unk_param1 = cmd_buff[1]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x1B, 0x2, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 ( 8bit value)
|
|
|
|
cmd_buff[3] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[4] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void StartTask(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 unk_param1 = cmd_buff[1]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x1C, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void StartTaskImmediate(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 unk_param1 = cmd_buff[1]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x1D, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CancelTask(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x1E, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskFinishHandle(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x1F, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0;
|
|
|
|
cmd_buff[3] = 0; // stub 0(This should be a handle of task_finish ?)
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) called");
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskState(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 buff_size = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[3];
|
|
|
|
u32 buff_addr = cmd_buff[4];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x20, 0x4, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (8 bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (32 bit value)
|
|
|
|
cmd_buff[4] = 0; // stub 0 (8 bit value)
|
|
|
|
cmd_buff[5] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[6] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) buff_size=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X",
|
|
|
|
buff_size, unk_param2, translation, buff_addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskResult(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x21, 0x4, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (8 bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (32 bit value)
|
|
|
|
cmd_buff[4] = 0; // stub 0 (8 bit value)
|
|
|
|
cmd_buff[5] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[6] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskCommErrorCode(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x22, 0x4, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32 bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (32 bit value)
|
|
|
|
cmd_buff[4] = 0; // stub 0 (8 bit value)
|
|
|
|
cmd_buff[5] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[6] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskStatus(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 unk_param3 = cmd_buff[3] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[4];
|
|
|
|
u32 buff_addr = cmd_buff[5];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x23, 0x2, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (8 bit value)
|
|
|
|
cmd_buff[3] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[4] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskError(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[4];
|
|
|
|
u32 buff_addr = cmd_buff[5];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x24, 0x2, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (8 bit value)
|
|
|
|
cmd_buff[3] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[4] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskInfo(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[4];
|
|
|
|
u32 buff_addr = cmd_buff[5];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x25, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void DeleteNsData(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x26, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X", unk_param1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNsDataHeaderInfo(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 translation = cmd_buff[4];
|
|
|
|
u32 buff_addr = cmd_buff[5];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x27, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xC);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ReadNsData(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
u32 translation = cmd_buff[5];
|
|
|
|
u32 buff_addr = cmd_buff[6];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x28, 0x3, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (32bit value)
|
|
|
|
cmd_buff[4] = (buff_size << 4 | 0xC);
|
|
|
|
cmd_buff[5] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"unk_param4=0x%08X, translation=0x%08X, "
|
|
|
|
"buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_param4, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetNsDataAdditionalInfo(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x29, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X", unk_param1,
|
|
|
|
unk_param2);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNsDataAdditionalInfo(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x2A, 0x2, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32bit value)
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X", unk_param1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetNsDataNewFlag(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
ns_data_new_flag = cmd_buff[2] & 0xFF;
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x2B, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, ns_data_new_flag=0x%08X", unk_param1,
|
|
|
|
ns_data_new_flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNsDataNewFlag(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x2C, 0x2, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = ns_data_new_flag;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, ns_data_new_flag=0x%08X", unk_param1,
|
|
|
|
ns_data_new_flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNsDataLastUpdate(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x2D, 0x3, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (32bit value)
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X", unk_param1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetErrorCode(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x2E, 0x2, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32bit value)
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X", unk_param1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegisterStorageEntry(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
u32 unk_param5 = cmd_buff[5] & 0xFF;
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x2F, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"unk_param4=0x%08X, unk_param5=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_param4, unk_param5);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetStorageEntryInfo(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x30, 0x3, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (16bit value)
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) called");
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetStorageOption(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1] & 0xFF;
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 unk_param3 = cmd_buff[3];
|
|
|
|
u32 unk_param4 = cmd_buff[4];
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x31, 0x1, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"unk_param3=0x%08X, unk_param4=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, unk_param4);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetStorageOption(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x32, 0x5, 0);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (32bit value)
|
|
|
|
cmd_buff[3] = 0; // stub 0 (8bit value)
|
|
|
|
cmd_buff[4] = 0; // stub 0 (16bit value)
|
|
|
|
cmd_buff[5] = 0; // stub 0 (16bit value)
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) called");
|
|
|
|
}
|
|
|
|
|
|
|
|
void StartBgImmediate(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 unk_param1 = cmd_buff[1]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x33, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) buff_size=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskActivePriority(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
|
|
|
|
u32 unk_param1 = cmd_buff[1]; // TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 translation = cmd_buff[2];
|
|
|
|
u32 buff_addr = cmd_buff[3];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x34, 0x2, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = 0; // stub 0 (8bit value)
|
|
|
|
cmd_buff[3] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[4] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) buff_size=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X",
|
|
|
|
unk_param1, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegisterImmediateTask(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2] & 0xFF;
|
|
|
|
u32 unk_param3 = cmd_buff[3] & 0xFF;
|
|
|
|
u32 translation = cmd_buff[4];
|
|
|
|
u32 buff_addr = cmd_buff[5];
|
|
|
|
u32 buff_size = (translation >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x35, 0x1, 0x2);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[3] = (buff_size << 4 | 0xA);
|
|
|
|
cmd_buff[4] = buff_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, unk_param3=0x%08X, "
|
|
|
|
"translation=0x%08X, buff_addr=0x%08X, buff_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, unk_param3, translation, buff_addr, buff_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetTaskQuery(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 translation1 = cmd_buff[3];
|
|
|
|
u32 buff1_addr = cmd_buff[4];
|
|
|
|
u32 buff1_size = (translation1 >> 4);
|
|
|
|
u32 translation2 = cmd_buff[5];
|
|
|
|
u32 buff2_addr = cmd_buff[6];
|
|
|
|
u32 buff2_size = (translation2 >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x36, 0x1, 0x4);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff1_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff1_addr;
|
|
|
|
cmd_buff[2] = (buff2_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff2_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation1=0x%08X, buff1_addr=0x%08X, buff1_size=0x%08X, "
|
|
|
|
"translation2=0x%08X, buff2_addr=0x%08X, buff2_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation1, buff1_addr, buff1_size, translation2,
|
|
|
|
buff2_addr, buff2_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetTaskQuery(Service::Interface* self) {
|
|
|
|
u32* cmd_buff = Kernel::GetCommandBuffer();
|
|
|
|
// TODO(JamePeng): Figure out the meaning of these parameters
|
|
|
|
u32 unk_param1 = cmd_buff[1];
|
|
|
|
u32 unk_param2 = cmd_buff[2];
|
|
|
|
u32 translation1 = cmd_buff[3];
|
|
|
|
u32 buff1_addr = cmd_buff[4];
|
|
|
|
u32 buff1_size = (translation1 >> 4);
|
|
|
|
u32 translation2 = cmd_buff[5];
|
|
|
|
u32 buff2_addr = cmd_buff[6];
|
|
|
|
u32 buff2_size = (translation2 >> 4);
|
|
|
|
|
|
|
|
cmd_buff[0] = IPC::MakeHeader(0x37, 0x1, 0x4);
|
|
|
|
cmd_buff[1] = RESULT_SUCCESS.raw;
|
|
|
|
cmd_buff[2] = (buff1_size << 4 | 0xA);
|
|
|
|
cmd_buff[3] = buff1_addr;
|
|
|
|
cmd_buff[2] = (buff2_size << 4 | 0xC);
|
|
|
|
cmd_buff[3] = buff2_addr;
|
|
|
|
|
|
|
|
LOG_WARNING(Service_BOSS, "(STUBBED) unk_param1=0x%08X, unk_param2=0x%08X, "
|
|
|
|
"translation1=0x%08X, buff1_addr=0x%08X, buff1_size=0x%08X, "
|
|
|
|
"translation2=0x%08X, buff2_addr=0x%08X, buff2_size=0x%08X",
|
|
|
|
unk_param1, unk_param2, translation1, buff1_addr, buff1_size, translation2,
|
|
|
|
buff2_addr, buff2_size);
|
|
|
|
}
|
|
|
|
|
2015-06-12 00:12:16 +02:00
|
|
|
void Init() {
|
|
|
|
using namespace Kernel;
|
|
|
|
|
|
|
|
AddService(new BOSS_P_Interface);
|
|
|
|
AddService(new BOSS_U_Interface);
|
2016-10-02 09:45:58 +02:00
|
|
|
|
|
|
|
new_arrival_flag = 0;
|
|
|
|
ns_data_new_flag = 0;
|
|
|
|
output_flag = 0;
|
2015-06-12 00:12:16 +02:00
|
|
|
}
|
|
|
|
|
2016-09-19 03:01:46 +02:00
|
|
|
void Shutdown() {}
|
2015-06-12 00:12:16 +02:00
|
|
|
|
|
|
|
} // namespace BOSS
|
|
|
|
|
|
|
|
} // namespace Service
|