X-Git-Url: https://git.saurik.com/apple/system_cmds.git/blobdiff_plain/1a7e3f61d38d679bba59130891c2031b5a0092b6..c00fdd175635bfca33c58d1b2951a1565ce91f17:/taskpolicy.tproj/taskpolicy.c?ds=sidebyside diff --git a/taskpolicy.tproj/taskpolicy.c b/taskpolicy.tproj/taskpolicy.c index 0688200..3260bb6 100644 --- a/taskpolicy.tproj/taskpolicy.c +++ b/taskpolicy.tproj/taskpolicy.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013 Apple Inc. All rights reserved. + * Copyright (c) 2013-2016 Apple Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * @@ -54,12 +54,12 @@ int main(int argc, char * argv[]) pid_t pid = 0; posix_spawnattr_t attr; extern char **environ; - bool flagx = false, flagX = false, flagb = false, flagB = false; + bool flagx = false, flagX = false, flagb = false, flagB = false, flaga = false; int flagd = -1, flagg = -1; struct task_qos_policy qosinfo = { LATENCY_QOS_TIER_UNSPECIFIED, THROUGHPUT_QOS_TIER_UNSPECIFIED }; uint64_t qos_clamp = POSIX_SPAWN_PROC_CLAMP_NONE; - - while ((ch = getopt(argc, argv, "xXbBd:g:c:t:l:p:")) != -1) { + + while ((ch = getopt(argc, argv, "xXbBd:g:c:t:l:p:a")) != -1) { switch (ch) { case 'x': flagx = true; @@ -115,6 +115,9 @@ int main(int argc, char * argv[]) usage(); } break; + case 'a': + flaga = true; + break; case '?': default: usage(); @@ -131,7 +134,7 @@ int main(int argc, char * argv[]) warnx("Incompatible option(s) used with -p"); usage(); } - + if (flagx && flagX){ warnx("Incompatible options -x, -X"); usage(); @@ -206,32 +209,39 @@ int main(int argc, char * argv[]) err(EX_SOFTWARE, "task_policy_set(...TASK_OVERRIDE_QOS_POLICY...)"); } } - + if (pid != 0) return 0; - - + ret = posix_spawnattr_init(&attr); if (ret != 0) errc(EX_NOINPUT, ret, "posix_spawnattr_init"); - + ret = posix_spawnattr_setflags(&attr, POSIX_SPAWN_SETEXEC); if (ret != 0) errc(EX_NOINPUT, ret, "posix_spawnattr_setflags"); - + if (qos_clamp != POSIX_SPAWN_PROC_CLAMP_NONE) { ret = posix_spawnattr_set_qos_clamp_np(&attr, qos_clamp); if (ret != 0) errc(EX_NOINPUT, ret, "posix_spawnattr_set_qos_clamp_np"); } - + + if (flaga) { + ret = posix_spawnattr_setprocesstype_np(&attr, POSIX_SPAWN_PROC_TYPE_APP_DEFAULT); + if (ret != 0) errc(EX_NOINPUT, ret, "posix_spawnattr_setprocesstype_np"); + + ret = posix_spawnattr_set_darwin_role_np(&attr, PRIO_DARWIN_ROLE_UI); + if (ret != 0) errc(EX_NOINPUT, ret, "posix_spawnattr_set_darwin_role_np"); + } + ret = posix_spawnp(&pid, argv[0], NULL, &attr, argv, environ); if (ret != 0) errc(EX_NOINPUT, ret, "posix_spawn"); - + return EX_OSERR; } static void usage(void) { fprintf(stderr, "Usage: %s [-x|-X] [-d ] [-g policy] [-c clamp] [-b] [-t ]\n" - " [-l ] [ [...]]\n", getprogname()); + " [-l ] [-a] [ [...]]\n", getprogname()); fprintf(stderr, " %s [-b|-B] [-t ] [-l ] -p pid\n", getprogname()); exit(EX_USAGE); } @@ -240,14 +250,14 @@ static int parse_disk_policy(const char *strpolicy) { long policy; char *endptr = NULL; - + /* first try as an integer */ policy = strtol(strpolicy, &endptr, 0); if (endptr && (endptr[0] == '\0') && (strpolicy[0] != '\0')) { /* parsed complete string as a number */ return (int)policy; } - + if (0 == strcasecmp(strpolicy, "DEFAULT") ) { return IOPOL_DEFAULT; } else if (0 == strcasecmp(strpolicy, "IMPORTANT")) { @@ -268,7 +278,7 @@ static int parse_disk_policy(const char *strpolicy) static int parse_qos_tier(const char *strtier, int parameter){ long policy; char *endptr = NULL; - + /* first try as an integer */ policy = strtol(strtier, &endptr, 0); if (endptr && (endptr[0] == '\0') && (strtier[0] != '\0')) { @@ -301,7 +311,7 @@ static int parse_qos_tier(const char *strtier, int parameter){ } static uint64_t parse_qos_clamp(const char *qos_string) { - + if (0 == strcasecmp(qos_string, "utility") ) { return POSIX_SPAWN_PROC_CLAMP_UTILITY; } else if (0 == strcasecmp(qos_string, "background")) {