blob: b56ff5dd0fd2b61ac807ec6e94c344e37eb1fcb9 [file] [log] [blame]
# Copyright 2014 The Chromium OS Authors. All rights reserved.
# Distributed under the terms of the GNU General Public License v2
EAPI=7
CROS_WORKON_COMMIT="ecd28d2c26fbe86b6822c6d6afb80f118a8f7f03"
CROS_WORKON_TREE=("791c6808b4f4f5f1c484108d66ff958d65f8f1e3" "81dfbbc1756a3b4224b447e7bf10a916d97c4f66" "0b612d0f1e8dbe59a5549b476f1e681e0b7fe94e" "a9708ef639f0f7929195d0f3921ebd1a12ad96bd" "a06a3f47395fb7b584188c6852764bc773e5497e" "e7dba8c91c1f3257c34d4a7ffff0ea2537aeb6bb")
CROS_WORKON_INCREMENTAL_BUILD=1
CROS_WORKON_LOCALNAME="platform2"
CROS_WORKON_PROJECT="chromiumos/platform2"
CROS_WORKON_OUTOFTREE_BUILD=1
# TODO(crbug/1184685): "libhwsec" is not necessary; remove it after solving
# the bug.
CROS_WORKON_SUBTREE="common-mk libhwsec libhwsec-foundation metrics trunks .gn"
PLATFORM_SUBDIR="trunks"
inherit cros-workon platform user
DESCRIPTION="Trunks service for Chromium OS"
HOMEPAGE="https://chromium.googlesource.com/chromiumos/platform2/+/master/trunks/"
LICENSE="Apache-2.0"
KEYWORDS="*"
IUSE="
cr50_onboard
csme_emulator
fuzzer
ftdi_tpm
generic_tpm2
pinweaver_csme
test
ti50_onboard
tpm2_simulator
vtpm_proxy
"
# This depends on protobuf because it uses protoc and needs to be rebuilt
# whenever the protobuf library is updated since generated source files may be
# incompatible across different versions of the protobuf library.
COMMON_DEPEND="
>=chromeos-base/metrics-0.0.1-r3152:=
chromeos-base/minijail:=
chromeos-base/power_manager-client:=
ftdi_tpm? ( dev-embedded/libftdi:= )
tpm2_simulator? (
chromeos-base/tpm2:=
vtpm_proxy? ( chromeos-base/tpm2-simulator:= )
)
dev-libs/protobuf:=
fuzzer? (
dev-cpp/gtest:=
)
"
RDEPEND="
${COMMON_DEPEND}
cr50_onboard? ( chromeos-base/chromeos-cr50 )
ti50_onboard? ( chromeos-base/chromeos-ti50 )
!app-crypt/tpm-tools
chromeos-base/libhwsec-foundation
"
DEPEND="
${COMMON_DEPEND}
chromeos-base/chromeos-ec-headers:=
"
src_install() {
insinto /etc/dbus-1/system.d
doins org.chromium.Trunks.conf
insinto /etc/init
if use tpm2_simulator && ! use vtpm_proxy; then
newins trunksd.conf.tpm2_simulator trunksd.conf
elif use cr50_onboard || use ti50_onboard; then
newins trunksd.conf.cr50 trunksd.conf
else
doins trunksd.conf
fi
if use pinweaver_csme && use generic_tpm2; then
newins csme/tpm_tunneld.conf tpm_tunneld.conf
fi
dosbin "${OUT}"/pinweaver_client
dosbin "${OUT}"/trunks_client
dosbin "${OUT}"/trunks_send
dosbin tpm_version
dosbin "${OUT}"/trunksd
dolib.so "${OUT}"/lib/libtrunks.so
# trunks_test library implements trunks mocks which
# are used by unittest and fuzzer.
if use test || use fuzzer; then
dolib.a "${OUT}"/libtrunks_test.a
fi
if use pinweaver_csme && use generic_tpm2; then
dosbin "${OUT}"/pinweaver_provision
dosbin "${OUT}"/tpm_tunneld
fi
insinto /usr/share/policy
newins trunksd-seccomp-${ARCH}.policy trunksd-seccomp.policy
if use pinweaver_csme && use generic_tpm2; then
newins csme/tpm_tunneld-seccomp-${ARCH}.policy tpm_tunneld-seccomp.policy
fi
insinto /usr/include/trunks
doins *.h
doins "${OUT}"/gen/include/trunks/*.h
insinto /usr/include/proto
doins "${S}"/pinweaver.proto
insinto /usr/include/chromeos/dbus/trunks
doins "${S}"/interface.proto
insinto "/usr/$(get_libdir)/pkgconfig"
doins "${OUT}"/obj/trunks/libtrunks.pc
platform_fuzzer_install "${S}"/OWNERS "${OUT}"/trunks_creation_blob_fuzzer
platform_fuzzer_install "${S}"/OWNERS \
"${OUT}"/trunks_hmac_authorization_delegate_fuzzer
platform_fuzzer_install "${S}"/OWNERS "${OUT}"/trunks_key_blob_fuzzer
platform_fuzzer_install "${S}"/OWNERS \
"${OUT}"/trunks_password_authorization_delegate_fuzzer
platform_fuzzer_install "${S}"/OWNERS "${OUT}"/trunks_resource_manager_fuzzer
platform_fuzzer_install "${S}"/OWNERS "${OUT}"/trunks_tpm_pinweaver_fuzzer
}
platform_pkg_test() {
"${S}/generator/generator_test.py" || die
local tests=(
trunks_testrunner
)
local test_bin
for test_bin in "${tests[@]}"; do
platform_test "run" "${OUT}/${test_bin}"
done
}
pkg_preinst() {
enewuser trunks
enewgroup trunks
}