blob: c654eedb8e846ef53ecbb26e461bdc1e14840e66 [file] [log] [blame]
Colin Crossf510f062012-08-08 13:06:26 -07001import /init.recovery.${ro.hardware}.rc
2
Colin Crossdd6a0412010-05-14 13:42:20 -07003on early-init
Stephen Smalley2c9d5b22014-01-13 09:44:42 -05004 # Apply strict SELinux checking of PROT_EXEC on mmap/mprotect calls.
5 write /sys/fs/selinux/checkreqprot 0
6
7 # Set the security context for the init process.
8 # This should occur before anything else (e.g. ueventd) is started.
9 setcon u:r:init:s0
10
Colin Crossdd6a0412010-05-14 13:42:20 -070011 start ueventd
Todd Poynor2f2c9882013-06-04 13:11:44 -070012 start healthd
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080013
14on init
Doug Zongker075ef322014-01-14 09:50:35 -080015 export PATH /sbin:/system/bin
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080016 export ANDROID_ROOT /system
17 export ANDROID_DATA /data
18 export EXTERNAL_STORAGE /sdcard
19
20 symlink /system/etc /etc
21
22 mkdir /sdcard
23 mkdir /system
24 mkdir /data
25 mkdir /cache
Doug Zongker075ad802014-06-26 15:35:51 -070026 mkdir /sideload
Doug Zongker075ef322014-01-14 09:50:35 -080027 mount tmpfs tmpfs /tmp
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080028
Doug Zongker703ed152012-03-19 15:52:03 -070029 chown root shell /tmp
30 chmod 0775 /tmp
31
Colin Cross22bcf972014-06-24 13:43:39 -070032 write /proc/sys/kernel/panic_on_oops 1
33
Benoit Goby1b964112014-02-19 17:41:02 -080034on fs
35 mkdir /dev/usb-ffs 0770 shell shell
36 mkdir /dev/usb-ffs/adb 0770 shell shell
37 mount functionfs adb /dev/usb-ffs/adb uid=2000,gid=2000
38
Doug Zongker66392482012-01-10 12:16:04 -080039 write /sys/class/android_usb/android0/enable 0
40 write /sys/class/android_usb/android0/idVendor 18D1
41 write /sys/class/android_usb/android0/idProduct D001
Benoit Goby1b964112014-02-19 17:41:02 -080042 write /sys/class/android_usb/android0/f_ffs/aliases adb
Doug Zongker66392482012-01-10 12:16:04 -080043 write /sys/class/android_usb/android0/functions adb
44 write /sys/class/android_usb/android0/iManufacturer ${ro.product.manufacturer}
45 write /sys/class/android_usb/android0/iProduct ${ro.product.model}
46 write /sys/class/android_usb/android0/iSerial ${ro.serialno}
47
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080048on boot
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080049 ifup lo
50 hostname localhost
51 domainname localdomain
52
53 class_start default
54
Riley Andrewse739d7e2014-06-24 16:29:16 -070055# Load properties from /system/ + /factory after fs mount.
56on load_all_props_action
57 load_all_props
58
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070059on firmware_mounts_complete
60 rm /dev/.booting
61
Riley Andrewse739d7e2014-06-24 16:29:16 -070062# Mount filesystems and start core system services.
63on late-init
64 trigger early-fs
65 trigger fs
66 trigger post-fs
67 trigger post-fs-data
68
69 # Load properties from /system/ + /factory after fs mount. Place
70 # this in another action so that the load will be scheduled after the prior
71 # issued fs triggers have completed.
72 trigger load_all_props_action
73
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070074 # Remove a file to wake up anything waiting for firmware
75 trigger firmware_mounts_complete
76
Riley Andrewse739d7e2014-06-24 16:29:16 -070077 trigger early-boot
78 trigger boot
79
Doug Zongker77ea71d2013-08-30 12:20:16 -070080on property:sys.powerctl=*
81 powerctl ${sys.powerctl}
82
Colin Crossdd6a0412010-05-14 13:42:20 -070083service ueventd /sbin/ueventd
84 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050085 seclabel u:r:ueventd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080086
Todd Poynorbe968092013-09-13 16:34:12 -070087service healthd /sbin/healthd -r
Todd Poynor2f2c9882013-06-04 13:11:44 -070088 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050089 seclabel u:r:healthd:s0
Todd Poynor2f2c9882013-06-04 13:11:44 -070090
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080091service recovery /sbin/recovery
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050092 seclabel u:r:recovery:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080093
Nick Kralevichc52c5b82014-01-18 09:22:50 -080094service adbd /sbin/adbd --root_seclabel=u:r:su:s0 --device_banner=recovery
Kenny Rootecc76ba2010-06-28 09:01:22 -070095 disabled
Doug Zongkercc2958f2013-09-11 13:24:32 -070096 socket adbd stream 660 system system
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050097 seclabel u:r:adbd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080098
Mike Lockwood718a2f72011-06-29 10:22:04 -040099# Always start adbd on userdebug and eng builds
100on property:ro.debuggable=1
Mike Lockwood7e58b652011-06-19 02:52:01 -0400101 write /sys/class/android_usb/android0/enable 1
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -0800102 start adbd
103
Mike Lockwood718a2f72011-06-29 10:22:04 -0400104# Restart adbd so it can run as root
Doug Zongkerfb04b872011-06-23 15:30:34 -0700105on property:service.adb.root=1
106 write /sys/class/android_usb/android0/enable 0
107 restart adbd
108 write /sys/class/android_usb/android0/enable 1