diff options
| -rw-r--r-- | clang/lib/Sema/SemaStmtAsm.cpp | 3 | ||||
| -rw-r--r-- | clang/test/CodeGen/ms-inline-asm.c | 3 | 
2 files changed, 3 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaStmtAsm.cpp b/clang/lib/Sema/SemaStmtAsm.cpp index 2af2afe398b..b6a4e62f952 100644 --- a/clang/lib/Sema/SemaStmtAsm.cpp +++ b/clang/lib/Sema/SemaStmtAsm.cpp @@ -624,7 +624,8 @@ StmtResult Sema::ActOnMSAsmStmt(SourceLocation AsmLoc,              ExprResult Result = ActOnIdExpression(getCurScope(), SS, Loc, Id,                                                    false, false);              if (!Result.isInvalid()) { -              if (isDef) { +              bool isMemDef = (i == 1) && Desc.mayStore(); +              if (isDef || isMemDef) {                  Outputs.push_back(II);                  OutputExprs.push_back(Result.take());                  OutputConstraints.push_back("=r"); diff --git a/clang/test/CodeGen/ms-inline-asm.c b/clang/test/CodeGen/ms-inline-asm.c index 8b4af0b9f8f..9c902cd198f 100644 --- a/clang/test/CodeGen/ms-inline-asm.c +++ b/clang/test/CodeGen/ms-inline-asm.c @@ -88,8 +88,7 @@ unsigned t10(void) {  // CHECK: [[I:%[a-zA-Z0-9]+]] = alloca i32, align 4  // CHECK: [[J:%[a-zA-Z0-9]+]] = alloca i32, align 4  // CHECK: store i32 1, i32* [[I]], align 4 -// Note: The AsmParser isn't properly matching the second instruction (i.e., j is being marked as an input, when in fact it is an output). -// CHECK: call void asm sideeffect "mov eax, i\0Amov j, eax", "r,r,~{eax},~{dirflag},~{fpsr},~{flags}"(i32 %{{.*}}, i32 %{{.*}}) nounwind ia_nsdialect +// CHECK: call i32 asm sideeffect "mov eax, i\0Amov j, eax", "=r,r,~{eax},~{dirflag},~{fpsr},~{flags}"(i32 %{{.*}}) nounwind ia_nsdialect  // CHECK: [[RET:%[a-zA-Z0-9]+]] = load i32* [[J]], align 4  // CHECK: ret i32 [[RET]]  }  | 

