diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-05-20 19:40:24 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-05-20 19:40:24 -0400 |
| commit | 5805977e63a36ad56594a623f3bd2bebcb7db233 (patch) | |
| tree | 8853fa72c4b5a8e27a03782bca0a7d2d5b3f89f4 | |
| parent | a9523f45264aee8ec8d9f82091a0dfe1418fb2f8 (diff) | |
| parent | 9b6fe313bfce27d4a261257da70196be0ac2bef5 (diff) | |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/drm-2.6
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/drm-2.6:
drm: Copy back ioctl data to userspace regardless of return code.
drm: Round size of SHM maps to PAGE_SIZE
| -rw-r--r-- | drivers/gpu/drm/drm_bufs.c | 8 | ||||
| -rw-r--r-- | drivers/gpu/drm/drm_drv.c | 2 |
2 files changed, 9 insertions, 1 deletions
diff --git a/drivers/gpu/drm/drm_bufs.c b/drivers/gpu/drm/drm_bufs.c index 6d80d17f1e96..0411d912d82a 100644 --- a/drivers/gpu/drm/drm_bufs.c +++ b/drivers/gpu/drm/drm_bufs.c | |||
| @@ -170,6 +170,14 @@ static int drm_addmap_core(struct drm_device * dev, resource_size_t offset, | |||
| 170 | } | 170 | } |
| 171 | DRM_DEBUG("offset = 0x%08llx, size = 0x%08lx, type = %d\n", | 171 | DRM_DEBUG("offset = 0x%08llx, size = 0x%08lx, type = %d\n", |
| 172 | (unsigned long long)map->offset, map->size, map->type); | 172 | (unsigned long long)map->offset, map->size, map->type); |
| 173 | |||
| 174 | /* page-align _DRM_SHM maps. They are allocated here so there is no security | ||
| 175 | * hole created by that and it works around various broken drivers that use | ||
| 176 | * a non-aligned quantity to map the SAREA. --BenH | ||
| 177 | */ | ||
| 178 | if (map->type == _DRM_SHM) | ||
| 179 | map->size = PAGE_ALIGN(map->size); | ||
| 180 | |||
| 173 | if ((map->offset & (~(resource_size_t)PAGE_MASK)) || (map->size & (~PAGE_MASK))) { | 181 | if ((map->offset & (~(resource_size_t)PAGE_MASK)) || (map->size & (~PAGE_MASK))) { |
| 174 | drm_free(map, sizeof(*map), DRM_MEM_MAPS); | 182 | drm_free(map, sizeof(*map), DRM_MEM_MAPS); |
| 175 | return -EINVAL; | 183 | return -EINVAL; |
diff --git a/drivers/gpu/drm/drm_drv.c b/drivers/gpu/drm/drm_drv.c index f01def16a669..019b7c578236 100644 --- a/drivers/gpu/drm/drm_drv.c +++ b/drivers/gpu/drm/drm_drv.c | |||
| @@ -481,7 +481,7 @@ int drm_ioctl(struct inode *inode, struct file *filp, | |||
| 481 | } | 481 | } |
| 482 | retcode = func(dev, kdata, file_priv); | 482 | retcode = func(dev, kdata, file_priv); |
| 483 | 483 | ||
| 484 | if ((retcode == 0) && (cmd & IOC_OUT)) { | 484 | if (cmd & IOC_OUT) { |
| 485 | if (copy_to_user((void __user *)arg, kdata, | 485 | if (copy_to_user((void __user *)arg, kdata, |
| 486 | _IOC_SIZE(cmd)) != 0) | 486 | _IOC_SIZE(cmd)) != 0) |
| 487 | retcode = -EFAULT; | 487 | retcode = -EFAULT; |
