Commit 5db4afe1 authored by Mika Kuoppala's avatar Mika Kuoppala Committed by Rodrigo Vivi

drm/xe: Fix unreffed ptr leak on engine lookup

The engine xarray holds a ref to engine, guarded by the lock.
While we do lookup for engine, we need to take the ref inside
the lock to prevent unreffed pointer escaping and
causing potential use-after-free after.

v2: remove branch prediction hint (Thomas)

Cc: Thomas Hellström <thomas.hellstrom@linux.intel.com>
Signed-off-by: default avatarMika Kuoppala <mika.kuoppala@linux.intel.com>
Reviewed-by: default avatarThomas Hellström <thomas.hellstrom@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230602172732.1001057-1-mika.kuoppala@linux.intel.comSigned-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
parent 898f86c2
...@@ -162,10 +162,9 @@ struct xe_engine *xe_engine_lookup(struct xe_file *xef, u32 id) ...@@ -162,10 +162,9 @@ struct xe_engine *xe_engine_lookup(struct xe_file *xef, u32 id)
mutex_lock(&xef->engine.lock); mutex_lock(&xef->engine.lock);
e = xa_load(&xef->engine.xa, id); e = xa_load(&xef->engine.xa, id);
mutex_unlock(&xef->engine.lock);
if (e) if (e)
xe_engine_get(e); xe_engine_get(e);
mutex_unlock(&xef->engine.lock);
return e; return e;
} }
...@@ -644,26 +643,27 @@ int xe_engine_get_property_ioctl(struct drm_device *dev, void *data, ...@@ -644,26 +643,27 @@ int xe_engine_get_property_ioctl(struct drm_device *dev, void *data,
struct xe_file *xef = to_xe_file(file); struct xe_file *xef = to_xe_file(file);
struct drm_xe_engine_get_property *args = data; struct drm_xe_engine_get_property *args = data;
struct xe_engine *e; struct xe_engine *e;
int ret;
if (XE_IOCTL_ERR(xe, args->reserved[0] || args->reserved[1])) if (XE_IOCTL_ERR(xe, args->reserved[0] || args->reserved[1]))
return -EINVAL; return -EINVAL;
mutex_lock(&xef->engine.lock); e = xe_engine_lookup(xef, args->engine_id);
e = xa_load(&xef->engine.xa, args->engine_id);
mutex_unlock(&xef->engine.lock);
if (XE_IOCTL_ERR(xe, !e)) if (XE_IOCTL_ERR(xe, !e))
return -ENOENT; return -ENOENT;
switch (args->property) { switch (args->property) {
case XE_ENGINE_GET_PROPERTY_BAN: case XE_ENGINE_GET_PROPERTY_BAN:
args->value = !!(e->flags & ENGINE_FLAG_BANNED); args->value = !!(e->flags & ENGINE_FLAG_BANNED);
ret = 0;
break; break;
default: default:
return -EINVAL; ret = -EINVAL;
} }
return 0; xe_engine_put(e);
return ret;
} }
static void engine_kill_compute(struct xe_engine *e) static void engine_kill_compute(struct xe_engine *e)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment