diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2013-08-10 15:49:33 +0100 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2013-08-10 15:49:33 +0100 |
commit | 467796acc80ced3440740d267c2e2a4f246d4b8a (patch) | |
tree | 0a8515b387709e1a41d468d2b0a6407b559869e7 /tests/gem_pwrite_pread.c | |
parent | dbbf2e9b24d1488402269a803a230f341791d39a (diff) |
Expand gem_set_cacheing testing to handle the proposed DISPLAY domain
Diffstat (limited to 'tests/gem_pwrite_pread.c')
-rw-r--r-- | tests/gem_pwrite_pread.c | 161 |
1 files changed, 100 insertions, 61 deletions
diff --git a/tests/gem_pwrite_pread.c b/tests/gem_pwrite_pread.c index 09a1f005..1f9187fc 100644 --- a/tests/gem_pwrite_pread.c +++ b/tests/gem_pwrite_pread.c @@ -398,75 +398,114 @@ int main(int argc, char **argv) src = gem_create(fd, object_size); tmp = malloc(object_size); - gem_set_cacheing(fd, src, 0); - gem_set_cacheing(fd, dst, 0); - if (drmtest_run_subtest("uncached-copy-correctness")) - test_copy(fd, src, dst, tmp, object_size); - if (drmtest_run_subtest("uncached-copy-performance")) { - for (count = 1; count <= 1<<17; count <<= 1) { - struct timeval start, end; - - gettimeofday(&start, NULL); - copy(fd, src, dst, tmp, object_size, count); - gettimeofday(&end, NULL); - printf("Time to uncached copy %d bytes x %6d: %7.3fµs, %s\n", - object_size, count, - elapsed(&start, &end, count), - bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); - fflush(stdout); + if (gem_set_cacheing(fd, src, 0) == 0 && + gem_set_cacheing(fd, dst, 0) == 0) { + if (drmtest_run_subtest("uncached-copy-correctness")) + test_copy(fd, src, dst, tmp, object_size); + if (drmtest_run_subtest("uncached-copy-performance")) { + for (count = 1; count <= 1<<17; count <<= 1) { + struct timeval start, end; + + gettimeofday(&start, NULL); + copy(fd, src, dst, tmp, object_size, count); + gettimeofday(&end, NULL); + printf("Time to uncached copy %d bytes x %6d: %7.3fµs, %s\n", + object_size, count, + elapsed(&start, &end, count), + bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); + fflush(stdout); + } } - } - if (drmtest_run_subtest("uncached-pwrite-blt-gtt_mmap-correctness")) - test_as_gtt_mmap(fd, src, dst, object_size); - if (drmtest_run_subtest("uncached-pwrite-blt-gtt_mmap-performance")) { - for (count = 1; count <= 1<<17; count <<= 1) { - struct timeval start, end; - - gettimeofday(&start, NULL); - as_gtt_mmap(fd, src, dst, tmp, object_size, count); - gettimeofday(&end, NULL); - printf("** mmap uncached copy %d bytes x %6d: %7.3fµs, %s\n", - object_size, count, - elapsed(&start, &end, count), - bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); - fflush(stdout); + if (drmtest_run_subtest("uncached-pwrite-blt-gtt_mmap-correctness")) + test_as_gtt_mmap(fd, src, dst, object_size); + if (drmtest_run_subtest("uncached-pwrite-blt-gtt_mmap-performance")) { + for (count = 1; count <= 1<<17; count <<= 1) { + struct timeval start, end; + + gettimeofday(&start, NULL); + as_gtt_mmap(fd, src, dst, tmp, object_size, count); + gettimeofday(&end, NULL); + printf("** mmap uncached copy %d bytes x %6d: %7.3fµs, %s\n", + object_size, count, + elapsed(&start, &end, count), + bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); + fflush(stdout); + } } } - gem_set_cacheing(fd, src, 1); - gem_set_cacheing(fd, dst, 1); - if (drmtest_run_subtest("snooped-copy-correctness")) - test_copy(fd, src, dst, tmp, object_size); - if (drmtest_run_subtest("snooped-copy-performance")) { - for (count = 1; count <= 1<<17; count <<= 1) { - struct timeval start, end; - - gettimeofday(&start, NULL); - copy(fd, src, dst, tmp, object_size, count); - gettimeofday(&end, NULL); - printf("Time to snooped copy %d bytes x %6d: %7.3fµs, %s\n", - object_size, count, - elapsed(&start, &end, count), - bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); - fflush(stdout); + if (gem_set_cacheing(fd, src, 1) == 0 && + gem_set_cacheing(fd, dst, 1) == 0) { + if (drmtest_run_subtest("snooped-copy-correctness")) + test_copy(fd, src, dst, tmp, object_size); + if (drmtest_run_subtest("snooped-copy-performance")) { + for (count = 1; count <= 1<<17; count <<= 1) { + struct timeval start, end; + + gettimeofday(&start, NULL); + copy(fd, src, dst, tmp, object_size, count); + gettimeofday(&end, NULL); + printf("Time to snooped copy %d bytes x %6d: %7.3fµs, %s\n", + object_size, count, + elapsed(&start, &end, count), + bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); + fflush(stdout); + } + } + + if (drmtest_run_subtest("snooped-pwrite-blt-cpu_mmap-correctness")) + test_as_cpu_mmap(fd, src, dst, object_size); + if (drmtest_run_subtest("snooped-pwrite-blt-cpu_mmap-performance")) { + for (count = 1; count <= 1<<17; count <<= 1) { + struct timeval start, end; + + gettimeofday(&start, NULL); + as_cpu_mmap(fd, src, dst, tmp, object_size, count); + gettimeofday(&end, NULL); + printf("** mmap snooped copy %d bytes x %6d: %7.3fµs, %s\n", + object_size, count, + elapsed(&start, &end, count), + bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); + fflush(stdout); + } } } - if (drmtest_run_subtest("snooped-pwrite-blt-cpu_mmap-correctness")) - test_as_cpu_mmap(fd, src, dst, object_size); - if (drmtest_run_subtest("snooped-pwrite-blt-cpu_mmap-performance")) { - for (count = 1; count <= 1<<17; count <<= 1) { - struct timeval start, end; - - gettimeofday(&start, NULL); - as_cpu_mmap(fd, src, dst, tmp, object_size, count); - gettimeofday(&end, NULL); - printf("** mmap snooped copy %d bytes x %6d: %7.3fµs, %s\n", - object_size, count, - elapsed(&start, &end, count), - bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); - fflush(stdout); + if (gem_set_cacheing(fd, src, 2) == 0 && + gem_set_cacheing(fd, dst, 2) == 0) { + if (drmtest_run_subtest("display-copy-correctness")) + test_copy(fd, src, dst, tmp, object_size); + if (drmtest_run_subtest("display-copy-performance")) { + for (count = 1; count <= 1<<17; count <<= 1) { + struct timeval start, end; + + gettimeofday(&start, NULL); + copy(fd, src, dst, tmp, object_size, count); + gettimeofday(&end, NULL); + printf("Time to display copy %d bytes x %6d: %7.3fµs, %s\n", + object_size, count, + elapsed(&start, &end, count), + bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); + fflush(stdout); + } + } + + if (drmtest_run_subtest("display-pwrite-blt-gtt_mmap-correctness")) + test_as_gtt_mmap(fd, src, dst, object_size); + if (drmtest_run_subtest("display-pwrite-blt-gtt_mmap-performance")) { + for (count = 1; count <= 1<<17; count <<= 1) { + struct timeval start, end; + + gettimeofday(&start, NULL); + as_gtt_mmap(fd, src, dst, tmp, object_size, count); + gettimeofday(&end, NULL); + printf("** mmap display copy %d bytes x %6d: %7.3fµs, %s\n", + object_size, count, + elapsed(&start, &end, count), + bytes_per_sec((char *)buf, object_size/elapsed(&start, &end, count)*1e6)); + fflush(stdout); + } } } |