mirror of
https://github.com/vgmstream/vgmstream.git
synced 2024-11-12 01:30:49 +01:00
EA SBK: additional format variations
This commit is contained in:
parent
a990c971ba
commit
88043ea4da
@ -2,7 +2,7 @@
|
|||||||
#include "../util/endianness.h"
|
#include "../util/endianness.h"
|
||||||
|
|
||||||
|
|
||||||
/* .SBK - EA Redwood Shores soundbank (Simpsons Game, Godfather) */
|
/* .SBK - EA Redwood Shores/Visceral Games soundbank */
|
||||||
VGMSTREAM* init_vgmstream_ea_sbk(STREAMFILE* sf) {
|
VGMSTREAM* init_vgmstream_ea_sbk(STREAMFILE* sf) {
|
||||||
VGMSTREAM* vgmstream = NULL;
|
VGMSTREAM* vgmstream = NULL;
|
||||||
int target_stream = sf->stream_index;
|
int target_stream = sf->stream_index;
|
||||||
@ -21,16 +21,15 @@ VGMSTREAM* init_vgmstream_ea_sbk(STREAMFILE* sf) {
|
|||||||
|
|
||||||
read_u32 = is_id32be(0x00, sf, "sbnk") ? read_u32le : read_u32be;
|
read_u32 = is_id32be(0x00, sf, "sbnk") ? read_u32le : read_u32be;
|
||||||
|
|
||||||
/* sdat_size is stored at 0x0C too? */
|
sdat_size = read_u32(0x0C, sf);
|
||||||
sdat_offset = read_u32(0x10, sf);
|
sdat_offset = read_u32(0x10, sf);
|
||||||
sdat_size = read_u32(0x14, sf);
|
/* sdat_size is also at 0x14 in all but its very early variant in PS2 007 */
|
||||||
|
|
||||||
/* lots of other unk data between here and the sdat chunk */
|
/* lots of other unk data between here and the sdat chunk */
|
||||||
|
|
||||||
if (read_u32(0x0C, sf) != sdat_size)
|
//if (read_u32(0x14, sf) != sdat_size) goto fail;
|
||||||
goto fail;
|
|
||||||
if (sdat_offset + sdat_size != get_streamfile_size(sf))
|
if (sdat_offset + sdat_size != get_streamfile_size(sf))
|
||||||
goto fail;
|
goto fail; /* TODO: also check with 4 byte alignment? */
|
||||||
|
|
||||||
|
|
||||||
if (target_stream < 0) goto fail;
|
if (target_stream < 0) goto fail;
|
||||||
@ -39,7 +38,7 @@ VGMSTREAM* init_vgmstream_ea_sbk(STREAMFILE* sf) {
|
|||||||
|
|
||||||
if (is_id32be(sdat_offset, sf, "BNKl") ||
|
if (is_id32be(sdat_offset, sf, "BNKl") ||
|
||||||
is_id32be(sdat_offset, sf, "BNKb")) {
|
is_id32be(sdat_offset, sf, "BNKb")) {
|
||||||
/* The Godfather */
|
/* 007: From Russia with Love, The Godfather */
|
||||||
|
|
||||||
vgmstream = load_vgmstream_ea_bnk(sf, sdat_offset, target_stream, 0);
|
vgmstream = load_vgmstream_ea_bnk(sf, sdat_offset, target_stream, 0);
|
||||||
if (!vgmstream) goto fail;
|
if (!vgmstream) goto fail;
|
||||||
@ -48,7 +47,7 @@ VGMSTREAM* init_vgmstream_ea_sbk(STREAMFILE* sf) {
|
|||||||
}
|
}
|
||||||
else if (is_id32be(sdat_offset, sf, "sdat") || /* sdat */
|
else if (is_id32be(sdat_offset, sf, "sdat") || /* sdat */
|
||||||
is_id32le(sdat_offset, sf, "sdat")) { /* tads */
|
is_id32le(sdat_offset, sf, "sdat")) { /* tads */
|
||||||
/* The Simpsons Game, The Godfather II */
|
/* The Simpsons Game, The Godfather II, Dead Space */
|
||||||
|
|
||||||
int total_streams;
|
int total_streams;
|
||||||
off_t entry_offset, stream_offset;
|
off_t entry_offset, stream_offset;
|
||||||
@ -65,6 +64,8 @@ VGMSTREAM* init_vgmstream_ea_sbk(STREAMFILE* sf) {
|
|||||||
* 0x04: 0x0313BABE (?)
|
* 0x04: 0x0313BABE (?)
|
||||||
* 0x08: stream offset
|
* 0x08: stream offset
|
||||||
* 0x0C: 0xFEEDFEED (?)
|
* 0x0C: 0xFEEDFEED (?)
|
||||||
|
*
|
||||||
|
* Dead Space 3 has non-placeholder data at 0x04 (SPS related?)
|
||||||
*/
|
*/
|
||||||
entry_offset = sdat_offset + 0x08 + target_stream * 0x10;
|
entry_offset = sdat_offset + 0x08 + target_stream * 0x10;
|
||||||
|
|
||||||
@ -77,6 +78,9 @@ VGMSTREAM* init_vgmstream_ea_sbk(STREAMFILE* sf) {
|
|||||||
//info.body_offset
|
//info.body_offset
|
||||||
info.type = meta_EA_SBK;
|
info.type = meta_EA_SBK;
|
||||||
|
|
||||||
|
if (read_u8(stream_offset, sf) == 0x48) /* 'H' - EAAC_BLOCKID1_HEADER */
|
||||||
|
info.is_sps = true; /* Dead Space 3 only? */
|
||||||
|
|
||||||
vgmstream = load_vgmstream_ea_eaac(&info);
|
vgmstream = load_vgmstream_ea_eaac(&info);
|
||||||
if (!vgmstream) goto fail;
|
if (!vgmstream) goto fail;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user