blob: f0af6be78162ff5c9b00b19081a45fb8ad55b35d [file] [log] [blame]
Matt Mowerec009e82015-01-30 13:00:49 -06001import /init.recovery.usb.rc
Matt Mower556411f2013-02-17 16:52:44 -06002import /init.recovery.${ro.hardware}.rc
3
Colin Crossdd6a0412010-05-14 13:42:20 -07004on early-init
Ethan Yonker58b09f12015-10-26 12:42:15 -05005 # Apply strict SELinux checking of PROT_EXEC on mmap/mprotect calls.
6 write /sys/fs/selinux/checkreqprot 0
7
8 # Set the security context for the init process.
9 # This should occur before anything else (e.g. ueventd) is started.
10 setcon u:r:init:s0
11
Colin Crossdd6a0412010-05-14 13:42:20 -070012 start ueventd
Todd Poynor2f2c9882013-06-04 13:11:44 -070013 start healthd
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080014
Ethan Yonkerc798c9c2015-10-09 11:15:26 -050015service set_permissive /sbin/permissive.sh
Ethan Yonker6cb35aa2014-12-16 14:21:42 -060016 oneshot
17 seclabel u:r:recovery:s0
18
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080019on init
Doug Zongker55d65422014-01-14 09:50:35 -080020 export PATH /sbin:/system/bin
Dees_Troy51a0e822012-09-05 15:24:24 -040021 export LD_LIBRARY_PATH .:/sbin
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080022 export ANDROID_ROOT /system
23 export ANDROID_DATA /data
24 export EXTERNAL_STORAGE /sdcard
25
Matt Mower556411f2013-02-17 16:52:44 -060026 mkdir /boot
27 mkdir /recovery
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080028 mkdir /system
29 mkdir /data
30 mkdir /cache
Doug Zongker075ad802014-06-26 15:35:51 -070031 mkdir /sideload
Doug Zongker55d65422014-01-14 09:50:35 -080032 mount tmpfs tmpfs /tmp
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080033
Matt Mower556411f2013-02-17 16:52:44 -060034 chown root shell /tmp
35 chmod 0775 /tmp
36
Colin Cross22bcf972014-06-24 13:43:39 -070037 write /proc/sys/kernel/panic_on_oops 1
Jesse Zhao5bf74b22015-01-08 15:59:23 -080038 write /proc/sys/vm/max_map_count 1000000
Colin Cross22bcf972014-06-24 13:43:39 -070039
Benoit Goby689e06b2014-02-19 17:41:02 -080040on fs
Vojtech Bocek05ec1d42015-03-08 16:32:41 +010041 mount pstore pstore /sys/fs/pstore
42
Benoit Goby689e06b2014-02-19 17:41:02 -080043 mkdir /dev/usb-ffs 0770 shell shell
44 mkdir /dev/usb-ffs/adb 0770 shell shell
45 mount functionfs adb /dev/usb-ffs/adb uid=2000,gid=2000
46
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080047on boot
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080048 ifup lo
49 hostname localhost
50 domainname localdomain
51
52 class_start default
53
Riley Andrewse739d7e2014-06-24 16:29:16 -070054# Load properties from /system/ + /factory after fs mount.
55on load_all_props_action
56 load_all_props
57
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070058on firmware_mounts_complete
59 rm /dev/.booting
60
Riley Andrewse739d7e2014-06-24 16:29:16 -070061# Mount filesystems and start core system services.
62on late-init
63 trigger early-fs
64 trigger fs
65 trigger post-fs
66 trigger post-fs-data
67
68 # Load properties from /system/ + /factory after fs mount. Place
69 # this in another action so that the load will be scheduled after the prior
70 # issued fs triggers have completed.
71 trigger load_all_props_action
72
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070073 # Remove a file to wake up anything waiting for firmware
74 trigger firmware_mounts_complete
75
Riley Andrewse739d7e2014-06-24 16:29:16 -070076 trigger early-boot
77 trigger boot
78
Doug Zongker77ea71d2013-08-30 12:20:16 -070079on property:sys.powerctl=*
80 powerctl ${sys.powerctl}
81
Colin Crossdd6a0412010-05-14 13:42:20 -070082service ueventd /sbin/ueventd
83 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050084 seclabel u:r:ueventd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080085
Todd Poynorbe968092013-09-13 16:34:12 -070086service healthd /sbin/healthd -r
Todd Poynor2f2c9882013-06-04 13:11:44 -070087 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050088 seclabel u:r:healthd:s0
Todd Poynor2f2c9882013-06-04 13:11:44 -070089
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080090service recovery /sbin/recovery
91
Nick Kralevichc52c5b82014-01-18 09:22:50 -080092service adbd /sbin/adbd --root_seclabel=u:r:su:s0 --device_banner=recovery
Kenny Rootecc76ba2010-06-28 09:01:22 -070093 disabled
Doug Zongkercc2958f2013-09-11 13:24:32 -070094 socket adbd stream 660 system system
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050095 seclabel u:r:adbd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080096
Mike Lockwood718a2f72011-06-29 10:22:04 -040097# Always start adbd on userdebug and eng builds
98on property:ro.debuggable=1
Dees_Troy0cd4cc22013-06-09 20:56:38 +000099 #write /sys/class/android_usb/android0/enable 1
100 #start adbd
Dees_Troy51a0e822012-09-05 15:24:24 -0400101 setprop service.adb.root 1
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -0800102
Mike Lockwood718a2f72011-06-29 10:22:04 -0400103# Restart adbd so it can run as root
Doug Zongkerfb04b872011-06-23 15:30:34 -0700104on property:service.adb.root=1
105 write /sys/class/android_usb/android0/enable 0
106 restart adbd
Benoit Goby689e06b2014-02-19 17:41:02 -0800107 write /sys/class/android_usb/android0/enable 1