Commit 4a420896 authored by Mat Martineau's avatar Mat Martineau

KEYS: Consistent ordering for __key_link_begin and restrict check

The keyring restrict callback was sometimes called before
__key_link_begin and sometimes after, which meant that the keyring
semaphores were not always held during the restrict callback.

If the semaphores are consistently acquired before checking link
restrictions, keyring contents cannot be changed after the restrict
check is complete but before the evaluated key is linked to the keyring.
Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
parent efba797b
...@@ -500,21 +500,23 @@ int key_instantiate_and_link(struct key *key, ...@@ -500,21 +500,23 @@ int key_instantiate_and_link(struct key *key,
} }
if (keyring) { if (keyring) {
ret = __key_link_begin(keyring, &key->index_key, &edit);
if (ret < 0)
goto error;
if (keyring->restrict_link && keyring->restrict_link->check) { if (keyring->restrict_link && keyring->restrict_link->check) {
struct key_restriction *keyres = keyring->restrict_link; struct key_restriction *keyres = keyring->restrict_link;
ret = keyres->check(keyring, key->type, &prep.payload, ret = keyres->check(keyring, key->type, &prep.payload,
keyres->key); keyres->key);
if (ret < 0) if (ret < 0)
goto error; goto error_link_end;
} }
ret = __key_link_begin(keyring, &key->index_key, &edit);
if (ret < 0)
goto error;
} }
ret = __key_instantiate_and_link(key, &prep, keyring, authkey, &edit); ret = __key_instantiate_and_link(key, &prep, keyring, authkey, &edit);
error_link_end:
if (keyring) if (keyring)
__key_link_end(keyring, &key->index_key, edit); __key_link_end(keyring, &key->index_key, edit);
...@@ -855,19 +857,19 @@ key_ref_t key_create_or_update(key_ref_t keyring_ref, ...@@ -855,19 +857,19 @@ key_ref_t key_create_or_update(key_ref_t keyring_ref,
} }
index_key.desc_len = strlen(index_key.description); index_key.desc_len = strlen(index_key.description);
if (restrict_link && restrict_link->check) { ret = __key_link_begin(keyring, &index_key, &edit);
ret = restrict_link->check(keyring, index_key.type,
&prep.payload, restrict_link->key);
if (ret < 0) { if (ret < 0) {
key_ref = ERR_PTR(ret); key_ref = ERR_PTR(ret);
goto error_free_prep; goto error_free_prep;
} }
}
ret = __key_link_begin(keyring, &index_key, &edit); if (restrict_link && restrict_link->check) {
ret = restrict_link->check(keyring, index_key.type,
&prep.payload, restrict_link->key);
if (ret < 0) { if (ret < 0) {
key_ref = ERR_PTR(ret); key_ref = ERR_PTR(ret);
goto error_free_prep; goto error_link_end;
}
} }
/* if we're going to allocate a new key, we're going to have /* if we're going to allocate a new key, we're going to have
......
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