Setting up repository
[linux-libre-firmware.git] / b43-tools / assembler / Makefile
1 # The toolchain definitions
2 CC              = gcc
3 LEX             = flex
4 YACC            = bison
5 SPARSE          = sparse
6
7 V               = @             # Verbose build:  make V=1
8 C               = 0             # Sparsechecker build:  make C=1
9 Q               = $(V: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)
14 ifeq ($(C),1)
15 QUIET_SPARSE    = $(Q:@=@echo '     SPARSE   '$@;)$(SPARSE)
16 else
17 QUIET_SPARSE    = @/bin/true
18 endif
19
20 PREFIX          ?= /usr/local
21 CFLAGS          ?= -O2 -fomit-frame-pointer -pipe
22 CFLAGS          += -std=gnu99 -D_GNU_SOURCE \
23                    -Wall -Wextra -Wformat=2 -Wundef -Wno-unused-parameter \
24                    -Wshadow -Wpointer-arith
25 SPARSEFLAGS     = $(CFLAGS) -D__transparent_union__=__unused__ -D_STRING_ARCH_unaligned=1 \
26                   -D__builtin_stpcpy=stpcpy
27 LDFLAGS         += -lfl
28
29 BIN             = b43-asm.bin
30 SRCS            = parser.c scanner.c main.c initvals.c util.c args.c
31
32 # YACC related CFLAGS
33 CFLAGS          += -DYYSTYPE="void *" -DYYERROR_VERBOSE -DYYDEBUG=1 -DYYENABLE_NLS=0 -DYYLTYPE_IS_TRIVIAL=0 -Wno-unused
34
35 .SUFFIXES:
36 .PHONY: all install clean distclean
37 .DEFAULT_GOAL := all
38
39 DEPS = $(sort $(patsubst %.c,dep/%.d,$(1)))
40 OBJS = $(sort $(patsubst %.c,obj/%.o,$(1)))
41
42 # Generate dependencies
43 $(call DEPS,$(SRCS)): dep/%.d: %.c 
44         @mkdir -p $(dir $@)
45         $(QUIET_DEPEND) -o $@.tmp -MM -MG -MT "$@ $(patsubst dep/%.d,obj/%.o,$@)" $(CFLAGS) $< && mv -f $@.tmp $@
46
47 -include $(call DEPS,$(SRCS))
48
49 # Generate object files
50 $(call OBJS,$(SRCS)): obj/%.o:
51         @mkdir -p $(dir $@)
52         $(QUIET_SPARSE) $(SPARSEFLAGS) $<
53         $(QUIET_CC) -o $@ -c $(CFLAGS) $<
54
55 all: $(BIN)
56
57 scanner.c: scanner.l parser.h main.h util.h
58         $(QUIET_LEX) -o scanner.c --header-file=scanner.h scanner.l
59
60 scanner.h: scanner.c
61
62 scanner.o: scanner.c
63         $(QUIET_CC) $(CFLAGS) -c -o scanner.o scanner.c
64
65 parser.c: parser.y main.h util.h
66         $(QUIET_YACC) --defines -o parser.c parser.y
67
68 parser.h: parser.c
69
70 parser.o: parser.c
71         $(QUIET_CC) $(CFLAGS) -c -o parser.o parser.c
72
73 $(BIN): $(call OBJS,$(SRCS))
74         $(QUIET_CC) $(CFLAGS) -o $(BIN) $(call OBJS,$(SRCS)) $(LDFLAGS)
75
76 install: all
77         install -m 755 $(BIN) $(PREFIX)/bin/
78         cp b43-asm b43-asm.inst
79         sed -i -e 's/installed=0/installed=1/' b43-asm.inst
80         install -m 755 b43-asm.inst $(PREFIX)/bin/b43-asm
81         rm -f b43-asm.inst
82
83 clean:
84         -rm -Rf dep obj *~ *.orig *.rej scanner.c scanner.h parser.c parser.h
85
86 distclean: clean
87         -rm -f $(BIN)