init.h revision 8348d279c7ce1a2453965ba7f05a7b818d58886c
1/* 2 * Copyright (C) 2007 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#ifndef _INIT_INIT_H 18#define _INIT_INIT_H 19 20#include <cutils/list.h> 21 22#include <sys/stat.h> 23 24void handle_control_message(const char *msg, const char *arg); 25 26struct command 27{ 28 /* list of commands in an action */ 29 struct listnode clist; 30 31 int (*func)(int nargs, char **args); 32 int nargs; 33 char *args[1]; 34}; 35 36struct action { 37 /* node in list of all actions */ 38 struct listnode alist; 39 /* node in the queue of pending actions */ 40 struct listnode qlist; 41 /* node in list of actions for a trigger */ 42 struct listnode tlist; 43 44 unsigned hash; 45 const char *name; 46 47 struct listnode commands; 48 struct command *current; 49}; 50 51struct socketinfo { 52 struct socketinfo *next; 53 const char *name; 54 const char *type; 55 uid_t uid; 56 gid_t gid; 57 int perm; 58 const char *socketcon; 59}; 60 61struct svcenvinfo { 62 struct svcenvinfo *next; 63 const char *name; 64 const char *value; 65}; 66 67#define SVC_DISABLED 0x01 /* do not autostart with class */ 68#define SVC_ONESHOT 0x02 /* do not restart on exit */ 69#define SVC_RUNNING 0x04 /* currently active */ 70#define SVC_RESTARTING 0x08 /* waiting to restart */ 71#define SVC_CONSOLE 0x10 /* requires console */ 72#define SVC_CRITICAL 0x20 /* will reboot into recovery if keeps crashing */ 73#define SVC_RESET 0x40 /* Use when stopping a process, but not disabling 74 so it can be restarted with its class */ 75#define SVC_RC_DISABLED 0x80 /* Remember if the disabled flag was set in the rc script */ 76#define SVC_RESTART 0x100 /* Use to safely restart (stop, wait, start) a service */ 77 78#define NR_SVC_SUPP_GIDS 12 /* twelve supplementary groups */ 79 80#define COMMAND_RETRY_TIMEOUT 5 81 82struct service { 83 /* list of all services */ 84 struct listnode slist; 85 86 const char *name; 87 const char *classname; 88 89 unsigned flags; 90 pid_t pid; 91 time_t time_started; /* time of last start */ 92 time_t time_crashed; /* first crash within inspection window */ 93 int nr_crashed; /* number of times crashed within window */ 94 95 uid_t uid; 96 gid_t gid; 97 gid_t supp_gids[NR_SVC_SUPP_GIDS]; 98 size_t nr_supp_gids; 99 100 char *seclabel; 101 102 struct socketinfo *sockets; 103 struct svcenvinfo *envvars; 104 105 struct action onrestart; /* Actions to execute on restart. */ 106 107 /* keycodes for triggering this service via /dev/keychord */ 108 int *keycodes; 109 int nkeycodes; 110 int keychord_id; 111 112 int ioprio_class; 113 int ioprio_pri; 114 115 int nargs; 116 /* "MUST BE AT THE END OF THE STRUCT" */ 117 char *args[1]; 118}; /* ^-------'args' MUST be at the end of this struct! */ 119 120void notify_service_state(const char *name, const char *state); 121 122struct service *service_find_by_name(const char *name); 123struct service *service_find_by_pid(pid_t pid); 124struct service *service_find_by_keychord(int keychord_id); 125void service_for_each(void (*func)(struct service *svc)); 126void service_for_each_class(const char *classname, 127 void (*func)(struct service *svc)); 128void service_for_each_flags(unsigned matchflags, 129 void (*func)(struct service *svc)); 130void service_stop(struct service *svc); 131void service_reset(struct service *svc); 132void service_restart(struct service *svc); 133void service_start(struct service *svc, const char *dynamic_args); 134void property_changed(const char *name, const char *value); 135 136#define INIT_IMAGE_FILE "/initlogo.rle" 137 138int load_565rle_image( char *file_name ); 139 140extern struct selabel_handle *sehandle; 141extern struct selabel_handle *sehandle_prop; 142extern int selinux_reload_policy(void); 143 144#endif /* _INIT_INIT_H */ 145