drm/radeon: fix a bug in the SA code
Aligning offset can make it bigger than tmp->offset leading to an overrun bug in the following subtraction. v2: Against initial suspicions this can't happen in mainline, so no need to push it into stable. Signed-off-by: Christian König <deathsimple@vodafone.de> Reviewed-by: Michel Dänzer <michel.daenzer@amd.com> Reviewed-by: Jerome Glisse <jglisse@redhat.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
parent
36abacaed3
commit
96050bca22
@ -150,7 +150,7 @@ int radeon_sa_bo_new(struct radeon_device *rdev,
|
|||||||
offset = 0;
|
offset = 0;
|
||||||
list_for_each_entry(tmp, &sa_manager->sa_bo, list) {
|
list_for_each_entry(tmp, &sa_manager->sa_bo, list) {
|
||||||
/* room before this object ? */
|
/* room before this object ? */
|
||||||
if ((tmp->offset - offset) >= size) {
|
if (offset < tmp->offset && (tmp->offset - offset) >= size) {
|
||||||
head = tmp->list.prev;
|
head = tmp->list.prev;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user