1 # The toolchain definitions
7 V = @ # Verbose build: make V=1
8 C = 0 # Sparsechecker build: make C=1
10 QUIET_CC = $(Q:@=@echo ' CC '$@;)$(CC)
11 QUIET_DEPEND = $(Q:@=@echo ' DEPEND '$@;)$(CC)
12 QUIET_LEX = $(Q:@=@echo ' LEX '$@;)$(LEX)
13 QUIET_YACC = $(Q:@=@echo ' YACC '$@;)$(YACC)
15 QUIET_SPARSE = $(Q:@=@echo ' SPARSE '$@;)$(SPARSE)
17 QUIET_SPARSE = @/bin/true
21 CFLAGS ?= -O2 -fomit-frame-pointer -D_BSD_SOURCE -D_GNU_SOURCE
22 CFLAGS += -std=c99 -Wall -D_BSD_SOURCE -D_GNU_SOURCE
23 SPARSEFLAGS = $(CFLAGS) -D__transparent_union__=__unused__ -D_STRING_ARCH_unaligned=1 \
24 -D__builtin_stpcpy=stpcpy
28 SRCS = parser.c scanner.c main.c initvals.c util.c args.c
31 CFLAGS += -DYYSTYPE="void *" -DYYERROR_VERBOSE -DYYDEBUG -DYYENABLE_NLS=0 -DYYLTYPE_IS_TRIVIAL=0 -Wno-unused
34 .PHONY: all install clean distclean
37 DEPS = $(sort $(patsubst %.c,dep/%.d,$(1)))
38 OBJS = $(sort $(patsubst %.c,obj/%.o,$(1)))
40 # Generate dependencies
41 $(call DEPS,$(SRCS)): dep/%.d: %.c
43 $(QUIET_DEPEND) -o $@.tmp -MM -MT "$@ $(patsubst dep/%.d,obj/%.o,$@)" $(CFLAGS) $< && mv -f $@.tmp $@
45 -include $(call DEPS,$(SRCS))
47 # Generate object files
48 $(call OBJS,$(SRCS)): obj/%.o:
50 $(QUIET_SPARSE) $(SPARSEFLAGS) $<
51 $(QUIET_CC) -o $@ -c $(CFLAGS) $<
55 scanner.c: scanner.l parser.c main.h
56 $(QUIET_LEX) -o scanner.c --header-file=scanner.h scanner.l
59 $(QUIET_CC) $(CFLAGS) -c -o scanner.o scanner.c
61 parser.c: parser.y main.h util.h
62 $(QUIET_YACC) --defines -o parser.c parser.y
65 $(QUIET_CC) $(CFLAGS) -c -o parser.o parser.c
67 $(BIN): $(call OBJS,$(SRCS))
68 $(QUIET_CC) $(CFLAGS) -o $(BIN) $(call OBJS,$(SRCS)) $(LDFLAGS)
71 install -o 0 -g 0 -m 755 $(BIN) $(PREFIX)/bin/
72 cp b43-asm b43-asm.inst
73 sed -i -e 's/installed=0/installed=1/' b43-asm.inst
74 install -o 0 -g 0 -m 755 b43-asm.inst $(PREFIX)/bin/b43-asm
78 -rm -Rf dep obj *~ *.orig *.rej scanner.c scanner.h parser.c parser.h