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