blob: 4fe779f193daa6c52f933315a1e9ac1589a1f9ee [file] [log] [blame]
# Copyright 2015 The Chromium OS Authors. All rights reserved.
# Distributed under the terms of the GNU General Public License v2
EAPI="5"
CROS_WORKON_COMMIT="f35f2919309cf11b0ddd9deb24a6b145d40d9254"
CROS_WORKON_TREE=("a625767bb59509159091f2ab0b71f8b9b4b2e353" "fb2b8277318fb7e7eff84f5c7669a46bf60f19f5" "b1c7898d3f42051cbba6426c62b35476a8de5b72" "99cb261212fa3c73badb7ce5bd2da101c2567206" "4a0dedab080195bdc122d2289118df4af3ddca2c" "2acba33c99f07fa000bb44a4df3a65a8fe313bb1" "97266a4772907835fdab5d56b3ca24ed9c1c7a0e" "e7dba8c91c1f3257c34d4a7ffff0ea2537aeb6bb")
CROS_WORKON_INCREMENTAL_BUILD=1
CROS_WORKON_LOCALNAME="platform2"
CROS_WORKON_PROJECT="chromiumos/platform2"
CROS_WORKON_OUTOFTREE_BUILD=1
# TODO(crbug.com/809389): Avoid directly including headers from other packages.
CROS_WORKON_SUBTREE="common-mk libhwsec libhwsec-foundation libtpmcrypto metrics tpm_manager trunks .gn"
PLATFORM_SUBDIR="tpm_manager"
inherit cros-workon platform user
DESCRIPTION="Daemon to manage TPM ownership."
HOMEPAGE="https://chromium.googlesource.com/chromiumos/platform2/+/master/tpm_manager/"
LICENSE="Apache-2.0"
SLOT="0"
KEYWORDS="*"
IUSE="cr50_onboard pinweaver_csme test tpm tpm_dynamic tpm2 fuzzer"
REQUIRED_USE="
?? ( cr50_onboard pinweaver_csme )
tpm_dynamic? ( tpm tpm2 )
!tpm_dynamic? ( ?? ( tpm tpm2 ) )
"
RDEPEND="
tpm? ( app-crypt/trousers )
tpm2? (
chromeos-base/trunks
)
>=chromeos-base/metrics-0.0.1-r3152
chromeos-base/minijail
chromeos-base/libhwsec
chromeos-base/libtpmcrypto
chromeos-base/system_api:=[fuzzer?]
chromeos-base/tpm_manager-client
"
DEPEND="${RDEPEND}
tpm2? ( chromeos-base/trunks[test?] )
fuzzer? ( dev-libs/libprotobuf-mutator )
"
pkg_preinst() {
enewuser tpm_manager
enewgroup tpm_manager
}
src_install() {
# Install D-Bus configuration file.
insinto /etc/dbus-1/system.d
doins server/org.chromium.TpmManager.conf
# Install upstart config file.
insinto /etc/init
doins server/tpm_managerd.conf
if use tpm_dynamic; then
conds=("started no-tpm-checker")
if use tpm; then
conds+=("started tcsd")
fi
if use tpm2; then
conds+=("started trunksd")
fi
cond=$(printf " or %s" "${conds[@]}")
cond=${cond:4}
sed -i "s/started tcsd/(${cond})/" \
"${D}/etc/init/tpm_managerd.conf" ||
die "Can't replace 'started tcsd' with '${cond}' in tpm_managerd.conf"
elif use tpm2; then
dep_job="trunksd"
if use pinweaver_csme; then
dep_job="tpm_tunneld"
fi
sed -i "s/started tcsd/started ${dep_job}/" \
"${D}/etc/init/tpm_managerd.conf" ||
die "Can't replace tcsd with ${dep_job} in tpm_managerd.conf"
fi
# Install the executables provided by TpmManager
dosbin "${OUT}"/tpm_managerd
dosbin "${OUT}"/local_data_migration
# Install seccomp policy files.
insinto /usr/share/policy
newins server/tpm_managerd-seccomp-${ARCH}.policy tpm_managerd-seccomp.policy
# Install fuzzer.
platform_fuzzer_install "${S}"/OWNERS "${OUT}"/tpm_manager_service_fuzzer
}
platform_pkg_test() {
local tests=(
tpm_manager_testrunner
)
local test_bin
for test_bin in "${tests[@]}"; do
platform_test "run" "${OUT}/${test_bin}"
done
}