blob: aeb99da0937fb69a8005e59737ef9e7bdfd10f51 [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
Alex Deymo080f5222016-03-02 14:21:02 -08004 # Set the security context of /postinstall if present.
5 restorecon /postinstall
6
Colin Crossdd6a0412010-05-14 13:42:20 -07007 start ueventd
Todd Poynor2f2c9882013-06-04 13:11:44 -07008 start healthd
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -08009
10on init
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080011 export ANDROID_ROOT /system
12 export ANDROID_DATA /data
13 export EXTERNAL_STORAGE /sdcard
14
15 symlink /system/etc /etc
16
17 mkdir /sdcard
18 mkdir /system
19 mkdir /data
20 mkdir /cache
Doug Zongker075ad802014-06-26 15:35:51 -070021 mkdir /sideload
Amit Blay8aca5122016-08-22 12:27:14 +030022 mkdir /firmware
Doug Zongker075ef322014-01-14 09:50:35 -080023 mount tmpfs tmpfs /tmp
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080024
Doug Zongker703ed152012-03-19 15:52:03 -070025 chown root shell /tmp
26 chmod 0775 /tmp
27
Colin Cross22bcf972014-06-24 13:43:39 -070028 write /proc/sys/kernel/panic_on_oops 1
Jesse Zhao5bf74b22015-01-08 15:59:23 -080029 write /proc/sys/vm/max_map_count 1000000
Colin Cross22bcf972014-06-24 13:43:39 -070030
Benoit Goby1b964112014-02-19 17:41:02 -080031on fs
32 mkdir /dev/usb-ffs 0770 shell shell
33 mkdir /dev/usb-ffs/adb 0770 shell shell
34 mount functionfs adb /dev/usb-ffs/adb uid=2000,gid=2000
35
Doug Zongker66392482012-01-10 12:16:04 -080036 write /sys/class/android_usb/android0/enable 0
37 write /sys/class/android_usb/android0/idVendor 18D1
38 write /sys/class/android_usb/android0/idProduct D001
Benoit Goby1b964112014-02-19 17:41:02 -080039 write /sys/class/android_usb/android0/f_ffs/aliases adb
Doug Zongker66392482012-01-10 12:16:04 -080040 write /sys/class/android_usb/android0/functions adb
41 write /sys/class/android_usb/android0/iManufacturer ${ro.product.manufacturer}
42 write /sys/class/android_usb/android0/iProduct ${ro.product.model}
43 write /sys/class/android_usb/android0/iSerial ${ro.serialno}
44
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080045on boot
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080046 ifup lo
47 hostname localhost
48 domainname localdomain
49
50 class_start default
51
Riley Andrewse739d7e2014-06-24 16:29:16 -070052# Load properties from /system/ + /factory after fs mount.
Paul Lawrence90c75b02015-07-06 10:44:33 -070053on load_system_props_action
54 load_system_props
Riley Andrewse739d7e2014-06-24 16:29:16 -070055
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070056on firmware_mounts_complete
57 rm /dev/.booting
58
Riley Andrewse739d7e2014-06-24 16:29:16 -070059# Mount filesystems and start core system services.
60on late-init
61 trigger early-fs
62 trigger fs
63 trigger post-fs
64 trigger post-fs-data
65
66 # Load properties from /system/ + /factory after fs mount. Place
67 # this in another action so that the load will be scheduled after the prior
68 # issued fs triggers have completed.
Paul Lawrence90c75b02015-07-06 10:44:33 -070069 trigger load_system_props_action
Riley Andrewse739d7e2014-06-24 16:29:16 -070070
JP Abgrall9eb8c8b2014-10-20 20:02:57 -070071 # Remove a file to wake up anything waiting for firmware
72 trigger firmware_mounts_complete
73
Riley Andrewse739d7e2014-06-24 16:29:16 -070074 trigger early-boot
75 trigger boot
76
Doug Zongker77ea71d2013-08-30 12:20:16 -070077on property:sys.powerctl=*
78 powerctl ${sys.powerctl}
79
Colin Crossdd6a0412010-05-14 13:42:20 -070080service ueventd /sbin/ueventd
81 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050082 seclabel u:r:ueventd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080083
Todd Poynorbe968092013-09-13 16:34:12 -070084service healthd /sbin/healthd -r
Todd Poynor2f2c9882013-06-04 13:11:44 -070085 critical
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050086 seclabel u:r:healthd:s0
Todd Poynor2f2c9882013-06-04 13:11:44 -070087
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080088service recovery /sbin/recovery
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050089 seclabel u:r:recovery:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080090
Nick Kralevichc52c5b82014-01-18 09:22:50 -080091service adbd /sbin/adbd --root_seclabel=u:r:su:s0 --device_banner=recovery
Kenny Rootecc76ba2010-06-28 09:01:22 -070092 disabled
Doug Zongkercc2958f2013-09-11 13:24:32 -070093 socket adbd stream 660 system system
Stephen Smalley2c9d5b22014-01-13 09:44:42 -050094 seclabel u:r:adbd:s0
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080095
Mike Lockwood718a2f72011-06-29 10:22:04 -040096# Always start adbd on userdebug and eng builds
97on property:ro.debuggable=1
Mike Lockwood7e58b652011-06-19 02:52:01 -040098 write /sys/class/android_usb/android0/enable 1
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080099 start adbd
100
Mike Lockwood718a2f72011-06-29 10:22:04 -0400101# Restart adbd so it can run as root
Doug Zongkerfb04b872011-06-23 15:30:34 -0700102on property:service.adb.root=1
103 write /sys/class/android_usb/android0/enable 0
104 restart adbd
105 write /sys/class/android_usb/android0/enable 1