Commit 7d83d177 authored by Mathieu Poirier's avatar Mathieu Poirier Committed by Greg Kroah-Hartman

coresight: tmc: adding sysFS management entries

Adding management registers that convey implementation
specific characteristics.  Those are useful for trace
configuration and collection along with general trouble
shooting.
Signed-off-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 960e3095
...@@ -6,3 +6,80 @@ Description: (RW) Disables write access to the Trace RAM by stopping the ...@@ -6,3 +6,80 @@ Description: (RW) Disables write access to the Trace RAM by stopping the
formatter after a defined number of words have been stored formatter after a defined number of words have been stored
following the trigger event. Additional interface for this following the trigger event. Additional interface for this
driver are expected to be added as it matures. driver are expected to be added as it matures.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/rsz
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Defines the size, in 32-bit words, of the local RAM buffer.
The value is read directly from HW register RSZ, 0x004.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/sts
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Shows the value held by the TMC status register. The value
is read directly from HW register STS, 0x00C.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/rrp
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Shows the value held by the TMC RAM Read Pointer register
that is used to read entries from the Trace RAM over the APB
interface. The value is read directly from HW register RRP,
0x014.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/rwp
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Shows the value held by the TMC RAM Write Pointer register
that is used to sets the write pointer to write entries from
the CoreSight bus into the Trace RAM. The value is read directly
from HW register RWP, 0x018.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/trg
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Similar to "trigger_cntr" above except that this value is
read directly from HW register TRG, 0x01C.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/ctl
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Shows the value held by the TMC Control register. The value
is read directly from HW register CTL, 0x020.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/ffsr
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Shows the value held by the TMC Formatter and Flush Status
register. The value is read directly from HW register FFSR,
0x300.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/ffcr
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Shows the value held by the TMC Formatter and Flush Control
register. The value is read directly from HW register FFCR,
0x304.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/mode
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Shows the value held by the TMC Mode register, which
indicate the mode the device has been configured to enact. The
The value is read directly from the MODE register, 0x028.
What: /sys/bus/coresight/devices/<memory_map>.tmc/mgmt/devid
Date: March 2016
KernelVersion: 4.7
Contact: Mathieu Poirier <mathieu.poirier@linaro.org>
Description: (R) Indicates the capabilities of the Coresight TMC.
The value is read directly from the DEVID register, 0xFC8,
...@@ -556,55 +556,37 @@ static const struct file_operations tmc_fops = { ...@@ -556,55 +556,37 @@ static const struct file_operations tmc_fops = {
.llseek = no_llseek, .llseek = no_llseek,
}; };
static ssize_t status_show(struct device *dev, #define coresight_tmc_simple_func(name, offset) \
struct device_attribute *attr, char *buf) coresight_simple_func(struct tmc_drvdata, name, offset)
{
unsigned long flags; coresight_tmc_simple_func(rsz, TMC_RSZ);
u32 tmc_rsz, tmc_sts, tmc_rrp, tmc_rwp, tmc_trg; coresight_tmc_simple_func(sts, TMC_STS);
u32 tmc_ctl, tmc_ffsr, tmc_ffcr, tmc_mode, tmc_pscr; coresight_tmc_simple_func(rrp, TMC_RRP);
u32 devid; coresight_tmc_simple_func(rwp, TMC_RWP);
struct tmc_drvdata *drvdata = dev_get_drvdata(dev->parent); coresight_tmc_simple_func(trg, TMC_TRG);
coresight_tmc_simple_func(ctl, TMC_CTL);
pm_runtime_get_sync(drvdata->dev); coresight_tmc_simple_func(ffsr, TMC_FFSR);
spin_lock_irqsave(&drvdata->spinlock, flags); coresight_tmc_simple_func(ffcr, TMC_FFCR);
CS_UNLOCK(drvdata->base); coresight_tmc_simple_func(mode, TMC_MODE);
coresight_tmc_simple_func(pscr, TMC_PSCR);
tmc_rsz = readl_relaxed(drvdata->base + TMC_RSZ); coresight_tmc_simple_func(devid, CORESIGHT_DEVID);
tmc_sts = readl_relaxed(drvdata->base + TMC_STS);
tmc_rrp = readl_relaxed(drvdata->base + TMC_RRP); static struct attribute *coresight_tmc_mgmt_attrs[] = {
tmc_rwp = readl_relaxed(drvdata->base + TMC_RWP); &dev_attr_rsz.attr,
tmc_trg = readl_relaxed(drvdata->base + TMC_TRG); &dev_attr_sts.attr,
tmc_ctl = readl_relaxed(drvdata->base + TMC_CTL); &dev_attr_rrp.attr,
tmc_ffsr = readl_relaxed(drvdata->base + TMC_FFSR); &dev_attr_rwp.attr,
tmc_ffcr = readl_relaxed(drvdata->base + TMC_FFCR); &dev_attr_trg.attr,
tmc_mode = readl_relaxed(drvdata->base + TMC_MODE); &dev_attr_ctl.attr,
tmc_pscr = readl_relaxed(drvdata->base + TMC_PSCR); &dev_attr_ffsr.attr,
devid = readl_relaxed(drvdata->base + CORESIGHT_DEVID); &dev_attr_ffcr.attr,
&dev_attr_mode.attr,
CS_LOCK(drvdata->base); &dev_attr_pscr.attr,
spin_unlock_irqrestore(&drvdata->spinlock, flags); &dev_attr_devid.attr,
pm_runtime_put(drvdata->dev); NULL,
};
return sprintf(buf,
"Depth:\t\t0x%x\n"
"Status:\t\t0x%x\n"
"RAM read ptr:\t0x%x\n"
"RAM wrt ptr:\t0x%x\n"
"Trigger cnt:\t0x%x\n"
"Control:\t0x%x\n"
"Flush status:\t0x%x\n"
"Flush ctrl:\t0x%x\n"
"Mode:\t\t0x%x\n"
"PSRC:\t\t0x%x\n"
"DEVID:\t\t0x%x\n",
tmc_rsz, tmc_sts, tmc_rrp, tmc_rwp, tmc_trg,
tmc_ctl, tmc_ffsr, tmc_ffcr, tmc_mode, tmc_pscr, devid);
return -EINVAL;
}
static DEVICE_ATTR_RO(status);
static ssize_t trigger_cntr_show(struct device *dev, ssize_t trigger_cntr_show(struct device *dev,
struct device_attribute *attr, char *buf) struct device_attribute *attr, char *buf)
{ {
struct tmc_drvdata *drvdata = dev_get_drvdata(dev->parent); struct tmc_drvdata *drvdata = dev_get_drvdata(dev->parent);
...@@ -630,26 +612,25 @@ static ssize_t trigger_cntr_store(struct device *dev, ...@@ -630,26 +612,25 @@ static ssize_t trigger_cntr_store(struct device *dev,
} }
static DEVICE_ATTR_RW(trigger_cntr); static DEVICE_ATTR_RW(trigger_cntr);
static struct attribute *coresight_etb_attrs[] = { static struct attribute *coresight_tmc_attrs[] = {
&dev_attr_trigger_cntr.attr, &dev_attr_trigger_cntr.attr,
&dev_attr_status.attr,
NULL, NULL,
}; };
ATTRIBUTE_GROUPS(coresight_etb);
static struct attribute *coresight_etr_attrs[] = { static const struct attribute_group coresight_tmc_group = {
&dev_attr_trigger_cntr.attr, .attrs = coresight_tmc_attrs,
&dev_attr_status.attr,
NULL,
}; };
ATTRIBUTE_GROUPS(coresight_etr);
static struct attribute *coresight_etf_attrs[] = { static const struct attribute_group coresight_tmc_mgmt_group = {
&dev_attr_trigger_cntr.attr, .attrs = coresight_tmc_mgmt_attrs,
&dev_attr_status.attr, .name = "mgmt",
};
const struct attribute_group *coresight_tmc_groups[] = {
&coresight_tmc_group,
&coresight_tmc_mgmt_group,
NULL, NULL,
}; };
ATTRIBUTE_GROUPS(coresight_etf);
static int tmc_probe(struct amba_device *adev, const struct amba_id *id) static int tmc_probe(struct amba_device *adev, const struct amba_id *id)
{ {
...@@ -725,20 +706,18 @@ static int tmc_probe(struct amba_device *adev, const struct amba_id *id) ...@@ -725,20 +706,18 @@ static int tmc_probe(struct amba_device *adev, const struct amba_id *id)
desc->pdata = pdata; desc->pdata = pdata;
desc->dev = dev; desc->dev = dev;
desc->subtype.sink_subtype = CORESIGHT_DEV_SUBTYPE_SINK_BUFFER; desc->subtype.sink_subtype = CORESIGHT_DEV_SUBTYPE_SINK_BUFFER;
desc->groups = coresight_tmc_groups;
if (drvdata->config_type == TMC_CONFIG_TYPE_ETB) { if (drvdata->config_type == TMC_CONFIG_TYPE_ETB) {
desc->type = CORESIGHT_DEV_TYPE_SINK; desc->type = CORESIGHT_DEV_TYPE_SINK;
desc->ops = &tmc_etb_cs_ops; desc->ops = &tmc_etb_cs_ops;
desc->groups = coresight_etb_groups;
} else if (drvdata->config_type == TMC_CONFIG_TYPE_ETR) { } else if (drvdata->config_type == TMC_CONFIG_TYPE_ETR) {
desc->type = CORESIGHT_DEV_TYPE_SINK; desc->type = CORESIGHT_DEV_TYPE_SINK;
desc->ops = &tmc_etr_cs_ops; desc->ops = &tmc_etr_cs_ops;
desc->groups = coresight_etr_groups;
} else { } else {
desc->type = CORESIGHT_DEV_TYPE_LINKSINK; desc->type = CORESIGHT_DEV_TYPE_LINKSINK;
desc->subtype.link_subtype = CORESIGHT_DEV_SUBTYPE_LINK_FIFO; desc->subtype.link_subtype = CORESIGHT_DEV_SUBTYPE_LINK_FIFO;
desc->ops = &tmc_etf_cs_ops; desc->ops = &tmc_etf_cs_ops;
desc->groups = coresight_etf_groups;
} }
drvdata->csdev = coresight_register(desc); drvdata->csdev = coresight_register(desc);
......
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