summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/VMCore/InlineAsm.cpp9
1 files changed, 3 insertions, 6 deletions
diff --git a/llvm/lib/VMCore/InlineAsm.cpp b/llvm/lib/VMCore/InlineAsm.cpp
index c4e065df057..bd3667db761 100644
--- a/llvm/lib/VMCore/InlineAsm.cpp
+++ b/llvm/lib/VMCore/InlineAsm.cpp
@@ -183,12 +183,9 @@ bool InlineAsm::ConstraintInfo::Parse(StringRef Str,
++I;
} else if (*I == '^') {
// Multi-letter constraint
- // These will only occur with the existing multiple alternative
- // constraints and so we can use the isalpha loop below.
- StringRef::iterator ConStart = ++I;
- while (I != E && isalpha(*I))
- ++I;
- pCodes->push_back(std::string(ConStart, I));
+ // FIXME: For now assuming these are 2-character constraints.
+ pCodes->push_back(std::string(I+1, I+3));
+ I += 3;
} else {
// Single letter constraint.
pCodes->push_back(std::string(I, I+1));
OpenPOWER on IntegriCloud