[lttng-dev] Printing bit fields with LTTng

Simon Marchi simon.marchi at polymtl.ca
Wed Jun 10 17:28:42 EDT 2015


On 10 June 2015 at 17:16, Chidhu R <chid1989 at gmail.com> wrote:
> Hello,
>
> I am getting compilation issues while trying to print bit field values with
> LTTng.
>
> Error:
>
> hello.c: In function ‘main’:
> hello.c:36:1: error: ‘typeof’ applied to a bit-field
> hello.c:36:1: error: ‘typeof’ applied to a bit-field
> hello.c:36:1: error: ‘typeof’ applied to a bit-field
> hello.c:36:1: error: ‘sizeof’ applied to a bit-field
>
> Snippet:
>
> struct abc{
>         int a:16;
>         int b:8;
> };
>
> Line 36: tracepoint(hello_world, my_third_tracepoint, aa.a, "welcome");
> Line 37: printf("val = %x\n",aa.a);
>
> tracepoint line results in compilation error.
> printf succeeds.
>
> Tp definition looks like this.
>
> TRACEPOINT_EVENT(
>     hello_world,
>     my_third_tracepoint,
>     TP_ARGS(
>         uint32_t, arg,
>         const char * , my_string_arg
>     ),
>     TP_FIELDS(
>         ctf_integer_hex(uint32_t, my_arg, arg)
>         ctf_string(field, my_string_arg)
>     )
> )
>
> How to print bit field values?
>
> Thanks
> Chid

I have no idea what the right fix would be, but an easy workaround
could be to add 0 to your value:

    tracepoint(hello_world, my_third_tracepoint, aa.a + 0, "welcome");

I just tried it and it works.

Simon



More information about the lttng-dev mailing list