blob: cf17ec99cc1700a06619633985a397c4eac9b129 [file] [log] [blame]
Sen Jiang299128e2016-06-03 17:48:18 -07001//
2// Copyright (C) 2016 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#include "update_engine/dbus_connection.h"
18
19#include <base/time/time.h>
20
21namespace chromeos_update_engine {
22
23namespace {
24const int kDBusSystemMaxWaitSeconds = 2 * 60;
25
26DBusConnection* dbus_connection_singleton = nullptr;
27} // namespace
28
29DBusConnection::DBusConnection() {
30 // We wait for the D-Bus connection for up two minutes to avoid re-spawning
31 // the daemon too fast causing thrashing if dbus-daemon is not running.
32 bus_ = dbus_connection_.ConnectWithTimeout(
33 base::TimeDelta::FromSeconds(kDBusSystemMaxWaitSeconds));
34
35 if (!bus_) {
36 // TODO(deymo): Make it possible to run update_engine even if dbus-daemon
37 // is not running or constantly crashing.
38 LOG(FATAL) << "Failed to initialize DBus, aborting.";
39 }
40
41 CHECK(bus_->SetUpAsyncOperations());
42}
43
44const scoped_refptr<dbus::Bus>& DBusConnection::GetDBus() {
45 CHECK(bus_);
46 return bus_;
47}
48
49DBusConnection* DBusConnection::Get() {
50 if (!dbus_connection_singleton)
51 dbus_connection_singleton = new DBusConnection();
52 return dbus_connection_singleton;
53}
54
55} // namespace chromeos_update_engine