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)
committerJani Nikula <jani.nikula@intel.com>
Mon, 3 Apr 2023 08:36:55 +0000 (11:36 +0300)
commitdc30c011469165d57af9adac5baff7d767d20e5c
tree3215c6a8e709bc8b2582d59bdcf4478e7aaca068
parent95d939bb97ff9be101ae4ceeb322535589da2190
drm/i915: fix race condition UAF in i915_perf_add_config_ioctl

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>
drivers/gpu/drm/i915/i915_perf.c