am 5fec7915: Merge "service_manager: reorder permission checks for find"

* commit '5fec79156d749322dcc0376da1d6cf4d9ee9ccf4':
  service_manager: reorder permission checks for find
This commit is contained in:
Nick Kralevich 2015-03-05 21:48:25 +00:00 committed by Android Git Automerger
commit fcf1689c1a

View File

@ -169,16 +169,12 @@ uint16_t svcmgr_id[] = {
uint32_t do_find_service(struct binder_state *bs, const uint16_t *s, size_t len, uid_t uid, pid_t spid) uint32_t do_find_service(struct binder_state *bs, const uint16_t *s, size_t len, uid_t uid, pid_t spid)
{ {
struct svcinfo *si; struct svcinfo *si = find_svc(s, len);
if (!svc_can_find(s, len, spid)) { if (!si || !si->handle) {
ALOGE("find_service('%s') uid=%d - PERMISSION DENIED\n",
str8(s, len), uid);
return 0; return 0;
} }
si = find_svc(s, len);
//ALOGI("check_service('%s') handle = %x\n", str8(s, len), si ? si->handle : 0);
if (si && si->handle) {
if (!si->allow_isolated) { if (!si->allow_isolated) {
// If this service doesn't allow access from isolated processes, // If this service doesn't allow access from isolated processes,
// then check the uid to see if it is isolated. // then check the uid to see if it is isolated.
@ -187,10 +183,12 @@ uint32_t do_find_service(struct binder_state *bs, const uint16_t *s, size_t len,
return 0; return 0;
} }
} }
return si->handle;
} else { if (!svc_can_find(s, len, spid)) {
return 0; return 0;
} }
return si->handle;
} }
int do_add_service(struct binder_state *bs, int do_add_service(struct binder_state *bs,