• Yang Jihong's avatar
    perf sched: Move start_work_mutex and work_done_wait_mutex initialization to perf_sched__replay() · c6907863
    Yang Jihong authored
    The start_work_mutex and work_done_wait_mutex are used only for the
    'perf sched replay'. Put their initialization in perf_sched__replay () to
    reduce unnecessary actions in other commands.
    
    Simple functional testing:
    
      # perf sched record perf bench sched messaging
      # Running 'sched/messaging' benchmark:
      # 20 sender and receiver processes per group
      # 10 groups == 400 processes run
    
           Total time: 0.197 [sec]
      [ perf record: Woken up 1 times to write data ]
      [ perf record: Captured and wrote 14.952 MB perf.data (134165 samples) ]
    
      # perf sched replay
      run measurement overhead: 108 nsecs
      sleep measurement overhead: 65658 nsecs
      the run test took 999991 nsecs
      the sleep test took 1079324 nsecs
      nr_run_events:        42378
      nr_sleep_events:      43102
      nr_wakeup_events:     31852
      target-less wakeups:  17
      multi-target wakeups: 712
      task      0 (             swapper:         0), nr_events: 10451
      task      1 (             swapper:         1), nr_events: 3
      task      2 (             swapper:         2), nr_events: 1
      <SNIP>
      task    717 (     sched-messaging:     74483), nr_events: 152
      task    718 (     sched-messaging:     74484), nr_events: 1944
      task    719 (     sched-messaging:     74485), nr_events: 73
      task    720 (     sched-messaging:     74486), nr_events: 163
      task    721 (     sched-messaging:     74487), nr_events: 942
      task    722 (     sched-messaging:     74488), nr_events: 78
      task    723 (     sched-messaging:     74489), nr_events: 1090
      ------------------------------------------------------------
      #1  : 1366.507, ravg: 1366.51, cpu: 7682.70 / 7682.70
      #2  : 1410.072, ravg: 1370.86, cpu: 7723.88 / 7686.82
      #3  : 1396.296, ravg: 1373.41, cpu: 7568.20 / 7674.96
      #4  : 1381.019, ravg: 1374.17, cpu: 7531.81 / 7660.64
      #5  : 1393.826, ravg: 1376.13, cpu: 7725.25 / 7667.11
      #6  : 1401.581, ravg: 1378.68, cpu: 7594.82 / 7659.88
      #7  : 1381.337, ravg: 1378.94, cpu: 7371.22 / 7631.01
      #8  : 1373.842, ravg: 1378.43, cpu: 7894.92 / 7657.40
      #9  : 1364.697, ravg: 1377.06, cpu: 7324.91 / 7624.15
      #10 : 1363.613, ravg: 1375.72, cpu: 7209.55 / 7582.69
      # echo $?
      0
    Signed-off-by: default avatarYang Jihong <yangjihong1@huawei.com>
    Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
    Link: https://lore.kernel.org/r/20240206083228.172607-2-yangjihong1@huawei.com
    c6907863
builtin-sched.c 91.3 KB