-
Notifications
You must be signed in to change notification settings - Fork 56
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Adding tests for the lmsensors component.
- Loading branch information
Treece Burgess
committed
Dec 13, 2024
1 parent
bd543fc
commit a9e5c1b
Showing
3 changed files
with
241 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
NAME=lmsensors | ||
include ../../Makefile_comp_tests.target | ||
|
||
TESTS = lmsensors_list_events \ | ||
lmsensors_read | ||
|
||
lmsensors_tests: $(TESTS) | ||
|
||
%.o:%.c | ||
$(CC) $(CFLAGS) $(OPTFLAGS) $(INCLUDE) -c -o $@ $< | ||
|
||
lmsensors_list_events: lmsensors_list_events.o $(UTILOBJS) $(PAPILIB) | ||
$(CC) $(CFLAGS) $(INCLUDE) -o $@ lmsensors_list_events.o $(UTILOBJS) $(PAPILIB) $(LDFLAGS) | ||
|
||
lmsensors_read: lmsensors_read.o $(UTILOBJS) $(PAPILIB) | ||
$(CC) $(CFLAGS) $(INCLUDE) -o $@ lmsensors_read.o $(UTILOBJS) $(PAPILIB) $(LDFLAGS) | ||
|
||
clean: | ||
rm -f $(TESTS) *.o |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
/****************************/ | ||
/* THIS IS OPEN SOURCE CODE */ | ||
/****************************/ | ||
|
||
/** | ||
* @author Treece Burgess (tburgess@icl.utk.edu) | ||
* | ||
* Test case for the lmsensors component. | ||
* For GitHub CI and terminal use. | ||
* | ||
* Tested on Leconte at ICL in winter 2024 with an | ||
* Intel(R) Xeon(R) CPU E5-2698. | ||
* | ||
* @brief | ||
* List the event code and event name for all | ||
* available lmsensor events on the current | ||
* machine. | ||
*/ | ||
|
||
#include <stdio.h> | ||
|
||
#include "papi.h" | ||
#include "papi_test.h" | ||
|
||
int main(int argc, char **argv) | ||
{ | ||
int retval, event_cnt = 0, EventCode, cidx; | ||
char EventName[PAPI_2MAX_STR_LEN]; | ||
|
||
/* determine if we quiet output */ | ||
tests_quiet(argc, argv); | ||
|
||
/* initialize the PAPI library */ | ||
retval = PAPI_library_init(PAPI_VER_CURRENT); | ||
if (retval != PAPI_VER_CURRENT) { | ||
test_fail(__FILE__, __LINE__, "PAPI_library_init", retval); | ||
} | ||
|
||
/* get the lmsensors component index */ | ||
cidx = PAPI_get_component_index("lmsensors"); | ||
if (cidx < 0) { | ||
test_fail(__FILE__, __LINE__, "PAPI_get_component_index failed for lmsensors", cidx); | ||
} | ||
|
||
if (!TESTS_QUIET) { | ||
printf("Component index for lmsensors: %d\n", cidx); | ||
} | ||
|
||
int modifier = PAPI_ENUM_FIRST; | ||
EventCode = PAPI_NATIVE_MASK; | ||
retval = PAPI_enum_cmp_event(&EventCode, modifier, cidx); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_enum_cmp_event", retval); | ||
} | ||
|
||
/* enumerate through all lmsensor events found on the current machine */ | ||
modifier = PAPI_ENUM_EVENTS; | ||
do { | ||
/* print output header */ | ||
if (event_cnt == 0 && !TESTS_QUIET) { | ||
printf("%s %s", "Event code", "Event name\n"); | ||
} | ||
|
||
retval = PAPI_event_code_to_name(EventCode, EventName); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_event_code_to_name", retval); | ||
} | ||
|
||
if (!TESTS_QUIET) { | ||
printf("%d %s\n", EventCode, EventName); | ||
} | ||
|
||
/* increment lmsensors event count */ | ||
event_cnt++; | ||
} while(PAPI_enum_cmp_event(&EventCode, modifier, cidx) == PAPI_OK); | ||
|
||
if (!TESTS_QUIET) { | ||
printf("Total number of events for lmsensor: %d\n", event_cnt); | ||
} | ||
|
||
PAPI_shutdown(); | ||
|
||
/* if we make it here everything ran succesfully */ | ||
test_pass(__FILE__); | ||
|
||
return PAPI_OK; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,135 @@ | ||
/****************************/ | ||
/* THIS IS OPEN SOURCE CODE */ | ||
/****************************/ | ||
|
||
/** | ||
* @author Treece Burgess (tburgess@icl.utk.edu) | ||
* | ||
* Test case for the lmsensors component. | ||
* For GitHub CI and terminal use. | ||
* | ||
* Tested on Leconte at ICL in winter 2024 with an | ||
* Intel(R) Xeon(R) CPU E5-2698. | ||
* | ||
* @brief | ||
* Creating a PAPI EventSet with lmsensor events | ||
* to add, start, read, and stop. | ||
*/ | ||
|
||
#include <stdio.h> | ||
#include <string.h> | ||
|
||
#include "papi.h" | ||
#include "papi_test.h" | ||
|
||
/* number of events we want to add to the PAPI */ | ||
#define NUM_EVENTS 3 | ||
|
||
int main(int argc, char **argv) | ||
{ | ||
int retval, i, event_cnt = 0, cidx; | ||
int EventCode, EventSet = PAPI_NULL; | ||
long long values[NUM_EVENTS]; | ||
char EventName[PAPI_MAX_STR_LEN], lm_events[NUM_EVENTS][PAPI_MAX_STR_LEN]; | ||
|
||
/* determine if we quiet output */ | ||
tests_quiet(argc, argv); | ||
|
||
/* initialize the PAPI library */ | ||
retval = PAPI_library_init(PAPI_VER_CURRENT); | ||
if (retval != PAPI_VER_CURRENT) { | ||
test_fail(__FILE__, __LINE__, "PAPI_library_init", retval); | ||
} | ||
|
||
/* get the lmsensors component index */ | ||
cidx = PAPI_get_component_index("lmsensors"); | ||
if (cidx < 0) { | ||
test_fail(__FILE__, __LINE__, "PAPI_get_component_index, failed for lmsensors", cidx); | ||
} | ||
|
||
if (!TESTS_QUIET) { | ||
printf("Component index for lmsensors: %d\n", cidx); | ||
} | ||
|
||
/* create a PAPI eventset */ | ||
retval = PAPI_create_eventset(&EventSet); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_create_eventset", retval); | ||
} | ||
|
||
int modifier = PAPI_ENUM_FIRST; | ||
EventCode = PAPI_NATIVE_MASK; | ||
retval = PAPI_enum_cmp_event(&EventCode, modifier, cidx); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_enum_cmp_event", retval); | ||
} | ||
|
||
/* enumerate UNITL we find 3 Core and max temp events */ | ||
modifier = PAPI_ENUM_EVENTS; | ||
do { | ||
retval = PAPI_event_code_to_name(EventCode, EventName); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_event_code_to_name", retval); | ||
} | ||
|
||
/* filter for only core and max temp events, max of three events to be added */ | ||
if (strstr(EventName, "Core") && strstr(EventName, "max")) { | ||
retval = PAPI_add_named_event(EventSet, EventName); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_add_named_event", retval); | ||
} | ||
|
||
if (!TESTS_QUIET) { | ||
printf("Successfully added %s to the EventSet.\n", EventName); | ||
} | ||
|
||
/* store current event name and increment count */ | ||
strncpy(lm_events[event_cnt], EventName, PAPI_MAX_STR_LEN); | ||
event_cnt++; | ||
} | ||
} while( ( PAPI_enum_cmp_event(&EventCode, modifier, cidx) == PAPI_OK ) && ( event_cnt < NUM_EVENTS ) ); | ||
|
||
/* start counting */ | ||
retval = PAPI_start(EventSet); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_start", retval); | ||
} | ||
|
||
/* read temp values */ | ||
retval = PAPI_read(EventSet, values); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_read", retval); | ||
} | ||
|
||
/* stop counting and ignore values */ | ||
retval = PAPI_stop(EventSet, NULL); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_stop", retval); | ||
} | ||
|
||
/* print out temp values for each event */ | ||
if (!TESTS_QUIET) { | ||
printf("Max temp output for events:\n"); | ||
for (i = 0; i < NUM_EVENTS; i++) { | ||
printf("%s: %d\n", lm_events[i], values[i]); | ||
} | ||
} | ||
|
||
/* cleanup for PAPI */ | ||
retval = PAPI_cleanup_eventset(EventSet); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_cleanup_eventset", retval); | ||
} | ||
|
||
retval = PAPI_destroy_eventset(&EventSet); | ||
if (retval != PAPI_OK) { | ||
test_fail(__FILE__, __LINE__, "PAPI_destory_eventset", retval); | ||
} | ||
|
||
PAPI_shutdown(); | ||
|
||
/* if we make it here everything ran succesfully */ | ||
test_pass(__FILE__); | ||
|
||
return PAPI_OK; | ||
} |