aboutsummaryrefslogtreecommitdiffstats
path: root/test/kvx/mmult/Makefile
blob: 252f891149e25e90cde88d5fa60adf07b478c08d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
KVXC ?= kvx-elf-gcc
CC ?= gcc
CCOMP ?= ccomp
CFLAGS ?= -O2
SIMU ?= kvx-mppa
TIMEOUT ?= 10s

KVXCPATH=$(shell which $(KVXC))
CCPATH=$(shell which $(CC))
CCOMPPATH=$(shell which $(CCOMP))
SIMUPATH=$(shell which $(SIMU))

PRNG=../prng/prng.c

ALL= mmult-test-gcc-x86 mmult-test-gcc-kvx mmult-test-ccomp-kvx
CCOMP_OUT= mmult-test-ccomp-kvx.out
GCC_OUT= mmult-test-gcc-kvx.out
X86_GCC_OUT= mmult-test-gcc-x86.out
STUB_OUT=.zero

all: $(ALL)

mmult-test-gcc-x86: mmult.c $(PRNG) $(CCPATH)
	$(CC) $(CFLAGS) $(filter-out $(CCPATH),$^) -o $@

mmult-test-gcc-kvx: mmult.c $(PRNG) $(KVXCPATH)
	$(KVXC) $(CFLAGS) $(filter-out $(KVXCPATH),$^) -o $@

mmult-test-ccomp-kvx: mmult.c $(PRNG) $(CCOMPPATH)
	$(CCOMP) $(CFLAGS) $(filter-out $(CCOMPPATH),$^) -o $@

.SECONDARY:
%kvx.out: %kvx $(SIMUPATH)
	ret=0; timeout $(TIMEOUT) $(SIMU) -- $< > $@ || { ret=$$?; }; echo $$ret >> $@

%x86.out: %x86
	ret=0; timeout $(TIMEOUT) ./$< > $@ || { ret=$$?; }; echo $$ret >> $@

.zero:
	@echo "0" > $@

.PHONY:
test: test-x86 test-kvx

.PHONY:
test-x86: $(X86_GCC_OUT) $(STUB_OUT)
	@if ! diff $< $(STUB_OUT); then\
		>&2 echo "ERROR x86: $< failed";\
	else\
		echo "GOOD x86: $< succeeded";\
	fi

.PHONY:
test-kvx: $(GCC_OUT) $(STUB_OUT)
	@if ! diff $< $(STUB_OUT); then\
		>&2 echo "ERROR kvx: $< failed";\
	else\
		echo "GOOD kvx: $< succeeded";\
	fi

.PHONY:
check: $(CCOMP_OUT) $(STUB_OUT)
	@if ! diff $< $(STUB_OUT); then\
		>&2 echo "ERROR kvx: $< failed";\
	else\
		echo "GOOD kvx: $< succeeded";\
	fi

.PHONY:
clean:
	rm -f *.out mmult-test-ccomp-kvx mmult-test-gcc-kvx mmult-test-gcc-x86