Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 03dfa27d authored by Treehugger Robot's avatar Treehugger Robot Committed by Gerrit Code Review
Browse files

Merge "Treat process group creation failure due to a dead process as non-fatal"

parents c8b5936f 26cc4077
Loading
Loading
Loading
Loading
+9 −4
Original line number Diff line number Diff line
@@ -1799,12 +1799,17 @@ static void SpecializeCommon(JNIEnv* env, uid_t uid, gid_t gid, jintArray gids,
    if (!is_system_server && getuid() == 0) {
        const int rc = createProcessGroup(uid, getpid());
        if (rc != 0) {
            if (rc == -ESRCH) {
                // If process is dead, treat this as a non-fatal error
                ALOGE("createProcessGroup(%d, %d) failed: %s", uid, /* pid= */ 0, strerror(-rc));
            } else {
                fail_fn(rc == -EROFS ? CREATE_ERROR("createProcessGroup failed, kernel missing "
                                                    "CONFIG_CGROUP_CPUACCT?")
                                     : CREATE_ERROR("createProcessGroup(%d, %d) failed: %s", uid,
                                                    /* pid= */ 0, strerror(-rc)));
            }
        }
    }

    SetGids(env, gids, is_child_zygote, fail_fn);
    SetRLimits(env, rlimits, fail_fn);