diff --git a/tools/llvmc/src/Hooks.cpp b/tools/llvmc/src/Hooks.cpp index bcf4a530dcd..5aa250e512b 100644 --- a/tools/llvmc/src/Hooks.cpp +++ b/tools/llvmc/src/Hooks.cpp @@ -10,19 +10,19 @@ namespace hooks { // See http://graphics.stanford.edu/~seander/bithacks.html#RoundUpPowerOf2 inline unsigned NextHighestPowerOf2 (unsigned i) { + --i; i |= i >> 1; i |= i >> 2; i |= i >> 4; i |= i >> 8; i |= i >> 16; - i++; + ++i; return i; } typedef std::vector StrVec; typedef llvm::StringMap ArgMap; - /// AddPlusOrMinus - Convert 'no-foo' to '-foo' and 'foo' to '+foo'. void AddPlusOrMinus (const std::string& Arg, std::string& out) { if (Arg.find("no-") == 0 && Arg[3] != 0) { @@ -78,27 +78,10 @@ std::string ConvertMArchToMAttr(const StrVec& Opts) { std::string mcpu("-mcpu="); bool mattrTouched = false; bool mcpuTouched = false; - bool firstIter = true; for (StrVec::const_iterator B = Opts.begin(), E = Opts.end(); B!=E; ++B) { const std::string& Arg = *B; - if (firstIter) - firstIter = false; - else - mattr += ","; - - // Check if the argument is a special case. - { - ArgMap::const_iterator I = MArchMap.find(Arg); - - if (I != MArchMap.end()) { - mattr += '+'; - mattr += I->getValue(); - continue; - } - } - // Check if the argument should be forwarded to -mcpu instead of -mattr. { ArgMap::const_iterator I = MArchMCpuMap.find(Arg); @@ -110,6 +93,21 @@ std::string ConvertMArchToMAttr(const StrVec& Opts) { } } + if (mattrTouched) + mattr += ","; + + // Check if the argument is a special case. + { + ArgMap::const_iterator I = MArchMap.find(Arg); + + if (I != MArchMap.end()) { + mattrTouched = true; + mattr += '+'; + mattr += I->getValue(); + continue; + } + } + AddPlusOrMinus(Arg, mattr); }