Commit 81b7c056 authored by Michael Niedermayer's avatar Michael Niedermayer

use assert.h

more assertions

Originally committed as revision 4807 to svn://svn.mplayerhq.hu/mplayer/trunk/postproc
parent e7774f11
...@@ -52,6 +52,7 @@ untested special converters ...@@ -52,6 +52,7 @@ untested special converters
#include <stdio.h> #include <stdio.h>
#include "../config.h" #include "../config.h"
#include "../mangle.h" #include "../mangle.h"
#include <assert.h>
#ifdef HAVE_MALLOC_H #ifdef HAVE_MALLOC_H
#include <malloc.h> #include <malloc.h>
#endif #endif
...@@ -76,7 +77,7 @@ untested special converters ...@@ -76,7 +77,7 @@ untested special converters
#define RET 0xC3 //near return opcode for X86 #define RET 0xC3 //near return opcode for X86
#ifdef MP_DEBUG #ifdef MP_DEBUG
#define ASSERT(x) if(!(x)) { printf("ASSERT " #x " failed\n"); *((int*)0)=0; } #define ASSERT(x) assert(x);
#else #else
#define ASSERT(x) ; #define ASSERT(x) ;
#endif #endif
...@@ -806,6 +807,8 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out ...@@ -806,6 +807,8 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out
else // downscale else // downscale
{ {
int xDstInSrc; int xDstInSrc;
ASSERT(dstW <= srcW)
if(flags&SWS_BICUBIC) filterSize= (int)ceil(1 + 4.0*srcW / (double)dstW); if(flags&SWS_BICUBIC) filterSize= (int)ceil(1 + 4.0*srcW / (double)dstW);
else if(flags&SWS_X) filterSize= (int)ceil(1 + 4.0*srcW / (double)dstW); else if(flags&SWS_X) filterSize= (int)ceil(1 + 4.0*srcW / (double)dstW);
else if(flags&SWS_AREA) filterSize= (int)ceil(1 + 1.0*srcW / (double)dstW); else if(flags&SWS_AREA) filterSize= (int)ceil(1 + 1.0*srcW / (double)dstW);
...@@ -858,9 +861,11 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out ...@@ -858,9 +861,11 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out
/* apply src & dst Filter to filter -> filter2 /* apply src & dst Filter to filter -> filter2
free(filter); free(filter);
*/ */
ASSERT(filterSize>0)
filter2Size= filterSize; filter2Size= filterSize;
if(srcFilter) filter2Size+= srcFilter->length - 1; if(srcFilter) filter2Size+= srcFilter->length - 1;
if(dstFilter) filter2Size+= dstFilter->length - 1; if(dstFilter) filter2Size+= dstFilter->length - 1;
ASSERT(filter2Size>0)
filter2= (double*)memalign(8, filter2Size*dstW*sizeof(double)); filter2= (double*)memalign(8, filter2Size*dstW*sizeof(double));
for(i=0; i<dstW; i++) for(i=0; i<dstW; i++)
...@@ -929,7 +934,9 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out ...@@ -929,7 +934,9 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out
if(min>minFilterSize) minFilterSize= min; if(min>minFilterSize) minFilterSize= min;
} }
ASSERT(minFilterSize > 0)
filterSize= (minFilterSize +(filterAlign-1)) & (~(filterAlign-1)); filterSize= (minFilterSize +(filterAlign-1)) & (~(filterAlign-1));
ASSERT(filterSize > 0)
filter= (double*)memalign(8, filterSize*dstW*sizeof(double)); filter= (double*)memalign(8, filterSize*dstW*sizeof(double));
*outFilterSize= filterSize; *outFilterSize= filterSize;
...@@ -948,7 +955,6 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out ...@@ -948,7 +955,6 @@ static inline void initFilter(int16_t **outFilter, int16_t **filterPos, int *out
} }
free(filter2); filter2=NULL; free(filter2); filter2=NULL;
ASSERT(filterSize > 0)
//FIXME try to align filterpos if possible //FIXME try to align filterpos if possible
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment