diff options
author | Suren A. Chilingaryan <csa@dside.dyndns.org> | 2011-07-13 23:55:54 +0200 |
---|---|---|
committer | Suren A. Chilingaryan <csa@dside.dyndns.org> | 2011-07-13 23:55:54 +0200 |
commit | 72e8984e195ad5d57b0461b4e6e8f205315e9764 (patch) | |
tree | 1e62356cba5f50bbd028ad6ddcb0839530491370 /cli.c | |
parent | 146c9e6b93a37de51b1116d1bab59b909aa9eb8d (diff) | |
download | ipecamera-72e8984e195ad5d57b0461b4e6e8f205315e9764.tar.gz ipecamera-72e8984e195ad5d57b0461b4e6e8f205315e9764.tar.bz2 ipecamera-72e8984e195ad5d57b0461b4e6e8f205315e9764.tar.xz ipecamera-72e8984e195ad5d57b0461b4e6e8f205315e9764.zip |
Support iterations argument and fix interpretation of size argument for benchmarking
Diffstat (limited to 'cli.c')
-rw-r--r-- | cli.c | 20 |
1 files changed, 14 insertions, 6 deletions
@@ -85,6 +85,7 @@ typedef enum { OPT_START_DMA = 129, OPT_STOP_DMA = 130, OPT_WAIT_IRQ = 131, + OPT_ITERATIONS = 132, OPT_HELP = 'h', } OPTIONS; @@ -97,6 +98,7 @@ static struct option long_options[] = { {"size", required_argument, 0, OPT_SIZE }, {"output", required_argument, 0, OPT_OUTPUT }, {"timeout", required_argument, 0, OPT_TIMEOUT }, + {"iterations", required_argument, 0, OPT_ITERATIONS }, {"info", no_argument, 0, OPT_INFO }, {"list", no_argument, 0, OPT_LIST }, {"reset", no_argument, 0, OPT_RESET }, @@ -335,7 +337,7 @@ void Info(pcilib_t *handle, pcilib_model_description_t *model_info) { #define BENCH_MAX_DMA_SIZE 16 * 1024 * 1024 #define BENCH_MAX_FIFO_SIZE 1024 * 1024 -int Benchmark(pcilib_t *handle, ACCESS_MODE mode, pcilib_dma_engine_addr_t dma, pcilib_bar_t bar, uintptr_t addr, size_t n, access_t access) { +int Benchmark(pcilib_t *handle, ACCESS_MODE mode, pcilib_dma_engine_addr_t dma, pcilib_bar_t bar, uintptr_t addr, size_t n, access_t access, size_t iterations) { int err; int i, j, errors; void *data, *buf, *check; @@ -357,10 +359,10 @@ int Benchmark(pcilib_t *handle, ACCESS_MODE mode, pcilib_dma_engine_addr_t dma, max_size = BENCH_MAX_DMA_SIZE; } - for (size = min_size; size < min_size + 1/*max_size*/; size *= 4) { - mbs_in = -1;//pcilib_benchmark_dma(handle, dma, addr, size, BENCHMARK_ITERATIONS, PCILIB_DMA_FROM_DEVICE); - mbs_out = -1;//pcilib_benchmark_dma(handle, dma, addr, size, BENCHMARK_ITERATIONS, PCILIB_DMA_TO_DEVICE); - mbs = pcilib_benchmark_dma(handle, dma, addr, size, BENCHMARK_ITERATIONS, PCILIB_DMA_BIDIRECTIONAL); + for (size = min_size; size <= max_size; size *= 4) { + mbs_in = pcilib_benchmark_dma(handle, dma, addr, size, BENCHMARK_ITERATIONS, PCILIB_DMA_FROM_DEVICE); + mbs_out = pcilib_benchmark_dma(handle, dma, addr, size, BENCHMARK_ITERATIONS, PCILIB_DMA_TO_DEVICE); + mbs = pcilib_benchmark_dma(handle, dma, addr, size, iterations, PCILIB_DMA_BIDIRECTIONAL); err = pcilib_wait_irq(handle, 0, 0, &irqs); if (err) irqs = 0; @@ -981,6 +983,7 @@ int main(int argc, char **argv) { int endianess = 0; size_t timeout = 0; const char *output = NULL; + size_t iterations = BENCHMARK_ITERATIONS; pcilib_t *handle; @@ -1133,6 +1136,11 @@ int main(int argc, char **argv) { case OPT_OUTPUT: output = optarg; break; + case OPT_ITERATIONS: + if ((!isnumber(optarg))||(sscanf(optarg, "%zu", &iterations) != 1)) + Usage(argc, argv, "Invalid number of iterations is specified (%s)", optarg); + size_set = 1; + break; case OPT_QUIETE: quiete = 1; break; @@ -1281,7 +1289,7 @@ int main(int argc, char **argv) { List(handle, model_info, bank, details); break; case MODE_BENCHMARK: - Benchmark(handle, amode, dma, bar, start, size_set?size:0, access); + Benchmark(handle, amode, dma, bar, start, size_set?size:0, access, iterations); break; case MODE_READ: if (addr) { |