Thread (23 messages) 23 messages, 3 authors, 2016-07-28

[PATCH V2 3/6] perf tools: add infrastructure for PMU specific configuration

From: Jiri Olsa <hidden>
Date: 2016-07-28 16:52:52
Also in: lkml

On Thu, Jul 28, 2016 at 10:15:52AM -0600, Mathieu Poirier wrote:
On 27 July 2016 at 13:26, Jiri Olsa [off-list ref] wrote:
quoted
On Wed, Jul 27, 2016 at 11:59:50AM -0600, Mathieu Poirier wrote:

SNIP
quoted
quoted
-PE_DRV_CFG_TERM
+'@' PE_NAME '=' PE_NAME
 {
        struct parse_events_term *term;

        ABORT_ON(parse_events_term__str(&term, PARSE_EVENTS__TERM_TYPE_DRV_CFG,
-                                       $1, $1, &@1, NULL));
+                                       $2, $4, &@2, &@4));
        $$ = term;
 }
The problem here is that the correlation between the first and the
second PE_NAME is lost and instead of seeing "PE_NAME=PE_NAME", the
kernel only gets the value associated with the second PE_NAME.

For example,

-e event/@cfg1=value1, at cfg2=value2/ ...

The above code will send "value1" and "value2" to the kernel driver
where there is no way to know what configurable the values correspond
hum.. you get the 'cfg1' and 'cfg2' strings in $1 no?
Indeed you do.

Macro ADD_CONFIG_TERM in function get_config_terms() only account for
the __val parameter and struct parse_events_term::config is completely
ignored.  We could concatenate the fields before calling
ADD_CONFIG_TERM() but between that and freeing the reserved memory, I
think it is cleaner to let flex do the work.
ah you need that whole string in one piece.. ok
let's do it by your original way then

please add some comments for in drv_str function describing
the usage of @ and the fact we're doing this because we need
whole assignment as single string

thanks,
jirka
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help