Re: [PATCH] perf tools: Fix not finding kcore in buildid cache

From: Adrian Hunter
Date: Wed Nov 27 2013 - 06:44:11 EST


On 27/11/13 13:32, Ingo Molnar wrote:
>
> * Adrian Hunter <adrian.hunter@xxxxxxxxx> wrote:
>
>> On 26/11/13 18:15, Ingo Molnar wrote:
>>>
>>> * Adrian Hunter <adrian.hunter@xxxxxxxxx> wrote:
>>>
>>>> The logic was not looking in the buildid cache for kcore
>>>> if the host kernel buildid did not match the recorded
>>>> kernel buildid.
>>>
>>> It would be nice to also include the specific failure mode in the
>>> changelog: exactly how can users run into this. That will be more
>>> useful to most people reading these changelogs than a more abstract
>>> bug description.
>>
>> The preconditions for the problem are that kcore is in the buildid
>> cache and that the running kernel has a different buildid e.g.
>>
>> $ perf buildid-list | grep kernel.kallsyms
>> b18fbe769dea12513028a4287dae02efc1582c29 [kernel.kallsyms]
>>
>> $ perf record -o /tmp/junk true >/dev/null 2>&1 ; perf buildid-list -i /tmp/junk | grep kernel.kallsyms
>> 504f9fd9328c40714995ce76fe1354c6e90136ce [kernel.kallsyms]
>>
>>
>>
>> Before the patch:
>>
>>
>> $ perf script -v >out.txt
>> build id event received for [kernel.kallsyms]: b18fbe769dea12513028a4287dae02efc1582c29
>> <SNIP>
>> Using /home/ahunter/.debug/[kernel.kallsyms]/b18fbe769dea12513028a4287dae02efc1582c29 for symbols
>>
>> perf script stopped
>>
>>
>> After the patch:
>>
>>
>> $ perf script -v >out.txt
>> build id event received for [kernel.kallsyms]: b18fbe769dea12513028a4287dae02efc1582c29
>> <SNIP>
>> Using /home/ahunter/.debug/[kernel.kcore]/b18fbe769dea12513028a4287dae02efc1582c29/2013112617084061/kcore for kernel object code
>> Using /home/ahunter/.debug/[kernel.kcore]/b18fbe769dea12513028a4287dae02efc1582c29/2013112617084061/kallsyms for symbols
>>
>> perf script stopped
>
> So the result of the patch is that kernel symbols get
> resolved/annotated correctly, as expected from the live kcore feature,
> right?

Yes but this is the non-live case i.e. the kernel has changed and we are
looking at a special copy of kcore that we placed in the buildid cache
(using "perf buildid-cache -v -k /proc/kcore") when the data was recorded.



--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/