builtins.c revision 42a9349dc4e98019d27d7f8d19bc6c431695d7e1
14f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project/* 24f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * Copyright (C) 2008 The Android Open Source Project 34f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * 44f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 54f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * you may not use this file except in compliance with the License. 64f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * You may obtain a copy of the License at 74f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * 84f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 94f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * 104f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 114f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 124f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 134f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * See the License for the specific language governing permissions and 144f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * limitations under the License. 154f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project */ 164f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 174f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <sys/types.h> 184f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <sys/stat.h> 194f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <fcntl.h> 204f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <unistd.h> 214f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <string.h> 224f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <stdio.h> 234f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <linux/kd.h> 244f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <errno.h> 254f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <sys/socket.h> 264f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <netinet/in.h> 274f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <linux/if.h> 284f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <arpa/inet.h> 294f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <stdlib.h> 304f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <sys/mount.h> 314f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <sys/resource.h> 32e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik)#include <linux/loop.h> 337bc6e9ebe4783d5fbae17d7249cb80e997531598Ken Sumrall#include <cutils/partition_utils.h> 3484bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin#include <sys/system_properties.h> 354f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 36e46f9d510db9351682cf17c49115110870147335Stephen Smalley#ifdef HAVE_SELINUX 37e46f9d510db9351682cf17c49115110870147335Stephen Smalley#include <selinux/selinux.h> 38e46f9d510db9351682cf17c49115110870147335Stephen Smalley#include <selinux/label.h> 39e46f9d510db9351682cf17c49115110870147335Stephen Smalley#endif 40e46f9d510db9351682cf17c49115110870147335Stephen Smalley 414f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include "init.h" 424f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include "keywords.h" 434f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include "property_service.h" 444f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include "devices.h" 456310a8261c922533a692fb3e74ece2da98d4bafaColin Cross#include "init_parser.h" 463899e9fc01cf608f19f716749c54cc5c4d17e766Colin Cross#include "util.h" 47ed8a7d84428ec945c48b6b53dc5a3a18fabaf683Colin Cross#include "log.h" 484f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 494f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project#include <private/android_filesystem_config.h> 504f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 514f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectvoid add_environment(const char *name, const char *value); 524f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 534f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectextern int init_module(void *, unsigned long, const char *); 544f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 554f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectstatic int write_file(const char *path, const char *value) 564f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 574f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project int fd, ret, len; 584f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 594f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project fd = open(path, O_WRONLY|O_CREAT, 0622); 604f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 614f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (fd < 0) 62008abac082f1c098d402f944d9287dce67ffce0aMike Chan return -errno; 634f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 644f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project len = strlen(value); 654f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 664f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project do { 674f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project ret = write(fd, value, len); 684f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } while (ret < 0 && errno == EINTR); 694f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 704f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project close(fd); 714f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (ret < 0) { 72008abac082f1c098d402f944d9287dce67ffce0aMike Chan return -errno; 734f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } else { 744f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 754f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 764f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 774f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 7842a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condrastatic int _chown(const char *path, unsigned int uid, unsigned int gid) 7942a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra{ 8042a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra int fd; 8142a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra int ret; 8242a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 8342a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra fd = open(path, O_RDONLY | O_NOFOLLOW); 8442a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (fd < 0) { 8542a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra return -1; 8642a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra } 8742a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 8842a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra ret = fchown(fd, uid, gid); 8942a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (ret < 0) { 9042a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra int errno_copy = errno; 9142a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra close(fd); 9242a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra errno = errno_copy; 9342a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra return -1; 9442a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra } 9542a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 9642a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra close(fd); 9742a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 9842a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra return 0; 9942a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra} 10042a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 10142a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condrastatic int _chmod(const char *path, mode_t mode) 10242a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra{ 10342a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra int fd; 10442a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra int ret; 10542a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 10642a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra fd = open(path, O_RDONLY | O_NOFOLLOW); 10742a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (fd < 0) { 10842a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra return -1; 10942a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra } 11042a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 11142a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra ret = fchmod(fd, mode); 11242a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (ret < 0) { 11342a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra int errno_copy = errno; 11442a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra close(fd); 11542a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra errno = errno_copy; 11642a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra return -1; 11742a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra } 11842a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 11942a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra close(fd); 12042a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 12142a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra return 0; 12242a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra} 12342a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra 12435237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Projectstatic int insmod(const char *filename, char *options) 1254f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 1264f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project void *module; 1274f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project unsigned size; 1284f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project int ret; 1294f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1304f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project module = read_file(filename, &size); 1314f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (!module) 1324f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -1; 1334f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 13435237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project ret = init_module(module, size, options); 1354f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1364f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project free(module); 1374f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1384f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return ret; 1394f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 1404f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1414f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectstatic int setkey(struct kbentry *kbe) 1424f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 1434f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project int fd, ret; 1444f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1454f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project fd = open("/dev/tty0", O_RDWR | O_SYNC); 1464f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (fd < 0) 1474f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -1; 1484f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1494f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project ret = ioctl(fd, KDSKBENT, kbe); 1504f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1514f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project close(fd); 1524f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return ret; 1534f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 1544f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1554f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectstatic int __ifupdown(const char *interface, int up) 1564f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 1574f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project struct ifreq ifr; 1584f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project int s, ret; 1594f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1604f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project strlcpy(ifr.ifr_name, interface, IFNAMSIZ); 1614f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1624f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project s = socket(AF_INET, SOCK_DGRAM, 0); 1634f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (s < 0) 1644f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -1; 1654f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1664f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project ret = ioctl(s, SIOCGIFFLAGS, &ifr); 1674f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (ret < 0) { 1684f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project goto done; 1694f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 1704f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1714f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (up) 1724f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project ifr.ifr_flags |= IFF_UP; 1734f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project else 1744f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project ifr.ifr_flags &= ~IFF_UP; 1754f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1764f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project ret = ioctl(s, SIOCSIFFLAGS, &ifr); 1774f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1784f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectdone: 1794f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project close(s); 1804f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return ret; 1814f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 1824f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 1834f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectstatic void service_start_if_not_disabled(struct service *svc) 1844f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 1854f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (!(svc->flags & SVC_DISABLED)) { 186f24e252903ca0f71c7fbfb135cf17e83e0c2ea90San Mehat service_start(svc, NULL); 1874f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 1884f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 1894f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 190e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik)int do_chdir(int nargs, char **args) 191e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik){ 192e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik) chdir(args[1]); 193e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik) return 0; 194e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik)} 195e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik) 196e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik)int do_chroot(int nargs, char **args) 197e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik){ 198e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik) chroot(args[1]); 199e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik) return 0; 200e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik)} 201e7cb137f32fbc7caf97b80fac152b4bd3ac242cdJay Freeman (saurik) 2024f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_class_start(int nargs, char **args) 2034f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2044f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project /* Starting a class does not start services 2054f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * which are explicitly disabled. They must 2064f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project * be started individually. 2074f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project */ 2084f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project service_for_each_class(args[1], service_start_if_not_disabled); 2094f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 2104f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2114f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2124f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_class_stop(int nargs, char **args) 2134f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2144f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project service_for_each_class(args[1], service_stop); 2154f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 2164f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2174f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 218752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrallint do_class_reset(int nargs, char **args) 219752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall{ 220752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall service_for_each_class(args[1], service_reset); 221752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall return 0; 222752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall} 223752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall 2244f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_domainname(int nargs, char **args) 2254f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2264f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return write_file("/proc/sys/kernel/domainname", args[1]); 2274f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2284f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2294f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_exec(int nargs, char **args) 2304f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2314f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -1; 2324f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2334f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2344f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_export(int nargs, char **args) 2354f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2364f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project add_environment(args[1], args[2]); 2374f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 2384f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2394f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2404f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_hostname(int nargs, char **args) 2414f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2424f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return write_file("/proc/sys/kernel/hostname", args[1]); 2434f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2444f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2454f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_ifup(int nargs, char **args) 2464f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2474f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return __ifupdown(args[1], 1); 2484f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2494f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 25035237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 25135237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Projectstatic int do_insmod_inner(int nargs, char **args, int opt_len) 25235237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project{ 25335237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project char options[opt_len + 1]; 25435237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project int i; 25535237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 25635237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project options[0] = '\0'; 25735237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project if (nargs > 2) { 25835237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project strcpy(options, args[2]); 25935237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project for (i = 3; i < nargs; ++i) { 26035237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project strcat(options, " "); 26135237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project strcat(options, args[i]); 26235237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project } 26335237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project } 26435237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 26535237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project return insmod(args[1], options); 26635237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project} 26735237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 2684f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_insmod(int nargs, char **args) 2694f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 27035237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project int i; 27135237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project int size = 0; 27235237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 27335237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project if (nargs > 2) { 27435237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project for (i = 2; i < nargs; ++i) 27535237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project size += strlen(args[i]) + 1; 27635237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project } 27735237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 27835237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project return do_insmod_inner(nargs, args, size); 2794f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 2804f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2814f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_mkdir(int nargs, char **args) 2824f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 2834f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project mode_t mode = 0755; 28427164dce5f0788476449057c978fa24e62245cb8Chia-chi Yeh int ret; 2854f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2864f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project /* mkdir <path> [mode] [owner] [group] */ 2874f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 2884f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (nargs >= 3) { 2894f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project mode = strtoul(args[2], 0, 8); 2904f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 2914f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 29227164dce5f0788476449057c978fa24e62245cb8Chia-chi Yeh ret = mkdir(args[1], mode); 29327164dce5f0788476449057c978fa24e62245cb8Chia-chi Yeh /* chmod in case the directory already exists */ 29427164dce5f0788476449057c978fa24e62245cb8Chia-chi Yeh if (ret == -1 && errno == EEXIST) { 29542a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra ret = _chmod(args[1], mode); 29627164dce5f0788476449057c978fa24e62245cb8Chia-chi Yeh } 29727164dce5f0788476449057c978fa24e62245cb8Chia-chi Yeh if (ret == -1) { 2984f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -errno; 2994f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 3004f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 3014f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (nargs >= 4) { 3024f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project uid_t uid = decode_uid(args[3]); 3034f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project gid_t gid = -1; 3044f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 3054f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (nargs == 5) { 3064f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project gid = decode_uid(args[4]); 3074f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 3084f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 30942a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (_chown(args[1], uid, gid) < 0) { 3104f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -errno; 3114f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 3124f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 3134f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 3144f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 3154f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 3164f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 3174f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectstatic struct { 3184f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project const char *name; 3194f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project unsigned flag; 3204f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} mount_flags[] = { 3214f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "noatime", MS_NOATIME }, 322b6ee25e3ad4cffa2b0f5bb734df4b503e1e367baLars Svensson { "noexec", MS_NOEXEC }, 3234f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "nosuid", MS_NOSUID }, 3244f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "nodev", MS_NODEV }, 3254f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "nodiratime", MS_NODIRATIME }, 3264f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "ro", MS_RDONLY }, 3274f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "rw", 0 }, 3284f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "remount", MS_REMOUNT }, 3294f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { "defaults", 0 }, 3304f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project { 0, 0 }, 3314f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project}; 3324f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 333752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall#define DATA_MNT_POINT "/data" 334752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall 3354f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project/* mount <type> <device> <path> <flags ...> <options> */ 3364f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_mount(int nargs, char **args) 3374f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 3384f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project char tmp[64]; 339e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) char *source, *target, *system; 3404f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project char *options = NULL; 3414f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project unsigned flags = 0; 3424f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project int n, i; 343cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross int wait = 0; 3444f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 3454f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project for (n = 4; n < nargs; n++) { 3464f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project for (i = 0; mount_flags[i].name; i++) { 3474f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (!strcmp(args[n], mount_flags[i].name)) { 3484f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project flags |= mount_flags[i].flag; 3494f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project break; 3504f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 3514f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 3524f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 353cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross if (!mount_flags[i].name) { 354cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross if (!strcmp(args[n], "wait")) 355cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross wait = 1; 356cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross /* if our last argument isn't a flag, wolf it up as an option string */ 357cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross else if (n + 1 == nargs) 358cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross options = args[n]; 359cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross } 3604f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 3614f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 362e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) system = args[1]; 3634f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project source = args[2]; 364e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) target = args[3]; 365e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 3664f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (!strncmp(source, "mtd@", 4)) { 3674f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project n = mtd_name_to_number(source + 4); 368e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (n < 0) { 369e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) return -1; 370e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 371e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 372e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) sprintf(tmp, "/dev/block/mtdblock%d", n); 373e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 374cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross if (wait) 375cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross wait_for_file(tmp, COMMAND_RETRY_TIMEOUT); 376e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (mount(tmp, target, system, flags, options) < 0) { 377e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) return -1; 378e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 379e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 380dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall goto exit_success; 381e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } else if (!strncmp(source, "loop@", 5)) { 382e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) int mode, loop, fd; 383e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) struct loop_info info; 384e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 385e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) mode = (flags & MS_RDONLY) ? O_RDONLY : O_RDWR; 386e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) fd = open(source + 5, mode); 387e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (fd < 0) { 388e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) return -1; 3894f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 390e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 391e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) for (n = 0; ; n++) { 392e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) sprintf(tmp, "/dev/block/loop%d", n); 393e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) loop = open(tmp, mode); 394e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (loop < 0) { 395e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) return -1; 396e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 397e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 398e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) /* if it is a blank loop device */ 399e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (ioctl(loop, LOOP_GET_STATUS, &info) < 0 && errno == ENXIO) { 400e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) /* if it becomes our loop device */ 401e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (ioctl(loop, LOOP_SET_FD, fd) >= 0) { 402e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) close(fd); 403e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 404e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (mount(tmp, target, system, flags, options) < 0) { 405e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) ioctl(loop, LOOP_CLR_FD, 0); 406e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) close(loop); 407e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) return -1; 408e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 409e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 410e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) close(loop); 411dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall goto exit_success; 412e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 413e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 414e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 415e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) close(loop); 416e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 417e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 418e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) close(fd); 419e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) ERROR("out of loopback devices"); 420e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) return -1; 421e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } else { 422cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross if (wait) 423cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross wait_for_file(source, COMMAND_RETRY_TIMEOUT); 424e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) if (mount(source, target, system, flags, options) < 0) { 4257bc6e9ebe4783d5fbae17d7249cb80e997531598Ken Sumrall /* If this fails, it may be an encrypted filesystem 4267bc6e9ebe4783d5fbae17d7249cb80e997531598Ken Sumrall * or it could just be wiped. If wiped, that will be 4277bc6e9ebe4783d5fbae17d7249cb80e997531598Ken Sumrall * handled later in the boot process. 428752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall * We only support encrypting /data. Check 429752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall * if we're trying to mount it, and if so, 430752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall * assume it's encrypted, mount a tmpfs instead. 431752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall * Then save the orig mount parms in properties 432752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall * for vold to query when it mounts the real 433752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall * encrypted /data. 434752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall */ 4357bc6e9ebe4783d5fbae17d7249cb80e997531598Ken Sumrall if (!strcmp(target, DATA_MNT_POINT) && !partition_wiped(source)) { 436752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall const char *tmpfs_options; 437752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall 438752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall tmpfs_options = property_get("ro.crypto.tmpfs_options"); 439752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall 440752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall if (mount("tmpfs", target, "tmpfs", MS_NOATIME | MS_NOSUID | MS_NODEV, 441752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall tmpfs_options) < 0) { 442752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall return -1; 443752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall } 444752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall 445752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall /* Set the property that triggers the framework to do a minimal 446752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall * startup and ask the user for a password 447752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall */ 4484e84d3bcf9af3452128fe2e8dc7607dff9016facKen Sumrall property_set("ro.crypto.state", "encrypted"); 449752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall property_set("vold.decrypt", "1"); 450752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall } else { 451752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall return -1; 452752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall } 453e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) } 454e520d036165b36cf5c4cb305f9cec7d183977b61Jay Freeman (saurik) 455752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall if (!strcmp(target, DATA_MNT_POINT)) { 456752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall char fs_flags[32]; 457752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall 458752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall /* Save the original mount options */ 459752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall property_set("ro.crypto.fs_type", system); 460752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall property_set("ro.crypto.fs_real_blkdev", source); 461752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall property_set("ro.crypto.fs_mnt_point", target); 462752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall if (options) { 463752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall property_set("ro.crypto.fs_options", options); 464752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall } 465752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall snprintf(fs_flags, sizeof(fs_flags), "0x%8.8x", flags); 466752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall property_set("ro.crypto.fs_flags", fs_flags); 467752923c168009d03e9e00e590155fbd0a2880ccbKen Sumrall } 4684f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 469dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall 470dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrallexit_success: 471dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall /* If not running encrypted, then set the property saying we are 472dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall * unencrypted, and also trigger the action for a nonencrypted system. 473dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall */ 474dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall if (!strcmp(target, DATA_MNT_POINT)) { 475c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall const char *prop; 476c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall 477dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall prop = property_get("ro.crypto.state"); 478dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall if (! prop) { 479dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall prop = "notset"; 480dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall } 481dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall if (strcmp(prop, "encrypted")) { 482dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall property_set("ro.crypto.state", "unencrypted"); 483dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall action_for_each_trigger("nonencrypted", action_add_queue_tail); 484dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall } 485dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall } 486dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall 487dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall return 0; 488dd4d786cbf993a024fcd0f926fd40b90c8a08d51Ken Sumrall 4894f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 4904f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 491e46f9d510db9351682cf17c49115110870147335Stephen Smalleyint do_setcon(int nargs, char **args) { 492e46f9d510db9351682cf17c49115110870147335Stephen Smalley#ifdef HAVE_SELINUX 493e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (is_selinux_enabled() <= 0) 494e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 495e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (setcon(args[1]) < 0) { 496e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -errno; 497e46f9d510db9351682cf17c49115110870147335Stephen Smalley } 498e46f9d510db9351682cf17c49115110870147335Stephen Smalley#endif 499e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 500e46f9d510db9351682cf17c49115110870147335Stephen Smalley} 501e46f9d510db9351682cf17c49115110870147335Stephen Smalley 502e46f9d510db9351682cf17c49115110870147335Stephen Smalleyint do_setenforce(int nargs, char **args) { 503e46f9d510db9351682cf17c49115110870147335Stephen Smalley#ifdef HAVE_SELINUX 504e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (is_selinux_enabled() <= 0) 505e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 506e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (security_setenforce(atoi(args[1])) < 0) { 507e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -errno; 508e46f9d510db9351682cf17c49115110870147335Stephen Smalley } 509e46f9d510db9351682cf17c49115110870147335Stephen Smalley#endif 510e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 511e46f9d510db9351682cf17c49115110870147335Stephen Smalley} 512e46f9d510db9351682cf17c49115110870147335Stephen Smalley 5134f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_setkey(int nargs, char **args) 5144f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 5154f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project struct kbentry kbe; 5164f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project kbe.kb_table = strtoul(args[1], 0, 0); 5174f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project kbe.kb_index = strtoul(args[2], 0, 0); 5184f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project kbe.kb_value = strtoul(args[3], 0, 0); 5194f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return setkey(&kbe); 5204f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5214f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 5224f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_setprop(int nargs, char **args) 5234f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 5241f0bd32f90161940d531040677099f32eef21fc4Mike Lockwood const char *name = args[1]; 5251f0bd32f90161940d531040677099f32eef21fc4Mike Lockwood const char *value = args[2]; 52684bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin char prop_val[PROP_VALUE_MAX]; 52784bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin int ret; 5281f0bd32f90161940d531040677099f32eef21fc4Mike Lockwood 52984bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin ret = expand_props(prop_val, value, sizeof(prop_val)); 53084bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin if (ret) { 53184bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin ERROR("cannot expand '%s' while assigning to '%s'\n", value, name); 53284bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin return -EINVAL; 5331f0bd32f90161940d531040677099f32eef21fc4Mike Lockwood } 53484bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin property_set(name, prop_val); 5354f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 5364f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5374f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 5384f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_setrlimit(int nargs, char **args) 5394f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 5404f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project struct rlimit limit; 5414f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project int resource; 5424f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project resource = atoi(args[1]); 5434f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project limit.rlim_cur = atoi(args[2]); 5444f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project limit.rlim_max = atoi(args[3]); 5454f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return setrlimit(resource, &limit); 5464f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5474f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 5484f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_start(int nargs, char **args) 5494f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 5504f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project struct service *svc; 5514f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project svc = service_find_by_name(args[1]); 5524f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (svc) { 553f24e252903ca0f71c7fbfb135cf17e83e0c2ea90San Mehat service_start(svc, NULL); 5544f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 5554f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 5564f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5574f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 5584f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_stop(int nargs, char **args) 5594f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 5604f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project struct service *svc; 5614f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project svc = service_find_by_name(args[1]); 5624f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (svc) { 5634f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project service_stop(svc); 5644f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 5654f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 5664f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5674f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 5684f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_restart(int nargs, char **args) 5694f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 5704f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project struct service *svc; 5714f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project svc = service_find_by_name(args[1]); 5724f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (svc) { 5734f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project service_stop(svc); 574f24e252903ca0f71c7fbfb135cf17e83e0c2ea90San Mehat service_start(svc, NULL); 5754f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 5764f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 5774f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5784f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 5794f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_trigger(int nargs, char **args) 5804f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 58111e1c42df69b15c938aa1b7570e4370e6ab15a86Jay Freeman (saurik) action_for_each_trigger(args[1], action_add_queue_tail); 5824f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 5834f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5844f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 5854f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_symlink(int nargs, char **args) 5864f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 5874f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return symlink(args[1], args[2]); 5884f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 5894f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 590203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrallint do_rm(int nargs, char **args) 591203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall{ 592203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall return unlink(args[1]); 593203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall} 594203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall 595203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrallint do_rmdir(int nargs, char **args) 596203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall{ 597203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall return rmdir(args[1]); 598203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall} 599203bad597fb4e46ddda051add28400070b5c3a5aKen Sumrall 60035237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Projectint do_sysclktz(int nargs, char **args) 60135237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project{ 60235237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project struct timezone tz; 60335237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 60435237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project if (nargs != 2) 60535237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project return -1; 60635237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 60735237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project memset(&tz, 0, sizeof(tz)); 60835237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project tz.tz_minuteswest = atoi(args[1]); 60935237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project if (settimeofday(NULL, &tz)) 61035237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project return -1; 61135237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project return 0; 61235237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project} 61335237d135807af84bf9b0e5b8d7f8633e58db6f5The Android Open Source Project 6144f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_write(int nargs, char **args) 6154f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project{ 6161f0bd32f90161940d531040677099f32eef21fc4Mike Lockwood const char *path = args[1]; 6171f0bd32f90161940d531040677099f32eef21fc4Mike Lockwood const char *value = args[2]; 61884bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin char prop_val[PROP_VALUE_MAX]; 61984bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin int ret; 6202c4d5dc41505d28cff369cfbe8b17ac81106d936Mike Lockwood 62184bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin ret = expand_props(prop_val, value, sizeof(prop_val)); 62284bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin if (ret) { 62384bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin ERROR("cannot expand '%s' while writing to '%s'\n", value, path); 62484bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin return -EINVAL; 62584bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin } 62684bf9af758c84da7d9ff2929bce06bf2b2f239b8Dima Zavin return write_file(path, prop_val); 6274f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 6284f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 6297c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehatint do_copy(int nargs, char **args) 6307c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat{ 6317c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat char *buffer = NULL; 6327c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat int rc = 0; 6337c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat int fd1 = -1, fd2 = -1; 6347c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat struct stat info; 6357c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat int brtw, brtr; 6367c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat char *p; 6377c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6387c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (nargs != 3) 6397c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat return -1; 6407c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6417c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (stat(args[1], &info) < 0) 6427c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat return -1; 6437c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6447c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if ((fd1 = open(args[1], O_RDONLY)) < 0) 6457c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat goto out_err; 6467c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6474833d9f4986d6dafacff841beb3bf93172c84bdcTom Zhu if ((fd2 = open(args[2], O_WRONLY|O_CREAT|O_TRUNC, 0660)) < 0) 6487c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat goto out_err; 6497c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6507c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (!(buffer = malloc(info.st_size))) 6517c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat goto out_err; 6527c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6537c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat p = buffer; 6547c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat brtr = info.st_size; 6557c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat while(brtr) { 6567c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat rc = read(fd1, p, brtr); 6577c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (rc < 0) 6587c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat goto out_err; 6597c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (rc == 0) 6607c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat break; 6617c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat p += rc; 6627c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat brtr -= rc; 6637c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat } 6647c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6657c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat p = buffer; 6667c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat brtw = info.st_size; 6677c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat while(brtw) { 6687c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat rc = write(fd2, p, brtw); 6697c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (rc < 0) 6707c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat goto out_err; 6717c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (rc == 0) 6727c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat break; 6737c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat p += rc; 6747c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat brtw -= rc; 6757c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat } 6767c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6777c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat rc = 0; 6787c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat goto out; 6797c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehatout_err: 6807c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat rc = -1; 6817c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehatout: 6827c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (buffer) 6837c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat free(buffer); 6847c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (fd1 >= 0) 6857c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat close(fd1); 6867c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat if (fd2 >= 0) 6877c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat close(fd2); 6887c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat return rc; 6897c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat} 6907c44fe5925b6dd51166f73d30de0a2f22d66373eSan Mehat 6914f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_chown(int nargs, char **args) { 6924f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project /* GID is optional. */ 6934f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (nargs == 3) { 69442a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (_chown(args[2], decode_uid(args[1]), -1) < 0) 6954f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -errno; 6964f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } else if (nargs == 4) { 69742a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (_chown(args[3], decode_uid(args[1]), decode_uid(args[2])) < 0) 6984f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -errno; 6994f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } else { 7004f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -1; 7014f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 7024f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 7034f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 7044f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 7054f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectstatic mode_t get_mode(const char *s) { 7064f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project mode_t mode = 0; 7074f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project while (*s) { 7084f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (*s >= '0' && *s <= '7') { 7094f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project mode = (mode<<3) | (*s-'0'); 7104f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } else { 7114f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -1; 7124f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 7134f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project s++; 7144f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 7154f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return mode; 7164f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 7174f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 7184f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_chmod(int nargs, char **args) { 7194f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project mode_t mode = get_mode(args[1]); 72042a9349dc4e98019d27d7f8d19bc6c431695d7e1Geremy Condra if (_chmod(args[2], mode) < 0) { 7214f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -errno; 7224f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 7234f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 7244f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 7254f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 726e46f9d510db9351682cf17c49115110870147335Stephen Smalleyint do_restorecon(int nargs, char **args) { 727e46f9d510db9351682cf17c49115110870147335Stephen Smalley#ifdef HAVE_SELINUX 728e46f9d510db9351682cf17c49115110870147335Stephen Smalley char *secontext = NULL; 729e46f9d510db9351682cf17c49115110870147335Stephen Smalley struct stat sb; 730e46f9d510db9351682cf17c49115110870147335Stephen Smalley int i; 731e46f9d510db9351682cf17c49115110870147335Stephen Smalley 732e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (is_selinux_enabled() <= 0 || !sehandle) 733e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 734e46f9d510db9351682cf17c49115110870147335Stephen Smalley 735e46f9d510db9351682cf17c49115110870147335Stephen Smalley for (i = 1; i < nargs; i++) { 736e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (lstat(args[i], &sb) < 0) 737e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -errno; 738e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (selabel_lookup(sehandle, &secontext, args[i], sb.st_mode) < 0) 739e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -errno; 740e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (lsetfilecon(args[i], secontext) < 0) { 741e46f9d510db9351682cf17c49115110870147335Stephen Smalley freecon(secontext); 742e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -errno; 743e46f9d510db9351682cf17c49115110870147335Stephen Smalley } 744e46f9d510db9351682cf17c49115110870147335Stephen Smalley freecon(secontext); 745e46f9d510db9351682cf17c49115110870147335Stephen Smalley } 746e46f9d510db9351682cf17c49115110870147335Stephen Smalley#endif 747e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 748e46f9d510db9351682cf17c49115110870147335Stephen Smalley} 749e46f9d510db9351682cf17c49115110870147335Stephen Smalley 750e46f9d510db9351682cf17c49115110870147335Stephen Smalleyint do_setsebool(int nargs, char **args) { 751e46f9d510db9351682cf17c49115110870147335Stephen Smalley#ifdef HAVE_SELINUX 752e46f9d510db9351682cf17c49115110870147335Stephen Smalley SELboolean *b = alloca(nargs * sizeof(SELboolean)); 753e46f9d510db9351682cf17c49115110870147335Stephen Smalley char *v; 754e46f9d510db9351682cf17c49115110870147335Stephen Smalley int i; 755e46f9d510db9351682cf17c49115110870147335Stephen Smalley 756e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (is_selinux_enabled() <= 0) 757e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 758e46f9d510db9351682cf17c49115110870147335Stephen Smalley 759e46f9d510db9351682cf17c49115110870147335Stephen Smalley for (i = 1; i < nargs; i++) { 760e46f9d510db9351682cf17c49115110870147335Stephen Smalley char *name = args[i]; 761e46f9d510db9351682cf17c49115110870147335Stephen Smalley v = strchr(name, '='); 762e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (!v) { 763e46f9d510db9351682cf17c49115110870147335Stephen Smalley ERROR("setsebool: argument %s had no =\n", name); 764e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -EINVAL; 765e46f9d510db9351682cf17c49115110870147335Stephen Smalley } 766e46f9d510db9351682cf17c49115110870147335Stephen Smalley *v++ = 0; 767e46f9d510db9351682cf17c49115110870147335Stephen Smalley b[i-1].name = name; 768e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (!strcmp(v, "1") || !strcasecmp(v, "true") || !strcasecmp(v, "on")) 769e46f9d510db9351682cf17c49115110870147335Stephen Smalley b[i-1].value = 1; 770e46f9d510db9351682cf17c49115110870147335Stephen Smalley else if (!strcmp(v, "0") || !strcasecmp(v, "false") || !strcasecmp(v, "off")) 771e46f9d510db9351682cf17c49115110870147335Stephen Smalley b[i-1].value = 0; 772e46f9d510db9351682cf17c49115110870147335Stephen Smalley else { 773e46f9d510db9351682cf17c49115110870147335Stephen Smalley ERROR("setsebool: invalid value %s\n", v); 774e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -EINVAL; 775e46f9d510db9351682cf17c49115110870147335Stephen Smalley } 776e46f9d510db9351682cf17c49115110870147335Stephen Smalley } 777e46f9d510db9351682cf17c49115110870147335Stephen Smalley 778e46f9d510db9351682cf17c49115110870147335Stephen Smalley if (security_set_boolean_list(nargs - 1, b, 0) < 0) 779e46f9d510db9351682cf17c49115110870147335Stephen Smalley return -errno; 780e46f9d510db9351682cf17c49115110870147335Stephen Smalley#endif 781e46f9d510db9351682cf17c49115110870147335Stephen Smalley return 0; 782e46f9d510db9351682cf17c49115110870147335Stephen Smalley} 783e46f9d510db9351682cf17c49115110870147335Stephen Smalley 7844f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Projectint do_loglevel(int nargs, char **args) { 7854f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project if (nargs == 2) { 7868f91282ebe1963b9d27f8779ad1342302b293bd2Dima Zavin klog_set_level(atoi(args[1])); 7874f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return 0; 7884f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project } 7894f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project return -1; 7904f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project} 7914f6e8d7a00cbeda1e70cc15be9c4af1018bdad5The Android Open Source Project 792c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrallint do_load_persist_props(int nargs, char **args) { 793c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall if (nargs == 1) { 794c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall load_persist_props(); 795c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall return 0; 796c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall } 797c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall return -1; 798c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall} 799c5c51033c86353d1a448c72e0e9388906eed7114Ken Sumrall 800cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Crossint do_wait(int nargs, char **args) 801cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross{ 802cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross if (nargs == 2) { 803cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross return wait_for_file(args[1], COMMAND_RETRY_TIMEOUT); 804cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross } 805cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross return -1; 806cd0f173e2790ee068fd2a20bcfc6c20468e97e51Colin Cross} 807