> On 7 May 2026, at 11:43 AM, Namhyung Kim <[email protected]> wrote:
>
> On Mon, May 04, 2026 at 08:43:20PM +0530, Athira Rajeev wrote:
>> perf trace record fails some cases in powerpc
>>
>> # ./perf test "perf trace record and replay"
>> 128: perf trace record and replay :
>> FAILED!
>>
>> # ./perf trace record sleep 1
>> # echo $?
>> 32
>>
>> This is happening because of non-zero err value from
>> auxtrace_record__init() function.
>>
>> static int record__auxtrace_init(struct record *rec)
>> {
>> int err;
>>
>> if ((rec->opts.auxtrace_snapshot_opts ||
>> rec->opts.auxtrace_sample_opts)
>> && record__threads_enabled(rec)) {
>> pr_err("AUX area tracing options are not available in
>> parallel streaming mode.\n");
>> return -EINVAL;
>> }
>>
>> if (!rec->itr) {
>> rec->itr = auxtrace_record__init(rec->evlist, &err);
>> if (err)
>> return err;
>> }
>>
>> Here "int err" is not initialised. The code expects "err" to be set
>> from auxtrace_record__init() function.
>>
>> Update auxtrace_record__init() in arch/powerpc/util/auxtrace.c to clear
>> err value in the beginning.
>>
>> - Clear err value in beginning of function. Any fail later will
>> set appropriate return code to err.
>> - Even if we haven't found any event for auxtrace, perf record
>> should continue for other events. NULL return
>> will indicate that there is no auxtrace record initialized.
>> - Not having "err" set here will affect monitoring of other events
>> also because perf record will fail seeing random value in err.
>>
>> Set err to -EINVAL before invoking auxtrace_record__init() in
>> builtin-record.c
>>
>> With the fix,
>>
>> # ./perf trace record sleep 1
>> [ perf record: Woken up 2 times to write data ]
>> [ perf record: Captured and wrote 0.033 MB perf.data (228 samples) ]
>>
>> Fixes: 1dbfaf94cf66 ("perf powerpc: Add basic CONFIG_AUXTRACE support for
>> VPA pmu on powerpc")
>> Reviewed-by: Adrian Hunter <[email protected]>
>> Signed-off-by: Athira Rajeev <[email protected]>
>
> For both patches,
>
> Acked-by: Namhyung Kim <[email protected]>
>
> Thanks,
> Namhyung
>
Hi,
Can we please have this pulled in, if the patches looks fine ?
Thanks
Athira
>> ---
>> Changelog:
>> v4:
>> Added Reviewed-by from Adrian
>>
>> v1 -> v2
>> Addressed review comment from Adrian:
>> - Set err to -EINVAL before invoking auxtrace_record__init() in
>> builtin-record.c
>> - Added kernel-doc to auxtrace_record__init() in tools/perf/util/auxtrace.c
>> Addressed review comment from Namhyung:
>> - Added fixes tag
>>
>> tools/perf/arch/powerpc/util/auxtrace.c | 6 ++++++
>> tools/perf/builtin-record.c | 1 +
>> 2 files changed, 7 insertions(+)
>>
>> diff --git a/tools/perf/arch/powerpc/util/auxtrace.c
>> b/tools/perf/arch/powerpc/util/auxtrace.c
>> index e39deff6c857..4600a1661b4f 100644
>> --- a/tools/perf/arch/powerpc/util/auxtrace.c
>> +++ b/tools/perf/arch/powerpc/util/auxtrace.c
>> @@ -71,6 +71,12 @@ struct auxtrace_record *auxtrace_record__init(struct
>> evlist *evlist,
>> struct evsel *pos;
>> int found = 0;
>>
>> + /*
>> + * Set err value to zero here. Any fail later
>> + * will set appropriate return code to err.
>> + */
>> + *err = 0;
>> +
>> evlist__for_each_entry(evlist, pos) {
>> if (strstarts(pos->name, "vpa_dtl")) {
>> found = 1;
>> diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c
>> index 4a5eba498c02..708825747af5 100644
>> --- a/tools/perf/builtin-record.c
>> +++ b/tools/perf/builtin-record.c
>> @@ -865,6 +865,7 @@ static int record__auxtrace_init(struct record *rec)
>> }
>>
>> if (!rec->itr) {
>> + err = -EINVAL;
>> rec->itr = auxtrace_record__init(rec->evlist, &err);
>> if (err)
>> return err;
>> --
>> 2.47.3