blob: 847a293900a56479ad5c2cc9e0321692b085855f [file] [log] [blame]
Captain Throwback1f127752016-01-19 17:30:20 -05001import /init.recovery.logd.rc
Matt Mowerec009e82015-01-30 13:00:49 -06002import /init.recovery.usb.rc
Ethan Yonkerf1179622016-08-25 15:32:21 -05003import /init.recovery.service.rc
nkk7171c6c502017-01-05 23:55:05 +02004import /init.recovery.vold_decrypt.rc
Matt Mower556411f2013-02-17 16:52:44 -06005import /init.recovery.${ro.hardware}.rc
6
Colin Crossdd6a0412010-05-14 13:42:20 -07007on early-init
Ethan Yonker58b09f12015-10-26 12:42:15 -05008 # Apply strict SELinux checking of PROT_EXEC on mmap/mprotect calls.
9 write /sys/fs/selinux/checkreqprot 0
10
11 # Set the security context for the init process.
12 # This should occur before anything else (e.g. ueventd) is started.
13 setcon u:r:init:s0
14
Alex Deymo080f5222016-03-02 14:21:02 -080015 # Set the security context of /postinstall if present.
16 restorecon /postinstall
17
Colin Crossdd6a0412010-05-14 13:42:20 -070018 start ueventd
Todd Poynor2f2c9882013-06-04 13:11:44 -070019 start healthd
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080020
Ethan Yonkerc798c9c2015-10-09 11:15:26 -050021service set_permissive /sbin/permissive.sh
Ethan Yonker6cb35aa2014-12-16 14:21:42 -060022 oneshot
23 seclabel u:r:recovery:s0
24
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080025on init
Doug Zongker55d65422014-01-14 09:50:35 -080026 export PATH /sbin:/system/bin
Dees_Troy51a0e822012-09-05 15:24:24 -040027 export LD_LIBRARY_PATH .:/sbin
Ethan Yonker34ae4832016-08-24 15:32:18 -050028
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080029 export ANDROID_ROOT /system
30 export ANDROID_DATA /data
31 export EXTERNAL_STORAGE /sdcard
32
Matt Mower556411f2013-02-17 16:52:44 -060033 mkdir /boot
34 mkdir /recovery
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080035 mkdir /system
36 mkdir /data
37 mkdir /cache
Doug Zongker075ad802014-06-26 15:35:51 -070038 mkdir /sideload
Doug Zongker55d65422014-01-14 09:50:35 -080039 mount tmpfs tmpfs /tmp
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080040
Matt Mower556411f2013-02-17 16:52:44 -060041 chown root shell /tmp
42 chmod 0775 /tmp
43
Colin Cross22bcf972014-06-24 13:43:39 -070044 write /proc/sys/kernel/panic_on_oops 1
Jesse Zhao5bf74b22015-01-08 15:59:23 -080045 write /proc/sys/vm/max_map_count 1000000
Colin Cross22bcf972014-06-24 13:43:39 -070046
Benoit Goby689e06b2014-02-19 17:41:02 -080047on fs
Vojtech Bocek05ec1d42015-03-08 16:32:41 +010048 mount pstore pstore /sys/fs/pstore
49
Benoit Goby689e06b2014-02-19 17:41:02 -080050 mkdir /dev/usb-ffs 0770 shell shell
51 mkdir /dev/usb-ffs/adb 0770 shell shell
52 mount functionfs adb /dev/usb-ffs/adb uid=2000,gid=2000
53
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080054on boot
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080055 ifup lo
56 hostname localhost
57 domainname localdomain
58
59 class_start default
60
Matt Mower4251a9b2015-11-13 14:01:49 -060061# Load properties, pre-Android 6.0
Riley Andrewse739d7e2014-06-24 16:29:16 -070062on load_all_props_action
63 load_all_props
64
Matt Mower4251a9b2015-11-13 14:01:49 -060065# Load properties, Android 6.0+
66on load_system_props_action
67 load_system_props
68
69# Load properties, Android 6.0+, vendor init lives here
70on load_persist_props_action
71 load_persist_props
72
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070073on firmware_mounts_complete
Matt Mower4251a9b2015-11-13 14:01:49 -060074 rm /dev/.booting
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070075
Riley Andrewse739d7e2014-06-24 16:29:16 -070076# Mount filesystems and start core system services.
77on late-init
78 trigger early-fs
79 trigger fs
80 trigger post-fs
81 trigger post-fs-data
82
Matt Mower4251a9b2015-11-13 14:01:49 -060083 # Load properties, pre-Android 6.0
Riley Andrewse739d7e2014-06-24 16:29:16 -070084 trigger load_all_props_action
85
Riley Andrewse739d7e2014-06-24 16:29:16 -070086 # Load properties from /system/ + /factory after fs mount. Place
87 # this in another action so that the load will be scheduled after the prior
88 # issued fs triggers have completed.
Paul Lawrence90c75b02015-07-06 10:44:33 -070089 trigger load_system_props_action
Riley Andrewse739d7e2014-06-24 16:29:16 -070090
Matt Mower4251a9b2015-11-13 14:01:49 -060091 # Load properties, Android 6.0+, vendor init lives here
92 trigger load_persist_props_action
93
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070094 # Remove a file to wake up anything waiting for firmware
95 trigger firmware_mounts_complete
96
Riley Andrewse739d7e2014-06-24 16:29:16 -070097 trigger early-boot
98 trigger boot
99
Doug Zongker77ea71d2013-08-30 12:20:16 -0700100on property:sys.powerctl=*
101 powerctl ${sys.powerctl}
102
Colin Crossdd6a0412010-05-14 13:42:20 -0700103service ueventd /sbin/ueventd
104 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -0500105 seclabel u:r:ueventd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -0800106
Todd Poynorbe968092013-09-13 16:34:12 -0700107service healthd /sbin/healthd -r
Todd Poynor2f2c9882013-06-04 13:11:44 -0700108 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -0500109 seclabel u:r:healthd:s0
Todd Poynor2f2c9882013-06-04 13:11:44 -0700110
Nick Kralevichc52c5b82014-01-18 09:22:50 -0800111service adbd /sbin/adbd --root_seclabel=u:r:su:s0 --device_banner=recovery
Kenny Rootecc76ba2010-06-28 09:01:22 -0700112 disabled
Doug Zongkercc2958f2013-09-11 13:24:32 -0700113 socket adbd stream 660 system system
Stephen Smalley2c9d5b22014-01-13 09:44:42 -0500114 seclabel u:r:adbd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -0800115
Mike Lockwood718a2f72011-06-29 10:22:04 -0400116# Always start adbd on userdebug and eng builds
117on property:ro.debuggable=1
Dees_Troy0cd4cc22013-06-09 20:56:38 +0000118 #write /sys/class/android_usb/android0/enable 1
119 #start adbd
Dees_Troy51a0e822012-09-05 15:24:24 -0400120 setprop service.adb.root 1
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -0800121
Mike Lockwood718a2f72011-06-29 10:22:04 -0400122# Restart adbd so it can run as root
Doug Zongkerfb04b872011-06-23 15:30:34 -0700123on property:service.adb.root=1
124 write /sys/class/android_usb/android0/enable 0
125 restart adbd
Benoit Goby689e06b2014-02-19 17:41:02 -0800126 write /sys/class/android_usb/android0/enable 1