From 099b54b3b011189083f557829988e88565a22b64 Mon Sep 17 00:00:00 2001 From: Tomek Malesinski Date: Tue, 28 Aug 2007 01:15:54 +0200 Subject: [PATCH] TMP: add special case to vorbis_book_decodevv_add for 2ch and even book->dim --- apps/codecs/Tremor/codebook.c | 54 ++++++++++++++++++++++++++++++++++++++++- 1 files changed, 53 insertions(+), 1 deletions(-) diff --git a/apps/codecs/Tremor/codebook.c b/apps/codecs/Tremor/codebook.c index 1287a95..6056206 100644 --- a/apps/codecs/Tremor/codebook.c +++ b/apps/codecs/Tremor/codebook.c @@ -199,7 +199,7 @@ STIN long decode_packed_entry_number(codebook *book, return(-1); } -static inline long decode_packed_block(codebook *book, oggpack_buffer *b, +static long decode_packed_block(codebook *book, oggpack_buffer *b, long *buf, int n){ long *bufptr = buf; long *bufend = buf + n; @@ -399,6 +399,55 @@ long vorbis_book_decodev_set(codebook *book,ogg_int32_t *a, return(0); } +static long vorbis_book_decodevv_add_2ch_even(codebook *book,ogg_int32_t **a, + long offset,oggpack_buffer *b, + int n,int point){ + long i,j,k,chunk,read; + int shift=point-book->binarypoint; + long entries[32]; + ogg_int32_t *p0 = &(a[0][offset]); + ogg_int32_t *p1 = &(a[1][offset]); + + if(shift>=0){ + + for(i=0;idim>(n-i)*2) + chunk=((n-i)*2+book->dim-1)/book->dim; + read = decode_packed_block(book,b,entries,chunk); + for(k=0;kvaluelist+entries[k]*book->dim; + const ogg_int32_t *u = t+book->dim; + do{ + *p0++ += *t++>>shift; + *p1++ += *t++>>shift; + }while(tdim/2; + } + }else{ + shift = -shift; + for(i=0;idim>(n-i)*2) + chunk=((n-i)*2+book->dim-1)/book->dim; + read = decode_packed_block(book,b,entries,chunk); + for(k=0;kvaluelist+entries[k]*book->dim; + const ogg_int32_t *u = t+book->dim; + do{ + *p0++ += *t++<dim/2; + } + } + return(0); +} + long vorbis_book_decodevv_add(codebook *book,ogg_int32_t **a, long offset,int ch, oggpack_buffer *b,int n,int point){ @@ -408,6 +457,9 @@ long vorbis_book_decodevv_add(codebook *book,ogg_int32_t **a, int shift=point-book->binarypoint; long entries[32]; + if (!(book->dim&1) && ch==2) + return vorbis_book_decodevv_add_2ch_even(book,a,offset,b,n,point); + if(shift>=0){ for(i=offset;i