Skip to content

Commit a41e95a

Browse files
committed
Merge tag 'amdtee-fix-for-v6.6' of https://git.linaro.org/people/jens.wiklander/linux-tee into arm/fixes
AMDTEE fix possible use-after-free * tag 'amdtee-fix-for-v6.6' of https://git.linaro.org/people/jens.wiklander/linux-tee: tee: amdtee: fix use-after-free vulnerability in amdtee_close_session Link: https://lore.kernel.org/r/20231003171835.GA669924@rayden Signed-off-by: Arnd Bergmann <arnd@arndb.de>
2 parents 6465e26 + f4384b3 commit a41e95a

1 file changed

Lines changed: 6 additions & 4 deletions

File tree

drivers/tee/amdtee/core.c

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -217,12 +217,12 @@ static int copy_ta_binary(struct tee_context *ctx, void *ptr, void **ta,
217217
return rc;
218218
}
219219

220+
/* mutex must be held by caller */
220221
static void destroy_session(struct kref *ref)
221222
{
222223
struct amdtee_session *sess = container_of(ref, struct amdtee_session,
223224
refcount);
224225

225-
mutex_lock(&session_list_mutex);
226226
list_del(&sess->list_node);
227227
mutex_unlock(&session_list_mutex);
228228
kfree(sess);
@@ -272,7 +272,8 @@ int amdtee_open_session(struct tee_context *ctx,
272272
if (arg->ret != TEEC_SUCCESS) {
273273
pr_err("open_session failed %d\n", arg->ret);
274274
handle_unload_ta(ta_handle);
275-
kref_put(&sess->refcount, destroy_session);
275+
kref_put_mutex(&sess->refcount, destroy_session,
276+
&session_list_mutex);
276277
goto out;
277278
}
278279

@@ -290,7 +291,8 @@ int amdtee_open_session(struct tee_context *ctx,
290291
pr_err("reached maximum session count %d\n", TEE_NUM_SESSIONS);
291292
handle_close_session(ta_handle, session_info);
292293
handle_unload_ta(ta_handle);
293-
kref_put(&sess->refcount, destroy_session);
294+
kref_put_mutex(&sess->refcount, destroy_session,
295+
&session_list_mutex);
294296
rc = -ENOMEM;
295297
goto out;
296298
}
@@ -331,7 +333,7 @@ int amdtee_close_session(struct tee_context *ctx, u32 session)
331333
handle_close_session(ta_handle, session_info);
332334
handle_unload_ta(ta_handle);
333335

334-
kref_put(&sess->refcount, destroy_session);
336+
kref_put_mutex(&sess->refcount, destroy_session, &session_list_mutex);
335337

336338
return 0;
337339
}

0 commit comments

Comments
 (0)