]> rtime.felk.cvut.cz Git - coffee/buildroot.git/commitdiff
libselinux: bump version to 2.6
authorAdam Duskett <Aduskett@gmail.com>
Mon, 9 Jan 2017 16:15:20 +0000 (11:15 -0500)
committerThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Wed, 25 Jan 2017 10:25:26 +0000 (23:25 +1300)
This commit also adds a patch that allows libselinux 2.6 to build
properly with older compilers such as gcc 4.4.

Signed-off-by: Adam Duskett <aduskett@codeblue.com>
[Thomas: add patch to fix gcc 4.4 build issue.]
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
package/libselinux/0001-libselinux-src-regex.c-support-old-compilers-for-the.patch [new file with mode: 0644]
package/libselinux/libselinux.hash
package/libselinux/libselinux.mk

diff --git a/package/libselinux/0001-libselinux-src-regex.c-support-old-compilers-for-the.patch b/package/libselinux/0001-libselinux-src-regex.c-support-old-compilers-for-the.patch
new file mode 100644 (file)
index 0000000..3bda607
--- /dev/null
@@ -0,0 +1,47 @@
+From e0803c0bdbb1abf06b6b5bb1b52fdb733505b8f7 Mon Sep 17 00:00:00 2001
+From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
+Date: Wed, 25 Jan 2017 22:41:02 +1300
+Subject: [PATCH] src/regex.c: support old compilers for the endian
+ check
+
+libselinux 2.6 has added some code in regex.c that uses __BYTE_ORDER__
+to determine the system endianness. Unfortunately, this definition
+provided directly by the compiler doesn't exist in older gcc versions
+such as gcc 4.4.
+
+In order to address this, this commit extends the logic to use
+<endian.h> definitions if __BYTE_ORDER__ is not provided by the
+compiler. This allows libselinux to build properly with gcc 4.4.
+
+Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
+---
+ src/regex.c | 13 ++++++++++++-
+ 1 file changed, 12 insertions(+), 1 deletion(-)
+
+diff --git a/src/regex.c b/src/regex.c
+index a3b427b..0c5ad27 100644
+--- a/src/regex.c
++++ b/src/regex.c
+@@ -13,7 +13,18 @@
+ #endif
+ #ifndef __BYTE_ORDER__
+-#error __BYTE_ORDER__ not defined. Unable to determine endianness.
++
++/* If the compiler doesn't define __BYTE_ORDER__, try to use the C
++ * library <endian.h> header definitions. */
++#include <endian.h>
++#ifndef __BYTE_ORDER
++#error Neither __BYTE_ORDER__ nor __BYTE_ORDER defined. Unable to determine endianness.
++#endif
++
++#define __ORDER_LITTLE_ENDIAN __LITTLE_ENDIAN
++#define __ORDER_BIG_ENDIAN __BIG_ENDIAN
++#define __BYTE_ORDER__ __BYTE_ORDER
++
+ #endif
+ #ifdef USE_PCRE2
+-- 
+2.7.4
+
index a4c34408be9836069dde54431deeb51bcc85adb2..76130b2dc003880f94c95f1fd20ae7d2a3b164e1 100644 (file)
@@ -1,2 +1,2 @@
 # Locally computed
-sha256 94c9e97706280bedcc288f784f67f2b9d3d6136c192b2c9f812115edba58514f libselinux-2.5.tar.gz
+sha256 4ea2dde50665c202253ba5caac7738370ea0337c47b251ba981c60d24e1a118a libselinux-2.6.tar.gz
index 165ac4c30d82f80bb3cb67bb11984d091af6d354..44120c4d3ba1eca2e7b72a7daf12e6f636ac8f7b 100644 (file)
@@ -4,8 +4,8 @@
 #
 ################################################################################
 
-LIBSELINUX_VERSION = 2.5
-LIBSELINUX_SITE = https://raw.githubusercontent.com/wiki/SELinuxProject/selinux/files/releases/20160223
+LIBSELINUX_VERSION = 2.6
+LIBSELINUX_SITE = https://raw.githubusercontent.com/wiki/SELinuxProject/selinux/files/releases/20161014
 LIBSELINUX_LICENSE = Public Domain
 LIBSELINUX_LICENSE_FILES = LICENSE