Я не могу видеть параметр power / energy-core ядра perf для измерения энергопотребления - PullRequest
1 голос
/ 20 марта 2020

В моей системе используется процессор Intel (R) Xeon (R) Gold и Centos, Linux версия ядра 5.5.2

, выходная версия perf составляет 5.5.2-1.el7.elrepo.x86_64

Не буду получить энергопотребление каждого ядра. поэтому я попробовал это.

>>>  sudo perf stat -a -r 1 -e "power/energy-cores/" ./run
event syntax error: 'power/energy-cores/'
                           \___ unknown term

valid terms: event,config,config1,config2,name,period,percore

Initial error:
event syntax error: 'power/energy-cores/'
                           \___ unknown term

valid terms: event,config,config1,config2,name,period,percore
Run 'perf list' for a list of valid events

 Usage: perf stat [<options>] [<command>]

    -e, --event <event>   event selector. use 'perf list' to list available event

Как видите, произошла ошибка.

Поэтому я заглянул в каталог /sys/bus/event_source/devices/power/events, чтобы увидеть, какие события были здесь.

под результатами.

>>> ls /sys/bus/event_source/devices/power/events

energy-pkg  energy-pkg.scale  energy-pkg.unit  energy-ram  energy-ram.scale  energy-ram.unit

Я не вижу опции power/energy-cores. У меня только есть варианты power/energy-pkg и power/energy-ram.

, а у некоторых людей было power/energy-gpu.

Как можно получить energy-cores и energy-gpu?

>>> perf list | grep energy
  power/energy-pkg/                                  [Kernel PMU event]
  power/energy-ram/                                  [Kernel PMU event]


>>> sudo perf stat -a -r 1 -e "power/energy-pkg/" -e "power/energy-ram/" ./run
6765
 Performance counter stats for 'system wide':

              0.06 Joules power/energy-pkg/
              0.01 Joules power/energy-ram/

       0.001452589 seconds time elapsed

1 Ответ

1 голос
/ 21 марта 2020

perf добавил неподтвержденный PMU для отображения счетчиков энергопотребления Intel RAPL. События power/energy-cores и power/gpu в perf сопоставляются с доменами RAPL PP0 и PP1 соответственно. Вы можете увидеть это здесь .

static struct perf_msr rapl_msrs[] = {
    [PERF_RAPL_PP0]  = { MSR_PP0_ENERGY_STATUS,      &rapl_events_cores_group, test_msr },
    [PERF_RAPL_PKG]  = { MSR_PKG_ENERGY_STATUS,      &rapl_events_pkg_group,   test_msr },
    [PERF_RAPL_RAM]  = { MSR_DRAM_ENERGY_STATUS,     &rapl_events_ram_group,   test_msr },
    [PERF_RAPL_PP1]  = { MSR_PP1_ENERGY_STATUS,      &rapl_events_gpu_group,   test_msr },
    [PERF_RAPL_PSYS] = { MSR_PLATFORM_ENERGY_STATUS, &rapl_events_psys_group,  test_msr },
};

Чтобы прочитать о доменах RAPL, пожалуйста, обратитесь к руководству Intel для разработчиков программного обеспечения, том 3b (Глава по управлению питанием и тепловым режимом).

Каждый из этих доменов имеет свои собственные архитектурные возможности. Эти возможности будут обозначены наличием определенных неархитектурных MSR в процессоре. Но наличие этих доменов зависит от модели процессора Intel. Некоторые модели процессоров будут поддерживать все эти домены, некоторые - только некоторые.

perf пытается выполнить поиск этих MSR RAPL и создает таблицу устройств rapl_model_match на основе модели процессора в соответствии с конструкцией модуля msr и cstate.

Снимок: здесь .

Например, вы можете увидеть здесь , что только домены Package и DRAM поддерживаются.

static struct rapl_model model_knl = {
    .events     = BIT(PERF_RAPL_PKG) |
                  BIT(PERF_RAPL_RAM),
    .apply_quirk    = true,
};

Таким образом, для получения других событий вам придется использовать систему с другой процессорной моделью , тем самым обеспечивая наличие всех соответствующих RAPL MSR. Вы не можете просто встроить поддержку в вашу существующую систему, чтобы волшебным образом использовать события energy-cores и gpu.

...