Skip to content

Commit 8cf13f7

Browse files
committed
Merge tag 'drm-intel-fixes-2019-03-20' of git://anongit.freedesktop.org/drm/drm-intel into drm-fixes
A protection on our mmap against attempts to map past the end of the object; plus a fix off-by-one in our hang report and a protection; and a fix for eDP panels on Gen9 platforms on VBT absence. Signed-off-by: Dave Airlie <airlied@redhat.com> From: Rodrigo Vivi <rodrigo.vivi@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190320201451.GA7993@intel.com
2 parents cd84579 + 000c4f9 commit 8cf13f7

File tree

3 files changed

+11
-7
lines changed

3 files changed

+11
-7
lines changed

drivers/gpu/drm/i915/i915_gem.c

Lines changed: 9 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1734,8 +1734,13 @@ i915_gem_mmap_ioctl(struct drm_device *dev, void *data,
17341734
* pages from.
17351735
*/
17361736
if (!obj->base.filp) {
1737-
i915_gem_object_put(obj);
1738-
return -ENXIO;
1737+
addr = -ENXIO;
1738+
goto err;
1739+
}
1740+
1741+
if (range_overflows(args->offset, args->size, (u64)obj->base.size)) {
1742+
addr = -EINVAL;
1743+
goto err;
17391744
}
17401745

17411746
addr = vm_mmap(obj->base.filp, 0, args->size,
@@ -1749,8 +1754,8 @@ i915_gem_mmap_ioctl(struct drm_device *dev, void *data,
17491754
struct vm_area_struct *vma;
17501755

17511756
if (down_write_killable(&mm->mmap_sem)) {
1752-
i915_gem_object_put(obj);
1753-
return -EINTR;
1757+
addr = -EINTR;
1758+
goto err;
17541759
}
17551760
vma = find_vma(mm, addr);
17561761
if (vma && __vma_matches(vma, obj->base.filp, addr, args->size))
@@ -1768,12 +1773,10 @@ i915_gem_mmap_ioctl(struct drm_device *dev, void *data,
17681773
i915_gem_object_put(obj);
17691774

17701775
args->addr_ptr = (u64)addr;
1771-
17721776
return 0;
17731777

17741778
err:
17751779
i915_gem_object_put(obj);
1776-
17771780
return addr;
17781781
}
17791782

drivers/gpu/drm/i915/i915_gpu_error.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1721,7 +1721,7 @@ error_msg(struct i915_gpu_state *error, unsigned long engines, const char *msg)
17211721
i915_error_generate_code(error, engines));
17221722
if (engines) {
17231723
/* Just show the first executing process, more is confusing */
1724-
i = ffs(engines);
1724+
i = __ffs(engines);
17251725
len += scnprintf(error->error_msg + len,
17261726
sizeof(error->error_msg) - len,
17271727
", in %s [%d]",

drivers/gpu/drm/i915/intel_bios.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1673,6 +1673,7 @@ init_vbt_missing_defaults(struct drm_i915_private *dev_priv)
16731673
info->supports_dvi = (port != PORT_A && port != PORT_E);
16741674
info->supports_hdmi = info->supports_dvi;
16751675
info->supports_dp = (port != PORT_E);
1676+
info->supports_edp = (port == PORT_A);
16761677
}
16771678
}
16781679

0 commit comments

Comments
 (0)