diff options
author | Kenny Root <kroot@google.com> | 2012-10-17 10:51:25 -0700 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2012-10-17 10:51:26 -0700 |
commit | 63a183c41f26e4eb475dfbcc4386b37372eb5fba (patch) | |
tree | 70ffa59ac813843a8664d1349979aa6c6edec8bc /cmds | |
parent | 0307bb5de2db991f2427f12702c106aaedf662b9 (diff) | |
parent | 367400491a22cefd4e366e2278caf63d574820b0 (diff) | |
download | frameworks_base-63a183c41f26e4eb475dfbcc4386b37372eb5fba.zip frameworks_base-63a183c41f26e4eb475dfbcc4386b37372eb5fba.tar.gz frameworks_base-63a183c41f26e4eb475dfbcc4386b37372eb5fba.tar.bz2 |
Merge "resolved conflicts for merge of 40f2f751 to jb-mr1-dev-plus-aosp" into jb-mr1-dev-plus-aosp
Diffstat (limited to 'cmds')
-rw-r--r-- | cmds/installd/commands.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/cmds/installd/commands.c b/cmds/installd/commands.c index 2c30ec7..4da772a 100644 --- a/cmds/installd/commands.c +++ b/cmds/installd/commands.c @@ -71,13 +71,20 @@ int install(const char *pkgname, uid_t uid, gid_t gid) return -1; } - if (selinux_android_setfilecon(libsymlink, pkgname, uid) < 0) { + if (selinux_android_setfilecon(libsymlink, pkgname, AID_SYSTEM) < 0) { ALOGE("cannot setfilecon dir '%s': %s\n", libsymlink, strerror(errno)); unlink(libsymlink); unlink(pkgdir); return -1; } + if (selinux_android_setfilecon(pkgdir, pkgname, uid) < 0) { + ALOGE("cannot setfilecon dir '%s': %s\n", pkgdir, strerror(errno)); + unlink(libsymlink); + unlink(pkgdir); + return -errno; + } + if (chown(pkgdir, uid, gid) < 0) { ALOGE("cannot chown dir '%s': %s\n", pkgdir, strerror(errno)); unlink(libsymlink); |