[PATCH 03/10] coresight: etm-perf: configuring filters from perf core

Suzuki K Poulose Suzuki.Poulose at arm.com
Wed Jul 20 09:07:43 PDT 2016


On 18/07/16 20:51, Mathieu Poirier wrote:
> This patch implements the required API needed to access
> and retrieve range and start/stop filters from the perf core.
>
> Signed-off-by: Mathieu Poirier <mathieu.poirier at linaro.org>
> ---
>  drivers/hwtracing/coresight/coresight-etm-perf.c | 146 ++++++++++++++++++++---
>  drivers/hwtracing/coresight/coresight-etm-perf.h |  32 +++++
>  2 files changed, 162 insertions(+), 16 deletions(-)
>
> diff --git a/drivers/hwtracing/coresight/coresight-etm-perf.c b/drivers/hwtracing/coresight/coresight-etm-perf.c
> index 78a1bc0013a2..fde7f42149c5 100644
> --- a/drivers/hwtracing/coresight/coresight-etm-perf.c
> +++ b/drivers/hwtracing/coresight/coresight-etm-perf.c
> @@ -29,6 +29,7 @@
>  #include <linux/workqueue.h>
>
>  #include "coresight-priv.h"
> +#include "coresight-etm-perf.h"
>
>  static struct pmu etm_pmu;
>  static bool etm_perf_up;
> @@ -83,12 +84,44 @@ static const struct attribute_group *etm_pmu_attr_groups[] = {
>
>  static void etm_event_read(struct perf_event *event) {}
>
> +static int etm_addr_filters_alloc(struct perf_event *event)
> +{

...

> +	return 0;
> +}
> +


> +
>  static int etm_event_init(struct perf_event *event)
>  {
> +	int ret;
> +
>  	if (event->attr.type != etm_pmu.type)
>  		return -ENOENT;
>
> -	return 0;
> +	ret = etm_addr_filters_alloc(event);


>  }
>
>  static void free_event_data(struct work_struct *work)
> @@ -456,6 +489,85 @@ static void etm_free_drv_configs(struct perf_event *event)
>  	}
>  }
>
> +static int etm_addr_filters_validate(struct list_head *filters)
> +{

> +
> +	return 0;
> +}
> +
> +static void etm_addr_filters_sync(struct perf_event *event)
> +{
> +	struct perf_addr_filters_head *head = perf_event_addr_filters(event);
> +	unsigned long start, stop, *offs = event->addr_filters_offs;
> +	struct etm_filters *filters = event->hw.addr_filters;
> +	struct perf_addr_filter *filter;
> +	int i = 0;

Is it possible to delay the etm_addr_filters_alloc() until this point ?
I understand that this function cannot report back failures if we fail
to allocate memory. Or may be do a lazy allocation from addr_filters_validate(),
when we get the first filter added.

Of course this could be done as a follow up patch to improve things once
we get the initial framework in.



> +
> +	list_for_each_entry(filter, &head->list, entry) {
> +		start = filter->offset + offs[i];
> +		stop = start + filter->size;
> +
> +		if (filter->range == 1) {
> +			filters->filter[i].start_addr = start;
> +			filters->filter[i].stop_addr = stop;
> +			filters->filter[i].type = ETM_ADDR_TYPE_RANGE;
> +		} else {
> +			if (filter->filter == 1) {
> +				filters->filter[i].start_addr = start;
> +				filters->filter[i].type = ETM_ADDR_TYPE_START;
> +			} else {
> +				filters->filter[i].stop_addr = stop;
> +				filters->filter[i].type = ETM_ADDR_TYPE_STOP;
> +			}
> +		}
> +		i++;
> +	}
> +
> +	filters->nr_filters = i;
> +/**
> + * struct etm_filters - set of filters for a session
> + * @etm_filter:	All the filters for this session.
> + * @nr_filters:	Number of filters
> + * @ssstatus:	Status of the start/stop logic.
> + */
> +struct etm_filters {
> +	struct etm_filter	filter[ETM_ADDR_CMP_MAX];

nit: having the variable renamed to etm_filter will make the code a bit more readable
where we populate/validate the filters.

Otherwise looks good

Suzuki



More information about the linux-arm-kernel mailing list