aboutsummaryrefslogtreecommitdiffstats
path: root/test/mppa/mmult/Makefile
blob: 23b31d4918f72d2e2ddc081e62daf3fc7a30ada0 (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
72
73
74
75
76
77
78
PRNG=../lib/prng.c
CCOMP=../../../ccomp

ALL= mmult-test-x86 mmult-test-k1c\

all: $(ALL)

%-test-x86: %.c $(PRNG)
	gcc -D__UNIT_TEST_$$(echo $(basename $<) | tr a-z A-Z)__ -O2 -std=c99 $^ -o $@

%-test-k1c: %.c $(PRNG)
	k1-gcc -D__UNIT_TEST_$$(echo $(basename $<) | tr a-z A-Z)__ -O2 -std=c99 $^ -o $@

test-x86: mmult.c $(PRNG)
	gcc -O2 -std=c99 $^ -o $@

test-k1c: mmult.c $(PRNG)
	k1-gcc -O2 -std=c99 $^ -o $@

%.s: %.c $(CCOMP)
	ccomp -O2 -S $< -o $@

test-ccomp: mmult.s $(subst .c,.s,$(PRNG))
	k1-gcc $^ -o $@

.PHONY:
unittest: unittest-x86 unittest-k1c

.PHONY:
check: check-x86 check-k1c

.PHONY:
compc-check: test-ccomp
	@if ! k1-cluster -- ./$<; then\
		>&2 echo "ERROR k1c: mmult $< failed";\
	else\
		echo "k1c: Test mmult $< succeeded";\
	fi

.PHONY:
check-x86: test-x86
	@if ! ./$<; then\
		>&2 echo "ERROR x86: $< failed";\
	else\
		echo "x86: Test $< succeeded";\
	fi

.PHONY:
check-k1c: test-k1c
	@if ! k1-cluster -- ./$<; then\
		>&2 echo "ERROR k1c: $< failed";\
	else\
		echo "k1c: Test $< succeeded";\
	fi

.PHONY:
unittest-x86: mmult-test-x86
	@for test in $^; do\
		if ! ./$$test; then\
			>&2 echo "ERROR x86: $$test failed";\
		else\
			echo "x86: Test $$test Succeeded";\
		fi;\
	done

.PHONY:
unittest-k1c: mmult-test-k1c
	@for test in $^; do\
		if ! k1-cluster -- ./$$test; then\
			>&2 echo "ERROR k1c: $$test failed";\
		else\
			echo "k1c: Test $$test Succeeded";\
		fi;\
	done

.PHONY:
clean:
	rm -f $(ALL)