TwlIPL/include/sysmenu/sysmenu_lib/common/sysmenu_work.h
yosiokat a9dbe9301a ・ルートのMakefileおよびMakefile.sysmenuで、TwlIPLツリーのビルドに必要な他ツリーのコードもビルドするよう変更。
・ショートカット起動や検査カードチェックもSYSM_ReadParameters内でチェックするよう変更。
・本体設定データが無効だった時の初期値において、バックライト輝度をMAXにする。
・ランチャーでのブートパラメータ処理を変更。
・ランチャーでのフェードアウト処理とロード処理の判定を調整。

git-svn-id: file:///Users/lillianskinner/Downloads/platinum/twl/TwlIPL/trunk@231 b08762b0-b915-fc4b-9d8c-17b2551a87ff
2007-11-20 13:21:01 +00:00

151 lines
4.9 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: sysmenu_work.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$
*---------------------------------------------------------------------------*/
#ifndef __SYSMENU_WORK_H__
#define __SYSMENU_WORK_H__
#include <twl.h>
#include <twl/nam.h>
#ifdef __cplusplus
extern "C" {
#endif
// compile switch ---------------------------------
// define data ------------------------------------
#define SYSM_RESET_PARAM_MAGIC_CODE "TRST"
#define SYSM_RESET_PARAM_MAGIC_CODE_LEN 4
#define CLONE_BOOT_MODE 1
#define OTHER_BOOT_MODE 2
// NAMTitleIDをHiLoに分割してアクセスする場合に使用
typedef struct TitleID_HiLo {
u8 Lo[ 4 ];
u32 Hi;
}TitleID_HiLo;
// リセットパラメータ フラグ
typedef struct BootFlags {
u16 isLogoSkip : 1; // ロゴデモスキップ要求
u16 isInitialShortcutSkip : 1; // 初回起動シーケンススキップ要求
u16 isAppLoadCompleted : 1; // アプリロード済みを示す
u16 isAppRelocate : 1; // アプリ再配置要求
u16 rsv : 12;
}BootFlags;
// リセットパラメータ ヘッダ
typedef struct ResetParameterHeader {
u32 magicCode; // SYSM_RESET_PARAM_MAGIC_CODEが入る
u8 type; // タイプによってBodyを判別する。
u8 bodyLength; // bodyの長さ
u16 crc16; // bodyのCRC16
}ResetParamHeader;
// リセットパラメータ ボディ
typedef union ResetParamBody {
struct { // ※とりあえず最初はTitlePropertyとフォーマットを合わせておく
NAMTitleId bootTitleID; // リセット後にダイレクト起動するタイトルID
BootFlags flags; // リセット時のランチャー動作フラグ
u8 rsv[ 4 ]; // 予約
}v1;
}ResetParamBody;
// リセットパラメータ
typedef struct ResetParam {
ResetParamHeader header;
ResetParamBody body;
}ResetParam;
//----------------------------------------------------------------------
// データ型定義
//----------------------------------------------------------------------
// SYSM共有ワーク構造体
typedef struct SYSM_work {
vu16 isARM9Start :1; // ARM9スタートフラグ
vu16 isHotStart :1; // Hot/Coldスタート判定
vu16 isValidResetParam :1; // リセットパラメータ有効
vu16 isValidTSD :1; // NITRO設定データ無効フラグ
vu16 isLogoSkip :1; // ロゴデモスキップ
vu16 isOnDebugger :1; // デバッガ動作か?
vu16 isExistCard :1; // 有効なNTR/TWLカードが存在するか
vu16 isLoadSucceeded :1;
vu16 rsv :8;
u16 cardHeaderCrc16; // システムメニューで計算したROMヘッダCRC16
int cloneBootMode;
ResetParam resetParam;
// NTR-IPL2のレガシー 最終的には消すと思う
u32 nCardID;
BOOL enableCardNormalOnly;
u8 rtcStatus;
}SYSM_work;
// NTRにおける仕様を継承する必要のあるワーク
typedef struct SDKBootCheckInfo{
u32 nCardID; // NORMALカードID // SDKではここだけ見ているっぽい ※最終的にはランチャーでここにカードIDをセットする
u32 sCardID; // SECUREカードID
u16 cardHeaderCrc16; // カードヘッダCRC16
u16 cardSecureCrc16; // カードSECURE領域CRC16
s16 cardHeaderError; // カードヘッダエラー
s16 disableEncryptedCardData; // カードSECURE領域暗号化データ無効
u16 sysromCrc16; // システムROMのCRC16
s16 enableCardNormalOnly; // カードNORMALモードのみ有効
s16 isOnDebugger; // デバッガ上で動作中か
s8 rtcError; // RTCエラー
u8 rtcStatus1; // RTCステータス1
}SDKBootCheckInfo;
//----------------------------------------------------------------------
// SYSM共有ワーク領域のアドレス獲得
//----------------------------------------------------------------------
#if 0
// SYSMリセットパラメータアドレスの取得※ライブラリ向け。ARM9側はSYSM_GetResetParamを使用して下さい。
#define SYSMi_GetResetParamAddr() ( (ResetParam *)0x02000100 )
// SYSM共有ワークの取得
#define SYSMi_GetWork() ( (SYSM_work *)HW_RED_RESERVED )
#else
#define SYSMi_GetResetParamAddr() ( (ResetParam *)( HW_RED_RESERVED + 0x50 ) )
#define SYSMi_GetWork() ( (SYSM_work *)HW_RED_RESERVED + 0x10 )
#endif
// SDKブートチェックアプリ起動時にカードIDをセットする必要がある。
#define SYSMi_GetSDKBootCheckInfo() ( (SDKBootCheckInfo *)HW_BOOT_CHECK_INFO_BUF )
#define SYSMi_GetSDKBootCheckInfoForNTR() ( (SDKBootCheckInfo *)0x027ffc00 )
// NANDファームがロードしてくれているマイコンフリーレジスタ値の取得
#define SYSMi_GetMCUFreeRegisterValue() ( *(vu8 *)HW_RESET_PARAMETER_BUF )
// カードROMヘッダワークの取得
#define SYSM_GetCardRomHeader() ( (ROM_Header_Short *)HW_TWL_ROM_HEADER_BUF )
#ifdef __cplusplus
}
#endif
#endif // __SYSMENU_WORK_H__