[app][tests] beef up the cache benchmark tests a little bit
This commit is contained in:
@@ -30,31 +30,43 @@
|
|||||||
#include <lib/console.h>
|
#include <lib/console.h>
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
|
|
||||||
static int cache_tests(int argc, const cmd_args *argv)
|
static void bench_cache(size_t bufsize)
|
||||||
{
|
{
|
||||||
lk_bigtime_t t;
|
lk_bigtime_t t;
|
||||||
|
|
||||||
printf("testing cache\n");
|
uint8_t *buf = memalign(PAGE_SIZE, bufsize);
|
||||||
|
printf("buf %p, size %zu\n", buf, bufsize);
|
||||||
|
|
||||||
#define BUFSIZE (256*1024)
|
if (!buf)
|
||||||
uint8_t *buf = memalign(PAGE_SIZE, BUFSIZE);
|
return;
|
||||||
printf("buf %p\n", buf);
|
|
||||||
|
|
||||||
t = current_time_hires();
|
t = current_time_hires();
|
||||||
arch_clean_cache_range((addr_t)buf, BUFSIZE);
|
arch_clean_cache_range((addr_t)buf, bufsize);
|
||||||
t = current_time_hires() - t;
|
t = current_time_hires() - t;
|
||||||
|
|
||||||
printf("took %llu usecs to clean %d bytes (cold)\n", t, BUFSIZE);
|
printf("took %llu usecs to clean %d bytes (cold)\n", t, bufsize);
|
||||||
|
|
||||||
memset(buf, 0x99, BUFSIZE);
|
memset(buf, 0x99, bufsize);
|
||||||
|
|
||||||
t = current_time_hires();
|
t = current_time_hires();
|
||||||
arch_clean_cache_range((addr_t)buf, BUFSIZE);
|
arch_clean_cache_range((addr_t)buf, bufsize);
|
||||||
t = current_time_hires() - t;
|
t = current_time_hires() - t;
|
||||||
|
|
||||||
printf("took %llu usecs to clean %d bytes (hot)\n", t, BUFSIZE);
|
printf("took %llu usecs to clean %d bytes (hot)\n", t, bufsize);
|
||||||
|
|
||||||
free(buf);
|
free(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int cache_tests(int argc, const cmd_args *argv)
|
||||||
|
{
|
||||||
|
printf("testing cache\n");
|
||||||
|
|
||||||
|
bench_cache(2*1024);
|
||||||
|
bench_cache(64*1024);
|
||||||
|
bench_cache(256*1024);
|
||||||
|
bench_cache(1024*1024);
|
||||||
|
bench_cache(16*1024*1024);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user