2018-05-09 12:06:04 -06:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2012, The Linux Foundation. All rights reserved.
|
2014-11-03 11:07:35 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LINUX_CORESIGHT_H
|
|
|
|
#define _LINUX_CORESIGHT_H
|
|
|
|
|
2023-07-10 11:54:58 +05:30
|
|
|
#include <linux/amba/bus.h>
|
|
|
|
#include <linux/clk.h>
|
2014-11-03 11:07:35 -07:00
|
|
|
#include <linux/device.h>
|
2021-02-01 11:13:25 -07:00
|
|
|
#include <linux/io.h>
|
2016-02-17 17:51:57 -07:00
|
|
|
#include <linux/perf_event.h>
|
2015-07-31 09:37:30 -06:00
|
|
|
#include <linux/sched.h>
|
2024-03-14 11:28:36 +05:30
|
|
|
#include <linux/platform_device.h>
|
2014-11-03 11:07:35 -07:00
|
|
|
|
|
|
|
/* Peripheral id registers (0xFD0-0xFEC) */
|
|
|
|
#define CORESIGHT_PERIPHIDR4 0xfd0
|
|
|
|
#define CORESIGHT_PERIPHIDR5 0xfd4
|
|
|
|
#define CORESIGHT_PERIPHIDR6 0xfd8
|
|
|
|
#define CORESIGHT_PERIPHIDR7 0xfdC
|
|
|
|
#define CORESIGHT_PERIPHIDR0 0xfe0
|
|
|
|
#define CORESIGHT_PERIPHIDR1 0xfe4
|
|
|
|
#define CORESIGHT_PERIPHIDR2 0xfe8
|
|
|
|
#define CORESIGHT_PERIPHIDR3 0xfeC
|
|
|
|
/* Component id registers (0xFF0-0xFFC) */
|
|
|
|
#define CORESIGHT_COMPIDR0 0xff0
|
|
|
|
#define CORESIGHT_COMPIDR1 0xff4
|
|
|
|
#define CORESIGHT_COMPIDR2 0xff8
|
|
|
|
#define CORESIGHT_COMPIDR3 0xffC
|
|
|
|
|
|
|
|
#define ETM_ARCH_V3_3 0x23
|
|
|
|
#define ETM_ARCH_V3_5 0x25
|
|
|
|
#define PFT_ARCH_V1_0 0x30
|
|
|
|
#define PFT_ARCH_V1_1 0x31
|
|
|
|
|
|
|
|
#define CORESIGHT_UNLOCK 0xc5acce55
|
|
|
|
|
2024-01-05 13:33:32 +01:00
|
|
|
extern const struct bus_type coresight_bustype;
|
2014-11-03 11:07:35 -07:00
|
|
|
|
|
|
|
enum coresight_dev_type {
|
|
|
|
CORESIGHT_DEV_TYPE_SINK,
|
|
|
|
CORESIGHT_DEV_TYPE_LINK,
|
|
|
|
CORESIGHT_DEV_TYPE_LINKSINK,
|
|
|
|
CORESIGHT_DEV_TYPE_SOURCE,
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
CORESIGHT_DEV_TYPE_HELPER,
|
2023-04-25 15:35:40 +01:00
|
|
|
CORESIGHT_DEV_TYPE_MAX
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
enum coresight_dev_subtype_sink {
|
2023-06-02 16:41:47 +08:00
|
|
|
CORESIGHT_DEV_SUBTYPE_SINK_DUMMY,
|
2014-11-03 11:07:35 -07:00
|
|
|
CORESIGHT_DEV_SUBTYPE_SINK_PORT,
|
|
|
|
CORESIGHT_DEV_SUBTYPE_SINK_BUFFER,
|
2020-07-16 11:57:43 -06:00
|
|
|
CORESIGHT_DEV_SUBTYPE_SINK_SYSMEM,
|
2021-04-05 17:43:03 +01:00
|
|
|
CORESIGHT_DEV_SUBTYPE_SINK_PERCPU_SYSMEM,
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
enum coresight_dev_subtype_link {
|
|
|
|
CORESIGHT_DEV_SUBTYPE_LINK_MERG,
|
|
|
|
CORESIGHT_DEV_SUBTYPE_LINK_SPLIT,
|
|
|
|
CORESIGHT_DEV_SUBTYPE_LINK_FIFO,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum coresight_dev_subtype_source {
|
|
|
|
CORESIGHT_DEV_SUBTYPE_SOURCE_PROC,
|
|
|
|
CORESIGHT_DEV_SUBTYPE_SOURCE_BUS,
|
|
|
|
CORESIGHT_DEV_SUBTYPE_SOURCE_SOFTWARE,
|
2023-09-28 14:29:36 +08:00
|
|
|
CORESIGHT_DEV_SUBTYPE_SOURCE_TPDM,
|
2023-01-17 06:57:01 -08:00
|
|
|
CORESIGHT_DEV_SUBTYPE_SOURCE_OTHERS,
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
enum coresight_dev_subtype_helper {
|
2018-07-11 13:40:31 -06:00
|
|
|
CORESIGHT_DEV_SUBTYPE_HELPER_CATU,
|
2023-04-25 15:35:40 +01:00
|
|
|
CORESIGHT_DEV_SUBTYPE_HELPER_ECT_CTI
|
2020-03-20 10:52:52 -06:00
|
|
|
};
|
|
|
|
|
2014-11-03 11:07:35 -07:00
|
|
|
/**
|
2018-07-11 13:40:29 -06:00
|
|
|
* union coresight_dev_subtype - further characterisation of a type
|
2014-11-03 11:07:35 -07:00
|
|
|
* @sink_subtype: type of sink this component is, as defined
|
2018-07-11 13:40:29 -06:00
|
|
|
* by @coresight_dev_subtype_sink.
|
2014-11-03 11:07:35 -07:00
|
|
|
* @link_subtype: type of link this component is, as defined
|
2018-07-11 13:40:29 -06:00
|
|
|
* by @coresight_dev_subtype_link.
|
2014-11-03 11:07:35 -07:00
|
|
|
* @source_subtype: type of source this component is, as defined
|
2018-07-11 13:40:29 -06:00
|
|
|
* by @coresight_dev_subtype_source.
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
* @helper_subtype: type of helper this component is, as defined
|
|
|
|
* by @coresight_dev_subtype_helper.
|
2014-11-03 11:07:35 -07:00
|
|
|
*/
|
2018-07-11 13:40:29 -06:00
|
|
|
union coresight_dev_subtype {
|
|
|
|
/* We have some devices which acts as LINK and SINK */
|
|
|
|
struct {
|
|
|
|
enum coresight_dev_subtype_sink sink_subtype;
|
|
|
|
enum coresight_dev_subtype_link link_subtype;
|
|
|
|
};
|
2014-11-03 11:07:35 -07:00
|
|
|
enum coresight_dev_subtype_source source_subtype;
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
enum coresight_dev_subtype_helper helper_subtype;
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
coresight: Fix support for sparsely populated ports
On some systems the firmware may not describe all the ports
connected to a component (e.g, for security reasons). This
could be especially problematic for "funnels" where we could
end up in modifying memory beyond the allocated space for
refcounts.
e.g, for a funnel with input ports listed 0, 3, 5, nr_inport = 3.
However the we could access refcnts[5] while checking for
references, like :
[ 526.110401] ==================================================================
[ 526.117988] BUG: KASAN: slab-out-of-bounds in funnel_enable+0x54/0x1b0
[ 526.124706] Read of size 4 at addr ffffff8135f9549c by task bash/1114
[ 526.131324]
[ 526.132886] CPU: 3 PID: 1114 Comm: bash Tainted: G S 5.4.25 #232
[ 526.140397] Hardware name: Qualcomm Technologies, Inc. SC7180 IDP (DT)
[ 526.147113] Call trace:
[ 526.149653] dump_backtrace+0x0/0x188
[ 526.153431] show_stack+0x20/0x2c
[ 526.156852] dump_stack+0xdc/0x144
[ 526.160370] print_address_description+0x3c/0x494
[ 526.165211] __kasan_report+0x144/0x168
[ 526.169170] kasan_report+0x10/0x18
[ 526.172769] check_memory_region+0x1a4/0x1b4
[ 526.177164] __kasan_check_read+0x18/0x24
[ 526.181292] funnel_enable+0x54/0x1b0
[ 526.185072] coresight_enable_path+0x104/0x198
[ 526.189649] coresight_enable+0x118/0x26c
...
[ 526.237782] Allocated by task 280:
[ 526.241298] __kasan_kmalloc+0xf0/0x1ac
[ 526.245249] kasan_kmalloc+0xc/0x14
[ 526.248849] __kmalloc+0x28c/0x3b4
[ 526.252361] coresight_register+0x88/0x250
[ 526.256587] funnel_probe+0x15c/0x228
[ 526.260365] dynamic_funnel_probe+0x20/0x2c
[ 526.264679] amba_probe+0xbc/0x158
[ 526.268193] really_probe+0x144/0x408
[ 526.271970] driver_probe_device+0x70/0x140
...
[ 526.316810]
[ 526.318364] Freed by task 0:
[ 526.321344] (stack is not available)
[ 526.325024]
[ 526.326580] The buggy address belongs to the object at ffffff8135f95480
[ 526.326580] which belongs to the cache kmalloc-128 of size 128
[ 526.339439] The buggy address is located 28 bytes inside of
[ 526.339439] 128-byte region [ffffff8135f95480, ffffff8135f95500)
[ 526.351399] The buggy address belongs to the page:
[ 526.356342] page:ffffffff04b7e500 refcount:1 mapcount:0 mapping:ffffff814b00c380 index:0x0 compound_mapcount: 0
[ 526.366711] flags: 0x4000000000010200(slab|head)
[ 526.371475] raw: 4000000000010200 ffffffff05034008 ffffffff0501eb08 ffffff814b00c380
[ 526.379435] raw: 0000000000000000 0000000000190019 00000001ffffffff 0000000000000000
[ 526.387393] page dumped because: kasan: bad access detected
[ 526.393128]
[ 526.394681] Memory state around the buggy address:
[ 526.399619] ffffff8135f95380: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[ 526.407046] ffffff8135f95400: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[ 526.414473] >ffffff8135f95480: 04 fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[ 526.421900] ^
[ 526.426029] ffffff8135f95500: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[ 526.433456] ffffff8135f95580: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
[ 526.440883] ==================================================================
To keep the code simple, we now track the maximum number of
possible input/output connections to/from this component
@ nr_inport and nr_outport in platform_data, respectively.
Thus the output connections could be sparse and code is
adjusted to skip the unspecified connections.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Cc: Mike Leach <mike.leach@linaro.org>
Reported-by: Sai Prakash Ranjan <saiprakash.ranjan@codeaurora.org>
Tested-by: Sai Prakash Ranjan <saiprakash.ranjan@codeaurora.org>
Tested-by: Stephen Boyd <swboyd@chromium.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Link: https://lore.kernel.org/r/20200518180242.7916-13-mathieu.poirier@linaro.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2020-05-18 12:02:31 -06:00
|
|
|
* struct coresight_platform_data - data harvested from the firmware
|
|
|
|
* specification.
|
|
|
|
*
|
2023-04-25 15:35:31 +01:00
|
|
|
* @nr_inconns: Number of elements for the input connections.
|
|
|
|
* @nr_outconns: Number of elements for the output connections.
|
2023-04-25 15:35:34 +01:00
|
|
|
* @out_conns: Array of nr_outconns pointers to connections from this
|
|
|
|
* component.
|
2023-04-25 15:35:36 +01:00
|
|
|
* @in_conns: Sparse array of pointers to input connections. Sparse
|
|
|
|
* because the source device owns the connection so when it's
|
|
|
|
* unloaded the connection leaves an empty slot.
|
2014-11-03 11:07:35 -07:00
|
|
|
*/
|
|
|
|
struct coresight_platform_data {
|
2023-04-25 15:35:31 +01:00
|
|
|
int nr_inconns;
|
|
|
|
int nr_outconns;
|
2023-04-25 15:35:34 +01:00
|
|
|
struct coresight_connection **out_conns;
|
2023-04-25 15:35:36 +01:00
|
|
|
struct coresight_connection **in_conns;
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
2021-02-01 11:13:25 -07:00
|
|
|
/**
|
|
|
|
* struct csdev_access - Abstraction of a CoreSight device access.
|
|
|
|
*
|
|
|
|
* @io_mem : True if the device has memory mapped I/O
|
|
|
|
* @base : When io_mem == true, base address of the component
|
|
|
|
* @read : Read from the given "offset" of the given instance.
|
|
|
|
* @write : Write "val" to the given "offset".
|
|
|
|
*/
|
|
|
|
struct csdev_access {
|
|
|
|
bool io_mem;
|
|
|
|
union {
|
|
|
|
void __iomem *base;
|
|
|
|
struct {
|
|
|
|
u64 (*read)(u32 offset, bool relaxed, bool _64bit);
|
|
|
|
void (*write)(u64 val, u32 offset, bool relaxed,
|
|
|
|
bool _64bit);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
#define CSDEV_ACCESS_IOMEM(_addr) \
|
|
|
|
((struct csdev_access) { \
|
|
|
|
.io_mem = true, \
|
|
|
|
.base = (_addr), \
|
|
|
|
})
|
|
|
|
|
2014-11-03 11:07:35 -07:00
|
|
|
/**
|
|
|
|
* struct coresight_desc - description of a component required from drivers
|
|
|
|
* @type: as defined by @coresight_dev_type.
|
|
|
|
* @subtype: as defined by @coresight_dev_subtype.
|
|
|
|
* @ops: generic operations for this component, as defined
|
2019-06-19 13:52:57 -06:00
|
|
|
* by @coresight_ops.
|
2014-11-03 11:07:35 -07:00
|
|
|
* @pdata: platform data collected from DT.
|
|
|
|
* @dev: The device entity associated to this component.
|
2014-11-13 14:12:48 +05:30
|
|
|
* @groups: operations specific to this component. These will end up
|
2019-06-19 13:52:57 -06:00
|
|
|
* in the component's sysfs sub-directory.
|
|
|
|
* @name: name for the coresight device, also shown under sysfs.
|
2021-02-01 11:13:25 -07:00
|
|
|
* @access: Describe access to the device
|
2014-11-03 11:07:35 -07:00
|
|
|
*/
|
|
|
|
struct coresight_desc {
|
|
|
|
enum coresight_dev_type type;
|
2018-07-11 13:40:29 -06:00
|
|
|
union coresight_dev_subtype subtype;
|
2014-11-03 11:07:35 -07:00
|
|
|
const struct coresight_ops *ops;
|
|
|
|
struct coresight_platform_data *pdata;
|
|
|
|
struct device *dev;
|
|
|
|
const struct attribute_group **groups;
|
2019-06-19 13:52:57 -06:00
|
|
|
const char *name;
|
2021-02-01 11:13:25 -07:00
|
|
|
struct csdev_access access;
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* struct coresight_connection - representation of a single connection
|
2023-04-25 15:35:32 +01:00
|
|
|
* @src_port: a connection's output port number.
|
|
|
|
* @dest_port: destination's input port number @src_port is connected to.
|
|
|
|
* @dest_fwnode: destination component's fwnode handle.
|
|
|
|
* @dest_dev: a @coresight_device representation of the component
|
|
|
|
connected to @src_port. NULL until the device is created
|
2020-05-18 12:02:23 -06:00
|
|
|
* @link: Representation of the connection as a sysfs link.
|
2023-04-25 15:35:36 +01:00
|
|
|
*
|
|
|
|
* The full connection structure looks like this, where in_conns store
|
|
|
|
* references to same connection as the source device's out_conns.
|
|
|
|
*
|
|
|
|
* +-----------------------------+ +-----------------------------+
|
|
|
|
* |coresight_device | |coresight_connection |
|
|
|
|
* |-----------------------------| |-----------------------------|
|
|
|
|
* | | | |
|
|
|
|
* | | | dest_dev*|<--
|
|
|
|
* |pdata->out_conns[nr_outconns]|<->|src_dev* | |
|
|
|
|
* | | | | |
|
|
|
|
* +-----------------------------+ +-----------------------------+ |
|
|
|
|
* |
|
|
|
|
* +-----------------------------+ |
|
|
|
|
* |coresight_device | |
|
|
|
|
* |------------------------------ |
|
|
|
|
* | | |
|
|
|
|
* | pdata->in_conns[nr_inconns]|<--
|
|
|
|
* | |
|
|
|
|
* +-----------------------------+
|
2014-11-03 11:07:35 -07:00
|
|
|
*/
|
|
|
|
struct coresight_connection {
|
2023-04-25 15:35:32 +01:00
|
|
|
int src_port;
|
|
|
|
int dest_port;
|
|
|
|
struct fwnode_handle *dest_fwnode;
|
|
|
|
struct coresight_device *dest_dev;
|
2020-05-18 12:02:23 -06:00
|
|
|
struct coresight_sysfs_link *link;
|
2023-04-25 15:35:36 +01:00
|
|
|
struct coresight_device *src_dev;
|
2023-04-25 15:35:37 +01:00
|
|
|
atomic_t src_refcnt;
|
|
|
|
atomic_t dest_refcnt;
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
2020-05-18 12:02:22 -06:00
|
|
|
/**
|
|
|
|
* struct coresight_sysfs_link - representation of a connection in sysfs.
|
|
|
|
* @orig: Originating (master) coresight device for the link.
|
|
|
|
* @orig_name: Name to use for the link orig->target.
|
|
|
|
* @target: Target (slave) coresight device for the link.
|
|
|
|
* @target_name: Name to use for the link target->orig.
|
|
|
|
*/
|
|
|
|
struct coresight_sysfs_link {
|
|
|
|
struct coresight_device *orig;
|
|
|
|
const char *orig_name;
|
|
|
|
struct coresight_device *target;
|
|
|
|
const char *target_name;
|
|
|
|
};
|
|
|
|
|
2024-07-22 11:11:53 +01:00
|
|
|
/* architecturally we have 128 IDs some of which are reserved */
|
|
|
|
#define CORESIGHT_TRACE_IDS_MAX 128
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Trace ID map.
|
|
|
|
*
|
|
|
|
* @used_ids: Bitmap to register available (bit = 0) and in use (bit = 1) IDs.
|
|
|
|
* Initialised so that the reserved IDs are permanently marked as
|
|
|
|
* in use.
|
|
|
|
* @pend_rel_ids: CPU IDs that have been released by the trace source but not
|
|
|
|
* yet marked as available, to allow re-allocation to the same
|
|
|
|
* CPU during a perf session.
|
|
|
|
*/
|
|
|
|
struct coresight_trace_id_map {
|
|
|
|
DECLARE_BITMAP(used_ids, CORESIGHT_TRACE_IDS_MAX);
|
|
|
|
DECLARE_BITMAP(pend_rel_ids, CORESIGHT_TRACE_IDS_MAX);
|
2024-07-22 11:11:55 +01:00
|
|
|
atomic_t __percpu *cpu_map;
|
2024-07-22 11:11:53 +01:00
|
|
|
};
|
|
|
|
|
2014-11-03 11:07:35 -07:00
|
|
|
/**
|
|
|
|
* struct coresight_device - representation of a device as used by the framework
|
2019-06-19 13:52:59 -06:00
|
|
|
* @pdata: Platform data with device connections associated to this device.
|
2014-11-03 11:07:35 -07:00
|
|
|
* @type: as defined by @coresight_dev_type.
|
|
|
|
* @subtype: as defined by @coresight_dev_subtype.
|
|
|
|
* @ops: generic operations for this component, as defined
|
2021-02-01 11:13:25 -07:00
|
|
|
* by @coresight_ops.
|
|
|
|
* @access: Device i/o access abstraction for this device.
|
2014-11-03 11:07:35 -07:00
|
|
|
* @dev: The device entity associated to this component.
|
2024-01-29 15:40:35 +00:00
|
|
|
* @mode: This tracer's mode, i.e sysFS, Perf or disabled. This is
|
|
|
|
* actually an 'enum cs_mode', but is stored in an atomic type.
|
|
|
|
* This is always accessed through local_read() and local_set(),
|
|
|
|
* but wherever it's done from within the Coresight device's lock,
|
2024-01-29 15:40:38 +00:00
|
|
|
* a non-atomic read would also work. This is the main point of
|
|
|
|
* synchronisation between code happening inside the sysfs mode's
|
|
|
|
* coresight_mutex and outside when running in Perf mode. A compare
|
|
|
|
* and exchange swap is done to atomically claim one mode or the
|
|
|
|
* other.
|
|
|
|
* @refcnt: keep track of what is in use. Only access this outside of the
|
|
|
|
* device's spinlock when the coresight_mutex held and mode ==
|
|
|
|
* CS_MODE_SYSFS. Otherwise it must be accessed from inside the
|
|
|
|
* spinlock.
|
2014-11-03 11:07:35 -07:00
|
|
|
* @orphan: true if the component has connections that haven't been linked.
|
2024-01-29 15:40:33 +00:00
|
|
|
* @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.
|
coresight: perf: Add "sinks" group to PMU directory
Add a "sinks" directory entry so that users can see all the sinks
available in the system in a single place. Individual sink are added
as they are registered with the coresight bus.
Committer tests:
Test built on a ubuntu 18.04 container with a cross build environment to
arm64, the new field is there, need to find a machine with this feature
to do further testing in the future.
root@d15263e5734a:/git/perf# grep CORESIGHT /tmp/build/v5.0-rc2+/.config
CONFIG_CORESIGHT=y
CONFIG_CORESIGHT_LINKS_AND_SINKS=y
CONFIG_CORESIGHT_LINK_AND_SINK_TMC=y
CONFIG_CORESIGHT_CATU=y
CONFIG_CORESIGHT_SINK_TPIU=y
CONFIG_CORESIGHT_SINK_ETBV10=y
CONFIG_CORESIGHT_SOURCE_ETM4X=y
CONFIG_CORESIGHT_DYNAMIC_REPLICATOR=y
CONFIG_CORESIGHT_STM=y
CONFIG_CORESIGHT_CPU_DEBUG=m
root@d15263e5734a:/git/perf#
root@d15263e5734a:/git/perf# file /tmp/build/v5.0-rc2+/drivers/hwtracing/coresight/*.o
.../coresight/coresight-catu.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-cpu-debug.mod.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-cpu-debug.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-dynamic-replicator.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etb10.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm-perf.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm4x-sysfs.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm4x.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-funnel.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-replicator.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-stm.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc-etf.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc-etr.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tpiu.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/of_coresight.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
root@d15263e5734a:/git/perf#
root@d15263e5734a:/git/perf# pahole -C coresight_device /tmp/build/v5.0-rc2+/drivers/hwtracing/coresight/coresight.o
struct coresight_device {
struct coresight_connection * conns; /* 0 8 */
int nr_inport; /* 8 4 */
int nr_outport; /* 12 4 */
enum coresight_dev_type type; /* 16 4 */
union coresight_dev_subtype subtype; /* 20 8 */
/* XXX 4 bytes hole, try to pack */
const struct coresight_ops * ops; /* 32 8 */
struct device dev; /* 40 1408 */
/* XXX last struct has 7 bytes of padding */
/* --- cacheline 22 boundary (1408 bytes) was 40 bytes ago --- */
atomic_t * refcnt; /* 1448 8 */
bool orphan; /* 1456 1 */
bool enable; /* 1457 1 */
bool activated; /* 1458 1 */
/* XXX 5 bytes hole, try to pack */
struct dev_ext_attribute * ea; /* 1464 8 */
/* size: 1472, cachelines: 23, members: 12 */
/* sum members: 1463, holes: 2, sum holes: 9 */
/* paddings: 1, sum paddings: 7 */
};
root@d15263e5734a:/git/perf#
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Reviewed-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Alexei Starovoitov <ast@kernel.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Will Deacon <will.deacon@arm.com>
Cc: linux-arm-kernel@lists.infradead.org
Cc: linux-s390@vger.kernel.org
Link: http://lkml.kernel.org/r/20190131184714.20388-3-mathieu.poirier@linaro.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2019-01-31 11:47:09 -07:00
|
|
|
* @ea: Device attribute for sink representation under PMU directory.
|
2020-07-16 11:57:43 -06:00
|
|
|
* @def_sink: cached reference to default sink found for this device.
|
2020-05-18 12:02:22 -06:00
|
|
|
* @nr_links: number of sysfs links created to other components from this
|
|
|
|
* device. These will appear in the "connections" group.
|
|
|
|
* @has_conns_grp: Have added a "connections" group for sysfs links.
|
2021-08-18 13:40:13 -06:00
|
|
|
* @feature_csdev_list: List of complex feature programming added to the device.
|
|
|
|
* @config_csdev_list: List of system configurations added to the device.
|
|
|
|
* @cscfg_csdev_lock: Protect the lists of configurations and features.
|
2021-08-18 13:40:16 -06:00
|
|
|
* @active_cscfg_ctxt: Context information for current active system configuration.
|
2014-11-03 11:07:35 -07:00
|
|
|
*/
|
|
|
|
struct coresight_device {
|
2019-06-19 13:52:59 -06:00
|
|
|
struct coresight_platform_data *pdata;
|
2014-11-03 11:07:35 -07:00
|
|
|
enum coresight_dev_type type;
|
2018-07-11 13:40:29 -06:00
|
|
|
union coresight_dev_subtype subtype;
|
2014-11-03 11:07:35 -07:00
|
|
|
const struct coresight_ops *ops;
|
2021-02-01 11:13:25 -07:00
|
|
|
struct csdev_access access;
|
2014-11-03 11:07:35 -07:00
|
|
|
struct device dev;
|
2024-01-29 15:40:35 +00:00
|
|
|
local_t mode;
|
2024-01-29 15:40:38 +00:00
|
|
|
int refcnt;
|
2014-11-03 11:07:35 -07:00
|
|
|
bool orphan;
|
coresight: perf: Add "sinks" group to PMU directory
Add a "sinks" directory entry so that users can see all the sinks
available in the system in a single place. Individual sink are added
as they are registered with the coresight bus.
Committer tests:
Test built on a ubuntu 18.04 container with a cross build environment to
arm64, the new field is there, need to find a machine with this feature
to do further testing in the future.
root@d15263e5734a:/git/perf# grep CORESIGHT /tmp/build/v5.0-rc2+/.config
CONFIG_CORESIGHT=y
CONFIG_CORESIGHT_LINKS_AND_SINKS=y
CONFIG_CORESIGHT_LINK_AND_SINK_TMC=y
CONFIG_CORESIGHT_CATU=y
CONFIG_CORESIGHT_SINK_TPIU=y
CONFIG_CORESIGHT_SINK_ETBV10=y
CONFIG_CORESIGHT_SOURCE_ETM4X=y
CONFIG_CORESIGHT_DYNAMIC_REPLICATOR=y
CONFIG_CORESIGHT_STM=y
CONFIG_CORESIGHT_CPU_DEBUG=m
root@d15263e5734a:/git/perf#
root@d15263e5734a:/git/perf# file /tmp/build/v5.0-rc2+/drivers/hwtracing/coresight/*.o
.../coresight/coresight-catu.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-cpu-debug.mod.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-cpu-debug.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-dynamic-replicator.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etb10.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm-perf.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm4x-sysfs.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm4x.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-funnel.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-replicator.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-stm.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc-etf.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc-etr.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tpiu.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/of_coresight.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
root@d15263e5734a:/git/perf#
root@d15263e5734a:/git/perf# pahole -C coresight_device /tmp/build/v5.0-rc2+/drivers/hwtracing/coresight/coresight.o
struct coresight_device {
struct coresight_connection * conns; /* 0 8 */
int nr_inport; /* 8 4 */
int nr_outport; /* 12 4 */
enum coresight_dev_type type; /* 16 4 */
union coresight_dev_subtype subtype; /* 20 8 */
/* XXX 4 bytes hole, try to pack */
const struct coresight_ops * ops; /* 32 8 */
struct device dev; /* 40 1408 */
/* XXX last struct has 7 bytes of padding */
/* --- cacheline 22 boundary (1408 bytes) was 40 bytes ago --- */
atomic_t * refcnt; /* 1448 8 */
bool orphan; /* 1456 1 */
bool enable; /* 1457 1 */
bool activated; /* 1458 1 */
/* XXX 5 bytes hole, try to pack */
struct dev_ext_attribute * ea; /* 1464 8 */
/* size: 1472, cachelines: 23, members: 12 */
/* sum members: 1463, holes: 2, sum holes: 9 */
/* paddings: 1, sum paddings: 7 */
};
root@d15263e5734a:/git/perf#
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Reviewed-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Alexei Starovoitov <ast@kernel.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Will Deacon <will.deacon@arm.com>
Cc: linux-arm-kernel@lists.infradead.org
Cc: linux-s390@vger.kernel.org
Link: http://lkml.kernel.org/r/20190131184714.20388-3-mathieu.poirier@linaro.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2019-01-31 11:47:09 -07:00
|
|
|
/* sink specific fields */
|
2024-01-29 15:40:33 +00:00
|
|
|
bool sysfs_sink_activated;
|
coresight: perf: Add "sinks" group to PMU directory
Add a "sinks" directory entry so that users can see all the sinks
available in the system in a single place. Individual sink are added
as they are registered with the coresight bus.
Committer tests:
Test built on a ubuntu 18.04 container with a cross build environment to
arm64, the new field is there, need to find a machine with this feature
to do further testing in the future.
root@d15263e5734a:/git/perf# grep CORESIGHT /tmp/build/v5.0-rc2+/.config
CONFIG_CORESIGHT=y
CONFIG_CORESIGHT_LINKS_AND_SINKS=y
CONFIG_CORESIGHT_LINK_AND_SINK_TMC=y
CONFIG_CORESIGHT_CATU=y
CONFIG_CORESIGHT_SINK_TPIU=y
CONFIG_CORESIGHT_SINK_ETBV10=y
CONFIG_CORESIGHT_SOURCE_ETM4X=y
CONFIG_CORESIGHT_DYNAMIC_REPLICATOR=y
CONFIG_CORESIGHT_STM=y
CONFIG_CORESIGHT_CPU_DEBUG=m
root@d15263e5734a:/git/perf#
root@d15263e5734a:/git/perf# file /tmp/build/v5.0-rc2+/drivers/hwtracing/coresight/*.o
.../coresight/coresight-catu.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-cpu-debug.mod.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-cpu-debug.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-dynamic-replicator.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etb10.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm-perf.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm4x-sysfs.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-etm4x.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-funnel.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-replicator.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-stm.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc-etf.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc-etr.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tmc.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight-tpiu.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/coresight.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
.../coresight/of_coresight.o: ELF 64-bit MSB relocatable, ARM aarch64, version 1 (SYSV), not stripped
root@d15263e5734a:/git/perf#
root@d15263e5734a:/git/perf# pahole -C coresight_device /tmp/build/v5.0-rc2+/drivers/hwtracing/coresight/coresight.o
struct coresight_device {
struct coresight_connection * conns; /* 0 8 */
int nr_inport; /* 8 4 */
int nr_outport; /* 12 4 */
enum coresight_dev_type type; /* 16 4 */
union coresight_dev_subtype subtype; /* 20 8 */
/* XXX 4 bytes hole, try to pack */
const struct coresight_ops * ops; /* 32 8 */
struct device dev; /* 40 1408 */
/* XXX last struct has 7 bytes of padding */
/* --- cacheline 22 boundary (1408 bytes) was 40 bytes ago --- */
atomic_t * refcnt; /* 1448 8 */
bool orphan; /* 1456 1 */
bool enable; /* 1457 1 */
bool activated; /* 1458 1 */
/* XXX 5 bytes hole, try to pack */
struct dev_ext_attribute * ea; /* 1464 8 */
/* size: 1472, cachelines: 23, members: 12 */
/* sum members: 1463, holes: 2, sum holes: 9 */
/* paddings: 1, sum paddings: 7 */
};
root@d15263e5734a:/git/perf#
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Reviewed-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Alexei Starovoitov <ast@kernel.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Will Deacon <will.deacon@arm.com>
Cc: linux-arm-kernel@lists.infradead.org
Cc: linux-s390@vger.kernel.org
Link: http://lkml.kernel.org/r/20190131184714.20388-3-mathieu.poirier@linaro.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2019-01-31 11:47:09 -07:00
|
|
|
struct dev_ext_attribute *ea;
|
2020-07-16 11:57:43 -06:00
|
|
|
struct coresight_device *def_sink;
|
2020-05-18 12:02:22 -06:00
|
|
|
/* sysfs links between components */
|
|
|
|
int nr_links;
|
|
|
|
bool has_conns_grp;
|
2021-08-18 13:40:13 -06:00
|
|
|
/* system configuration and feature lists */
|
|
|
|
struct list_head feature_csdev_list;
|
|
|
|
struct list_head config_csdev_list;
|
|
|
|
spinlock_t cscfg_csdev_lock;
|
2021-08-18 13:40:16 -06:00
|
|
|
void *active_cscfg_ctxt;
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
2019-06-19 13:53:04 -06:00
|
|
|
/*
|
|
|
|
* coresight_dev_list - Mapping for devices to "name" index for device
|
|
|
|
* names.
|
|
|
|
*
|
|
|
|
* @nr_idx: Number of entries already allocated.
|
|
|
|
* @pfx: Prefix pattern for device name.
|
|
|
|
* @fwnode_list: Array of fwnode_handles associated with each allocated
|
|
|
|
* index, upto nr_idx entries.
|
|
|
|
*/
|
|
|
|
struct coresight_dev_list {
|
|
|
|
int nr_idx;
|
|
|
|
const char *pfx;
|
|
|
|
struct fwnode_handle **fwnode_list;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define DEFINE_CORESIGHT_DEVLIST(var, dev_pfx) \
|
|
|
|
static struct coresight_dev_list (var) = { \
|
|
|
|
.pfx = dev_pfx, \
|
|
|
|
.nr_idx = 0, \
|
|
|
|
.fwnode_list = NULL, \
|
|
|
|
}
|
|
|
|
|
2014-11-03 11:07:35 -07:00
|
|
|
#define to_coresight_device(d) container_of(d, struct coresight_device, dev)
|
|
|
|
|
2023-04-25 15:35:29 +01:00
|
|
|
enum cs_mode {
|
|
|
|
CS_MODE_DISABLED,
|
|
|
|
CS_MODE_SYSFS,
|
|
|
|
CS_MODE_PERF,
|
|
|
|
};
|
|
|
|
|
2014-11-03 11:07:35 -07:00
|
|
|
#define source_ops(csdev) csdev->ops->source_ops
|
|
|
|
#define sink_ops(csdev) csdev->ops->sink_ops
|
|
|
|
#define link_ops(csdev) csdev->ops->link_ops
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
#define helper_ops(csdev) csdev->ops->helper_ops
|
2020-03-20 10:52:52 -06:00
|
|
|
#define ect_ops(csdev) csdev->ops->ect_ops
|
2014-11-03 11:07:35 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* struct coresight_ops_sink - basic operations for a sink
|
|
|
|
* Operations available for sinks
|
2016-02-17 17:52:00 -07:00
|
|
|
* @enable: enables the sink.
|
|
|
|
* @disable: disables the sink.
|
|
|
|
* @alloc_buffer: initialises perf's ring buffer for trace collection.
|
|
|
|
* @free_buffer: release memory allocated in @get_config.
|
|
|
|
* @update_buffer: update buffer pointers after a trace session.
|
2014-11-03 11:07:35 -07:00
|
|
|
*/
|
|
|
|
struct coresight_ops_sink {
|
2023-04-25 15:35:29 +01:00
|
|
|
int (*enable)(struct coresight_device *csdev, enum cs_mode mode,
|
|
|
|
void *data);
|
2019-04-25 13:52:55 -06:00
|
|
|
int (*disable)(struct coresight_device *csdev);
|
2019-04-25 13:53:01 -06:00
|
|
|
void *(*alloc_buffer)(struct coresight_device *csdev,
|
|
|
|
struct perf_event *event, void **pages,
|
|
|
|
int nr_pages, bool overwrite);
|
2016-02-17 17:52:00 -07:00
|
|
|
void (*free_buffer)(void *config);
|
2018-09-20 13:17:54 -06:00
|
|
|
unsigned long (*update_buffer)(struct coresight_device *csdev,
|
2016-02-17 17:52:00 -07:00
|
|
|
struct perf_output_handle *handle,
|
|
|
|
void *sink_config);
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* struct coresight_ops_link - basic operations for a link
|
|
|
|
* Operations available for links.
|
|
|
|
* @enable: enables flow between iport and oport.
|
|
|
|
* @disable: disables flow between iport and oport.
|
|
|
|
*/
|
|
|
|
struct coresight_ops_link {
|
2023-04-25 15:35:37 +01:00
|
|
|
int (*enable)(struct coresight_device *csdev,
|
|
|
|
struct coresight_connection *in,
|
|
|
|
struct coresight_connection *out);
|
|
|
|
void (*disable)(struct coresight_device *csdev,
|
|
|
|
struct coresight_connection *in,
|
|
|
|
struct coresight_connection *out);
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* struct coresight_ops_source - basic operations for a source
|
|
|
|
* Operations available for sources.
|
2016-02-02 14:14:01 -07:00
|
|
|
* @cpu_id: returns the value of the CPU number this component
|
|
|
|
* is associated to.
|
2015-10-07 09:26:39 -06:00
|
|
|
* @enable: enables tracing for a source.
|
2014-11-03 11:07:35 -07:00
|
|
|
* @disable: disables tracing for a source.
|
|
|
|
*/
|
|
|
|
struct coresight_ops_source {
|
2016-02-02 14:14:01 -07:00
|
|
|
int (*cpu_id)(struct coresight_device *csdev);
|
2023-04-25 15:35:29 +01:00
|
|
|
int (*enable)(struct coresight_device *csdev, struct perf_event *event,
|
|
|
|
enum cs_mode mode);
|
2016-08-25 15:19:10 -06:00
|
|
|
void (*disable)(struct coresight_device *csdev,
|
|
|
|
struct perf_event *event);
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
/**
|
|
|
|
* struct coresight_ops_helper - Operations for a helper device.
|
|
|
|
*
|
|
|
|
* All operations could pass in a device specific data, which could
|
|
|
|
* help the helper device to determine what to do.
|
|
|
|
*
|
|
|
|
* @enable : Enable the device
|
|
|
|
* @disable : Disable the device
|
|
|
|
*/
|
|
|
|
struct coresight_ops_helper {
|
2023-04-25 15:35:39 +01:00
|
|
|
int (*enable)(struct coresight_device *csdev, enum cs_mode mode,
|
|
|
|
void *data);
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
int (*disable)(struct coresight_device *csdev, void *data);
|
|
|
|
};
|
|
|
|
|
2014-11-03 11:07:35 -07:00
|
|
|
struct coresight_ops {
|
|
|
|
const struct coresight_ops_sink *sink_ops;
|
|
|
|
const struct coresight_ops_link *link_ops;
|
|
|
|
const struct coresight_ops_source *source_ops;
|
coresight: Add helper device type
Add a new coresight device type, which do not belong to any
of the existing types, i.e, source, sink, link etc. A helper
device could be connected to a coresight device, which could
augment the functionality of the coresight device.
This is intended to cover Coresight Address Translation Unit (CATU)
devices, which provide improved Scatter Gather mechanism for TMC
ETR. The idea is that the helper device could be controlled by
the driver of the device it is attached to (in this case ETR),
transparent to the generic coresight driver (and paths).
The operations include enable(), disable(), both of which could
accept a device specific "data" which the driving device and
the helper device could share. Since they don't appear in the
coresight "path" tracked by software, we have to ensure that
they are powered up/down whenever the master device is turned
on.
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-07-11 13:40:30 -06:00
|
|
|
const struct coresight_ops_helper *helper_ops;
|
2014-11-03 11:07:35 -07:00
|
|
|
};
|
|
|
|
|
2021-02-01 11:13:25 -07:00
|
|
|
static inline u32 csdev_access_relaxed_read32(struct csdev_access *csa,
|
|
|
|
u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
return readl_relaxed(csa->base + offset);
|
|
|
|
|
|
|
|
return csa->read(offset, true, false);
|
|
|
|
}
|
|
|
|
|
2023-07-10 11:54:58 +05:30
|
|
|
#define CORESIGHT_CIDRn(i) (0xFF0 + ((i) * 4))
|
|
|
|
|
|
|
|
static inline u32 coresight_get_cid(void __iomem *base)
|
|
|
|
{
|
|
|
|
u32 i, cid = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < 4; i++)
|
|
|
|
cid |= readl(base + CORESIGHT_CIDRn(i)) << (i * 8);
|
|
|
|
|
|
|
|
return cid;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool is_coresight_device(void __iomem *base)
|
|
|
|
{
|
|
|
|
u32 cid = coresight_get_cid(base);
|
|
|
|
|
|
|
|
return cid == CORESIGHT_CID;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Attempt to find and enable "APB clock" for the given device
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
*
|
|
|
|
* clk - Clock is found and enabled
|
|
|
|
* NULL - clock is not found
|
|
|
|
* ERROR - Clock is found but failed to enable
|
|
|
|
*/
|
|
|
|
static inline struct clk *coresight_get_enable_apb_pclk(struct device *dev)
|
|
|
|
{
|
|
|
|
struct clk *pclk;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
pclk = clk_get(dev, "apb_pclk");
|
|
|
|
if (IS_ERR(pclk))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
ret = clk_prepare_enable(pclk);
|
|
|
|
if (ret) {
|
|
|
|
clk_put(pclk);
|
|
|
|
return ERR_PTR(ret);
|
|
|
|
}
|
|
|
|
return pclk;
|
|
|
|
}
|
|
|
|
|
2023-07-10 11:54:57 +05:30
|
|
|
#define CORESIGHT_PIDRn(i) (0xFE0 + ((i) * 4))
|
|
|
|
|
|
|
|
static inline u32 coresight_get_pid(struct csdev_access *csa)
|
|
|
|
{
|
|
|
|
u32 i, pid = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < 4; i++)
|
|
|
|
pid |= csdev_access_relaxed_read32(csa, CORESIGHT_PIDRn(i)) << (i * 8);
|
|
|
|
|
|
|
|
return pid;
|
|
|
|
}
|
|
|
|
|
2022-08-30 18:26:10 +01:00
|
|
|
static inline u64 csdev_access_relaxed_read_pair(struct csdev_access *csa,
|
2022-08-30 18:26:13 +01:00
|
|
|
u32 lo_offset, u32 hi_offset)
|
2022-08-30 18:26:10 +01:00
|
|
|
{
|
|
|
|
if (likely(csa->io_mem)) {
|
2022-08-30 18:26:13 +01:00
|
|
|
return readl_relaxed(csa->base + lo_offset) |
|
|
|
|
((u64)readl_relaxed(csa->base + hi_offset) << 32);
|
2022-08-30 18:26:10 +01:00
|
|
|
}
|
|
|
|
|
2022-08-30 18:26:13 +01:00
|
|
|
return csa->read(lo_offset, true, false) | (csa->read(hi_offset, true, false) << 32);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void csdev_access_relaxed_write_pair(struct csdev_access *csa, u64 val,
|
|
|
|
u32 lo_offset, u32 hi_offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem)) {
|
|
|
|
writel_relaxed((u32)val, csa->base + lo_offset);
|
|
|
|
writel_relaxed((u32)(val >> 32), csa->base + hi_offset);
|
|
|
|
} else {
|
|
|
|
csa->write((u32)val, lo_offset, true, false);
|
|
|
|
csa->write((u32)(val >> 32), hi_offset, true, false);
|
|
|
|
}
|
2022-08-30 18:26:10 +01:00
|
|
|
}
|
|
|
|
|
2021-02-01 11:13:25 -07:00
|
|
|
static inline u32 csdev_access_read32(struct csdev_access *csa, u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
return readl(csa->base + offset);
|
|
|
|
|
|
|
|
return csa->read(offset, false, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void csdev_access_relaxed_write32(struct csdev_access *csa,
|
|
|
|
u32 val, u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
writel_relaxed(val, csa->base + offset);
|
|
|
|
else
|
|
|
|
csa->write(val, offset, true, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void csdev_access_write32(struct csdev_access *csa, u32 val, u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
writel(val, csa->base + offset);
|
|
|
|
else
|
|
|
|
csa->write(val, offset, false, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef CONFIG_64BIT
|
|
|
|
|
|
|
|
static inline u64 csdev_access_relaxed_read64(struct csdev_access *csa,
|
|
|
|
u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
return readq_relaxed(csa->base + offset);
|
|
|
|
|
|
|
|
return csa->read(offset, true, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline u64 csdev_access_read64(struct csdev_access *csa, u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
return readq(csa->base + offset);
|
|
|
|
|
|
|
|
return csa->read(offset, false, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void csdev_access_relaxed_write64(struct csdev_access *csa,
|
|
|
|
u64 val, u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
writeq_relaxed(val, csa->base + offset);
|
|
|
|
else
|
|
|
|
csa->write(val, offset, true, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void csdev_access_write64(struct csdev_access *csa, u64 val, u32 offset)
|
|
|
|
{
|
|
|
|
if (likely(csa->io_mem))
|
|
|
|
writeq(val, csa->base + offset);
|
|
|
|
else
|
|
|
|
csa->write(val, offset, false, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
#else /* !CONFIG_64BIT */
|
|
|
|
|
|
|
|
static inline u64 csdev_access_relaxed_read64(struct csdev_access *csa,
|
|
|
|
u32 offset)
|
|
|
|
{
|
|
|
|
WARN_ON(1);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline u64 csdev_access_read64(struct csdev_access *csa, u32 offset)
|
|
|
|
{
|
|
|
|
WARN_ON(1);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void csdev_access_relaxed_write64(struct csdev_access *csa,
|
|
|
|
u64 val, u32 offset)
|
|
|
|
{
|
|
|
|
WARN_ON(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void csdev_access_write64(struct csdev_access *csa, u64 val, u32 offset)
|
|
|
|
{
|
|
|
|
WARN_ON(1);
|
|
|
|
}
|
|
|
|
#endif /* CONFIG_64BIT */
|
|
|
|
|
2021-04-05 17:43:03 +01:00
|
|
|
static inline bool coresight_is_percpu_source(struct coresight_device *csdev)
|
|
|
|
{
|
|
|
|
return csdev && (csdev->type == CORESIGHT_DEV_TYPE_SOURCE) &&
|
|
|
|
(csdev->subtype.source_subtype == CORESIGHT_DEV_SUBTYPE_SOURCE_PROC);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool coresight_is_percpu_sink(struct coresight_device *csdev)
|
|
|
|
{
|
|
|
|
return csdev && (csdev->type == CORESIGHT_DEV_TYPE_SINK) &&
|
|
|
|
(csdev->subtype.sink_subtype == CORESIGHT_DEV_SUBTYPE_SINK_PERCPU_SYSMEM);
|
|
|
|
}
|
|
|
|
|
2024-01-29 15:40:41 +00:00
|
|
|
/*
|
|
|
|
* Atomically try to take the device and set a new mode. Returns true on
|
|
|
|
* success, false if the device is already taken by someone else.
|
|
|
|
*/
|
|
|
|
static inline bool coresight_take_mode(struct coresight_device *csdev,
|
|
|
|
enum cs_mode new_mode)
|
|
|
|
{
|
|
|
|
return local_cmpxchg(&csdev->mode, CS_MODE_DISABLED, new_mode) ==
|
|
|
|
CS_MODE_DISABLED;
|
|
|
|
}
|
|
|
|
|
2024-01-29 15:40:42 +00:00
|
|
|
static inline enum cs_mode coresight_get_mode(struct coresight_device *csdev)
|
|
|
|
{
|
|
|
|
return local_read(&csdev->mode);
|
|
|
|
}
|
|
|
|
|
2024-01-29 15:40:43 +00:00
|
|
|
static inline void coresight_set_mode(struct coresight_device *csdev,
|
|
|
|
enum cs_mode new_mode)
|
|
|
|
{
|
|
|
|
enum cs_mode current_mode = coresight_get_mode(csdev);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Changing to a new mode must be done from an already disabled state
|
|
|
|
* unless it's synchronized with coresight_take_mode(). Otherwise the
|
|
|
|
* device is already in use and signifies a locking issue.
|
|
|
|
*/
|
|
|
|
WARN(new_mode != CS_MODE_DISABLED && current_mode != CS_MODE_DISABLED &&
|
|
|
|
current_mode != new_mode, "Device already in use\n");
|
|
|
|
|
|
|
|
local_set(&csdev->mode, new_mode);
|
|
|
|
}
|
|
|
|
|
2014-11-03 11:07:35 -07:00
|
|
|
extern struct coresight_device *
|
|
|
|
coresight_register(struct coresight_desc *desc);
|
|
|
|
extern void coresight_unregister(struct coresight_device *csdev);
|
2024-01-29 15:40:37 +00:00
|
|
|
extern int coresight_enable_sysfs(struct coresight_device *csdev);
|
|
|
|
extern void coresight_disable_sysfs(struct coresight_device *csdev);
|
2021-02-01 11:13:27 -07:00
|
|
|
extern int coresight_timeout(struct csdev_access *csa, u32 offset,
|
2014-11-03 11:07:35 -07:00
|
|
|
int position, int value);
|
2018-09-20 13:18:11 -06:00
|
|
|
|
2021-02-01 11:13:28 -07:00
|
|
|
extern int coresight_claim_device(struct coresight_device *csdev);
|
|
|
|
extern int coresight_claim_device_unlocked(struct coresight_device *csdev);
|
2018-09-20 13:18:11 -06:00
|
|
|
|
2021-02-01 11:13:28 -07:00
|
|
|
extern void coresight_disclaim_device(struct coresight_device *csdev);
|
|
|
|
extern void coresight_disclaim_device_unlocked(struct coresight_device *csdev);
|
2019-06-19 13:53:04 -06:00
|
|
|
extern char *coresight_alloc_device_name(struct coresight_dev_list *devs,
|
|
|
|
struct device *dev);
|
2019-11-04 11:12:38 -07:00
|
|
|
|
|
|
|
extern bool coresight_loses_context_with_cpu(struct device *dev);
|
2021-02-01 11:13:25 -07:00
|
|
|
|
|
|
|
u32 coresight_relaxed_read32(struct coresight_device *csdev, u32 offset);
|
|
|
|
u32 coresight_read32(struct coresight_device *csdev, u32 offset);
|
|
|
|
void coresight_write32(struct coresight_device *csdev, u32 val, u32 offset);
|
|
|
|
void coresight_relaxed_write32(struct coresight_device *csdev,
|
|
|
|
u32 val, u32 offset);
|
|
|
|
u64 coresight_relaxed_read64(struct coresight_device *csdev, u32 offset);
|
|
|
|
u64 coresight_read64(struct coresight_device *csdev, u32 offset);
|
|
|
|
void coresight_relaxed_write64(struct coresight_device *csdev,
|
|
|
|
u64 val, u32 offset);
|
|
|
|
void coresight_write64(struct coresight_device *csdev, u64 val, u32 offset);
|
|
|
|
|
2019-06-19 13:52:55 -06:00
|
|
|
extern int coresight_get_cpu(struct device *dev);
|
2014-11-03 11:07:35 -07:00
|
|
|
|
2019-06-19 13:52:54 -06:00
|
|
|
struct coresight_platform_data *coresight_get_platform_data(struct device *dev);
|
2023-04-25 15:35:33 +01:00
|
|
|
struct coresight_connection *
|
|
|
|
coresight_add_out_conn(struct device *dev,
|
|
|
|
struct coresight_platform_data *pdata,
|
|
|
|
const struct coresight_connection *new_conn);
|
2023-04-25 15:35:36 +01:00
|
|
|
int coresight_add_in_conn(struct coresight_connection *conn);
|
2023-04-25 15:35:39 +01:00
|
|
|
struct coresight_device *
|
|
|
|
coresight_find_input_type(struct coresight_platform_data *pdata,
|
|
|
|
enum coresight_dev_type type,
|
|
|
|
union coresight_dev_subtype subtype);
|
|
|
|
struct coresight_device *
|
|
|
|
coresight_find_output_type(struct coresight_platform_data *pdata,
|
|
|
|
enum coresight_dev_type type,
|
|
|
|
union coresight_dev_subtype subtype);
|
2019-06-19 13:52:54 -06:00
|
|
|
|
2024-03-14 11:28:36 +05:30
|
|
|
int coresight_init_driver(const char *drv, struct amba_driver *amba_drv,
|
|
|
|
struct platform_driver *pdev_drv);
|
|
|
|
|
|
|
|
void coresight_remove_driver(struct amba_driver *amba_drv,
|
|
|
|
struct platform_driver *pdev_drv);
|
2021-02-01 11:13:25 -07:00
|
|
|
#endif /* _LINUX_COREISGHT_H */
|