]> git.saurik.com Git - apple/system_cmds.git/blobdiff - taskpolicy.tproj/taskpolicy.c
system_cmds-790.30.1.tar.gz
[apple/system_cmds.git] / taskpolicy.tproj / taskpolicy.c
index 0688200af299505e8ed4d646d074eb357057fd5a..3260bb62cf51eb2c794d84ac1401964e883eb9bd 100644 (file)
@@ -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 <policy>] [-g policy] [-c clamp] [-b] [-t <tier>]\n"
-                    "                  [-l <tier>] <program> [<pargs> [...]]\n", getprogname());
+                    "                  [-l <tier>] [-a] <program> [<pargs> [...]]\n", getprogname());
        fprintf(stderr, "       %s [-b|-B] [-t <tier>] [-l <tier>] -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")) {