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