diff options
author | Alexey Yakovenko <waker@users.sourceforge.net> | 2014-06-23 21:59:50 +0200 |
---|---|---|
committer | Alexey Yakovenko <waker@users.sourceforge.net> | 2014-06-23 21:59:50 +0200 |
commit | a0d3c07df36f17a0ce22cc81ce9770dc9ab6549e (patch) | |
tree | e22a702c4b6e4f1f50d74361b27b3682b95a81cc /plugins | |
parent | 7167ecb58fb9b4d1de580344a625c7cf66d62bbc (diff) |
flac: ignore embedded flac cuesheet metadata block if it's out of file bounds
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/flac/flac.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/plugins/flac/flac.c b/plugins/flac/flac.c index 977298b0..0332ecc3 100644 --- a/plugins/flac/flac.c +++ b/plugins/flac/flac.c @@ -620,6 +620,15 @@ cflac_init_metadata_callback(const FLAC__StreamDecoder *decoder, const FLAC__Str static DB_playItem_t * cflac_insert_with_embedded_cue (ddb_playlist_t *plt, DB_playItem_t *after, DB_playItem_t *origin, const FLAC__StreamMetadata_CueSheet *cuesheet, int totalsamples, int samplerate) { DB_playItem_t *ins = after; + + // first check if cuesheet is matching the data + for (int i = 0; i < cuesheet->num_tracks-1; i++) { + if (cuesheet->tracks[i].offset + cuesheet->tracks[i+1].offset-1 > totalsamples) { + fprintf (stderr, "The flac %s has invalid embedded cuesheet. You should remove it using metaflac.\n", deadbeef->pl_find_meta_raw (origin, ":URI")); + return NULL; + } + } + for (int i = 0; i < cuesheet->num_tracks-1; i++) { const char *uri = deadbeef->pl_find_meta_raw (origin, ":URI"); const char *dec = deadbeef->pl_find_meta_raw (origin, ":DECODER"); |