提交 d963007c 编写于 作者: P Paul E. McKenney

keyring: Remove now-redundant smp_read_barrier_depends()

Now that the associative-array library properly heads dependency chains,
the various smp_read_barrier_depends() calls in security/keys/keyring.c
are no longer needed.  This commit therefore removes them.
Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
Cc: David Howells <dhowells@redhat.com>
Cc: "Serge E. Hallyn" <serge@hallyn.com>
Cc: <keyrings@vger.kernel.org>
Cc: <linux-security-module@vger.kernel.org>
Reviewed-by: NJames Morris <james.l.morris@oracle.com>
上级 4be2b04e
...@@ -713,7 +713,6 @@ static bool search_nested_keyrings(struct key *keyring, ...@@ -713,7 +713,6 @@ static bool search_nested_keyrings(struct key *keyring,
* doesn't contain any keyring pointers. * doesn't contain any keyring pointers.
*/ */
shortcut = assoc_array_ptr_to_shortcut(ptr); shortcut = assoc_array_ptr_to_shortcut(ptr);
smp_read_barrier_depends();
if ((shortcut->index_key[0] & ASSOC_ARRAY_FAN_MASK) != 0) if ((shortcut->index_key[0] & ASSOC_ARRAY_FAN_MASK) != 0)
goto not_this_keyring; goto not_this_keyring;
...@@ -723,8 +722,6 @@ static bool search_nested_keyrings(struct key *keyring, ...@@ -723,8 +722,6 @@ static bool search_nested_keyrings(struct key *keyring,
} }
node = assoc_array_ptr_to_node(ptr); node = assoc_array_ptr_to_node(ptr);
smp_read_barrier_depends();
ptr = node->slots[0]; ptr = node->slots[0];
if (!assoc_array_ptr_is_meta(ptr)) if (!assoc_array_ptr_is_meta(ptr))
goto begin_node; goto begin_node;
...@@ -736,7 +733,6 @@ static bool search_nested_keyrings(struct key *keyring, ...@@ -736,7 +733,6 @@ static bool search_nested_keyrings(struct key *keyring,
kdebug("descend"); kdebug("descend");
if (assoc_array_ptr_is_shortcut(ptr)) { if (assoc_array_ptr_is_shortcut(ptr)) {
shortcut = assoc_array_ptr_to_shortcut(ptr); shortcut = assoc_array_ptr_to_shortcut(ptr);
smp_read_barrier_depends();
ptr = READ_ONCE(shortcut->next_node); ptr = READ_ONCE(shortcut->next_node);
BUG_ON(!assoc_array_ptr_is_node(ptr)); BUG_ON(!assoc_array_ptr_is_node(ptr));
} }
...@@ -744,7 +740,6 @@ static bool search_nested_keyrings(struct key *keyring, ...@@ -744,7 +740,6 @@ static bool search_nested_keyrings(struct key *keyring,
begin_node: begin_node:
kdebug("begin_node"); kdebug("begin_node");
smp_read_barrier_depends();
slot = 0; slot = 0;
ascend_to_node: ascend_to_node:
/* Go through the slots in a node */ /* Go through the slots in a node */
...@@ -792,14 +787,12 @@ static bool search_nested_keyrings(struct key *keyring, ...@@ -792,14 +787,12 @@ static bool search_nested_keyrings(struct key *keyring,
if (ptr && assoc_array_ptr_is_shortcut(ptr)) { if (ptr && assoc_array_ptr_is_shortcut(ptr)) {
shortcut = assoc_array_ptr_to_shortcut(ptr); shortcut = assoc_array_ptr_to_shortcut(ptr);
smp_read_barrier_depends();
ptr = READ_ONCE(shortcut->back_pointer); ptr = READ_ONCE(shortcut->back_pointer);
slot = shortcut->parent_slot; slot = shortcut->parent_slot;
} }
if (!ptr) if (!ptr)
goto not_this_keyring; goto not_this_keyring;
node = assoc_array_ptr_to_node(ptr); node = assoc_array_ptr_to_node(ptr);
smp_read_barrier_depends();
slot++; slot++;
/* If we've ascended to the root (zero backpointer), we must have just /* If we've ascended to the root (zero backpointer), we must have just
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册