diff --git a/libswscale/swscale.c b/libswscale/swscale.c
index 8728e2bb6c20ac52aa57e57737cdc3beaf5020b8..391a39f6673daa4b61340cf3a51b896c8b056a44 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
         {