blob: 34a78cf8d7f35eba18f283f8df163ea83b16fa8d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
# Copyright 1999-2019 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=6
inherit eutils toolchain-funcs
# This is the latest commit in the latest branch.
GIT_SHA1="a32c930e8c46424a3bba3c296fd78b3e60f50aeb"
DESCRIPTION="Chrome OS verified boot tools"
HOMEPAGE="https://chromium.googlesource.com/chromiumos/platform/vboot_reference/ http://dev.chromium.org/chromium-os/chromiumos-design-docs/verified-boot"
# Can't use gitiles directly until b/19710536 is fixed.
#SRC_URI="https://chromium.googlesource.com/chromiumos/platform/vboot_reference/+archive/${GIT_SHA1}.tar.gz -> ${P}.tar.gz"
SRC_URI="mirror://gentoo/${P}.tar.xz
https://dev.gentoo.org/~zmedico/dist/${P}.tar.xz"
LICENSE="BSD"
SLOT="0"
KEYWORDS="~amd64 ~arm ~arm64 ~mips ~x86"
IUSE="libressl minimal static"
LIB_DEPEND="
dev-libs/libyaml:=[static-libs(+)]
app-arch/xz-utils:=[static-libs(+)]"
LIB_DEPEND_MINIMAL="
!libressl? ( dev-libs/openssl:0=[static-libs(+)] )
libressl? ( dev-libs/libressl:0=[static-libs(+)] )
sys-apps/util-linux:=[static-libs(+)]
dev-libs/libzip:=[static-libs(+)]"
RDEPEND="!static? (
${LIB_DEPEND_MINIMAL//\[static-libs(+)]}
!minimal? ( ${LIB_DEPEND//\[static-libs(+)]} )
)
elibc_musl? ( sys-libs/fts-standalone )"
DEPEND="${RDEPEND}
static? (
${LIB_DEPEND_MINIMAL}
!minimal? ( ${LIB_DEPEND} )
)
app-crypt/trousers"
S=${WORKDIR}
src_prepare() {
eapply "${FILESDIR}"/${P}-libressl.patch
default
sed -i \
-e 's:${DESTDIR}/\(bin\|${LIBDIR}\):${DESTDIR}/usr/\1:g' \
-e 's:${DESTDIR}/default:${DESTDIR}/etc/default:g' \
-e 's:${TEST_INSTALL_DIR}/bin:${TEST_INSTALL_DIR}/usr/bin:' \
-e '/cgpt -D 358400/d' \
Makefile || die
sed -e 's:^BIN_DIR=${BUILD_DIR}/install_for_test/bin:BIN_DIR=${BUILD_DIR}/install_for_test/usr/bin:' \
-i tests/common.sh || die
sed -e "s:/mnt/host/source/src/platform/vboot_reference:${S}:" \
-i tests/futility/expect_output/* || die
}
_emake() {
local arch=$(tc-arch)
emake \
V=1 \
QEMU_ARCH= \
ARCH=${arch} \
HOST_ARCH=${arch} \
LIBDIR="$(get_libdir)" \
DEBUG_FLAGS= \
WERROR= \
MINIMAL=$(usev minimal) \
STATIC=$(usev static) \
$(usex elibc_musl HAVE_MUSL=1 "") \
"$@"
}
src_compile() {
tc-export CC AR CXX PKG_CONFIG
_emake TEST_BINS= all
}
src_test() {
_emake runtests
}
src_install() {
_emake DESTDIR="${ED}" install
insinto /usr/share/vboot/devkeys
doins tests/devkeys/*
insinto /usr/include/vboot
doins host/include/* \
firmware/include/gpt.h \
firmware/include/tlcl.h \
firmware/include/tss_constants.h
dolib.a build/libvboot_host.a
dodoc README
}
|