Commit 3375e686 authored by Mathieu Poirier's avatar Mathieu Poirier Committed by Stefan Bader

coresight: remove csdev's link from topology

BugLink: https://bugs.launchpad.net/bugs/1826212

[ Upstream commit ad725aee ]

In function 'coresight_unregister()', all references to the csdev that
is being taken away need to be removed from the topology.  Otherwise
building the next coresight path from source to sink may use memory
that has been released.
Signed-off-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
Signed-off-by: default avatarKleber Sacilotto de Souza <kleber.souza@canonical.com>
parent b683c8a0
...@@ -582,6 +582,50 @@ static void coresight_fixup_device_conns(struct coresight_device *csdev) ...@@ -582,6 +582,50 @@ static void coresight_fixup_device_conns(struct coresight_device *csdev)
} }
} }
static int coresight_remove_match(struct device *dev, void *data)
{
int i;
struct coresight_device *csdev, *iterator;
struct coresight_connection *conn;
csdev = data;
iterator = to_coresight_device(dev);
/* No need to check oneself */
if (csdev == iterator)
return 0;
/*
* Circle throuch all the connection of that component. If we find
* a connection whose name matches @csdev, remove it.
*/
for (i = 0; i < iterator->nr_outport; i++) {
conn = &iterator->conns[i];
if (conn->child_dev == NULL)
continue;
if (!strcmp(dev_name(&csdev->dev), conn->child_name)) {
iterator->orphan = true;
conn->child_dev = NULL;
/* No need to continue */
break;
}
}
/*
* Returning '0' ensures that all known component on the
* bus will be checked.
*/
return 0;
}
static void coresight_remove_conns(struct coresight_device *csdev)
{
bus_for_each_dev(&coresight_bustype, NULL,
csdev, coresight_remove_match);
}
/** /**
* coresight_timeout - loop until a bit has changed to a specific state. * coresight_timeout - loop until a bit has changed to a specific state.
* @addr: base address of the area of interest. * @addr: base address of the area of interest.
...@@ -720,6 +764,8 @@ EXPORT_SYMBOL_GPL(coresight_register); ...@@ -720,6 +764,8 @@ EXPORT_SYMBOL_GPL(coresight_register);
void coresight_unregister(struct coresight_device *csdev) void coresight_unregister(struct coresight_device *csdev)
{ {
/* Remove references of that device in the topology */
coresight_remove_conns(csdev);
device_unregister(&csdev->dev); device_unregister(&csdev->dev);
} }
EXPORT_SYMBOL_GPL(coresight_unregister); EXPORT_SYMBOL_GPL(coresight_unregister);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment