1a9643ea8Slogwang# 2a9643ea8Slogwang# Copyright (c) 2013 Patrick Kelsey. All rights reserved. 3a9643ea8Slogwang# Copyright (C) 2017 THL A29 Limited, a Tencent company. 4a9643ea8Slogwang# All rights reserved. 5a9643ea8Slogwang# 6a9643ea8Slogwang# Derived in part from libuinet's Makefile. 7a9643ea8Slogwang# 8a9643ea8Slogwang# Derived from FreeBSD auto-generated kernel Makefile and 9a9643ea8Slogwang# machine-specific Makefile templates 10a9643ea8Slogwang# 11a9643ea8Slogwang 12a9643ea8SlogwangTOPDIR?=${CURDIR}/.. 13a9643ea8SlogwangS=${TOPDIR}/freebsd 14a9643ea8SlogwangMACHINE_INCLUDES_ROOT:=${CURDIR}/machine_include 15a9643ea8SlogwangOVERRIDE_INCLUDES_ROOT:=${CURDIR}/include 16a9643ea8SlogwangX86_INCLUDES=0 17a9643ea8Slogwang 18a9643ea8SlogwangHOST_OS:=$(shell uname -s) 19dc42d452Swhl739 20dc42d452Swhl739#DEBUG=-O0 -gdwarf-2 -g3 -Wno-format-truncation 21dc42d452Swhl739 225523938cSrootFF_KNI=1 23127dd473Swhl739#FF_NETGRAPH=1 24127dd473Swhl739#FF_IPFW=1 25a9643ea8Slogwang 26a9643ea8Slogwangifeq ($(FF_DPDK),) 27*bf05b3b7SDonBearHifeq (${shell uname -m},aarch64) 289bd490e8Sdongbo4 FF_DPDK=${TOPDIR}/dpdk/build 299bd490e8Sdongbo4else 30*bf05b3b7SDonBearH FF_DPDK=${TOPDIR}/dpdk/x86_64-native-linuxapp-gcc 319bd490e8Sdongbo4endif 32a9643ea8Slogwangendif 33a9643ea8Slogwang 347230b27cSmorishima311ifdef RTE_SDK 35*bf05b3b7SDonBearHifeq (${shell uname -m},aarch64) 369bd490e8Sdongbo4 FF_DPDK=${RTE_SDK}/build 379bd490e8Sdongbo4else 38*bf05b3b7SDonBearH FF_DPDK=${RTE_SDK}/x86_64-native-linuxapp-gcc 399bd490e8Sdongbo4endif 407230b27cSmorishima311endif 417230b27cSmorishima311 42a9643ea8SlogwangDPDK_CFLAGS= -Wall -Werror -include ${FF_DPDK}/include/rte_config.h 43a9643ea8SlogwangDPDK_CFLAGS+= -march=native -DRTE_MACHINE_CPUFLAG_SSE -DRTE_MACHINE_CPUFLAG_SSE2 -DRTE_MACHINE_CPUFLAG_SSE3 44a9643ea8SlogwangDPDK_CFLAGS+= -DRTE_MACHINE_CPUFLAG_SSSE3 -DRTE_MACHINE_CPUFLAG_SSE4_1 -DRTE_MACHINE_CPUFLAG_SSE4_2 45a9643ea8SlogwangDPDK_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 46a9643ea8SlogwangDPDK_CFLAGS+= -I${FF_DPDK}/include 47a9643ea8Slogwang 48a9643ea8Slogwanginclude ${TOPDIR}/mk/kern.pre.mk 49a9643ea8Slogwang 50a9643ea8SlogwangKERNPREINCLUDES:= ${INCLUDES} 51a9643ea8SlogwangINCLUDES= -I${OVERRIDE_INCLUDES_ROOT} ${KERNPREINCLUDES} 52a9643ea8SlogwangINCLUDES+= -I./machine_include 53a9643ea8SlogwangINCLUDES+= -I./opt 54a9643ea8Slogwang 55a9643ea8Slogwang# Include search path for files that only include host OS headers 56a9643ea8SlogwangHOST_INCLUDES= -I. 57a9643ea8Slogwangifndef DEBUG 58dc42d452Swhl739HOST_CFLAGS = -O2 -frename-registers -funswitch-loops -fweb -Wno-format-truncation 59a9643ea8Slogwangelse 60a9643ea8SlogwangHOST_CFLAGS = ${DEBUG} 61a9643ea8Slogwangendif 623b2bd0f6Slogwang 63dc42d452Swhl739ifdef FF_KNI 64dc42d452Swhl739HOST_CFLAGS+= -DFF_KNI 65dc42d452Swhl739endif 66dc42d452Swhl739 67a9643ea8SlogwangHOST_CFLAGS+= ${DPDK_CFLAGS} 6834b2fad4SYuYangHOST_CFLAGS+= ${CONF_CFLAGS} 693b2bd0f6Slogwang 703b2bd0f6Slogwangifdef FF_NETGRAPH 713b2bd0f6SlogwangHOST_CFLAGS+= -DFF_NETGRAPH 723b2bd0f6Slogwangendif 733b2bd0f6Slogwang 74127dd473Swhl739ifdef FF_IPFW 75127dd473Swhl739HOST_CFLAGS+= -DFF_IPFW 76127dd473Swhl739endif 77127dd473Swhl739 78a9643ea8SlogwangHOST_C= ${CC} -c $(HOST_CFLAGS) ${HOST_INCLUDES} ${WERROR} ${PROF} $< 79a9643ea8Slogwang 80a9643ea8Slogwang 81a9643ea8Slogwangifneq ($(filter amd64 i386,${MACHINE_CPUARCH}),) 82a9643ea8SlogwangX86_INCLUDES=1 83a9643ea8Slogwangendif 84a9643ea8Slogwang 85a9643ea8Slogwang 86a9643ea8Slogwang# 87a9643ea8Slogwang# Distilled from FreeBSD src/sys/conf/Makefile.amd64 88a9643ea8Slogwang# 89a9643ea8Slogwangifeq (${MACHINE_CPUARCH},amd64) 90a9643ea8Slogwangendif 91a9643ea8Slogwang 92a9643ea8Slogwang# 93a9643ea8Slogwang# Distilled from FreeBSD src/sys/conf/Makefile.arm 94a9643ea8Slogwang# 95a9643ea8Slogwangifeq (${MACHINE_CPUARCH},arm) 96a9643ea8Slogwang 97a9643ea8Slogwangifneq (${COMPILER_TYPE},clang) 98a9643ea8SlogwangCFLAGS += -mno-thumb-interwork 99a9643ea8Slogwangendif 100a9643ea8Slogwang 101a9643ea8Slogwangendif 102a9643ea8Slogwang 1039bd490e8Sdongbo4# 1049bd490e8Sdongbo4# fix the MACHINE_CPUARCH to match the FreeBSD directory name 1059bd490e8Sdongbo4# 1069bd490e8Sdongbo4ifeq (${MACHINE_CPUARCH},aarch64) 1079bd490e8Sdongbo4MACHINE_CPUARCH=arm64 1089bd490e8Sdongbo4endif 1099bd490e8Sdongbo4 110a9643ea8Slogwang 111a9643ea8Slogwang# 112a9643ea8Slogwang# Distilled from FreeBSD src/sys/conf/Makefile.i386 113a9643ea8Slogwang# 114a9643ea8Slogwangifeq (${MACHINE_CPUARCH},i386) 115a9643ea8SlogwangMACHINE=i386 116a9643ea8Slogwangendif 117a9643ea8Slogwang 118a9643ea8Slogwang 119a9643ea8Slogwang# 120a9643ea8Slogwang# Distilled from FreeBSD src/sys/conf/Makefile.mips 121a9643ea8Slogwang# 122a9643ea8Slogwangifeq (${MACHINE_CPUARCH},mips) 123a9643ea8Slogwang 124a9643ea8Slogwang# We default to the MIPS32 ISA, if none specified in the 125a9643ea8Slogwang# kernel configuration file. 126a9643ea8SlogwangARCH_FLAGS?=-march=mips32 127a9643ea8Slogwang 128a9643ea8SlogwangHACK_EXTRA_FLAGS=-shared 129a9643ea8Slogwang 130a9643ea8SlogwangCFLAGS+=${EXTRA_FLAGS} $(ARCH_FLAGS) 131a9643ea8SlogwangHACK_EXTRA_FLAGS+=${EXTRA_FLAGS} $(ARCH_FLAGS) 132a9643ea8Slogwangendif 133a9643ea8Slogwang 134a9643ea8SlogwangCFLAGS+= -DFSTACK 135a9643ea8Slogwang 13608dba010SAndy# add for LVS tcp option toa, disabled by default 13708dba010SAndy# CFLAGS+= -DLVS_TCPOPT_TOA 13808dba010SAndy 139a9643ea8SlogwangVPATH+= $S/${MACHINE_CPUARCH}/${MACHINE_CPUARCH} 140a9643ea8SlogwangVPATH+= $S/kern 141a9643ea8SlogwangVPATH+= $S/crypto 142a9643ea8SlogwangVPATH+= $S/crypto/aesni 143a9643ea8SlogwangVPATH+= $S/crypto/blowfish 144a9643ea8SlogwangVPATH+= $S/crypto/camellia 145a9643ea8SlogwangVPATH+= $S/crypto/des 146a9643ea8SlogwangVPATH+= $S/crypto/rijndael 147a9643ea8SlogwangVPATH+= $S/crypto/sha2 148a9643ea8SlogwangVPATH+= $S/crypto/siphash 149a9643ea8SlogwangVPATH+= $S/net 150a416aa08Slogwangifdef FF_NETGRAPH 151a1fd9364SlogwangVPATH+= $S/netgraph 152a416aa08Slogwangendif 153a9643ea8SlogwangVPATH+= $S/netinet 154a1fd9364SlogwangVPATH+= $S/netinet/libalias 155a9643ea8SlogwangVPATH+= $S/netinet/cc 156a9643ea8SlogwangVPATH+= $S/netipsec 157127dd473Swhl739ifdef FF_IPFW 158127dd473Swhl739VPATH+= $S/netpfil/ipfw 159127dd473Swhl739endif 160a9643ea8SlogwangVPATH+= $S/opencrypto 161a9643ea8SlogwangVPATH+= $S/vm 162a9643ea8SlogwangVPATH+= $S/libkern 163a9643ea8Slogwang 164a9643ea8Slogwang 165a9643ea8SlogwangFF_SRCS+= \ 166a9643ea8Slogwang ff_compat.c \ 167a9643ea8Slogwang ff_glue.c \ 168a9643ea8Slogwang ff_freebsd_init.c \ 169a9643ea8Slogwang ff_init_main.c \ 170a9643ea8Slogwang ff_kern_condvar.c \ 171a9643ea8Slogwang ff_kern_environment.c \ 172a9643ea8Slogwang ff_kern_intr.c \ 173a9643ea8Slogwang ff_kern_subr.c \ 174a9643ea8Slogwang ff_kern_synch.c \ 175a9643ea8Slogwang ff_kern_timeout.c \ 176a9643ea8Slogwang ff_lock.c \ 177a9643ea8Slogwang ff_syscall_wrapper.c \ 178a9643ea8Slogwang ff_subr_prf.c \ 179a9643ea8Slogwang ff_vfs_ops.c \ 180a9643ea8Slogwang ff_veth.c \ 181144c6bcdSlogwang ff_route.c 182a9643ea8Slogwang 1833b2bd0f6Slogwangifdef FF_NETGRAPH 1843b2bd0f6SlogwangFF_SRCS+= \ 1853b2bd0f6Slogwang ff_ng_base.c \ 1863b2bd0f6Slogwang ff_ngctl.c 1873b2bd0f6Slogwangendif 1883b2bd0f6Slogwang 189a9643ea8SlogwangFF_HOST_SRCS+= \ 190a9643ea8Slogwang ff_host_interface.c \ 191a9643ea8Slogwang ff_config.c \ 192a9643ea8Slogwang ff_ini_parser.c \ 193a9643ea8Slogwang ff_dpdk_if.c \ 194a9643ea8Slogwang ff_dpdk_pcap.c \ 1951a78ce8eSRon ff_epoll.c \ 196a9643ea8Slogwang ff_init.c 197a9643ea8Slogwang 198dc42d452Swhl739ifdef FF_KNI 199dc42d452Swhl739FF_HOST_SRCS+= \ 200dc42d452Swhl739 ff_dpdk_kni.c 201dc42d452Swhl739endif 202dc42d452Swhl739 203a9643ea8Slogwangifdef FF_IPSEC 204a9643ea8SlogwangCRYPTO_ASM_SRCS+= \ 205a9643ea8Slogwang aesencdec_${MACHINE_CPUARCH}.S \ 206a9643ea8Slogwang aeskeys_${MACHINE_CPUARCH}.S 207a9643ea8Slogwang 208a9643ea8SlogwangCRYPTO_SRCS+= \ 209a9643ea8Slogwang aesni.c \ 210a9643ea8Slogwang aesni_wrap.c \ 211a9643ea8Slogwang bf_ecb.c \ 212a9643ea8Slogwang bf_enc.c \ 213a9643ea8Slogwang bf_skey.c \ 214a9643ea8Slogwang camellia.c \ 215a9643ea8Slogwang camellia-api.c \ 216a9643ea8Slogwang des_ecb.c \ 217a9643ea8Slogwang des_enc.c \ 218a9643ea8Slogwang des_setkey.c \ 219a9643ea8Slogwang rijndael-alg-fst.c \ 220a9643ea8Slogwang rijndael-api.c \ 221a9643ea8Slogwang sha1.c \ 222a9643ea8Slogwang sha256c.c \ 223a9643ea8Slogwang sha512c.c \ 224a9643ea8Slogwang siphash.c 225a9643ea8Slogwangelse 226a9643ea8SlogwangCRYPTO_SRCS+= \ 227a9643ea8Slogwang sha1.c \ 228a9643ea8Slogwang siphash.c 229a9643ea8Slogwangendif 230a9643ea8Slogwang 231a9643ea8SlogwangKERN_SRCS+= \ 232a9643ea8Slogwang kern_descrip.c \ 233a9643ea8Slogwang kern_event.c \ 234a9643ea8Slogwang kern_fail.c \ 235a9643ea8Slogwang kern_khelp.c \ 236a9643ea8Slogwang kern_hhook.c \ 237a9643ea8Slogwang kern_linker.c \ 238a9643ea8Slogwang kern_mbuf.c \ 239a9643ea8Slogwang kern_module.c \ 240a9643ea8Slogwang kern_mtxpool.c \ 241a9643ea8Slogwang kern_ntptime.c \ 242a9643ea8Slogwang kern_osd.c \ 243a9643ea8Slogwang kern_sysctl.c \ 244a9643ea8Slogwang kern_tc.c \ 245a9643ea8Slogwang kern_uuid.c \ 246a9643ea8Slogwang link_elf.c \ 247a9643ea8Slogwang md5c.c \ 248a9643ea8Slogwang subr_capability.c \ 249a9643ea8Slogwang subr_counter.c \ 250a9643ea8Slogwang subr_eventhandler.c \ 251a9643ea8Slogwang subr_kobj.c \ 252a9643ea8Slogwang subr_lock.c \ 253a9643ea8Slogwang subr_module.c \ 254a9643ea8Slogwang subr_param.c \ 255a9643ea8Slogwang subr_pcpu.c \ 256a9643ea8Slogwang subr_sbuf.c \ 257a9643ea8Slogwang subr_taskqueue.c \ 258a9643ea8Slogwang subr_unit.c \ 259a9643ea8Slogwang sys_capability.c \ 260a9643ea8Slogwang sys_generic.c \ 261a9643ea8Slogwang sys_socket.c \ 262a9643ea8Slogwang uipc_accf.c \ 263a9643ea8Slogwang uipc_mbuf.c \ 264a9643ea8Slogwang uipc_mbuf2.c \ 265a9643ea8Slogwang uipc_domain.c \ 266a9643ea8Slogwang uipc_sockbuf.c \ 267a9643ea8Slogwang uipc_socket.c \ 268a9643ea8Slogwang uipc_syscalls.c 269a9643ea8Slogwang 270a9643ea8Slogwang 271a9643ea8SlogwangKERN_MHEADERS+= \ 272a9643ea8Slogwang bus_if.m \ 273a9643ea8Slogwang device_if.m \ 274a9643ea8Slogwang linker_if.m 275a9643ea8Slogwang 276a9643ea8Slogwang 277a9643ea8SlogwangKERN_MSRCS+= \ 278a9643ea8Slogwang linker_if.m 279a9643ea8Slogwang 2809bd490e8Sdongbo4ifeq (${MACHINE_CPUARCH},arm64) 2819bd490e8Sdongbo4LIBKERN_SRCS+= \ 2829bd490e8Sdongbo4 bcd.c \ 2839bd490e8Sdongbo4 crc32.c \ 2849bd490e8Sdongbo4 inet_ntoa.c \ 2859bd490e8Sdongbo4 jenkins_hash.c \ 2869bd490e8Sdongbo4 strlcpy.c \ 2879bd490e8Sdongbo4 strnlen.c \ 2889bd490e8Sdongbo4 zlib.c \ 2899bd490e8Sdongbo4 fls.c \ 2909bd490e8Sdongbo4 flsl.c 2919bd490e8Sdongbo4else 292a9643ea8SlogwangLIBKERN_SRCS+= \ 293a9643ea8Slogwang bcd.c \ 294a1fd9364Slogwang crc32.c \ 295a9643ea8Slogwang inet_ntoa.c \ 296a9643ea8Slogwang jenkins_hash.c \ 297a9643ea8Slogwang strlcpy.c \ 298a1fd9364Slogwang strnlen.c \ 299a1fd9364Slogwang zlib.c 3009bd490e8Sdongbo4endif 301a9643ea8Slogwang 302a9643ea8Slogwang 303a9643ea8SlogwangMACHINE_SRCS+= \ 304a9643ea8Slogwang in_cksum.c 305a9643ea8Slogwang 306a9643ea8Slogwang 307a9643ea8SlogwangNET_SRCS+= \ 308a9643ea8Slogwang bpf.c \ 309df6ad731Slogwang bridgestp.c \ 310a9643ea8Slogwang if.c \ 311df6ad731Slogwang if_bridge.c \ 312a9643ea8Slogwang if_clone.c \ 313a9643ea8Slogwang if_dead.c \ 314a9643ea8Slogwang if_ethersubr.c \ 315a9643ea8Slogwang if_loop.c \ 316a9643ea8Slogwang if_llatbl.c \ 317a1fd9364Slogwang if_media.c \ 318a1fd9364Slogwang if_spppfr.c \ 319a1fd9364Slogwang if_spppsubr.c \ 320a1fd9364Slogwang if_vlan.c \ 321a1fd9364Slogwang if_vxlan.c \ 322a9643ea8Slogwang in_fib.c \ 323df6ad731Slogwang in_gif.c \ 324a9643ea8Slogwang ip_reass.c \ 325a9643ea8Slogwang netisr.c \ 326a9643ea8Slogwang pfil.c \ 327a9643ea8Slogwang radix.c \ 328a9643ea8Slogwang raw_cb.c \ 329a9643ea8Slogwang raw_usrreq.c \ 330a9643ea8Slogwang route.c \ 331a1fd9364Slogwang rtsock.c \ 332a1fd9364Slogwang slcompress.c 333a9643ea8Slogwang 334a416aa08Slogwangifdef FF_NETGRAPH 335a1fd9364SlogwangNETGRAPH_SRCS += \ 336a1fd9364Slogwang ng_async.c \ 337a1fd9364Slogwang ng_atmllc.c \ 338a1fd9364Slogwang ng_bridge.c \ 339a1fd9364Slogwang ng_car.c \ 340a1fd9364Slogwang ng_cisco.c \ 341a1fd9364Slogwang ng_deflate.c \ 342a1fd9364Slogwang ng_echo.c \ 343a1fd9364Slogwang ng_eiface.c \ 344a1fd9364Slogwang ng_etf.c \ 345a1fd9364Slogwang ng_ether.c \ 346a1fd9364Slogwang ng_ether_echo.c \ 347a1fd9364Slogwang ng_frame_relay.c \ 348a1fd9364Slogwang ng_gif.c \ 349a1fd9364Slogwang ng_gif_demux.c \ 350a1fd9364Slogwang ng_hole.c \ 351a1fd9364Slogwang ng_hub.c \ 352a1fd9364Slogwang ng_iface.c \ 353a1fd9364Slogwang ng_ip_input.c \ 354a1fd9364Slogwang ng_ipfw.c \ 355a1fd9364Slogwang ng_ksocket.c \ 356a1fd9364Slogwang ng_l2tp.c \ 357a1fd9364Slogwang ng_lmi.c \ 358a1fd9364Slogwang ng_nat.c \ 359a1fd9364Slogwang ng_one2many.c \ 360a1fd9364Slogwang ng_parse.c \ 361a1fd9364Slogwang ng_patch.c \ 362a1fd9364Slogwang ng_pipe.c \ 363a1fd9364Slogwang ng_ppp.c \ 364a1fd9364Slogwang ng_pppoe.c \ 365a1fd9364Slogwang ng_pptpgre.c \ 366a1fd9364Slogwang ng_pred1.c \ 367a1fd9364Slogwang ng_rfc1490.c \ 368a1fd9364Slogwang ng_sample.c \ 369a1fd9364Slogwang ng_socket.c \ 370a1fd9364Slogwang ng_source.c \ 371a1fd9364Slogwang ng_split.c \ 372a1fd9364Slogwang ng_sppp.c \ 373a1fd9364Slogwang ng_tag.c \ 374a1fd9364Slogwang ng_tcpmss.c \ 375a1fd9364Slogwang ng_tee.c \ 376a1fd9364Slogwang ng_UI.c \ 377a1fd9364Slogwang ng_vjc.c \ 378a1fd9364Slogwang ng_vlan.c 379a416aa08Slogwangendif 380a9643ea8Slogwang 381a9643ea8SlogwangNETINET_SRCS+= \ 382a9643ea8Slogwang if_ether.c \ 383df6ad731Slogwang if_gif.c \ 384a9643ea8Slogwang igmp.c \ 385a9643ea8Slogwang in.c \ 386a9643ea8Slogwang in_mcast.c \ 387a9643ea8Slogwang in_pcb.c \ 388a9643ea8Slogwang in_proto.c \ 389a9643ea8Slogwang in_rmx.c \ 390a1fd9364Slogwang ip_carp.c \ 39162a0d716Slogwang ip_divert.c \ 392df6ad731Slogwang ip_ecn.c \ 393a9643ea8Slogwang ip_encap.c \ 394a9643ea8Slogwang ip_fastfwd.c \ 395a9643ea8Slogwang ip_icmp.c \ 396a9643ea8Slogwang ip_id.c \ 397a9643ea8Slogwang ip_input.c \ 3981eaf0ac3Slogwang ip_mroute.c \ 399a9643ea8Slogwang ip_options.c \ 400a9643ea8Slogwang ip_output.c \ 401a9643ea8Slogwang raw_ip.c \ 402a9643ea8Slogwang tcp_debug.c \ 403a9643ea8Slogwang tcp_fastopen.c \ 404a9643ea8Slogwang tcp_hostcache.c \ 405a9643ea8Slogwang tcp_input.c \ 406a9643ea8Slogwang tcp_lro.c \ 407a9643ea8Slogwang tcp_offload.c \ 408a9643ea8Slogwang tcp_output.c \ 409a9643ea8Slogwang tcp_reass.c \ 410a9643ea8Slogwang tcp_sack.c \ 411a9643ea8Slogwang tcp_subr.c \ 412a9643ea8Slogwang tcp_syncache.c \ 413a9643ea8Slogwang tcp_timer.c \ 414a9643ea8Slogwang tcp_timewait.c \ 415a9643ea8Slogwang tcp_usrreq.c \ 416a9643ea8Slogwang udp_usrreq.c \ 417a9643ea8Slogwang cc.c \ 418a9643ea8Slogwang cc_newreno.c \ 419a9643ea8Slogwang cc_htcp.c \ 420a1fd9364Slogwang cc_cubic.c \ 421a1fd9364Slogwang alias.c \ 422a1fd9364Slogwang alias_db.c \ 423a1fd9364Slogwang alias_mod.c \ 424a1fd9364Slogwang alias_proxy.c \ 425a1fd9364Slogwang alias_sctp.c \ 426a1fd9364Slogwang alias_util.c 427a9643ea8Slogwang 428127dd473Swhl739ifdef FF_IPFW 429127dd473Swhl739NETIPFW_SRCS+= \ 430127dd473Swhl739 ip_fw_dynamic.c \ 431127dd473Swhl739 ip_fw_eaction.c \ 432127dd473Swhl739 ip_fw_iface.c \ 433127dd473Swhl739 ip_fw_log.c \ 434127dd473Swhl739 ip_fw_nat.c \ 435127dd473Swhl739 ip_fw_pfil.c \ 436127dd473Swhl739 ip_fw_sockopt.c \ 437127dd473Swhl739 ip_fw_table.c \ 438127dd473Swhl739 ip_fw_table_algo.c \ 439127dd473Swhl739 ip_fw_table_value.c \ 440127dd473Swhl739 ip_fw2.c 441127dd473Swhl739endif 442127dd473Swhl739 443a9643ea8Slogwangifdef FF_IPSEC 444a9643ea8SlogwangNETINET_SRCS+= \ 445a9643ea8Slogwang ip_ipsec.c 446a9643ea8Slogwangendif 447a9643ea8Slogwang 448a9643ea8Slogwang 449a9643ea8Slogwangifdef FF_IPSEC 450a9643ea8SlogwangNETIPSEC_SRCS+= \ 451a9643ea8Slogwang ipsec.c \ 452a9643ea8Slogwang ipsec_input.c \ 453a9643ea8Slogwang ipsec_mbuf.c \ 454a9643ea8Slogwang ipsec_output.c \ 455a9643ea8Slogwang key.c \ 456a9643ea8Slogwang key_debug.c \ 457a9643ea8Slogwang keysock.c \ 458a9643ea8Slogwang xform_ah.c \ 459a9643ea8Slogwang xform_esp.c \ 460a9643ea8Slogwang xform_ipcomp.c 461a9643ea8Slogwangendif 462a9643ea8Slogwang 463a9643ea8Slogwang# only if TCP_SIGNTAURE is defined 464a9643ea8Slogwang#xform_tcp.c 465a9643ea8Slogwang 466a9643ea8SlogwangNETINET6_SRCS+= 467a9643ea8Slogwang 468a9643ea8Slogwang 469a9643ea8Slogwangifdef FF_IPSEC 470a9643ea8SlogwangOPENCRYPTO_SRCS+= \ 471a9643ea8Slogwang cast.c \ 472a9643ea8Slogwang criov.c \ 473a9643ea8Slogwang crypto.c \ 474a9643ea8Slogwang cryptosoft.c \ 475a9643ea8Slogwang deflate.c \ 476a9643ea8Slogwang rmd160.c \ 477a9643ea8Slogwang skipjack.c \ 478a9643ea8Slogwang xform.c 479a9643ea8Slogwangendif 480a9643ea8Slogwang 481a9643ea8Slogwang# cryptodev.c 482a9643ea8Slogwang 483a9643ea8SlogwangOPENCRYPTO_MHEADERS= cryptodev_if.m 484a9643ea8SlogwangOPENCRYPTO_MSRCS= cryptodev_if.m 485a9643ea8Slogwang 486a9643ea8SlogwangVM_SRCS+= \ 487a9643ea8Slogwang uma_core.c 488a9643ea8Slogwang 489a9643ea8Slogwang 490a9643ea8SlogwangMHEADERS= $(patsubst %.m,%.h,${KERN_MHEADERS}) 491a9643ea8SlogwangMHEADERS+= vnode_if.h vnode_if_newproto.h vnode_if_typedef.h 492a9643ea8SlogwangMHEADERS+= $(patsubst %.m,%.h,${OPENCRYPTO_MHEADERS}) 493a9643ea8Slogwang 494a9643ea8SlogwangMSRCS= $(patsubst %.m,%.c,${KERN_MSRCS}) 495a9643ea8SlogwangMSRCS+= $(patsubst %.m,%.c,${OPENCRYPTO_MSRCS}) 496a9643ea8Slogwang 497a9643ea8SlogwangASM_SRCS = ${CRYPTO_ASM_SRCS} 498a9643ea8Slogwang 499a9643ea8SlogwangSRCS= ${FF_SRCS} ${CRYPTO_SRCS} ${KERN_SRCS} ${LIBKERN_SRCS} ${MACHINE_SRCS} 500a1fd9364SlogwangSRCS+= ${MSRCS} ${NET_SRCS} ${NETGRAPH_SRCS} ${NETINET_SRCS} ${NETINET6_SRCS} 501127dd473Swhl739SRCS+= ${NETIPSEC_SRCS} ${NETIPFW_SRCS} ${OPENCRYPTO_SRCS} ${VM_SRCS} 502a9643ea8Slogwang 503a9643ea8Slogwang# If witness is enabled. 504a9643ea8Slogwang# SRCS+= ${KERN_WITNESS_SRCS} 505a9643ea8Slogwang 506c36e692aSlogwang# Extra FreeBSD kernel module srcs. 507c36e692aSlogwangSRCS+= ${KMOD_SRCS} 508c36e692aSlogwang 509a9643ea8SlogwangHOST_SRCS = ${FF_HOST_SRCS} 510a9643ea8Slogwang 511a9643ea8SlogwangASM_OBJS+= $(patsubst %.S,%.o,${ASM_SRCS}) 512a9643ea8SlogwangOBJS+= $(patsubst %.c,%.o,${SRCS}) 513a9643ea8SlogwangHOST_OBJS+= $(patsubst %.c,%.o,${HOST_SRCS}) 514a9643ea8Slogwang 515a9643ea8Slogwangall: libfstack.a 516a9643ea8Slogwang 517a9643ea8Slogwang# 518a9643ea8Slogwang# The library is built by first incrementally linking all the object 519a9643ea8Slogwang# to resolve internal references. Then, all symbols are made local. 520a9643ea8Slogwang# Then, only the symbols that are part of the API are made 521a9643ea8Slogwang# externally available. 522a9643ea8Slogwang# 523a9643ea8Slogwanglibfstack.a: machine_includes ff_api.symlist ${MHEADERS} ${MSRCS} ${HOST_OBJS} ${ASM_OBJS} ${OBJS} 5248cf1d457Slogwang ${LD} -d -r -o $*.ro ${ASM_OBJS} ${OBJS} 525a9643ea8Slogwang nm $*.ro | grep -v ' U ' | cut -d ' ' -f 3 > $*_localize_list.tmp 526a9643ea8Slogwang objcopy --localize-symbols=$*_localize_list.tmp $*.ro 527a9643ea8Slogwang rm $*_localize_list.tmp 528a9643ea8Slogwang objcopy --globalize-symbols=ff_api.symlist $*.ro 529a9643ea8Slogwang rm -f $@ 530a9643ea8Slogwang ar -cqs $@ $*.ro ${HOST_OBJS} 531a9643ea8Slogwang rm -f $*.ro 532a9643ea8Slogwang 533a9643ea8Slogwang${HOST_OBJS}: %.o: %.c 534a9643ea8Slogwang ${HOST_C} 535a9643ea8Slogwang 536a9643ea8Slogwang${ASM_OBJS}: %.o: %.S ${IMACROS_FILE} 537a9643ea8Slogwang ${NORMAL_S} 538a9643ea8Slogwang 539a9643ea8Slogwang${OBJS}: %.o: %.c ${IMACROS_FILE} 540a9643ea8Slogwang ${NORMAL_C} 541a9643ea8Slogwang 542a9643ea8Slogwang 543a9643ea8Slogwang.SUFFIXES: .m 544a9643ea8Slogwang 545a9643ea8Slogwang.m.c: 546a9643ea8Slogwang ${AWK} -f $S/tools/makeobjops.awk $< -c 547a9643ea8Slogwang 548a9643ea8Slogwang.m.h: 549a9643ea8Slogwang ${AWK} -f $S/tools/makeobjops.awk $< -h 550a9643ea8Slogwang 551a9643ea8Slogwang.PHONY: clean 552a9643ea8Slogwangclean: 553a9643ea8Slogwang rm -f libfstack.a 554a9643ea8Slogwang rm -f ${MHEADERS} ${MSRCS} ${HOST_OBJS} ${ASM_OBJS} ${OBJS} ${PROGRAM} ${IMACROS_FILE} 555a9643ea8Slogwang rm -rf ${MACHINE_INCLUDES_ROOT} 556a9643ea8Slogwang 557a9643ea8Slogwang 558a9643ea8Slogwang.PHONY: machine_includes 559a9643ea8Slogwangmachine_includes: 560a9643ea8Slogwang @rm -rf ${MACHINE_INCLUDES_ROOT} 561a9643ea8Slogwang @mkdir -p ${MACHINE_INCLUDES_ROOT}/machine 562a9643ea8Slogwang @cp -r $S/${MACHINE_CPUARCH}/include/* ${MACHINE_INCLUDES_ROOT}/machine 563a9643ea8Slogwang @if [ "${X86_INCLUDES}" != "0" ]; then \ 564a9643ea8Slogwang mkdir -p ${MACHINE_INCLUDES_ROOT}/x86; \ 565a9643ea8Slogwang cp -r $S/x86/include/* ${MACHINE_INCLUDES_ROOT}/x86; \ 566a9643ea8Slogwang fi 567a9643ea8Slogwang 568a9643ea8Slogwang# 569a9643ea8Slogwang# Distilled from FreeBSD src/sys/conf/kern.post.mk 570a9643ea8Slogwang# 571a9643ea8Slogwangvnode_if.h vnode_if_newproto.h vnode_if_typedef.h: $S/tools/vnode_if.awk \ 572a9643ea8Slogwang $S/kern/vnode_if.src 573a9643ea8Slogwangvnode_if.h: vnode_if_newproto.h vnode_if_typedef.h 574a9643ea8Slogwang ${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -h 575a9643ea8Slogwangvnode_if_newproto.h: 576a9643ea8Slogwang ${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -p 577a9643ea8Slogwangvnode_if_typedef.h: 578a9643ea8Slogwang ${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -q 579a9643ea8Slogwang 580a9643ea8Slogwanginclude ${TOPDIR}/mk/kern.mk 581a9643ea8Slogwang 582