Home | History | Annotate | Download | only in keymaster
      1 //
      2 // Copyright (C) 2015 The Android Open-Source Project
      3 //
      4 // Licensed under the Apache License, Version 2.0 (the "License");
      5 // you may not use this file except in compliance with the License.
      6 // You may obtain a copy of the License at
      7 //
      8 //      http://www.apache.org/licenses/LICENSE-2.0
      9 //
     10 // Unless required by applicable law or agreed to in writing, software
     11 // distributed under the License is distributed on an "AS IS" BASIS,
     12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13 // See the License for the specific language governing permissions and
     14 // limitations under the License.
     15 //
     16 
     17 // WARNING: Everything listed here will be built on ALL platforms,
     18 // including x86, the emulator, and the SDK.  Modules must be uniquely
     19 // named (liblights.panda), and must build everywhere, or limit themselves
     20 // to only building on ARM if they include assembly. Individual makefiles
     21 // are responsible for having their own logic, for fine-grained control.
     22 
     23 // trusty_keymaster is a binary used only for on-device testing.  It
     24 // runs Trusty Keymaster through a basic set of operations with RSA
     25 // and ECDSA keys.
     26 cc_binary {
     27     name: "trusty_keymaster_tipc",
     28     vendor: true,
     29     srcs: [
     30         "trusty_keymaster_device.cpp",
     31         "trusty_keymaster_ipc.cpp",
     32         "trusty_keymaster_main.cpp",
     33     ],
     34     cflags: [
     35         "-Wall",
     36         "-Werror",
     37     ],
     38     shared_libs: [
     39         "libcrypto",
     40         "libcutils",
     41         "libkeymaster_portable",
     42         "libtrusty",
     43         "libkeymaster_messages",
     44         "libsoftkeymasterdevice",
     45         "liblog",
     46     ],
     47 }
     48 
     49 // keystore.trusty is the HAL used by keystore on Trusty devices.
     50 cc_library_shared {
     51     name: "keystore.trusty",
     52     vendor: true,
     53     relative_install_path: "hw",
     54     srcs: [
     55         "module.cpp",
     56         "trusty_keymaster_ipc.cpp",
     57         "trusty_keymaster_device.cpp",
     58     ],
     59 
     60     cflags: [
     61         "-fvisibility=hidden",
     62         "-Wall",
     63         "-Werror",
     64     ],
     65 
     66     shared_libs: [
     67         "libcrypto",
     68         "libkeymaster_messages",
     69         "libtrusty",
     70         "liblog",
     71         "libcutils",
     72     ],
     73     header_libs: ["libhardware_headers"],
     74 }
     75