X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=security%2Fkeys%2Fprocess_keys.c;h=2a0eb946fc7ee84f95b7b32cc39149c8e510a2f5;hb=75e06e2d7dd48ba655789e143e81c73617737890;hp=32150cf7c37f8de1662758746e1123a6e8a100e6;hpb=7e047ef5fe2d52e83020e856b1bf2556a6a2ce98;p=linux-2.6 diff --git a/security/keys/process_keys.c b/security/keys/process_keys.c index 32150cf7c3..2a0eb946fc 100644 --- a/security/keys/process_keys.c +++ b/security/keys/process_keys.c @@ -26,8 +26,8 @@ static DEFINE_MUTEX(key_session_mutex); /* the root user's tracking struct */ struct key_user root_key_user = { .usage = ATOMIC_INIT(3), - .consq = LIST_HEAD_INIT(root_key_user.consq), - .lock = SPIN_LOCK_UNLOCKED, + .cons_lock = __MUTEX_INITIALIZER(root_key_user.cons_lock), + .lock = __SPIN_LOCK_UNLOCKED(root_key_user.lock), .nkeys = ATOMIC_INIT(2), .nikeys = ATOMIC_INIT(2), .uid = 0, @@ -679,8 +679,18 @@ key_ref_t lookup_user_key(struct task_struct *context, key_serial_t id, break; } - /* check the status */ - if (perm) { + if (!partial) { + ret = wait_for_key_construction(key, true); + switch (ret) { + case -ERESTARTSYS: + goto invalid_key; + default: + if (perm) + goto invalid_key; + case 0: + break; + } + } else if (perm) { ret = key_validate(key); if (ret < 0) goto invalid_key;