Skip to content

Latest commit

 

History

History
135 lines (110 loc) · 5.07 KB

rvth_notes.md

File metadata and controls

135 lines (110 loc) · 5.07 KB

RVT-H Reverse-Engineering Notes

This document is Copyright (C) 2018 by David Korth.
Licensed under the GNU Free Documentation License v1.3.

These notes were written using a full dump of an RVT-H Reader HDD using the front-panel USB port and an API trace of rvtwriter.exe 1.0.0.4.

NOTE: Sectors (LBAs) are assumed to be 512 bytes.

Test System

According to rvtwriter, this RVT-H Reader has:

  • Bank 1: Empty
  • Bank 2: THE LAST STORY / 2011.11.25 10:18:15
  • Bank 3: ^ (dual-layer)
  • Bank 4: THE LAST STORY / 2011.11.28 10:30:09
  • Bank 5: ^ (dual-layer)
  • Bank 6: Empty
  • Bank 7: Empty
  • Bank 8: Empty

NHCD Bank Table

At 0x60000000:

60000000  4e 48 43 44 00 00 00 01  00 00 00 08 00 00 00 00  |NHCD............|
60000010  00 2f f0 00 00 00 00 00  00 00 00 00 00 00 00 00  |./..............|
60000020  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
*
60000400  4e 4e 32 4c 30 30 30 30  30 30 30 30 30 30 30 30  |NN2L000000000000|
60000410  30 30 32 30 31 31 31 31  32 35 31 30 31 38 31 35  |0020111125101815|
60000420  00 bc 4a 09 00 ee 00 00  00 00 00 00 00 00 00 00  |..J.............|
60000430  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
*
60000800  4e 4e 32 4c 30 30 30 30  30 30 30 30 30 30 30 30  |NN2L000000000000|
60000810  30 30 32 30 31 31 31 31  32 38 31 30 33 30 30 39  |0020111128103009|
60000820  01 d4 de 09 00 ee 00 00  00 00 00 00 00 00 00 00  |................|
60000830  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|

$60000000: Control struct.

typedef struct _NHCD_BankTable_Header {
	char magic[4];		// [0x000] "NHCD"
	uint32_t x004;		// [0x004] 0x00000001
	uint32_t bank_count;	// [0x008] Bank count.
	uint32_t x00C;		// [0x00C] 0x00000000
	uint32_t x010;		// [0x010] 0x002FF000
	uint8_t unk[492];	// [0x014] Unknown
} NHCD_BankTable_Header;

On all known RVT-H Reader systems, bank_count is set to 8. Earlier models included a 40 GB HDD, which can hold up to 8 banks. Later models have an 80 GB HDD, possibly because the 40 GB HDD was no longer manufactured. These systems are still limited to 8 banks by default.

By modifying bank_count, it is possible to get more than 8 banks on systems with larger HDDs. Note that the bank table size will increase by 512 bytes for each bank added, and this will run into the default offset for Bank 1. Hence, to take full advantage of extra banks, the entire disk will need to be repartitioned.

rvthtool does not currently support non-standard partition layouts.

Note that the front-panel display on the RVT-H Reader has a 4-bit binary counter. This counter normally shows 1-8 for selected banks, or 15 if the drive is in "writable" mode. It should be possible to extend bank_count to at least 14. Larger bank counts may work, but the counter display will be incorrect.

$60000200: Bank 1. Each bank entry is 512 bytes.

typedef struct _NHCD_BankEntry {
	char type[4];		// [0x000] Type. (See below.)
	char all_zero[14];	// [0x004] All ASCII zeroes. ('0')
	char timestamp[14];	// [0x012] Full timestamp, in ASCII. ('20180112222720')
	uint32_t lba_start;	// [0x020] Starting LBA. (512-byte sectors)
	uint32_t lba_len;	// [0x024] Length, in 512-byte sectors.
	uint8_t unk[472];	// [0x028] Unknown
} NHCD_BankEntry;

Bank types:

  • "GC1L": GameCube single-layer disc.
  • "NN1L": Wii single-layer disc.
  • "NN2L": Wii dual-layer disc.

Bank starting offsets are usually the same on all systems, assuming the official development tools are used. Length may differ depending on if the game is GameCube, Wii single-layer, or Wii dual-layer, and if the image is encrypted or unencrypted.

Each bank is 0x8C4A00 sectors. (4,707,319,808 bytes)

  • This matches the size of RVT-R and DVD-R discs.

The dual-layer games installed on this system take up 0xEE0000 sectors.

  • 7,985,954,816 bytes
  • These images are unencrypted, so encrypted DL images are probably larger.
  • DVD-R DL discs are 0xFE9F00 sectors. (8,543,666,176 bytes)
  • Retail Wii DL discs are 0xFDA700 sectors. (8,511,160,320 bytes)

Single-layer GCN disc image: 0x2B82C0 sectors (1,459,978,240 bytes)

  • May be the same as NR discs.

The standard NHCD layout is as follows:

  • Bank 1: 0x060001200 (LBA 0x00300009)
  • Bank 2: 0x178941200 (LBA 0x00BC4A09)
  • Bank 3: 0x291281200 (LBA 0x01489409)
  • Bank 4: 0x3A9BC1200 (LBA 0x01D4DE09)
  • Bank 5: 0x4C2501200 (LBA 0x02612809)
  • Bank 6: 0x5DAE41200 (LBA 0x02ED7209)
  • Bank 7: 0x6F3781200 (LBA 0x0379BC09)
  • Bank 8: 0x80C0C1200 (LBA 0x04060609)

Deleted Banks

  • On some RVT-H Reader systems, deleting a bank by pressing the "Flush" button merely erases the bank table entry.
  • On other RVT-H Reader systems, this also zeroes out the first 16 KB of the bank.
  • This may depend on the RVT-H Reader firmware version.

The first 16 KB contains:

  • Wii: Disc header.
  • GameCube: Disc header, bi2.bin, and apploader

For Wii, the disc header can be reconstructed by copying the disc header from the primary game partition. (The hash/crypto bytes need to be flipped if the disc image is encrypted.)

For GameCube, the disc header, bi2.bin, and apploader cannot be automatically reconstructed; it needs to be manually rebuilt.