scsiback_get_pend_req() hands a pvSCSI frontend request a session tag and
a zeroed se_cmd. Two error paths that run before the command completes
through the target core mishandle that command and leak (or, in one case,
underflow) the tag.
Impact: a pvSCSI guest can exhaust a LUN's per-session command tag pool,
stopping the LUN, via crafted ring requests; for the first case the
refcount underflow also panics the host under panic_on_warn.
Patch 1 fixes scsiback_do_cmd_fn(): on a failed grant map and on an
unknown request type the never-initialised command (cmd_kref == 0) is
freed with transport_generic_free_cmd(), which underflows the zero
refcount and leaks the tag.
Patch 2 fixes scsiback_device_action(): when target_submit_tmr() fails the
err: path frees nothing. transport_generic_free_cmd() cannot be used there
either, since the command is initialised by then and se_tmr_req has already
been freed on one error sub-path.
Both paths go through one helper that returns just the tag.
Patch 1's underflow was reproduced on a Xen dom0 (guest to host, with a
panic_on_warn host panic); with the series applied the same request is
handled with no underflow.
Michael Bommarito (2):
xen/scsiback: free unsubmitted command instead of double-putting it
xen/scsiback: free the command tag on the TMR submit-failure path
drivers/xen/xen-scsiback.c | 30 +++++++++++++++++++++++-------
1 file changed, 23 insertions(+), 7 deletions(-)
base-commit: 5200f5f493f79f14bbdc349e402a40dfb32f23c8
--
2.53.0