mirror of
https://github.com/rvtr/ctr_Repair.git
synced 2025-10-31 13:51:08 -04:00
NUPスキップモードの追加
データの書き込みを行う場合必ずRTCが読み込まれるように git-svn-id: file:///Volumes/Transfer/gigaleak_20231201/2020-05-23%20-%20ctr.7z%20+%20svn_v1.068.zip/ctr/svn/ctr_Repair@290 385bec56-5757-e545-9c3a-d8741f4650f1
This commit is contained in:
parent
d1c5bd626c
commit
dff70c8bf8
@ -50,6 +50,8 @@ bool s_NupOnlyMode = false;
|
||||
bool s_GetIvsOnlyMode = false;
|
||||
// SDカード確認専用モード
|
||||
bool s_CheckSdOnlyMode = false;
|
||||
// NUPスキップモードかどうか
|
||||
bool s_SkipNupMode = false;
|
||||
|
||||
// APSettingの書式が無い警告サウンドを鳴らしたかどうか
|
||||
bool s_ExistAPSettingAnnotation = false;
|
||||
@ -94,6 +96,11 @@ bool NeedsAcAdater(common::HardwareStateManager& manager)
|
||||
return manager.IsBatteryLower() && !manager.IsAdapterConnected();
|
||||
}
|
||||
|
||||
bool HasValidRtcData()
|
||||
{
|
||||
return !s_CheckSdOnlyMode && !s_NupOnlyMode && !s_GetIvsOnlyMode;
|
||||
}
|
||||
|
||||
typedef enum RestoreState
|
||||
{
|
||||
STARTUP, // 初期値
|
||||
@ -216,16 +223,12 @@ void CheckSdWritable(common::HardwareStateManager& manager, ::std::vector<std::s
|
||||
// 設定ファイル書式チェック
|
||||
void CheckApSetting(common::HardwareStateManager& manager, ::std::vector<std::string>& message, bool& goNextStep)
|
||||
{
|
||||
NN_UNUSED_VAR(manager);
|
||||
NN_UNUSED_VAR(goNextStep);
|
||||
|
||||
if (CheckAndReadAPSetting(message))
|
||||
{
|
||||
if(s_CheckSdOnlyMode)
|
||||
{
|
||||
s_RestoreState = CHECK_IVS;
|
||||
}
|
||||
else
|
||||
{
|
||||
CheckNupExecuted(manager, message, goNextStep);
|
||||
}
|
||||
s_RestoreState = IMPORT_RTC;
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -680,7 +683,7 @@ bool CheckAndReadAPSetting(::std::vector<std::string>& operationMessage)
|
||||
if (!s_ReadSettingDone)
|
||||
{
|
||||
s_ReadSettingDone = true;
|
||||
s_ReadSettingIsSuccess = ReadSetting(&s_NupOnlyMode, &s_GetIvsOnlyMode, &s_CheckSdOnlyMode);
|
||||
s_ReadSettingIsSuccess = ReadSetting(&s_NupOnlyMode, &s_GetIvsOnlyMode, &s_CheckSdOnlyMode, &s_SkipNupMode);
|
||||
}
|
||||
|
||||
if (s_NupOnlyMode && s_GetIvsOnlyMode
|
||||
@ -690,6 +693,11 @@ bool CheckAndReadAPSetting(::std::vector<std::string>& operationMessage)
|
||||
operationMessage.push_back("Only one special mode setting is valid!!");
|
||||
s_ReadSettingIsSuccess = false;
|
||||
}
|
||||
else if(s_NupOnlyMode && s_SkipNupMode)
|
||||
{
|
||||
operationMessage.push_back("Both NUP_ONLY and SKIP_NUP are described!!");
|
||||
s_ReadSettingIsSuccess = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (s_NupOnlyMode)
|
||||
@ -804,14 +812,7 @@ void ControlState(common::HardwareStateManager& manager, ::std::vector<std::stri
|
||||
if (nextStep)
|
||||
{
|
||||
COMMON_LOGGER("Start Network Update\n");
|
||||
if(s_GetIvsOnlyMode)
|
||||
{
|
||||
s_RestoreState = UPDATE_IN_PROGRESS;
|
||||
}
|
||||
else
|
||||
{
|
||||
s_RestoreState = IMPORT_RTC;
|
||||
}
|
||||
s_RestoreState = UPDATE_IN_PROGRESS;
|
||||
}
|
||||
}
|
||||
break;
|
||||
@ -865,14 +866,36 @@ void ControlState(common::HardwareStateManager& manager, ::std::vector<std::stri
|
||||
|
||||
case IMPORT_RTC:
|
||||
{
|
||||
result = ExecSyncMcuRtc(manager);
|
||||
if (result <= nn::fs::ResultVerificationFailed())
|
||||
result = nn::ResultSuccess();
|
||||
if (HasValidRtcData())
|
||||
{
|
||||
s_RestoreState = FAIL;
|
||||
result = ExecSyncMcuRtc(manager);
|
||||
if (result <= nn::fs::ResultVerificationFailed())
|
||||
{
|
||||
s_RestoreState = FAIL;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (s_SkipNupMode)
|
||||
{
|
||||
CheckAccountTransfered(manager, operationMessage, nextStep);
|
||||
}
|
||||
else
|
||||
{
|
||||
CheckNupExecuted(manager, operationMessage, nextStep);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
s_RestoreState = UPDATE_IN_PROGRESS;
|
||||
if (s_CheckSdOnlyMode)
|
||||
{
|
||||
s_RestoreState = CHECK_IVS;
|
||||
}
|
||||
else
|
||||
{
|
||||
CheckNupExecuted(manager, operationMessage, nextStep);
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
@ -1572,6 +1595,7 @@ void InitializeState()
|
||||
s_SdWriteProetctAnnotation = false;
|
||||
s_WifiStatusOffAnnotation = false;
|
||||
s_CheckSdOnlyMode = false;
|
||||
s_SkipNupMode = false;
|
||||
}
|
||||
|
||||
u32 GetProgress()
|
||||
|
||||
@ -1015,7 +1015,7 @@ bool UpdateNetworkSetting(nn::ac::NetworkSetting& networkSetting)
|
||||
return retval;
|
||||
}
|
||||
|
||||
bool ReadSetting(bool* nupOnly, bool* getIvs, bool* checkSd)
|
||||
bool ReadSetting(bool* nupOnly, bool* getIvs, bool* checkSd, bool* skipNup)
|
||||
{
|
||||
nn::Result result;
|
||||
bool retval = true;
|
||||
@ -1358,6 +1358,20 @@ bool ReadSetting(bool* nupOnly, bool* getIvs, bool* checkSd)
|
||||
}
|
||||
}
|
||||
|
||||
{
|
||||
const wchar_t* const SKIP_NUP_STR = L"SKIP_NUP";
|
||||
NN_NULL_ASSERT(skipNup);
|
||||
if (configfileLoader.ReadAsChar(SKIP_NUP_STR) != NULL)
|
||||
{
|
||||
s32 num = configfileLoader.ReadAsInteger(SKIP_NUP_STR);
|
||||
if (num == 1)
|
||||
{
|
||||
*skipNup = true;
|
||||
COMMON_LOGGER("Skip NUP Mode.\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
configfileLoader.Finalize();
|
||||
|
||||
// 書き込み完了しなければfalse
|
||||
|
||||
@ -108,7 +108,7 @@ struct TimeZone
|
||||
};
|
||||
|
||||
// ネットワーク設定ファイルを読み込む
|
||||
bool ReadSetting(bool* nupOnly, bool* getIvs, bool* checkSd);
|
||||
bool ReadSetting(bool* nupOnly, bool* getIvs, bool* checkSd, bool* skipNup);
|
||||
|
||||
// ネットワーク設定ファイルからNTPサーバの名前を取得する
|
||||
// 先にReadSettingが成功している必要がある
|
||||
|
||||
Loading…
Reference in New Issue
Block a user