Commit a0fef3f0 authored by James Clark's avatar James Clark Committed by Suzuki K Poulose

coresight: Make language around "activated" sinks consistent

Activated has the specific meaning of a sink that's selected for use by
the user via sysfs. But comments in some code that's shared by Perf use
the same word, so in those cases change them to just say "selected"
instead. With selected implying either via Perf or "activated" via
sysfs.

coresight_get_enabled_sink() doesn't actually get an enabled sink, it
only gets an activated one, so change that too.

And change the activated variable name to include "sysfs" so it can't
be confused as a general status.
Signed-off-by: default avatarJames Clark <james.clark@arm.com>
Link: https://lore.kernel.org/r/20240129154050.569566-3-james.clark@arm.comSigned-off-by: default avatarSuzuki K Poulose <suzuki.poulose@arm.com>
parent f68bbe4d
...@@ -500,7 +500,7 @@ static void coresight_disable_path_from(struct list_head *path, ...@@ -500,7 +500,7 @@ static void coresight_disable_path_from(struct list_head *path,
/* /*
* ETF devices are tricky... They can be a link or a sink, * ETF devices are tricky... They can be a link or a sink,
* depending on how they are configured. If an ETF has been * depending on how they are configured. If an ETF has been
* "activated" it will be configured as a sink, otherwise * selected as a sink it will be configured as a sink, otherwise
* go ahead with the link configuration. * go ahead with the link configuration.
*/ */
if (type == CORESIGHT_DEV_TYPE_LINKSINK) if (type == CORESIGHT_DEV_TYPE_LINKSINK)
...@@ -578,7 +578,7 @@ int coresight_enable_path(struct list_head *path, enum cs_mode mode, ...@@ -578,7 +578,7 @@ int coresight_enable_path(struct list_head *path, enum cs_mode mode,
/* /*
* ETF devices are tricky... They can be a link or a sink, * ETF devices are tricky... They can be a link or a sink,
* depending on how they are configured. If an ETF has been * depending on how they are configured. If an ETF has been
* "activated" it will be configured as a sink, otherwise * selected as a sink it will be configured as a sink, otherwise
* go ahead with the link configuration. * go ahead with the link configuration.
*/ */
if (type == CORESIGHT_DEV_TYPE_LINKSINK) if (type == CORESIGHT_DEV_TYPE_LINKSINK)
...@@ -635,15 +635,21 @@ struct coresight_device *coresight_get_sink(struct list_head *path) ...@@ -635,15 +635,21 @@ struct coresight_device *coresight_get_sink(struct list_head *path)
return csdev; return csdev;
} }
/**
* coresight_find_activated_sysfs_sink - returns the first sink activated via
* sysfs using connection based search starting from the source reference.
*
* @csdev: Coresight source device reference
*/
static struct coresight_device * static struct coresight_device *
coresight_find_enabled_sink(struct coresight_device *csdev) coresight_find_activated_sysfs_sink(struct coresight_device *csdev)
{ {
int i; int i;
struct coresight_device *sink = NULL; struct coresight_device *sink = NULL;
if ((csdev->type == CORESIGHT_DEV_TYPE_SINK || if ((csdev->type == CORESIGHT_DEV_TYPE_SINK ||
csdev->type == CORESIGHT_DEV_TYPE_LINKSINK) && csdev->type == CORESIGHT_DEV_TYPE_LINKSINK) &&
csdev->activated) csdev->sysfs_sink_activated)
return csdev; return csdev;
/* /*
...@@ -654,7 +660,7 @@ coresight_find_enabled_sink(struct coresight_device *csdev) ...@@ -654,7 +660,7 @@ coresight_find_enabled_sink(struct coresight_device *csdev)
child_dev = csdev->pdata->out_conns[i]->dest_dev; child_dev = csdev->pdata->out_conns[i]->dest_dev;
if (child_dev) if (child_dev)
sink = coresight_find_enabled_sink(child_dev); sink = coresight_find_activated_sysfs_sink(child_dev);
if (sink) if (sink)
return sink; return sink;
} }
...@@ -662,21 +668,6 @@ coresight_find_enabled_sink(struct coresight_device *csdev) ...@@ -662,21 +668,6 @@ coresight_find_enabled_sink(struct coresight_device *csdev)
return NULL; return NULL;
} }
/**
* coresight_get_enabled_sink - returns the first enabled sink using
* connection based search starting from the source reference
*
* @source: Coresight source device reference
*/
struct coresight_device *
coresight_get_enabled_sink(struct coresight_device *source)
{
if (!source)
return NULL;
return coresight_find_enabled_sink(source);
}
static int coresight_sink_by_id(struct device *dev, const void *data) static int coresight_sink_by_id(struct device *dev, const void *data)
{ {
struct coresight_device *csdev = to_coresight_device(dev); struct coresight_device *csdev = to_coresight_device(dev);
...@@ -810,11 +801,10 @@ static void coresight_drop_device(struct coresight_device *csdev) ...@@ -810,11 +801,10 @@ static void coresight_drop_device(struct coresight_device *csdev)
* @sink: The final sink we want in this path. * @sink: The final sink we want in this path.
* @path: The list to add devices to. * @path: The list to add devices to.
* *
* The tree of Coresight device is traversed until an activated sink is * The tree of Coresight device is traversed until @sink is found.
* found. From there the sink is added to the list along with all the * From there the sink is added to the list along with all the devices that led
* devices that led to that point - the end result is a list from source * to that point - the end result is a list from source to sink. In that list
* to sink. In that list the source is the first device and the sink the * the source is the first device and the sink the last one.
* last one.
*/ */
static int _coresight_build_path(struct coresight_device *csdev, static int _coresight_build_path(struct coresight_device *csdev,
struct coresight_device *sink, struct coresight_device *sink,
...@@ -824,7 +814,7 @@ static int _coresight_build_path(struct coresight_device *csdev, ...@@ -824,7 +814,7 @@ static int _coresight_build_path(struct coresight_device *csdev,
bool found = false; bool found = false;
struct coresight_node *node; struct coresight_node *node;
/* An activated sink has been found. Enqueue the element */ /* The sink has been found. Enqueue the element */
if (csdev == sink) if (csdev == sink)
goto out; goto out;
...@@ -1145,7 +1135,7 @@ int coresight_enable(struct coresight_device *csdev) ...@@ -1145,7 +1135,7 @@ int coresight_enable(struct coresight_device *csdev)
goto out; goto out;
} }
sink = coresight_get_enabled_sink(csdev); sink = coresight_find_activated_sysfs_sink(csdev);
if (!sink) { if (!sink) {
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;
...@@ -1259,7 +1249,7 @@ static ssize_t enable_sink_show(struct device *dev, ...@@ -1259,7 +1249,7 @@ static ssize_t enable_sink_show(struct device *dev,
{ {
struct coresight_device *csdev = to_coresight_device(dev); struct coresight_device *csdev = to_coresight_device(dev);
return scnprintf(buf, PAGE_SIZE, "%u\n", csdev->activated); return scnprintf(buf, PAGE_SIZE, "%u\n", csdev->sysfs_sink_activated);
} }
static ssize_t enable_sink_store(struct device *dev, static ssize_t enable_sink_store(struct device *dev,
...@@ -1274,10 +1264,7 @@ static ssize_t enable_sink_store(struct device *dev, ...@@ -1274,10 +1264,7 @@ static ssize_t enable_sink_store(struct device *dev,
if (ret) if (ret)
return ret; return ret;
if (val) csdev->sysfs_sink_activated = !!val;
csdev->activated = true;
else
csdev->activated = false;
return size; return size;
......
...@@ -130,8 +130,6 @@ void coresight_disable_path(struct list_head *path); ...@@ -130,8 +130,6 @@ void coresight_disable_path(struct list_head *path);
int coresight_enable_path(struct list_head *path, enum cs_mode mode, int coresight_enable_path(struct list_head *path, enum cs_mode mode,
void *sink_data); void *sink_data);
struct coresight_device *coresight_get_sink(struct list_head *path); struct coresight_device *coresight_get_sink(struct list_head *path);
struct coresight_device *
coresight_get_enabled_sink(struct coresight_device *source);
struct coresight_device *coresight_get_sink_by_id(u32 id); struct coresight_device *coresight_get_sink_by_id(u32 id);
struct coresight_device * struct coresight_device *
coresight_find_default_sink(struct coresight_device *csdev); coresight_find_default_sink(struct coresight_device *csdev);
......
...@@ -229,10 +229,12 @@ struct coresight_sysfs_link { ...@@ -229,10 +229,12 @@ struct coresight_sysfs_link {
* @refcnt: keep track of what is in use. * @refcnt: keep track of what is in use.
* @orphan: true if the component has connections that haven't been linked. * @orphan: true if the component has connections that haven't been linked.
* @enable: 'true' if component is currently part of an active path. * @enable: 'true' if component is currently part of an active path.
* @activated: 'true' only if a _sink_ has been activated. A sink can be * @sysfs_sink_activated: 'true' when a sink has been selected for use via sysfs
* activated but not yet enabled. Enabling for a _sink_ * by writing a 1 to the 'enable_sink' file. A sink can be
* happens when a source has been selected and a path is enabled * activated but not yet enabled. Enabling for a _sink_ happens
* from source to that sink. * when a source has been selected and a path is enabled from
* source to that sink. A sink can also become enabled but not
* activated if it's used via Perf.
* @ea: Device attribute for sink representation under PMU directory. * @ea: Device attribute for sink representation under PMU directory.
* @def_sink: cached reference to default sink found for this device. * @def_sink: cached reference to default sink found for this device.
* @nr_links: number of sysfs links created to other components from this * @nr_links: number of sysfs links created to other components from this
...@@ -252,9 +254,9 @@ struct coresight_device { ...@@ -252,9 +254,9 @@ struct coresight_device {
struct device dev; struct device dev;
atomic_t refcnt; atomic_t refcnt;
bool orphan; bool orphan;
bool enable; /* true only if configured as part of a path */ bool enable;
/* sink specific fields */ /* sink specific fields */
bool activated; /* true only if a sink is part of a path */ bool sysfs_sink_activated;
struct dev_ext_attribute *ea; struct dev_ext_attribute *ea;
struct coresight_device *def_sink; struct coresight_device *def_sink;
/* sysfs links between components */ /* sysfs links between components */
......
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