|
@@ -1,17 +1,17 @@
|
|
|
/********************************************************************
|
|
|
* *
|
|
|
- * THIS FILE IS PART OF THE OggVorbis SOFTWARE CODEC SOURCE CODE. *
|
|
|
+ * THIS FILE IS PART OF THE Ogg CONTAINER SOURCE CODE. *
|
|
|
* USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
|
|
|
* GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
|
|
|
* IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
|
|
|
* *
|
|
|
- * THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2002 *
|
|
|
+ * THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2010 *
|
|
|
* by the Xiph.Org Foundation http://www.xiph.org/ *
|
|
|
* *
|
|
|
********************************************************************
|
|
|
|
|
|
function: packing variable sized words into an octet stream
|
|
|
- last mod: $Id: bitwise.c 7675 2004-09-01 00:34:39Z xiphmont $
|
|
|
+ last mod: $Id: bitwise.c 18051 2011-08-04 17:56:39Z giles $
|
|
|
|
|
|
********************************************************************/
|
|
|
|
|
@@ -20,6 +20,7 @@
|
|
|
|
|
|
#include <string.h>
|
|
|
#include <stdlib.h>
|
|
|
+#include <limits.h>
|
|
|
#include <ogg/ogg.h>
|
|
|
|
|
|
#define BUFFER_INCREMENT 256
|
|
@@ -47,49 +48,68 @@ void oggpackB_writeinit(oggpack_buffer *b){
|
|
|
oggpack_writeinit(b);
|
|
|
}
|
|
|
|
|
|
+int oggpack_writecheck(oggpack_buffer *b){
|
|
|
+ if(!b->ptr || !b->storage)return -1;
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+int oggpackB_writecheck(oggpack_buffer *b){
|
|
|
+ return oggpack_writecheck(b);
|
|
|
+}
|
|
|
+
|
|
|
void oggpack_writetrunc(oggpack_buffer *b,long bits){
|
|
|
long bytes=bits>>3;
|
|
|
- bits-=bytes*8;
|
|
|
- b->ptr=b->buffer+bytes;
|
|
|
- b->endbit=bits;
|
|
|
- b->endbyte=bytes;
|
|
|
- *b->ptr&=mask[bits];
|
|
|
+ if(b->ptr){
|
|
|
+ bits-=bytes*8;
|
|
|
+ b->ptr=b->buffer+bytes;
|
|
|
+ b->endbit=bits;
|
|
|
+ b->endbyte=bytes;
|
|
|
+ *b->ptr&=mask[bits];
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
void oggpackB_writetrunc(oggpack_buffer *b,long bits){
|
|
|
long bytes=bits>>3;
|
|
|
- bits-=bytes*8;
|
|
|
- b->ptr=b->buffer+bytes;
|
|
|
- b->endbit=bits;
|
|
|
- b->endbyte=bytes;
|
|
|
- *b->ptr&=mask8B[bits];
|
|
|
+ if(b->ptr){
|
|
|
+ bits-=bytes*8;
|
|
|
+ b->ptr=b->buffer+bytes;
|
|
|
+ b->endbit=bits;
|
|
|
+ b->endbyte=bytes;
|
|
|
+ *b->ptr&=mask8B[bits];
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
/* Takes only up to 32 bits. */
|
|
|
void oggpack_write(oggpack_buffer *b,unsigned long value,int bits){
|
|
|
- if(b->endbyte+4>=b->storage){
|
|
|
- b->buffer=_ogg_realloc(b->buffer,b->storage+BUFFER_INCREMENT);
|
|
|
+ if(bits<0 || bits>32) goto err;
|
|
|
+ if(b->endbyte>=b->storage-4){
|
|
|
+ void *ret;
|
|
|
+ if(!b->ptr)return;
|
|
|
+ if(b->storage>LONG_MAX-BUFFER_INCREMENT) goto err;
|
|
|
+ ret=_ogg_realloc(b->buffer,b->storage+BUFFER_INCREMENT);
|
|
|
+ if(!ret) goto err;
|
|
|
+ b->buffer=ret;
|
|
|
b->storage+=BUFFER_INCREMENT;
|
|
|
b->ptr=b->buffer+b->endbyte;
|
|
|
}
|
|
|
|
|
|
- value&=mask[bits];
|
|
|
+ value&=mask[bits];
|
|
|
bits+=b->endbit;
|
|
|
|
|
|
- b->ptr[0]|=value<<b->endbit;
|
|
|
-
|
|
|
+ b->ptr[0]|=value<<b->endbit;
|
|
|
+
|
|
|
if(bits>=8){
|
|
|
b->ptr[1]=(unsigned char)(value>>(8-b->endbit));
|
|
|
if(bits>=16){
|
|
|
b->ptr[2]=(unsigned char)(value>>(16-b->endbit));
|
|
|
if(bits>=24){
|
|
|
- b->ptr[3]=(unsigned char)(value>>(24-b->endbit));
|
|
|
- if(bits>=32){
|
|
|
- if(b->endbit)
|
|
|
- b->ptr[4]=(unsigned char)(value>>(32-b->endbit));
|
|
|
- else
|
|
|
- b->ptr[4]=0;
|
|
|
- }
|
|
|
+ b->ptr[3]=(unsigned char)(value>>(24-b->endbit));
|
|
|
+ if(bits>=32){
|
|
|
+ if(b->endbit)
|
|
|
+ b->ptr[4]=(unsigned char)(value>>(32-b->endbit));
|
|
|
+ else
|
|
|
+ b->ptr[4]=0;
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -97,33 +117,42 @@ void oggpack_write(oggpack_buffer *b,unsigned long value,int bits){
|
|
|
b->endbyte+=bits/8;
|
|
|
b->ptr+=bits/8;
|
|
|
b->endbit=bits&7;
|
|
|
+ return;
|
|
|
+ err:
|
|
|
+ oggpack_writeclear(b);
|
|
|
}
|
|
|
|
|
|
/* Takes only up to 32 bits. */
|
|
|
void oggpackB_write(oggpack_buffer *b,unsigned long value,int bits){
|
|
|
- if(b->endbyte+4>=b->storage){
|
|
|
- b->buffer=_ogg_realloc(b->buffer,b->storage+BUFFER_INCREMENT);
|
|
|
+ if(bits<0 || bits>32) goto err;
|
|
|
+ if(b->endbyte>=b->storage-4){
|
|
|
+ void *ret;
|
|
|
+ if(!b->ptr)return;
|
|
|
+ if(b->storage>LONG_MAX-BUFFER_INCREMENT) goto err;
|
|
|
+ ret=_ogg_realloc(b->buffer,b->storage+BUFFER_INCREMENT);
|
|
|
+ if(!ret) goto err;
|
|
|
+ b->buffer=ret;
|
|
|
b->storage+=BUFFER_INCREMENT;
|
|
|
b->ptr=b->buffer+b->endbyte;
|
|
|
}
|
|
|
|
|
|
- value=(value&mask[bits])<<(32-bits);
|
|
|
+ value=(value&mask[bits])<<(32-bits);
|
|
|
bits+=b->endbit;
|
|
|
|
|
|
- b->ptr[0]|=value>>(24+b->endbit);
|
|
|
-
|
|
|
+ b->ptr[0]|=value>>(24+b->endbit);
|
|
|
+
|
|
|
if(bits>=8){
|
|
|
b->ptr[1]=(unsigned char)(value>>(16+b->endbit));
|
|
|
if(bits>=16){
|
|
|
b->ptr[2]=(unsigned char)(value>>(8+b->endbit));
|
|
|
if(bits>=24){
|
|
|
- b->ptr[3]=(unsigned char)(value>>(b->endbit));
|
|
|
- if(bits>=32){
|
|
|
- if(b->endbit)
|
|
|
- b->ptr[4]=(unsigned char)(value<<(8-b->endbit));
|
|
|
- else
|
|
|
- b->ptr[4]=0;
|
|
|
- }
|
|
|
+ b->ptr[3]=(unsigned char)(value>>(b->endbit));
|
|
|
+ if(bits>=32){
|
|
|
+ if(b->endbit)
|
|
|
+ b->ptr[4]=(unsigned char)(value<<(8-b->endbit));
|
|
|
+ else
|
|
|
+ b->ptr[4]=0;
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -131,6 +160,9 @@ void oggpackB_write(oggpack_buffer *b,unsigned long value,int bits){
|
|
|
b->endbyte+=bits/8;
|
|
|
b->ptr+=bits/8;
|
|
|
b->endbit=bits&7;
|
|
|
+ return;
|
|
|
+ err:
|
|
|
+ oggpack_writeclear(b);
|
|
|
}
|
|
|
|
|
|
void oggpack_writealign(oggpack_buffer *b){
|
|
@@ -146,12 +178,12 @@ void oggpackB_writealign(oggpack_buffer *b){
|
|
|
}
|
|
|
|
|
|
static void oggpack_writecopy_helper(oggpack_buffer *b,
|
|
|
- void *source,
|
|
|
- long bits,
|
|
|
- void (*w)(oggpack_buffer *,
|
|
|
- unsigned long,
|
|
|
- int),
|
|
|
- int msb){
|
|
|
+ void *source,
|
|
|
+ long bits,
|
|
|
+ void (*w)(oggpack_buffer *,
|
|
|
+ unsigned long,
|
|
|
+ int),
|
|
|
+ int msb){
|
|
|
unsigned char *ptr=(unsigned char *)source;
|
|
|
|
|
|
long bytes=bits/8;
|
|
@@ -161,12 +193,17 @@ static void oggpack_writecopy_helper(oggpack_buffer *b,
|
|
|
int i;
|
|
|
/* unaligned copy. Do it the hard way. */
|
|
|
for(i=0;i<bytes;i++)
|
|
|
- w(b,(unsigned long)(ptr[i]),8);
|
|
|
+ w(b,(unsigned long)(ptr[i]),8);
|
|
|
}else{
|
|
|
/* aligned block copy */
|
|
|
if(b->endbyte+bytes+1>=b->storage){
|
|
|
+ void *ret;
|
|
|
+ if(!b->ptr) goto err;
|
|
|
+ if(b->endbyte+bytes+BUFFER_INCREMENT>b->storage) goto err;
|
|
|
b->storage=b->endbyte+bytes+BUFFER_INCREMENT;
|
|
|
- b->buffer=_ogg_realloc(b->buffer,b->storage);
|
|
|
+ ret=_ogg_realloc(b->buffer,b->storage);
|
|
|
+ if(!ret) goto err;
|
|
|
+ b->buffer=ret;
|
|
|
b->ptr=b->buffer+b->endbyte;
|
|
|
}
|
|
|
|
|
@@ -178,10 +215,13 @@ static void oggpack_writecopy_helper(oggpack_buffer *b,
|
|
|
}
|
|
|
if(bits){
|
|
|
if(msb)
|
|
|
- w(b,(unsigned long)(ptr[bytes]>>(8-bits)),bits);
|
|
|
+ w(b,(unsigned long)(ptr[bytes]>>(8-bits)),bits);
|
|
|
else
|
|
|
- w(b,(unsigned long)(ptr[bytes]),bits);
|
|
|
+ w(b,(unsigned long)(ptr[bytes]),bits);
|
|
|
}
|
|
|
+ return;
|
|
|
+ err:
|
|
|
+ oggpack_writeclear(b);
|
|
|
}
|
|
|
|
|
|
void oggpack_writecopy(oggpack_buffer *b,void *source,long bits){
|
|
@@ -193,6 +233,7 @@ void oggpackB_writecopy(oggpack_buffer *b,void *source,long bits){
|
|
|
}
|
|
|
|
|
|
void oggpack_reset(oggpack_buffer *b){
|
|
|
+ if(!b->ptr)return;
|
|
|
b->ptr=b->buffer;
|
|
|
b->buffer[0]=0;
|
|
|
b->endbit=b->endbyte=0;
|
|
@@ -203,7 +244,7 @@ void oggpackB_reset(oggpack_buffer *b){
|
|
|
}
|
|
|
|
|
|
void oggpack_writeclear(oggpack_buffer *b){
|
|
|
- _ogg_free(b->buffer);
|
|
|
+ if(b->buffer)_ogg_free(b->buffer);
|
|
|
memset(b,0,sizeof(*b));
|
|
|
}
|
|
|
|
|
@@ -224,24 +265,29 @@ void oggpackB_readinit(oggpack_buffer *b,unsigned char *buf,int bytes){
|
|
|
/* Read in bits without advancing the bitptr; bits <= 32 */
|
|
|
long oggpack_look(oggpack_buffer *b,int bits){
|
|
|
unsigned long ret;
|
|
|
- unsigned long m=mask[bits];
|
|
|
+ unsigned long m;
|
|
|
|
|
|
+ if(bits<0 || bits>32) return -1;
|
|
|
+ m=mask[bits];
|
|
|
bits+=b->endbit;
|
|
|
|
|
|
- if(b->endbyte+4>=b->storage){
|
|
|
+ if(b->endbyte >= b->storage-4){
|
|
|
/* not the main path */
|
|
|
- if(b->endbyte*8+bits>b->storage*8)return(-1);
|
|
|
+ if(b->endbyte > b->storage-((bits+7)>>3)) return -1;
|
|
|
+ /* special case to avoid reading b->ptr[0], which might be past the end of
|
|
|
+ the buffer; also skips some useless accounting */
|
|
|
+ else if(!bits)return(0L);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
ret=b->ptr[0]>>b->endbit;
|
|
|
if(bits>8){
|
|
|
- ret|=b->ptr[1]<<(8-b->endbit);
|
|
|
+ ret|=b->ptr[1]<<(8-b->endbit);
|
|
|
if(bits>16){
|
|
|
- ret|=b->ptr[2]<<(16-b->endbit);
|
|
|
+ ret|=b->ptr[2]<<(16-b->endbit);
|
|
|
if(bits>24){
|
|
|
- ret|=b->ptr[3]<<(24-b->endbit);
|
|
|
- if(bits>32 && b->endbit)
|
|
|
- ret|=b->ptr[4]<<(32-b->endbit);
|
|
|
+ ret|=b->ptr[3]<<(24-b->endbit);
|
|
|
+ if(bits>32 && b->endbit)
|
|
|
+ ret|=b->ptr[4]<<(32-b->endbit);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -253,22 +299,26 @@ long oggpackB_look(oggpack_buffer *b,int bits){
|
|
|
unsigned long ret;
|
|
|
int m=32-bits;
|
|
|
|
|
|
+ if(m<0 || m>32) return -1;
|
|
|
bits+=b->endbit;
|
|
|
|
|
|
- if(b->endbyte+4>=b->storage){
|
|
|
+ if(b->endbyte >= b->storage-4){
|
|
|
/* not the main path */
|
|
|
- if(b->endbyte*8+bits>b->storage*8)return(-1);
|
|
|
+ if(b->endbyte > b->storage-((bits+7)>>3)) return -1;
|
|
|
+ /* special case to avoid reading b->ptr[0], which might be past the end of
|
|
|
+ the buffer; also skips some useless accounting */
|
|
|
+ else if(!bits)return(0L);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
ret=b->ptr[0]<<(24+b->endbit);
|
|
|
if(bits>8){
|
|
|
- ret|=b->ptr[1]<<(16+b->endbit);
|
|
|
+ ret|=b->ptr[1]<<(16+b->endbit);
|
|
|
if(bits>16){
|
|
|
- ret|=b->ptr[2]<<(8+b->endbit);
|
|
|
+ ret|=b->ptr[2]<<(8+b->endbit);
|
|
|
if(bits>24){
|
|
|
- ret|=b->ptr[3]<<(b->endbit);
|
|
|
- if(bits>32 && b->endbit)
|
|
|
- ret|=b->ptr[4]>>(8-b->endbit);
|
|
|
+ ret|=b->ptr[3]<<(b->endbit);
|
|
|
+ if(bits>32 && b->endbit)
|
|
|
+ ret|=b->ptr[4]>>(8-b->endbit);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -287,9 +337,18 @@ long oggpackB_look1(oggpack_buffer *b){
|
|
|
|
|
|
void oggpack_adv(oggpack_buffer *b,int bits){
|
|
|
bits+=b->endbit;
|
|
|
+
|
|
|
+ if(b->endbyte > b->storage-((bits+7)>>3)) goto overflow;
|
|
|
+
|
|
|
b->ptr+=bits/8;
|
|
|
b->endbyte+=bits/8;
|
|
|
b->endbit=bits&7;
|
|
|
+ return;
|
|
|
+
|
|
|
+ overflow:
|
|
|
+ b->ptr=NULL;
|
|
|
+ b->endbyte=b->storage;
|
|
|
+ b->endbit=1;
|
|
|
}
|
|
|
|
|
|
void oggpackB_adv(oggpack_buffer *b,int bits){
|
|
@@ -311,86 +370,95 @@ void oggpackB_adv1(oggpack_buffer *b){
|
|
|
/* bits <= 32 */
|
|
|
long oggpack_read(oggpack_buffer *b,int bits){
|
|
|
long ret;
|
|
|
- unsigned long m=mask[bits];
|
|
|
+ unsigned long m;
|
|
|
|
|
|
+ if(bits<0 || bits>32) goto err;
|
|
|
+ m=mask[bits];
|
|
|
bits+=b->endbit;
|
|
|
|
|
|
- if(b->endbyte+4>=b->storage){
|
|
|
+ if(b->endbyte >= b->storage-4){
|
|
|
/* not the main path */
|
|
|
- ret=-1L;
|
|
|
- if(b->endbyte*8+bits>b->storage*8)goto overflow;
|
|
|
+ if(b->endbyte > b->storage-((bits+7)>>3)) goto overflow;
|
|
|
+ /* special case to avoid reading b->ptr[0], which might be past the end of
|
|
|
+ the buffer; also skips some useless accounting */
|
|
|
+ else if(!bits)return(0L);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
ret=b->ptr[0]>>b->endbit;
|
|
|
if(bits>8){
|
|
|
- ret|=b->ptr[1]<<(8-b->endbit);
|
|
|
+ ret|=b->ptr[1]<<(8-b->endbit);
|
|
|
if(bits>16){
|
|
|
- ret|=b->ptr[2]<<(16-b->endbit);
|
|
|
+ ret|=b->ptr[2]<<(16-b->endbit);
|
|
|
if(bits>24){
|
|
|
- ret|=b->ptr[3]<<(24-b->endbit);
|
|
|
- if(bits>32 && b->endbit){
|
|
|
- ret|=b->ptr[4]<<(32-b->endbit);
|
|
|
- }
|
|
|
+ ret|=b->ptr[3]<<(24-b->endbit);
|
|
|
+ if(bits>32 && b->endbit){
|
|
|
+ ret|=b->ptr[4]<<(32-b->endbit);
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
ret&=m;
|
|
|
-
|
|
|
- overflow:
|
|
|
-
|
|
|
b->ptr+=bits/8;
|
|
|
b->endbyte+=bits/8;
|
|
|
b->endbit=bits&7;
|
|
|
- return(ret);
|
|
|
+ return ret;
|
|
|
+
|
|
|
+ overflow:
|
|
|
+ err:
|
|
|
+ b->ptr=NULL;
|
|
|
+ b->endbyte=b->storage;
|
|
|
+ b->endbit=1;
|
|
|
+ return -1L;
|
|
|
}
|
|
|
|
|
|
/* bits <= 32 */
|
|
|
long oggpackB_read(oggpack_buffer *b,int bits){
|
|
|
long ret;
|
|
|
long m=32-bits;
|
|
|
-
|
|
|
+
|
|
|
+ if(m<0 || m>32) goto err;
|
|
|
bits+=b->endbit;
|
|
|
|
|
|
if(b->endbyte+4>=b->storage){
|
|
|
/* not the main path */
|
|
|
- ret=-1L;
|
|
|
- if(b->endbyte*8+bits>b->storage*8)goto overflow;
|
|
|
+ if(b->endbyte > b->storage-((bits+7)>>3)) goto overflow;
|
|
|
+ /* special case to avoid reading b->ptr[0], which might be past the end of
|
|
|
+ the buffer; also skips some useless accounting */
|
|
|
+ else if(!bits)return(0L);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
ret=b->ptr[0]<<(24+b->endbit);
|
|
|
if(bits>8){
|
|
|
- ret|=b->ptr[1]<<(16+b->endbit);
|
|
|
+ ret|=b->ptr[1]<<(16+b->endbit);
|
|
|
if(bits>16){
|
|
|
- ret|=b->ptr[2]<<(8+b->endbit);
|
|
|
+ ret|=b->ptr[2]<<(8+b->endbit);
|
|
|
if(bits>24){
|
|
|
- ret|=b->ptr[3]<<(b->endbit);
|
|
|
- if(bits>32 && b->endbit)
|
|
|
- ret|=b->ptr[4]>>(8-b->endbit);
|
|
|
+ ret|=b->ptr[3]<<(b->endbit);
|
|
|
+ if(bits>32 && b->endbit)
|
|
|
+ ret|=b->ptr[4]>>(8-b->endbit);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
ret=((ret&0xffffffffUL)>>(m>>1))>>((m+1)>>1);
|
|
|
-
|
|
|
- overflow:
|
|
|
|
|
|
b->ptr+=bits/8;
|
|
|
b->endbyte+=bits/8;
|
|
|
b->endbit=bits&7;
|
|
|
- return(ret);
|
|
|
+ return ret;
|
|
|
+
|
|
|
+ overflow:
|
|
|
+ err:
|
|
|
+ b->ptr=NULL;
|
|
|
+ b->endbyte=b->storage;
|
|
|
+ b->endbit=1;
|
|
|
+ return -1L;
|
|
|
}
|
|
|
|
|
|
long oggpack_read1(oggpack_buffer *b){
|
|
|
long ret;
|
|
|
-
|
|
|
- if(b->endbyte>=b->storage){
|
|
|
- /* not the main path */
|
|
|
- ret=-1L;
|
|
|
- goto overflow;
|
|
|
- }
|
|
|
|
|
|
+ if(b->endbyte >= b->storage) goto overflow;
|
|
|
ret=(b->ptr[0]>>b->endbit)&1;
|
|
|
-
|
|
|
- overflow:
|
|
|
|
|
|
b->endbit++;
|
|
|
if(b->endbit>7){
|
|
@@ -398,21 +466,20 @@ long oggpack_read1(oggpack_buffer *b){
|
|
|
b->ptr++;
|
|
|
b->endbyte++;
|
|
|
}
|
|
|
- return(ret);
|
|
|
+ return ret;
|
|
|
+
|
|
|
+ overflow:
|
|
|
+ b->ptr=NULL;
|
|
|
+ b->endbyte=b->storage;
|
|
|
+ b->endbit=1;
|
|
|
+ return -1L;
|
|
|
}
|
|
|
|
|
|
long oggpackB_read1(oggpack_buffer *b){
|
|
|
long ret;
|
|
|
-
|
|
|
- if(b->endbyte>=b->storage){
|
|
|
- /* not the main path */
|
|
|
- ret=-1L;
|
|
|
- goto overflow;
|
|
|
- }
|
|
|
|
|
|
+ if(b->endbyte >= b->storage) goto overflow;
|
|
|
ret=(b->ptr[0]>>(7-b->endbit))&1;
|
|
|
-
|
|
|
- overflow:
|
|
|
|
|
|
b->endbit++;
|
|
|
if(b->endbit>7){
|
|
@@ -420,7 +487,13 @@ long oggpackB_read1(oggpack_buffer *b){
|
|
|
b->ptr++;
|
|
|
b->endbyte++;
|
|
|
}
|
|
|
- return(ret);
|
|
|
+ return ret;
|
|
|
+
|
|
|
+ overflow:
|
|
|
+ b->ptr=NULL;
|
|
|
+ b->endbyte=b->storage;
|
|
|
+ b->endbit=1;
|
|
|
+ return -1L;
|
|
|
}
|
|
|
|
|
|
long oggpack_bytes(oggpack_buffer *b){
|
|
@@ -438,7 +511,7 @@ long oggpackB_bytes(oggpack_buffer *b){
|
|
|
long oggpackB_bits(oggpack_buffer *b){
|
|
|
return oggpack_bits(b);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
unsigned char *oggpack_get_buffer(oggpack_buffer *b){
|
|
|
return(b->buffer);
|
|
|
}
|
|
@@ -461,7 +534,7 @@ static int ilog(unsigned int v){
|
|
|
}
|
|
|
return(ret);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
oggpack_buffer o;
|
|
|
oggpack_buffer r;
|
|
|
|
|
@@ -493,10 +566,10 @@ void cliptest(unsigned long *b,int vals,int bits,int *comp,int compsize){
|
|
|
report("looked at incorrect value!\n");
|
|
|
if(tbit==1)
|
|
|
if(oggpack_look1(&r)!=(b[i]&mask[tbit]))
|
|
|
- report("looked at single bit incorrect value!\n");
|
|
|
+ report("looked at single bit incorrect value!\n");
|
|
|
if(tbit==1){
|
|
|
if(oggpack_read1(&r)!=(b[i]&mask[tbit]))
|
|
|
- report("read incorrect single bit value!\n");
|
|
|
+ report("read incorrect single bit value!\n");
|
|
|
}else{
|
|
|
if(oggpack_read(&r,tbit)!=(b[i]&mask[tbit]))
|
|
|
report("read incorrect value!\n");
|
|
@@ -508,7 +581,7 @@ void cliptest(unsigned long *b,int vals,int bits,int *comp,int compsize){
|
|
|
void cliptestB(unsigned long *b,int vals,int bits,int *comp,int compsize){
|
|
|
long bytes,i;
|
|
|
unsigned char *buffer;
|
|
|
-
|
|
|
+
|
|
|
oggpackB_reset(&o);
|
|
|
for(i=0;i<vals;i++)
|
|
|
oggpackB_write(&o,b[i],bits?bits:ilog(b[i]));
|
|
@@ -528,10 +601,10 @@ void cliptestB(unsigned long *b,int vals,int bits,int *comp,int compsize){
|
|
|
report("looked at incorrect value!\n");
|
|
|
if(tbit==1)
|
|
|
if(oggpackB_look1(&r)!=(b[i]&mask[tbit]))
|
|
|
- report("looked at single bit incorrect value!\n");
|
|
|
+ report("looked at single bit incorrect value!\n");
|
|
|
if(tbit==1){
|
|
|
if(oggpackB_read1(&r)!=(b[i]&mask[tbit]))
|
|
|
- report("read incorrect single bit value!\n");
|
|
|
+ report("read incorrect single bit value!\n");
|
|
|
}else{
|
|
|
if(oggpackB_read(&r,tbit)!=(b[i]&mask[tbit]))
|
|
|
report("read incorrect value!\n");
|
|
@@ -569,8 +642,8 @@ int main(void){
|
|
|
34,242,223,136,35,222,211,86,171,50,225,135,214,75,172,
|
|
|
223,4};
|
|
|
static int oneB[33]={150,101,131,33,203,15,204,216,105,193,156,65,84,85,222,
|
|
|
- 8,139,145,227,126,34,55,244,171,85,100,39,195,173,18,
|
|
|
- 245,251,128};
|
|
|
+ 8,139,145,227,126,34,55,244,171,85,100,39,195,173,18,
|
|
|
+ 245,251,128};
|
|
|
|
|
|
int twosize=6;
|
|
|
static int two[6]={61,255,255,251,231,29};
|
|
@@ -582,25 +655,25 @@ int main(void){
|
|
|
58,135,196,61,55,129,183,54,101,100,170,37,127,126,10,
|
|
|
100,52,4,14,18,86,77,1};
|
|
|
static int threeB[54]={206,128,42,153,57,8,183,251,13,89,36,30,32,144,183,
|
|
|
- 130,59,240,121,59,85,223,19,228,180,134,33,107,74,98,
|
|
|
- 233,253,196,135,63,2,110,114,50,155,90,127,37,170,104,
|
|
|
- 200,20,254,4,58,106,176,144,0};
|
|
|
+ 130,59,240,121,59,85,223,19,228,180,134,33,107,74,98,
|
|
|
+ 233,253,196,135,63,2,110,114,50,155,90,127,37,170,104,
|
|
|
+ 200,20,254,4,58,106,176,144,0};
|
|
|
|
|
|
int foursize=38;
|
|
|
static int four[38]={18,6,163,252,97,194,104,131,32,1,7,82,137,42,129,11,72,
|
|
|
132,60,220,112,8,196,109,64,179,86,9,137,195,208,122,169,
|
|
|
28,2,133,0,1};
|
|
|
static int fourB[38]={36,48,102,83,243,24,52,7,4,35,132,10,145,21,2,93,2,41,
|
|
|
- 1,219,184,16,33,184,54,149,170,132,18,30,29,98,229,67,
|
|
|
- 129,10,4,32};
|
|
|
+ 1,219,184,16,33,184,54,149,170,132,18,30,29,98,229,67,
|
|
|
+ 129,10,4,32};
|
|
|
|
|
|
int fivesize=45;
|
|
|
static int five[45]={169,2,126,139,144,172,30,4,80,72,240,59,130,218,73,62,
|
|
|
241,24,210,44,4,20,0,248,116,49,135,100,110,130,181,169,
|
|
|
84,75,159,2,1,0,132,192,8,0,0,18,22};
|
|
|
static int fiveB[45]={1,84,145,111,245,100,128,8,56,36,40,71,126,78,213,226,
|
|
|
- 124,105,12,0,133,128,0,162,233,242,67,152,77,205,77,
|
|
|
- 172,150,169,129,79,128,0,6,4,32,0,27,9,0};
|
|
|
+ 124,105,12,0,133,128,0,162,233,242,67,152,77,205,77,
|
|
|
+ 172,150,169,129,79,128,0,6,4,32,0,27,9,0};
|
|
|
|
|
|
int sixsize=7;
|
|
|
static int six[7]={17,177,170,242,169,19,148};
|
|
@@ -633,7 +706,7 @@ int main(void){
|
|
|
if(oggpack_look(&r,32)==-1)report("out of data. failed!");
|
|
|
if(oggpack_look(&r,32)!=large[i]){
|
|
|
fprintf(stderr,"%ld != %ld (%lx!=%lx):",oggpack_look(&r,32),large[i],
|
|
|
- oggpack_look(&r,32),large[i]);
|
|
|
+ oggpack_look(&r,32),large[i]);
|
|
|
report("read incorrect value!\n");
|
|
|
}
|
|
|
oggpack_adv(&r,32);
|
|
@@ -654,7 +727,7 @@ int main(void){
|
|
|
fprintf(stderr,"ok.");
|
|
|
|
|
|
fprintf(stderr,"\nTesting read past end (LSb): ");
|
|
|
- oggpack_readinit(&r,"\0\0\0\0\0\0\0\0",8);
|
|
|
+ oggpack_readinit(&r,(unsigned char *)"\0\0\0\0\0\0\0\0",8);
|
|
|
for(i=0;i<64;i++){
|
|
|
if(oggpack_read(&r,1)!=0){
|
|
|
fprintf(stderr,"failed; got -1 prematurely.\n");
|
|
@@ -666,7 +739,7 @@ int main(void){
|
|
|
fprintf(stderr,"failed; read past end without -1.\n");
|
|
|
exit(1);
|
|
|
}
|
|
|
- oggpack_readinit(&r,"\0\0\0\0\0\0\0\0",8);
|
|
|
+ oggpack_readinit(&r,(unsigned char *)"\0\0\0\0\0\0\0\0",8);
|
|
|
if(oggpack_read(&r,30)!=0 || oggpack_read(&r,16)!=0){
|
|
|
fprintf(stderr,"failed 2; got -1 prematurely.\n");
|
|
|
exit(1);
|
|
@@ -719,7 +792,7 @@ int main(void){
|
|
|
if(oggpackB_look(&r,32)==-1)report("out of data. failed!");
|
|
|
if(oggpackB_look(&r,32)!=large[i]){
|
|
|
fprintf(stderr,"%ld != %ld (%lx!=%lx):",oggpackB_look(&r,32),large[i],
|
|
|
- oggpackB_look(&r,32),large[i]);
|
|
|
+ oggpackB_look(&r,32),large[i]);
|
|
|
report("read incorrect value!\n");
|
|
|
}
|
|
|
oggpackB_adv(&r,32);
|
|
@@ -740,7 +813,7 @@ int main(void){
|
|
|
fprintf(stderr,"ok.");
|
|
|
|
|
|
fprintf(stderr,"\nTesting read past end (MSb): ");
|
|
|
- oggpackB_readinit(&r,"\0\0\0\0\0\0\0\0",8);
|
|
|
+ oggpackB_readinit(&r,(unsigned char *)"\0\0\0\0\0\0\0\0",8);
|
|
|
for(i=0;i<64;i++){
|
|
|
if(oggpackB_read(&r,1)!=0){
|
|
|
fprintf(stderr,"failed; got -1 prematurely.\n");
|
|
@@ -752,7 +825,7 @@ int main(void){
|
|
|
fprintf(stderr,"failed; read past end without -1.\n");
|
|
|
exit(1);
|
|
|
}
|
|
|
- oggpackB_readinit(&r,"\0\0\0\0\0\0\0\0",8);
|
|
|
+ oggpackB_readinit(&r,(unsigned char *)"\0\0\0\0\0\0\0\0",8);
|
|
|
if(oggpackB_read(&r,30)!=0 || oggpackB_read(&r,16)!=0){
|
|
|
fprintf(stderr,"failed 2; got -1 prematurely.\n");
|
|
|
exit(1);
|
|
@@ -778,7 +851,7 @@ int main(void){
|
|
|
|
|
|
|
|
|
return(0);
|
|
|
-}
|
|
|
+}
|
|
|
#endif /* _V_SELFTEST */
|
|
|
|
|
|
#undef BUFFER_INCREMENT
|