aboutsummaryrefslogtreecommitdiffstats
path: root/libswscale/swscale.c
diff options
context:
space:
mode:
authorCédric Schieli <cschieli@gmail.com>2009-03-17 19:53:36 +0000
committerCédric Schieli <cschieli@gmail.com>2009-03-17 19:53:36 +0000
commitd4da3e4790fabcd0fb27c025c12e6d960d22ef80 (patch)
tree80d31684bfa181f8cb248c688bc7cc8e918ceb46 /libswscale/swscale.c
parent4c01b868de80e94a5619370e02f8d45dde4007b7 (diff)
downloadffmpeg-d4da3e4790fabcd0fb27c025c12e6d960d22ef80.tar.gz
Add a fillPlane function to fill a plane with one constant value
Originally committed as revision 28986 to svn://svn.mplayerhq.hu/mplayer/trunk/libswscale
Diffstat (limited to 'libswscale/swscale.c')
-rw-r--r--libswscale/swscale.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/libswscale/swscale.c b/libswscale/swscale.c
index 8728e2bb6c..391a39f667 100644
--- a/libswscale/swscale.c
+++ b/libswscale/swscale.c
@@ -953,6 +953,15 @@ static inline void yuv2rgbXinC_full(SwsContext *c, int16_t *lumFilter, int16_t *
}
}
+static void fillPlane(uint8_t* plane, int stride, int width, int height, int y, uint8_t val){
+ int i;
+ uint8_t *ptr = plane + stride*y;
+ for (i=0; i<height; i++){
+ memset(ptr, val, width);
+ ptr += stride;
+ }
+}
+
//Note: we have C, X86, MMX, MMX2, 3DNOW versions, there is no 3DNOW+MMX2 one
//Plain C versions
#if !HAVE_MMX || defined (RUNTIME_CPUDETECT) || !CONFIG_GPL
@@ -1934,14 +1943,8 @@ static int planarCopy(SwsContext *c, uint8_t* src[], int srcStride[], int srcSli
if ((isGray(c->srcFormat) || isGray(c->dstFormat)) && plane>0)
{
- if (!isGray(c->dstFormat)){
- int i;
- uint8_t *ptr = dst[plane] + dstStride[plane]*y;
- for (i=0; i<height; i++){
- memset(ptr, 128, length);
- ptr += dstStride[plane];
- }
- }
+ if (!isGray(c->dstFormat))
+ fillPlane(dst[plane], dstStride[plane], length, height, y, 128);
}
else
{