Skip to content

Commit

Permalink
Merge pull request vgmstream#1517 from EdnessP/master
Browse files Browse the repository at this point in the history
RAGE AUD: Additional todo note
  • Loading branch information
bnnm authored Apr 19, 2024
2 parents 63a12e1 + 611db38 commit 2efdcb6
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 4 deletions.
8 changes: 4 additions & 4 deletions src/layout/blocked_rage_aud.c
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ void block_update_rage_aud(off_t block_offset, VGMSTREAM* vgmstream) {
off_t seek_info_offset;
int i;

//big_endian = read_u32le(0x00, sf) == 0; /* 64-bit number */
//big_endian = read_u32le(block_offset, sf) == 0; /* 64-bit number */
read_u64_t read_u64 = vgmstream->codec_endian ? read_u64be : read_u64le;
read_u32_t read_u32 = vgmstream->codec_endian ? read_u32be : read_u32le;

Expand Down Expand Up @@ -37,13 +37,13 @@ void block_update_rage_aud(off_t block_offset, VGMSTREAM* vgmstream) {
* (table is max 0x7b8 + seek table offset + 0x800-padded) */

/* TODO: This isn't really reliable, there are several very short 4-7ch streams in
* both MCLA and GTA4 whose seek tables are short enough to fit in 0x800 alignment
*
* both MCLA and GTA4 whose seek tables are small enough to fit in 0x800 alignment
*
* The best option might be to search for the highest start_entry offset across all the
* seek info entries (offsets 0x00 and 0x04, can be along with the block_samples loop),
* and do seek_info_size + furthest_offset * 0x08 + num_entries * 0x08, since sometimes
* the number of seek entries are off by one, so just adding them all up won't match.
*
*
* However this should always be done from the 1st stream block, or at the very least
* not the final block, since it can have less data left over due to it being the end
* of the stream, where the calculation would result in it being smaller than it is.
Expand Down
7 changes: 7 additions & 0 deletions src/meta/rage_aud.c
Original file line number Diff line number Diff line change
Expand Up @@ -155,6 +155,13 @@ static int parse_aud_header(STREAMFILE* sf, aud_header* aud) {
aud->stream_offset = read_u32(0x2c, sf);
channel_info_offset = channel_table_offset + aud->channel_count * 0x10;

/* TODO: While not exactly relevant currently without it being supported yet,
* there are two Xbox 360 (XMA) streams, where the block count is off by one.
*
* This size check will fail on the following two files:
* GTA4 - Header says 2 blocks, actually has 3 - EP1_SFX/RP03_ML
* MCLA - Header says 3 blocks, actually has 4 - AUDIO/X360/SFX/AMBIENCE_STREAM/AMB_QUADSHOT_MALL_ADVERT_09
*/
if ((aud->block_count * aud->block_size) + aud->stream_offset != get_streamfile_size(sf)) {
VGM_LOG("RAGE AUD: bad file size\n");
goto fail;
Expand Down

0 comments on commit 2efdcb6

Please sign in to comment.