diff options
| author | Nick Kralevich <nnk@google.com> | 2013-06-25 21:08:56 +0000 | 
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2013-06-25 21:08:56 +0000 | 
| commit | cbc76fcadb9b04007cc693aab39e86b33cb394aa (patch) | |
| tree | 11ec5f8f17810a4f08c66d981970691a9e52fb74 | |
| parent | 25383a5da2ce4ada76df46e1bc7ae56ac0e41fc4 (diff) | |
| parent | b710ed21dec88c0dde8209264df054c842561589 (diff) | |
| download | system_core-cbc76fcadb9b04007cc693aab39e86b33cb394aa.zip system_core-cbc76fcadb9b04007cc693aab39e86b33cb394aa.tar.gz system_core-cbc76fcadb9b04007cc693aab39e86b33cb394aa.tar.bz2 | |
Merge "init: move SELinux into enforcing mode."
| -rw-r--r--[-rwxr-xr-x] | init/init.c | 41 | 
1 files changed, 20 insertions, 21 deletions
| diff --git a/init/init.c b/init/init.c index 28d2863..4196620 100755..100644 --- a/init/init.c +++ b/init/init.c @@ -39,6 +39,7 @@  #include <libgen.h>  #include <cutils/list.h> +#include <cutils/android_reboot.h>  #include <cutils/sockets.h>  #include <cutils/iosched_policy.h>  #include <private/android_filesystem_config.h> @@ -73,8 +74,6 @@ static char hardware[32];  static unsigned revision = 0;  static char qemu[32]; -static int selinux_enabled = 1; -  static struct action *cur_action = NULL;  static struct command *cur_command = NULL;  static struct listnode *command_queue = NULL; @@ -614,10 +613,6 @@ static void import_kernel_nv(char *name, int for_emulator)      *value++ = 0;      if (name_len == 0) return; -    if (!strcmp(name,"selinux")) { -        selinux_enabled = atoi(value); -    } -      if (for_emulator) {          /* in the emulator, export any kernel option with the           * ro.kernel. prefix */ @@ -800,10 +795,6 @@ void selinux_init_all_handles(void)  int selinux_reload_policy(void)  { -    if (!selinux_enabled) { -        return -1; -    } -      INFO("SELinux: Attempting to reload policy files\n");      if (selinux_android_reload_policy() == -1) { @@ -826,6 +817,24 @@ int audit_callback(void *data, security_class_t cls, char *buf, size_t len)      return 0;  } +static void selinux_initialize(void) +{ +    if (access("/sys/fs/selinux", F_OK) != 0) { +        // SELinux is not compiled into this kernel. Fail gracefully. +        return; +    } + +    INFO("loading selinux policy\n"); +    if (selinux_android_load_policy() < 0) { +        ERROR("SELinux: Failed to load policy; rebooting into recovery mode\n"); +        android_reboot(ANDROID_RB_RESTART2, 0, "recovery"); +        while (1) { pause(); }  // never reached +    } + +    selinux_init_all_handles(); +    security_setenforce(1); +} +  int main(int argc, char **argv)  {      int fd_count = 0; @@ -886,17 +895,7 @@ int main(int argc, char **argv)      cb.func_audit = audit_callback;      selinux_set_callback(SELINUX_CB_AUDIT, cb); -    INFO("loading selinux policy\n"); -    if (selinux_enabled) { -        if (selinux_android_load_policy() < 0) { -            selinux_enabled = 0; -            INFO("SELinux: Disabled due to failed policy load\n"); -        } else { -            selinux_init_all_handles(); -        } -    } else { -        INFO("SELinux:  Disabled by command line option\n"); -    } +    selinux_initialize();      /* These directories were necessarily created before initial policy load       * and therefore need their security context restored to the proper value.       * This must happen before /dev is populated by ueventd. | 
