blob: 21f70eb41dfe53226ef449adb635cbd2ee45fab1 (
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
|
# The toolchain definitions
CC = cc
SPARSE = sparse
V = @ # Verbose build: make V=1
C = 0 # Sparsechecker build: make C=1
Q = $(V:1=)
QUIET_CC = $(Q:@=@echo ' CC '$@;)$(CC)
QUIET_DEPEND = $(Q:@=@echo ' DEPEND '$@;)$(CC)
ifeq ($(C),1)
QUIET_SPARSE = $(Q:@=@echo ' SPARSE '$@;)$(SPARSE)
else
QUIET_SPARSE = @/bin/true
endif
PREFIX ?= /usr/local
CFLAGS += -std=c99 -O2 -fomit-frame-pointer -Wall -D_BSD_SOURCE
LDFLAGS ?=
SRCS = ssb_sprom.c utils.c
BIN = ssb-sprom
.SUFFIXES:
.PHONY: all install clean distclean
.DEFAULT_GOAL := all
DEPS = $(sort $(patsubst %.c,dep/%.d,$(1)))
OBJS = $(sort $(patsubst %.c,obj/%.o,$(1)))
# Generate dependencies
$(call DEPS,$(SRCS)): dep/%.d: %.c
@mkdir -p $(dir $@)
$(QUIET_DEPEND) -o $@.tmp -MM -MG -MT "$@ $(patsubst dep/%.d,obj/%.o,$@)" $(CFLAGS) $< && mv -f $@.tmp $@
-include $(call DEPS,$(SRCS))
# Generate object files
$(call OBJS,$(SRCS)): obj/%.o:
@mkdir -p $(dir $@)
$(QUIET_SPARSE) $(SPARSEFLAGS) $<
$(QUIET_CC) -o $@ -c $(CFLAGS) $<
all: $(BIN)
$(BIN): $(call OBJS,$(SRCS))
$(QUIET_CC) $(CFLAGS) -o $(BIN) $(call OBJS,$(SRCS)) $(LDFLAGS)
install: all
install -o 0 -g 0 -m 755 $(BIN) $(PREFIX)/bin/
clean:
-rm -Rf obj dep *~ *.orig *.rej
distclean: clean
-rm -f $(BIN)
|