libscrypt: New package
authorStefan Sørensen <stefan.sorensen@spectralink.com>
Thu, 9 Feb 2017 13:45:55 +0000 (14:45 +0100)
committerThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Sun, 12 Mar 2017 22:56:37 +0000 (23:56 +0100)
Signed-off-by: Stefan Sørensen <stefan.sorensen@spectralink.com>
[Thomas:
 - Add entry to DEVELOPERS file for the new package
 - Add dependency on !BR2_STATIC_LIBS, because the Makefile
   unconditionally builds a shared library
 - Use the "github" helper function to define <pkg>_SITE, get rid of
   <pkg>_SOURCE.
 - License is BSD-2c, not just BSD.
 - Add <pkg>_LICENSE_FILES variable.
 - Define LIBSCRYPT_DISABLE_STACK_PROTECTOR inside the
   BR2_TOOLCHAIN_HAS_SSP condition, and move from a
   LIBSCRYPT_POST_EXTRACT_HOOKS to a LIBSCRYPT_POST_PATCH_HOOKS.
 - Pass $(TARGET_CONFIGURE_OPTS) instead of just passing CC.
 - Pass $(TARGET_MAKE_ENV) when calling $(MAKE).]
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
DEVELOPERS
package/Config.in
package/libscrypt/Config.in [new file with mode: 0644]
package/libscrypt/libscrypt.hash [new file with mode: 0644]
package/libscrypt/libscrypt.mk [new file with mode: 0644]

index afd8f383a24d4a57378b688acf948c57bda4bf5b..70a5428b8c8df2b2f5181e507cca76de56be5ca9 100644 (file)
@@ -1440,6 +1440,9 @@ F:        package/libtasn1/
 F:     package/proxychains-ng/
 F:     package/yasm/
 
+N:     Stefan Sørensen <stefan.sorensen@spectralink.com>
+F:     package/libscrypt/
+
 N:     Stephan Hoffmann <sho@relinux.de>
 F:     package/cache-calibrator/
 F:     package/gtest/
index 7721727bbc2ac4ec8deafc635545f5cfb301dbb1..85e4dee843e01881e26babbe452b02361230bba9 100644 (file)
@@ -937,6 +937,7 @@ menu "Crypto"
        source "package/libmcrypt/Config.in"
        source "package/libmhash/Config.in"
        source "package/libnss/Config.in"
+       source "package/libscrypt/Config.in"
        source "package/libsecret/Config.in"
        source "package/libsha1/Config.in"
        source "package/libsodium/Config.in"
diff --git a/package/libscrypt/Config.in b/package/libscrypt/Config.in
new file mode 100644 (file)
index 0000000..b467fd6
--- /dev/null
@@ -0,0 +1,12 @@
+config BR2_PACKAGE_LIBSCRYPT
+       bool "libscrypt"
+       # Unconditionally builds a shared library
+       depends on !BR2_STATIC_LIBS
+       help
+         This is a library that implements the secure password
+         hashing function "scrypt".
+
+         http://www.lolware.net/libscrypt.html
+
+comment "libscrypt needs a toolchain w/ dynamic library"
+       depends on BR2_STATIC_LIBS
diff --git a/package/libscrypt/libscrypt.hash b/package/libscrypt/libscrypt.hash
new file mode 100644 (file)
index 0000000..bf3f441
--- /dev/null
@@ -0,0 +1,2 @@
+# Locally calculated
+sha256 68e377e79745c10d489b759b970e52d819dbb80dd8ca61f8c975185df3f457d3        libscrypt-v1.21.tar.gz
diff --git a/package/libscrypt/libscrypt.mk b/package/libscrypt/libscrypt.mk
new file mode 100644 (file)
index 0000000..8f72d67
--- /dev/null
@@ -0,0 +1,34 @@
+################################################################################
+#
+# libscrypt
+#
+################################################################################
+
+LIBSCRYPT_VERSION = v1.21
+LIBSCRYPT_SITE = $(call github,technion,libscrypt,$(LIBSCRYPT_VERSION))
+LIBSCRYPT_LICENSE = BSD-2c
+LIBSCRYPT_LICENSE_FILES = LICENSE
+LIBSCRYPT_INSTALL_STAGING = YES
+
+ifeq ($(BR2_TOOLCHAIN_HAS_SSP),)
+define LIBSCRYPT_DISABLE_STACK_PROTECTOR
+       $(SED) 's/-fstack-protector//g' $(@D)/Makefile
+endef
+LIBSCRYPT_POST_PATCH_HOOKS += LIBSCRYPT_DISABLE_STACK_PROTECTOR
+endif
+
+define LIBSCRYPT_BUILD_CMDS
+       $(TARGET_MAKE_ENV) $(MAKE) -C $(@D) $(TARGET_CONFIGURE_OPTS)
+endef
+
+define LIBSCRYPT_INSTALL_STAGING_CMDS
+        $(TARGET_MAKE_ENV) $(MAKE) -C $(@D) PREFIX=/usr \
+               DESTDIR=$(STAGING_DIR) install
+endef
+
+define LIBSCRYPT_INSTALL_TARGET_CMDS
+        $(TARGET_MAKE_ENV) $(MAKE) -C $(@D) PREFIX=/usr \
+               DESTDIR=$(TARGET_DIR) install
+endef
+
+$(eval $(generic-package))