blob: bc4754eab8d5cc1f067f22b8bb7ee7ea6bf55bb3 [file] [log] [blame]
Andrew Geissler82c905d2020-04-13 13:39:40 -05001SUMMARY = "Library for getting/setting POSIX.1e capabilities"
2HOMEPAGE = "http://sites.google.com/site/fullycapable/"
3
4# no specific GPL version required
5LICENSE = "BSD | GPLv2"
6LIC_FILES_CHKSUM = "file://License;md5=3f84fd6f29d453a56514cb7e4ead25f1"
7
8DEPENDS = "hostperl-runtime-native gperf-native"
9
10SRC_URI = "${KERNELORG_MIRROR}/linux/libs/security/linux-privs/${BPN}2/${BPN}-${PV}.tar.xz \
11 file://0001-ensure-the-XATTR_NAME_CAPS-is-defined-when-it-is-use.patch \
12 file://0002-tests-do-not-run-target-executables.patch \
13 file://0001-tests-do-not-statically-link-a-test.patch \
14 "
Andrew Geisslerd1e89492021-02-12 15:35:20 -060015SRC_URI[sha256sum] = "af165df45f9fe8b315164ec7143740947489f36ccbe6999b6cdf86e7a8dca04b"
Andrew Geissler82c905d2020-04-13 13:39:40 -050016
17UPSTREAM_CHECK_URI = "https://www.kernel.org/pub/linux/libs/security/linux-privs/${BPN}2/"
18
19inherit lib_package
20
21# do NOT pass target cflags to host compilations
22#
23do_configure() {
24 # libcap uses := for compilers, fortunately, it gives us a hint
25 # on what should be replaced with ?=
26 sed -e 's,:=,?=,g' -i Make.Rules
Andrew Geissler4ed12e12020-06-05 18:00:41 -050027 sed -e 's,^BUILD_CFLAGS ?= ,BUILD_CFLAGS := $(BUILD_CFLAGS) ,' -i Make.Rules
Andrew Geissler82c905d2020-04-13 13:39:40 -050028}
29
30PACKAGECONFIG ??= "${@bb.utils.filter('DISTRO_FEATURES', 'pam', d)}"
31PACKAGECONFIG_class-native ??= ""
32
33PACKAGECONFIG[pam] = "PAM_CAP=yes,PAM_CAP=no,libpam"
34
35EXTRA_OEMAKE = " \
36 INDENT= \
37 lib='${baselib}' \
38 RAISE_SETFCAP=no \
39 DYNAMIC=yes \
40 BUILD_GPERF=yes \
41"
42
43EXTRA_OEMAKE_append_class-target = " SYSTEM_HEADERS=${STAGING_INCDIR}"
44
45# these are present in the libcap defaults, so include in our CFLAGS too
46CFLAGS += "-D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64"
47
48do_compile() {
49 oe_runmake ${PACKAGECONFIG_CONFARGS}
50}
51
52do_install() {
53 oe_runmake install \
54 ${PACKAGECONFIG_CONFARGS} \
55 DESTDIR="${D}" \
56 prefix="${prefix}" \
57 SBINDIR="${sbindir}"
58}
59
60do_install_append() {
61 # Move the library to base_libdir
62 install -d ${D}${base_libdir}
63 if [ ! ${D}${libdir} -ef ${D}${base_libdir} ]; then
64 mv ${D}${libdir}/libcap* ${D}${base_libdir}
65 if [ -d ${D}${libdir}/security ]; then
66 mv ${D}${libdir}/security ${D}${base_libdir}
67 fi
68 fi
69}
70
71FILES_${PN}-dev += "${base_libdir}/*.so"
72
73# pam files
74FILES_${PN} += "${base_libdir}/security/*.so"
75
76BBCLASSEXTEND = "native nativesdk"