TwlIPL/include/firm/format/format_rom_certificate.h
yutaka cbac3f86b7 new rom header
git-svn-id: file:///Users/lillianskinner/Downloads/platinum/twl/TwlIPL/trunk@37 b08762b0-b915-fc4b-9d8c-17b2551a87ff
2007-10-03 10:16:48 +00:00

51 lines
1.7 KiB
C

/*---------------------------------------------------------------------------*
Project: TwlSDK - tools - makerom.TWL
File: format_rom_certificate.h
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 FORMAT_ROM_CERTIFICATE_H_
#define FORMAT_ROM_CERTIFICATE_H_
//#include "misc.h"
/*===========================================================================*
* ROM CERTIFICATE FORMAT
*===========================================================================*/
#define TWL_ROM_CERT_MAGIC_NUMBER 0x54524543 // "CERT"の文字列
#define RSA_KEY_LENGTH ( 1024 / 8 )
#define ROM_CERT_SIGN_OFFSET 256
#define ROM_HEADER_SIGN_TARGET_SIZE 0xe00
// ROM証明書ヘッダ
typedef struct RomCertificateHeader {
u32 magicNumber;
u32 version;
u32 serialNo;
u32 gameCode;
}RomCertificateHeader;
// ROM証明書
typedef struct RomCertificate {
RomCertificateHeader header;
u8 reserved[ ROM_CERT_SIGN_OFFSET - sizeof(RomCertificateHeader) - RSA_KEY_LENGTH ];
u8 pubKeyMod[ RSA_KEY_LENGTH ];
u8 sign[ RSA_KEY_LENGTH ];
}RomCertificate;
#endif //FORMAT_ROM_CERTIFICATE_H_