-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
90 lines (75 loc) · 1.57 KB
/
Makefile
File metadata and controls
90 lines (75 loc) · 1.57 KB
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
79
80
81
82
83
84
85
86
87
88
89
90
#
# File:
# Makefile
#
# Description:
# Makefile for the JLab TIpcie Trigger Interface module
# using PC running Linux
#
# Uncomment DEBUG line, to include some debugging info ( -g and -Wall)
DEBUG ?= 1
QUIET ?= 1
#
ifeq ($(QUIET),1)
Q = @
else
Q =
endif
#
#
BASENAME=TIpcie
ARCH=${shell uname -m}
KERNEL_VERSION=${shell uname -r}
CC = gcc
CXX = g++
ifeq ($(ARCH),i686)
CC += -m32
CXX += -m32
endif
AR = ar
RANLIB = ranlib
CFLAGS = -fpic -L.
INCS = -I.
LIBS = lib${BASENAME}.a lib${BASENAME}.so
ifdef DEBUG
CFLAGS += -Wall -Wno-unused -g
else
CFLAGS += -O2
endif
SRC = ${BASENAME}Lib.c ${BASENAME}Config.cpp
HDRS = ${BASENAME}Lib.h ${BASENAME}Config.h
OBJ = $(HDRS:%.h=%.o)
DEPS = $(HDRS:%.h=%.d)
all: echoarch $(LIBS)
%.o: %.c
@echo " CC $@"
${Q}$(CC) $(CFLAGS) $(INCS) -c -o $@ $<
%.o: %.cpp
@echo " CXX $@"
${Q}$(CXX) $(CFLAGS) -std=c++11 $(INCS) -c -o $@ $<
%.so: $(OBJ)
@echo " CC $@"
${Q}$(CC) -shared $(CFLAGS) $(INCS) -o $(@:%.a=%.so) $(OBJ)
%.a: $(OBJ)
@echo " AR $@"
${Q}$(AR) ru $@ $<
@echo " RANLIB $@"
${Q}$(RANLIB) $@
%.d: %.c
@echo " DEP $@"
@set -e; rm -f $@; \
$(CC) -MM -shared $(INCS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
%.d: %.cpp
@echo " DEP $@"
@set -e; rm -f $@; \
$(CXX) -MM -shared $(INCS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
-include $(DEPS)
clean:
@rm -vf ${OBJ} ${DEPS} ${LIBS}
echoarch:
@echo "Make for $(ARCH)"
.PHONY: clean echoarch