5ceb7b3ebd
Currently if a process sets the sys.powerctl property, init adds this
property change into the event queue, just like any other property.
The actual logic to shutdown the device is not executed until init
gets to the action associated with the property change.
This is bad for multiple reasons, but explicitly causes deadlock in
the follow scenario:
A service is started with `exec` or `exec_start`
The same service sets sys.powerctl indicating to the system to
shutdown
The same service then waits infinitely
In this case, init doesn't process any further commands until the exec
service completes, including the command to reboot the device.
This change causes init to immediately handle sys.powerctl and reboot
the device regardless of the state of the event queue, wait for exec,
or wait for property conditions.
Bug: 37209359
Bug: 37415192
Test: Init reboots normally
Test: Update verifier can reboot the system
Change-Id: Iff2295aed970840f47e56c4bacc93001b791fa35
(cherry picked from commit 98ad32a967
)
37 lines
1.2 KiB
C++
37 lines
1.2 KiB
C++
/*
|
|
* Copyright (C) 2007 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.
|
|
*/
|
|
|
|
#ifndef _INIT_INIT_H
|
|
#define _INIT_INIT_H
|
|
|
|
#include <string>
|
|
|
|
extern const char *ENV[32];
|
|
extern std::string default_console;
|
|
extern struct selabel_handle *sehandle;
|
|
extern struct selabel_handle *sehandle_prop;
|
|
|
|
void handle_control_message(const std::string& msg, const std::string& arg);
|
|
|
|
void property_changed(const std::string& name, const std::string& value);
|
|
|
|
void register_epoll_handler(int fd, void (*fn)());
|
|
|
|
int add_environment(const char* key, const char* val);
|
|
|
|
bool start_waiting_for_property(const char *name, const char *value);
|
|
|
|
#endif /* _INIT_INIT_H */
|