[llvm-commits] CVS: llvm/include/llvm/InlineAsm.h
Chris Lattner
lattner at cs.uiuc.edu
Tue Jan 31 17:27:49 PST 2006
Changes in directory llvm/include/llvm:
InlineAsm.h updated: 1.6 -> 1.7
---
Log message:
Beef up the interface to inline asm constraint parsing, making it more
general, useful, and easier to use.
---
Diffs of the changes: (+27 -3)
InlineAsm.h | 30 +++++++++++++++++++++++++++---
1 files changed, 27 insertions(+), 3 deletions(-)
Index: llvm/include/llvm/InlineAsm.h
diff -u llvm/include/llvm/InlineAsm.h:1.6 llvm/include/llvm/InlineAsm.h:1.7
--- llvm/include/llvm/InlineAsm.h:1.6 Wed Jan 25 20:21:42 2006
+++ llvm/include/llvm/InlineAsm.h Tue Jan 31 19:27:37 2006
@@ -70,17 +70,41 @@
enum ConstraintPrefix {
isInput, // 'x'
isOutput, // '=x'
- isIndirectOutput, // '==x'
isClobber, // '~x'
};
+ struct ConstraintInfo {
+ /// Type - The basic type of the constraint: input/output/clobber
+ ///
+ ConstraintPrefix Type;
+
+ /// isEarlyClobber - "&": output operand writes result before inputs are all
+ /// read. This is only ever set for an output operand.
+ bool isEarlyClobber;
+
+ /// isIndirectOutput - If this is true for an output constraint, the address
+ /// to store the output result is passed as an operand to the call.
+ bool isIndirectOutput;
+
+ /// Code - The constraint code, either the register name (in braces) or the
+ /// constraint letter/number.
+ std::vector<std::string> Codes;
+
+ /// Parse - Analyze the specified string (e.g. "==&{eax}") and fill in the
+ /// fields in this structure. If the constraint string is not understood,
+ /// return true, otherwise return false.
+ bool Parse(const std::string &Str);
+ };
+
/// ParseConstraints - Split up the constraint string into the specific
/// constraints and their prefixes. If this returns an empty vector, and if
/// the constraint string itself isn't empty, there was an error parsing.
- static std::vector<std::pair<ConstraintPrefix, std::string> >
+ static std::vector<ConstraintInfo>
ParseConstraints(const std::string &ConstraintString);
- std::vector<std::pair<ConstraintPrefix, std::string> >
+ /// ParseConstraints - Parse the constraints of this inlineasm object,
+ /// returning them the same way that ParseConstraints(str) does.
+ std::vector<ConstraintInfo>
ParseConstraints() const {
return ParseConstraints(Constraints);
}
More information about the llvm-commits
mailing list