freebsd-dev/sys/dev/mlx4
Hans Petter Selasky dd2a8c8f72 mlx4core: Use-after-free causes a resource leak in flow-steering detach
mlx4_QP_FLOW_STEERING_DETACH_wrapper first removes the steering
rule (which results in freeing the rule structure), and then
references a field in this struct (the qp number) when releasing the
busy-status on the rule's qp.

Since this memory was freed, it could reallocated and changed.
Therefore, the qp number in the struct may be incorrect,
so that we are releasing the incorrect qp. This leaves the rule's qp
in the busy state (and could possibly release an incorrect qp as well).

Fix this by saving the qp number in a local variable, for use after
removing the steering rule.

Linux commit:
3b01fe7f91c8e4f9afc4fae3c5af72c14958d2d8

PR:	     	264469
MFC after:	1 week
Sponsored by:	NVIDIA Networking
2022-06-07 16:28:32 +02:00
..
mlx4_core mlx4core: Use-after-free causes a resource leak in flow-steering detach 2022-06-07 16:28:32 +02:00
mlx4_en mlx4: rename conflicting netdev_priv() to mlx4_netdev_priv() 2021-10-25 20:12:32 +00:00
mlx4_ib mlx4: Remove unused variables. 2022-04-08 17:25:13 -07:00
cmd.h
cq.h
device.h mlx4: Map core_clock page to user space only when allowed 2021-07-12 14:22:35 +02:00
doorbell.h
driver.h
qp.h
srq.h
stats.h