From 3de369291d1c995fe5cbb471892c4fdb26d9de15 Mon Sep 17 00:00:00 2001 From: Yujie Liu Date: Mon, 22 Jan 2024 17:23:23 +0800 Subject: [PATCH 1/2] ufs/tpmi_ufs.sh: Fix sysfs_verify to really test the path The sysfs_verify function sets test type as "dir", "file" or "exist" from the parameter, but there is no code that really does the check. The test_print_trc function simply echoes a line no matter the path exists or not. This may cause some false test results such as: $ ls /sys/devices/system/cpu/intel_uncore_frequency/current_freq_khz ls: cannot access '/sys/devices/system/cpu/intel_uncore_frequency/current_freq_khz': No such file or directory $ sudo ./runtests -c "./ufs/tpmi_ufs.sh -t check_ufs_sysfs_attr" <<> |0122_171944.874|TRACE|Check TPMI_UFS driver sysfs attribute:| |0122_171944.876|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/current_freq_khz does exist| |0122_171944.879|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/initial_max_freq_khz does exist| |0122_171944.881|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/domain_id does exist| |0122_171944.883|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/fabric_cluster_id does exist| |0122_171944.886|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/initial_min_freq_khz does exist| |0122_171944.888|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/max_freq_khz does exist| |0122_171944.891|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/min_freq_khz does exist| |0122_171944.893|TRACE|/sys/devices/system/cpu/intel_uncore_frequency/package_id does exist| |0122_171944.899|TRACE|package_00_die_00| <<> Test Start Time: 2024-01-22_17-19-44 -------------------------------------------------------- Testcase Result Exit Value Duration -------- ------ ---------- -------- [RESULT][./ufs/tpmi_ufs.sh -t check_ufs_sysfs_attr] [PASS] [0] [0.057s] -------------------------------------------------------- Reported-by: kernel test robot Signed-off-by: Yujie Liu --- ufs/tpmi_ufs.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ufs/tpmi_ufs.sh b/ufs/tpmi_ufs.sh index 0349a7a6..6fa278ec 100755 --- a/ufs/tpmi_ufs.sh +++ b/ufs/tpmi_ufs.sh @@ -38,8 +38,8 @@ sysfs_verify() { if [[ "$TYPE" != "d" ]] && [[ "$TYPE" != "f" ]]; then TYPE="e" fi - test_print_trc "$path does exist" - return 0 + + test -$TYPE "$path" && test_print_trc "$path does exist" } ufs_unbind_bind() { From 3d114da118b160c29cd05d0eaf62044c5b826262 Mon Sep 17 00:00:00 2001 From: Yujie Liu Date: Tue, 23 Jan 2024 09:37:38 +0800 Subject: [PATCH 2/2] ufs/tpmi_ufs.sh: Fix possible false results when driver sysfs does not exist If the kernel is built without CONFIG_INTEL_UNCORE_FREQ_CONTROL enabled, the driver sysfs path won't exist, so the tests are expected to fail, but actually it gives PASS results: <<> ls: cannot access '/sys/devices/system/cpu/intel_uncore_frequency': No such file or directory |1214_133318.071|TRACE|Uncore number: 0| <<> <<> ls: cannot access '/sys/devices/system/cpu/intel_uncore_frequency': No such file or directory <<> <<> ls: cannot access '/sys/devices/system/cpu/intel_uncore_frequency': No such file or directory <<> <<> ls: cannot access '/sys/devices/system/cpu/intel_uncore_frequency': No such file or directory <<> After CONFIG_INTEL_UNCORE_FREQ_CONTROL being enabled in the kernel, if the uncore number is 0, the tests are not done, either, so it is expected to be shown as BLOCK instead of PASS. <<> |0122_044137.087|TRACE|Uncore number: 0| <<> <<> <<> <<> <<> <<> <<> Reported-by: kernel test robot Signed-off-by: Yujie Liu --- ufs/tpmi_ufs.sh | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/ufs/tpmi_ufs.sh b/ufs/tpmi_ufs.sh index 6fa278ec..2292ced0 100755 --- a/ufs/tpmi_ufs.sh +++ b/ufs/tpmi_ufs.sh @@ -104,8 +104,10 @@ ufs_sysfs_attr() { } ufs_init_min_max_value() { + [[ -d "$UFS_SYSFS_PATH" ]] || die "$UFS_SYSFS_PATH does not exist" per_die_num=$(ls "$UFS_SYSFS_PATH" | grep -c uncore) test_print_trc "Uncore number: $per_die_num" + [[ "$per_die_num" = 0 ]] && block_test "Uncore number is 0" for ((i = 1; i <= per_die_num; i++)); do per_die=$(ls "$UFS_SYSFS_PATH" | grep uncore | sed -n "$i,1p") init_min=$(cat $UFS_SYSFS_PATH/"$per_die"/initial_min_freq_khz) @@ -125,7 +127,10 @@ ufs_init_min_max_value() { min_equals_to_max() { # Test Uncore freq is based on per die, this function is to set # Min_freq_khz to the same value of initial_max_freq_khz + [[ -d "$UFS_SYSFS_PATH" ]] || die "$UFS_SYSFS_PATH does not exist" per_die_num=$(ls "$UFS_SYSFS_PATH" | grep -c uncore) + test_print_trc "Uncore number: $per_die_num" + [[ "$per_die_num" = 0 ]] && block_test "Uncore number is 0" for ((i = 1; i <= per_die_num; i++)); do per_die=$(ls "$UFS_SYSFS_PATH" | grep uncore | sed -n "$i,1p") @@ -173,7 +178,10 @@ the max test freq $init_max khz" max_equals_to_min() { # Test Uncore freq is based on per die, this function is to set # Max_freq_khz to the same value of initial_min_freq_khz + [[ -d "$UFS_SYSFS_PATH" ]] || die "$UFS_SYSFS_PATH does not exist" per_die_num=$(ls "$UFS_SYSFS_PATH" | grep -c uncore) + test_print_trc "Uncore number: $per_die_num" + [[ "$per_die_num" = 0 ]] && block_test "Uncore number is 0" for ((i = 1; i <= per_die_num; i++)); do per_die=$(ls "$UFS_SYSFS_PATH" | grep uncore | sed -n "$i,1p") @@ -223,7 +231,10 @@ min_max_dynamic() { # Test Uncore freq is based on per die, this function is to set test freq to # current_freq_khz value + 100000 khz + [[ -d "$UFS_SYSFS_PATH" ]] || die "$UFS_SYSFS_PATH does not exist" per_die_num=$(ls "$UFS_SYSFS_PATH" | grep -c uncore) + test_print_trc "Uncore number: $per_die_num" + [[ "$per_die_num" = 0 ]] && block_test "Uncore number is 0" for ((i = 1; i <= per_die_num; i++)); do per_die=$(ls "$UFS_SYSFS_PATH" | grep uncore | sed -n "$i,1p") @@ -276,7 +287,10 @@ min and max test freq $test_freq khz" } pkg_max_min_freq_change() { + [[ -d "$UFS_SYSFS_PATH" ]] || die "$UFS_SYSFS_PATH does not exist" pkg_num=$(ls "$UFS_SYSFS_PATH" | grep -c package) + test_print_trc "Package number: $pkg_num" + [[ "$pkg_num" = 0 ]] && block_test "Package number is 0" # All the packages initial_max_freq_khz and initial_min_freq_khz are same at boot # So set test_max_freq and test_min_freq by referring any package