Commit fdb99487 authored by David Howells's avatar David Howells Committed by David S. Miller

rxrpc: Fix security setting propagation

Fix the propagation of the security settings from sendmsg to the rxrpc_call
struct.

Fixes: f3441d41 ("rxrpc: Copy client call parameters into rxrpc_call earlier")
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
cc: Marc Dionne <marc.dionne@auristor.com>
cc: linux-afs@lists.infradead.org
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 4feb2c44
...@@ -217,6 +217,7 @@ static struct rxrpc_call *rxrpc_alloc_client_call(struct rxrpc_sock *rx, ...@@ -217,6 +217,7 @@ static struct rxrpc_call *rxrpc_alloc_client_call(struct rxrpc_sock *rx,
call->tx_total_len = p->tx_total_len; call->tx_total_len = p->tx_total_len;
call->key = key_get(cp->key); call->key = key_get(cp->key);
call->local = rxrpc_get_local(cp->local, rxrpc_local_get_call); call->local = rxrpc_get_local(cp->local, rxrpc_local_get_call);
call->security_level = cp->security_level;
if (p->kernel) if (p->kernel)
__set_bit(RXRPC_CALL_KERNEL, &call->flags); __set_bit(RXRPC_CALL_KERNEL, &call->flags);
if (cp->upgrade) if (cp->upgrade)
......
...@@ -551,8 +551,6 @@ static void rxrpc_activate_one_channel(struct rxrpc_connection *conn, ...@@ -551,8 +551,6 @@ static void rxrpc_activate_one_channel(struct rxrpc_connection *conn,
call->conn = rxrpc_get_connection(conn, rxrpc_conn_get_activate_call); call->conn = rxrpc_get_connection(conn, rxrpc_conn_get_activate_call);
call->cid = conn->proto.cid | channel; call->cid = conn->proto.cid | channel;
call->call_id = call_id; call->call_id = call_id;
call->security = conn->security;
call->security_ix = conn->security_ix;
call->dest_srx.srx_service = conn->service_id; call->dest_srx.srx_service = conn->service_id;
trace_rxrpc_connect_call(call); trace_rxrpc_connect_call(call);
......
...@@ -67,13 +67,13 @@ const struct rxrpc_security *rxrpc_security_lookup(u8 security_index) ...@@ -67,13 +67,13 @@ const struct rxrpc_security *rxrpc_security_lookup(u8 security_index)
*/ */
int rxrpc_init_client_call_security(struct rxrpc_call *call) int rxrpc_init_client_call_security(struct rxrpc_call *call)
{ {
const struct rxrpc_security *sec; const struct rxrpc_security *sec = &rxrpc_no_security;
struct rxrpc_key_token *token; struct rxrpc_key_token *token;
struct key *key = call->key; struct key *key = call->key;
int ret; int ret;
if (!key) if (!key)
return 0; goto found;
ret = key_validate(key); ret = key_validate(key);
if (ret < 0) if (ret < 0)
...@@ -88,7 +88,7 @@ int rxrpc_init_client_call_security(struct rxrpc_call *call) ...@@ -88,7 +88,7 @@ int rxrpc_init_client_call_security(struct rxrpc_call *call)
found: found:
call->security = sec; call->security = sec;
_leave(" = 0"); call->security_ix = sec->security_index;
return 0; return 0;
} }
......
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