diff --git a/branches/SelfCupExecChecker/HeapManager.cpp b/branches/SelfCupExecChecker/HeapManager.cpp deleted file mode 100644 index 8e95885..0000000 --- a/branches/SelfCupExecChecker/HeapManager.cpp +++ /dev/null @@ -1,59 +0,0 @@ -/*---------------------------------------------------------------------------* - Project: Horizon - File: HeapManager.cpp - - Copyright 2009 Nintendo. All rights reserved. - - These coded instructions, statements, and computer programs contain - proprietary information of Nintendo of America Inc. and/or Nintendo - Company Ltd., and are protected by Federal copyright law. They may - not be disclosed to third parties or copied or duplicated in any form, - in whole or in part, without the prior written consent of Nintendo. - - $Rev$ - *---------------------------------------------------------------------------*/ - -#include "HeapManager.h" - -nn::fnd::ThreadSafeExpHeap s_AppHeap; - - -HeapManager::HeapManager(size_t byteSize, s32 alignment, bit8 groupId, nn::fnd::ExpHeapBase::AllocationMode mode, bool reuse) -{ - m_Ptr = s_AppHeap.Allocate(byteSize, alignment, groupId, mode, reuse); -} - -HeapManager::~HeapManager() -{ - if(m_Ptr != NULL) - { - s_AppHeap.Free(m_Ptr); - } -} -void* HeapManager::GetAddr() -{ - return m_Ptr; -} - -void InitializeHeap() -{ - s_AppHeap.Initialize(nn::os::GetDeviceMemoryAddress(), nn::os::GetDeviceMemorySize(), nn::os::ALLOCATE_OPTION_LINEAR); -} - -size_t GetAllocatableSize(s32 alignment) -{ - return s_AppHeap.GetAllocatableSize(alignment); -} - -void* ForceAllocate(size_t byteSize, s32 alignment, bit8 groupId, nn::fnd::ExpHeapBase::AllocationMode mode, bool reuse) -{ - return s_AppHeap.Allocate(byteSize, alignment, groupId, mode, reuse); -} - -void ForceFree(void* ptr) -{ - if(ptr != NULL) - { - s_AppHeap.Free(ptr); - } -} diff --git a/branches/SelfCupExecChecker/HeapManager.h b/branches/SelfCupExecChecker/HeapManager.h deleted file mode 100644 index f50f3fe..0000000 --- a/branches/SelfCupExecChecker/HeapManager.h +++ /dev/null @@ -1,46 +0,0 @@ -/*---------------------------------------------------------------------------* - Project: Horizon - File: HeapManager.h - - Copyright 2009 Nintendo. All rights reserved. - - These coded instructions, statements, and computer programs contain - proprietary information of Nintendo of America Inc. and/or Nintendo - Company Ltd., and are protected by Federal copyright law. They may - not be disclosed to third parties or copied or duplicated in any form, - in whole or in part, without the prior written consent of Nintendo. - - $Rev$ - *---------------------------------------------------------------------------*/ - -#ifndef HEAPMANAGER_H_ -#define HEAPMANAGER_H_ - -#include -#include - -class HeapManager -{ -public: - explicit HeapManager(size_t byteSize, s32 alignment = nn::fnd::ExpHeapBase::DEFAULT_ALIGNMENT, bit8 groupId = 0, - nn::fnd::ExpHeapBase::AllocationMode mode = nn::fnd::ExpHeapBase::ALLOCATION_MODE_FIRST_FIT, bool reuse = false); - virtual ~HeapManager(); - - void* GetAddr(); - -private: - void* m_Ptr; - -}; - -void InitializeHeap(); -size_t GetAllocatableSize(s32 alignment = nn::fnd::ExpHeapBase::DEFAULT_ALIGNMENT); - -// HeapManagerを使わず確保する場合のみ -void* ForceAllocate(size_t byteSize, s32 alignment = nn::fnd::ExpHeapBase::DEFAULT_ALIGNMENT, bit8 groupId = 0, - nn::fnd::ExpHeapBase::AllocationMode mode = nn::fnd::ExpHeapBase::ALLOCATION_MODE_FIRST_FIT, bool reuse = false); - -// HeapManagerを使わず解放する場合のみ -void ForceFree(void* ptr); - -#endif /* HEAPMANAGER_H_ */ diff --git a/branches/SelfCupExecChecker/OMakefile b/branches/SelfCupExecChecker/OMakefile deleted file mode 100644 index 26a88d5..0000000 --- a/branches/SelfCupExecChecker/OMakefile +++ /dev/null @@ -1,47 +0,0 @@ -#!/usr/bin/env omake -#---------------------------------------------------------------------------- -# Project: Horizon -# File: OMakefile -# -# Copyright (C)2009 Nintendo Co., Ltd. All rights reserved. -# -# These coded instructions, statements, and computer programs contain -# proprietary information of Nintendo of America Inc. and/or Nintendo -# Company Ltd., and are protected by Federal copyright law. They may -# not be disclosed to third parties or copied or duplicated in any form, -# in whole or in part, without the prior written consent of Nintendo. -# -# $Rev$ -#---------------------------------------------------------------------------- -CTR_APPTYPE=CARD - -SUPPORTED_TARGETS = CTR-T*.Process.MPCore.* - -SAMPLED_DEMOS_COMMON_INCLUDE_DIR = $(dir $(HORIZON_ROOT)/../CTR/SampleDemos/common/include) -INCLUDES += $(SAMPLED_DEMOS_COMMON_INCLUDE_DIR) - -SOURCES[] = - main.cpp - scrollBuffer.cpp - VersionDetect.cpp - HeapManager.cpp - -LIBS += lib_demo \ - libnn_am \ - libnn_cup \ - libnn_ns \ - -ROMFS_ROOT = romfiles - -DESCRIPTOR = $(HORIZON_ROOT)/resources/specfiles/SelfCup.desc - -TARGET_PROGRAM = SelfCupTool - -TITLE = SelfCupTool -ROM_SPEC_FILE = SelfCupTool.rsf - -CTR_BANNER_SPEC = $(TARGET_PROGRAM).bsf - -include $(ROOT_OMAKE)/modulerules - -build: $(DEFAULT_TARGETS) diff --git a/branches/SelfCupExecChecker/OMakeroot b/branches/SelfCupExecChecker/OMakeroot deleted file mode 100644 index 7ee1cb5..0000000 --- a/branches/SelfCupExecChecker/OMakeroot +++ /dev/null @@ -1,73 +0,0 @@ -#!/usr/bin/env omake -#---------------------------------------------------------------------------- -# Project: Horizon -# File: OMakeroot -# -# Copyright (C)2009 Nintendo Co., Ltd. All rights reserved. -# -# These coded instructions, statements, and computer programs contain -# proprietary information of Nintendo of America Inc. and/or Nintendo -# Company Ltd., and are protected by Federal copyright law. They may -# not be disclosed to third parties or copied or duplicated in any form, -# in whole or in part, without the prior written consent of Nintendo. -# -# $Rev:$ -#---------------------------------------------------------------------------- - -# fBNgCAEgɂ‚Ă̐ -# -# a) \[XR[h[gfBNgɔzuꍇ -# : -# /OMakeroot -# /foo/bar/OMakefile -# -# : -# OMakefile ƓfBNgȉ objects images ܂B -# -# /foo/bar/objects/... -# /foo/bar/images/.. -# -# -# b) \[XR[h sources ȉɔzuꍇ -# : -# /OMakeroot -# /sources/foo/bar/OMakefile -# -# : -# [gfBNgȉ objects images ܂B -# -# /objects/foo/bar/... -# /images/foo/bar/... -# -# - -# [g‹ϐ̎擾 -public.HORIZON_ROOT = -if $(defined-env HORIZON_ROOT) - HORIZON_ROOT = $(absname $(getenv HORIZON_ROOT)) - export - -if $(defined-env CTRSDK_ROOT) - CTRSDK_ROOT = $(absname $(getenv CTRSDK_ROOT)) - if $(and $(defined-env HORIZON_ROOT), $(not $(equal $(HORIZON_ROOT), $(CTRSDK_ROOT)))) - eprintln(HORIZON_ROOT CTRSDK_ROOT v܂BpXݒ肷邩Aǂ炩`ĉB) - exit(1) - HORIZON_ROOT = $(CTRSDK_ROOT) - export - -if $(not $(HORIZON_ROOT)) - eprintln($"$$CTRSDK_ROOT `Ă܂") - exit(1) - -include $(HORIZON_ROOT)/build/omake/commondefs - -DefineCommandVars() - -.PHONY: all build clean clobber -.PHONY: run run-scripts run-emumem - -# -# OMakefile ̓ǂݍ -# -.SUBDIRS: . - diff --git a/branches/SelfCupExecChecker/Readme.txt b/branches/SelfCupExecChecker/Readme.txt deleted file mode 100644 index 01dd48d..0000000 --- a/branches/SelfCupExecChecker/Readme.txt +++ /dev/null @@ -1,4 +0,0 @@ -rh‹ -ESDK - Horizon 2.3 branch r38025 + r38091 SelfCup.desc - + trunk r38944 pl_SharedDataTitleId.h diff --git a/branches/SelfCupExecChecker/SelfCupTool.bsf b/branches/SelfCupExecChecker/SelfCupTool.bsf deleted file mode 100644 index 104a94d..0000000 Binary files a/branches/SelfCupExecChecker/SelfCupTool.bsf and /dev/null differ diff --git a/branches/SelfCupExecChecker/SelfCupTool.rsf b/branches/SelfCupExecChecker/SelfCupTool.rsf deleted file mode 100644 index 4a361c9..0000000 --- a/branches/SelfCupExecChecker/SelfCupTool.rsf +++ /dev/null @@ -1,26 +0,0 @@ -BasicInfo: - Title: SelfCupTool - ProductCode: CTR-P-234A - BackupMemoryType: None - Logo: Nintendo - -CardInfo: - CardDevice: None - -TitleInfo: - Use: Evaluation - UniqueId: 0xf802a - Version: 0 - -SystemControlInfo: - AppType : Application - StackSize : 65536 - Dependency: - - nwm - - socket - - ssl - - friends - - ac - - cecd - - boss - - ndm diff --git a/branches/SelfCupExecChecker/VersionDetect.cpp b/branches/SelfCupExecChecker/VersionDetect.cpp deleted file mode 100644 index 0204041..0000000 --- a/branches/SelfCupExecChecker/VersionDetect.cpp +++ /dev/null @@ -1,67 +0,0 @@ -/*---------------------------------------------------------------------------* - Project: Horizon - File: VersionDetect.cpp - - Copyright 2009 Nintendo. All rights reserved. - - These coded instructions, statements, and computer programs contain - proprietary information of Nintendo of America Inc. and/or Nintendo - Company Ltd., and are protected by Federal copyright law. They may - not be disclosed to third parties or copied or duplicated in any form, - in whole or in part, without the prior written consent of Nintendo. - - $Rev$ - *---------------------------------------------------------------------------*/ - -#include -#include -#include - -#include "VersionDetect.h" -#include "HeapManager.h" - -void GetNupVersion(nn::pl::CTR::NetworkUpdateVersion* nup, nn::cfg::CTR::CfgRegionCode region) -{ - nn::Result result; - const size_t BUF_SIZE = 1024; - u8 buf[BUF_SIZE]; - - // NUPバージョン - { - result = nn::fs::MountContent("nver:", nn::fs::MEDIA_TYPE_NAND, cNupVerId[region], 0, 1, 1, buf, - BUF_SIZE); - - nn::fs::FileInputStream fis; - - result = fis.TryInitialize(L"nver:/version.bin"); - if (result.IsSuccess()) - { - s64 fileSize = fis.GetSize(); - NN_LOG("version.bin size = %lld\n", fileSize); - s32 ret; - void* addr = NULL; - HeapManager heap(fileSize); - addr = heap.GetAddr(); - if (addr != NULL) - { - result = fis.TryRead(&ret, addr, fileSize); - if (result.IsSuccess()) - { - nn::pl::CTR::NetworkUpdateVersion* ver_buf = - reinterpret_cast (addr); - - std::memcpy(nup, ver_buf, sizeof(nn::pl::CTR::NetworkUpdateVersion)); - } - } - } - - fis.Finalize(); - nn::fs::Unmount("nver:"); - } - -} - -void GetSystemVersion(VerDef* mVerData, nn::cfg::CTR::CfgRegionCode region) -{ - GetNupVersion(&mVerData->nup, region); -} diff --git a/branches/SelfCupExecChecker/VersionDetect.h b/branches/SelfCupExecChecker/VersionDetect.h deleted file mode 100644 index 7f94174..0000000 --- a/branches/SelfCupExecChecker/VersionDetect.h +++ /dev/null @@ -1,55 +0,0 @@ -/*---------------------------------------------------------------------------* - Project: Horizon - File: VersionDetect.h - - Copyright 2009 Nintendo. All rights reserved. - - These coded instructions, statements, and computer programs contain - proprietary information of Nintendo of America Inc. and/or Nintendo - Company Ltd., and are protected by Federal copyright law. They may - not be disclosed to third parties or copied or duplicated in any form, - in whole or in part, without the prior written consent of Nintendo. - - $Rev$ - *---------------------------------------------------------------------------*/ - -#ifndef VERSIONDETECT_H_ -#define VERSIONDETECT_H_ - -#include -#include -#include - -struct VerDef -{ - nn::pl::CTR::CardUpdateVersion cup; - nn::pl::CTR::NetworkUpdateVersion nup; -}; - -// TODO:リージョン追加時に範囲外アクセスにならないよう注意 -const nn::ProgramId cCupVerId[] = -{ - nn::pl::CTR::SHAREDDATA_TITLEID_CUP_VERSION_JP, - nn::pl::CTR::SHAREDDATA_TITLEID_CUP_VERSION_US, - nn::pl::CTR::SHAREDDATA_TITLEID_CUP_VERSION_EU, - nn::pl::CTR::SHAREDDATA_TITLEID_CUP_VERSION_EU, - nn::pl::CTR::SHAREDDATA_TITLEID_CUP_VERSION_CN, - nn::pl::CTR::SHAREDDATA_TITLEID_CUP_VERSION_KR, - nn::pl::CTR::SHAREDDATA_TITLEID_CUP_VERSION_TW, -}; - -const nn::ProgramId cNupVerId[] = -{ - nn::pl::CTR::SHAREDDATA_TITLEID_NUP_VERSION_JP, - nn::pl::CTR::SHAREDDATA_TITLEID_NUP_VERSION_US, - nn::pl::CTR::SHAREDDATA_TITLEID_NUP_VERSION_EU, - nn::pl::CTR::SHAREDDATA_TITLEID_NUP_VERSION_EU, - nn::pl::CTR::SHAREDDATA_TITLEID_NUP_VERSION_CN, - nn::pl::CTR::SHAREDDATA_TITLEID_NUP_VERSION_KR, - nn::pl::CTR::SHAREDDATA_TITLEID_NUP_VERSION_TW, -}; - -// リージョンコードに基づいてバージョン情報を取得する -void GetSystemVersion(VerDef* mVerData, nn::cfg::CTR::CfgRegionCode region); - -#endif /* VERSIONDETECT_H_ */ diff --git a/branches/SelfCupExecChecker/banner/model.cbmd b/branches/SelfCupExecChecker/banner/model.cbmd deleted file mode 100644 index f1c7b62..0000000 Binary files a/branches/SelfCupExecChecker/banner/model.cbmd and /dev/null differ diff --git a/branches/SelfCupExecChecker/banner/sound.cbsd b/branches/SelfCupExecChecker/banner/sound.cbsd deleted file mode 100644 index f1c7b62..0000000 Binary files a/branches/SelfCupExecChecker/banner/sound.cbsd and /dev/null differ diff --git a/branches/SelfCupExecChecker/banner/unknown24x24.ctpk b/branches/SelfCupExecChecker/banner/unknown24x24.ctpk deleted file mode 100644 index 794b136..0000000 --- a/branches/SelfCupExecChecker/banner/unknown24x24.ctpk +++ /dev/null @@ -1 +0,0 @@ -888yyYyYyyyYyyYyyyyYyYy8 \ No newline at end of file diff --git a/branches/SelfCupExecChecker/banner/unknown48x48.ctpk b/branches/SelfCupExecChecker/banner/unknown48x48.ctpk deleted file mode 100644 index 8c7da16..0000000 --- a/branches/SelfCupExecChecker/banner/unknown48x48.ctpk +++ /dev/null @@ -1 +0,0 @@ -Y8888ƺ8888YYyyYYޚ޺yY8YyYYޚyY8ޚ8 \ No newline at end of file diff --git a/branches/SelfCupExecChecker/main.cpp b/branches/SelfCupExecChecker/main.cpp deleted file mode 100644 index c97922c..0000000 --- a/branches/SelfCupExecChecker/main.cpp +++ /dev/null @@ -1,358 +0,0 @@ -/*---------------------------------------------------------------------------* - Project: Horizon - File: main.cpp - - Copyright (C)2009 Nintendo Co., Ltd. All rights reserved. - - These coded instructions, statements, and computer programs contain - proprietary information of Nintendo of America Inc. and/or Nintendo - Company Ltd., and are protected by Federal copyright law. They may - not be disclosed to third parties or copied or duplicated in any form, - in whole or in part, without the prior written consent of Nintendo. - - $Rev$ - *---------------------------------------------------------------------------*/ - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include - -#include "demo.h" -#include "scrollBuffer.h" -#include "VersionDetect.h" -#include "HeapManager.h" - -namespace -{ -const s32 s_GxHeapSize = 0x800000; -uptr s_GxHeap; - -demo::RenderSystemDrawing s_RenderSystem; -ScrollBuffer s_scrollBufferInstance; -ScrollBuffer *s_scrollBuffer; - -char s_updaterBuffer[1 << 20] NN_ATTRIBUTE_ALIGN(4096); - -// デモの初期化 -void Initialize() -{ - // NuiShellの初期化 (CUPに必須) - NN_UTIL_PANIC_IF_FAILED(nn::ns::CTR::InitializeForShell()); - - // ndmの初期化 - nn::ndm::Initialize(); - - // 全デーモンの自律動作をacの自動接続も含めて止める - nn::ndm::SuspendScheduler(); - - // amの初期化 - nn::am::InitializeForSystemMenu(); - - // fsの初期化 (カード確認用) - nn::fs::Initialize(); - - // appletの初期化 - //nn::applet::InitializeForSystem( nn::applet::PHOME_MENU_APPLET_ID, nn::applet::TYPE_SYS ); - //nn::applet::Initialize( nn::applet::TEST2_APPLET_ID); - //nn::applet::SetAppletMode(); - nn::applet::Enable(); - - nn::cfg::Initialize(); - - // デバイスメモリの設定 - const s32 DEVICE_MEMORY_SIZE = 32 * 1024 * 1024; - NN_UTIL_PANIC_IF_FAILED(nn::os::SetDeviceMemorySize(DEVICE_MEMORY_SIZE)); - - // ヒープの初期化 - InitializeHeap(); - - // 描画インスタンスの初期化 - s_GxHeap = reinterpret_cast(ForceAllocate(s_GxHeapSize));s_RenderSystem - .Initialize(s_GxHeap, s_GxHeapSize); - - // 描画インスタンスの初期化 - s_scrollBufferInstance.Initialize(&s_RenderSystem); - s_scrollBuffer = &s_scrollBufferInstance; - - // GPU利用宣言 - nn::applet::AssignGpuRight(); -} - -// 消費時間取得用関数群 -s64 s_StartTick; -void SetTick() -{ - s_StartTick = nn::os::Tick::GetSystemCurrent(); -} -s64 GetConsumedMillisec() -{ - s64 endTick = nn::os::Tick::GetSystemCurrent(); - nn::os::Tick consumed(endTick - s_StartTick); - return ((nn::fnd::TimeSpan) consumed).GetMilliSeconds(); -} - -// 動いていることを知らせるための、くるくる画面表示取得用メソッド -const char s_progress[] = "-\\|/"; -s32 s_progressIndex = 0; -char GetProgressChar() -{ - s_progressIndex = (s_progressIndex + 1) % (sizeof(s_progress) - 1); - return s_progress[s_progressIndex]; -} - -nn::Result UpdateCore() -{ - nn::Result result; - nn::cup::ProgressInfo info; - - /********************** アップデート*******************/ - SetTick(); - s_scrollBuffer->AppendText("Start Card Update")->Render(); - NN_UTIL_RETURN_IF_FAILED(nn::cup::CTR::DoUpdate()); - - // ステータスがStartedになるまで、プログレスは取得できない - s_scrollBuffer->AppendText(""); - do - { - s_scrollBuffer->ReplaceText(" %c Initializing", GetProgressChar())->Render(); - result = nn::cup::CTR::GetProgressInfo(&info); - NN_UTIL_RETURN_IF_FAILED(result); - nn::os::Thread::Sleep(nn::fnd::TimeSpan::FromMilliSeconds(40)); - } while (info.state == nn::cup::CTR::UPDATE_STATE_INITIALIZING); - - // 抜けた際のstateがFAILEDかどうか確認 - if (info.state == nn::cup::CTR::UPDATE_STATE_FAILED) - { - NN_UTIL_RETURN_IF_FAILED(info.lastResult); - } - s_scrollBuffer->ReplaceText(" - Initialized (%lldmsec)", GetConsumedMillisec()); - - /********************* アップデート中 ******************/ - SetTick(); - s_scrollBuffer->AppendText("")->Render(); - do - { - result = nn::cup::CTR::GetProgressInfo(&info); - NN_UTIL_RETURN_IF_FAILED(result); - s_scrollBuffer->ReplaceText(" %c Title %d/%d, size %lld/%lld", GetProgressChar(), info.numImportedTitles, - info.numTotalTitles, info.importedSize, info.totalSize)->Render(); - nn::os::Thread::Sleep(nn::fnd::TimeSpan::FromMilliSeconds(40)); - - } while (info.state == nn::cup::CTR::UPDATE_STATE_STARTED); - // 抜けた際のstateがFAILEDかどうか確認 - if (info.state == nn::cup::CTR::UPDATE_STATE_FAILED) - { - NN_UTIL_RETURN_IF_FAILED(info.lastResult); - } - s_scrollBuffer->AppendText(" - Imported (%lldmsec)", GetConsumedMillisec())->Render(); - - /***************** アップデート終了中 ******************/ - SetTick(); - s_scrollBuffer->AppendText("")->Render(); - do - { - result = nn::cup::CTR::GetProgressInfo(&info); - NN_UTIL_RETURN_IF_FAILED(result); - s_scrollBuffer->ReplaceText(" %c Update Finalizing", GetProgressChar())->Render(); - nn::os::Thread::Sleep(nn::fnd::TimeSpan::FromMilliSeconds(40)); - } while (info.state == nn::cup::CTR::UPDATE_STATE_FINALIZING); - // 抜けた際のstateがFAILEDかどうか確認 - if (info.state == nn::cup::CTR::UPDATE_STATE_FAILED) - { - NN_UTIL_RETURN_IF_FAILED(info.lastResult); - } - - /******************* アップデート終了 *******************/ - s_scrollBuffer->AppendText(" - Finalized (%lldmsec)", GetConsumedMillisec())->Render(); - s_scrollBuffer->AppendText(""); - - return nn::ResultSuccess(); -} - -nn::Result UpdateSequence(bool *isHandledError) -{ - nn::Result result; - nn::Result lastResult = nn::ResultSuccess(); - - /********************* CUPの初期化 *******************/ - s_scrollBuffer->AppendText("Initializing Cup Library")->Render(); - SetTick(); // 初期化開始前の時間をセット - result = nn::cup::CTR::Initialize(s_updaterBuffer, sizeof(s_updaterBuffer)); - if (result == nn::cup::CTR::ResultUpdatePartitionNotFound()) - { - s_scrollBuffer->AppendText(" - Update Partition Not Found (%lldmsec)", GetConsumedMillisec())->Render(); - s_scrollBuffer->AppendText("")->Render(); - *isHandledError = true; - return result; - } - if (result == nn::cup::CTR::ResultUpdateNotRequired()) - { - s_scrollBuffer->AppendText(" - Already Updated (%lldmsec)", GetConsumedMillisec())->Render(); - s_scrollBuffer->AppendText("")->Render(); - *isHandledError = true; - return result; - } - if (result == nn::cup::CTR::ResultInvalidUpdatePartitionFormat()) - { - s_scrollBuffer->AppendText(" - Invalid Update Partition (%lldmsec)", GetConsumedMillisec())->Render(); - s_scrollBuffer->AppendText("")->Render(); - *isHandledError = true; - return result; - }NN_UTIL_RETURN_IF_FAILED(result); - - s_scrollBuffer->AppendText(" - Need Update (%lldmsec)", GetConsumedMillisec())->Render(); - s_scrollBuffer->AppendText("")->Render(); - - lastResult = UpdateCore(); - - // Initializeに成功した場合のみ、再びInitializeするためにFinalizeが必要 - SetTick(); - s_scrollBuffer->AppendText("Finalizing Cup Library")->Render(); - NN_UTIL_RETURN_IF_FAILED(nn::cup::CTR::Finalize()); - s_scrollBuffer->AppendText(" - Complete (%lldmsec)", GetConsumedMillisec())->Render(); - s_scrollBuffer->AppendText("")->Render(); - - return lastResult; -} -} - -nn::Result ExecuteCup(ScrollBuffer* scrollBuf) -{ - nn::Result result; - bool isHandledError = false; - result = UpdateSequence(&isHandledError); - if (isHandledError == false && result.IsFailure()) - { - { - // それ以外の場合は、Resultを表示 - scrollBuf->AppendText(" - Unhandled Error: 0x%08x", result.GetPrintableBits()); - scrollBuf->AppendText("")->Render(); - } - } - - return result; -} - -extern "C" void nnMain() -{ - NN_LOG("Start cup demo\n"); - nn::Result result; - Initialize(); - - nn::ProgramId MMEN_PROGRAM_ID = 0x0004003000008202; - - nn::cfg::CfgRegionCode region = nn::cfg::GetRegion(); - switch (region) - { - case nn::cfg::CFG_REGION_AMERICA: - { - MMEN_PROGRAM_ID = 0x0004003000008f02; - } - break; - - case nn::cfg::CFG_REGION_EUROPE: - case nn::cfg::CFG_REGION_AUSTRALIA: - { - MMEN_PROGRAM_ID = 0x0004003000009802; - } - break; - - case nn::cfg::CFG_REGION_JAPAN: - { - MMEN_PROGRAM_ID = 0x0004003000008202; - } - break; - } - - nn::am::ProgramInfo outInfos; - result = nn::am::GetProgramInfos(&outInfos, nn::fs::MEDIA_TYPE_NAND, &MMEN_PROGRAM_ID, 1); - if (result.IsSuccess()) - { - result = ExecuteCup(s_scrollBuffer); - // CUP不要だがNUPバージョンのほうが新しかったら強制的に実行 - if (result == nn::cup::CTR::ResultUpdateNotRequired()) - { - // バージョンの取得 - VerDef versionData; - GetSystemVersion(&versionData, region); - - const size_t ROMFS_BUFFER_SIZE = 1024 * 32; - u8 buffer[ROMFS_BUFFER_SIZE]; - result = nn::fs::MountRom(16, 16, buffer, ROMFS_BUFFER_SIZE); - if (result.IsSuccess()) - { - nn::fs::FileReader fileReader; - result = fileReader.TryInitialize("rom:/nup_version.bin"); - if (result.IsSuccess()) - { - u8 buf[1024]; - s32 readSize; - result = fileReader.TryRead(&readSize, buf, sizeof(buf)); - if (result.IsSuccess()) - { - if (versionData.nup.majorVersion < *reinterpret_cast(buf)) - { - // CUPバージョンを削除 - result = nn::am::DeleteProgram(nn::fs::MEDIA_TYPE_NAND, cCupVerId[region]); - if (result.IsSuccess()) - { - result = ExecuteCup(s_scrollBuffer); - } - } - } - } - } - } - } - else if (result == nn::am::ResultNotFound()) - { - s_scrollBuffer->AppendText("Cannot find Home Menu"); - } - - s_scrollBuffer->AppendText("")->Render(); - - for (;;) - { - s_RenderSystem.SetRenderTarget(NN_GX_DISPLAY0); - if (result.IsSuccess() || result == nn::cup::CTR::ResultUpdateNotRequired()) - { - s_RenderSystem.SetClearColor(NN_GX_DISPLAY0, 0, 1, 0, 1); - } - else - { - s_RenderSystem.SetClearColor(NN_GX_DISPLAY0, 1, 0, 0, 1); - } - s_RenderSystem.Clear(); - s_RenderSystem.SwapBuffers(); - s_RenderSystem.SetRenderTarget(NN_GX_DISPLAY1); - if (result.IsSuccess() || result == nn::cup::CTR::ResultUpdateNotRequired()) - { - s_RenderSystem.SetClearColor(NN_GX_DISPLAY1, 0, 1, 0, 1); - } - else - { - s_RenderSystem.SetClearColor(NN_GX_DISPLAY1, 1, 0, 0, 1); - } - s_scrollBuffer->ReplaceText("%c Finished", GetProgressChar())->Render(); - - if (nn::applet::IsExpectedToCloseApplication()) - { - nn::applet::PrepareToCloseApplication(); - nn::applet::CloseApplication(); - } - - } -} diff --git a/branches/SelfCupExecChecker/romfiles/nup_version.bin b/branches/SelfCupExecChecker/romfiles/nup_version.bin deleted file mode 100644 index 45a8ca0..0000000 --- a/branches/SelfCupExecChecker/romfiles/nup_version.bin +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/branches/SelfCupExecChecker/scrollBuffer.cpp b/branches/SelfCupExecChecker/scrollBuffer.cpp deleted file mode 100644 index 54de11e..0000000 --- a/branches/SelfCupExecChecker/scrollBuffer.cpp +++ /dev/null @@ -1,89 +0,0 @@ -/*---------------------------------------------------------------------------* - Project: Horizon - File: scrollBuffer.cpp - - Copyright (C)2009 Nintendo Co., Ltd. All rights reserved. - - These coded instructions, statements, and computer programs contain - proprietary information of Nintendo of America Inc. and/or Nintendo - Company Ltd., and are protected by Federal copyright law. They may - not be disclosed to third parties or copied or duplicated in any form, - in whole or in part, without the prior written consent of Nintendo. - - $Rev$ - *---------------------------------------------------------------------------*/ - -#include -#include "scrollBuffer.h" - -using namespace std; - -char ScrollBuffer::s_buffers[MAX_BUFFER_LINE][MAX_BUFFER_CHARS]; - -char *ScrollBuffer::GetFormattedString(const char *fmt, va_list arg) -{ - static char formattedBuffer[MAX_BUFFER_CHARS]; - vsnprintf(formattedBuffer, MAX_BUFFER_CHARS, fmt, arg); - return formattedBuffer; -} - -ScrollBuffer *ScrollBuffer::Update() -{ - return this; -} - -ScrollBuffer *ScrollBuffer::AppendText(const char *fmt, ...) -{ - va_list vlist; - va_start(vlist, fmt); - - int nextPosition=(m_tail+1)%MAX_BUFFER_LINE; - if(nextPosition==m_head){ - // ヘッドとビューの移動 - if(m_head==m_currentView){ - m_currentView=(m_head+1)%MAX_BUFFER_LINE; - } - m_head=(m_head+1)%MAX_BUFFER_LINE; - - } - strlcpy(s_buffers[m_tail], GetFormattedString(fmt, vlist), MAX_BUFFER_CHARS); - m_tail=nextPosition; - NN_LOG("cup: %s\n", GetFormattedString(fmt, vlist)); - - // ビューの移動 - if((m_currentView+MAX_DISPLAY_LINES)%MAX_BUFFER_LINE==m_tail){ - m_currentView=(m_currentView+1)%MAX_BUFFER_LINE; - } - - return this; -} -ScrollBuffer *ScrollBuffer::ReplaceText(const char *fmt, ...) -{ - va_list vlist; - va_start(vlist, fmt); - - NN_ASSERT(m_tail!=m_head); - strlcpy(s_buffers[(m_tail-1)%MAX_BUFFER_LINE], GetFormattedString(fmt, vlist), MAX_BUFFER_CHARS); - - return this; -} - -void ScrollBuffer::Render() -{ - // 描画前処理 - m_render->SetRenderTarget(NN_GX_DISPLAY1); - m_render->Clear(); - m_render->SetColor(1.0f, 1.0f, 1.0f, 1.0f); - - // リングバッファなので、終端条件を調整 - int tail=(m_tailDrawText(0, (i-m_currentView)*FONT_SIZE, s_buffers[i%MAX_BUFFER_LINE]); - } - } - - // 描画転送 - m_render->SwapBuffers(); -} diff --git a/branches/SelfCupExecChecker/scrollBuffer.h b/branches/SelfCupExecChecker/scrollBuffer.h deleted file mode 100644 index 1d3563a..0000000 --- a/branches/SelfCupExecChecker/scrollBuffer.h +++ /dev/null @@ -1,55 +0,0 @@ -/*---------------------------------------------------------------------------* - Project: Horizon - File: scrollBuffer.h - - Copyright (C)2009 Nintendo Co., Ltd. All rights reserved. - - These coded instructions, statements, and computer programs contain - proprietary information of Nintendo of America Inc. and/or Nintendo - Company Ltd., and are protected by Federal copyright law. They may - not be disclosed to third parties or copied or duplicated in any form, - in whole or in part, without the prior written consent of Nintendo. - - $Rev$ - *---------------------------------------------------------------------------*/ - -#ifndef SCROLL_BUFFER_H_ -#define SCROLL_BUFFER_H_ - -#include "demo.h" -class ScrollBuffer -{ -private: - enum - { - MAX_BUFFER_LINE=128, - MAX_BUFFER_CHARS=80, - MAX_DISPLAY_LINES=20, - FONT_SIZE=12 - }; - // 表示文字のバッファ (リングバッファ) - static char s_buffers[MAX_BUFFER_LINE][MAX_BUFFER_CHARS]; - int m_head; - int m_tail; - int m_currentView; - - demo::RenderSystemDrawing *m_render; - - char *GetFormattedString(const char *fmt, va_list arg); - -public: - ScrollBuffer() : - m_head(0), m_tail(0), m_currentView(0) - {} - void Initialize(demo::RenderSystemDrawing *render) - { - m_render=render; - } - - ScrollBuffer *Update(); // キー入力を参照して、スクロールする - ScrollBuffer *AppendText(const char *fmt, ...); // 文字列を追加する - ScrollBuffer *ReplaceText(const char *fmt, ...); // 最新の文字列を置換する - void Render(); // レンダリング -}; - -#endif // SCROLL_BUFFER_H