c649ca538d
This makes it easier to add or remove the Trusty keymaster service from a device by providing a manifest fragment to add whenever it is enabled. Test: Keymaster VTS, Keystore CTS (sans attestation) Change-Id: Ib0f5fd7c016c0c18d77c9d2623c89f3b35ba7ad7
141 lines
3.7 KiB
Text
141 lines
3.7 KiB
Text
//
|
|
// Copyright (C) 2015 The Android Open-Source Project
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
|
|
// WARNING: Everything listed here will be built on ALL platforms,
|
|
// including x86, the emulator, and the SDK. Modules must be uniquely
|
|
// named (liblights.panda), and must build everywhere, or limit themselves
|
|
// to only building on ARM if they include assembly. Individual makefiles
|
|
// are responsible for having their own logic, for fine-grained control.
|
|
|
|
// trusty_keymaster is a binary used only for on-device testing. It
|
|
// runs Trusty Keymaster through a basic set of operations with RSA
|
|
// and ECDSA keys.
|
|
cc_binary {
|
|
name: "trusty_keymaster_tipc",
|
|
vendor: true,
|
|
srcs: [
|
|
"ipc/trusty_keymaster_ipc.cpp",
|
|
"legacy/trusty_keymaster_device.cpp",
|
|
"legacy/trusty_keymaster_main.cpp",
|
|
],
|
|
cflags: [
|
|
"-Wall",
|
|
"-Werror",
|
|
],
|
|
|
|
local_include_dirs: ["include"],
|
|
|
|
shared_libs: [
|
|
"libcrypto",
|
|
"libcutils",
|
|
"libkeymaster_portable",
|
|
"libtrusty",
|
|
"libkeymaster_messages",
|
|
"libsoftkeymasterdevice",
|
|
"liblog",
|
|
],
|
|
}
|
|
|
|
// keystore.trusty is the HAL used by keystore on Trusty devices.
|
|
cc_library_shared {
|
|
name: "keystore.trusty",
|
|
vendor: true,
|
|
relative_install_path: "hw",
|
|
srcs: [
|
|
"ipc/trusty_keymaster_ipc.cpp",
|
|
"legacy/module.cpp",
|
|
"legacy/trusty_keymaster_device.cpp",
|
|
],
|
|
|
|
cflags: [
|
|
"-fvisibility=hidden",
|
|
"-Wall",
|
|
"-Werror",
|
|
],
|
|
|
|
local_include_dirs: ["include"],
|
|
|
|
shared_libs: [
|
|
"libcrypto",
|
|
"libkeymaster_messages",
|
|
"libtrusty",
|
|
"liblog",
|
|
"libcutils",
|
|
],
|
|
header_libs: ["libhardware_headers"],
|
|
}
|
|
|
|
cc_binary {
|
|
name: "android.hardware.keymaster@3.0-service.trusty",
|
|
defaults: ["hidl_defaults"],
|
|
relative_install_path: "hw",
|
|
vendor: true,
|
|
init_rc: ["3.0/android.hardware.keymaster@3.0-service.trusty.rc"],
|
|
srcs: [
|
|
"3.0/service.cpp",
|
|
"3.0/TrustyKeymaster3Device.cpp",
|
|
"ipc/trusty_keymaster_ipc.cpp",
|
|
"TrustyKeymaster.cpp",
|
|
],
|
|
|
|
local_include_dirs: ["include"],
|
|
|
|
shared_libs: [
|
|
"liblog",
|
|
"libcutils",
|
|
"libdl",
|
|
"libbase",
|
|
"libutils",
|
|
"libhardware",
|
|
"libhidlbase",
|
|
"libtrusty",
|
|
"libkeymaster_messages",
|
|
"libkeymaster3device",
|
|
"android.hardware.keymaster@3.0"
|
|
],
|
|
}
|
|
|
|
cc_binary {
|
|
name: "android.hardware.keymaster@4.0-service.trusty",
|
|
defaults: ["hidl_defaults"],
|
|
relative_install_path: "hw",
|
|
vendor: true,
|
|
init_rc: ["4.0/android.hardware.keymaster@4.0-service.trusty.rc"],
|
|
srcs: [
|
|
"4.0/service.cpp",
|
|
"4.0/TrustyKeymaster4Device.cpp",
|
|
"ipc/trusty_keymaster_ipc.cpp",
|
|
"TrustyKeymaster.cpp",
|
|
],
|
|
|
|
local_include_dirs: ["include"],
|
|
|
|
shared_libs: [
|
|
"liblog",
|
|
"libcutils",
|
|
"libdl",
|
|
"libbase",
|
|
"libutils",
|
|
"libhardware",
|
|
"libhidlbase",
|
|
"libtrusty",
|
|
"libkeymaster_messages",
|
|
"libkeymaster4",
|
|
"android.hardware.keymaster@4.0"
|
|
],
|
|
|
|
vintf_fragments: ["4.0/android.hardware.keymaster@4.0-service.trusty.xml"],
|
|
}
|