Difference between revisions of "IMG archive"
|  (The mystery has been solved) |  (Language closer to R*'s nameclatures) | ||
| Line 1: | Line 1: | ||
| − | GTA's most commonly used [[archive file]]s are known by the extension <code>'''.img'''</code>. They have a very simple format and currently exist in multiple versions. | + | GTA's most commonly used [[archive file]]s are cd images, known by the extension <code>'''.img'''</code>. They have a very simple format and currently exist in multiple versions. | 
| + | |||
| == Structure == | == Structure == | ||
| + | |||
| + | The format reflects [http://en.wikipedia.org/wiki/Disk_sector sectors] of CD-ROMs, improving I/O speed on the storage media. Every file contained in the img archive must be sector aligned, where the size of each sector is '''2048 bytes'''. | ||
| + | Thus values for offset and size have to be ''multiplied by 2048''. This means that even a file with only 123 byte content will take up 2 KiB in the archive. | ||
| + | |||
| + | The format is divided between directory entries, which contains information about the actual files in the img archive, and the actual files, which are stored (usually) unsorted, uncompressed and linear (no directory tree). | ||
| + | |||
| + | Directory entries should be in the same order as the files are stored, and there should not be any empty block between files. This is because the game might read more than one file with a single system call. By not following this rule, the game might get unstable. | ||
| === Version 1 - GTA III & VC === | === Version 1 - GTA III & VC === | ||
| − | + | In this version, the directory and the raw files are stored in separate files, the directory entries are stored in a <code>.dir</code> and the content pointed by the directory in the <code>.img</code> itself.   | |
| − | The directory  | + | The directory archive (<code>.dir</code>) must have the same name as the <code>.img</code> archive, except for the extension. | 
| + | The directory archive is pretty simple, it contains no header, just the following structure repeated until the end of the file. | ||
| − | + | ==== Directory Entry ==== | |
| − | + | Size of '''32 bytes''' | |
| + |   4 byte - DWORD 	- Offset (in sectors) | ||
| + |   4 byte - DWORD 	- Size (in sectors) | ||
| + |  24 byte - CHAR[24]	- Name of the file (null terminated) | ||
| − | + | The total number of entries can be found by dividing the size of the <code>.dir</code> file by 32. | |
| − | + | The <code>.img</code> file itself has no special structure or header, just all the files pointed by the directory. | |
| − | |||
| − | |||
| − | |||
| − | |||
| − | The <code>.img</code> file itself has no special structure or header, just all the files  | ||
| This format was also used in the PC version of ''Bully: Scholarship Edition''. | This format was also used in the PC version of ''Bully: Scholarship Edition''. | ||
| Line 25: | Line 32: | ||
| === Version 2 - GTA SA === | === Version 2 - GTA SA === | ||
| − | + | Introduced with GTA San Andreas, combines the directory entries (<code>.dir</code>) and raw files (<code>.img</code>) into one <code>.img</code> file. | |
| + | The directory has the same format as in version 1, but is located at the beginning of the archive. File offsets are relative to the start of the whole archive, not to the end of the file list. | ||
| ==== Header ==== | ==== Header ==== | ||
| Size of '''8 bytes''' | Size of '''8 bytes''' | ||
| − | + | ||
| − |   4 byte - DWORD		- Number  | + |   4 byte - DWORD		- Number Of Entries | 
| − | ==== Entry ==== | + | Followed by the header, there are the directory entries, containing information about the files in the archive. | 
| + | |||
| + | ==== Directory Entry ==== | ||
| Size of '''32 bytes'''    | Size of '''32 bytes'''    | ||
| − |    4 byte - DWORD 	-  | + |    4 byte - DWORD 	- Offset (in sectors) | 
| − |    2 byte - WORD		-  | + |    2 byte - WORD		- Size (in sectors) | 
| − |    2 byte - WORD		-  | + |    2 byte - WORD		- Streaming Size (in sectors) ''(always 0)'' | 
| − |   24 byte - CHAR[24]	-  | + |   24 byte - CHAR[24]	- Name of the file (null terminated) | 
| − | |||
| − | |||
| − | + | The streaming size is how many actual sectors the file takes in memory. If streaming size is 0, size will be used as streaming size. The stock img files never used streaming size (thus always 0), it's believed that this mechanism would be used for compression of files, but it never made it's way into production. | |
| A major drawback of this format is the complicated extendability. If you have to add many files, it might happen that you run out of space for the directory, and have to move the first file(s) to the end. | A major drawback of this format is the complicated extendability. If you have to add many files, it might happen that you run out of space for the directory, and have to move the first file(s) to the end. | ||
| Line 47: | Line 55: | ||
| === Version 3 - GTA IV === | === Version 3 - GTA IV === | ||
| − | GTA IV introduced yet another <code>.img</code> file format. Not only the format is new, also there can be encrypted archive headers (see below). The internal IMG parser of the game works with 2 kb buffers, which means that the 2 kb bounds from earlier versions ( | + | GTA IV introduced yet another <code>.img</code> file format. Not only the format is new, also there can be encrypted archive headers (see below). The internal IMG parser of the game works with 2 kb buffers, which means that the 2 kb bounds from earlier versions (sectors) are still present, yet optional. | 
| ==== IMG Header ==== | ==== IMG Header ==== | ||
| Line 66: | Line 74: | ||
|   4 byte - DWORD      - Itemsize (in bytes) |   4 byte - DWORD      - Itemsize (in bytes) | ||
|   4 byte - DWORD      - Resource type |   4 byte - DWORD      - Resource type | ||
| − |   4 byte - DWORD      - Offset (in  | + |   4 byte - DWORD      - Offset (in sectors) | 
|   2 byte - WORD       - Used Blocks |   2 byte - WORD       - Used Blocks | ||
|   2 byte - WORD       - Padding |   2 byte - WORD       - Padding | ||
| Line 134: | Line 142: | ||
| * [[X Archive Poison]] | * [[X Archive Poison]] | ||
| − | {{N|4|SA}} | + | {{N|4|SA|VC|3}} | 
| [[Category:File Formats]][[Category:GTA 3]][[Category:GTA VC]][[Category:GTA LCS]][[Category:GTA VCS]] | [[Category:File Formats]][[Category:GTA 3]][[Category:GTA VC]][[Category:GTA LCS]][[Category:GTA VCS]] | ||
Revision as of 03:04, 21 August 2014
GTA's most commonly used archive files are cd images, known by the extension .img. They have a very simple format and currently exist in multiple versions.
Contents
Structure
The format reflects sectors of CD-ROMs, improving I/O speed on the storage media. Every file contained in the img archive must be sector aligned, where the size of each sector is 2048 bytes. Thus values for offset and size have to be multiplied by 2048. This means that even a file with only 123 byte content will take up 2 KiB in the archive.
The format is divided between directory entries, which contains information about the actual files in the img archive, and the actual files, which are stored (usually) unsorted, uncompressed and linear (no directory tree).
Directory entries should be in the same order as the files are stored, and there should not be any empty block between files. This is because the game might read more than one file with a single system call. By not following this rule, the game might get unstable.
Version 1 - GTA III & VC
In this version, the directory and the raw files are stored in separate files, the directory entries are stored in a .dir and the content pointed by the directory in the .img itself. 
The directory archive (.dir) must have the same name as the .img archive, except for the extension.
The directory archive is pretty simple, it contains no header, just the following structure repeated until the end of the file.
Directory Entry
Size of 32 bytes
4 byte - DWORD - Offset (in sectors) 4 byte - DWORD - Size (in sectors) 24 byte - CHAR[24] - Name of the file (null terminated)
The total number of entries can be found by dividing the size of the .dir file by 32.
The .img file itself has no special structure or header, just all the files pointed by the directory.
This format was also used in the PC version of Bully: Scholarship Edition.
Version 2 - GTA SA
Introduced with GTA San Andreas, combines the directory entries (.dir) and raw files (.img) into one .img file.
The directory has the same format as in version 1, but is located at the beginning of the archive. File offsets are relative to the start of the whole archive, not to the end of the file list.
Header
Size of 8 bytes
4 byte - CHAR[4] - 4 byte - DWORD - Number Of Entries
Followed by the header, there are the directory entries, containing information about the files in the archive.
Directory Entry
Size of 32 bytes
4 byte - DWORD - Offset (in sectors) 2 byte - WORD - Size (in sectors) 2 byte - WORD - Streaming Size (in sectors) (always 0) 24 byte - CHAR[24] - Name of the file (null terminated)
The streaming size is how many actual sectors the file takes in memory. If streaming size is 0, size will be used as streaming size. The stock img files never used streaming size (thus always 0), it's believed that this mechanism would be used for compression of files, but it never made it's way into production.
A major drawback of this format is the complicated extendability. If you have to add many files, it might happen that you run out of space for the directory, and have to move the first file(s) to the end.
Version 3 - GTA IV
GTA IV introduced yet another .img file format. Not only the format is new, also there can be encrypted archive headers (see below). The internal IMG parser of the game works with 2 kb buffers, which means that the 2 kb bounds from earlier versions (sectors) are still present, yet optional.
IMG Header
The header of an unencrypted file always has a size of 20 bytes.
4 byte - DWORD - Identifier (0xA94E2A52 if the archive is not encrypted) 4 byte - DWORD - Version (always 3, if not the format would be differ) 4 byte - DWORD - Number of Items 4 byte - DWORD - Table Size (in bytes) 2 byte - WORD - Size of Table Items (needs to be always 0x10) 2 byte - WORD - Unknown
IMG Table
The table holds information about the items. Each item header has a size of 16 bytes .
4 byte - DWORD - Itemsize (in bytes) 4 byte - DWORD - Resource type 4 byte - DWORD - Offset (in sectors) 2 byte - WORD - Used Blocks 2 byte - WORD - Padding
Item Names' length will be calculate as :
Table Size - (Number of Items * Item Size)
Next that string will be split by '\x0'
A resource type is identified by the 4b DWORD value:
- 0x01: Generic
- 0x08: Texture archive
- 0x20: Bounds
- 0x6E: Model file
- 0x24: xpfl
Encryption
The header and directory (table) of IMG archives can be encrypted. This is usually the case if the 4 byte identifier at the start of the file seems invalid. Decryption is done via 16 repetitions of AES-128 in ECB mode.
Additional archives
It is possible to add additional IMG archives to the current default ones. The following examples are lines that can be added anywhere in either the default.dat or gta*.dat files.
|    | CDIMAGE MODELS\FOO.IMG | 
|  | IMG MODELS\FOO.IMG | 
Where FOO can be any name. The FOO.IMG (and FOO.DIR for GTA III and Vice City) must be created and placed within the ..\models folder in these examples. This method is primarily used for modifying version 2 of San Andreas, as well as for storing assets (models/textures/etc.) used in total conversions.
By default GTA San Andreas is able to load max of 8 archives (3 standard archives gta3.img, gta_int.img, player.img and 5 archives defined within default.dat or gta.dat). GTA VC is able to load max of 8 archives (one archive is hard-coded to be loaded - gta3.img) too. Using more than 8 archives crashes the game, although this can be fixed with fastman92's IMG Limit Adjuster.
Tools
|    | ImgEd – by Dan Strandberg | 
|        | IMG Manager – by xmen | 
|  |  GTAGarage: Spark – by aru | 
|      | IMG Tool – by Spooky | 
|      | G-IMG – by REspawn | 
|      |  GTAForums: fastman92 IMG Console – by fastman92 | 
|    |  GTAForums: IMG & Stream Limit Adjuster – by fastman92 | 
|    |  GTAForums: GTA Stories IMG Tool – by HackMan128 | 
|  | SparkIV – by aru | 
|  | OpenIV – by GooD-NTS | 
|  | Shadow-Mapper – by Prince-Link | 
Libraries
Version 2 only
Version 3 only
|  Grand Theft Auto IV | |
|---|---|
| File Formats | .dat • .gxt • .ide • .img • .ipl • .nod • .sco • .rpf • .rrr • .wad • .wbd/.wbn • .wdd • .wdr • .wft • .whm • .wpl • .wtd | 
| Documentation | Audio • Bink Video • Cryptography • Cutscenes • GXT Text • Image listing • Keycodes • Map Listing • Native functions • Paths • Radar Blips • Radio Stations • Saves • Scenarios • VTable • Weapons | 
| Tools | ASI Loader • ENBSeries • SCO Toolbox • G-Texture •  GIMS IV • Ingame WPL Editor • IV Needle • OpenIV • SparkIV • XLiveLess • WPL Manager • X Mod Installer Alice • C++ Script Hook • .NET Script Hook • SC-CL • Scocl | 
| Tutorials | Importing Textures with OpenIV • Importing Textures with SparkIV | 
| Multiplayer | GTA Connected • CitizenMP:IV Reloaded • IV Multiplayer • Four Multiplayer • Gostown IV | 
| Useful links | Community portal • Discussion forums • Modding forums • Mods on GTAGarage.com | 

