summaryrefslogtreecommitdiff
path: root/SCAN-SSA
diff options
context:
space:
mode:
Diffstat (limited to 'SCAN-SSA')
-rw-r--r--SCAN-SSA/Makefile4
-rw-r--r--SCAN-SSA/host/app.c2
-rw-r--r--SCAN-SSA/support/params.h6
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();