From 20acdef8164d77b99f8abede198a03ac510a7a08 Mon Sep 17 00:00:00 2001 From: Tom Cherry Date: Tue, 3 Oct 2017 13:15:03 -0700 Subject: [PATCH] init: log failures if a service cannot start during class_start Test: boot system with this logging and see appropriate failures Change-Id: I312dca89f6215afe05b10b2539258a212a0c1ae2 --- init/builtins.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/init/builtins.cpp b/init/builtins.cpp index 60c0007c0..027b392fd 100644 --- a/init/builtins.cpp +++ b/init/builtins.cpp @@ -99,7 +99,14 @@ static void ForEachServiceInClass(const std::string& classname, F function) { static Result do_class_start(const BuiltinArguments& args) { // Starting a class does not start services which are explicitly disabled. // They must be started individually. - ForEachServiceInClass(args[1], &Service::StartIfNotDisabled); + for (const auto& service : ServiceList::GetInstance()) { + if (service->classnames().count(args[1])) { + if (auto result = service->StartIfNotDisabled(); !result) { + LOG(ERROR) << "Could not start service '" << service->name() + << "' as part of class '" << args[1] << "': " << result.error(); + } + } + } return Success(); }