aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/hwtracing/coresight/coresight-priv.h8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/hwtracing/coresight/coresight-priv.h b/drivers/hwtracing/coresight/coresight-priv.h
index ad975c58080d..decfd52b5dc3 100644
--- a/drivers/hwtracing/coresight/coresight-priv.h
+++ b/drivers/hwtracing/coresight/coresight-priv.h
@@ -16,6 +16,7 @@
16#include <linux/bitops.h> 16#include <linux/bitops.h>
17#include <linux/io.h> 17#include <linux/io.h>
18#include <linux/coresight.h> 18#include <linux/coresight.h>
19#include <linux/pm_runtime.h>
19 20
20/* 21/*
21 * Coresight management registers (0xf00-0xfcc) 22 * Coresight management registers (0xf00-0xfcc)
@@ -42,8 +43,11 @@ static ssize_t name##_show(struct device *_dev, \
42 struct device_attribute *attr, char *buf) \ 43 struct device_attribute *attr, char *buf) \
43{ \ 44{ \
44 type *drvdata = dev_get_drvdata(_dev->parent); \ 45 type *drvdata = dev_get_drvdata(_dev->parent); \
45 return scnprintf(buf, PAGE_SIZE, "0x%x\n", \ 46 u32 val; \
46 readl_relaxed(drvdata->base + offset)); \ 47 pm_runtime_get_sync(_dev->parent); \
48 val = readl_relaxed(drvdata->base + offset); \
49 pm_runtime_put_sync(_dev->parent); \
50 return scnprintf(buf, PAGE_SIZE, "0x%x\n", val); \
47} \ 51} \
48static DEVICE_ATTR_RO(name) 52static DEVICE_ATTR_RO(name)
49 53