mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-01 08:04:22 +08:00
tools/power/turbostat: Introduce BIC_SAM_mc6/BIC_SAMMHz/BIC_SAMACTMHz
Graphics driver (i915/Xe) on mordern platforms splits GFX and SA Media information via different sysfs knobs. Existing BIC_GFX_rc6/BIC_GFXMHz/BIC_GFXACTMHz columns can be reused for GFX. Introduce BIC_SAM_mc6/BIC_SAMMHz/BIC_SAMACTMHz columns for SA Media. Signed-off-by: Zhang Rui <rui.zhang@intel.com>
This commit is contained in:
parent
60add818ab
commit
3bbb331c1d
@ -129,9 +129,17 @@ The system configuration dump (if --quiet is not used) is followed by statistics
|
||||
.PP
|
||||
\fBPkgTmp\fP Degrees Celsius reported by the per-package Package Thermal Monitor.
|
||||
.PP
|
||||
\fBGFX%rc6\fP The percentage of time the GPU is in the "render C6" state, rc6, during the measurement interval. From /sys/class/drm/card0/power/rc6_residency_ms.
|
||||
\fBGFX%rc6\fP The percentage of time the GPU is in the "render C6" state, rc6, during the measurement interval. From /sys/class/drm/card0/power/rc6_residency_ms or /sys/class/drm/card0/gt/gt0/rc6_residency_ms or /sys/class/drm/card0/device/tile0/gtN/gtidle/idle_residency_ms depending on the graphics driver being used.
|
||||
.PP
|
||||
\fBGFXMHz\fP Instantaneous snapshot of what sysfs presents at the end of the measurement interval. From /sys/class/graphics/fb0/device/drm/card0/gt_cur_freq_mhz.
|
||||
\fBGFXMHz\fP Instantaneous snapshot of what sysfs presents at the end of the measurement interval. From /sys/class/graphics/fb0/device/drm/card0/gt_cur_freq_mhz or /sys/class/drm/card0/gt_cur_freq_mhz or /sys/class/drm/card0/gt/gt0/rps_cur_freq_mhz or /sys/class/drm/card0/device/tile0/gtN/freq0/cur_freq depending on the graphics driver being used.
|
||||
.PP
|
||||
\fBGFXAMHz\fP Instantaneous snapshot of what sysfs presents at the end of the measurement interval. From /sys/class/graphics/fb0/device/drm/card0/gt_act_freq_mhz or /sys/class/drm/card0/gt_act_freq_mhz or /sys/class/drm/card0/gt/gt0/rps_act_freq_mhz or /sys/class/drm/card0/device/tile0/gtN/freq0/act_freq depending on the graphics driver being used.
|
||||
.PP
|
||||
\fBSAM%mc6\fP The percentage of time the SA Media is in the "module C6" state, mc6, during the measurement interval. From /sys/class/drm/card0/gt/gt1/rc6_residency_ms or /sys/class/drm/card0/device/tile0/gtN/gtidle/idle_residency_ms depending on the graphics driver being used.
|
||||
.PP
|
||||
\fBSAMMHz\fP Instantaneous snapshot of what sysfs presents at the end of the measurement interval. From /sys/class/drm/card0/gt/gt1/rps_cur_freq_mhz or /sys/class/drm/card0/device/tile0/gtN/freq0/cur_freq depending on the graphics driver being used.
|
||||
.PP
|
||||
\fBSAMAMHz\fP Instantaneous snapshot of what sysfs presents at the end of the measurement interval. From /sys/class/drm/card0/gt/gt1/rps_act_freq_mhz or /sys/class/drm/card0/device/tile0/gtN/freq0/act_freq depending on the graphics driver being used.
|
||||
.PP
|
||||
\fBPkg%pc2, Pkg%pc3, Pkg%pc6, Pkg%pc7\fP percentage residency in hardware package idle states. These numbers are from hardware residency counters.
|
||||
.PP
|
||||
|
@ -133,6 +133,9 @@ struct msr_counter bic[] = {
|
||||
{ 0x0, "IPC", "", 0, 0, 0, NULL, 0 },
|
||||
{ 0x0, "CoreThr", "", 0, 0, 0, NULL, 0 },
|
||||
{ 0x0, "UncMHz", "", 0, 0, 0, NULL, 0 },
|
||||
{ 0x0, "SAM%mc6", "", 0, 0, 0, NULL, 0 },
|
||||
{ 0x0, "SAMMHz", "", 0, 0, 0, NULL, 0 },
|
||||
{ 0x0, "SAMAMHz", "", 0, 0, 0, NULL, 0 },
|
||||
};
|
||||
|
||||
#define MAX_BIC (sizeof(bic) / sizeof(struct msr_counter))
|
||||
@ -191,11 +194,14 @@ struct msr_counter bic[] = {
|
||||
#define BIC_IPC (1ULL << 52)
|
||||
#define BIC_CORE_THROT_CNT (1ULL << 53)
|
||||
#define BIC_UNCORE_MHZ (1ULL << 54)
|
||||
#define BIC_SAM_mc6 (1ULL << 55)
|
||||
#define BIC_SAMMHz (1ULL << 56)
|
||||
#define BIC_SAMACTMHz (1ULL << 57)
|
||||
|
||||
#define BIC_TOPOLOGY (BIC_Package | BIC_Node | BIC_CoreCnt | BIC_PkgCnt | BIC_Core | BIC_CPU | BIC_Die )
|
||||
#define BIC_THERMAL_PWR ( BIC_CoreTmp | BIC_PkgTmp | BIC_PkgWatt | BIC_CorWatt | BIC_GFXWatt | BIC_RAMWatt | BIC_PKG__ | BIC_RAM__)
|
||||
#define BIC_FREQUENCY ( BIC_Avg_MHz | BIC_Busy | BIC_Bzy_MHz | BIC_TSC_MHz | BIC_GFXMHz | BIC_GFXACTMHz | BIC_UNCORE_MHZ)
|
||||
#define BIC_IDLE ( BIC_sysfs | BIC_CPU_c1 | BIC_CPU_c3 | BIC_CPU_c6 | BIC_CPU_c7 | BIC_GFX_rc6 | BIC_Pkgpc2 | BIC_Pkgpc3 | BIC_Pkgpc6 | BIC_Pkgpc7 | BIC_Pkgpc8 | BIC_Pkgpc9 | BIC_Pkgpc10 | BIC_CPU_LPI | BIC_SYS_LPI | BIC_Mod_c6 | BIC_Totl_c0 | BIC_Any_c0 | BIC_GFX_c0 | BIC_CPUGFX)
|
||||
#define BIC_FREQUENCY (BIC_Avg_MHz | BIC_Busy | BIC_Bzy_MHz | BIC_TSC_MHz | BIC_GFXMHz | BIC_GFXACTMHz | BIC_SAMMHz | BIC_SAMACTMHz | BIC_UNCORE_MHZ)
|
||||
#define BIC_IDLE (BIC_sysfs | BIC_CPU_c1 | BIC_CPU_c3 | BIC_CPU_c6 | BIC_CPU_c7 | BIC_GFX_rc6 | BIC_Pkgpc2 | BIC_Pkgpc3 | BIC_Pkgpc6 | BIC_Pkgpc7 | BIC_Pkgpc8 | BIC_Pkgpc9 | BIC_Pkgpc10 | BIC_CPU_LPI | BIC_SYS_LPI | BIC_Mod_c6 | BIC_Totl_c0 | BIC_Any_c0 | BIC_GFX_c0 | BIC_CPUGFX | BIC_SAM_mc6)
|
||||
#define BIC_OTHER ( BIC_IRQ | BIC_SMI | BIC_ThreadC | BIC_CoreTmp | BIC_IPC)
|
||||
|
||||
#define BIC_DISABLED_BY_DEFAULT (BIC_USEC | BIC_TOD | BIC_APIC | BIC_X2APIC)
|
||||
@ -277,6 +283,9 @@ enum gfx_sysfs_idx {
|
||||
GFX_rc6,
|
||||
GFX_MHz,
|
||||
GFX_ACTMHz,
|
||||
SAM_mc6,
|
||||
SAM_MHz,
|
||||
SAM_ACTMHz,
|
||||
GFX_MAX
|
||||
};
|
||||
|
||||
@ -1193,6 +1202,9 @@ struct pkg_data {
|
||||
long long gfx_rc6_ms;
|
||||
unsigned int gfx_mhz;
|
||||
unsigned int gfx_act_mhz;
|
||||
long long sam_mc6_ms;
|
||||
unsigned int sam_mhz;
|
||||
unsigned int sam_act_mhz;
|
||||
unsigned int package_id;
|
||||
struct rapl_counter energy_pkg; /* MSR_PKG_ENERGY_STATUS */
|
||||
struct rapl_counter energy_dram; /* MSR_DRAM_ENERGY_STATUS */
|
||||
@ -1844,6 +1856,15 @@ void print_header(char *delim)
|
||||
if (DO_BIC(BIC_GFXACTMHz))
|
||||
outp += sprintf(outp, "%sGFXAMHz", (printed++ ? delim : ""));
|
||||
|
||||
if (DO_BIC(BIC_SAM_mc6))
|
||||
outp += sprintf(outp, "%sSAM%%mc6", (printed++ ? delim : ""));
|
||||
|
||||
if (DO_BIC(BIC_SAMMHz))
|
||||
outp += sprintf(outp, "%sSAMMHz", (printed++ ? delim : ""));
|
||||
|
||||
if (DO_BIC(BIC_SAMACTMHz))
|
||||
outp += sprintf(outp, "%sSAMAMHz", (printed++ ? delim : ""));
|
||||
|
||||
if (DO_BIC(BIC_Totl_c0))
|
||||
outp += sprintf(outp, "%sTotl%%C0", (printed++ ? delim : ""));
|
||||
if (DO_BIC(BIC_Any_c0))
|
||||
@ -2251,6 +2272,24 @@ int format_counters(struct thread_data *t, struct core_data *c, struct pkg_data
|
||||
if (DO_BIC(BIC_GFXACTMHz))
|
||||
outp += sprintf(outp, "%s%d", (printed++ ? delim : ""), p->gfx_act_mhz);
|
||||
|
||||
/* SAMmc6 */
|
||||
if (DO_BIC(BIC_SAM_mc6)) {
|
||||
if (p->sam_mc6_ms == -1) { /* detect GFX counter reset */
|
||||
outp += sprintf(outp, "%s**.**", (printed++ ? delim : ""));
|
||||
} else {
|
||||
outp += sprintf(outp, "%s%.2f", (printed++ ? delim : ""),
|
||||
p->sam_mc6_ms / 10.0 / interval_float);
|
||||
}
|
||||
}
|
||||
|
||||
/* SAMMHz */
|
||||
if (DO_BIC(BIC_SAMMHz))
|
||||
outp += sprintf(outp, "%s%d", (printed++ ? delim : ""), p->sam_mhz);
|
||||
|
||||
/* SAMACTMHz */
|
||||
if (DO_BIC(BIC_SAMACTMHz))
|
||||
outp += sprintf(outp, "%s%d", (printed++ ? delim : ""), p->sam_act_mhz);
|
||||
|
||||
/* Totl%C0, Any%C0 GFX%C0 CPUGFX% */
|
||||
if (DO_BIC(BIC_Totl_c0))
|
||||
outp += sprintf(outp, "%s%.2f", (printed++ ? delim : ""), 100.0 * p->pkg_wtd_core_c0 / tsc);
|
||||
@ -2437,6 +2476,15 @@ int delta_package(struct pkg_data *new, struct pkg_data *old)
|
||||
old->gfx_mhz = new->gfx_mhz;
|
||||
old->gfx_act_mhz = new->gfx_act_mhz;
|
||||
|
||||
/* flag an error when mc6 counter resets/wraps */
|
||||
if (old->sam_mc6_ms > new->sam_mc6_ms)
|
||||
old->sam_mc6_ms = -1;
|
||||
else
|
||||
old->sam_mc6_ms = new->sam_mc6_ms - old->sam_mc6_ms;
|
||||
|
||||
old->sam_mhz = new->sam_mhz;
|
||||
old->sam_act_mhz = new->sam_act_mhz;
|
||||
|
||||
old->energy_pkg.raw_value = new->energy_pkg.raw_value - old->energy_pkg.raw_value;
|
||||
old->energy_cores.raw_value = new->energy_cores.raw_value - old->energy_cores.raw_value;
|
||||
old->energy_gfx.raw_value = new->energy_gfx.raw_value - old->energy_gfx.raw_value;
|
||||
@ -2661,6 +2709,9 @@ void clear_counters(struct thread_data *t, struct core_data *c, struct pkg_data
|
||||
p->uncore_mhz = 0;
|
||||
p->gfx_mhz = 0;
|
||||
p->gfx_act_mhz = 0;
|
||||
p->sam_mc6_ms = 0;
|
||||
p->sam_mhz = 0;
|
||||
p->sam_act_mhz = 0;
|
||||
for (i = 0, mp = sys.tp; mp; i++, mp = mp->next)
|
||||
t->counter[i] = 0;
|
||||
|
||||
@ -2775,6 +2826,9 @@ int sum_counters(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
||||
average.packages.uncore_mhz = p->uncore_mhz;
|
||||
average.packages.gfx_mhz = p->gfx_mhz;
|
||||
average.packages.gfx_act_mhz = p->gfx_act_mhz;
|
||||
average.packages.sam_mc6_ms = p->sam_mc6_ms;
|
||||
average.packages.sam_mhz = p->sam_mhz;
|
||||
average.packages.sam_act_mhz = p->sam_act_mhz;
|
||||
|
||||
average.packages.pkg_temp_c = MAX(average.packages.pkg_temp_c, p->pkg_temp_c);
|
||||
|
||||
@ -3572,19 +3626,28 @@ int get_counters(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
||||
p->pkg_temp_c = tj_max - ((msr >> 16) & 0x7F);
|
||||
}
|
||||
|
||||
if (DO_BIC(BIC_GFX_rc6))
|
||||
p->gfx_rc6_ms = gfx_info[GFX_rc6].val_ull;
|
||||
|
||||
/* n.b. assume die0 uncore frequency applies to whole package */
|
||||
if (DO_BIC(BIC_UNCORE_MHZ))
|
||||
p->uncore_mhz = get_uncore_mhz(p->package_id, 0);
|
||||
|
||||
if (DO_BIC(BIC_GFX_rc6))
|
||||
p->gfx_rc6_ms = gfx_info[GFX_rc6].val_ull;
|
||||
|
||||
if (DO_BIC(BIC_GFXMHz))
|
||||
p->gfx_mhz = gfx_info[GFX_MHz].val;
|
||||
|
||||
if (DO_BIC(BIC_GFXACTMHz))
|
||||
p->gfx_act_mhz = gfx_info[GFX_ACTMHz].val;
|
||||
|
||||
if (DO_BIC(BIC_SAM_mc6))
|
||||
p->sam_mc6_ms = gfx_info[SAM_mc6].val_ull;
|
||||
|
||||
if (DO_BIC(BIC_SAMMHz))
|
||||
p->sam_mhz = gfx_info[SAM_MHz].val;
|
||||
|
||||
if (DO_BIC(BIC_SAMACTMHz))
|
||||
p->sam_act_mhz = gfx_info[SAM_ACTMHz].val;
|
||||
|
||||
for (i = 0, mp = sys.pp; mp; i++, mp = mp->next) {
|
||||
if (get_mp(cpu, mp, &p->counter[i]))
|
||||
return -10;
|
||||
@ -4634,6 +4697,7 @@ int snapshot_graphics(int idx)
|
||||
|
||||
switch (idx) {
|
||||
case GFX_rc6:
|
||||
case SAM_mc6:
|
||||
fp = fopen_or_die(gfx_info[idx].path, "r");
|
||||
retval = fscanf(fp, "%lld", &gfx_info[idx].val_ull);
|
||||
if (retval != 1)
|
||||
@ -4642,6 +4706,8 @@ int snapshot_graphics(int idx)
|
||||
return 0;
|
||||
case GFX_MHz:
|
||||
case GFX_ACTMHz:
|
||||
case SAM_MHz:
|
||||
case SAM_ACTMHz:
|
||||
if (gfx_info[idx].fp == NULL) {
|
||||
gfx_info[idx].fp = fopen_or_die(gfx_info[idx].path, "r");
|
||||
} else {
|
||||
@ -4727,6 +4793,15 @@ int snapshot_proc_sysfs_files(void)
|
||||
if (DO_BIC(BIC_GFXACTMHz))
|
||||
snapshot_graphics(GFX_ACTMHz);
|
||||
|
||||
if (DO_BIC(BIC_SAM_mc6))
|
||||
snapshot_graphics(SAM_mc6);
|
||||
|
||||
if (DO_BIC(BIC_SAMMHz))
|
||||
snapshot_graphics(SAM_MHz);
|
||||
|
||||
if (DO_BIC(BIC_SAMACTMHz))
|
||||
snapshot_graphics(SAM_ACTMHz);
|
||||
|
||||
if (DO_BIC(BIC_CPU_LPI))
|
||||
snapshot_cpu_lpi_us();
|
||||
|
||||
@ -5325,6 +5400,12 @@ static void probe_graphics(void)
|
||||
BIC_PRESENT(BIC_GFXMHz);
|
||||
if (gfx_info[GFX_ACTMHz].path)
|
||||
BIC_PRESENT(BIC_GFXACTMHz);
|
||||
if (gfx_info[SAM_mc6].path)
|
||||
BIC_PRESENT(BIC_SAM_mc6);
|
||||
if (gfx_info[SAM_MHz].path)
|
||||
BIC_PRESENT(BIC_SAMMHz);
|
||||
if (gfx_info[SAM_ACTMHz].path)
|
||||
BIC_PRESENT(BIC_SAMACTMHz);
|
||||
}
|
||||
|
||||
static void dump_sysfs_cstate_config(void)
|
||||
|
Loading…
Reference in New Issue
Block a user