NWC24Config: Make creation stage an enum class

Makes the enum strongly typed instead of interacting with a raw u32
value. While we're at it, we can add helpers to the NWC24Config to make
using code poke at the internals of the class a little bit less and also
make the querying a little nicer to read.
This commit is contained in:
Lioncash 2021-08-24 08:02:04 -04:00
parent 82371b89fc
commit bc939df69c
3 changed files with 24 additions and 20 deletions

View File

@ -60,7 +60,7 @@ void NWC24Config::ResetConfig()
SetMagic(0x57634366); SetMagic(0x57634366);
SetUnk(8); SetUnk(8);
SetCreationStage(NWC24_IDCS_INITIAL); SetCreationStage(NWC24CreationStage::Initial);
SetEnableBooting(0); SetEnableBooting(0);
SetEmail("@wii.com"); SetEmail("@wii.com");
@ -165,14 +165,14 @@ void NWC24Config::SetChecksum(u32 checksum)
m_data.checksum = Common::swap32(checksum); m_data.checksum = Common::swap32(checksum);
} }
u32 NWC24Config::CreationStage() const NWC24CreationStage NWC24Config::CreationStage() const
{ {
return Common::swap32(m_data.creation_stage); return NWC24CreationStage(Common::swap32(u32(m_data.creation_stage)));
} }
void NWC24Config::SetCreationStage(u32 creation_stage) void NWC24Config::SetCreationStage(NWC24CreationStage creation_stage)
{ {
m_data.creation_stage = Common::swap32(creation_stage); m_data.creation_stage = NWC24CreationStage(Common::swap32(u32(creation_stage)));
} }
u32 NWC24Config::EnableBooting() const u32 NWC24Config::EnableBooting() const

View File

@ -25,16 +25,16 @@ enum ErrorCode : s32
WC24_ERR_ID_NOT_REGISTERED = -44, WC24_ERR_ID_NOT_REGISTERED = -44,
}; };
enum class NWC24CreationStage : u32
{
Initial = 0,
Generated = 1,
Registered = 2
};
class NWC24Config final class NWC24Config final
{ {
public: public:
enum
{
NWC24_IDCS_INITIAL = 0,
NWC24_IDCS_GENERATED = 1,
NWC24_IDCS_REGISTERED = 2
};
enum enum
{ {
URL_COUNT = 0x05, URL_COUNT = 0x05,
@ -65,8 +65,12 @@ public:
u32 Checksum() const; u32 Checksum() const;
void SetChecksum(u32 checksum); void SetChecksum(u32 checksum);
u32 CreationStage() const; NWC24CreationStage CreationStage() const;
void SetCreationStage(u32 creation_stage); void SetCreationStage(NWC24CreationStage creation_stage);
bool IsCreated() const { return CreationStage() == NWC24CreationStage::Initial; }
bool IsGenerated() const { return CreationStage() == NWC24CreationStage::Generated; }
bool IsRegistered() const { return CreationStage() == NWC24CreationStage::Registered; }
u32 EnableBooting() const; u32 EnableBooting() const;
void SetEnableBooting(u32 enable_booting); void SetEnableBooting(u32 enable_booting);
@ -85,7 +89,7 @@ private:
u32 unk_04; // must be 8 u32 unk_04; // must be 8
u64 nwc24_id; u64 nwc24_id;
u32 id_generation; u32 id_generation;
u32 creation_stage; // 0:not_generated; 1:generated; 2:registered NWC24CreationStage creation_stage;
char email[MAX_EMAIL_LENGTH]; char email[MAX_EMAIL_LENGTH];
char paswd[MAX_PASSWORD_LENGTH]; char paswd[MAX_PASSWORD_LENGTH];
char mlchkid[0x24]; char mlchkid[0x24];

View File

@ -228,7 +228,7 @@ std::optional<IPCReply> NetKDRequestDevice::IOCtl(const IOCtlRequest& request)
case IOCTL_NWC24_REQUEST_GENERATED_USER_ID: // (Input: none, Output: 32 bytes) case IOCTL_NWC24_REQUEST_GENERATED_USER_ID: // (Input: none, Output: 32 bytes)
INFO_LOG_FMT(IOS_WC24, "NET_KD_REQ: IOCTL_NWC24_REQUEST_GENERATED_USER_ID"); INFO_LOG_FMT(IOS_WC24, "NET_KD_REQ: IOCTL_NWC24_REQUEST_GENERATED_USER_ID");
if (config.CreationStage() == NWC24::NWC24Config::NWC24_IDCS_INITIAL) if (config.IsCreated())
{ {
const std::string settings_file_path = const std::string settings_file_path =
Common::GetTitleDataPath(Titles::SYSTEM_MENU) + "/" WII_SETTING; Common::GetTitleDataPath(Titles::SYSTEM_MENU) + "/" WII_SETTING;
@ -258,7 +258,7 @@ std::optional<IPCReply> NetKDRequestDevice::IOCtl(const IOCtlRequest& request)
const s32 ret = NWC24MakeUserID(&user_id, hollywood_id, id_ctr, hardware_model, area_code); const s32 ret = NWC24MakeUserID(&user_id, hollywood_id, id_ctr, hardware_model, area_code);
config.SetId(user_id); config.SetId(user_id);
config.IncrementIdGen(); config.IncrementIdGen();
config.SetCreationStage(NWC24::NWC24Config::NWC24_IDCS_GENERATED); config.SetCreationStage(NWC24::NWC24CreationStage::Generated);
config.WriteConfig(); config.WriteConfig();
WriteReturnValue(ret, request.buffer_out); WriteReturnValue(ret, request.buffer_out);
@ -268,16 +268,16 @@ std::optional<IPCReply> NetKDRequestDevice::IOCtl(const IOCtlRequest& request)
WriteReturnValue(NWC24::WC24_ERR_FATAL, request.buffer_out); WriteReturnValue(NWC24::WC24_ERR_FATAL, request.buffer_out);
} }
} }
else if (config.CreationStage() == NWC24::NWC24Config::NWC24_IDCS_GENERATED) else if (config.IsGenerated())
{ {
WriteReturnValue(NWC24::WC24_ERR_ID_GENERATED, request.buffer_out); WriteReturnValue(NWC24::WC24_ERR_ID_GENERATED, request.buffer_out);
} }
else if (config.CreationStage() == NWC24::NWC24Config::NWC24_IDCS_REGISTERED) else if (config.IsRegistered())
{ {
WriteReturnValue(NWC24::WC24_ERR_ID_REGISTERED, request.buffer_out); WriteReturnValue(NWC24::WC24_ERR_ID_REGISTERED, request.buffer_out);
} }
Memory::Write_U64(config.Id(), request.buffer_out + 4); Memory::Write_U64(config.Id(), request.buffer_out + 4);
Memory::Write_U32(config.CreationStage(), request.buffer_out + 0xC); Memory::Write_U32(u32(config.CreationStage()), request.buffer_out + 0xC);
break; break;
case IOCTL_NWC24_GET_SCHEDULER_STAT: case IOCTL_NWC24_GET_SCHEDULER_STAT: