include Makefile.defs # If CFLAGS_CRAY is empty set it to CFLAGS ifeq ($(CFLAGS_CRAY),) CFLAGS_CRAY = ${CFLAGS} endif .c.o: ${CC} ${CFLAGS} $(OMPFLAG) -c $*.c SYNCOBJS = syncbench.o common.o SCHEDOBJS = schedbench.o common_sched.o ARRAYOBJS = arraybench_$(IDA).o common.o TASKOBJS = taskbench.o common.o SCHEDFLAGS = -DSCHEDBENCH all: syncbench schedbench taskbench prog: arraybench_$(IDA) # We need to generate a linker map file so that Xray can resolve function names LDFLAGS += -Wl,-Map=$@.map syncbench: $(SYNCOBJS) $(CC) -o syncbench $(SYNCOBJS) $(LDFLAGS) $(CLOCKOBJS) $(LIBS) -lm # Rule to ensure the lower optimisation level is picked up for common.c # with the Cray compiler common.o: ${CC} ${CFLAGS_CRAY} $(OMPFLAG) -c $*.c # Separate rule to build common_sched.o as we need to ensure the correct # DEFAULT_DELAY_TIME is used. common_sched.o: ${CC} ${CFLAGS_CRAY} $(SCHEDFLAGS) $(OMPFLAG) -o common_sched.o -c common.c schedbench: $(SCHEDOBJS) $(CC) -o schedbench $(SCHEDOBJS) $(LDFLAGS) $(CLOCKOBJS) $(LIBS) -lm # Multiple header files due to multiple array sizes, makes header file arraybench_*.h arraybench_$(IDA).h: arraybench.h $(CPP) -DIDA=$(IDA) $(OMPFLAG) -P arraybench.h -o $@ # Multiple object files due to multiple array sizes, makes object file arraybench_*.o arraybench_$(IDA).o: arraybench_$(IDA).h arraybench.c $(CC) $(CFLAGS) -DIDA=$(IDA) $(OMPFLAG) arraybench.c -c -o $@ # Multiple executables due to multiple array sizes, makes exe file arraybench_* arraybench_$(IDA): $(ARRAYOBJS) $(CLOCKOBJS) arraybench.c $(CC) -o $@ $(LDFLAGS) $(ARRAYOBJS) $(CLOCKOBJS) $(LIBS) -lm taskbench: $(TASKOBJS) $(CC) -o taskbench $(TASKOBJS) $(LDFLAGS) $(OMPFLAG) $(CLOCKOBJS) $(LIBS) -lm clean: -rm -rf *.o *.xray *.map syncbench schedbench arraybench_* taskbench veryclean: clean -rm -rf OpenMPBench.* *.all