• Arnaldo Carvalho de Melo's avatar
    perf evlist: No need to setup affinities when disabling events for pid targets · 0d3d2376
    Arnaldo Carvalho de Melo authored
    When the target is a pid, not started by 'perf stat' we need to disable
    the events, and in that case there is no need to setup affinities as we
    use a dummy CPU map, with just one entry set to -1.
    
    So stop doing it to avoid this needless call to sched_getaffinity():
    
      # strace -ke sched_getaffinity perf stat -e cycles -p 241957 sleep 1
      <SNIP>
      sched_getaffinity(0, 512, [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31]) = 8
       > /usr/lib64/libc-2.33.so(sched_getaffinity@@GLIBC_2.3.4+0x1a) [0xe6eea]
       > /var/home/acme/bin/perf(affinity__setup+0x6a) [0x532a2a]
       > /var/home/acme/bin/perf(__evlist__disable.constprop.0+0x27) [0x4b9827]
       > /var/home/acme/bin/perf(cmd_stat+0x29b5) [0x431725]
       > /var/home/acme/bin/perf(run_builtin+0x6a) [0x4a2cfa]
       > /var/home/acme/bin/perf(main+0x612) [0x40f8c2]
       > /usr/lib64/libc-2.33.so(__libc_start_main+0xd4) [0x27b74]
       > /var/home/acme/bin/perf(_start+0x2d) [0x40fadd]
      <SNIP>
    Acked-by: default avatarIan Rogers <irogers@google.com>
    Cc: Adrian Hunter <adrian.hunter@intel.com>
    Cc: Andi Kleen <andi@firstfloor.org>
    Cc: Ian Rogers <irogers@google.com>
    Cc: Jiri Olsa <jolsa@kernel.org>
    Cc: Namhyung Kim <namhyung@kernel.org>
    Link: https://lore.kernel.org/r/20220117160931.1191712-5-acme@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
    0d3d2376
evlist.c 49.7 KB