Commit 90a009db authored by Ilpo Järvinen's avatar Ilpo Järvinen Committed by Shuah Khan

selftests/resctrl: Replace file write with volatile variable

The fill_buf code prevents compiler optimizating the entire read loop
away by writing the final value of the variable into a file. While it
achieves the goal, writing into a file requires significant amount of
work within the innermost test loop and also error handling.

A simpler approach is to take advantage of volatile. Writing through
a pointer to a volatile variable is enough to prevent compiler from
optimizing the write away, and therefore compiler cannot remove the
read loop either.

Add a volatile 'value_sink' into resctrl_tests.c and make fill_buf to
write into it. As a result, the error handling in fill_buf.c can be
simplified.
Signed-off-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Reviewed-by: default avatarReinette Chatre <reinette.chatre@intel.com>
Signed-off-by: default avatarShuah Khan <skhan@linuxfoundation.org>
parent 2892731e
...@@ -78,10 +78,9 @@ static void fill_one_span_write(unsigned char *buf, size_t buf_size) ...@@ -78,10 +78,9 @@ static void fill_one_span_write(unsigned char *buf, size_t buf_size)
} }
} }
static int fill_cache_read(unsigned char *buf, size_t buf_size, bool once) static void fill_cache_read(unsigned char *buf, size_t buf_size, bool once)
{ {
int ret = 0; int ret = 0;
FILE *fp;
while (1) { while (1) {
ret = fill_one_span_read(buf, buf_size); ret = fill_one_span_read(buf, buf_size);
...@@ -90,26 +89,16 @@ static int fill_cache_read(unsigned char *buf, size_t buf_size, bool once) ...@@ -90,26 +89,16 @@ static int fill_cache_read(unsigned char *buf, size_t buf_size, bool once)
} }
/* Consume read result so that reading memory is not optimized out. */ /* Consume read result so that reading memory is not optimized out. */
fp = fopen("/dev/null", "w"); *value_sink = ret;
if (!fp) {
ksft_perror("Unable to write to /dev/null");
return -1;
}
fprintf(fp, "Sum: %d ", ret);
fclose(fp);
return 0;
} }
static int fill_cache_write(unsigned char *buf, size_t buf_size, bool once) static void fill_cache_write(unsigned char *buf, size_t buf_size, bool once)
{ {
while (1) { while (1) {
fill_one_span_write(buf, buf_size); fill_one_span_write(buf, buf_size);
if (once) if (once)
break; break;
} }
return 0;
} }
static unsigned char *alloc_buffer(size_t buf_size, int memflush) static unsigned char *alloc_buffer(size_t buf_size, int memflush)
...@@ -143,21 +132,16 @@ static unsigned char *alloc_buffer(size_t buf_size, int memflush) ...@@ -143,21 +132,16 @@ static unsigned char *alloc_buffer(size_t buf_size, int memflush)
int run_fill_buf(size_t buf_size, int memflush, int op, bool once) int run_fill_buf(size_t buf_size, int memflush, int op, bool once)
{ {
unsigned char *buf; unsigned char *buf;
int ret;
buf = alloc_buffer(buf_size, memflush); buf = alloc_buffer(buf_size, memflush);
if (!buf) if (!buf)
return -1; return -1;
if (op == 0) if (op == 0)
ret = fill_cache_read(buf, buf_size, once); fill_cache_read(buf, buf_size, once);
else else
ret = fill_cache_write(buf, buf_size, once); fill_cache_write(buf, buf_size, once);
free(buf); free(buf);
if (ret) {
printf("\n Error in fill cache\n");
return -1;
}
return 0; return 0;
} }
...@@ -78,6 +78,13 @@ struct perf_event_read { ...@@ -78,6 +78,13 @@ struct perf_event_read {
#define CMT_STR "cmt" #define CMT_STR "cmt"
#define CAT_STR "cat" #define CAT_STR "cat"
/*
* Memory location that consumes values compiler must not optimize away.
* Volatile ensures writes to this location cannot be optimized away by
* compiler.
*/
extern volatile int *value_sink;
extern pid_t bm_pid, ppid; extern pid_t bm_pid, ppid;
extern char llc_occup_path[1024]; extern char llc_occup_path[1024];
......
...@@ -10,6 +10,10 @@ ...@@ -10,6 +10,10 @@
*/ */
#include "resctrl.h" #include "resctrl.h"
/* Volatile memory sink to prevent compiler optimizations */
static volatile int sink_target;
volatile int *value_sink = &sink_target;
static int detect_vendor(void) static int detect_vendor(void)
{ {
FILE *inf = fopen("/proc/cpuinfo", "r"); FILE *inf = fopen("/proc/cpuinfo", "r");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment