mirror of
https://github.com/Lime3DS/Lime3DS
synced 2024-12-31 11:32:36 -06:00
Merge pull request #1706 from mailwl/mii-selector
Layout Mii parameters input/output, and return success as result of applet work
This commit is contained in:
commit
24d064e830
2 changed files with 49 additions and 0 deletions
|
@ -55,6 +55,11 @@ ResultCode MiiSelector::StartImpl(const Service::APT::AppletStartupParameter& pa
|
||||||
// TODO(Subv): Set the expected fields in the response buffer before resending it to the application.
|
// TODO(Subv): Set the expected fields in the response buffer before resending it to the application.
|
||||||
// TODO(Subv): Reverse the parameter format for the Mii Selector
|
// TODO(Subv): Reverse the parameter format for the Mii Selector
|
||||||
|
|
||||||
|
if(parameter.buffer_size >= sizeof(u32)) {
|
||||||
|
// TODO: defaults return no error, but garbage in other unknown fields
|
||||||
|
memset(parameter.data, 0, sizeof(u32));
|
||||||
|
}
|
||||||
|
|
||||||
// Let the application know that we're closing
|
// Let the application know that we're closing
|
||||||
Service::APT::MessageParameter message;
|
Service::APT::MessageParameter message;
|
||||||
message.buffer_size = parameter.buffer_size;
|
message.buffer_size = parameter.buffer_size;
|
||||||
|
|
|
@ -16,6 +16,50 @@
|
||||||
namespace HLE {
|
namespace HLE {
|
||||||
namespace Applets {
|
namespace Applets {
|
||||||
|
|
||||||
|
struct MiiConfig {
|
||||||
|
u8 unk_000;
|
||||||
|
u8 unk_001;
|
||||||
|
u8 unk_002;
|
||||||
|
u8 unk_003;
|
||||||
|
u8 unk_004;
|
||||||
|
INSERT_PADDING_BYTES(3);
|
||||||
|
u16 unk_008;
|
||||||
|
INSERT_PADDING_BYTES(0x8C - 0xA);
|
||||||
|
u8 unk_08C;
|
||||||
|
INSERT_PADDING_BYTES(3);
|
||||||
|
u16 unk_090;
|
||||||
|
INSERT_PADDING_BYTES(2);
|
||||||
|
u32 unk_094;
|
||||||
|
u16 unk_098;
|
||||||
|
u8 unk_09A[0x64];
|
||||||
|
u8 unk_0FE;
|
||||||
|
u8 unk_0FF;
|
||||||
|
u32 unk_100;
|
||||||
|
};
|
||||||
|
|
||||||
|
static_assert(sizeof(MiiConfig) == 0x104, "MiiConfig structure has incorrect size");
|
||||||
|
#define ASSERT_REG_POSITION(field_name, position) static_assert(offsetof(MiiConfig, field_name) == position, "Field "#field_name" has invalid position")
|
||||||
|
ASSERT_REG_POSITION(unk_008, 0x08);
|
||||||
|
ASSERT_REG_POSITION(unk_08C, 0x8C);
|
||||||
|
ASSERT_REG_POSITION(unk_090, 0x90);
|
||||||
|
ASSERT_REG_POSITION(unk_094, 0x94);
|
||||||
|
ASSERT_REG_POSITION(unk_0FE, 0xFE);
|
||||||
|
#undef ASSERT_REG_POSITION
|
||||||
|
|
||||||
|
struct MiiResult {
|
||||||
|
u32 result_code;
|
||||||
|
u8 unk_04;
|
||||||
|
INSERT_PADDING_BYTES(7);
|
||||||
|
u8 unk_0C[0x60];
|
||||||
|
u8 unk_6C[0x16];
|
||||||
|
INSERT_PADDING_BYTES(2);
|
||||||
|
};
|
||||||
|
static_assert(sizeof(MiiResult) == 0x84, "MiiResult structure has incorrect size");
|
||||||
|
#define ASSERT_REG_POSITION(field_name, position) static_assert(offsetof(MiiResult, field_name) == position, "Field "#field_name" has invalid position")
|
||||||
|
ASSERT_REG_POSITION(unk_0C, 0x0C);
|
||||||
|
ASSERT_REG_POSITION(unk_6C, 0x6C);
|
||||||
|
#undef ASSERT_REG_POSITION
|
||||||
|
|
||||||
class MiiSelector final : public Applet {
|
class MiiSelector final : public Applet {
|
||||||
public:
|
public:
|
||||||
MiiSelector(Service::APT::AppletId id);
|
MiiSelector(Service::APT::AppletId id);
|
||||||
|
|
Loading…
Reference in a new issue