TwlIPL/build/systemMenu_RED/Launcher/ARM9/src/main.c
nakasima 25afc40222 シャッター音専用DSPライブラリの削除に対応。
git-svn-id: file:///Users/lillianskinner/Downloads/platinum/twl/TwlIPL/trunk@1869 b08762b0-b915-fc4b-9d8c-17b2551a87ff
2008-07-14 05:07:13 +00:00

703 lines
21 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*---------------------------------------------------------------------------*
Project: TwlIPL
File: main.c
Copyright 2007 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.
$Date:: $
$Rev$
$Author$
*---------------------------------------------------------------------------*/
#include <twl.h>
#include <twl/dsp.h>
#include <twl/dsp/common/g711.h>
#include <twl/camera.h>
#include <sysmenu/errorLog.h>
#include "launcher.h"
#include "misc.h"
#include "logoDemo.h"
#include "sound.h"
#include "loadWlanFirm.h"
#include "loadSharedFont.h"
#include "loadSysmVersion.h"
#include "scanWDS.h"
// extern data-----------------------------------------------------------------
// define data-----------------------------------------------------------------
#define INIT_DEVICES_LIKE_UIG_LAUNCHER
#define MEASURE_TIME 1
// function's prototype-------------------------------------------------------
static void INTR_VBlank( void );
static void deleteTmp();
void SYSM_DeleteTempDirectory( TitleProperty *pBootTitle );
static BOOL IsCommandSelected(void);
static void PrintPause(void);
static void PrintError(void);
// global variable-------------------------------------------------------------
// static variable-------------------------------------------------------------
static TitleProperty *sp_titleList;
static u64 s_strmThreadStack[THREAD_STACK_SIZE / sizeof(u64)];
static OSThread s_strmThread;
static StreamInfo s_strm; // stream info
// const data------------------------------------------------------------------
const char filename[] = "data/fanfare.32.wav";
static const char *fatal_error_msg[FATAL_ERROR_MAX] =
{
"UNDEFINED",
"NAND",
"HWINFO_NORMAL",
"HWINFO_SECURE",
"TWLSETTINGS",
"SHARED_FONT",
"WLANFIRM_AUTH",
"WLANFIRM_LOAD",
"TITLE_LOAD_FAILED",
"TITLE_POINTER_ERROR",
"AUTHENTICATE_FAILED",
"ENTRY_ADDRESS_ERROR",
"TITLE_BOOTTYPE_ERROR",
"SIGN_DECRYPTION_FAILED",
"SIGN_COMPARE_FAILED",
"HEADER_HASH_CALC_FAILED",
"TITLEID_COMPARE_FAILED",
"VALID_SIGN_FLAG_OFF",
"CHECK_TITLE_LAUNCH_RIGHTS_FAILED",
"MODULE_HASH_CHECK_FAILED",
"MODULE_HASH_CALC_FAILED",
"MEDIA_CHECK_FAILED",
"DL_MAGICCODE_CHECK_FAILED",
"DL_SIGN_DECRYPTION_FAILED",
"DL_HASH_CALC_FAILED",
"DL_SIGN_COMPARE_FAILED",
"WHITELIST_INITDB_FAILED",
"WHITELIST_NOTFOUND",
"DHT_PHASE1_FAILED",
"DHT_PHASE2_FAILED",
"LANDING_TMP_JUMP_FLAG_OFF",
"TWL_BOOTTYPE_UNKNOWN",
"NTR_BOOTTYPE_UNKNOWN",
"PLATFORM_UNKNOWN",
"LOAD_UNFINISHED",
"LOAD_OPENFILE_FAILED",
"LOAD_MEMALLOC_FAILED",
"LOAD_SEEKFILE_FAILED",
"LOAD_READHEADER_FAILED",
"LOAD_LOGOCRC_ERROR",
"LOAD_READDLSIGN_FAILED",
"LOAD_RELOCATEINFO_FAILED",
"LOAD_READMODULE_FAILED",
"NINTENDO_LOGO_CHECK_FAILED"
};
//#define DEBUG_LAUNCHER_DUMP
#ifdef DEBUG_LAUNCHER_DUMP
// <20>f<EFBFBD>o<EFBFBD>O<EFBFBD>p<EFBFBD>BSD<53><44>0x02ffc000<30><30><EFBFBD><EFBFBD>0x02ffe000<30>܂<EFBFBD>dump.dat<61>Ƃ<EFBFBD><C682><EFBFBD><EFBFBD>_<EFBFBD><5F><EFBFBD>v<EFBFBD><76><EFBFBD>f<EFBFBD><66>
static void debugWriteToSD( void )
{
FSFile dest;
FS_InitFile( &dest );
(void)FS_CreateFile("sdmc:/dump.dat", FS_PERMIT_W | FS_PERMIT_R);
if ( !FS_OpenFileEx( &dest, "sdmc:/dump.dat", FS_FILEMODE_W ) ) return;
FS_WriteFile( &dest, (void *)0x02ffc000, 0x2000 );
if ( !FS_CloseFile( &dest ) ) return;
OS_TPrintf( "debugWriteToSD:ok\n");
}
#endif
#ifdef INIT_DEVICES_LIKE_UIG_LAUNCHER
static int CreateDspSlotBitmap(int slot_num)
{
int i, bitmap;
bitmap = 0;
for (i=0; i<slot_num; i++)
{
bitmap += (1 << i);
}
return bitmap;
}
#endif // INIT_DEVICES_LIKE_UIG_LAUNCHER
// <20><><EFBFBD>C<EFBFBD><43>
void TwlMain( void )
{
enum {
LOGODEMO_INIT = 0,
LOGODEMO = 1,
LAUNCHER_INIT = 2,
LAUNCHER = 3,
LOAD_START = 4,
LOADING = 5,
LOAD_PAUSE = 6,
AUTHENTICATE = 7,
BOOT = 8,
STOP = 9
};
u32 state = LOGODEMO_INIT;
TitleProperty *pBootTitle = NULL;
OSTick allstart, start, end = 0;
BOOL direct_boot = FALSE;
BOOL isStartScanWDS = FALSE;
#ifdef DEBUG_LAUNCHER_DUMP
// you should comment out to clear GX/G2/DMA/TM/PAD register in reboot.c to retreive valid boot time
STD_TSPrintf((char*)0x02FFCFC0, "\nLauncher Boot Time: %lld usec\n", OS_TicksToMicroSeconds(reg_OS_TM3CNT_L * (1024/64)));
STD_TSPrintf((char*)0x02FFCFF0, "HOTSTART(0x%08x): %02x\n", HW_NAND_FIRM_HOTSTART_FLAG, *(u8 *)HW_NAND_FIRM_HOTSTART_FLAG);
#endif
// <20>V<EFBFBD>X<EFBFBD>e<EFBFBD><65><EFBFBD><EFBFBD><EFBFBD>j<EFBFBD><6A><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>----------
SYSM_Init( Alloc, Free ); // OS_Init<69>̑O<CC91>ŃR<C583>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>K<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>B
OS_Init();
SYSM_SetArena(); // OS_Init<69>̌<EFBFBD><CC8C>ŃR<C583>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>K<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>B
// OS<4F><53><EFBFBD><EFBFBD><EFBFBD><EFBFBD>------------------------
OS_InitTick();
// start <20><><EFBFBD>Ԍv<D48C><76>total
#if (MEASURE_TIME == 1)
allstart = OS_GetTick();
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76><EFBFBD>P
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
PM_Init();
(void)OS_EnableIrq();
(void)OS_EnableInterrupts();
SYSM_InitPXI(); // <20><><EFBFBD><EFBFBD>݋<EFBFBD><DD8B>Œ<EFBFBD><C28C>ɃR<C983>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>K<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>B
FS_Init( FS_DMA_NOT_USE );
#ifdef DEBUG_LAUNCHER_DUMP
// debug
debugWriteToSD();
#endif
GX_Init();
PM_Init();
TP_Init();
RTC_Init();
SND_Init();// sound init
#ifdef USE_WRAM_LOAD
HOTSW_Init();
#endif
//NAM<41>̏<EFBFBD><CC8F><EFBFBD><EFBFBD><EFBFBD>
NAM_Init( Alloc, Free );
OS_TPrintf( "SYSM_work size = 0x%x\n", sizeof(SYSM_work) );
// <20><><EFBFBD><EFBFBD>݋<EFBFBD><DD8B><EFBFBD>--------------------
(void)OS_SetIrqFunction(OS_IE_V_BLANK, INTR_VBlank);
(void)OS_EnableIrqMask(OS_IE_V_BLANK);
(void)GX_VBlankIntr(TRUE);
// <20>V<EFBFBD>X<EFBFBD>e<EFBFBD><65><EFBFBD>̏<EFBFBD><CC8F><EFBFBD><EFBFBD><EFBFBD>----------------
InitAllocator(); // <20><>SYSM_Init<69>ȊO<C88A><4F>SYSM<53><4D><EFBFBD>C<EFBFBD>u<EFBFBD><75><EFBFBD><EFBFBD><EFBFBD>֐<EFBFBD><D690><EFBFBD><EFBFBD>ĂԑO<D491><4F>
ErrorLog_Init( Alloc, Free );
// end<6E><64><EFBFBD>Ԍv<D48C><76><EFBFBD>P
#if (MEASURE_TIME == 1)
OS_TPrintf( "System Init Time 1: %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76><EFBFBD>P-b
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
// Alloc, Free<65>œo<C593>^<5E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>A<EFBFBD><41><EFBFBD>P<EFBFBD>[<5B>^<5E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>B
#ifdef INIT_DEVICES_LIKE_UIG_LAUNCHER
// [TODO]<5D>J<EFBFBD><4A><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڑ<EFBFBD><DA91><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882>Ɩ<EFBFBD><C696><EFBFBD><EFBFBD><EFBFBD><EFBFBD>[<5B>v<EFBFBD>ɂȂ<C982><C882>I<EFBFBD>I<EFBFBD><49><EFBFBD>ӁI<D381>I
// <20>J<EFBFBD><4A><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
// CAMERA_Init();
// end<6E><64><EFBFBD>Ԍv<D48C><76><EFBFBD>P-b
#if (MEASURE_TIME == 1)
OS_TPrintf( "Camera Init: %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
#ifdef USE_HYENA_COMPONENT
// DSP<53><50><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
{
FSFile file[1];
MIWramSize sizeB = MI_WRAM_SIZE_32KB;
MIWramSize sizeC = MI_WRAM_SIZE_64KB;
int slotB = CreateDspSlotBitmap( DSP_SLOT_B_COMPONENT_G711 ); // <20>P<EFBFBD>X<EFBFBD><58><EFBFBD>b<EFBFBD>g
int slotC = CreateDspSlotBitmap( DSP_SLOT_C_COMPONENT_G711 ); // <20>Q<EFBFBD>X<EFBFBD><58><EFBFBD>b<EFBFBD>g
MI_FreeWramSlot_B( 0, sizeB, MI_WRAM_ARM9 );
MI_FreeWramSlot_C( 0, sizeC, MI_WRAM_ARM9 );
MI_CancelWramSlot_B( 0, sizeB, MI_WRAM_ARM9 );
MI_CancelWramSlot_C( 0, sizeC, MI_WRAM_ARM9 );
FS_InitFile(file);
DSPi_OpenStaticComponentG711Core(file);
if ( ! DSP_LoadG711(file, slotB, slotC) )
{
OS_TPanic("failed to load G.711 DSP-component! (lack of WRAM-B/C)");
}
DSP_UnloadG711();
}
#endif // USE_HYENA_COMPONENT
#endif // INIT_DEVICES_LIKE_UIG_LAUNCHER
// start<72><74><EFBFBD>Ԍv<D48C><76><EFBFBD>P-c
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
// <20>e<EFBFBD><65><EFBFBD>p<EFBFBD><70><EFBFBD><EFBFBD><EFBFBD>[<5B>^<5E>̎擾------------
pBootTitle = SYSM_ReadParameters(); // <20>{<7B>̐ݒ<CC90><DD92>f<EFBFBD>[<5B>^<5E>AHW<48><57><EFBFBD>񃊁[<5B>h
// <20>A<EFBFBD>v<EFBFBD><76><EFBFBD>W<EFBFBD><57><EFBFBD><EFBFBD><EFBFBD>v<EFBFBD>A<EFBFBD><41><EFBFBD><EFBFBD><EFBFBD>p<EFBFBD>J<EFBFBD>[<5B>h<EFBFBD>N<EFBFBD><4E><EFBFBD>A<EFBFBD><41><EFBFBD>Y<EFBFBD>H<EFBFBD><48><EFBFBD>p<EFBFBD>V<EFBFBD><56><EFBFBD>[<5B>g<EFBFBD>J<EFBFBD>b<EFBFBD>g<EFBFBD>A<EFBFBD>f<EFBFBD>o<EFBFBD>b<EFBFBD>K<EFBFBD>N<EFBFBD><4E><EFBFBD>A<EFBFBD><41><EFBFBD><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD>V<EFBFBD>[<5B>P<EFBFBD><50><EFBFBD>X<EFBFBD>ATP<54>ݒ<EFBFBD><DD92>V<EFBFBD><56><EFBFBD>[<5B>g<EFBFBD>J<EFBFBD>b<EFBFBD>g<EFBFBD>̔<EFBFBD><CC94><EFBFBD>
// TP<54>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>u<EFBFBD><75><EFBFBD>[<5B>V<EFBFBD><56><EFBFBD><EFBFBD>
UTL_CaribrateTP( LCFG_TSD_GetTPCalibrationPtr() );
if( UTL_IsFatalError() ) {
// FATAL<41>G<EFBFBD><47><EFBFBD>[<5B><><EFBFBD><EFBFBD>
PrintError(); // <20>G<EFBFBD><47><EFBFBD>[<5B>\<5C><>
state = STOP;
goto MAIN_LOOP_START; // state <20><> STOP <20>ɂ<EFBFBD><C982>ċ<EFBFBD><C48B><EFBFBD><EFBFBD>I<EFBFBD>Ƀ<EFBFBD><C983>C<EFBFBD><43><EFBFBD><EFBFBD><EFBFBD>[<5B>v<EFBFBD>J<EFBFBD>n
}
if( !LCFG_TSD_IsFinishedInitialSetting_Launcher() ) {
// <20><><EFBFBD><EFBFBD><EFBFBD>`<60><><EFBFBD>[<5B><><EFBFBD>ł̏<C582><CC8F><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD>V<EFBFBD>[<5B>P<EFBFBD><50><EFBFBD>X<EFBFBD><58><EFBFBD>Ȃ<EFBFBD><C882>A<EFBFBD>ʐ^<5E>B<EFBFBD>e<EFBFBD><65><EFBFBD><EFBFBD><EFBFBD>s<EFBFBD><73><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɂ<EFBFBD><C982><EFBFBD><EFBFBD>B
// <20><><EFBFBD>{<7B>̐ݒ<CC90><DD92><EFBFBD><EFBFBD>ł̏<C582><CC8F><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD>V<EFBFBD>[<5B>P<EFBFBD><50><EFBFBD>X<EFBFBD><58><EFBFBD>̏ꍇ<CC8F>́ASYSM_ReadParameters <20><><EFBFBD>̃`<60>F<EFBFBD>b<EFBFBD>N<EFBFBD>Ō<EFBFBD><C58C>o<EFBFBD><6F><EFBFBD><EFBFBD><EFBFBD>āA<C481>{<7B>̐ݒ肪<DD92>N<EFBFBD><4E><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɂȂ<C982><C882>Ă<EFBFBD><C482>܂<EFBFBD><DC82>B
}
// end<6E><64><EFBFBD>Ԍv<D48C><76><EFBFBD>P-c
#if (MEASURE_TIME == 1)
OS_TPrintf( "SYSM_ReadParameters: %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76>4
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
// <20>^<5E>C<EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>g<EFBFBD>̏<EFBFBD><CC8F><EFBFBD>
SYSM_InitTitleList();
// end<6E><64><EFBFBD>Ԍv<D48C><76>4
#if (MEASURE_TIME == 1)
OS_TPrintf( "InitNandTitleList : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76><EFBFBD>Q
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
sp_titleList = SYSM_GetCardTitleList(NULL); // <20>J<EFBFBD>[<5B>h<EFBFBD>A<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>g<EFBFBD>̎擾<CC8E>i<EFBFBD>J<EFBFBD>[<5B>h<EFBFBD>A<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD>sp_titleList[0]<5D>Ɋi<C98A>[<5B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>j
// end<6E><64><EFBFBD>Ԍv<D48C><76><EFBFBD>Q
#if (MEASURE_TIME == 1)
OS_TPrintf( "GetCardTitleList Time : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76>3
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
// TMP<4D>t<EFBFBD>H<EFBFBD><48><EFBFBD>_<EFBFBD>̃N<CC83><4E><EFBFBD>[<5B><>
SYSM_DeleteTmpDirectory( pBootTitle );
// end<6E><64><EFBFBD>Ԍv<D48C><76>3
#if (MEASURE_TIME == 1)
OS_TPrintf( "TmpClean : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76>5
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
// <20>u<EFBFBD>_<EFBFBD>C<EFBFBD><43><EFBFBD>N<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>łȂ<C582><C882>v<EFBFBD>Ȃ<EFBFBD>
if( !pBootTitle ) {
// NAND & <20>J<EFBFBD>[<5B>h<EFBFBD>A<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>g<EFBFBD>
if( !SYSM_IsLogoDemoSkip() )
{
SYSM_MakeNandTitleListAsync(); // NAND<4E>A<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>g<EFBFBD>̍쐬<CC8D>i<EFBFBD><EFBFBD>͂<EFBFBD><CD82>Ă<EFBFBD><C482>Ȃ<EFBFBD><C882>̂Œ<CC82><C592>Ӂj
}else
{
sp_titleList = SYSM_GetNandTitleList();
}
}else
{
if( !pBootTitle->flags.isLogoSkip )
{
SYSM_MakeNandTitleListMakerInfoAsync(); // <09>A<EFBFBD>v<EFBFBD><76><EFBFBD>Ɉ<EFBFBD><C988><EFBFBD><EFBFBD>n<EFBFBD><6E><EFBFBD>^<5E>C<EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>g<EFBFBD><EFBFBD>p<EFBFBD><70><EFBFBD><EFBFBD><EFBFBD>̍쐬
}else
{
SYSM_MakeNandTitleListMakerInfo();
}
}
// end<6E><64><EFBFBD>Ԍv<D48C><76>5
#if (MEASURE_TIME == 1)
OS_TPrintf( "GetNandTitleList : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76>6
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
// <20>u<EFBFBD>_<EFBFBD>C<EFBFBD><43><EFBFBD>N<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>łȂ<C582><C882>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
// <20>u<EFBFBD>_<EFBFBD>C<EFBFBD><43><EFBFBD>N<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD>A<EFBFBD><41><EFBFBD>S<EFBFBD>f<EFBFBD><66><EFBFBD>\<5C><><EFBFBD>v<EFBFBD>̎<EFBFBD><CC8E>A<EFBFBD>e<EFBFBD><EFBFBD>\<5C>[<5B>X<EFBFBD>̃<EFBFBD><CC83>[<5B>h------------
if( !pBootTitle ||
( pBootTitle && !SYSM_IsLogoDemoSkip() ) ) {
u32 timestamp;
if( !LoadSharedFontInit() ) { // <20><><EFBFBD>L<EFBFBD>t<EFBFBD>H<EFBFBD><48><EFBFBD>g<EFBFBD>̃<EFBFBD><CC83>[<5B>h
UTL_SetFatalError( FATAL_ERROR_SHARED_FONT );
}
timestamp = OS_GetSharedFontTimestamp();
if( timestamp > 0 ) OS_TPrintf( "SharedFont timestamp : %08x\n", timestamp );
}
// end<6E><64><EFBFBD>Ԍv<D48C><76>6
#if (MEASURE_TIME == 1)
OS_TPrintf( "GetSharedFont : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// <20><><EFBFBD><EFBFBD><EFBFBD>̃o<CC83>[<5B>W<EFBFBD><57><EFBFBD><EFBFBD><EFBFBD>t<EFBFBD>@<40>C<EFBFBD><43><EFBFBD>ɖ<EFBFBD><C996>Ή<EFBFBD><CE89>Ȃ<EFBFBD><C882>߃R<DF83><52><EFBFBD><EFBFBD><EFBFBD>g<EFBFBD>A<EFBFBD>E<EFBFBD>g
/*
if( LoadSysmVersion() )
{
OS_TPrintf("Launcher Version = %d.%d\n",GetSysmMajorVersion(), GetSysmMinorVersion() );
}
*/
// <20>J<EFBFBD>n<EFBFBD>X<EFBFBD>e<EFBFBD>[<5B>g<EFBFBD>̔<EFBFBD><CC94><EFBFBD>--------------
// start<72><74><EFBFBD>Ԍv<D48C><76>7
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
if( pBootTitle ) {
// <20>_<EFBFBD>C<EFBFBD><43><EFBFBD>N<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>Ȃ<EFBFBD><C882>A<EFBFBD><41><EFBFBD>S<EFBFBD>A<EFBFBD><41><EFBFBD><EFBFBD><EFBFBD>`<60><><EFBFBD>[<5B><><EFBFBD><EFBFBD><EFBFBD>΂<EFBFBD><CE82>ă<EFBFBD><C483>[<5B>h<EFBFBD>J<EFBFBD>n
if( pBootTitle->flags.isLogoSkip ) {
state = LOAD_START;
}else {
state = LOGODEMO_INIT;
}
direct_boot = TRUE;
}else if( SYSM_IsLogoDemoSkip() ) {
// <20><><EFBFBD>S<EFBFBD>f<EFBFBD><66><EFBFBD>X<EFBFBD>L<EFBFBD>b<EFBFBD>v<EFBFBD><76><EFBFBD>w<EFBFBD><EFBFBD><E882B3><EFBFBD>Ă<EFBFBD><C482><EFBFBD><EFBFBD><EFBFBD><EFBFBD>A<EFBFBD><41><EFBFBD><EFBFBD><EFBFBD>`<60><><EFBFBD>[<5B>N<EFBFBD><4E>
state = LAUNCHER_INIT;
}else {
// <20><><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882>Ȃ<EFBFBD><C882>A<EFBFBD><41><EFBFBD>S<EFBFBD>f<EFBFBD><66><EFBFBD>N<EFBFBD><4E>
state = LOGODEMO_INIT;
}
// <20><><EFBFBD><EFBFBD><EFBFBD>`<60><><EFBFBD>[<5B><><EFBFBD>ʂ<EFBFBD><CA82><EFBFBD><EFBFBD>Ε\<5C><><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882>o<EFBFBD>[<5B>W<EFBFBD><57><EFBFBD><EFBFBD>
if( SYSM_IsLauncherHidden() )
{
if(direct_boot == FALSE)
{
state = STOP;
}else
{
state = LOAD_START;
}
}
// <20>`<60><><EFBFBD><EFBFBD><EFBFBD>l<EFBFBD><6C><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>b<EFBFBD>N<EFBFBD><4E><EFBFBD><EFBFBD>
SND_LockChannel((1 << L_CHANNEL) | (1 << R_CHANNEL), 0);
/* <20>X<EFBFBD>g<EFBFBD><67><EFBFBD>[<5B><><EFBFBD>X<EFBFBD><58><EFBFBD>b<EFBFBD>h<EFBFBD>̋N<CC8B><4E> */
OS_CreateThread(&s_strmThread,
StrmThread,
NULL,
s_strmThreadStack + THREAD_STACK_SIZE / sizeof(u64),
THREAD_STACK_SIZE, STREAM_THREAD_PRIO);
OS_WakeupThreadDirect(&s_strmThread);
// end<6E><64><EFBFBD>Ԍv<D48C><76>7
#if (MEASURE_TIME == 1)
OS_TPrintf( "time 7 (etc...) : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
// start<72><74><EFBFBD>Ԍv<D48C><76>8
#if (MEASURE_TIME == 1)
start = OS_GetTick();
#endif
// <20><><EFBFBD><EFBFBD><EFBFBD>t<EFBFBD>@<40>[<5B><><EFBFBD>E<EFBFBD>F<EFBFBD>A<EFBFBD>𖳐<EFBFBD><F096B390><EFBFBD><EFBFBD>W<EFBFBD><57><EFBFBD>[<5B><><EFBFBD>Ƀ_<C983>E<EFBFBD><45><EFBFBD><EFBFBD><EFBFBD>[<5B>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD>B
#ifndef DISABLE_WLFIRM_LOAD
if( FALSE == InstallWlanFirmware( SYSM_IsHotStart() ) ) {
OS_TPrintf( "ERROR: Wireless firmware download failed!\n" );
}
#endif // DISABLE_WLFIRM_LOAD
// end<6E><64><EFBFBD>Ԍv<D48C><76>8
#if (MEASURE_TIME == 1)
OS_TPrintf( "Load WlanFirm Time : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - start ) );
#endif
if( UTL_IsFatalError() ) {
// FATAL<41>G<EFBFBD><47><EFBFBD>[<5B><><EFBFBD><EFBFBD>
PrintError(); // <20>G<EFBFBD><47><EFBFBD>[<5B>\<5C><>
state = STOP;
goto MAIN_LOOP_START; // state <20><> STOP <20>ɂ<EFBFBD><C982>ċ<EFBFBD><C48B><EFBFBD><EFBFBD>I<EFBFBD>Ƀ<EFBFBD><C983>C<EFBFBD><43><EFBFBD><EFBFBD><EFBFBD>[<5B>v<EFBFBD>J<EFBFBD>n
}
// end <20><><EFBFBD>Ԍv<D48C><76>total
#if (MEASURE_TIME == 1)
OS_TPrintf( "Total Time : %dms\n", OS_TicksToMilliSeconds( OS_GetTick() - allstart ) );
#endif
MAIN_LOOP_START:
// <20><><EFBFBD>C<EFBFBD><43><EFBFBD><EFBFBD><EFBFBD>[<5B>v--------------------
while( 1 ) {
OS_WaitIrq(1, OS_IE_V_BLANK); // V<>u<EFBFBD><75><EFBFBD><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD><EFBFBD>ݑ҂<DD91>
// <20>`<60>q<EFBFBD>l<EFBFBD>V<EFBFBD>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD><68><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>M
while (SND_RecvCommandReply(SND_COMMAND_NOBLOCK) != NULL)
{
}
ReadKeyPad(); // <20>L<EFBFBD>[<5B><><EFBFBD>͂̎擾
ReadTP(); // TP<54><50><EFBFBD>͂̎擾
switch( state ) {
case LOGODEMO_INIT:
LogoInit();
// <20><><EFBFBD>‚<C282>e<EFBFBD>X<EFBFBD>g
FS_InitFile(&s_strm.file);
s_strm.isPlay = FALSE;
PlayStream(&s_strm, filename);
state = LOGODEMO;
break;
case LOGODEMO:
if( IsFinishedLoadSharedFont() && // <20>ʏ<EFBFBD><CA8F>u<EFBFBD>[<5B>g<EFBFBD><67><EFBFBD>́A<CD81>t<EFBFBD>H<EFBFBD><48><EFBFBD>g<EFBFBD><67><EFBFBD>[<5B>h<EFBFBD>I<EFBFBD><49><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ń`<60>F<EFBFBD>b<EFBFBD>N
LogoMain() &&
SYSM_isNandTitleListReady() // NAND<4E>^<5E>C<EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD><E693BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ǂ<EFBFBD><C782><EFBFBD><EFBFBD>`<60>F<EFBFBD>b<EFBFBD>N
) {
if( !direct_boot ) {
sp_titleList = SYSM_GetTitlePropertyList();// TitlePropertyList<73>̎擾
state = LAUNCHER_INIT;
}else {
state = LOAD_START;
}
}
break;
case LAUNCHER_INIT:
LauncherInit( NULL );
state = LAUNCHER;
break;
case LAUNCHER:
pBootTitle = LauncherMain( sp_titleList );
if( pBootTitle ) {
state = LOAD_START;
}
break;
case LOAD_START:
if( IsFinishedLoadSharedFont() // <20>_<EFBFBD>C<EFBFBD><43><EFBFBD>N<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>̎<EFBFBD><CC8E>́A<CD81>t<EFBFBD>H<EFBFBD><48><EFBFBD>g<EFBFBD><67><EFBFBD>[<5B>h<EFBFBD>I<EFBFBD><49><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ń`<60>F<EFBFBD>b<EFBFBD>N
#ifndef DISABLE_WLFIRM_LOAD // <20>A<EFBFBD>v<EFBFBD><76><EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>O<EFBFBD>ɖ<EFBFBD><C996><EFBFBD><EFBFBD>t<EFBFBD>@<40>[<5B><><EFBFBD>̃<EFBFBD><CC83>[<5B>h<EFBFBD>͊<EFBFBD><CD8A><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482><EFBFBD>
&& PollingInstallWlanFirmware()
#endif // DISABLE_WLFIRM_LOAD
#ifndef DISABLE_WDS_SCAN // <20>A<EFBFBD>v<EFBFBD><76><EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>O<EFBFBD><4F>WDS<44>X<EFBFBD>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>͏I<CD8F><49><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482><EFBFBD><EFBFBD>K<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
&& ( WDS_WrapperStopScan() != WDSWRAPPER_ERRCODE_OPERATING )
#endif // DISABLE_WLFIRM_LOAD
) {
SYSM_StartLoadTitle( pBootTitle );
state = LOADING;
start = OS_GetTick();
}
break;
case LOADING:
// <20><><EFBFBD><EFBFBD><EFBFBD>Ń<EFBFBD><C583>[<5B>h<EFBFBD>O<EFBFBD>z<EFBFBD><7A><EFBFBD>C<EFBFBD>g<EFBFBD><67><EFBFBD>X<EFBFBD>g<EFBFBD>`<60>F<EFBFBD>b<EFBFBD>N<EFBFBD><4E><EFBFBD>s<EFBFBD><73><EFBFBD>b<EFBFBD>Z<EFBFBD>[<5B>W<EFBFBD><57><EFBFBD>|<7C>[<5B><><EFBFBD><EFBFBD><EFBFBD>O<EFBFBD><4F><EFBFBD>A<EFBFBD>󂯎<EFBFBD><F382AF8E><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>state<74><65>LOAD_PAUSE<53><45>
if( SYSM_IsLoadTitlePaused() )
{
state = LOAD_PAUSE;
PrintPause();
}
if( SYSM_IsLoadTitleFinished() ) {
SYSM_StartAuthenticateTitle( pBootTitle );
state = AUTHENTICATE;
}
if( !direct_boot )
{
(void)LauncherFadeout( sp_titleList ); // <20>_<EFBFBD>C<EFBFBD><43><EFBFBD>N<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>łȂ<C582><C882>Ƃ<EFBFBD><C682>̓t<CD83>F<EFBFBD>[<5B>h<EFBFBD>A<EFBFBD>E<EFBFBD>g<EFBFBD><67><EFBFBD>s<EFBFBD><73>
}
if( ( end == 0 ) &&
SYSM_IsLoadTitleFinished() ) {
end = OS_GetTick();
OS_TPrintf( "Load Time : %dms\n", OS_TicksToMilliSeconds( end - start ) );
}
break;
case LOAD_PAUSE:
// <20><><EFBFBD>[<5B>h<EFBFBD>O<EFBFBD>z<EFBFBD><7A><EFBFBD>C<EFBFBD>g<EFBFBD><67><EFBFBD>X<EFBFBD>g<EFBFBD>`<60>F<EFBFBD>b<EFBFBD>N<EFBFBD><4E><EFBFBD>s<EFBFBD>ňꎞ<C588><EA8E9E><EFBFBD>~<7E><>
// <20><><EFBFBD><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD><EFBFBD><EFBFBD><EFBFBD><E982A9><EFBFBD>~<7E><><EFBFBD><EFBFBD>̑I<CC91><49><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EA82BD>LOADING<4E>ɖ߂<C996>
if( IsCommandSelected() )
{
state = LOADING;
}
break;
case AUTHENTICATE:
if( ( direct_boot || ( !direct_boot && LauncherFadeout( sp_titleList ) ) ) &&
SYSM_IsAuthenticateTitleFinished()
) {
// <20><><EFBFBD>C<EFBFBD><43><EFBFBD><EFBFBD><EFBFBD>[<5B>v<EFBFBD>J<EFBFBD>n<EFBFBD><6E><EFBFBD><EFBFBD>؏I<D88F><49><EFBFBD>܂ł̊ԂɋN<C98B><4E><EFBFBD><EFBFBD>FATAL<41>̏<EFBFBD><CC8F><EFBFBD>
if( UTL_IsFatalError() ) {
// FATAL<41>G<EFBFBD><47><EFBFBD>[<5B><><EFBFBD><EFBFBD>
// [TODO:]<5D>N<EFBFBD><4E><EFBFBD>A<EFBFBD><41><EFBFBD><EFBFBD><EFBFBD>ق<EFBFBD><D982><EFBFBD><EFBFBD>ǂ<EFBFBD><C782>f<EFBFBD>[<5B>^<5E>i<EFBFBD><69><EFBFBD>Ȃǁj<C781><6A><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ώ<EFBFBD><CE8F><EFBFBD>
PrintError(); // <20>G<EFBFBD><47><EFBFBD>[<5B>\<5C><>
state = STOP;
break; // state <20><> STOP <20>ɂ<EFBFBD><C982><EFBFBD> break <20><><EFBFBD>A Boot <20><><EFBFBD><EFBFBD><EFBFBD>Ȃ<EFBFBD>
}
#ifndef DISABLE_WDS_SCAN
// Nintendo<64>X<EFBFBD>|<7C>b<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD><67><EFBFBD>́A<CD81>A<EFBFBD>v<EFBFBD><76><EFBFBD>ԃp<D483><70><EFBFBD><EFBFBD><EFBFBD>[<5B>^<5E>Ƀr<C983>[<5B>R<EFBFBD><52><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Z<EFBFBD>b<EFBFBD>g<EFBFBD><67><EFBFBD><EFBFBD><EFBFBD>B
if( STD_CompareNString( (char *)&pBootTitle->titleID + 1, "JNH", 3 ) == 0 )
{
(void)WDS_WrapperSetArgumentParam();
}
#endif // DISABLE_WDS_SCAN
state = BOOT;
}
break;
case BOOT:
#ifndef DISABLE_WDS_SCAN
// <20>A<EFBFBD>v<EFBFBD><76><EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>O<EFBFBD><4F>WDS<44>X<EFBFBD>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>͏I<CD8F><49><EFBFBD><EFBFBD><EFBFBD>Ă<EFBFBD><C482><EFBFBD><EFBFBD>K<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if( ( WDS_WrapperCleanup() != WDSWRAPPER_ERRCODE_OPERATING ) &&
IsClearnupWDSWrapper() )
#endif // DISABLE_WDS_SCAN
{
SYSM_TryToBootTitle( pBootTitle ); // never return.
}
break;
case STOP: // <20><><EFBFBD>~
break;
}
// <20>J<EFBFBD>[<5B>h<EFBFBD>A<EFBFBD>v<EFBFBD><76><EFBFBD><EFBFBD><EFBFBD>X<EFBFBD>g<EFBFBD>̎擾<CC8E>i<EFBFBD>X<EFBFBD><58><EFBFBD>b<EFBFBD>h<EFBFBD>Ő<EFBFBD><C590><EFBFBD><EFBFBD>J<EFBFBD>[<5B>h<EFBFBD>}<7D><><EFBFBD><EFBFBD><EFBFBD>ʒm<CA92><6D><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̂<EFBFBD><CC82><EFBFBD><EFBFBD>C<EFBFBD><43><EFBFBD><EFBFBD><EFBFBD>[<5B>v<EFBFBD>Ŏ擾<C58E>j
{
BOOL changed;
sp_titleList = SYSM_GetCardTitleList( &changed );
if( changed )
{
OS_TPrintf( "Change CARD status.\n" );
}
}
// <20><><EFBFBD><EFBFBD><EFBFBD>t<EFBFBD>@<40>[<5B><><EFBFBD><EFBFBD><EFBFBD>[<5B>h<EFBFBD>̃|<7C>[<5B><><EFBFBD><EFBFBD><EFBFBD>O
if( PollingInstallWlanFirmware() &&
( GetWlanFirmwareInstallFinalResult() == WLANFIRM_RESULT_SUCCESS ) // <20><><EFBFBD>[<5B>h<EFBFBD><68><EFBFBD><EFBFBD>
) {
// <20><><EFBFBD>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>𖞂<EFBFBD><F0969E82><EFBFBD><EFBFBD>Ȃ<EFBFBD><C882>AWDS<44>X<EFBFBD>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>J<EFBFBD>n
#ifndef DISABLE_WDS_SCAN
if( !isStartScanWDS && // WDS<44>X<EFBFBD>L<EFBFBD><4C><EFBFBD><EFBFBD><EFBFBD>J<EFBFBD>n<EFBFBD>ς݂łȂ<C582>
!direct_boot && // <20>_<EFBFBD>C<EFBFBD><43><EFBFBD>N<EFBFBD>g<EFBFBD>u<EFBFBD>[<5B>g<EFBFBD>łȂ<C582>
!LCFG_THW_IsForceDisableWireless() && // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>OFF<46>łȂ<C582>
LCFG_TSD_IsAvailableWireless() // <20><><EFBFBD><EFBFBD>ON
) {
InitializeWDS(); // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ɠ<EFBFBD><C693><EFBFBD><EFBFBD>J<EFBFBD>n<EFBFBD><6E><EFBFBD><EFBFBD><EFBFBD>˂Ă<CB82><C482><EFBFBD><EFBFBD>B<EFBFBD>i<EFBFBD><69><EFBFBD>s<EFBFBD><73><EFBFBD>Ă<EFBFBD><C482>~<7E>܂<EFBFBD><DC82>͂<EFBFBD><CD82>Ȃ<EFBFBD><C882>̂ŁA<C581>C<EFBFBD>ɂ<EFBFBD><C982>Ȃ<EFBFBD><C882>j
isStartScanWDS = TRUE;
}
#endif // DISABLE_WDS_SCAN
}
// <20>R<EFBFBD>}<7D><><EFBFBD>h<EFBFBD>t<EFBFBD><74><EFBFBD>b<EFBFBD>V<EFBFBD><56>
(void)SND_FlushCommand(SND_COMMAND_NOBLOCK);
#ifndef DISABLE_SLEEP
// <20>X<EFBFBD><58><EFBFBD>[<5B>v<EFBFBD><76><EFBFBD>[<5B>h<EFBFBD>ւ̑J<CC91>ځi<DA81>W<EFBFBD>J<EFBFBD><4A><EFBFBD><EFBFBD><EFBFBD>Ԃƃf<C683>o<EFBFBD>b<EFBFBD>K<EFBFBD>ڑ<EFBFBD><DA91><EFBFBD><EFBFBD>̃L<CC83><4C><EFBFBD><EFBFBD><EFBFBD>Z<EFBFBD><5A><EFBFBD>̓f<CD83>t<EFBFBD>H<EFBFBD><48><EFBFBD>g<EFBFBD>ōs<C58D><73><EFBFBD>j
UTL_GoSleepMode();
#endif // DISABLE_SLEEP
}
}
static BOOL IsCommandSelected(void)
{
static BOOL left = FALSE;
if( !( pad.cont & ( PAD_BUTTON_A | PAD_BUTTON_B ) ) )
{
left = TRUE;
}
if( left && ( pad.trg & PAD_BUTTON_A ) )
{
NNS_G2dCharCanvasClear( &gCanvas, TXT_COLOR_NULL );
PrintfSJIS( 1, 25, TXT_COLOR_RED,"Resume Loading....\n" );
SYSM_ResumeLoadingThread( TRUE );
left = FALSE;
return TRUE;
}else if( left && ( pad.trg & PAD_BUTTON_B ) )
{
NNS_G2dCharCanvasClear( &gCanvas, TXT_COLOR_NULL );
PrintfSJIS( 1, 25, TXT_COLOR_RED,"Please Wait....\n" );
SYSM_ResumeLoadingThread( FALSE );
left = FALSE;
return TRUE;
}
return FALSE;
}
static void PrintPause(void)
{
LauncherInit( NULL );
GX_SetVisiblePlane( GX_PLANEMASK_BG0 );
NNS_G2dCharCanvasClear( &gCanvas, TXT_COLOR_NULL );
G2_ChangeBlendAlpha( 0, 31 );
PrintfSJIS( 1, 25, TXT_COLOR_RED,"WhiteList Check Failed.\n" );
PrintfSJIS( 1, 40, TXT_COLOR_RED,"Prease Select Command." );
PrintfSJIS( 1, 55, TXT_COLOR_RED,"A : Force to Launch" );
PrintfSJIS( 1, 70, TXT_COLOR_RED," or" );
PrintfSJIS( 1, 85, TXT_COLOR_RED,"B : Stop And Show Error Message" );
GX_DispOn();
GXS_DispOn();
}
static void PrintError( void )
{
u64 error_code;
int l;
int count = 0;
LauncherInit( NULL );
GX_SetVisiblePlane( GX_PLANEMASK_BG0 );
NNS_G2dCharCanvasClear( &gCanvas, TXT_COLOR_NULL );
G2_ChangeBlendAlpha( 0, 31 );
error_code = UTL_GetFatalError();
PrintfSJIS( 2, 25, TXT_COLOR_RED,"ERROR! - 0x%0.16x\n", error_code );
ErrorLog_WriteErrorLog(error_code);
for(l=0;l<64;l++)
{
if( error_code & 0x1 )
{
PrintfSJIS( 2, 50+count*13, TXT_COLOR_RED,"%s\n", fatal_error_msg[l] );
count++;
}
error_code = error_code >> 1;
}
GX_DispOn();
GXS_DispOn();
}
// ============================================================================
// <20><><EFBFBD><EFBFBD>ݏ<EFBFBD><DD8F><EFBFBD>
// ============================================================================
// V<>u<EFBFBD><75><EFBFBD><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD><EFBFBD><E88D9E>
static void INTR_VBlank(void)
{
OS_SetIrqCheckFlag(OS_IE_V_BLANK); // V<>u<EFBFBD><75><EFBFBD><EFBFBD><EFBFBD>N<EFBFBD><4E><EFBFBD><EFBFBD><EFBFBD>`<60>F<EFBFBD>b<EFBFBD>N<EFBFBD>̃Z<CC83>b<EFBFBD>g
}