xref: /f-stack/lib/Makefile (revision c36e692a)
1#
2# Copyright (c) 2013 Patrick Kelsey. All rights reserved.
3# Copyright (C) 2017 THL A29 Limited, a Tencent company.
4# All rights reserved.
5#
6# Derived in part from libuinet's Makefile.
7#
8# Derived from FreeBSD auto-generated kernel Makefile and
9# machine-specific Makefile templates
10#
11
12TOPDIR?=${CURDIR}/..
13S=${TOPDIR}/freebsd
14MACHINE_INCLUDES_ROOT:=${CURDIR}/machine_include
15OVERRIDE_INCLUDES_ROOT:=${CURDIR}/include
16X86_INCLUDES=0
17
18HOST_OS:=$(shell uname -s)
19#DEBUG=-O0 -gdwarf-2 -g3
20
21ifeq ($(FF_DPDK),)
22    FF_DPDK=${TOPDIR}/dpdk/x86_64-native-linuxapp-gcc
23endif
24
25DPDK_CFLAGS= -Wall -Werror -include ${FF_DPDK}/include/rte_config.h
26DPDK_CFLAGS+= -march=native -DRTE_MACHINE_CPUFLAG_SSE -DRTE_MACHINE_CPUFLAG_SSE2 -DRTE_MACHINE_CPUFLAG_SSE3
27DPDK_CFLAGS+= -DRTE_MACHINE_CPUFLAG_SSSE3 -DRTE_MACHINE_CPUFLAG_SSE4_1 -DRTE_MACHINE_CPUFLAG_SSE4_2
28DPDK_CFLAGS+= -DRTE_COMPILE_TIME_CPUFLAGS=RTE_CPUFLAG_SSE,RTE_CPUFLAG_SSE2,RTE_CPUFLAG_SSE3,RTE_CPUFLAG_SSSE3,RTE_CPUFLAG_SSE4_1,RTE_CPUFLAG_SSE4_2
29DPDK_CFLAGS+= -I${FF_DPDK}/include
30
31include ${TOPDIR}/mk/kern.pre.mk
32
33KERNPREINCLUDES:= ${INCLUDES}
34INCLUDES= -I${OVERRIDE_INCLUDES_ROOT} ${KERNPREINCLUDES}
35INCLUDES+= -I./machine_include
36INCLUDES+= -I./opt
37
38# Include search path for files that only include host OS headers
39HOST_INCLUDES= -I.
40ifndef DEBUG
41HOST_CFLAGS = -O2 -frename-registers  -funswitch-loops -fweb
42else
43HOST_CFLAGS = ${DEBUG}
44endif
45HOST_CFLAGS+= ${DPDK_CFLAGS}
46HOST_CFLAGS+= ${CONF_CFLAGS}
47HOST_C= ${CC} -c $(HOST_CFLAGS) ${HOST_INCLUDES} ${WERROR} ${PROF} $<
48
49
50ifneq ($(filter amd64 i386,${MACHINE_CPUARCH}),)
51X86_INCLUDES=1
52endif
53
54
55#
56# Distilled from FreeBSD src/sys/conf/Makefile.amd64
57#
58ifeq (${MACHINE_CPUARCH},amd64)
59endif
60
61#
62# Distilled from FreeBSD src/sys/conf/Makefile.arm
63#
64ifeq (${MACHINE_CPUARCH},arm)
65
66ifneq (${COMPILER_TYPE},clang)
67CFLAGS += -mno-thumb-interwork
68endif
69
70endif
71
72
73#
74# Distilled from FreeBSD src/sys/conf/Makefile.i386
75#
76ifeq (${MACHINE_CPUARCH},i386)
77MACHINE=i386
78endif
79
80
81#
82# Distilled from FreeBSD src/sys/conf/Makefile.mips
83#
84ifeq (${MACHINE_CPUARCH},mips)
85
86# We default to the MIPS32 ISA, if none specified in the
87# kernel configuration file.
88ARCH_FLAGS?=-march=mips32
89
90HACK_EXTRA_FLAGS=-shared
91
92CFLAGS+=${EXTRA_FLAGS} $(ARCH_FLAGS)
93HACK_EXTRA_FLAGS+=${EXTRA_FLAGS} $(ARCH_FLAGS)
94endif
95
96CFLAGS+= -DFSTACK
97
98# add for LVS tcp option toa, disabled by default
99# CFLAGS+= -DLVS_TCPOPT_TOA
100
101VPATH+= $S/${MACHINE_CPUARCH}/${MACHINE_CPUARCH}
102VPATH+= $S/kern
103VPATH+= $S/crypto
104VPATH+= $S/crypto/aesni
105VPATH+= $S/crypto/blowfish
106VPATH+= $S/crypto/camellia
107VPATH+= $S/crypto/des
108VPATH+= $S/crypto/rijndael
109VPATH+= $S/crypto/sha2
110VPATH+= $S/crypto/siphash
111VPATH+= $S/net
112VPATH+= $S/netgraph
113VPATH+= $S/netinet
114VPATH+= $S/netinet/libalias
115VPATH+= $S/netinet/cc
116VPATH+= $S/netipsec
117VPATH+= $S/opencrypto
118VPATH+= $S/vm
119VPATH+= $S/libkern
120
121
122FF_SRCS+=                     \
123	ff_compat.c           \
124	ff_glue.c             \
125	ff_freebsd_init.c     \
126	ff_init_main.c        \
127	ff_kern_condvar.c     \
128	ff_kern_environment.c \
129	ff_kern_intr.c        \
130	ff_kern_subr.c        \
131	ff_kern_synch.c       \
132	ff_kern_timeout.c     \
133	ff_lock.c             \
134	ff_syscall_wrapper.c  \
135	ff_subr_prf.c         \
136	ff_vfs_ops.c          \
137	ff_veth.c             \
138	ff_route.c
139
140FF_HOST_SRCS+=              \
141	ff_host_interface.c \
142	ff_config.c         \
143	ff_ini_parser.c     \
144	ff_dpdk_if.c        \
145	ff_dpdk_kni.c       \
146	ff_dpdk_pcap.c      \
147	ff_epoll.c          \
148	ff_init.c
149
150ifdef FF_IPSEC
151CRYPTO_ASM_SRCS+=                       \
152	aesencdec_${MACHINE_CPUARCH}.S  \
153	aeskeys_${MACHINE_CPUARCH}.S
154
155CRYPTO_SRCS+=               \
156	aesni.c	            \
157	aesni_wrap.c        \
158	bf_ecb.c            \
159	bf_enc.c            \
160	bf_skey.c           \
161	camellia.c          \
162	camellia-api.c      \
163	des_ecb.c           \
164	des_enc.c           \
165	des_setkey.c        \
166	rijndael-alg-fst.c  \
167	rijndael-api.c      \
168	sha1.c              \
169	sha256c.c           \
170	sha512c.c           \
171	siphash.c
172else
173CRYPTO_SRCS+=               \
174	sha1.c              \
175	siphash.c
176endif
177
178KERN_SRCS+=                 \
179	kern_descrip.c      \
180	kern_event.c        \
181	kern_fail.c         \
182	kern_khelp.c        \
183	kern_hhook.c        \
184	kern_linker.c       \
185	kern_mbuf.c         \
186	kern_module.c       \
187	kern_mtxpool.c      \
188	kern_ntptime.c      \
189	kern_osd.c          \
190	kern_sysctl.c       \
191	kern_tc.c           \
192	kern_uuid.c         \
193	link_elf.c          \
194	md5c.c              \
195	subr_capability.c   \
196	subr_counter.c      \
197	subr_eventhandler.c \
198	subr_kobj.c         \
199	subr_lock.c         \
200	subr_module.c       \
201	subr_param.c        \
202	subr_pcpu.c         \
203	subr_sbuf.c         \
204	subr_taskqueue.c    \
205	subr_unit.c         \
206	sys_capability.c    \
207	sys_generic.c       \
208	sys_socket.c        \
209	uipc_accf.c         \
210	uipc_mbuf.c         \
211	uipc_mbuf2.c        \
212	uipc_domain.c       \
213	uipc_sockbuf.c      \
214	uipc_socket.c       \
215	uipc_syscalls.c
216
217
218KERN_MHEADERS+=		\
219	bus_if.m	\
220	device_if.m	\
221	linker_if.m
222
223
224KERN_MSRCS+=		\
225	linker_if.m
226
227
228LIBKERN_SRCS+=		 \
229	bcd.c		 \
230	crc32.c          \
231	inet_ntoa.c	 \
232	jenkins_hash.c   \
233	strlcpy.c	 \
234	strnlen.c        \
235	zlib.c
236
237
238MACHINE_SRCS+=		 \
239	in_cksum.c
240
241
242NET_SRCS+=		 \
243	bpf.c		 \
244	bridgestp.c      \
245	if.c		 \
246	if_bridge.c      \
247	if_clone.c	 \
248	if_dead.c	 \
249	if_ethersubr.c	 \
250	if_loop.c	 \
251	if_llatbl.c	 \
252	if_media.c       \
253	if_spppfr.c      \
254	if_spppsubr.c    \
255	if_vlan.c        \
256	if_vxlan.c       \
257	in_fib.c	 \
258	in_gif.c         \
259	ip_reass.c	 \
260	netisr.c	 \
261	pfil.c		 \
262	radix.c		 \
263	raw_cb.c	 \
264	raw_usrreq.c	 \
265	route.c		 \
266	rtsock.c         \
267	slcompress.c
268
269NETGRAPH_SRCS +=         \
270	ng_async.c       \
271	ng_atmllc.c      \
272	ng_base.c        \
273	ng_bridge.c      \
274	ng_car.c         \
275	ng_cisco.c       \
276	ng_deflate.c     \
277	ng_echo.c        \
278	ng_eiface.c      \
279	ng_etf.c         \
280	ng_ether.c       \
281	ng_ether_echo.c  \
282	ng_frame_relay.c \
283	ng_gif.c         \
284	ng_gif_demux.c   \
285	ng_hole.c        \
286	ng_hub.c         \
287	ng_iface.c       \
288	ng_ip_input.c    \
289	ng_ipfw.c        \
290	ng_ksocket.c     \
291	ng_l2tp.c        \
292	ng_lmi.c         \
293	ng_nat.c         \
294	ng_one2many.c    \
295	ng_parse.c       \
296	ng_patch.c       \
297	ng_pipe.c        \
298	ng_ppp.c         \
299	ng_pppoe.c       \
300	ng_pptpgre.c     \
301	ng_pred1.c       \
302	ng_rfc1490.c     \
303	ng_sample.c      \
304	ng_socket.c      \
305	ng_source.c      \
306	ng_split.c       \
307	ng_sppp.c        \
308	ng_tag.c         \
309	ng_tcpmss.c      \
310	ng_tee.c         \
311	ng_UI.c          \
312	ng_vjc.c         \
313	ng_vlan.c
314
315NETINET_SRCS+=		\
316	if_ether.c	\
317	if_gif.c        \
318	igmp.c		\
319	in.c		\
320	in_mcast.c	\
321	in_pcb.c	\
322	in_proto.c	\
323	in_rmx.c	\
324	ip_carp.c	\
325	ip_ecn.c        \
326	ip_encap.c	\
327	ip_fastfwd.c	\
328	ip_icmp.c	\
329	ip_id.c		\
330	ip_input.c	\
331	ip_mroute.c     \
332	ip_options.c	\
333	ip_output.c	\
334	raw_ip.c	\
335	tcp_debug.c	\
336	tcp_fastopen.c	\
337	tcp_hostcache.c	\
338	tcp_input.c	\
339	tcp_lro.c	\
340	tcp_offload.c	\
341	tcp_output.c	\
342	tcp_reass.c	\
343	tcp_sack.c	\
344	tcp_subr.c	\
345	tcp_syncache.c	\
346	tcp_timer.c	\
347	tcp_timewait.c	\
348	tcp_usrreq.c	\
349	udp_usrreq.c	\
350	cc.c		\
351	cc_newreno.c    \
352	cc_htcp.c       \
353	cc_cubic.c      \
354	alias.c         \
355	alias_db.c      \
356	alias_mod.c     \
357	alias_proxy.c   \
358	alias_sctp.c    \
359	alias_util.c
360
361ifdef FF_IPSEC
362NETINET_SRCS+=		\
363	ip_ipsec.c
364endif
365
366
367ifdef FF_IPSEC
368NETIPSEC_SRCS+=		\
369	ipsec.c		\
370	ipsec_input.c	\
371	ipsec_mbuf.c	\
372	ipsec_output.c	\
373	key.c		\
374	key_debug.c	\
375	keysock.c	\
376	xform_ah.c	\
377	xform_esp.c	\
378	xform_ipcomp.c
379endif
380
381# only if TCP_SIGNTAURE is defined
382#xform_tcp.c
383
384NETINET6_SRCS+=
385
386
387ifdef FF_IPSEC
388OPENCRYPTO_SRCS+=	\
389	cast.c		\
390	criov.c		\
391	crypto.c	\
392	cryptosoft.c	\
393	deflate.c	\
394	rmd160.c	\
395	skipjack.c	\
396	xform.c
397endif
398
399#	cryptodev.c
400
401OPENCRYPTO_MHEADERS= cryptodev_if.m
402OPENCRYPTO_MSRCS= cryptodev_if.m
403
404VM_SRCS+=		\
405	uma_core.c
406
407
408MHEADERS= $(patsubst %.m,%.h,${KERN_MHEADERS})
409MHEADERS+= vnode_if.h vnode_if_newproto.h vnode_if_typedef.h
410MHEADERS+= $(patsubst %.m,%.h,${OPENCRYPTO_MHEADERS})
411
412MSRCS= $(patsubst %.m,%.c,${KERN_MSRCS})
413MSRCS+= $(patsubst %.m,%.c,${OPENCRYPTO_MSRCS})
414
415ASM_SRCS = ${CRYPTO_ASM_SRCS}
416
417SRCS=  ${FF_SRCS} ${CRYPTO_SRCS} ${KERN_SRCS} ${LIBKERN_SRCS} ${MACHINE_SRCS}
418SRCS+= ${MSRCS} ${NET_SRCS} ${NETGRAPH_SRCS} ${NETINET_SRCS} ${NETINET6_SRCS}
419SRCS+= ${NETIPSEC_SRCS} ${OPENCRYPTO_SRCS} ${VM_SRCS}
420
421# If witness is enabled.
422# SRCS+= ${KERN_WITNESS_SRCS}
423
424# Extra FreeBSD kernel module srcs.
425SRCS+= ${KMOD_SRCS}
426
427HOST_SRCS = ${FF_HOST_SRCS}
428
429ASM_OBJS+= $(patsubst %.S,%.o,${ASM_SRCS})
430OBJS+= $(patsubst %.c,%.o,${SRCS})
431HOST_OBJS+= $(patsubst %.c,%.o,${HOST_SRCS})
432
433all: libfstack.a
434
435#
436# The library is built by first incrementally linking all the object
437# to resolve internal references.  Then, all symbols are made local.
438# Then, only the symbols that are part of the  API are made
439# externally available.
440#
441libfstack.a: machine_includes ff_api.symlist ${MHEADERS} ${MSRCS} ${HOST_OBJS} ${ASM_OBJS} ${OBJS}
442	${LD} -d -r -o $*.ro ${ASM_OBJS} ${OBJS}
443	nm $*.ro  | grep -v ' U ' | cut -d ' ' -f 3 > $*_localize_list.tmp
444	objcopy --localize-symbols=$*_localize_list.tmp $*.ro
445	rm $*_localize_list.tmp
446	objcopy --globalize-symbols=ff_api.symlist $*.ro
447	rm -f $@
448	ar -cqs $@ $*.ro ${HOST_OBJS}
449	rm -f $*.ro
450
451${HOST_OBJS}: %.o: %.c
452	${HOST_C}
453
454${ASM_OBJS}: %.o: %.S ${IMACROS_FILE}
455	${NORMAL_S}
456
457${OBJS}: %.o: %.c ${IMACROS_FILE}
458	${NORMAL_C}
459
460
461.SUFFIXES: .m
462
463.m.c:
464	${AWK} -f $S/tools/makeobjops.awk $< -c
465
466.m.h:
467	${AWK} -f $S/tools/makeobjops.awk $< -h
468
469.PHONY: clean
470clean:
471	rm -f libfstack.a
472	rm -f ${MHEADERS} ${MSRCS} ${HOST_OBJS} ${ASM_OBJS} ${OBJS} ${PROGRAM} ${IMACROS_FILE}
473	rm -rf ${MACHINE_INCLUDES_ROOT}
474
475
476.PHONY: machine_includes
477machine_includes:
478	@rm -rf ${MACHINE_INCLUDES_ROOT}
479	@mkdir -p ${MACHINE_INCLUDES_ROOT}/machine
480	@cp -r $S/${MACHINE_CPUARCH}/include/* ${MACHINE_INCLUDES_ROOT}/machine
481	@if [ "${X86_INCLUDES}" != "0" ]; then 				\
482		mkdir -p ${MACHINE_INCLUDES_ROOT}/x86;			\
483		cp -r $S/x86/include/* ${MACHINE_INCLUDES_ROOT}/x86;	\
484	fi
485
486#
487# Distilled from FreeBSD src/sys/conf/kern.post.mk
488#
489vnode_if.h vnode_if_newproto.h vnode_if_typedef.h: $S/tools/vnode_if.awk \
490    $S/kern/vnode_if.src
491vnode_if.h: vnode_if_newproto.h vnode_if_typedef.h
492	${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -h
493vnode_if_newproto.h:
494	${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -p
495vnode_if_typedef.h:
496	${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -q
497
498include ${TOPDIR}/mk/kern.mk
499
500