[cfe-commits] r165070 - /cfe/trunk/lib/Sema/SemaStmtAsm.cpp
Chad Rosier
mcrosier at apple.com
Tue Oct 2 16:38:55 PDT 2012
Author: mcrosier
Date: Tue Oct 2 18:38:55 2012
New Revision: 165070
URL: http://llvm.org/viewvc/llvm-project?rev=165070&view=rev
Log:
Revert 165058, per Jim request. This requires further discussion.
Modified:
cfe/trunk/lib/Sema/SemaStmtAsm.cpp
Modified: cfe/trunk/lib/Sema/SemaStmtAsm.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaStmtAsm.cpp?rev=165070&r1=165069&r2=165070&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaStmtAsm.cpp (original)
+++ cfe/trunk/lib/Sema/SemaStmtAsm.cpp Tue Oct 2 18:38:55 2012
@@ -575,43 +575,6 @@
// If we had an error parsing the operands, fail gracefully.
if (HadError) { DEF_SIMPLE_MSASM(EmptyAsmStr); return Owned(NS); }
- // Rewrite the symbol references as wildcard MCParsedAsmOperands.
- for (unsigned i = 1, e = Operands.size(); i != e; ++i)
- if (Operands[i]->isMem()) {
- StringRef Name = getMSInlineAsmExprName(Pieces[StrIdx][i]);
-
- // The expr may be a register. E.g., DWORD PTR [eax]
- if (Context.getTargetInfo().isValidGCCRegisterName(Name))
- continue;
-
- IdentifierInfo *II = getIdentifierInfo(Name, AsmToks,
- AsmTokRanges[StrIdx].first,
- AsmTokRanges[StrIdx].second);
- // Lookup the identifier.
- // TODO: Someone with more experience with clang should verify this the
- // proper way of doing a symbol lookup.
- DeclarationName DeclName(II);
- Scope *CurScope = getCurScope();
- LookupResult R(*this, DeclName, AsmLoc, Sema::LookupOrdinaryName);
- if (!this->LookupName(R, CurScope, false/*AllowBuiltinCreation*/))
- assert(0 && "Sema::LookupName failed!");
- assert (R.isSingleResult() && "Expected a single result?!");
- NamedDecl *Decl = R.getFoundDecl();
- switch (Decl->getKind()) {
- default:
- assert(0 && "Unknown decl kind.");
- break;
- case Decl::Var: {
- case Decl::ParmVar:
- VarDecl *Var = cast<VarDecl>(Decl);
- QualType Ty = Var->getType();
- // Set the expected operand size.
- Operands[i]->setMSAsmWildcard(Context.getTypeInfo(Ty).first);
- break;
- }
- }
- }
-
// Match the MCInstr.
unsigned Kind;
unsigned Opcode;
@@ -656,7 +619,8 @@
// Expr/Input or Output.
StringRef Name = getMSInlineAsmExprName(Pieces[StrIdx][i]);
- // The expr may be a register. E.g., DWORD PTR [eax]
+ // The expr may be a register.
+ // E.g., DWORD PTR [eax]
if (Context.getTargetInfo().isValidGCCRegisterName(Name))
continue;
More information about the cfe-commits
mailing list