2024-05-22 17:08:14

by Muhammad Usama Anjum

[permalink] [raw]
Subject: [PATCH 1/2] selftests/thermel/intel: conform the test to TAP output

Conform the layout, informational and status messages to TAP. No
functional change is intended other than the layout of output messages.

Signed-off-by: Muhammad Usama Anjum <[email protected]>
---
.../intel/workload_hint/workload_hint_test.c | 98 ++++++++-----------
1 file changed, 39 insertions(+), 59 deletions(-)

diff --git a/tools/testing/selftests/thermal/intel/workload_hint/workload_hint_test.c b/tools/testing/selftests/thermal/intel/workload_hint/workload_hint_test.c
index 217c3a641c537..d107c2d6f3a22 100644
--- a/tools/testing/selftests/thermal/intel/workload_hint/workload_hint_test.c
+++ b/tools/testing/selftests/thermal/intel/workload_hint/workload_hint_test.c
@@ -9,6 +9,7 @@
#include <fcntl.h>
#include <poll.h>
#include <signal.h>
+#include "../../../kselftest.h"

#define WORKLOAD_NOTIFICATION_DELAY_ATTRIBUTE "/sys/bus/pci/devices/0000:00:04.0/workload_hint/notification_delay_ms"
#define WORKLOAD_ENABLE_ATTRIBUTE "/sys/bus/pci/devices/0000:00:04.0/workload_hint/workload_hint_enable"
@@ -31,17 +32,13 @@ void workload_hint_exit(int signum)
/* Disable feature via sysfs knob */

fd = open(WORKLOAD_ENABLE_ATTRIBUTE, O_RDWR);
- if (fd < 0) {
- perror("Unable to open workload type feature enable file\n");
- exit(1);
- }
+ if (fd < 0)
+ ksft_exit_fail_perror("Unable to open workload type feature enable file");

- if (write(fd, "0\n", 2) < 0) {
- perror("Can' disable workload hints\n");
- exit(1);
- }
+ if (write(fd, "0\n", 2) < 0)
+ ksft_exit_fail_perror("Can' disable workload hints");

- printf("Disabled workload type prediction\n");
+ ksft_print_msg("Disabled workload type prediction\n");

close(fd);
}
@@ -54,32 +51,27 @@ int main(int argc, char **argv)
char delay_str[64];
int delay = 0;

- printf("Usage: workload_hint_test [notification delay in milli seconds]\n");
+ ksft_print_header();
+ ksft_set_plan(1);
+
+ ksft_print_msg("Usage: workload_hint_test [notification delay in milli seconds]\n");

if (argc > 1) {
ret = sscanf(argv[1], "%d", &delay);
- if (ret < 0) {
- printf("Invalid delay\n");
- exit(1);
- }
+ if (ret < 0)
+ ksft_exit_fail_perror("Invalid delay");

- printf("Setting notification delay to %d ms\n", delay);
+ ksft_print_msg("Setting notification delay to %d ms\n", delay);
if (delay < 0)
- exit(1);
-
- sprintf(delay_str, "%s\n", argv[1]);
+ ksft_exit_fail_msg("delay can never be negative\n");

sprintf(delay_str, "%s\n", argv[1]);
fd = open(WORKLOAD_NOTIFICATION_DELAY_ATTRIBUTE, O_RDWR);
- if (fd < 0) {
- perror("Unable to open workload notification delay\n");
- exit(1);
- }
+ if (fd < 0)
+ ksft_exit_fail_perror("Unable to open workload notification delay");

- if (write(fd, delay_str, strlen(delay_str)) < 0) {
- perror("Can't set delay\n");
- exit(1);
- }
+ if (write(fd, delay_str, strlen(delay_str)) < 0)
+ ksft_exit_fail_perror("Can't set delay");

close(fd);
}
@@ -93,63 +85,51 @@ int main(int argc, char **argv)

/* Enable feature via sysfs knob */
fd = open(WORKLOAD_ENABLE_ATTRIBUTE, O_RDWR);
- if (fd < 0) {
- perror("Unable to open workload type feature enable file\n");
- exit(1);
- }
+ if (fd < 0)
+ ksft_exit_fail_perror("Unable to open workload type feature enable file");

- if (write(fd, "1\n", 2) < 0) {
- perror("Can' enable workload hints\n");
- exit(1);
- }
+ if (write(fd, "1\n", 2) < 0)
+ ksft_exit_fail_perror("Can' enable workload hints");

close(fd);

- printf("Enabled workload type prediction\n");
+ ksft_print_msg("Enabled workload type prediction\n");

while (1) {
fd = open(WORKLOAD_TYPE_INDEX_ATTRIBUTE, O_RDONLY);
- if (fd < 0) {
- perror("Unable to open workload type file\n");
- exit(1);
- }
+ if (fd < 0)
+ ksft_exit_fail_perror("Unable to open workload type file");

- if ((lseek(fd, 0L, SEEK_SET)) < 0) {
- fprintf(stderr, "Failed to set pointer to beginning\n");
- exit(1);
- }
+ if ((lseek(fd, 0L, SEEK_SET)) < 0)
+ ksft_exit_fail_perror("Failed to set pointer to beginning");

- if (read(fd, index_str, sizeof(index_str)) < 0) {
- fprintf(stderr, "Failed to read from:%s\n",
- WORKLOAD_TYPE_INDEX_ATTRIBUTE);
- exit(1);
- }
+ if (read(fd, index_str, sizeof(index_str)) < 0)
+ ksft_exit_fail_perror("Failed to read from: workload_type_index");

ufd.fd = fd;
ufd.events = POLLPRI;

ret = poll(&ufd, 1, -1);
if (ret < 0) {
- perror("poll error");
- exit(1);
+ ksft_exit_fail_perror("poll error");
} else if (ret == 0) {
- printf("Poll Timeout\n");
+ ksft_print_msg("Poll Timeout\n");
} else {
- if ((lseek(fd, 0L, SEEK_SET)) < 0) {
- fprintf(stderr, "Failed to set pointer to beginning\n");
- exit(1);
- }
+ if ((lseek(fd, 0L, SEEK_SET)) < 0)
+ ksft_exit_fail_perror("Failed to set pointer to beginning");

- if (read(fd, index_str, sizeof(index_str)) < 0)
- exit(0);
+ if (read(fd, index_str, sizeof(index_str)) < 0) {
+ ksft_test_result_pass("Successfully read\n");
+ ksft_finished();
+ }

ret = sscanf(index_str, "%d", &index);
if (ret < 0)
break;
if (index > WORKLOAD_TYPE_MAX_INDEX)
- printf("Invalid workload type index\n");
+ ksft_print_msg("Invalid workload type index\n");
else
- printf("workload type:%s\n", workload_types[index]);
+ ksft_print_msg("workload type:%s\n", workload_types[index]);
}

close(fd);
--
2.39.2



2024-05-22 17:08:29

by Muhammad Usama Anjum

[permalink] [raw]
Subject: [PATCH 2/2] selftests/thermel/intel: conform the test to TAP output

Conform the layout, informational and status messages to TAP. No
functional change is intended other than the layout of output messages.

Signed-off-by: Muhammad Usama Anjum <[email protected]>
---
.../intel/power_floor/power_floor_test.c | 68 ++++++++-----------
1 file changed, 28 insertions(+), 40 deletions(-)

diff --git a/tools/testing/selftests/thermal/intel/power_floor/power_floor_test.c b/tools/testing/selftests/thermal/intel/power_floor/power_floor_test.c
index 0326b39a11b91..1626c6d92e621 100644
--- a/tools/testing/selftests/thermal/intel/power_floor/power_floor_test.c
+++ b/tools/testing/selftests/thermal/intel/power_floor/power_floor_test.c
@@ -9,6 +9,7 @@
#include <fcntl.h>
#include <poll.h>
#include <signal.h>
+#include "../../../kselftest.h"

#define POWER_FLOOR_ENABLE_ATTRIBUTE "/sys/bus/pci/devices/0000:00:04.0/power_limits/power_floor_enable"
#define POWER_FLOOR_STATUS_ATTRIBUTE "/sys/bus/pci/devices/0000:00:04.0/power_limits/power_floor_status"
@@ -20,17 +21,13 @@ void power_floor_exit(int signum)
/* Disable feature via sysfs knob */

fd = open(POWER_FLOOR_ENABLE_ATTRIBUTE, O_RDWR);
- if (fd < 0) {
- perror("Unable to open power floor enable file\n");
- exit(1);
- }
+ if (fd < 0)
+ ksft_exit_fail_perror("Unable to open power floor enable file");

- if (write(fd, "0\n", 2) < 0) {
- perror("Can' disable power floor notifications\n");
- exit(1);
- }
+ if (write(fd, "0\n", 2) < 0)
+ ksft_exit_fail_perror("Can' disable power floor notifications");

- printf("Disabled power floor notifications\n");
+ ksft_print_msg("Disabled power floor notifications\n");

close(fd);
}
@@ -41,6 +38,9 @@ int main(int argc, char **argv)
char status_str[3];
int fd, ret;

+ ksft_print_header();
+ ksft_set_plan(1);
+
if (signal(SIGINT, power_floor_exit) == SIG_IGN)
signal(SIGINT, SIG_IGN);
if (signal(SIGHUP, power_floor_exit) == SIG_IGN)
@@ -50,57 +50,45 @@ int main(int argc, char **argv)

/* Enable feature via sysfs knob */
fd = open(POWER_FLOOR_ENABLE_ATTRIBUTE, O_RDWR);
- if (fd < 0) {
- perror("Unable to open power floor enable file\n");
- exit(1);
- }
+ if (fd < 0)
+ ksft_exit_fail_perror("Unable to open power floor enable file");

- if (write(fd, "1\n", 2) < 0) {
- perror("Can' enable power floor notifications\n");
- exit(1);
- }
+ if (write(fd, "1\n", 2) < 0)
+ ksft_exit_fail_perror("Can' enable power floor notifications");

close(fd);

- printf("Enabled power floor notifications\n");
+ ksft_print_msg("Enabled power floor notifications\n");

while (1) {
fd = open(POWER_FLOOR_STATUS_ATTRIBUTE, O_RDONLY);
- if (fd < 0) {
- perror("Unable to power floor status file\n");
- exit(1);
- }
+ if (fd < 0)
+ ksft_exit_fail_perror("Unable to power floor status file");

- if ((lseek(fd, 0L, SEEK_SET)) < 0) {
- fprintf(stderr, "Failed to set pointer to beginning\n");
- exit(1);
- }
+ if ((lseek(fd, 0L, SEEK_SET)) < 0)
+ ksft_exit_fail_perror("Failed to set pointer to beginning\n");

if (read(fd, status_str, sizeof(status_str)) < 0) {
- fprintf(stderr, "Failed to read from:%s\n",
- POWER_FLOOR_STATUS_ATTRIBUTE);
- exit(1);
- }
+ ksft_exit_fail_perror(stderr, "Failed to read from: power_floor_status");

ufd.fd = fd;
ufd.events = POLLPRI;

ret = poll(&ufd, 1, -1);
if (ret < 0) {
- perror("poll error");
- exit(1);
+ ksft_exit_fail_msg("Poll error\n");
} else if (ret == 0) {
- printf("Poll Timeout\n");
+ ksft_print_msg("Poll Timeout\n");
} else {
- if ((lseek(fd, 0L, SEEK_SET)) < 0) {
- fprintf(stderr, "Failed to set pointer to beginning\n");
- exit(1);
- }
+ if ((lseek(fd, 0L, SEEK_SET)) < 0)
+ ksft_exit_fail_msg("Failed to set pointer to beginning\n");

- if (read(fd, status_str, sizeof(status_str)) < 0)
- exit(0);
+ if (read(fd, status_str, sizeof(status_str)) < 0) {
+ ksft_test_result_pass("Successfully read\n");
+ ksft_finished();
+ }

- printf("power floor status: %s\n", status_str);
+ ksft_print_msg("power floor status: %s\n", status_str);
}

close(fd);
--
2.39.2