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