]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commit
drm/i915: fix race condition UAF in i915_perf_add_config_ioctl
authorMin Li <lm0963hack@gmail.com>
Tue, 28 Mar 2023 09:36:27 +0000 (17:36 +0800)
committerRoxana Nicolescu <roxana.nicolescu@canonical.com>
Wed, 17 May 2023 11:34:03 +0000 (13:34 +0200)
commit071a498d3b839000b6200b4dd3058d57451d1614
tree4f96ba62f815267e982e5fce6cad52180c00403d
parentdaeee8e0db5733e8e0532cfc31a53e1629ed9eba
drm/i915: fix race condition UAF in i915_perf_add_config_ioctl

BugLink: https://bugs.launchpad.net/bugs/2016879
commit dc30c011469165d57af9adac5baff7d767d20e5c upstream.

Userspace can guess the id value and try to race oa_config object creation
with config remove, resulting in a use-after-free if we dereference the
object after unlocking the metrics_lock.  For that reason, unlocking the
metrics_lock must be done after we are done dereferencing the object.

Signed-off-by: Min Li <lm0963hack@gmail.com>
Fixes: f89823c21224 ("drm/i915/perf: Implement I915_PERF_ADD/REMOVE_CONFIG interface")
Cc: <stable@vger.kernel.org> # v4.14+
Reviewed-by: Andi Shyti <andi.shyti@linux.intel.com>
Reviewed-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230328093627.5067-1-lm0963hack@gmail.com
[tursulin: Manually added stable tag.]
(cherry picked from commit 49f6f6483b652108bcb73accd0204a464b922395)
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Paolo Pisati <paolo.pisati@canonical.com>
drivers/gpu/drm/i915/i915_perf.c