On Tue, Sep 01, 2020 at 09:38:03AM +0100, Leo Yan wrote: SNIP
> @@ -2941,30 +2942,38 @@ static int perf_c2c__record(int argc, const char > **argv) > rec_argv[i++] = "record"; > > if (!event_set) { > - perf_mem_events[PERF_MEM_EVENTS__LOAD].record = true; > - perf_mem_events[PERF_MEM_EVENTS__STORE].record = true; > + e = perf_mem_events__ptr(PERF_MEM_EVENTS__LOAD); > + e->record = true; > + > + e = perf_mem_events__ptr(PERF_MEM_EVENTS__STORE); > + e->record = true; > } > > - if (perf_mem_events[PERF_MEM_EVENTS__LOAD].record) > + e = perf_mem_events__ptr(PERF_MEM_EVENTS__LOAD); > + if (e->record) > rec_argv[i++] = "-W"; > > rec_argv[i++] = "-d"; > rec_argv[i++] = "--phys-data"; > rec_argv[i++] = "--sample-cpu"; > > - for (j = 0; j < PERF_MEM_EVENTS__MAX; j++) { > - if (!perf_mem_events[j].record) > + j = 0; > + while ((e = perf_mem_events__ptr(j)) != NULL) { > + if (!e->record) { you could keep the above 'for loop' in here, it seems better than taking care of j++ > + j++; > continue; > + } > > - if (!perf_mem_events[j].supported) { > + if (!e->supported) { > pr_err("failed: event '%s' not supported\n", > - perf_mem_events[j].name); > + perf_mem_events__name(j)); > free(rec_argv); > return -1; > } > > rec_argv[i++] = "-e"; > rec_argv[i++] = perf_mem_events__name(j); > + j++; > } > > if (all_user) SNIP > @@ -100,11 +106,14 @@ static int __cmd_record(int argc, const char **argv, > struct perf_mem *mem) > if (mem->phys_addr) > rec_argv[i++] = "--phys-data"; > > - for (j = 0; j < PERF_MEM_EVENTS__MAX; j++) { > - if (!perf_mem_events[j].record) > + j = 0; > + while ((e = perf_mem_events__ptr(j)) != NULL) { > + if (!e->record) { same here thanks, jirka > + j++; > continue; > + } > > - if (!perf_mem_events[j].supported) { > + if (!e->supported) { > pr_err("failed: event '%s' not supported\n", > perf_mem_events__name(j)); > free(rec_argv); > @@ -113,6 +122,7 @@ static int __cmd_record(int argc, const char **argv, > struct perf_mem *mem) > > rec_argv[i++] = "-e"; > rec_argv[i++] = perf_mem_events__name(j); > + j++; SNIP