Index: Makefile
===================================================================
--- Makefile (nonexistent)
+++ Makefile (revision 5)
@@ -0,0 +1,290 @@
+
+COMPONENT_TARGETS = $(HARDWARE_INTEL_PC32)
+COMPONENT_TARGETS += $(HARDWARE_INTEL_PC64)
+COMPONENT_TARGETS += $(HARDWARE_EBOX_3350DX2)
+COMPONENT_TARGETS += $(HARDWARE_CB1X)
+COMPONENT_TARGETS += $(HARDWARE_CB2X)
+COMPONENT_TARGETS += $(HARDWARE_CB3X)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP2E)
+COMPONENT_TARGETS += $(HARDWARE_NANOPI_NEO)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PL2)
+COMPONENT_TARGETS += $(HARDWARE_WECHIP_TX6)
+COMPONENT_TARGETS += $(HARDWARE_FFRK3288)
+COMPONENT_TARGETS += $(HARDWARE_POIN2)
+COMPONENT_TARGETS += $(HARDWARE_RK3328_CC)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_EDGE)
+COMPONENT_TARGETS += $(HARDWARE_LEEZ_P710)
+COMPONENT_TARGETS += $(HARDWARE_M201)
+COMPONENT_TARGETS += $(HARDWARE_MXV)
+COMPONENT_TARGETS += $(HARDWARE_P201)
+COMPONENT_TARGETS += $(HARDWARE_NEXBOX_A95X)
+COMPONENT_TARGETS += $(HARDWARE_ODROID_C2)
+COMPONENT_TARGETS += $(HARDWARE_P212)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM)
+COMPONENT_TARGETS += $(HARDWARE_Q201)
+COMPONENT_TARGETS += $(HARDWARE_ENYBOX_X2)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM2)
+COMPONENT_TARGETS += $(HARDWARE_NIT6Q)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6DL_C)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6Q_C)
+COMPONENT_TARGETS += $(HARDWARE_BONE_BLACK)
+COMPONENT_TARGETS += $(HARDWARE_OMAP5UEVM)
+COMPONENT_TARGETS += $(HARDWARE_DRA7XXEVM)
+COMPONENT_TARGETS += $(HARDWARE_CI20)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_T1)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_M1)
+COMPONENT_TARGETS += $(HARDWARE_S824L)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN)
+COMPONENT_TARGETS += $(HARDWARE_S824L_LSB)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_SIFIVE_U740)
+
+
+NEED_ABS_PATH = true
+COMPONENT_IS_3PP = true
+
+
+include ../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES = sources/packages/n/openvpn
+
+REQUIRES = libs/lz4/1.9.4
+REQUIRES += libs/lzo/2.10
+REQUIRES += net/libnsl/1.3.0
+REQUIRES += net/openssl/1.1.1r
+REQUIRES += secure/pam/1.5.1
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version = 2.5.2
+tar_xz_archive = $(SRC_PACKAGE_PATH)/packages/n/openvpn/openvpn-$(version).tar.xz
+SRC_ARCHIVE = $(tar_xz_archive)
+SRC_DIR = $(TARGET_BUILD_DIR)/openvpn-$(version)
+src_dir_name = openvpn-$(version)
+src_done = $(TARGET_BUILD_DIR)/.source_done
+
+PATCHES = PATCHES
+
+build_dir = $(TARGET_BUILD_DIR)/build
+build_target = $(TARGET_BUILD_DIR)/.build_done
+install_target = $(TARGET_BUILD_DIR)/.install_done
+
+openvpn_init_d = $(CURDIR)/conf/rc.openvpn
+openvpn_sample = $(CURDIR)/conf/radix.conf
+openvpn_readme = $(CURDIR)/conf/README.TXT
+
+
+####### Targets
+
+PKG_GROUP = net
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+OPENVPN_PKG_NAME = openvpn
+OPENVPN_PKG_VERSION = 2.5.2
+OPENVPN_PKG_ARCH = $(PKGARCH)
+OPENVPN_PKG_DISTRO_NAME = $(DISTRO_NAME)
+OPENVPN_PKG_DISTRO_VERSION = $(DISTRO_VERSION)
+OPENVPN_PKG_GROUP = $(PKG_GROUP)
+### |---handy-ruler-------------------------------|
+OPENVPN_PKG_SHORT_DESCRIPTION = secure IP tunnel daemon
+OPENVPN_PKG_URL = $(BUG_URL)
+OPENVPN_PKG_LICENSE = GPLv2
+OPENVPN_PKG_DESCRIPTION_FILE = $(TARGET_BUILD_DIR)/$(OPENVPN_PKG_NAME)-pkg-description
+OPENVPN_PKG_DESCRIPTION_FILE_IN = $(OPENVPN_PKG_NAME)-pkg-description.in
+OPENVPN_PKG_INSTALL_SCRIPT = $(OPENVPN_PKG_NAME)-pkg-install.sh
+
+OPENVPN_PKG = $(CURDIR)/$(TARGET_BUILD_DIR)/$(OPENVPN_PKG_NAME)-package
+
+pkg_basename = $(OPENVPN_PKG_NAME)-$(OPENVPN_PKG_VERSION)-$(OPENVPN_PKG_ARCH)-$(OPENVPN_PKG_DISTRO_NAME)-$(OPENVPN_PKG_DISTRO_VERSION)
+
+pkg_archive = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)
+pkg_certificate = $(call cert-name,$(pkg_archive))
+pkg_signature = $(call sign-name,$(pkg_archive))
+pkg_description = $(call desc-name,$(pkg_archive))
+products = $(call pkg-files,$(pkg_archive))
+
+BUILD_TARGETS = $(build_target)
+BUILD_TARGETS += $(install_target)
+
+PRODUCT_TARGETS = $(products)
+
+ROOTFS_TARGETS = $(pkg_archive)
+
+
+include ../../../build-system/core.mk
+
+
+env_sysroot = DESTDIR=$(OPENVPN_PKG)
+
+
+extra_configure_switches = --libdir=/usr/lib$(LIBSUFFIX)
+extra_configure_switches += --docdir=/usr/share/doc/$(src_dir_name)
+extra_configure_switches += --mandir=/usr/share/man
+extra_configure_switches += --sysconfdir=/etc/openvpn
+extra_configure_switches += --localstatedir=/var
+
+extra_configure_switches += --with-crypto-library=openssl
+
+extra_configure_switches += --enable-lz4
+extra_configure_switches += --enable-lzo
+extra_configure_switches += --enable-iproute2
+extra_configure_switches += --enable-plugins
+extra_configure_switches += --enable-plugin-auth-pam
+extra_configure_switches += --enable-plugin-down-root
+extra_configure_switches += --disable-unit-tests
+
+ifeq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --enable-static=yes
+else
+extra_configure_switches += --enable-static=no
+endif
+extra_configure_switches += --enable-shared=yes
+
+
+CFLAGS += -Wformat-overflow=0
+LDFLAGS += -Wl,-rpath,/lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX):/usr/lib/../lib$(LIBSUFFIX)
+
+TARGET_BIN_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX)
+TARGET_LIB_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX):/usr/lib/../lib$(LIBSUFFIX)
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+ $(UNPACK_SRC_ARCHIVE)
+ $(APPLY_PATCHES)
+ @( cd $(SRC_DIR) ; autoreconf -vif )
+ @touch $@
+
+$(build_target): $(src_done)
+ @mkdir -p $(build_dir)
+ @cd $(build_dir) && $(BUILD_ENVIRONMENT) ../$(src_dir_name)/configure \
+ --prefix=/usr \
+ --build=$(BUILD) \
+ --host=$(TARGET) \
+ $(extra_configure_switches)
+ @cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE)
+ @touch $@
+
+$(install_target): $(build_target)
+ @mkdir -p $(OPENVPN_PKG)/etc/rc.d
+ @cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
+ # ======= Install a startup script =======
+ @cat $(openvpn_init_d) > $(OPENVPN_PKG)/etc/rc.d/rc.openvpn.new
+ @chmod 644 $(OPENVPN_PKG)/etc/rc.d/rc.openvpn.new
+ # ======= Create a decent config directories =======
+ @mkdir -p $(OPENVPN_PKG)/etc/openvpn/{certs,keys}
+ @chmod 750 $(OPENVPN_PKG)/etc/openvpn/{certs,keys}
+ @cat $(openvpn_readme) > $(OPENVPN_PKG)/etc/openvpn/README.TXT
+ # ======= Install Documentation =======
+ @if [ -d $(OPENVPN_PKG)/usr/share/man ]; then \
+ ( cd $(OPENVPN_PKG)/usr/share/man ; \
+ for manpagedir in `find . -type d -name "man*"` ; do \
+ ( cd $$manpagedir ; \
+ for eachpage in `find . -type l -maxdepth 1` ; do \
+ ln -s `readlink $$eachpage`.gz $$eachpage.gz ; \
+ rm $$eachpage ; \
+ done ; \
+ gzip -9 *.? ; \
+ ) \
+ done \
+ ) \
+ fi
+ @mkdir -p $(OPENVPN_PKG)/usr/doc/$(src_dir_name)
+ @cp -a $(SRC_DIR)/AUTHORS $(SRC_DIR)/COPYING $(SRC_DIR)/COPYRIGHT.GPL \
+ $(OPENVPN_PKG)/usr/doc/$(src_dir_name)
+ @mkdir -p $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)
+ @( cd $(SRC_DIR) ; \
+ cp -a AUTHORS COPYING COPYRIGHT.GPL Changes.rst INSTALL PORTS README* TODO* \
+ sample/sample-config-files sample/sample-keys sample/sample-scripts \
+ $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name) ; \
+ )
+ @( cd $(SRC_DIR) ; \
+ if [ -r ChangeLog ]; then \
+ DOCSDIR=`echo $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)` ; \
+ cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
+ touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
+ fi \
+ )
+ # ======= Add a link to sample-config-files =======
+ @( cd $(OPENVPN_PKG)/etc/openvpn ; \
+ ln -sf ../../usr/share/doc/$(src_dir_name)/sample-config-files . ; \
+ )
+ # ======= Install a reasonably generic sample config file =======
+ @mkdir -p $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)/sample-config-files
+ @cp -a $(openvpn_sample) $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)/sample-config-files
+ # ======= remove toolchain path from target libtool *.la files =======
+ @( cd $(OPENVPN_PKG)/usr/lib$(LIBSUFFIX)/openvpn/plugins ; \
+ sed -i "s,$(TARGET_DEST_DIR),,g" openvpn-plugin-auth-pam.la openvpn-plugin-down-root.la ; \
+ )
+ # ======= Install the same to $(TARGET_DEST_DIR) =======
+ $(call install-into-devenv, $(OPENVPN_PKG))
+ # ======= tune libtool *.la search path to the target destination for development =======
+ @( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/openvpn/plugins ; \
+ sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" openvpn-plugin-auth-pam.la \
+ openvpn-plugin-down-root.la ; \
+ sed -i "s,L/lib,L$(TARGET_DEST_DIR)/lib,g" openvpn-plugin-auth-pam.la \
+ openvpn-plugin-down-root.la ; \
+ sed -i "s,/lib/libpam,$(TARGET_DEST_DIR)/lib/libpam,g" openvpn-plugin-auth-pam.la \
+ openvpn-plugin-down-root.la ; \
+ )
+ # ======= Strip binaries =======
+ @( cd $(OPENVPN_PKG) ; \
+ find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+ find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+ )
+ifneq ($(PATCHELF),)
+ # ======= Set RPATH/RUNPATH for target binaries =======
+ @( cd $(OPENVPN_PKG)/usr/sbin ; \
+ for file in `find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
+ rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
+ if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
+ $(PATCHELF) --set-rpath $(TARGET_BIN_RPATH) $$file 1> /dev/null 2> /dev/null ; \
+ fi ; \
+ done ; \
+ )
+ # ======= Set RPATH/RUNPATH for target shared objects =======
+ @( cd $(OPENVPN_PKG)/usr/lib$(LIBSUFFIX)/openvpn/plugins ; \
+ for file in `find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
+ rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
+ if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
+ $(PATCHELF) --set-rpath $(TARGET_LIB_RPATH) $$file 1> /dev/null 2> /dev/null ; \
+ fi ; \
+ done ; \
+ )
+endif
+ @touch $@
+
+$(OPENVPN_PKG_DESCRIPTION_FILE): $(OPENVPN_PKG_DESCRIPTION_FILE_IN)
+ @cat $< | $(SED) -e "s/@VERSION@/$(version)/g" > $@
+
+$(pkg_certificate) : $(pkg_archive) ;
+$(pkg_signature) : $(pkg_archive) ;
+$(pkg_description) : $(pkg_archive) ;
+
+$(pkg_archive): $(install_target) $(OPENVPN_PKG_DESCRIPTION_FILE) $(OPENVPN_PKG_INSTALL_SCRIPT)
+ @cp $(OPENVPN_PKG_DESCRIPTION_FILE) $(OPENVPN_PKG)/.DESCRIPTION
+ @cp $(OPENVPN_PKG_INSTALL_SCRIPT) $(OPENVPN_PKG)/.INSTALL
+ @$(BUILD_PKG_REQUIRES) $(OPENVPN_PKG)/.REQUIRES
+ @echo "pkgname=$(OPENVPN_PKG_NAME)" > $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "pkgver=$(OPENVPN_PKG_VERSION)" >> $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "arch=$(OPENVPN_PKG_ARCH)" >> $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "distroname=$(OPENVPN_PKG_DISTRO_NAME)" >> $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "distrover=$(OPENVPN_PKG_DISTRO_VERSION)" >> $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "group=$(OPENVPN_PKG_GROUP)" >> $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "short_description=\"$(OPENVPN_PKG_SHORT_DESCRIPTION)\"" >> $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "url=$(OPENVPN_PKG_URL)" >> $(OPENVPN_PKG)/.PKGINFO ; \
+ echo "license=$(OPENVPN_PKG_LICENSE)" >> $(OPENVPN_PKG)/.PKGINFO
+ @$(PSEUDO) sh -c "cd $(OPENVPN_PKG) && \
+ chown -R root:root . && \
+ chown -R 0:99 etc/openvpn/{certs,keys} && \
+ $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."