mirror of
https://github.com/vgmstream/vgmstream.git
synced 2024-11-28 00:20:47 +01:00
Sony BNK: version 0x1C
This commit is contained in:
parent
e48ea0cafe
commit
7e43776892
@ -443,10 +443,11 @@ static bool process_tables(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
|
|
||||||
/* later versions have a few more tables (some optional) and work slightly differently (header is part of wave) */
|
/* later versions have a few more tables (some optional) and work slightly differently (header is part of wave) */
|
||||||
case 0x1a: /* Demon's Souls (PS5) */
|
case 0x1a: /* Demon's Souls (PS5) */
|
||||||
|
case 0x1c: /* The Last of Us Part II */
|
||||||
case 0x23: { /* The Last of Us (PC) */
|
case 0x23: { /* The Last of Us (PC) */
|
||||||
uint32_t bank_name_offset = h->sblk_offset + (h->sblk_version <= 0x1a ? 0x1c : 0x20);
|
uint32_t bank_name_offset = h->sblk_offset + (h->sblk_version <= 0x1c ? 0x1c : 0x20);
|
||||||
uint32_t tables_offset = h->sblk_offset + (h->sblk_version <= 0x1a ? 0x120 : 0x128);
|
uint32_t tables_offset = h->sblk_offset + (h->sblk_version <= 0x1c ? 0x120 : 0x128);
|
||||||
uint32_t counts_offset = tables_offset + (h->sblk_version <= 0x1a ? 0x98 : 0xb0);
|
uint32_t counts_offset = tables_offset + (h->sblk_version <= 0x1c ? 0x98 : 0xb0);
|
||||||
|
|
||||||
//h->table1_offset = h->sblk_offset + read_u32(tables_offset+0x00,sf); /* sounds/cues */
|
//h->table1_offset = h->sblk_offset + read_u32(tables_offset+0x00,sf); /* sounds/cues */
|
||||||
//h->table2_offset = 0;
|
//h->table2_offset = 0;
|
||||||
@ -513,6 +514,7 @@ static bool process_headers(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x1a:
|
case 0x1a:
|
||||||
|
case 0x1c:
|
||||||
case 0x23:
|
case 0x23:
|
||||||
h->total_subsongs = h->stream_entries;
|
h->total_subsongs = h->stream_entries;
|
||||||
h->table3_entry_offset = (h->target_subsong - 1) * 0x08;
|
h->table3_entry_offset = (h->target_subsong - 1) * 0x08;
|
||||||
@ -632,8 +634,9 @@ static bool process_headers(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
h->sample_rate = (int)read_f32(sndh_offset+0x4c,sf);
|
h->sample_rate = (int)read_f32(sndh_offset+0x4c,sf);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x1a: /* Demon's Souls (PS5) */
|
case 0x1a:
|
||||||
case 0x23: /* The Last of Us (PC) */
|
case 0x1c:
|
||||||
|
case 0x23:
|
||||||
h->stream_offset = read_u32(sndh_offset+0x00,sf);
|
h->stream_offset = read_u32(sndh_offset+0x00,sf);
|
||||||
/* rest is part of data, handled later */
|
/* rest is part of data, handled later */
|
||||||
break;
|
break;
|
||||||
@ -1118,6 +1121,7 @@ static bool process_data(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x1a:
|
case 0x1a:
|
||||||
|
case 0x1c:
|
||||||
case 0x23:
|
case 0x23:
|
||||||
if (h->stream_offset == 0xFFFFFFFF) {
|
if (h->stream_offset == 0xFFFFFFFF) {
|
||||||
h->channels = 1;
|
h->channels = 1;
|
||||||
@ -1141,7 +1145,8 @@ static bool process_data(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
stream_name_size = STREAM_NAME_SIZE;
|
stream_name_size = STREAM_NAME_SIZE;
|
||||||
read_string(h->stream_name, stream_name_size, stream_name_offset, sf);
|
read_string(h->stream_name, stream_name_size, stream_name_offset, sf);
|
||||||
|
|
||||||
if (read_u32(info_offset + 0x0c, sf) != 0x01) {
|
/* size check is necessary, otherwise it risks a false positive with the ZLSD version number */
|
||||||
|
if (info_offset + 0x10 > h->data_offset + h->data_size || read_u32(info_offset + 0x0c, sf) != 0x01) {
|
||||||
h->channels = 1;
|
h->channels = 1;
|
||||||
h->codec = EXTERNAL;
|
h->codec = EXTERNAL;
|
||||||
break;
|
break;
|
||||||
@ -1159,9 +1164,9 @@ static bool process_data(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
h->codec = PCM16;
|
h->codec = PCM16;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* should be split, but 0x1A has no other known codecs yet */
|
/* should be split, but 0x1A/0x1C has no other known codecs yet */
|
||||||
case 0x01: /* ATRAC9 (0x23) */
|
case 0x01: /* ATRAC9 (0x23) */
|
||||||
case 0x03: /* ATRAC9 (0x1A) */
|
case 0x03: /* ATRAC9 (0x1A/0x1C) */
|
||||||
/* 0x00: extradata size (without pre-info, also above) */
|
/* 0x00: extradata size (without pre-info, also above) */
|
||||||
h->atrac9_info = read_u32be(info_offset + 0x04, sf);
|
h->atrac9_info = read_u32be(info_offset + 0x04, sf);
|
||||||
h->num_samples = read_s32(info_offset + 0x08, sf);
|
h->num_samples = read_s32(info_offset + 0x08, sf);
|
||||||
@ -1210,7 +1215,7 @@ static bool process_zlsd(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
int zlsd_subsongs, target_subsong;
|
int zlsd_subsongs, target_subsong;
|
||||||
uint32_t zlsd_table_offset, zlsd_table_entry_offset, stream_offset, stream_name_hash;
|
uint32_t zlsd_table_offset, zlsd_table_entry_offset, stream_name_hash;
|
||||||
read_u32_t read_u32 = h->big_endian ? read_u32be : read_u32le;
|
read_u32_t read_u32 = h->big_endian ? read_u32be : read_u32le;
|
||||||
|
|
||||||
if (read_u32(h->zlsd_offset + 0x00, sf) != get_id32be("DSLZ"))
|
if (read_u32(h->zlsd_offset + 0x00, sf) != get_id32be("DSLZ"))
|
||||||
@ -1219,7 +1224,7 @@ static bool process_zlsd(STREAMFILE* sf, bnk_header_t* h) {
|
|||||||
/* 0x04: version? (1) */
|
/* 0x04: version? (1) */
|
||||||
zlsd_subsongs = read_u32(h->zlsd_offset + 0x08, sf);
|
zlsd_subsongs = read_u32(h->zlsd_offset + 0x08, sf);
|
||||||
/* 0x0c: start (most of the time) */
|
/* 0x0c: start (most of the time) */
|
||||||
/* 0x10: start if 64-bit zlsd_subsongs? seen in SBlk 0x1A */
|
/* 0x10: start if 64-bit zlsd_subsongs? seen in SBlk 0x1A/0x1C */
|
||||||
zlsd_table_offset = read_u32(h->zlsd_offset + 0x0C, sf);
|
zlsd_table_offset = read_u32(h->zlsd_offset + 0x0C, sf);
|
||||||
/* rest: null */
|
/* rest: null */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user