cxl/port: Fix endpoint refcount leak
authorDan Williams <dan.j.williams@intel.com>
Fri, 11 Feb 2022 01:04:42 +0000 (17:04 -0800)
committerDan Williams <dan.j.williams@intel.com>
Fri, 18 Feb 2022 00:50:30 +0000 (16:50 -0800)
commit41ae9105f5e23e98a1734be2eeddddf488e42c2e
tree9e6eab847326214ba6b7f4ea5829a8eef85b63df
parente6e17cc6ed751072513fe16cb595ac09f6821a43
cxl/port: Fix endpoint refcount leak

An endpoint can be unregistered via two paths. Either its parent port is
unregistered, or the memdev that registered the endpoint is removed. The
memdev remove path is responsible for synchronizing against the parent
->remove() event and if the memdev remove path wins, manually trigger
unregister_port() via devm_release_action(). Until that race is resolved
the memdev remove path holds a reference on the endpoint.

If the parent port for the endpoint can not be found that is an
indication that the endpoint has already been registered. Be sure to
drop the reference in all exit paths from delete_endpoint().

Fixes: 8dd2bc0f8e02 ("cxl/mem: Add the cxl_mem driver")
Link: https://lore.kernel.org/r/164454148209.3429624.12905500880311609053.stgit@dwillia2-desk3.amr.corp.intel.com
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
drivers/cxl/core/port.c