All of lore.kernel.org
 help / color / mirror / Atom feed
* perf record: why we used type casting of (uint64_t *) instead of int
@ 2012-05-24  9:21 Anshuman Khandual
  2012-05-25  5:27 ` Anshuman Khandual
  0 siblings, 1 reply; 7+ messages in thread
From: Anshuman Khandual @ 2012-05-24  9:21 UTC (permalink / raw)
  To: eranian, Arnaldo Carvalho de Melo; +Cc: linux-kernel

Hey Stephane,

Just wondering why we used the type casting of (uint64_t *) on a data 
which is defined as "int" in the structure of "perf_record_opts".

struct perf_record_opts {
        struct perf_target target;
        bool         call_graph;
        bool         group;
        bool         inherit_stat;
        bool         no_delay;
        bool         no_inherit;
        bool         no_samples;
        bool         pipe_output;
        bool         raw_samples;
        bool         sample_address;
        bool         sample_time;
        bool         sample_id_all_missing;
        bool         exclude_guest_missing;
        bool         period;
        unsigned int freq;
        unsigned int mmap_pages;
        unsigned int user_freq;
        int          branch_stack;
        u64          default_interval;
        u64          user_interval;
};

static int
parse_branch_stack(const struct option *opt, const char *str, int unset)
{
#define ONLY_PLM \
        (PERF_SAMPLE_BRANCH_USER        |\
         PERF_SAMPLE_BRANCH_KERNEL      |\
         PERF_SAMPLE_BRANCH_HV)

        uint64_t *mode = (uint64_t *)opt->value;
--
Regards
Anshuman Khandual


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: perf record: why we used type casting of (uint64_t *) instead of int
  2012-05-24  9:21 perf record: why we used type casting of (uint64_t *) instead of int Anshuman Khandual
@ 2012-05-25  5:27 ` Anshuman Khandual
  2012-05-25  8:03   ` [PATCH] perf record: Fixing record option data type in parse_branch_stack Anshuman Khandual
  2012-05-25  8:20   ` perf record: why we used type casting of (uint64_t *) instead of int Stephane Eranian
  0 siblings, 2 replies; 7+ messages in thread
From: Anshuman Khandual @ 2012-05-25  5:27 UTC (permalink / raw)
  To: eranian, Arnaldo Carvalho de Melo; +Cc: linux-kernel

This code is breaking in powerpc systems.

(1) 'opt->value' gets updated inside the function parse_branch_stack via
    dereferencing a (uint64_t *) type casted pointer.

(2) But the value is not accessible when we again use opt->value via 
    dereferencing a (int *) type casted pointer.

(3) As a result record.opts.branch_stack remains 0 and unchanged by parse_branch_stack

This is caused by bit representation of 'uint64_t' and 'int' in powerpc systems. Bytes update
for the data (when accessed trough (uint64_t *) casting) is no longer available to the
data when accessed through (int *) type casting. Verified this from bit representation of
the data (accessed through both type casting methods).

However this problem does not seem to be present on an Intel box. Integer dereferencing of
the opt->value still gives the value which was updated as (uint64_t).

All this problem would not have been there if we had used (int *) instead of (uint64_t *) in
the first place inside parse_branch_stack function.

On Thursday 24 May 2012 02:51 PM, Anshuman Khandual wrote:

> Hey Stephane,
> 
> Just wondering why we used the type casting of (uint64_t *) on a data 
> which is defined as "int" in the structure of "perf_record_opts".
> 
> struct perf_record_opts {
>         struct perf_target target;
>         bool         call_graph;
>         bool         group;
>         bool         inherit_stat;
>         bool         no_delay;
>         bool         no_inherit;
>         bool         no_samples;
>         bool         pipe_output;
>         bool         raw_samples;
>         bool         sample_address;
>         bool         sample_time;
>         bool         sample_id_all_missing;
>         bool         exclude_guest_missing;
>         bool         period;
>         unsigned int freq;
>         unsigned int mmap_pages;
>         unsigned int user_freq;
>         int          branch_stack;
>         u64          default_interval;
>         u64          user_interval;
> };
> 
> static int
> parse_branch_stack(const struct option *opt, const char *str, int unset)
> {
> #define ONLY_PLM \
>         (PERF_SAMPLE_BRANCH_USER        |\
>          PERF_SAMPLE_BRANCH_KERNEL      |\
>          PERF_SAMPLE_BRANCH_HV)
> 
>         uint64_t *mode = (uint64_t *)opt->value;
> --
> Regards
> Anshuman Khandual
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 



^ permalink raw reply	[flat|nested] 7+ messages in thread

* [PATCH] perf record: Fixing record option data type in parse_branch_stack
  2012-05-25  5:27 ` Anshuman Khandual
@ 2012-05-25  8:03   ` Anshuman Khandual
  2012-05-25  8:44     ` Stephane Eranian
  2012-05-25  8:20   ` perf record: why we used type casting of (uint64_t *) instead of int Stephane Eranian
  1 sibling, 1 reply; 7+ messages in thread
From: Anshuman Khandual @ 2012-05-25  8:03 UTC (permalink / raw)
  To: eranian, Arnaldo Carvalho de Melo; +Cc: linux-kernel

perf record: Fixing record option data type in parse_branch_stack

	Currently parse_branch_stack does not update record.opts.branch_stack
	value in powerpc architecture. opt->value is declared as int in struct
	perf_record_opts. But is worked on as uint64_t isnide the function.
	This breaks functionality in poweprc due to bit representation
	of uint64_t which is inaccessible as int.

Signed-off-by: Anshuman Khandual <khandual@linux.vnet.ibm.com>
---
 tools/perf/builtin-record.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c
index e5cb084..161c0f1 100644
--- a/tools/perf/builtin-record.c
+++ b/tools/perf/builtin-record.c
@@ -677,7 +677,7 @@ parse_branch_stack(const struct option *opt, const char *str, int unset)
 	 PERF_SAMPLE_BRANCH_KERNEL	|\
 	 PERF_SAMPLE_BRANCH_HV)
 
-	uint64_t *mode = (uint64_t *)opt->value;
+	int *mode = (int *)opt->value;
 	const struct branch_mode *br;
 	char *s, *os = NULL, *p;
 	int ret = -1;
-- 
1.7.9.5



On Friday 25 May 2012 10:57 AM, Anshuman Khandual wrote:

> This code is breaking in powerpc systems.
> 
> (1) 'opt->value' gets updated inside the function parse_branch_stack via
>     dereferencing a (uint64_t *) type casted pointer.
> 
> (2) But the value is not accessible when we again use opt->value via 
>     dereferencing a (int *) type casted pointer.
> 
> (3) As a result record.opts.branch_stack remains 0 and unchanged by parse_branch_stack
> 
> This is caused by bit representation of 'uint64_t' and 'int' in powerpc systems. Bytes update
> for the data (when accessed trough (uint64_t *) casting) is no longer available to the
> data when accessed through (int *) type casting. Verified this from bit representation of
> the data (accessed through both type casting methods).
> 
> However this problem does not seem to be present on an Intel box. Integer dereferencing of
> the opt->value still gives the value which was updated as (uint64_t).
> 
> All this problem would not have been there if we had used (int *) instead of (uint64_t *) in
> the first place inside parse_branch_stack function.
> 
> On Thursday 24 May 2012 02:51 PM, Anshuman Khandual wrote:
> 
>> Hey Stephane,
>>
>> Just wondering why we used the type casting of (uint64_t *) on a data 
>> which is defined as "int" in the structure of "perf_record_opts".
>>
>> struct perf_record_opts {
>>         struct perf_target target;
>>         bool         call_graph;
>>         bool         group;
>>         bool         inherit_stat;
>>         bool         no_delay;
>>         bool         no_inherit;
>>         bool         no_samples;
>>         bool         pipe_output;
>>         bool         raw_samples;
>>         bool         sample_address;
>>         bool         sample_time;
>>         bool         sample_id_all_missing;
>>         bool         exclude_guest_missing;
>>         bool         period;
>>         unsigned int freq;
>>         unsigned int mmap_pages;
>>         unsigned int user_freq;
>>         int          branch_stack;
>>         u64          default_interval;
>>         u64          user_interval;
>> };
>>
>> static int
>> parse_branch_stack(const struct option *opt, const char *str, int unset)
>> {
>> #define ONLY_PLM \
>>         (PERF_SAMPLE_BRANCH_USER        |\
>>          PERF_SAMPLE_BRANCH_KERNEL      |\
>>          PERF_SAMPLE_BRANCH_HV)
>>
>>         uint64_t *mode = (uint64_t *)opt->value;
>> --
>> Regards
>> Anshuman Khandual
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>> Please read the FAQ at  http://www.tux.org/lkml/
>>
> 
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 



^ permalink raw reply related	[flat|nested] 7+ messages in thread

* Re: perf record: why we used type casting of (uint64_t *) instead of int
  2012-05-25  5:27 ` Anshuman Khandual
  2012-05-25  8:03   ` [PATCH] perf record: Fixing record option data type in parse_branch_stack Anshuman Khandual
@ 2012-05-25  8:20   ` Stephane Eranian
  1 sibling, 0 replies; 7+ messages in thread
From: Stephane Eranian @ 2012-05-25  8:20 UTC (permalink / raw)
  To: Anshuman Khandual; +Cc: Arnaldo Carvalho de Melo, linux-kernel

On Fri, May 25, 2012 at 7:27 AM, Anshuman Khandual
<khandual@linux.vnet.ibm.com> wrote:
> This code is breaking in powerpc systems.
>
> (1) 'opt->value' gets updated inside the function parse_branch_stack via
>    dereferencing a (uint64_t *) type casted pointer.
>
> (2) But the value is not accessible when we again use opt->value via
>    dereferencing a (int *) type casted pointer.
>
> (3) As a result record.opts.branch_stack remains 0 and unchanged by parse_branch_stack
>
> This is caused by bit representation of 'uint64_t' and 'int' in powerpc systems. Bytes update
> for the data (when accessed trough (uint64_t *) casting) is no longer available to the
> data when accessed through (int *) type casting. Verified this from bit representation of
> the data (accessed through both type casting methods).
>
> However this problem does not seem to be present on an Intel box. Integer dereferencing of
> the opt->value still gives the value which was updated as (uint64_t).
>
> All this problem would not have been there if we had used (int *) instead of (uint64_t *) in
> the first place inside parse_branch_stack function.
>
The bug is that in struct record_opts, branch_stack is declared int
instead of u64.
I can post a patch to fix that. The value is eventually passed to struct
perf_event_attr.branch_sample_type  which is defined as u64.

I can post a patch to fix that.

Thanks for catching this.

> On Thursday 24 May 2012 02:51 PM, Anshuman Khandual wrote:
>
>> Hey Stephane,
>>
>> Just wondering why we used the type casting of (uint64_t *) on a data
>> which is defined as "int" in the structure of "perf_record_opts".
>>
>> struct perf_record_opts {
>>         struct perf_target target;
>>         bool         call_graph;
>>         bool         group;
>>         bool         inherit_stat;
>>         bool         no_delay;
>>         bool         no_inherit;
>>         bool         no_samples;
>>         bool         pipe_output;
>>         bool         raw_samples;
>>         bool         sample_address;
>>         bool         sample_time;
>>         bool         sample_id_all_missing;
>>         bool         exclude_guest_missing;
>>         bool         period;
>>         unsigned int freq;
>>         unsigned int mmap_pages;
>>         unsigned int user_freq;
>>         int          branch_stack;
>>         u64          default_interval;
>>         u64          user_interval;
>> };
>>
>> static int
>> parse_branch_stack(const struct option *opt, const char *str, int unset)
>> {
>> #define ONLY_PLM \
>>         (PERF_SAMPLE_BRANCH_USER        |\
>>          PERF_SAMPLE_BRANCH_KERNEL      |\
>>          PERF_SAMPLE_BRANCH_HV)
>>
>>         uint64_t *mode = (uint64_t *)opt->value;
>> --
>> Regards
>> Anshuman Khandual
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>> Please read the FAQ at  http://www.tux.org/lkml/
>>
>
>

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH] perf record: Fixing record option data type in parse_branch_stack
  2012-05-25  8:03   ` [PATCH] perf record: Fixing record option data type in parse_branch_stack Anshuman Khandual
@ 2012-05-25  8:44     ` Stephane Eranian
  2012-05-25 10:32       ` Anshuman Khandual
  0 siblings, 1 reply; 7+ messages in thread
From: Stephane Eranian @ 2012-05-25  8:44 UTC (permalink / raw)
  To: Anshuman Khandual; +Cc: Arnaldo Carvalho de Melo, linux-kernel

Hi,

It should be something like that instead:

diff --git a/tools/perf/perf.h b/tools/perf/perf.h
index 8a9687e..c9ca7c4 100644
--- a/tools/perf/perf.h
+++ b/tools/perf/perf.h
@@ -228,7 +228,7 @@ struct perf_record_opts {
        unsigned int freq;
        unsigned int mmap_pages;
        unsigned int user_freq;
-       int          branch_stack;
+       u64          branch_stack;
        u64          default_interval;
        u64          user_interval;
 };


On Fri, May 25, 2012 at 10:03 AM, Anshuman Khandual
<khandual@linux.vnet.ibm.com> wrote:
> perf record: Fixing record option data type in parse_branch_stack
>
>        Currently parse_branch_stack does not update record.opts.branch_stack
>        value in powerpc architecture. opt->value is declared as int in struct
>        perf_record_opts. But is worked on as uint64_t isnide the function.
>        This breaks functionality in poweprc due to bit representation
>        of uint64_t which is inaccessible as int.
>
> Signed-off-by: Anshuman Khandual <khandual@linux.vnet.ibm.com>
> ---
>  tools/perf/builtin-record.c |    2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c
> index e5cb084..161c0f1 100644
> --- a/tools/perf/builtin-record.c
> +++ b/tools/perf/builtin-record.c
> @@ -677,7 +677,7 @@ parse_branch_stack(const struct option *opt, const char *str, int unset)
>         PERF_SAMPLE_BRANCH_KERNEL      |\
>         PERF_SAMPLE_BRANCH_HV)
>
> -       uint64_t *mode = (uint64_t *)opt->value;
> +       int *mode = (int *)opt->value;
>        const struct branch_mode *br;
>        char *s, *os = NULL, *p;
>        int ret = -1;
> --
> 1.7.9.5
>
>
>
> On Friday 25 May 2012 10:57 AM, Anshuman Khandual wrote:
>
>> This code is breaking in powerpc systems.
>>
>> (1) 'opt->value' gets updated inside the function parse_branch_stack via
>>     dereferencing a (uint64_t *) type casted pointer.
>>
>> (2) But the value is not accessible when we again use opt->value via
>>     dereferencing a (int *) type casted pointer.
>>
>> (3) As a result record.opts.branch_stack remains 0 and unchanged by parse_branch_stack
>>
>> This is caused by bit representation of 'uint64_t' and 'int' in powerpc systems. Bytes update
>> for the data (when accessed trough (uint64_t *) casting) is no longer available to the
>> data when accessed through (int *) type casting. Verified this from bit representation of
>> the data (accessed through both type casting methods).
>>
>> However this problem does not seem to be present on an Intel box. Integer dereferencing of
>> the opt->value still gives the value which was updated as (uint64_t).
>>
>> All this problem would not have been there if we had used (int *) instead of (uint64_t *) in
>> the first place inside parse_branch_stack function.
>>
>> On Thursday 24 May 2012 02:51 PM, Anshuman Khandual wrote:
>>
>>> Hey Stephane,
>>>
>>> Just wondering why we used the type casting of (uint64_t *) on a data
>>> which is defined as "int" in the structure of "perf_record_opts".
>>>
>>> struct perf_record_opts {
>>>         struct perf_target target;
>>>         bool         call_graph;
>>>         bool         group;
>>>         bool         inherit_stat;
>>>         bool         no_delay;
>>>         bool         no_inherit;
>>>         bool         no_samples;
>>>         bool         pipe_output;
>>>         bool         raw_samples;
>>>         bool         sample_address;
>>>         bool         sample_time;
>>>         bool         sample_id_all_missing;
>>>         bool         exclude_guest_missing;
>>>         bool         period;
>>>         unsigned int freq;
>>>         unsigned int mmap_pages;
>>>         unsigned int user_freq;
>>>         int          branch_stack;
>>>         u64          default_interval;
>>>         u64          user_interval;
>>> };
>>>
>>> static int
>>> parse_branch_stack(const struct option *opt, const char *str, int unset)
>>> {
>>> #define ONLY_PLM \
>>>         (PERF_SAMPLE_BRANCH_USER        |\
>>>          PERF_SAMPLE_BRANCH_KERNEL      |\
>>>          PERF_SAMPLE_BRANCH_HV)
>>>
>>>         uint64_t *mode = (uint64_t *)opt->value;
>>> --
>>> Regards
>>> Anshuman Khandual
>>>
>>> --
>>> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
>>> the body of a message to majordomo@vger.kernel.org
>>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>> Please read the FAQ at  http://www.tux.org/lkml/
>>>
>>
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>> Please read the FAQ at  http://www.tux.org/lkml/
>>
>
>

^ permalink raw reply related	[flat|nested] 7+ messages in thread

* Re: [PATCH] perf record: Fixing record option data type in parse_branch_stack
  2012-05-25  8:44     ` Stephane Eranian
@ 2012-05-25 10:32       ` Anshuman Khandual
  2012-05-25 14:47         ` Arnaldo Carvalho de Melo
  0 siblings, 1 reply; 7+ messages in thread
From: Anshuman Khandual @ 2012-05-25 10:32 UTC (permalink / raw)
  To: Stephane Eranian; +Cc: Arnaldo Carvalho de Melo, linux-kernel

On Friday 25 May 2012 02:14 PM, Stephane Eranian wrote:

> Hi,
> 
> It should be something like that instead:
> 
> diff --git a/tools/perf/perf.h b/tools/perf/perf.h
> index 8a9687e..c9ca7c4 100644
> --- a/tools/perf/perf.h
> +++ b/tools/perf/perf.h
> @@ -228,7 +228,7 @@ struct perf_record_opts {
>         unsigned int freq;
>         unsigned int mmap_pages;
>         unsigned int user_freq;
> -       int          branch_stack;
> +       u64          branch_stack;
>         u64          default_interval;
>         u64          user_interval;
>  };
> 



Agreed. I just tried to fix the problem where it was more evident because
of the data type mismatch.


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH] perf record: Fixing record option data type in parse_branch_stack
  2012-05-25 10:32       ` Anshuman Khandual
@ 2012-05-25 14:47         ` Arnaldo Carvalho de Melo
  0 siblings, 0 replies; 7+ messages in thread
From: Arnaldo Carvalho de Melo @ 2012-05-25 14:47 UTC (permalink / raw)
  To: Anshuman Khandual; +Cc: Stephane Eranian, linux-kernel

Em Fri, May 25, 2012 at 04:02:15PM +0530, Anshuman Khandual escreveu:
> On Friday 25 May 2012 02:14 PM, Stephane Eranian wrote:
> 
> > Hi,
> > 
> > It should be something like that instead:
> > 
> > diff --git a/tools/perf/perf.h b/tools/perf/perf.h
> > index 8a9687e..c9ca7c4 100644
> > --- a/tools/perf/perf.h
> > +++ b/tools/perf/perf.h
> > @@ -228,7 +228,7 @@ struct perf_record_opts {
> >         unsigned int freq;
> >         unsigned int mmap_pages;
> >         unsigned int user_freq;
> > -       int          branch_stack;
> > +       u64          branch_stack;
> >         u64          default_interval;
> >         u64          user_interval;
> >  };
> > 
> 
> 
> 
> Agreed. I just tried to fix the problem where it was more evident because
> of the data type mismatch.

Can you send an updated patch on a message just for that?

- Arnaldo

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2012-05-25 14:47 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2012-05-24  9:21 perf record: why we used type casting of (uint64_t *) instead of int Anshuman Khandual
2012-05-25  5:27 ` Anshuman Khandual
2012-05-25  8:03   ` [PATCH] perf record: Fixing record option data type in parse_branch_stack Anshuman Khandual
2012-05-25  8:44     ` Stephane Eranian
2012-05-25 10:32       ` Anshuman Khandual
2012-05-25 14:47         ` Arnaldo Carvalho de Melo
2012-05-25  8:20   ` perf record: why we used type casting of (uint64_t *) instead of int Stephane Eranian

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.