diff options
Diffstat (limited to 'SCAN-SSA')
-rw-r--r-- | SCAN-SSA/Makefile | 4 | ||||
-rw-r--r-- | SCAN-SSA/host/app.c | 2 | ||||
-rw-r--r-- | SCAN-SSA/support/params.h | 6 |
3 files changed, 8 insertions, 4 deletions
diff --git a/SCAN-SSA/Makefile b/SCAN-SSA/Makefile index 1ac9ecc..319f2da 100644 --- a/SCAN-SSA/Makefile +++ b/SCAN-SSA/Makefile @@ -25,10 +25,10 @@ all: bin/dpu_code bin/host_code bin: ${QUIET}mkdir -p bin -bin/dpu_code: ${DPU_SOURCES} +bin/dpu_code: ${DPU_SOURCES} bin ${QUIET}dpu-upmem-dpurte-clang ${DPU_FLAGS} ${DPU_SOURCES} -o $@ -bin/host_code: ${HOST_SOURCES} +bin/host_code: ${HOST_SOURCES} bin ${QUIET}${CC} ${HOST_FLAGS} ${HOST_SOURCES} -o $@ bin/omp_code: ${OMP_SOURCES} diff --git a/SCAN-SSA/host/app.c b/SCAN-SSA/host/app.c index 8354245..ba6b5e9 100644 --- a/SCAN-SSA/host/app.c +++ b/SCAN-SSA/host/app.c @@ -89,7 +89,7 @@ int main(int argc, char **argv) { unsigned int i = 0; T accum = 0; - const unsigned int input_size = p.input_size * nr_of_dpus; // Total input size (weak or strong scaling) + const unsigned int input_size = p.exp == 0 ? p.input_size * nr_of_dpus : p.input_size; // Total input size (weak or strong scaling) const unsigned int input_size_dpu_ = divceil(input_size, nr_of_dpus); // Input size per DPU (max.) const unsigned int input_size_dpu_round = (input_size_dpu_ % (NR_TASKLETS * REGS) != 0) ? roundup(input_size_dpu_, (NR_TASKLETS * REGS)) : input_size_dpu_; // Input size per DPU (max.), 8-byte aligned diff --git a/SCAN-SSA/support/params.h b/SCAN-SSA/support/params.h index 8d51c98..9f6aacc 100644 --- a/SCAN-SSA/support/params.h +++ b/SCAN-SSA/support/params.h @@ -7,6 +7,7 @@ typedef struct Params { unsigned int input_size; int n_warmup; int n_reps; + int exp; }Params; static void usage() { @@ -17,6 +18,7 @@ static void usage() { "\n -h help" "\n -w <W> # of untimed warmup iterations (default=1)" "\n -e <E> # of timed repetition iterations (default=3)" + "\n -x <X> Weak (0) or strong (1) scaling (default=0)" "\n" "\nBenchmark-specific options:" "\n -i <I> input size (default=3932160 elements)" @@ -28,9 +30,10 @@ struct Params input_params(int argc, char **argv) { p.input_size = 3932160; p.n_warmup = 1; p.n_reps = 3; + p.exp = 0; int opt; - while((opt = getopt(argc, argv, "hi:w:e:")) >= 0) { + while((opt = getopt(argc, argv, "hi:w:e:x:")) >= 0) { switch(opt) { case 'h': usage(); @@ -39,6 +42,7 @@ struct Params input_params(int argc, char **argv) { case 'i': p.input_size = atoi(optarg); break; case 'w': p.n_warmup = atoi(optarg); break; case 'e': p.n_reps = atoi(optarg); break; + case 'x': p.exp = atoi(optarg); break; default: fprintf(stderr, "\nUnrecognized option!\n"); usage(); |