tipc: check return value of pskb_trim()
[ Upstream commit e46e06ffc6d667a89b979701288e2264f45e6a7b ]
goto free_skb if an unexpected result is returned by pskb_tirm()
in tipc_crypto_rcv_complete().
Fixes: fc1b6d6de2
("tipc: introduce TIPC encryption & authentication")
Signed-off-by: Yuanjun Gong <ruc_gongyuanjun@163.com>
Reviewed-by: Tung Nguyen <tung.q.nguyen@dektech.com.au>
Link: https://lore.kernel.org/r/20230725064810.5820-1-ruc_gongyuanjun@163.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
0069a11a6f
commit
5f6a842db1
@ -1960,7 +1960,8 @@ static void tipc_crypto_rcv_complete(struct net *net, struct tipc_aead *aead,
|
|||||||
|
|
||||||
skb_reset_network_header(*skb);
|
skb_reset_network_header(*skb);
|
||||||
skb_pull(*skb, tipc_ehdr_size(ehdr));
|
skb_pull(*skb, tipc_ehdr_size(ehdr));
|
||||||
pskb_trim(*skb, (*skb)->len - aead->authsize);
|
if (pskb_trim(*skb, (*skb)->len - aead->authsize))
|
||||||
|
goto free_skb;
|
||||||
|
|
||||||
/* Validate TIPCv2 message */
|
/* Validate TIPCv2 message */
|
||||||
if (unlikely(!tipc_msg_validate(skb))) {
|
if (unlikely(!tipc_msg_validate(skb))) {
|
||||||
|
Loading…
Reference in New Issue
Block a user