diff --git a/libavcodec/libpostproc/postprocess.c b/libavcodec/libpostproc/postprocess.c
index c03a36ed3f6b5b3aee06c4405a55ffb35a5ff581..cf93fa8505a2a96bac6cb195736c0c09fa80bd72 100644
--- a/libavcodec/libpostproc/postprocess.c
+++ b/libavcodec/libpostproc/postprocess.c
@@ -800,7 +800,6 @@ void  pp_postprocess(uint8_t * src[3], int srcStride[3],
 {
 	int mbWidth = (width+15)>>4;
 	int mbHeight= (height+15)>>4;
-	int horz_size,vert_size;
 	PPMode *mode = (PPMode*)vm;
 	PPContext *c = (PPContext*)vc;
         int minStride= MAX(srcStride[0], dstStride[0]);
@@ -848,40 +847,18 @@ for(y=0; y<mbHeight; y++){
 		printf("using npp filters 0x%X/0x%X\n", mode->lumMode, mode->chromMode);
 	}
 
-	/* special case for 405.avi: (width=356)%8 !=0  */
-	horz_size = (width / BLOCK_SIZE) * BLOCK_SIZE;
-
 	postProcess(src[0], srcStride[0], dst[0], dstStride[0],
-		horz_size, height, QP_store, QPStride, 0, mode, c);
-
-	if(horz_size < width)
-	{
-		unsigned y,tail;
-		tail = width-horz_size;
-		for(y=0; y<height; y++)
-			memcpy(&(dst[0][y*dstStride[0]+horz_size]), &(src[0][y*srcStride[0]+horz_size]), tail);
-	}
+		width, height, QP_store, QPStride, 0, mode, c);
 
 	width  = (width )>>c->hChromaSubSample;
-	horz_size = (width / BLOCK_SIZE) * BLOCK_SIZE;
 	height = (height)>>c->vChromaSubSample;
 
 	if(mode->chromMode)
 	{
 		postProcess(src[1], srcStride[1], dst[1], dstStride[1],
-			horz_size, height, QP_store, QPStride, 1, mode, c);
+			width, height, QP_store, QPStride, 1, mode, c);
 		postProcess(src[2], srcStride[2], dst[2], dstStride[2],
-			horz_size, height, QP_store, QPStride, 2, mode, c);
-		if(horz_size < width)
-		{
-			unsigned y,tail;
-			tail = width-horz_size;
-			for(y=0; y<height; y++)
-			{
-				memcpy(&(dst[1][y*dstStride[1]+horz_size]), &(src[1][y*srcStride[1]+horz_size]), tail);
-				memcpy(&(dst[2][y*dstStride[2]+horz_size]), &(src[2][y*srcStride[2]+horz_size]), tail);
-			}
-		}
+			width, height, QP_store, QPStride, 2, mode, c);
 	}
 	else if(srcStride[1] == dstStride[1] && srcStride[2] == dstStride[2])
 	{