summaryrefslogtreecommitdiff
path: root/block.c
diff options
context:
space:
mode:
authorTim Terriberry <tterribe@xiph.org>2010-10-14 01:09:06 +0000
committerTim Terriberry <tterribe@xiph.org>2010-10-14 01:09:06 +0000
commitff67c8b500127406b0b89be773cd3e186cde0cf8 (patch)
treeb368bfab0df172874447134fb6d3669e9017c15a /block.c
parent28854b5669212379c190640063be53b19f12ab88 (diff)
downloadtremor-ff67c8b500127406b0b89be773cd3e186cde0cf8.tar.gz
Port r16328 and r16330 from libvorbis.
ivorbisfile_example.c ignores an error code and plows ahead blindly if libvorbisidec reports the current bitstream section is bad (OV_EBADLINK). Retrying after the error crashes libvorbisidec due to the unitialized state. git-svn-id: https://svn.xiph.org/trunk/Tremor@17526 0101bb08-14d6-0310-b084-bc0e0c8e3800
Diffstat (limited to 'block.c')
-rw-r--r--block.c25
1 files changed, 18 insertions, 7 deletions
diff --git a/block.c b/block.c
index b41482c..4fff4ad 100644
--- a/block.c
+++ b/block.c
@@ -161,14 +161,16 @@ static int _vds_init(vorbis_dsp_state *v,vorbis_info *vi){
b->window[1]=_vorbis_window(0,ci->blocksizes[1]/2);
/* finish the codebooks */
- if(!ci->fullbooks){
+ if(!ci->fullbooks)
ci->fullbooks=(codebook *)_ogg_calloc(ci->books,sizeof(*ci->fullbooks));
- for(i=0;i<ci->books;i++){
- vorbis_book_init_decode(ci->fullbooks+i,ci->book_param[i]);
- /* decode codebooks are now standalone after init */
- vorbis_staticbook_destroy(ci->book_param[i]);
- ci->book_param[i]=NULL;
- }
+ for(i=0;i<ci->books;i++){
+ if(ci->book_param[i]==NULL)
+ goto abort_books;
+ if(vorbis_book_init_decode(ci->fullbooks+i,ci->book_param[i]))
+ goto abort_books;
+ /* decode codebooks are now standalone after init */
+ vorbis_staticbook_destroy(ci->book_param[i]);
+ ci->book_param[i]=NULL;
}
v->pcm_storage=ci->blocksizes[1];
@@ -191,6 +193,15 @@ static int _vds_init(vorbis_dsp_state *v,vorbis_info *vi){
ci->map_param[mapnum]);
}
return 0;
+abort_books:
+ for(i=0;i<ci->books;i++){
+ if(ci->book_param[i]!=NULL){
+ vorbis_staticbook_destroy(ci->book_param[i]);
+ ci->book_param[i]=NULL;
+ }
+ }
+ vorbis_dsp_clear(v);
+ return -1;
}
int vorbis_synthesis_restart(vorbis_dsp_state *v){