mirror of
https://github.com/torvalds/linux.git
synced 2026-05-12 16:18:45 +02:00
rxrpc: Fix key quota calculation for multitoken keys
In the rxrpc key preparsing, every token extracted sets the proposed quota
value, but for multitoken keys, this will overwrite the previous proposed
quota, losing it.
Fix this by adding to the proposed quota instead.
Fixes: 8a7a3eb4dd ("KEYS: RxRPC: Use key preparsing")
Closes: https://sashiko.dev/#/patchset/20260319150150.4189381-1-dhowells%40redhat.com
Signed-off-by: David Howells <dhowells@redhat.com>
cc: Marc Dionne <marc.dionne@auristor.com>
cc: Jeffrey Altman <jaltman@auristor.com>
cc: Simon Horman <horms@kernel.org>
cc: linux-afs@lists.infradead.org
cc: stable@kernel.org
Link: https://patch.msgid.link/20260408121252.2249051-2-dhowells@redhat.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
c09ea768bd
commit
bdbfead6d3
|
|
@ -72,7 +72,7 @@ static int rxrpc_preparse_xdr_rxkad(struct key_preparsed_payload *prep,
|
|||
return -EKEYREJECTED;
|
||||
|
||||
plen = sizeof(*token) + sizeof(*token->kad) + tktlen;
|
||||
prep->quotalen = datalen + plen;
|
||||
prep->quotalen += datalen + plen;
|
||||
|
||||
plen -= sizeof(*token);
|
||||
token = kzalloc_obj(*token);
|
||||
|
|
@ -199,7 +199,7 @@ static int rxrpc_preparse_xdr_yfs_rxgk(struct key_preparsed_payload *prep,
|
|||
}
|
||||
|
||||
plen = sizeof(*token) + sizeof(*token->rxgk) + tktlen + keylen;
|
||||
prep->quotalen = datalen + plen;
|
||||
prep->quotalen += datalen + plen;
|
||||
|
||||
plen -= sizeof(*token);
|
||||
token = kzalloc_obj(*token);
|
||||
|
|
@ -460,6 +460,7 @@ static int rxrpc_preparse(struct key_preparsed_payload *prep)
|
|||
memcpy(&kver, prep->data, sizeof(kver));
|
||||
prep->data += sizeof(kver);
|
||||
prep->datalen -= sizeof(kver);
|
||||
prep->quotalen = 0;
|
||||
|
||||
_debug("KEY I/F VERSION: %u", kver);
|
||||
|
||||
|
|
@ -497,7 +498,7 @@ static int rxrpc_preparse(struct key_preparsed_payload *prep)
|
|||
goto error;
|
||||
|
||||
plen = sizeof(*token->kad) + v1->ticket_length;
|
||||
prep->quotalen = plen + sizeof(*token);
|
||||
prep->quotalen += plen + sizeof(*token);
|
||||
|
||||
ret = -ENOMEM;
|
||||
token = kzalloc_obj(*token);
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user