xref: /aosp_15_r20/external/sandboxed-api/sandboxed_api/sandbox2/forkingclient.cc (revision ec63e07ab9515d95e79c211197c445ef84cefa6a)
1*ec63e07aSXin Li // Copyright 2019 Google LLC
2*ec63e07aSXin Li //
3*ec63e07aSXin Li // Licensed under the Apache License, Version 2.0 (the "License");
4*ec63e07aSXin Li // you may not use this file except in compliance with the License.
5*ec63e07aSXin Li // You may obtain a copy of the License at
6*ec63e07aSXin Li //
7*ec63e07aSXin Li //     https://www.apache.org/licenses/LICENSE-2.0
8*ec63e07aSXin Li //
9*ec63e07aSXin Li // Unless required by applicable law or agreed to in writing, software
10*ec63e07aSXin Li // distributed under the License is distributed on an "AS IS" BASIS,
11*ec63e07aSXin Li // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*ec63e07aSXin Li // See the License for the specific language governing permissions and
13*ec63e07aSXin Li // limitations under the License.
14*ec63e07aSXin Li 
15*ec63e07aSXin Li #include "sandboxed_api/sandbox2/forkingclient.h"
16*ec63e07aSXin Li 
17*ec63e07aSXin Li #include <unistd.h>
18*ec63e07aSXin Li 
19*ec63e07aSXin Li #include <cstdlib>
20*ec63e07aSXin Li #include <memory>
21*ec63e07aSXin Li 
22*ec63e07aSXin Li #include "absl/log/check.h"
23*ec63e07aSXin Li #include "absl/log/log.h"
24*ec63e07aSXin Li #include "sandboxed_api/sandbox2/forkserver.h"
25*ec63e07aSXin Li #include "sandboxed_api/sandbox2/sanitizer.h"
26*ec63e07aSXin Li #include "sandboxed_api/util/raw_logging.h"
27*ec63e07aSXin Li 
28*ec63e07aSXin Li namespace sandbox2 {
29*ec63e07aSXin Li 
WaitAndFork()30*ec63e07aSXin Li pid_t ForkingClient::WaitAndFork() {
31*ec63e07aSXin Li   // We don't instantiate the Fork-Server until the first Fork() call takes
32*ec63e07aSXin Li   // place (in order to conserve resources, and avoid calling Fork-Server
33*ec63e07aSXin Li   // initialization routines).
34*ec63e07aSXin Li   if (!fork_server_worker_) {
35*ec63e07aSXin Li     sanitizer::WaitForSanitizer();
36*ec63e07aSXin Li     // Perform that check once only, because it's quite CPU-expensive.
37*ec63e07aSXin Li     int n = sanitizer::GetNumberOfThreads(getpid());
38*ec63e07aSXin Li     CHECK_NE(n, -1) << "sanitizer::GetNumberOfThreads failed";
39*ec63e07aSXin Li     CHECK_EQ(n, 1) << "Too many threads (" << n
40*ec63e07aSXin Li                    << ") during sandbox2::Client::WaitAndFork()";
41*ec63e07aSXin Li     fork_server_worker_ = std::make_unique<ForkServer>(comms_);
42*ec63e07aSXin Li   }
43*ec63e07aSXin Li   pid_t pid = fork_server_worker_->ServeRequest();
44*ec63e07aSXin Li   if (pid == -1 && fork_server_worker_->IsTerminated()) {
45*ec63e07aSXin Li     VLOG(1) << "ForkServer Comms closed. Exiting";
46*ec63e07aSXin Li     exit(0);
47*ec63e07aSXin Li   }
48*ec63e07aSXin Li   return pid;
49*ec63e07aSXin Li }
50*ec63e07aSXin Li 
51*ec63e07aSXin Li }  // namespace sandbox2
52