Merge pull request #780 from NicknineTheEagle/sbk

Sbk
This commit is contained in:
NicknineTheEagle 2020-12-09 19:40:50 +03:00 committed by GitHub
commit dda311e696
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 106 additions and 2 deletions

View File

@ -425,6 +425,7 @@ static const char* extension_list[] = {
"sb5", "sb5",
"sb6", "sb6",
"sb7", "sb7",
"sbk",
"sbr", "sbr",
"sbv", "sbv",
"sm0", "sm0",
@ -1319,6 +1320,7 @@ static const meta_info meta_info_list[] = {
{meta_WADY, "Marble WADY header"}, {meta_WADY, "Marble WADY header"},
{meta_DSP_SQEX, "Square Enix DSP header"}, {meta_DSP_SQEX, "Square Enix DSP header"},
{meta_DSP_WIIVOICE, "Koei Tecmo WiiVoice header"}, {meta_DSP_WIIVOICE, "Koei Tecmo WiiVoice header"},
{meta_SBK, "Team17 SBK header"},
}; };
void get_vgmstream_coding_description(VGMSTREAM* vgmstream, char* out, size_t out_size) { void get_vgmstream_coding_description(VGMSTREAM* vgmstream, char* out, size_t out_size) {

View File

@ -227,6 +227,7 @@
<ClCompile Include="meta\mtaf.c" /> <ClCompile Include="meta\mtaf.c" />
<ClCompile Include="meta\ps2_spm.c" /> <ClCompile Include="meta\ps2_spm.c" />
<ClCompile Include="meta\rad.c" /> <ClCompile Include="meta\rad.c" />
<ClCompile Include="meta\sbk.c" />
<ClCompile Include="meta\tgc.c" /> <ClCompile Include="meta\tgc.c" />
<ClCompile Include="meta\vs_str.c" /> <ClCompile Include="meta\vs_str.c" />
<ClCompile Include="meta\ps2_wmus.c" /> <ClCompile Include="meta\ps2_wmus.c" />

View File

@ -1834,5 +1834,8 @@
<ClCompile Include="meta\kat.c"> <ClCompile Include="meta\kat.c">
<Filter>meta\Source Files</Filter> <Filter>meta\Source Files</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="meta\sbk.c">
<Filter>meta\Source Files</Filter>
</ClCompile>
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@ -928,4 +928,6 @@ VGMSTREAM* init_vgmstream_wady(STREAMFILE* sf);
VGMSTREAM* init_vgmstream_cpk(STREAMFILE* sf); VGMSTREAM* init_vgmstream_cpk(STREAMFILE* sf);
VGMSTREAM* init_vgmstream_cpk_memory(STREAMFILE* sf, STREAMFILE* sf_acb); VGMSTREAM* init_vgmstream_cpk_memory(STREAMFILE* sf, STREAMFILE* sf_acb);
VGMSTREAM *init_vgmstream_sbk(STREAMFILE *sf);
#endif /*_META_H*/ #endif /*_META_H*/

95
src/meta/sbk.c Normal file
View File

@ -0,0 +1,95 @@
#include "meta.h"
#include "../coding/coding.h"
/* .SBK - from Addiction Pinball (PC) */
VGMSTREAM *init_vgmstream_sbk(STREAMFILE *sf) {
VGMSTREAM *vgmstream = NULL;
uint32_t sound_offset, sound_size, padding_size, sample_rate;
uint16_t format, channels, block_size, bps;
off_t table_offset, data_offset, entry_offset, start_offset;
size_t table_size, data_size;
int target_subsong = sf->stream_index, total_subsongs, loop_flag;
/* checks */
if (!check_extensions(sf, "sbk"))
goto fail;
/* check header */
if (read_u32be(0x00, sf) != 0x52494646) /* "RIFF" */
goto fail;
if (read_u32be(0x08, sf) != 0x53424E4B) /* "SBNK" */
goto fail;
if (!find_chunk_le(sf, 0x57415649, 0x0c, 0, &table_offset, &table_size)) /* "WAVI" */
goto fail;
total_subsongs = table_size / 0x38;
if (target_subsong == 0) target_subsong = 1;
if (target_subsong < 0 || target_subsong > total_subsongs || total_subsongs < 1)
goto fail;
entry_offset = table_offset + 0x38 * (target_subsong - 1);
sound_offset = read_u32le(entry_offset + 0x04, sf);
sound_size = read_u32le(entry_offset + 0x00, sf);
padding_size = read_u32le(entry_offset + 0x10, sf);
sound_offset += padding_size;
sound_size -= padding_size;
/* read fmt chunk */
format = read_u16le(entry_offset + 0x1c, sf);
channels = read_u16le(entry_offset + 0x1e, sf);
sample_rate = read_u32le(entry_offset + 0x20, sf);
block_size = read_u16le(entry_offset + 0x28, sf);
bps = read_u16le(entry_offset + 0x2a, sf);
loop_flag = 0;
/* build the VGMSTREAM */
vgmstream = allocate_vgmstream(channels, loop_flag);
if (!vgmstream) goto fail;
/* fill in the vital statistics */
vgmstream->meta_type = meta_SBK;
vgmstream->sample_rate = sample_rate;
vgmstream->stream_size = sound_size;
vgmstream->num_streams = total_subsongs;
switch (format) {
case 0x01: /* PCM */
if (bps != 8 && bps != 16)
goto fail;
vgmstream->coding_type = (bps == 8) ? coding_PCM8_U : coding_PCM16LE;
vgmstream->layout_type = layout_interleave;
vgmstream->interleave_block_size = (bps == 8) ? 0x01 : 0x02;
vgmstream->num_samples = pcm_bytes_to_samples(sound_size, channels, bps);
if (!find_chunk_le(sf, 0x57415644, 0x0c, 0, &data_offset, &data_size)) /* "WAVD" */
goto fail;
start_offset = data_offset + sound_offset;
break;
case 0x11: /* Microsoft IMA */
vgmstream->coding_type = coding_MS_IMA;
vgmstream->layout_type = layout_none;
vgmstream->interleave_block_size = block_size;
vgmstream->num_samples = ms_ima_bytes_to_samples(sound_size, block_size, channels);
if (!find_chunk_le(sf, 0x53574156, 0x0c, 0, &data_offset, &data_size)) /* "SWAV" */
goto fail;
start_offset = data_offset + sound_offset;
break;
default:
goto fail;
}
if (!vgmstream_open_stream(vgmstream, sf, start_offset))
goto fail;
return vgmstream;
fail:
close_vgmstream(vgmstream);
return NULL;
}

View File

@ -1868,7 +1868,7 @@ static int parse_type_audio(ubi_sb_header* sb, off_t offset, STREAMFILE* sf) {
/* apparently, there may also be other subblocks based on various flags but they were not seen so far */ /* apparently, there may also be other subblocks based on various flags but they were not seen so far */
if (sb->cfg.audio_subblock_flag && sb->cfg.audio_subblock_and) { if (sb->cfg.audio_subblock_flag && sb->cfg.audio_subblock_and) {
/* flag probably means "hardware decoded" */ /* flag probably means "software decoded" */
int subblock_flag = read_32bit(offset + sb->cfg.audio_subblock_flag, sf) & sb->cfg.audio_subblock_and; int subblock_flag = read_32bit(offset + sb->cfg.audio_subblock_flag, sf) & sb->cfg.audio_subblock_and;
sb->subblock_id = (!subblock_flag) ? 0 : 1; sb->subblock_id = (!subblock_flag) ? 0 : 1;
@ -3039,7 +3039,6 @@ static int config_sb_version(ubi_sb_header* sb, STREAMFILE* sf) {
config_sb_sequence(sb, 0x2c, 0x1c); config_sb_sequence(sb, 0x2c, 0x1c);
/* no layers */ /* no layers */
return 1; return 1;
} }

View File

@ -512,6 +512,7 @@ VGMSTREAM* (*init_vgmstream_functions[])(STREAMFILE* sf) = {
init_vgmstream_xws, init_vgmstream_xws,
init_vgmstream_cpk, init_vgmstream_cpk,
init_vgmstream_opus_nsopus, init_vgmstream_opus_nsopus,
init_vgmstream_sbk,
/* lowest priority metas (should go after all metas, and TXTH should go before raw formats) */ /* lowest priority metas (should go after all metas, and TXTH should go before raw formats) */
init_vgmstream_txth, /* proper parsers should supersede TXTH, once added */ init_vgmstream_txth, /* proper parsers should supersede TXTH, once added */

View File

@ -741,6 +741,7 @@ typedef enum {
meta_WADY, meta_WADY,
meta_DSP_SQEX, meta_DSP_SQEX,
meta_DSP_WIIVOICE, meta_DSP_WIIVOICE,
meta_SBK,
} meta_t; } meta_t;
/* standard WAVEFORMATEXTENSIBLE speaker positions */ /* standard WAVEFORMATEXTENSIBLE speaker positions */