const Expr *InputExpr = S.getOutputExpr(i);
llvm::Value *Arg = EmitAsmInput(S, Info, InputExpr, InOutConstraints);
- InOutConstraints += llvm::utostr(Args.size());
+ if (Info & TargetInfo::CI_AllowsRegister)
+ InOutConstraints += llvm::utostr(i);
+ else
+ InOutConstraints += OutputConstraint;
InOutArgTypes.push_back(Arg->getType());
InOutArgs.push_back(Arg);
-// RUN: clang %s -arch=i386 -verify -fsyntax-only
-void f(int len)
+// RUN: clang -emit-llvm %s -o %t -arch=i386
+void t1(int len)
{
- __asm__ volatile("" :"=&r"(len), "+&r"(len));
+ __asm__ volatile("" : "=&r"(len), "+&r"(len));
}
+
+void t2(unsigned long long t)
+{
+ __asm__ volatile("" : "+m"(t));
+}
+
+void t3(unsigned char *src, unsigned long long temp)
+{
+ __asm__ volatile("" : "+m"(temp), "+r"(src));
+}
+
+
+
+
+
+