blob: 8b9cd32b7a0fde9bb07cfb569fcb7880d9ee746a [file] [log] [blame]
# Copyright 2016 The ChromiumOS Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
CROS_WORKON_COMMIT="8b6e11a069e490c761cdab7ab3ff59434806cd9c"
CROS_WORKON_TREE=("41d899585b7a07ea908a0cca2944a7b8a4d13655" "2f516afa9d288e2aa6b2ed1a6e4ddfbb962929d4" "9942607d3de36a375711502f44f44d28aac7bd3a" "67442b9578c0475865b147e940740e227d50027c" "9dbbe059a64bdb3260dc088895573df5ea421399" "0d9d2046eb78dc8620f7594f245298f9fd964832" "faa5b8036561b66b5b9d79ea1af8a95927a0ae0f" "f91b6afd5f2ae04ee9a2c19109a3a4a36f7659e6")
CROS_WORKON_USE_VCSID="1"
CROS_WORKON_LOCALNAME="platform2"
CROS_WORKON_PROJECT="chromiumos/platform2"
CROS_WORKON_OUTOFTREE_BUILD=1
CROS_WORKON_SUBTREE="common-mk biod chromeos-config libec libhwsec libhwsec-foundation metrics .gn"
PLATFORM_SUBDIR="biod"
inherit cros-fuzzer cros-sanitizers cros-workon cros-unibuild platform \
tmpfiles udev user
DESCRIPTION="Biometrics Daemon for Chromium OS"
HOMEPAGE="https://chromium.googlesource.com/chromiumos/platform2/+/HEAD/biod/README.md"
LICENSE="BSD-Google"
KEYWORDS="*"
IUSE="
factory_branch
fp_on_power_button
fpmcu_firmware_bloonchipper
fpmcu_firmware_dartmonkey
fpmcu_firmware_nami
fpmcu_firmware_nocturne
fuzzer
"
COMMON_DEPEND="
chromeos-base/chromeos-config-tools:=
chromeos-base/libec:=
chromeos-base/libhwsec:=[test?]
chromeos-base/libhwsec-foundation:=
>=chromeos-base/metrics-0.0.1-r3152:=
chromeos-base/vboot_reference:=
sys-apps/flashmap:=
"
# For biod_client_tool. The biod_proxy library will be built on all boards but
# biod_client_tool will be built only on boards with biod.
COMMON_DEPEND+="
chromeos-base/biod_proxy:=
"
RDEPEND="
${COMMON_DEPEND}
sys-apps/crosec-legacy-drv:=
sys-apps/flashrom
!factory_branch? ( virtual/chromeos-firmware-fpmcu )
"
# Release branch firmware.
# The USE flags below come from USE_EXPAND variables.
# See third_party/chromiumos-overlay/profiles/base/make.defaults.
RDEPEND+="
!factory_branch? (
fpmcu_firmware_bloonchipper? ( sys-firmware/chromeos-fpmcu-release-bloonchipper )
fpmcu_firmware_dartmonkey? ( sys-firmware/chromeos-fpmcu-release-dartmonkey )
fpmcu_firmware_nami? ( sys-firmware/chromeos-fpmcu-release-nami )
fpmcu_firmware_nocturne? ( sys-firmware/chromeos-fpmcu-release-nocturne )
)
"
DEPEND="
${COMMON_DEPEND}
chromeos-base/chromeos-ec-headers:=
chromeos-base/power_manager-client:=
chromeos-base/system_api:=[fuzzer?]
dev-libs/openssl:=
"
pkg_setup() {
enewuser biod
enewgroup biod
enewgroup fpdev
}
src_install() {
platform_src_install
udev_dorules udev/99-biod.rules
dotmpfiles tmpfiles.d/*.conf
# Set up cryptohome daemon mount store in daemon's mount
# namespace.
local daemon_store="/etc/daemon-store/biod"
dodir "${daemon_store}"
fperms 0700 "${daemon_store}"
fowners biod:biod "${daemon_store}"
local fuzzer_component_id="782045"
platform_fuzzer_install "${S}/OWNERS" "${OUT}"/biod_storage_fuzzer --comp "${fuzzer_component_id}"
platform_fuzzer_install "${S}/OWNERS" "${OUT}"/biod_crypto_validation_value_fuzzer --comp "${fuzzer_component_id}"
}
platform_pkg_test() {
platform test_all
}