summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff McGee <jeff.mcgee@intel.com>2014-01-10 15:12:30 -0600
committerDaniel Vetter <daniel.vetter@ffwll.ch>2014-01-10 22:31:51 +0100
commit265efbb2c4401542c8753e0d83d7a98493720865 (patch)
tree406e404bfea50a6c86f364159d95d52cc5f17f72
parent45d63644d28c34202a97bd812f6c46c853e97d28 (diff)
pm_rps: Use unbuffered I/O on sysfs files
Bionic C library may not re-read a buffered, read-only file which results in failure to monitor changes in gt_cur_freq_mhz. Signed-off-by: Jeff McGee <jeff.mcgee@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
-rw-r--r--tests/pm_rps.c7
1 files changed, 2 insertions, 5 deletions
diff --git a/tests/pm_rps.c b/tests/pm_rps.c
index e8affdbc..91234515 100644
--- a/tests/pm_rps.c
+++ b/tests/pm_rps.c
@@ -22,6 +22,7 @@
*
* Authors:
* Ben Widawsky <ben@bwidawsk.net>
+ * Jeff McGee <jeff.mcgee@intel.com>
*
*/
@@ -66,7 +67,6 @@ static int readval(FILE *filp)
int val;
int scanned;
- fflush(filp);
rewind(filp);
scanned = fscanf(filp, "%d", &val);
igt_assert(scanned == 1);
@@ -76,15 +76,11 @@ static int readval(FILE *filp)
static int do_writeval(FILE *filp, int val, int lerrno)
{
- /* Must write twice to sysfs since the first one simply calculates the size and won't return the error */
int ret;
rewind(filp);
ret = fprintf(filp, "%d", val);
- rewind(filp);
- ret = fprintf(filp, "%d", val);
if (ret && lerrno)
igt_assert(errno = lerrno);
- fflush(filp);
return ret;
}
#define writeval(filp, val) do_writeval(filp, val, 0)
@@ -146,6 +142,7 @@ igt_simple_main
igt_assert(ret != -1);
junk->filp = fopen(path, junk->mode);
igt_require(junk->filp);
+ setbuf(junk->filp, NULL);
val = readval(junk->filp);
igt_assert(val >= 0);