blob: b98c5c1056c380a10dddaa0c6b4a3e6c5d50796c [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001PROG= aicasm
2
3.SUFFIXES= .l .y .c .h
4
5CSRCS= aicasm.c aicasm_symbol.c
6YSRCS= aicasm_gram.y aicasm_macro_gram.y
7LSRCS= aicasm_scan.l aicasm_macro_scan.l
8
9GENHDRS= aicdb.h $(YSRCS:.y=.h)
10GENSRCS= $(YSRCS:.y=.c) $(LSRCS:.l=.c)
11
12SRCS= ${CSRCS} ${GENSRCS}
13LIBS= -ldb
14clean-files:= ${GENSRCS} ${GENHDRS} $(YSRCS:.y=.output) $(PROG)
15# Override default kernel CFLAGS. This is a userland app.
16AICASM_CFLAGS:= -I/usr/include -I.
Sam Ravnborgdba654d2006-07-08 00:27:49 +020017LEX= flex
18YACC= bison
Linus Torvalds1da177e2005-04-16 15:20:36 -070019YFLAGS= -d
20
21NOMAN= noman
22
23ifneq ($(HOSTCC),)
24AICASM_CC= $(HOSTCC)
25else
26AICASM_CC= $(CC)
27endif
28
29ifdef DEBUG
30CFLAGS+= -DDEBUG -g
31YFLAGS+= -t -v
32LFLAGS= -d
33endif
34
35$(PROG): ${GENHDRS} $(SRCS)
36 $(AICASM_CC) $(AICASM_CFLAGS) $(SRCS) -o $(PROG) $(LIBS)
37
38aicdb.h:
39 @if [ -e "/usr/include/db4/db_185.h" ]; then \
40 echo "#include <db4/db_185.h>" > aicdb.h; \
41 elif [ -e "/usr/include/db3/db_185.h" ]; then \
42 echo "#include <db3/db_185.h>" > aicdb.h; \
43 elif [ -e "/usr/include/db2/db_185.h" ]; then \
44 echo "#include <db2/db_185.h>" > aicdb.h; \
45 elif [ -e "/usr/include/db1/db_185.h" ]; then \
46 echo "#include <db1/db_185.h>" > aicdb.h; \
47 elif [ -e "/usr/include/db/db_185.h" ]; then \
48 echo "#include <db/db_185.h>" > aicdb.h; \
49 elif [ -e "/usr/include/db_185.h" ]; then \
50 echo "#include <db_185.h>" > aicdb.h; \
51 else \
52 echo "*** Install db development libraries"; \
53 fi
54
55clean:
56 rm -f $(clean-files)
57
58# Create a dependency chain in generated files
59# to avoid concurrent invocations of the single
60# rule that builds them all.
61aicasm_gram.c: aicasm_gram.h
62aicasm_gram.c aicasm_gram.h: aicasm_gram.y
63 $(YACC) $(YFLAGS) -b $(<:.y=) $<
64 mv $(<:.y=).tab.c $(<:.y=.c)
65 mv $(<:.y=).tab.h $(<:.y=.h)
66
67# Create a dependency chain in generated files
68# to avoid concurrent invocations of the single
69# rule that builds them all.
70aicasm_macro_gram.c: aicasm_macro_gram.h
71aicasm_macro_gram.c aicasm_macro_gram.h: aicasm_macro_gram.y
72 $(YACC) $(YFLAGS) -b $(<:.y=) -p mm $<
73 mv $(<:.y=).tab.c $(<:.y=.c)
74 mv $(<:.y=).tab.h $(<:.y=.h)
75
76aicasm_scan.c: aicasm_scan.l
77 $(LEX) $(LFLAGS) -o$@ $<
78
79aicasm_macro_scan.c: aicasm_macro_scan.l
80 $(LEX) $(LFLAGS) -Pmm -o$@ $<