No edit summary |
No edit summary |
||
Line 2: | Line 2: | ||
<div style="text-align: center;"> | <div style="text-align: center;"> | ||
<div style="color: red;"> | <div style="color: red;">This section needs a lot of research.</div> | ||
<div style="color: red; text-align: center;"> | <div style="color: red; text-align: center;">Research on how the header works and how the file interacts is needed.</div> | ||
</div> | </div> | ||
Revision as of 21:57, 22 August 2022
This section needs a lot of research.
Research on how the header works and how the file interacts is needed.
Format
On retrouve des groupes de fichiers BIN ayant une même taille de fichier (version NTSC) :
- 432 - 198 fichiers
- 864 - 10 fichiers
- 7840 - 209 fichiers
On retrouve ensuite plus de 150 tailles différentes apparaissant moins de 10 fois.
Le PGCD des tailles de tous les BIN est 4.
Header
Le magic number "STIH" désigne les fichiers HITS (big endian) :
- gets.pzz -> 008, 009, 010
- stxx.pzz -> 001, 002, 003
- hitxxx.bin -> (les 54 fichiers)
- Header: (0x8 octets)
- 4 octets - STIH
- 4 octets - file_length - taille totale du fichier
- Section 0: (0x20 octets)
- 4 octets [2] - Inconnu - ne désigne pas d'offset, on dirait une taille (500 ?)
- 4 octets [2] - Inconnu - ne désigne pas d'offset, on dirait une taille (42 ?)
- 4 octets [2] - entier signé (-11000 ?)
- 4 octets - Inconnu (32 ?)
- 4 octets - offset data block 2 - fin du data block 1 - adresse à laquelle il faut ajouter la taille du header (8)
- Table de Relocations
- 4 octets [3528]
- Les adresses sont relatives à la fin du Header, on y ajoutera alors 8 pour obtenir les adresse dans le fichier. Elles pointent sur les structures du Data Block 1;
- Data block 1
- Contient de petites structures (4 - 8 - 12 ... octets) avec des offsets du Data Block 2 en adresses relatives au début du DB2. Chaque suite d'offsets est terminé par FF FF FF FF (-1). On vérifie cela facilement et rigoureusement avec un script sur l'ensemble des valeurs du DB1 et effectivement, la valeur maximale retrouvée (hors FF FF FF FF = -1) ajoutée à l'adresse du DB2 pointe un peu avant la toute fin du DB2; Certaines entrées sont vides (juste -1), on en déduit donc que l'ensemble des structures du DB1 correspondent à quelque chose d'existant (un modèle ? Etc.).
- Data block 2
- On remarque l'usage de CC CC CC CC qui est inhabituel. Il s'agit probablement d'une normalisation pour ne pas utiliser FF FF FF FF dans tout le block et signaler peut-être quelque chose (fin de structure ? fin de données ?).