Re: [PATCH 2/8] coresight: Make language around "activated" sinks consistent

From: James Clark
Date: Wed Jan 24 2024 - 06:10:56 EST




On 08/01/2024 11:21, Suzuki K Poulose wrote:
> Hi James,
>
>
> On 12/12/2023 15:53, James Clark wrote:
>> 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.
>>
>
> These changes look good to me. Please see a minor nit below.
>
>> And change the activated variable name to include "sysfs" so it can't
>> be confused as a general status.
>>
>> Signed-off-by: James Clark <james.clark@xxxxxxx>
>> ---
>>   drivers/hwtracing/coresight/coresight-core.c | 51 ++++++++------------
>>   drivers/hwtracing/coresight/coresight-priv.h |  2 -
>>   include/linux/coresight.h                    | 14 +++---
>>   3 files changed, 27 insertions(+), 40 deletions(-)
>>
>> diff --git a/drivers/hwtracing/coresight/coresight-core.c
>> b/drivers/hwtracing/coresight/coresight-core.c
>> index 965bb6d4e1bf..f79aa9ff9b64 100644
>> --- a/drivers/hwtracing/coresight/coresight-core.c
>> +++ b/drivers/hwtracing/coresight/coresight-core.c
>> @@ -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,
>>            * 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.
>>            */
>>           if (type == CORESIGHT_DEV_TYPE_LINKSINK)
>> @@ -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,
>>            * 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.
>>            */
>>           if (type == CORESIGHT_DEV_TYPE_LINKSINK)
>> @@ -635,15 +635,21 @@ struct coresight_device
>> *coresight_get_sink(struct list_head *path)
>>       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 *
>> -coresight_find_enabled_sink(struct coresight_device *csdev)
>> +coresight_find_activated_sysfs_sink(struct coresight_device *csdev)
>>   {
>>       int i;
>>       struct coresight_device *sink = NULL;
>>         if ((csdev->type == CORESIGHT_DEV_TYPE_SINK ||
>>            csdev->type == CORESIGHT_DEV_TYPE_LINKSINK) &&
>> -         csdev->activated)
>> +         csdev->sysfs_sink_activated)
>>           return csdev;
>>         /*
>> @@ -654,7 +660,7 @@ coresight_find_enabled_sink(struct
>> coresight_device *csdev)
>>             child_dev = csdev->pdata->out_conns[i]->dest_dev;
>>           if (child_dev)
>> -            sink = coresight_find_enabled_sink(child_dev);
>> +            sink = coresight_find_activated_sysfs_sink(child_dev);
>>           if (sink)
>>               return sink;
>>       }
>> @@ -662,21 +668,6 @@ coresight_find_enabled_sink(struct
>> coresight_device *csdev)
>>       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)
>>   {
>>       struct coresight_device *csdev = to_coresight_device(dev);
>> @@ -810,11 +801,10 @@ static void coresight_drop_device(struct
>> coresight_device *csdev)
>>    * @sink:    The final sink we want in this path.
>>    * @path:    The list to add devices to.
>>    *
>> - * The tree of Coresight device is traversed until an activated sink is
>> - * found.  From there the sink is added to the list along with all the
>> - * devices that led to that point - the end result is a list from source
>> - * to sink. In that list the source is the first device and the sink the
>> - * last one.
>> + * The tree of Coresight device is traversed until the selected sink
>> is found.
>
> minor nit: s/until the selected/until *a* selected/
>
> There could be multiple sinks activated that can be reached from the
> source. But we choose the "closest" possible selected sink for a source.
> So, it may be better to drop "the".
>
>

For _coresight_build_path() this isn't strictly true because the sink is
passed in as an argument so there is only one. The only function that
behaves like that is coresight_find_activated_sysfs_sink() which already
seems to be documented properly.

To clarify it I'll just change "until the selected" to "until @sink" is
found.

>> + * From there the sink is added to the list along with all the
>> devices that led
>> + * to that point - the end result is a list from source to sink. In
>> that list
>> + * the source is the first device and the sink the last one.
>>    */
>>   static int _coresight_build_path(struct coresight_device *csdev,
>>                    struct coresight_device *sink,
>> @@ -824,7 +814,7 @@ static int _coresight_build_path(struct
>> coresight_device *csdev,
>>       bool found = false;
>>       struct coresight_node *node;
>>   -    /* An activated sink has been found.  Enqueue the element */
>> +    /* The selected sink has been found.  Enqueue the element */
>
> Similarly here.
>

Same as above.

> Rest looks fine to me.
>
> Suzuki
>
>
>>       if (csdev == sink)
>>           goto out;
>>   @@ -1145,7 +1135,7 @@ int coresight_enable(struct coresight_device
>> *csdev)
>>           goto out;
>>       }
>>   -    sink = coresight_get_enabled_sink(csdev);
>> +    sink = coresight_find_activated_sysfs_sink(csdev);
>>       if (!sink) {
>>           ret = -EINVAL;
>>           goto out;
>> @@ -1259,7 +1249,7 @@ static ssize_t enable_sink_show(struct 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,
>> @@ -1274,10 +1264,7 @@ static ssize_t enable_sink_store(struct device
>> *dev,
>>       if (ret)
>>           return ret;
>>   -    if (val)
>> -        csdev->activated = true;
>> -    else
>> -        csdev->activated = false;
>> +    csdev->sysfs_sink_activated = !!val;
>>         return size;
>>   diff --git a/drivers/hwtracing/coresight/coresight-priv.h
>> b/drivers/hwtracing/coresight/coresight-priv.h
>> index 30c051055e54..ced5be05a527 100644
>> --- a/drivers/hwtracing/coresight/coresight-priv.h
>> +++ b/drivers/hwtracing/coresight/coresight-priv.h
>> @@ -130,8 +130,6 @@ void coresight_disable_path(struct list_head *path);
>>   int coresight_enable_path(struct list_head *path, enum cs_mode mode,
>>                 void *sink_data);
>>   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_find_default_sink(struct coresight_device *csdev);
>> diff --git a/include/linux/coresight.h b/include/linux/coresight.h
>> index a4cb7dd6ca23..65131bfbd904 100644
>> --- a/include/linux/coresight.h
>> +++ b/include/linux/coresight.h
>> @@ -229,10 +229,12 @@ struct coresight_sysfs_link {
>>    * @refcnt:    keep track of what is in use.
>>    * @orphan:    true if the component has connections that haven't
>> been linked.
>>    * @enable:    'true' if component is currently part of an active path.
>> - * @activated:    'true' only if a _sink_ has been activated.  A sink
>> can be
>> - *        activated but not yet enabled.  Enabling for a _sink_
>> - *        happens when a source has been selected and a path is enabled
>> - *        from source to that sink.
>> + * @sysfs_sink_activated: 'true' when a sink has been selected for
>> use via sysfs
>> + *        by writing a 1 to the 'enable_sink' file.  A sink can be
>> + *        activated but not yet enabled.  Enabling for a _sink_ happens
>> + *        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.
>>    * @def_sink:    cached reference to default sink found for this
>> device.
>>    * @nr_links:   number of sysfs links created to other components
>> from this
>> @@ -252,9 +254,9 @@ struct coresight_device {
>>       struct device dev;
>>       atomic_t refcnt;
>>       bool orphan;
>> -    bool enable;    /* true only if configured as part of a path */
>> +    bool enable;
>>       /* 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 coresight_device *def_sink;
>>       /* sysfs links between components */
>