aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-10-13 04:32:07 +0000
committerChris Lattner <sabre@nondot.org>2009-10-13 04:32:07 +0000
commit4053983963cb94a6129da47bca8cce637c8b7bff (patch)
tree1e4f9aeaef28488d0eef1dd9a4fdf2d60a439654
parentc9f4af634b3aadbabdd1d4b9b81d67e30bb8ce96 (diff)
fix PR4938 by recognizing % as a modifier on outputs,
previously we only recognized it on inputs. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@83939 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Basic/TargetInfo.cpp3
-rw-r--r--test/CodeGen/asm.c9
2 files changed, 12 insertions, 0 deletions
diff --git a/lib/Basic/TargetInfo.cpp b/lib/Basic/TargetInfo.cpp
index 35d9ccd401..9cd12493e7 100644
--- a/lib/Basic/TargetInfo.cpp
+++ b/lib/Basic/TargetInfo.cpp
@@ -188,6 +188,9 @@ bool TargetInfo::validateOutputConstraint(ConstraintInfo &Info) const {
}
case '&': // early clobber.
break;
+ case '%': // commutative.
+ // FIXME: Check that there is a another register after this one.
+ break;
case 'r': // general register.
Info.setAllowsRegister();
break;
diff --git a/test/CodeGen/asm.c b/test/CodeGen/asm.c
index 46563213b1..52afc91527 100644
--- a/test/CodeGen/asm.c
+++ b/test/CodeGen/asm.c
@@ -101,3 +101,12 @@ void t14(struct S *P) {
}
+// PR4938
+int t16() {
+ int a,b;
+ asm ( "nop;"
+ :"=%c" (a)
+ : "r" (b)
+ );
+ return 0;
+}