You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

143 lines
4.3 KiB

  1. #
  2. # Copyright (C) 2019 Lucian Cristian
  3. #
  4. # This is free software, licensed under the GNU General Public License v2.
  5. # See /LICENSE for more information.
  6. #
  7. include $(TOPDIR)/rules.mk
  8. PKG_NAME:=nss
  9. PKG_VERSION:=3.47
  10. PKG_RELEASE:=1
  11. PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
  12. PKG_SOURCE_URL:= \
  13. https://download.cdn.mozilla.net/pub/security/$(PKG_NAME)/releases/NSS_$(subst .,_,$(PKG_VERSION))_RTM/src \
  14. https://archive.mozilla.org/pub/security/$(PKG_NAME)/releases/NSS_$(subst .,_,$(PKG_VERSION))_RTM/src
  15. PKG_HASH:=6cd0c4438b616bdacc0b5f25ff1506b0d07ee97ea6c95d514c5487200a155fa7
  16. PKG_MAINTAINER:=Lucian Cristian <lucian.cristian@gmail.com>
  17. PKG_LICENCE:=MPL-2.0
  18. PKG_LICENSE_FILES:=nss/COPYING
  19. PKG_CPE_ID:=cpe:/a:mozilla:network_security_services
  20. PKG_BUILD_PARALLEL:=0
  21. include $(INCLUDE_DIR)/package.mk
  22. define Package/libnss
  23. SECTION:=libs
  24. SUBMENU:=SSL
  25. CATEGORY:=Libraries
  26. TITLE:=Mozilla's SSL and TLS implementation
  27. URL:=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS
  28. DEPENDS:=+libpthread +libsqlite3 +nspr
  29. endef
  30. define Package/nss-utils
  31. SECTION:=utils
  32. CATEGORY:=Utilities
  33. TITLE:=Utilities for Mozilla's SSL and TLS implementation
  34. URL:=https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS
  35. DEPENDS:=+libnss
  36. endef
  37. define Package/libnss/description
  38. Network Security Services (NSS) is a set of libraries designed to support
  39. cross-platform development of security-enabled client and server applications.
  40. Applications built with NSS can support SSL v2 and v3, TLS, PKCS 5, PKCS 7,
  41. PKCS 11, PKCS 12, S/MIME, X.509 v3 certificates, and other security standards.
  42. endef
  43. CONFIGURE_PATH = ./nss
  44. MAKE_PATH = ./nss
  45. LBITS = $(shell $(TARGET_CC) -dM -E - </dev/null | grep -q "__LP64__" && echo 64 || echo 32)
  46. ifeq ($(LBITS),64)
  47. export USE_64=1
  48. endif
  49. TARGET_LDFLAGS += -Wl,--gc-sections,--as-needed
  50. export CROSS_COMPILE=1
  51. export BUILD_OPT=1
  52. export NATIVE_CC=$(HOSTCC)
  53. export NATIVE_FLAGS=$(HOST_CFLAGS)
  54. export NSDISTMODE=copy
  55. export NSS_ENABLE_WERROR=0
  56. export NSS_DISABLE_GTESTS=1
  57. export NSS_USE_SYSTEM_SQLITE=1
  58. export OS_TARGET=Linux
  59. export OS_ARCH=Linux
  60. export OS_TEST=$(ARCH)
  61. export CPU_ARCH=$(ARCH)
  62. export fpic=$(FPIC)
  63. export NSPR_INCLUDE_DIR=$(STAGING_DIR)/usr/include/nspr
  64. export SEED_ONLY_DEV_URANDOM=1
  65. export OS_REL_CFLAGS=$(TARGET_CFLAGS)
  66. export NS_USE_GCC=1
  67. export FREEBL_NO_DEPEND=1
  68. #size optimisation, seems to not impact speed
  69. export NSS_DISABLE_DBM=1
  70. export NSS_PKIX_NO_LDAP=1
  71. export ALLOW_OPT_CODE_SIZE=1
  72. export OPT_CODE_SIZE=1
  73. #native compile nsinstall
  74. define Build/Prepare
  75. $(call Build/Prepare/Default)
  76. USE_NATIVE=1 OS_REL_CFLAGS="$(HOST_CFLAGS)" LDFLAGS="$(HOST_LDFLAGS)" CC="$(HOSTCC)" \
  77. $(MAKE) -C $(PKG_BUILD_DIR)/nss/coreconf/nsinstall
  78. endef
  79. define Package/libnss/conffiles
  80. /etc/pki/nssdb
  81. endef
  82. define Build/InstallDev
  83. $(INSTALL_DIR) \
  84. $(1)/usr/include/nss \
  85. $(1)/usr/lib \
  86. $(1)/usr/lib/pkgconfig
  87. $(CP) $(PKG_BUILD_DIR)/dist/private/nss/*.h \
  88. $(1)/usr/include/nss/
  89. $(CP) $(PKG_BUILD_DIR)/dist/public/nss/*.h \
  90. $(1)/usr/include/nss/
  91. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/lib/*.so \
  92. $(1)/usr/lib/
  93. $(CP) $(PKG_BUILD_DIR)/nss/config/*.pc \
  94. $(1)/usr/lib/pkgconfig/
  95. endef
  96. define Package/nss-utils/install
  97. $(INSTALL_DIR) \
  98. $(1)/usr/bin
  99. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/bin/certutil $(1)/usr/bin
  100. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/bin/pk12util $(1)/usr/bin
  101. endef
  102. #for now pack only libreswan needed libs
  103. define Package/libnss/install
  104. $(INSTALL_DIR) \
  105. $(1)/usr/lib \
  106. $(1)/etc/pki/nssdb \
  107. $(1)/etc/ipsec.d
  108. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/lib/libfreebl3.so $(1)/usr/lib/
  109. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/lib/libnss3.so $(1)/usr/lib/
  110. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/lib/libnssutil3.so $(1)/usr/lib/
  111. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/lib/libsmime3.so $(1)/usr/lib/
  112. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/lib/libsoftokn3.so $(1)/usr/lib/
  113. $(CP) $(PKG_BUILD_DIR)/dist/build_dir/lib/libssl3.so $(1)/usr/lib/
  114. # Provide databases with a blank certificate
  115. $(CP) ./files/blank-cert9.db $(1)/etc/pki/nssdb/cert9.db
  116. $(CP) ./files/blank-key4.db $(1)/etc/pki/nssdb/key4.db
  117. $(CP) ./files/system-pkcs11.txt $(1)/etc/pki/nssdb/pkcs11.txt
  118. ln -s /etc/pki/nssdb/cert9.db $(1)/etc/ipsec.d/cert9.db
  119. ln -s /etc/pki/nssdb/key4.db $(1)/etc/ipsec.d/key4.db
  120. ln -s /etc/pki/nssdb/pkcs11.txt $(1)/etc/ipsec.d/pkcs11.txt
  121. endef
  122. $(eval $(call BuildPackage,nss-utils))
  123. $(eval $(call BuildPackage,libnss))