[FFmpeg-cvslog] r31948 - in trunk/libswscale: Makefile swscale-test.c
ramiro
subversion
Sun Aug 8 20:14:44 CEST 2010
Author: ramiro
Date: Sun Aug 8 20:14:43 2010
New Revision: 31948
Log:
swscale-test: get strides using av_fill_image_linesizes() from libavcore
Modified:
trunk/libswscale/Makefile
trunk/libswscale/swscale-test.c
Modified: trunk/libswscale/Makefile
==============================================================================
--- trunk/libswscale/Makefile Sat Aug 7 23:21:38 2010 (r31947)
+++ trunk/libswscale/Makefile Sun Aug 8 20:14:43 2010 (r31948)
@@ -20,3 +20,4 @@ TESTPROGS = colorspace swscale
DIRS = bfin mlib ppc sparc x86
include $(SUBDIR)../subdir.mak
+$(SUBDIR)swscale-test$(EXESUF): ELIBS = -lavcore
Modified: trunk/libswscale/swscale-test.c
==============================================================================
--- trunk/libswscale/swscale-test.c Sat Aug 7 23:21:38 2010 (r31947)
+++ trunk/libswscale/swscale-test.c Sun Aug 8 20:14:43 2010 (r31948)
@@ -25,6 +25,7 @@
#include <stdarg.h>
#undef HAVE_AV_CONFIG_H
+#include "libavcore/imgutils.h"
#include "libavutil/mem.h"
#include "libavutil/avutil.h"
#include "libavutil/pixdesc.h"
@@ -84,24 +85,19 @@ static int doTest(uint8_t *ref[4], int r
struct SwsContext *dstContext = NULL, *outContext = NULL;
int res = 0;
+ av_fill_image_linesizes(dstStride, dstFormat, dstW);
for (i=0; i<4; i++) {
- // avoid stride % bpp != 0
- if (dstFormat==PIX_FMT_RGB24 || dstFormat==PIX_FMT_BGR24)
- dstStride[i]= dstW*3;
- else if (dstFormat==PIX_FMT_RGB48BE || dstFormat==PIX_FMT_RGB48LE)
- dstStride[i]= dstW*6;
- else
- dstStride[i]= dstW*4;
-
/* Image buffers passed into libswscale can be allocated any way you
* prefer, as long as they're aligned enough for the architecture, and
* they're freed appropriately (such as using av_free for buffers
* allocated with av_malloc). */
/* An extra 16 bytes is being allocated because some scalers may write
* out of bounds. */
+ if (dstStride[i])
dst[i]= av_mallocz(dstStride[i]*dstH+16);
+ if (refStride[i])
out[i]= av_mallocz(refStride[i]*h);
- if (!dst[i] || !out[i]) {
+ if ((dstStride[i] && !dst[i]) || (refStride[i] && !out[i])) {
perror("Malloc");
res = -1;
@@ -162,7 +158,9 @@ end:
sws_freeContext(outContext);
for (i=0; i<4; i++) {
+ if (dstStride[i])
av_free(dst[i]);
+ if (refStride[i])
av_free(out[i]);
}
@@ -201,17 +199,11 @@ static void selfTest(uint8_t *ref[4], in
uint8_t *src[4] = {0};
int srcStride[4];
int p;
+ av_fill_image_linesizes(srcStride, srcFormat, srcW);
for (p = 0; p < 4; p++) {
- if (srcFormat == PIX_FMT_RGB24 ||
- srcFormat == PIX_FMT_BGR24)
- srcStride[p] = srcW*3;
- else if (srcFormat==PIX_FMT_RGB48BE ||
- srcFormat==PIX_FMT_RGB48LE)
- srcStride[p] = srcW*6;
- else
- srcStride[p] = srcW*4;
+ if (srcStride[p])
src[p] = av_mallocz(srcStride[p]*srcH+16);
- if (!src[p]) {
+ if (srcStride[p] && !src[p]) {
perror("Malloc");
return;
}
@@ -234,6 +226,7 @@ static void selfTest(uint8_t *ref[4], in
sws_freeContext(srcContext);
for (p = 0; p < 4; p++)
+ if (srcStride[p])
av_free(src[p]);
}
}
More information about the ffmpeg-cvslog
mailing list