ROMヘッダ偽装:新旧の開発用暗号フラグ入れ替えオプションを追加。

git-svn-id: file:///Users/lillianskinner/Downloads/platinum/twl/TwlIPL/trunk@2391 b08762b0-b915-fc4b-9d8c-17b2551a87ff
This commit is contained in:
nishikawa_takeshi 2008-09-04 01:41:40 +00:00
parent fc422815ae
commit f270ea75ac
3 changed files with 24 additions and 2 deletions

View File

@ -21,7 +21,7 @@ include $(TWLSDK_ROOT)/build/buildtools/commondefs
TARGETS = fakeRomHeader.exe
TARGETS = FakeRomHeader.exe
SOURCES_C = main.c keys.c

View File

@ -25,6 +25,7 @@ ROM
・オプション
-p: プラットフォームコードを0x01にします。
-s: 署名有効フラグをOffにします。
-d: 新・開発用暗号フラグを0にして、旧・開発用暗号フラグを1にします。
・他にもROMヘッダをいじりたいとき
-> バイナリエディタなどでROMヘッダをいじった後に、

View File

@ -60,6 +60,7 @@ typedef struct _SContext
// オプション
BOOL bPlatform;
BOOL bSignFlag;
BOOL bDevFlag;
FILE *ifp;
FILE *ofp;
@ -99,6 +100,7 @@ void usage()
printf( "-h : print help only.\n" );
printf( "-p : write invalid platform code in a ROM Header.\n" );
printf( "-s : negate flag for the signature in a ROM Header.\n" );
printf( "-d : negate a new developer encrypt flag, and assert an old one.\n" );
printf( "-----------------------------------------------------------------------------\n" );
}
@ -120,7 +122,7 @@ int main(int argc, char *argv[])
memset( &context, 0, sizeof(SContext) );
// オプション
while( (opt = getopt(argc, argv, "hps")) >= 0 )
while( (opt = getopt(argc, argv, "hpsd")) >= 0 )
{
switch( opt )
{
@ -136,6 +138,10 @@ int main(int argc, char *argv[])
case 's':
context.bSignFlag = TRUE;
break;
case 'd':
context.bDevFlag = TRUE;
break;
default: // オプション引数が指定されていないときにも実行される
usage();
@ -164,6 +170,13 @@ int main(int argc, char *argv[])
printf( "output_file: %s\n", pDst );
printf( "\n" );
// 入力ファイルと出力ファイル名が同じならダメ
if( (strlen(pSrc) == strlen(pDst)) && (memcmp(pSrc, pDst, strlen(pSrc)) == 0) )
{
printf( "The name of output_file must be different from the one of input_file\n" );
exit(1);
}
// 出力ファイルが存在するとき上書きするかどうかを確認する
if( stat( pDst, &st )==0 )
{
@ -248,6 +261,14 @@ static BOOL iMain( SContext *pContext )
printf( "enable_signature: 0x%02x -> 0x00\n", rh.s.enable_signature );
rh.s.enable_signature = 0x0;
}
if( pContext->bDevFlag )
{
printf( "old dev. encrypt: 0x%02x -> 0x01x\n", rh.s.developer_encrypt_old );
printf( "new dev. encrypt: 0x%02x -> 0x00x\n", rh.s.exFlags.developer_encrypt );
rh.s.developer_encrypt_old = 0x1;
rh.s.exFlags.developer_encrypt = 0x0;
}
}
// ヘッダCRC計算