Difference between revisions of "CSMP (File Format)"

From Retro Modding Wiki
Jump to: navigation, search
m (Minor edits for grammar/consistency)
(Restructuring a little and adding some info)
Line 5: Line 5:
 
__TOC__
 
__TOC__
  
== Header ==
+
== Format ==
  
This is the header structure found in Metroid Prime 3 and Donkey Kong Country Returns; Tropical Freeze's seems to be a bit different. The file can be read using a simple while loop; each chunk sets its own size.
+
CSMP files are made up of a number of data chunks. Since not every file always has every chunk, the best way to read a CSMP file is to use a while loop to check the chunk headers and parse their contents until you reach the end of the file.
 +
 
 +
=== Header ===
 +
 
 +
This is the header structure found in Metroid Prime 3 and Donkey Kong Country Returns; Tropical Freeze's is a bit different.
  
 
{{todo|We've had success getting audio out of Tropical Freeze, crediar mentioned ddspadpcm being used in Tropical Freeze. What is it? And can we find any information on it?}}
 
{{todo|We've had success getting audio out of Tropical Freeze, crediar mentioned ddspadpcm being used in Tropical Freeze. What is it? And can we find any information on it?}}
Line 25: Line 29:
 
|}
 
|}
  
== Chunk ==
+
=== Chunk Header ===
 +
 
 +
Every chunk begins with this header; it contains a brief data type identifier and a size.
  
 
{|class="wikitable"
 
{|class="wikitable"
Line 41: Line 47:
 
|-
 
|-
 
|0x8+N
 
|0x8+N
|colspan=2|End of chunk (usually, subtract 4 when the chunk type is equal to 0x44415441 ["DATA"])
+
|colspan=2|End of chunk
 
|}
 
|}
 
== Chunk Types ==
 
 
The structure for each chunk are as follows:
 
  
 
=== NAME ===
 
=== NAME ===
Line 82: Line 84:
 
=== PAD ===
 
=== PAD ===
  
Padding; just skip this chunk using its size value.
+
This chunk is just padded with 0xFF; usually contains 0x14 bytes.
  
 
=== DATA ===
 
=== DATA ===
  
Refer to the [[DSP (File Format)|DSP]] page for details.
+
The DATA section essentially just embeds a standard DSP, including the full header and ADPCM audio data. Refer to the [[DSP (File Format)|DSP]] page for details. Note that for some reason, the DATA chunk is often 4 bytes smaller than its size indicates.
  
 
[[Category:File Formats]]
 
[[Category:File Formats]]

Revision as of 15:08, 25 January 2015

The .CSMP file format is an audio format seen in Retro Studios games starting in Metroid Prime 3. It's very similar in use to AGSC and usually contains sound affects. Where CSMP differs is the fact that it only contains one sound and is broken up into obvious data chunks with easily identifiable sizes.


GravitySuitIcon.png To do:
Notate Tropical freeze differences (Paraxade do you know anything?)

Format

CSMP files are made up of a number of data chunks. Since not every file always has every chunk, the best way to read a CSMP file is to use a while loop to check the chunk headers and parse their contents until you reach the end of the file.

Header

This is the header structure found in Metroid Prime 3 and Donkey Kong Country Returns; Tropical Freeze's is a bit different.


GravitySuitIcon.png To do:
We've had success getting audio out of Tropical Freeze, crediar mentioned ddspadpcm being used in Tropical Freeze. What is it? And can we find any information on it?
Offset Size Description
0x0 4 "CSMP" magic fourCC
0x4 4 Version; always 1

Chunk Header

Every chunk begins with this header; it contains a brief data type identifier and a size.

Offset Size Description
0x0 4 Chunk type
0x4 4 Chunk size (N)
0x8+N End of chunk

NAME

This chunk just has a null-terminated string; it's the name of the contained sound data.

INFO

Offset Size Description
0x0 1 Unknown
0x1 1 Loop Flag
0x2 4 Unknown
0x6 2 Unknown
0x8 4 Volume

PAD

This chunk is just padded with 0xFF; usually contains 0x14 bytes.

DATA

The DATA section essentially just embeds a standard DSP, including the full header and ADPCM audio data. Refer to the DSP page for details. Note that for some reason, the DATA chunk is often 4 bytes smaller than its size indicates.