coresight: perf: Refactor function free_event_data()
authorMathieu Poirier <mathieu.poirier@linaro.org>
Thu, 25 Apr 2019 19:53:00 +0000 (13:53 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Apr 2019 20:00:17 +0000 (22:00 +0200)
Function free_event_data() is already busy and is bound to become
worse with the addition of CPU-wide trace scenarios.  As such spin
off a new function to strickly take care of the sink buffers.

Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Reviewed-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Tested-by: Leo Yan <leo.yan@linaro.org>
Tested-by: Robert Walker <robert.walker@arm.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/hwtracing/coresight/coresight-etm-perf.c

index b8ca3800b56b61fd03ac6667580bc4d2a315b2b3..806b3dd5872dbd4d476b0a8766f651c3839cda08 100644 (file)
@@ -120,22 +120,34 @@ out:
        return ret;
 }
 
+static void free_sink_buffer(struct etm_event_data *event_data)
+{
+       int cpu;
+       cpumask_t *mask = &event_data->mask;
+       struct coresight_device *sink;
+
+       if (WARN_ON(cpumask_empty(mask)))
+               return;
+
+       if (!event_data->snk_config)
+               return;
+
+       cpu = cpumask_first(mask);
+       sink = coresight_get_sink(etm_event_cpu_path(event_data, cpu));
+       sink_ops(sink)->free_buffer(event_data->snk_config);
+}
+
 static void free_event_data(struct work_struct *work)
 {
        int cpu;
        cpumask_t *mask;
        struct etm_event_data *event_data;
-       struct coresight_device *sink;
 
        event_data = container_of(work, struct etm_event_data, work);
        mask = &event_data->mask;
 
        /* Free the sink buffers, if there are any */
-       if (event_data->snk_config && !WARN_ON(cpumask_empty(mask))) {
-               cpu = cpumask_first(mask);
-               sink = coresight_get_sink(etm_event_cpu_path(event_data, cpu));
-               sink_ops(sink)->free_buffer(event_data->snk_config);
-       }
+       free_sink_buffer(event_data);
 
        for_each_cpu(cpu, mask) {
                struct list_head **ppath;