summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/drm_mm.c
diff options
context:
space:
mode:
authorThomas Hellstrom <thellstrom@vmware.com>2010-02-12 00:17:59 +0100
committerDave Airlie <airlied@redhat.com>2010-02-15 02:19:14 +0100
commit775c67090c98780b44c4f95d5c05565df715b8bd (patch)
tree8326fb57dc82a90fb609f1fe5d32372aba3ea6f0 /drivers/gpu/drm/drm_mm.c
parentLinux 2.6.33-rc8 (diff)
downloadlinux-775c67090c98780b44c4f95d5c05565df715b8bd.tar.xz
linux-775c67090c98780b44c4f95d5c05565df715b8bd.zip
drm: Fix a bug in the range manager.
When searching for free space in a range, the function could return a node extending outside of the given range. Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/drm_mm.c')
-rw-r--r--drivers/gpu/drm/drm_mm.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/gpu/drm/drm_mm.c b/drivers/gpu/drm/drm_mm.c
index cdec32977129..2ac074c8f5d2 100644
--- a/drivers/gpu/drm/drm_mm.c
+++ b/drivers/gpu/drm/drm_mm.c
@@ -405,7 +405,8 @@ struct drm_mm_node *drm_mm_search_free_in_range(const struct drm_mm *mm,
wasted += alignment - tmp;
}
- if (entry->size >= size + wasted) {
+ if (entry->size >= size + wasted &&
+ (entry->start + wasted + size) <= end) {
if (!best_match)
return entry;
if (entry->size < best_size) {