Skip to content

Commit

Permalink
test/power: round CPU frequency to check
Browse files Browse the repository at this point in the history
[ upstream commit 606a234 ]

The value in "/sys/.../cpuinfo_cur_freq" may not be exactly the
same as what was set. For example, if "2400000" is written to
"/sys/.../cpufreq/scaling_setspeed" to set the frequency, then the
value in "/sys/.../cpuinfo_cur_freq" may be "2401222". So need to
round the value.

Fixes: ed7c51a ("app/test: vm power management")

Signed-off-by: Richael Zhuang <richael.zhuang@arm.com>
Reviewed-by: David Hunt <david.hunt@intel.com>
  • Loading branch information
richael02 authored and cpaelzer committed May 17, 2021
1 parent 002beb9 commit 46adbaf
Showing 1 changed file with 15 additions and 1 deletion.
16 changes: 15 additions & 1 deletion app/test/test_power_cpufreq.c
Expand Up @@ -35,6 +35,10 @@ test_power_caps(void)
#define TEST_POWER_LCORE_INVALID ((unsigned)RTE_MAX_LCORE)
#define TEST_POWER_FREQS_NUM_MAX ((unsigned)RTE_MAX_LCORE_FREQS)

/* macros used for rounding frequency to nearest 100000 */
#define TEST_FREQ_ROUNDING_DELTA 50000
#define TEST_ROUND_FREQ_TO_N_100000 100000

#define TEST_POWER_SYSFILE_CUR_FREQ \
"/sys/devices/system/cpu/cpu%u/cpufreq/cpuinfo_cur_freq"

Expand Down Expand Up @@ -67,7 +71,17 @@ check_cur_freq(unsigned lcore_id, uint32_t idx)
goto fail_all;

cur_freq = strtoul(buf, NULL, TEST_POWER_CONVERT_TO_DECIMAL);
ret = (freqs[idx] == cur_freq ? 0 : -1);

/* convert the frequency to nearest 100000 value
* Ex: if cur_freq=1396789 then freq_conv=1400000
* Ex: if cur_freq=800030 then freq_conv=800000
*/
unsigned int freq_conv = 0;
freq_conv = (cur_freq + TEST_FREQ_ROUNDING_DELTA)
/ TEST_ROUND_FREQ_TO_N_100000;
freq_conv = freq_conv * TEST_ROUND_FREQ_TO_N_100000;

ret = (freqs[idx] == freq_conv ? 0 : -1);

if (ret == 0)
break;
Expand Down

0 comments on commit 46adbaf

Please sign in to comment.