mirror of
https://github.com/torvalds/linux.git
synced 2024-11-10 14:11:52 +00:00
rxrpc: Fix undefined packet handling
By analogy with other Rx implementations, RxRPC packet types 9, 10 and 11 should just be discarded rather than being aborted like other undefined packet types. Reported-by: Jeffrey Altman <jaltman@auristor.com> Signed-off-by: David Howells <dhowells@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
17dec0a949
commit
b41d7cfef5
@ -1200,6 +1200,12 @@ void rxrpc_data_ready(struct sock *udp_sk)
|
||||
!rxrpc_validate_jumbo(skb))
|
||||
goto bad_message;
|
||||
break;
|
||||
|
||||
/* Packet types 9-11 should just be ignored. */
|
||||
case RXRPC_PACKET_TYPE_PARAMS:
|
||||
case RXRPC_PACKET_TYPE_10:
|
||||
case RXRPC_PACKET_TYPE_11:
|
||||
goto discard;
|
||||
}
|
||||
|
||||
rcu_read_lock();
|
||||
|
@ -46,6 +46,9 @@ struct rxrpc_wire_header {
|
||||
#define RXRPC_PACKET_TYPE_CHALLENGE 6 /* connection security challenge (SRVR->CLNT) */
|
||||
#define RXRPC_PACKET_TYPE_RESPONSE 7 /* connection secutity response (CLNT->SRVR) */
|
||||
#define RXRPC_PACKET_TYPE_DEBUG 8 /* debug info request */
|
||||
#define RXRPC_PACKET_TYPE_PARAMS 9 /* Parameter negotiation (unspec'd, ignore) */
|
||||
#define RXRPC_PACKET_TYPE_10 10 /* Ignored */
|
||||
#define RXRPC_PACKET_TYPE_11 11 /* Ignored */
|
||||
#define RXRPC_PACKET_TYPE_VERSION 13 /* version string request */
|
||||
#define RXRPC_N_PACKET_TYPES 14 /* number of packet types (incl type 0) */
|
||||
|
||||
@ -78,6 +81,9 @@ struct rxrpc_wire_header {
|
||||
(1 << RXRPC_PACKET_TYPE_CHALLENGE) | \
|
||||
(1 << RXRPC_PACKET_TYPE_RESPONSE) | \
|
||||
/*(1 << RXRPC_PACKET_TYPE_DEBUG) | */ \
|
||||
(1 << RXRPC_PACKET_TYPE_PARAMS) | \
|
||||
(1 << RXRPC_PACKET_TYPE_10) | \
|
||||
(1 << RXRPC_PACKET_TYPE_11) | \
|
||||
(1 << RXRPC_PACKET_TYPE_VERSION))
|
||||
|
||||
/*****************************************************************************/
|
||||
|
Loading…
Reference in New Issue
Block a user