/* ** ** Copyright 2018, 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. */ #include #include #include #include #include #include "common/libs/fs/shared_fd.h" #include "common/libs/security/keymaster_channel.h" #include #include const char device[] = "/dev/hvc3"; int main(int argc, char** argv) { ::android::base::InitLogging(argv, ::android::base::KernelLogger); gflags::ParseCommandLineFlags(&argc, &argv, true); ::android::hardware::configureRpcThreadpool(1, true); LOG(INFO) << "Starting keymaster service4"; auto fd = cuttlefish::SharedFD::Open(device, O_RDWR); if (!fd->IsOpen()) { LOG(FATAL) << "Could not connect to keymaster: " << fd->StrError(); } if (fd->SetTerminalRaw() < 0) { LOG(FATAL) << "Could not make " << device << " a raw terminal: " << fd->StrError(); } cuttlefish::KeymasterChannel keymasterChannel(fd, fd); auto remoteKeymaster = new keymaster::RemoteKeymaster(&keymasterChannel); if (!remoteKeymaster->Initialize()) { LOG(FATAL) << "Could not initialize keymaster"; } auto keymaster = new ::keymaster::V4_1::RemoteKeymaster4Device(remoteKeymaster); auto status = keymaster->registerAsService(); if (status != android::OK) { LOG(FATAL) << "Could not register service for Keymaster 4.1 (" << status << ")"; return -1; } android::hardware::joinRpcThreadpool(); return -1; // Should never get here. }