* [PATCH v2] powerpc/powernv: Expose OPAL firmware symbol map
@ 2014-12-05 4:26 Benjamin Herrenschmidt
2014-12-05 9:40 ` [v2] " Michael Ellerman
0 siblings, 1 reply; 2+ messages in thread
From: Benjamin Herrenschmidt @ 2014-12-05 4:26 UTC (permalink / raw)
To: linuxppc-dev@ozlabs.org list; +Cc: Michael Ellerman, Anton Blanchard
Newer versions of OPAL will provide this, so let's expose it to user
space so tools like perf can use it to properly decode samples in
firmware space.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
---
v2. Use memory_read_from_buffer()
diff --git a/arch/powerpc/platforms/powernv/opal.c b/arch/powerpc/platforms/powernv/opal.c
index 06d9076..98f50e8 100644
--- a/arch/powerpc/platforms/powernv/opal.c
+++ b/arch/powerpc/platforms/powernv/opal.c
@@ -61,6 +61,8 @@ static DEFINE_SPINLOCK(opal_notifier_lock);
static uint64_t last_notified_mask = 0x0ul;
static atomic_t opal_notifier_hold = ATOMIC_INIT(0);
static uint32_t opal_heartbeat;
+static void *opal_symmap;
+static uint64_t opal_symmap_size;
static void opal_reinit_cores(void)
{
@@ -608,6 +610,40 @@ static int opal_sysfs_init(void)
return 0;
}
+static ssize_t symbol_map_read(struct file *fp, struct kobject *kobj,
+ struct bin_attribute *bin_attr,
+ char *buf, loff_t off, size_t count)
+{
+ return memory_read_from_buffer(buf, count, &off,
+ opal_symmap, opal_symmap_size);
+}
+
+static BIN_ATTR_RO(symbol_map, 0);
+
+static void opal_export_symmap(void)
+{
+ const __be64 *syms;
+ unsigned int size;
+ struct device_node *fw;
+ int rc;
+
+ fw = of_find_node_by_path("/ibm,opal/firmware");
+ if (!fw)
+ return;
+ syms = of_get_property(fw, "symbol-map", &size);
+ if (!syms || size != 2 * sizeof(__be64))
+ return;
+
+ opal_symmap = __va(be64_to_cpu(syms[0]));
+ opal_symmap_size = be64_to_cpu(syms[1]);
+
+ /* Setup attributes */
+ bin_attr_symbol_map.size = opal_symmap_size;
+ rc = sysfs_create_bin_file(opal_kobj, &bin_attr_symbol_map);
+ if (rc)
+ pr_warn("Error %d creating OPAL symbols file\n", rc);
+}
+
static void __init opal_dump_region_init(void)
{
void *addr;
@@ -738,6 +774,8 @@ static int __init opal_init(void)
/* Create "opal" kobject under /sys/firmware */
rc = opal_sysfs_init();
if (rc == 0) {
+ /* Export symbol map to userspace */
+ opal_export_symmap();
/* Setup dump region interface */
opal_dump_region_init();
/* Setup error log interface */
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [v2] powerpc/powernv: Expose OPAL firmware symbol map
2014-12-05 4:26 [PATCH v2] powerpc/powernv: Expose OPAL firmware symbol map Benjamin Herrenschmidt
@ 2014-12-05 9:40 ` Michael Ellerman
0 siblings, 0 replies; 2+ messages in thread
From: Michael Ellerman @ 2014-12-05 9:40 UTC (permalink / raw)
To: Benjamin Herrenschmidt, linuxppc-dev@ozlabs.org list; +Cc: Anton Blanchard
On Fri, 2014-05-12 at 04:26:17 UTC, Benjamin Herrenschmidt wrote:
> Newer versions of OPAL will provide this, so let's expose it to user
> space so tools like perf can use it to properly decode samples in
> firmware space.
>
> diff --git a/arch/powerpc/platforms/powernv/opal.c b/arch/powerpc/platforms/powernv/opal.c
> index 06d9076..98f50e8 100644
> --- a/arch/powerpc/platforms/powernv/opal.c
> +++ b/arch/powerpc/platforms/powernv/opal.c
> @@ -61,6 +61,8 @@ static DEFINE_SPINLOCK(opal_notifier_lock);
> static uint64_t last_notified_mask = 0x0ul;
> static atomic_t opal_notifier_hold = ATOMIC_INIT(0);
> static uint32_t opal_heartbeat;
> +static void *opal_symmap;
> +static uint64_t opal_symmap_size;
We shouldn't need these.
The bin_attribute has a size (you set it), you just need to use it in
symbol_map_read().
And the attribute also has a private pointer, which you can use for
opal_symmap.
> @@ -608,6 +610,40 @@ static int opal_sysfs_init(void)
> return 0;
> }
>
> +static ssize_t symbol_map_read(struct file *fp, struct kobject *kobj,
> + struct bin_attribute *bin_attr,
> + char *buf, loff_t off, size_t count)
> +{
> + return memory_read_from_buffer(buf, count, &off,
> + opal_symmap, opal_symmap_size);
So this would be:
return memory_read_from_buffer(buf, count, &off,
bin_attr->private, bin_attr->size);
> +}
> +
> +static BIN_ATTR_RO(symbol_map, 0);
> +
> +static void opal_export_symmap(void)
> +{
> + const __be64 *syms;
> + unsigned int size;
> + struct device_node *fw;
> + int rc;
> +
> + fw = of_find_node_by_path("/ibm,opal/firmware");
> + if (!fw)
> + return;
> + syms = of_get_property(fw, "symbol-map", &size);
> + if (!syms || size != 2 * sizeof(__be64))
> + return;
> +
> + opal_symmap = __va(be64_to_cpu(syms[0]));
> + opal_symmap_size = be64_to_cpu(syms[1]);
I was going to tell you to use of_property_read_u64_index(), but it doesn't
exist - we can add it one day and clean this up then.
> + /* Setup attributes */
> + bin_attr_symbol_map.size = opal_symmap_size;
> + rc = sysfs_create_bin_file(opal_kobj, &bin_attr_symbol_map);
> + if (rc)
> + pr_warn("Error %d creating OPAL symbols file\n", rc);
Can you prefix it please, so:
pr_warn("opal: Error .."
Or add to the very top of the file:
#define pr_fmt(fmt) "opal: " fmt
cheers
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2014-12-05 9:40 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-12-05 4:26 [PATCH v2] powerpc/powernv: Expose OPAL firmware symbol map Benjamin Herrenschmidt
2014-12-05 9:40 ` [v2] " Michael Ellerman
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).