diff options
| author | Cong Wang <[email protected]> | 2020-12-27 00:50:20 +0000 |
|---|---|---|
| committer | Steffen Klassert <[email protected]> | 2021-01-04 09:05:50 +0000 |
| commit | afbc293add6466f8f3f0c3d944d85f53709c170f (patch) | |
| tree | 97288782f050eb5a58aa1ecb6149a23bef333dff /net/lapb/lapb_out.c | |
| parent | xfrm: fix disable_xfrm sysctl when used on xfrm interfaces (diff) | |
| download | kernel-afbc293add6466f8f3f0c3d944d85f53709c170f.tar.gz kernel-afbc293add6466f8f3f0c3d944d85f53709c170f.zip | |
af_key: relax availability checks for skb size calculation
xfrm_probe_algs() probes kernel crypto modules and changes the
availability of struct xfrm_algo_desc. But there is a small window
where ealg->available and aalg->available get changed between
count_ah_combs()/count_esp_combs() and dump_ah_combs()/dump_esp_combs(),
in this case we may allocate a smaller skb but later put a larger
amount of data and trigger the panic in skb_put().
Fix this by relaxing the checks when counting the size, that is,
skipping the test of ->available. We may waste some memory for a few
of sizeof(struct sadb_comb), but it is still much better than a panic.
Reported-by: [email protected]
Cc: Steffen Klassert <[email protected]>
Cc: Herbert Xu <[email protected]>
Signed-off-by: Cong Wang <[email protected]>
Signed-off-by: Steffen Klassert <[email protected]>
Diffstat (limited to 'net/lapb/lapb_out.c')
0 files changed, 0 insertions, 0 deletions
