f-stack/lib/Makefile

751 lines
14 KiB
Makefile

#
# Copyright (c) 2013 Patrick Kelsey. All rights reserved.
# Copyright (C) 2017-2021 THL A29 Limited, a Tencent company.
# All rights reserved.
#
# Derived in part from libuinet's Makefile.
#
# Derived from FreeBSD auto-generated kernel Makefile and
# machine-specific Makefile templates
#
TOPDIR?=${CURDIR}/..
S=${TOPDIR}/freebsd
C=${TOPDIR}/freebsd/contrib/ck/include
MACHINE_INCLUDES_ROOT:=${CURDIR}/machine_include
OVERRIDE_INCLUDES_ROOT:=${CURDIR}/include
X86_INCLUDES=0
PREFIX=/usr/local
PREFIX_LIB=${PREFIX}/lib
PREFIX_INCLUDE=/usr/local/include
PREFIX_BIN=/usr/local/bin
F-STACK_CONF=/etc/f-stack.conf
F-STACK_VERSION=1.24
TGT_OS=$(shell uname)
ifeq ($(TGT_OS),FreeBSD)
CC=gcc
endif
HOST_OS:=$(shell uname -s)
#DEBUG=-O0 -gdwarf-2 -g3 -Wno-format-truncation
# No DPDK KNI support on FreeBSD
ifneq ($(TGT_OS),FreeBSD)
FF_KNI=1
#FF_KNI_KNI=1
endif
#FF_FLOW_ISOLATE=1
#FF_FDIR=1
# NETGRAPH drivers ipfw
#FF_NETGRAPH=1
#FF_IPFW=1
#FF_USE_PAGE_ARRAY=1
#FF_ZC_SEND=1
FF_INET6=1
# TCPHPTS drivers rack and bbr
FF_TCPHPTS=1
FF_EXTRA_TCP_STACKS=1
include ${TOPDIR}/mk/kern.pre.mk
ifneq ($(shell pkg-config --exists libdpdk && echo 0),0)
$(error "no installation of DPDK found, maybe you shuld export environment variable `PKG_CONFIG_PATH`")
endif
PKGCONF ?= pkg-config
DPDK_CFLAGS= -Wall -Wno-deprecated-declarations -Werror $(shell $(PKGCONF) --cflags libdpdk)
KERNPREINCLUDES:= ${INCLUDES}
INCLUDES= -I${OVERRIDE_INCLUDES_ROOT} ${KERNPREINCLUDES}
INCLUDES+= -I./machine_include
INCLUDES+= -I./opt
# Include search path for files that only include host OS headers
HOST_INCLUDES= -I.
# Use libepoll shim on FreeBSD
ifeq ($(TGT_OS),FreeBSD)
HOST_INCLUDES+= -I/usr/local/include/libepoll-shim
endif
ifndef DEBUG
HOST_CFLAGS = -O2 -frename-registers -funswitch-loops -fweb -Wno-format-truncation
else
HOST_CFLAGS = ${DEBUG}
endif
ifdef FF_KNI
HOST_CFLAGS+= -DFF_KNI
endif
ifdef FF_KNI_KNI
HOST_CFLAGS+= -DFF_KNI_KNI
endif
HOST_CFLAGS+= ${DPDK_CFLAGS}
HOST_CFLAGS+= ${CONF_CFLAGS}
ifdef FF_FDIR
HOST_CFLAGS+= -DFF_FDIR
endif
ifdef FF_FLOW_ISOLATE
HOST_CFLAGS+= -DFF_FLOW_ISOLATE
endif
ifdef FF_NETGRAPH
HOST_CFLAGS+= -DFF_NETGRAPH
endif
ifdef FF_IPFW
HOST_CFLAGS+= -DFF_IPFW
CFLAGS+= -DFF_IPFW
endif
ifdef FF_USE_PAGE_ARRAY
HOST_CFLAGS+= -DFF_USE_PAGE_ARRAY
endif
HOST_CFLAGS+= -DINET
CFLAGS+= -DINET
GCCVERGE10 = $(shell expr `gcc -dumpversion | cut -f1 -d.` \>= 10)
ifeq "$(GCCVERGE10)" "1"
CFLAGS+= -Wno-error=stringop-overflow
endif
GCCVERGE11 = $(shell expr `gcc -dumpversion | cut -f1 -d.` \>= 11)
ifeq "$(GCCVERGE11)" "1"
CFLAGS+= -Wno-error=stringop-overread
endif
GCCVERGE13 = $(shell expr `gcc -dumpversion | cut -f1 -d.` \>= 13)
ifeq "$(GCCVERGE13)" "1"
CFLAGS+= -Wno-error=dangling-pointer
endif
ifdef FF_INET6
HOST_CFLAGS+= -DINET6
CFLAGS+= -DINET6
endif
ifdef FF_TCPHPTS
CFLAGS+= -DTCPHPTS -DRATELIMIT
endif
ifdef FF_IPSEC
HOST_CFLAGS+= -DIPSEC
CFLAGS+= -DIPSEC
endif
HOST_C= ${CC} -c $(HOST_CFLAGS) ${HOST_INCLUDES} ${WERROR} ${PROF} $<
ifneq ($(filter amd64 i386,${MACHINE_CPUARCH}),)
X86_INCLUDES=1
endif
#
# Distilled from FreeBSD src/sys/conf/Makefile.amd64
#
ifeq (${MACHINE_CPUARCH},amd64)
endif
#
# Distilled from FreeBSD src/sys/conf/Makefile.arm
#
ifeq (${MACHINE_CPUARCH},arm)
ifneq (${COMPILER_TYPE},clang)
CFLAGS += -mno-thumb-interwork
endif
endif
#
# fix the MACHINE_CPUARCH to match the FreeBSD directory name
#
ifeq (${MACHINE_CPUARCH},aarch64)
MACHINE_CPUARCH=arm64
endif
#
# Distilled from FreeBSD src/sys/conf/Makefile.i386
#
ifeq (${MACHINE_CPUARCH},i386)
MACHINE=i386
endif
#
# Distilled from FreeBSD src/sys/conf/Makefile.mips
#
ifeq (${MACHINE_CPUARCH},mips)
# We default to the MIPS32 ISA, if none specified in the
# kernel configuration file.
ARCH_FLAGS?=-march=mips32
HACK_EXTRA_FLAGS=-shared
CFLAGS+=${EXTRA_FLAGS} $(ARCH_FLAGS)
HACK_EXTRA_FLAGS+=${EXTRA_FLAGS} $(ARCH_FLAGS)
endif
CFLAGS+= -DFSTACK
ifdef FF_ZC_SEND
CFLAGS+= -DFSTACK_ZC_SEND
endif
# add for LVS tcp option toa, disabled by default
# CFLAGS+= -DLVS_TCPOPT_TOA
VPATH+= $S/${MACHINE_CPUARCH}/${MACHINE_CPUARCH}
VPATH+= $S/kern
VPATH+= $S/x86
VPATH+= $S/crypto
VPATH+= $S/crypto/aesni
VPATH+= $S/crypto/blowfish
VPATH+= $S/crypto/camellia
VPATH+= $S/crypto/des
VPATH+= $S/crypto/rijndael
VPATH+= $S/crypto/sha2
VPATH+= $S/crypto/siphash
VPATH+= $S/net
VPATH+= $S/net/route
ifdef FF_NETGRAPH
VPATH+= $S/netgraph
endif
VPATH+= $S/netinet
VPATH+= $S/netinet/libalias
VPATH+= $S/netinet/cc
ifdef FF_INET6
VPATH+= $S/netinet6
endif
ifdef FF_EXTRA_TCP_STACKS
VPATH+= $S/netinet/tcp_stacks
endif
VPATH+= $S/netipsec
ifdef FF_IPFW
VPATH+= $S/netpfil/ipfw
endif
VPATH+= $S/opencrypto
VPATH+= $S/vm
VPATH+= $S/libkern
FF_SRCS+= \
ff_compat.c \
ff_glue.c \
ff_freebsd_init.c \
ff_init_main.c \
ff_kern_condvar.c \
ff_kern_environment.c \
ff_kern_intr.c \
ff_kern_subr.c \
ff_kern_synch.c \
ff_kern_timeout.c \
ff_subr_epoch.c \
ff_lock.c \
ff_syscall_wrapper.c \
ff_subr_prf.c \
ff_vfs_ops.c \
ff_veth.c \
ff_route.c
ifdef FF_NETGRAPH
FF_SRCS+= \
ff_ng_base.c \
ff_ngctl.c
endif
FF_HOST_SRCS+= \
ff_host_interface.c \
ff_thread.c \
ff_config.c \
ff_ini_parser.c \
ff_dpdk_if.c \
ff_dpdk_pcap.c \
ff_epoll.c \
ff_init.c
ifdef FF_KNI
FF_HOST_SRCS+= \
ff_dpdk_kni.c
endif
ifdef FF_USE_PAGE_ARRAY
FF_HOST_SRCS+= \
ff_memory.c
endif
ifdef FF_IPSEC
CRYPTO_SRCS+= \
#aesni.c \
aesni_wrap.c \
bf_ecb.c \
bf_enc.c \
bf_skey.c \
camellia.c \
camellia-api.c \
des_ecb.c \
des_enc.c \
des_setkey.c \
rijndael-alg-fst.c \
rijndael-api.c \
sha1.c \
sha256c.c \
sha512c.c \
siphash.c
else
CRYPTO_SRCS+= \
sha1.c \
siphash.c
endif
KERN_SRCS+= \
kern_descrip.c \
kern_event.c \
kern_fail.c \
kern_khelp.c \
kern_hhook.c \
kern_linker.c \
kern_mbuf.c \
kern_module.c \
kern_mtxpool.c \
kern_ntptime.c \
kern_osd.c \
kern_sysctl.c \
kern_tc.c \
kern_uuid.c \
link_elf.c \
md5c.c \
subr_capability.c \
subr_counter.c \
subr_eventhandler.c \
subr_kobj.c \
subr_lock.c \
subr_module.c \
subr_param.c \
subr_pcpu.c \
subr_sbuf.c \
subr_taskqueue.c \
subr_unit.c \
subr_smr.c \
sys_capability.c \
sys_generic.c \
sys_socket.c \
uipc_accf.c \
uipc_mbuf.c \
uipc_mbuf2.c \
uipc_domain.c \
uipc_sockbuf.c \
uipc_socket.c \
uipc_syscalls.c
KERN_MHEADERS+= \
bus_if.m \
device_if.m \
linker_if.m
KERN_MSRCS+= \
linker_if.m
ifeq (${MACHINE_CPUARCH},arm64)
LIBKERN_SRCS+= \
bcd.c \
inet_ntoa.c \
jenkins_hash.c \
strlcpy.c \
strnlen.c \
fls.c \
flsl.c
else
LIBKERN_SRCS+= \
bcd.c \
gsb_crc32.c \
inet_ntoa.c \
jenkins_hash.c \
strlcpy.c \
strnlen.c
endif
MACHINE_SRCS+= \
in_cksum.c
NET_SRCS+= \
bpf.c \
bridgestp.c \
if.c \
if_bridge.c \
if_clone.c \
if_dead.c \
if_ethersubr.c \
if_loop.c \
if_llatbl.c \
if_media.c \
if_spppfr.c \
if_spppsubr.c \
if_vlan.c \
if_vxlan.c \
in_fib.c \
in_gif.c \
ip_reass.c \
netisr.c \
pfil.c \
radix.c \
raw_cb.c \
raw_usrreq.c \
route.c \
route_ctl.c \
route_tables.c \
route_helpers.c \
route_ifaddrs.c \
route_temporal.c \
nhop_utils.c \
nhop.c \
nhop_ctl.c \
rtsock.c \
slcompress.c
ifdef FF_NETGRAPH
NETGRAPH_SRCS += \
ng_async.c \
ng_atmllc.c \
ng_bridge.c \
ng_car.c \
ng_cisco.c \
ng_deflate.c \
ng_echo.c \
ng_eiface.c \
ng_etf.c \
ng_ether.c \
ng_ether_echo.c \
ng_frame_relay.c \
ng_gif.c \
ng_gif_demux.c \
ng_hole.c \
ng_hub.c \
ng_iface.c \
ng_ip_input.c \
ng_ipfw.c \
ng_ksocket.c \
ng_l2tp.c \
ng_lmi.c \
ng_nat.c \
ng_one2many.c \
ng_parse.c \
ng_patch.c \
ng_pipe.c \
ng_ppp.c \
ng_pppoe.c \
ng_pptpgre.c \
ng_pred1.c \
ng_rfc1490.c \
ng_sample.c \
ng_socket.c \
ng_source.c \
ng_split.c \
ng_sppp.c \
ng_tag.c \
ng_tcpmss.c \
ng_tee.c \
ng_UI.c \
ng_vjc.c \
ng_vlan.c
endif
NETINET_SRCS+= \
if_ether.c \
if_gif.c \
igmp.c \
in.c \
in_mcast.c \
in_pcb.c \
in_proto.c \
in_rmx.c \
ip_carp.c \
ip_divert.c \
ip_ecn.c \
ip_encap.c \
ip_fastfwd.c \
ip_icmp.c \
ip_id.c \
ip_input.c \
ip_mroute.c \
ip_options.c \
ip_output.c \
raw_ip.c \
tcp_debug.c \
tcp_hostcache.c \
tcp_input.c \
tcp_lro.c \
tcp_offload.c \
tcp_output.c \
tcp_reass.c \
tcp_sack.c \
tcp_subr.c \
tcp_syncache.c \
tcp_timer.c \
tcp_timewait.c \
tcp_usrreq.c \
udp_usrreq.c \
cc.c \
cc_newreno.c \
cc_htcp.c \
cc_cubic.c \
alias.c \
alias_db.c \
alias_mod.c \
alias_proxy.c \
alias_sctp.c \
alias_util.c
ifdef FF_INET6
NETINET6_SRCS+= \
dest6.c \
frag6.c \
icmp6.c \
in6.c \
in6_ifattach.c \
in6_mcast.c \
in6_pcb.c \
in6_pcbgroup.c \
in6_proto.c \
in6_rmx.c \
in6_src.c \
ip6_forward.c \
ip6_id.c \
ip6_input.c \
ip6_fastfwd.c \
ip6_mroute.c \
ip6_output.c \
mld6.c \
nd6.c \
nd6_nbr.c \
nd6_rtr.c \
raw_ip6.c \
route6.c \
scope6.c \
send.c \
udp6_usrreq.c \
in6_cksum.c \
in6_fib.c \
in6_gif.c
#ip6_gre.c
#ip6_ipsec.c
#sctp6_usrreq.c
#in6_rss.c
ifdef FF_TCPHPTS
EXTRA_TCP_STACKS_SRCS+= \
tcp_hpts.c
endif
ifdef FF_EXTRA_TCP_STACKS
EXTRA_TCP_STACKS_SRCS+= \
subr_filter.c \
tcp_ratelimit.c \
arc4random_uniform.c \
sack_filter.c \
rack_bbr_common.c \
rack.c \
bbr.c
endif
ifneq ($(TGT_OS),FreeBSD)
ifndef FF_KNI
FF_HOST_SRCS+= \
ff_dpdk_kni.c
endif #FF_KNI
endif #FreeBSD OS Check
endif #INET6
ifdef FF_IPFW
NETIPFW_SRCS+= \
ip_fw_dynamic.c \
ip_fw_eaction.c \
ip_fw_iface.c \
ip_fw_log.c \
ip_fw_nat.c \
ip_fw_pfil.c \
ip_fw_sockopt.c \
ip_fw_table.c \
ip_fw_table_algo.c \
ip_fw_table_value.c \
ip_fw2.c
endif
ifdef FF_IPSEC
NETIPSEC_SRCS+= \
ipsec.c \
ipsec_input.c \
ipsec_mbuf.c \
ipsec_output.c \
key.c \
key_debug.c \
keysock.c \
xform_ah.c \
xform_esp.c \
xform_ipcomp.c
endif
# only if TCP_SIGNTAURE is defined
#xform_tcp.c
ifdef FF_IPSEC
OPENCRYPTO_SRCS+= \
criov.c \
crypto.c \
cryptosoft.c \
cryptodeflate.c \
rmd160.c \
xform.c
endif
# cryptodev.c
OPENCRYPTO_MHEADERS= cryptodev_if.m
OPENCRYPTO_MSRCS= cryptodev_if.m
VM_SRCS+= \
uma_core.c
MHEADERS= $(patsubst %.m,%.h,${KERN_MHEADERS})
MHEADERS+= vnode_if.h vnode_if_newproto.h vnode_if_typedef.h
MHEADERS+= $(patsubst %.m,%.h,${OPENCRYPTO_MHEADERS})
MSRCS= $(patsubst %.m,%.c,${KERN_MSRCS})
MSRCS+= $(patsubst %.m,%.c,${OPENCRYPTO_MSRCS})
ASM_SRCS = ${CRYPTO_ASM_SRCS}
SRCS= ${FF_SRCS} ${CRYPTO_SRCS} ${KERN_SRCS} ${LIBKERN_SRCS} ${MACHINE_SRCS}
SRCS+= ${MSRCS} ${NET_SRCS} ${NETGRAPH_SRCS} ${NETINET_SRCS} ${NETINET6_SRCS} ${EXTRA_TCP_STACKS_SRCS}
SRCS+= ${NETIPSEC_SRCS} ${NETIPFW_SRCS} ${OPENCRYPTO_SRCS} ${VM_SRCS}
# If witness is enabled.
# SRCS+= ${KERN_WITNESS_SRCS}
# Extra FreeBSD kernel module srcs.
SRCS+= ${KMOD_SRCS}
HOST_SRCS = ${FF_HOST_SRCS}
ASM_OBJS+= $(patsubst %.S,%.o,${ASM_SRCS})
OBJS+= $(patsubst %.c,%.o,${SRCS})
HOST_OBJS+= $(patsubst %.c,%.o,${HOST_SRCS})
all: libfstack.a
#
# The library is built by first incrementally linking all the object
# to resolve internal references. Then, all symbols are made local.
# Then, only the symbols that are part of the API are made
# externally available.
#
libfstack.a: machine_includes ff_api.symlist ${MHEADERS} ${MSRCS} ${HOST_OBJS} ${ASM_OBJS} ${OBJS}
${LD} -d -r -o $*.ro ${ASM_OBJS} ${OBJS}
nm $*.ro | grep -v ' U ' | cut -d ' ' -f 3 > $*_localize_list.tmp
objcopy --localize-symbols=$*_localize_list.tmp $*.ro
rm $*_localize_list.tmp
objcopy --globalize-symbols=ff_api.symlist $*.ro
rm -f $@
ar -cqs $@ $*.ro ${HOST_OBJS}
rm -f $*.ro
${HOST_OBJS}: %.o: %.c
${HOST_C}
${ASM_OBJS}: %.o: %.S ${IMACROS_FILE}
${NORMAL_S}
${OBJS}: %.o: %.c ${IMACROS_FILE}
${NORMAL_C}
.SUFFIXES: .m
.m.c:
${AWK} -f $S/tools/makeobjops.awk $< -c
.m.h:
${AWK} -f $S/tools/makeobjops.awk $< -h
.PHONY: clean
clean:
rm -f libfstack.a
rm -f ${MHEADERS} ${MSRCS} ${HOST_OBJS} ${ASM_OBJS} ${OBJS} ${PROGRAM} ${IMACROS_FILE}
rm -rf ${MACHINE_INCLUDES_ROOT}
.PHONY: machine_includes
machine_includes:
@rm -rf ${MACHINE_INCLUDES_ROOT}
@mkdir -p ${MACHINE_INCLUDES_ROOT}/machine
@cp -r $S/${MACHINE_CPUARCH}/include/* ${MACHINE_INCLUDES_ROOT}/machine
@if [ "${X86_INCLUDES}" != "0" ]; then \
mkdir -p ${MACHINE_INCLUDES_ROOT}/x86; \
cp -r $S/x86/include/* ${MACHINE_INCLUDES_ROOT}/x86; \
fi
#
# Distilled from FreeBSD src/sys/conf/kern.post.mk
#
vnode_if.h vnode_if_newproto.h vnode_if_typedef.h: $S/tools/vnode_if.awk \
$S/kern/vnode_if.src
vnode_if.h: vnode_if_newproto.h vnode_if_typedef.h
${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -h
vnode_if_newproto.h:
${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -p
vnode_if_typedef.h:
${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -q
include ${TOPDIR}/mk/kern.mk
install:
rm -rf ${PREFIX_LIB}/libfstack.a.${F-STACK_VERSION}
rm -rf ${PREFIX_LIB}/libfstack.a
rm -rf ${PREFIX_INCLUDE}/ff_config.h
rm -rf ${PREFIX_INCLUDE}/ff_api.h
rm -rf ${PREFIX_INCLUDE}/ff_event.h
rm -rf ${PREFIX_INCLUDE}/ff_errno.h
rm -rf ${PREFIX_INCLUDE}/ff_epoll.h
rm -rf ${PREFIX_BIN}/ff_start
cp -f libfstack.a ${PREFIX_LIB}/libfstack.a.${F-STACK_VERSION}
ln -sf ${PREFIX_LIB}/libfstack.a.${F-STACK_VERSION} ${PREFIX_LIB}/libfstack.a
cp -f ff_config.h ${PREFIX_INCLUDE}/ff_config.h
cp -f ff_api.h ${PREFIX_INCLUDE}/ff_api.h
cp -f ff_event.h ${PREFIX_INCLUDE}/ff_event.h
cp -f ff_errno.h ${PREFIX_INCLUDE}/ff_errno.h
cp -f ff_epoll.h ${PREFIX_INCLUDE}/ff_epoll.h
cp -f ${TOPDIR}/start.sh ${PREFIX_BIN}/ff_start
test -f '${F-STACK_CONF}' || cp -f ${TOPDIR}/config.ini ${F-STACK_CONF}
uninstall:
rm -rf ${PREFIX_LIB}/libfstack.a.${F-STACK_VERSION}
rm -rf ${PREFIX_LIB}/libfstack.a
rm -rf ${PREFIX_INCLUDE}/ff_config.h
rm -rf ${PREFIX_INCLUDE}/ff_api.h
rm -rf ${PREFIX_INCLUDE}/ff_event.h
rm -rf ${PREFIX_INCLUDE}/ff_errno.h
rm -rf ${PREFIX_INCLUDE}/ff_epoll.h
rm -rf ${PREFIX_BIN}/ff_start
rm -rf ${F-STACK_CONF}