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