summaryrefslogtreecommitdiffstats
path: root/libhb/decomb.c
diff options
context:
space:
mode:
authorjstebbins <[email protected]>2012-09-12 15:54:00 +0000
committerjstebbins <[email protected]>2012-09-12 15:54:00 +0000
commit001b8708d3b15564c7096a21be769b9328bc2cb8 (patch)
treed77148f3096a479999af72cd05b3c9cd6d300652 /libhb/decomb.c
parent6af5392e79799d76135e4b006c5ea817d5af01df (diff)
libhb: fix potential invalid memory access in decomb (again)
I missed a spot where an even wider left/right margin is needed. git-svn-id: svn://svn.handbrake.fr/HandBrake/trunk@4961 b64f7644-9d1e-0410-96f1-a4d463321fa5
Diffstat (limited to 'libhb/decomb.c')
-rw-r--r--libhb/decomb.c21
1 files changed, 15 insertions, 6 deletions
diff --git a/libhb/decomb.c b/libhb/decomb.c
index 4f969194d..e931db020 100644
--- a/libhb/decomb.c
+++ b/libhb/decomb.c
@@ -1658,15 +1658,24 @@ static void yadif_filter_line(
spatial_pred = (c+e)>>1;
}
- // YADIF_CHECK touches pixels -3 and +3 around the current x pos
- // when MODE_CUBIC is enabled
- if( x >= 3 && x <= width - 4 )
+ // YADIF_CHECK requires a margin to avoid invalid memory access.
+ // In MODE_CUBIC, margin needed is 2 + ABS(param).
+ // Else, the margin needed is 1 + ABS(param).
+ int margin = 2;
+ if (pv->mode & MODE_CUBIC)
+ margin = 3;
+
+ if (x >= margin && x <= width - (margin + 1))
{
- YADIF_CHECK(-1) YADIF_CHECK(-2) }} }}
+ YADIF_CHECK(-1)
+ if (x >= margin + 1 && x <= width - (margin + 2))
+ YADIF_CHECK(-2) }} }}
}
- if( x >= 3 && x <= width - 4 )
+ if (x >= margin && x <= width - (margin + 1))
{
- YADIF_CHECK(1) YADIF_CHECK(2) }} }}
+ YADIF_CHECK(1)
+ if (x >= margin + 1 && x <= width - (margin + 2))
+ YADIF_CHECK(2) }} }}
}
}