poolarch.c

Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2007, Novell Inc.
00003  *
00004  * This program is licensed under the BSD license, read LICENSE.BSD
00005  * for further information
00006  */
00007 
00008 /*
00009  * poolarch.c
00010  *
00011  * create architecture policies
00012  */
00013 
00014 #include <stdio.h>
00015 #include <stdlib.h>
00016 #include <string.h>
00017 
00018 #include "pool.h"
00019 #include "poolid.h"
00020 #include "poolarch.h"
00021 #include "util.h"
00022 
00023 static const char *archpolicies[] = {
00024   "x86_64",     "x86_64:i686:i586:i486:i386",
00025   "i686",       "i686:i586:i486:i386",
00026   "i586",       "i586:i486:i386",
00027   "i486",       "i486:i386",
00028   "i386",       "i386",
00029   "s390x",      "s390x:s390",
00030   "s390",       "s390",
00031   "ia64",       "ia64:i686:i586:i486:i386",
00032   "ppc64",      "ppc64:ppc",
00033   "ppc",        "ppc",
00034   "armv7nhl",   "armv7nhl:armv7hl",
00035   "armv7hl",    "armv7hl",
00036   "armv7l",     "armv7l:armv6l:armv5tejl:armv5tel:armv5l:armv4tl:armv4l:armv3l",
00037   "armv6l",     "armv6l:armv5tejl:armv5tel:armv5l:armv4tl:armv4l:armv3l",
00038   "armv5tejl",  "armv5tejl:armv5tel:armv5l:armv4tl:armv4l:armv3l",
00039   "armv5tel",   "armv5tel:armv5l:armv4tl:armv4l:armv3l",
00040   "armv5l",     "armv5l:armv4tl:armv4l:armv3l",
00041   "armv4tl",    "armv4tl:armv4l:armv3l",
00042   "armv4l",     "armv4l:armv3l",
00043   "armv3l",     "armv3l",
00044   "sh3",        "sh3",
00045   "sh4",        "sh4",
00046   "sh4a",       "sh4a:sh4",
00047   "sparc64v",   "sparc64v:sparc64:sparcv9v:sparcv9:sparcv8:sparc",
00048   "sparc64",    "sparc64:sparcv9:sparcv8:sparc",
00049   "sparcv9v",   "sparcv9v:sparcv9:sparcv8:sparc",
00050   "sparcv9",    "sparcv9:sparcv8:sparc",
00051   "sparcv8",    "sparcv8:sparc",
00052   "sparc",      "sparc",
00053   0
00054 };
00055 
00056 void
00057 pool_setarch(Pool *pool, const char *arch)
00058 {
00059   if (arch)
00060     {
00061       int i;
00062 
00063       /* convert arch to known policy */
00064       for (i = 0; archpolicies[i]; i += 2)
00065         if (!strcmp(archpolicies[i], arch))
00066           break;
00067       if (archpolicies[i])
00068         arch = archpolicies[i + 1];
00069       else
00070         arch = "";
00071     }
00072   pool_setarchpolicy(pool, arch);
00073 }
00074 
00075 /*
00076  * we support three relations:
00077  *
00078  * a = b   both architectures a and b are treated as equivalent
00079  * a > b   a is considered a "better" architecture, the solver
00080  *         should change from a to b, but must not change from b to a
00081  * a : b   a is considered a "better" architecture, the solver
00082  *         must not change the architecture from a to b or b to a
00083  */
00084 void
00085 pool_setarchpolicy(Pool *pool, const char *arch)
00086 {
00087   unsigned int score = 0x10001;
00088   size_t l;
00089   char d;
00090   Id *id2arch;
00091   Id id, lastarch;
00092 
00093   pool->id2arch = sat_free(pool->id2arch);
00094   pool->id2color = sat_free(pool->id2color);
00095   if (!arch)
00096     {
00097       pool->lastarch = 0;
00098       return;
00099     }
00100 #ifndef DEBIAN_SEMANTICS
00101   id = ARCH_NOARCH;
00102 #else
00103   id = ARCH_ALL;
00104 #endif
00105   lastarch = id + 255;
00106   id2arch = sat_calloc(lastarch + 1, sizeof(Id));
00107   id2arch[id] = 1;      /* the "noarch" class */
00108 
00109   d = 0;
00110   while (*arch)
00111     {
00112       l = strcspn(arch, ":=>");
00113       if (l)
00114         {
00115           id = strn2id(pool, arch, l, 1);
00116           if (id > lastarch)
00117             {
00118               id2arch = sat_realloc2(id2arch, (id + 255 + 1), sizeof(Id));
00119               memset(id2arch + lastarch + 1, 0, (id + 255 - lastarch) * sizeof(Id));
00120               lastarch = id + 255;
00121             }
00122           if (id2arch[id] == 0)
00123             {
00124               if (d == ':')
00125                 score += 0x10000;
00126               else if (d == '>')
00127                 score += 0x00001;
00128               id2arch[id] = score;
00129             }
00130         }
00131       arch += l;
00132       if ((d = *arch++) == 0)
00133         break;
00134     }
00135   pool->id2arch = id2arch;
00136   pool->lastarch = lastarch;
00137 }
00138 
00139 unsigned char
00140 pool_arch2color_slow(Pool *pool, Id arch)
00141 {
00142   const char *s;
00143   unsigned char color;
00144 
00145   if (arch > pool->lastarch)
00146     return ARCHCOLOR_ALL;
00147   if (!pool->id2color)
00148     pool->id2color = sat_calloc(pool->lastarch + 1, 1);
00149   s = id2str(pool, arch);
00150   if (arch == ARCH_NOARCH || arch == ARCH_ALL)
00151     color = ARCHCOLOR_ALL;
00152   else if (!strcmp(s, "s390x") || strstr(s, "64"))
00153     color = ARCHCOLOR_64;
00154   else
00155     color = ARCHCOLOR_32;
00156   return color;
00157 }
00158 

Generated on Mon Dec 15 17:56:24 2014 for satsolver by  doxygen 1.5.6