diff options
author | Bill Wendling <isanbard@gmail.com> | 2012-10-25 00:32:44 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2012-10-25 00:32:44 +0000 |
commit | d75987dde9538365fc97a0ce5a58c17ec4e7596d (patch) | |
tree | ac0a71b58a8160ec1142b3123d1e44a93fbad614 /clang/lib/Sema/SemaStmtAsm.cpp | |
parent | 164df7debd74c698e6b26c0e7a1f014ad35b4690 (diff) | |
download | bcm5719-llvm-d75987dde9538365fc97a0ce5a58c17ec4e7596d.tar.gz bcm5719-llvm-d75987dde9538365fc97a0ce5a58c17ec4e7596d.zip |
Revert r166647 to rethink the patch...
llvm-svn: 166655
Diffstat (limited to 'clang/lib/Sema/SemaStmtAsm.cpp')
-rw-r--r-- | clang/lib/Sema/SemaStmtAsm.cpp | 48 |
1 files changed, 0 insertions, 48 deletions
diff --git a/clang/lib/Sema/SemaStmtAsm.cpp b/clang/lib/Sema/SemaStmtAsm.cpp index 138d6714701..3a5f40c74fa 100644 --- a/clang/lib/Sema/SemaStmtAsm.cpp +++ b/clang/lib/Sema/SemaStmtAsm.cpp @@ -208,54 +208,6 @@ StmtResult Sema::ActOnGCCAsmStmt(SourceLocation AsmLoc, bool IsSimple, return StmtError(); } - // Validate constraints and modifiers. - for (unsigned i = 0, e = Pieces.size(); i != e; ++i) { - GCCAsmStmt::AsmStringPiece &Piece = Pieces[i]; - if (!Piece.isOperand()) continue; - - // Look for the correct constraint index. - unsigned Idx = 0; - unsigned ConstraintIdx = 0; - for (unsigned i = 0, e = NS->getNumOutputs(); i != e; ++i, ++ConstraintIdx) { - TargetInfo::ConstraintInfo &Info = OutputConstraintInfos[i]; - if (Idx == Piece.getOperandNo()) - break; - ++Idx; - - if (Info.isReadWrite()) { - if (Idx == Piece.getOperandNo()) - break; - ++Idx; - } - } - - for (unsigned i = 0, e = NS->getNumInputs(); i != e; ++i, ++ConstraintIdx) { - TargetInfo::ConstraintInfo &Info = InputConstraintInfos[i]; - if (Idx == Piece.getOperandNo()) - break; - ++Idx; - - if (Info.isReadWrite()) { - if (Idx == Piece.getOperandNo()) - break; - ++Idx; - } - } - - // Now that we have the right indexes go ahead and check. - StringLiteral *Literal = Constraints[ConstraintIdx]; - const Type *Ty = Exprs[ConstraintIdx]->getType().getTypePtr(); - if (Ty->isDependentType() || Ty->isIncompleteType()) - continue; - - unsigned Size = Context.getTypeSize(Ty); - if (!Context.getTargetInfo() - .validateConstraintModifier(Literal->getString(), - Piece.getModifier(), Size)) - Diag(Exprs[ConstraintIdx]->getLocStart(), - diag::warn_mismatched_size_modifier); - } - // Validate tied input operands for type mismatches. for (unsigned i = 0, e = InputConstraintInfos.size(); i != e; ++i) { TargetInfo::ConstraintInfo &Info = InputConstraintInfos[i]; |