mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 01:49:46 +00:00
rxrpc: Fix checks as to whether we should set up a new call
[ Upstream commitdc71db34e4] There's a check in rxrpc_data_ready() that's checking the CLIENT_INITIATED flag in the packet type field rather than in the packet flags field. Fix this by creating a pair of helper functions to check whether the packet is going to the client or to the server and use them generally. Fixes:248f219cb8("rxrpc: Rewrite the data and ack handling code") Signed-off-by: David Howells <dhowells@redhat.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
605c374d8d
commit
6a14d1c933
@@ -462,6 +462,16 @@ struct rxrpc_connection {
|
||||
u8 out_clientflag; /* RXRPC_CLIENT_INITIATED if we are client */
|
||||
};
|
||||
|
||||
static inline bool rxrpc_to_server(const struct rxrpc_skb_priv *sp)
|
||||
{
|
||||
return sp->hdr.flags & RXRPC_CLIENT_INITIATED;
|
||||
}
|
||||
|
||||
static inline bool rxrpc_to_client(const struct rxrpc_skb_priv *sp)
|
||||
{
|
||||
return !rxrpc_to_server(sp);
|
||||
}
|
||||
|
||||
/*
|
||||
* Flags in call->flags.
|
||||
*/
|
||||
|
||||
@@ -99,7 +99,7 @@ struct rxrpc_connection *rxrpc_find_connection_rcu(struct rxrpc_local *local,
|
||||
k.epoch = sp->hdr.epoch;
|
||||
k.cid = sp->hdr.cid & RXRPC_CIDMASK;
|
||||
|
||||
if (sp->hdr.flags & RXRPC_CLIENT_INITIATED) {
|
||||
if (rxrpc_to_server(sp)) {
|
||||
/* We need to look up service connections by the full protocol
|
||||
* parameter set. We look up the peer first as an intermediate
|
||||
* step and then the connection from the peer's tree.
|
||||
|
||||
@@ -1171,10 +1171,6 @@ void rxrpc_data_ready(struct sock *udp_sk)
|
||||
|
||||
trace_rxrpc_rx_packet(sp);
|
||||
|
||||
_net("Rx RxRPC %s ep=%x call=%x:%x",
|
||||
sp->hdr.flags & RXRPC_CLIENT_INITIATED ? "ToServer" : "ToClient",
|
||||
sp->hdr.epoch, sp->hdr.cid, sp->hdr.callNumber);
|
||||
|
||||
if (sp->hdr.type >= RXRPC_N_PACKET_TYPES ||
|
||||
!((RXRPC_SUPPORTED_PACKET_TYPES >> sp->hdr.type) & 1)) {
|
||||
_proto("Rx Bad Packet Type %u", sp->hdr.type);
|
||||
@@ -1183,13 +1179,13 @@ void rxrpc_data_ready(struct sock *udp_sk)
|
||||
|
||||
switch (sp->hdr.type) {
|
||||
case RXRPC_PACKET_TYPE_VERSION:
|
||||
if (!(sp->hdr.flags & RXRPC_CLIENT_INITIATED))
|
||||
if (rxrpc_to_client(sp))
|
||||
goto discard;
|
||||
rxrpc_post_packet_to_local(local, skb);
|
||||
goto out;
|
||||
|
||||
case RXRPC_PACKET_TYPE_BUSY:
|
||||
if (sp->hdr.flags & RXRPC_CLIENT_INITIATED)
|
||||
if (rxrpc_to_server(sp))
|
||||
goto discard;
|
||||
/* Fall through */
|
||||
|
||||
@@ -1269,7 +1265,7 @@ void rxrpc_data_ready(struct sock *udp_sk)
|
||||
call = rcu_dereference(chan->call);
|
||||
|
||||
if (sp->hdr.callNumber > chan->call_id) {
|
||||
if (!(sp->hdr.flags & RXRPC_CLIENT_INITIATED)) {
|
||||
if (rxrpc_to_client(sp)) {
|
||||
rcu_read_unlock();
|
||||
goto reject_packet;
|
||||
}
|
||||
@@ -1292,7 +1288,7 @@ void rxrpc_data_ready(struct sock *udp_sk)
|
||||
}
|
||||
|
||||
if (!call || atomic_read(&call->usage) == 0) {
|
||||
if (!(sp->hdr.type & RXRPC_CLIENT_INITIATED) ||
|
||||
if (rxrpc_to_client(sp) ||
|
||||
sp->hdr.callNumber == 0 ||
|
||||
sp->hdr.type != RXRPC_PACKET_TYPE_DATA)
|
||||
goto bad_message_unlock;
|
||||
|
||||
Reference in New Issue
Block a user