da40c00137
Also make important events in init's life NOTICE rather than INFO, and ensure that NOTICE events actually make it to the kernel log. Also fix the logging so that if you have a printf format string error, the compiler now catches it. Also give messages from init, ueventd, and watchdogd distinct tags. (Previously they'd all call themselves "init", and dmesg doesn't include pids, so you couldn't untangle them.) Also include the tag in SELinux messages. Bug: 19544788 Change-Id: Ica6daea065bfdb80155c52c0b06f346a7df208fe
64 lines
1.8 KiB
C++
64 lines
1.8 KiB
C++
/*
|
|
* Copyright (C) 2010 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_UTIL_H_
|
|
#define _INIT_UTIL_H_
|
|
|
|
#include <sys/stat.h>
|
|
#include <sys/types.h>
|
|
|
|
#include <string>
|
|
|
|
#define ARRAY_SIZE(x) (sizeof(x)/sizeof(x[0]))
|
|
|
|
#define COLDBOOT_DONE "/dev/.coldboot_done"
|
|
|
|
int mtd_name_to_number(const char *name);
|
|
int create_socket(const char *name, int type, mode_t perm,
|
|
uid_t uid, gid_t gid, const char *socketcon);
|
|
|
|
bool read_file(const char* path, std::string* content);
|
|
int write_file(const char* path, const char* content);
|
|
|
|
time_t gettime();
|
|
uint64_t gettime_ns();
|
|
|
|
class Timer {
|
|
public:
|
|
Timer() : t0(gettime_ns()) {
|
|
}
|
|
|
|
double duration() {
|
|
return static_cast<double>(gettime_ns() - t0) / 1000000000.0;
|
|
}
|
|
|
|
private:
|
|
uint64_t t0;
|
|
};
|
|
|
|
unsigned int decode_uid(const char *s);
|
|
|
|
int mkdir_recursive(const char *pathname, mode_t mode);
|
|
void sanitize(char *p);
|
|
void make_link(const char *oldpath, const char *newpath);
|
|
void remove_link(const char *oldpath, const char *newpath);
|
|
int wait_for_file(const char *filename, int timeout);
|
|
void open_devnull_stdio(void);
|
|
void import_kernel_cmdline(int in_qemu, void (*import_kernel_nv)(char *name, int in_qemu));
|
|
int make_dir(const char *path, mode_t mode);
|
|
int restorecon(const char *pathname);
|
|
int restorecon_recursive(const char *pathname);
|
|
#endif
|