/* * Copyright (C) 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. */ #pragma once #include #include #include #include #include namespace cvd { struct MonitorEntry; using OnSocketReadyCb = std::function; struct MonitorEntry { std::unique_ptr cmd; std::unique_ptr proc; OnSocketReadyCb on_control_socket_ready_cb; }; // Keeps track of launched subprocesses, restarts them if they unexpectedly exit class ProcessMonitor { public: ProcessMonitor(); // Starts a managed subprocess with a controlling socket. The // on_control_socket_ready_cb callback will be called when data is ready to be // read from the socket or the subprocess has ended. No member functions of // the process monitor object should be called from the callback as it may // lead to a dealock. If the callback returns false the subprocess will no // longer be monitored void StartSubprocess(Command cmd, OnSocketReadyCb on_control_socket_ready_cb); // Monitors an alreacy started subprocess void MonitorExistingSubprocess(Command cmd, Subprocess sub_process, OnSocketReadyCb on_control_socket_ready_cb); static bool RestartOnExitCb(MonitorEntry* entry); static bool DoNotMonitorCb(MonitorEntry* entry); private: void MonitorRoutine(); std::vector monitored_processes_; // Used for communication with the restarter thread cvd::SharedFD thread_comm_main_, thread_comm_monitor_; std::thread monitor_thread_; // Protects access to the monitored_processes_ std::mutex processes_mutex_; }; } // namespace cvd