diff options
| author | Gavin Li <[email protected]> | 2023-11-14 13:58:37 -0800 | 
|---|---|---|
| committer | Jakub Kicinski <[email protected]> | 2023-11-15 22:34:31 -0800 | 
| commit | 3a4aa3cb83563df942be49d145ee3b7ddf17d6bb (patch) | |
| tree | 452b2be3ff680410936840f271481022ec1de917 /tools/perf/scripts/python/Perf-Trace-Util/Context.c | |
| parent | 6f9b1a0731662648949a1c0587f6acb3b7f8acf1 (diff) | |
net/mlx5e: fix double free of encap_header in update funcs
Follow up to the previous patch to fix the same issue for
mlx5e_tc_tun_update_header_ipv4{6} when mlx5_packet_reformat_alloc()
fails.
When mlx5_packet_reformat_alloc() fails, the encap_header allocated in
mlx5e_tc_tun_update_header_ipv4{6} will be released within it. However,
e->encap_header is already set to the previously freed encap_header
before mlx5_packet_reformat_alloc(). As a result, the later
mlx5e_encap_put() will free e->encap_header again, causing a double free
issue.
mlx5e_encap_put()
     --> mlx5e_encap_dealloc()
         --> kfree(e->encap_header)
This patch fix it by not setting e->encap_header until
mlx5_packet_reformat_alloc() success.
Fixes: a54e20b4fcae ("net/mlx5e: Add basic TC tunnel set action for SRIOV offloads")
Signed-off-by: Gavin Li <[email protected]>
Signed-off-by: Saeed Mahameed <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Jakub Kicinski <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/Perf-Trace-Util/Context.c')
0 files changed, 0 insertions, 0 deletions