Chromium Code Reviews

Side by Side Diff: src/IceTargetLoweringX8632.cpp

Issue 476323004: Start adding an integrated assembler. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: simplify Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff |
OLDNEW
1 //===- subzero/src/IceTargetLoweringX8632.cpp - x86-32 lowering -----------===// 1 //===- subzero/src/IceTargetLoweringX8632.cpp - x86-32 lowering -----------===//
2 // 2 //
3 // The Subzero Code Generator 3 // The Subzero Code Generator
4 // 4 //
5 // This file is distributed under the University of Illinois Open Source 5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details. 6 // License. See LICENSE.TXT for details.
7 // 7 //
8 //===----------------------------------------------------------------------===// 8 //===----------------------------------------------------------------------===//
9 // 9 //
10 // This file implements the TargetLoweringX8632 class, which 10 // This file implements the TargetLoweringX8632 class, which
(...skipping 495 matching lines...)
506 if (!hasFramePointer()) 506 if (!hasFramePointer())
507 Offset += getStackAdjustment(); 507 Offset += getStackAdjustment();
508 if (Offset) { 508 if (Offset) {
509 if (Offset > 0) 509 if (Offset > 0)
510 Str << "+"; 510 Str << "+";
511 Str << Offset; 511 Str << Offset;
512 } 512 }
513 Str << "]"; 513 Str << "]";
514 } 514 }
515 515
516 x86::Address TargetX8632::stackVarToAsmOperand(const Variable *Var) const {
517 assert(!Var->hasReg());
518 int32_t Offset = Var->getStackOffset();
519 if (!hasFramePointer())
520 Offset += getStackAdjustment();
521 return x86::Address(x86::Register(getFrameOrStackReg()), Offset);
522 }
523
516 void TargetX8632::lowerArguments() { 524 void TargetX8632::lowerArguments() {
517 VarList &Args = Func->getArgs(); 525 VarList &Args = Func->getArgs();
518 // The first four arguments of vector type, regardless of their 526 // The first four arguments of vector type, regardless of their
519 // position relative to the other arguments in the argument list, are 527 // position relative to the other arguments in the argument list, are
520 // passed in registers xmm0 - xmm3. 528 // passed in registers xmm0 - xmm3.
521 unsigned NumXmmArgs = 0; 529 unsigned NumXmmArgs = 0;
522 530
523 Context.init(Func->getEntryNode()); 531 Context.init(Func->getEntryNode());
524 Context.setInsertPoint(Context.getCur()); 532 Context.setInsertPoint(Context.getCur());
525 533
(...skipping 3892 matching lines...)
4418 Str << "\t.align\t" << Align << "\n"; 4426 Str << "\t.align\t" << Align << "\n";
4419 Str << MangledName << ":\n"; 4427 Str << MangledName << ":\n";
4420 for (SizeT i = 0; i < Size; ++i) { 4428 for (SizeT i = 0; i < Size; ++i) {
4421 Str << "\t.byte\t" << (((unsigned)Data[i]) & 0xff) << "\n"; 4429 Str << "\t.byte\t" << (((unsigned)Data[i]) & 0xff) << "\n";
4422 } 4430 }
4423 Str << "\t.size\t" << MangledName << ", " << Size << "\n"; 4431 Str << "\t.size\t" << MangledName << ", " << Size << "\n";
4424 } 4432 }
4425 } 4433 }
4426 4434
4427 } // end of namespace Ice 4435 } // end of namespace Ice
OLDNEW
« no previous file with comments | « src/IceTargetLoweringX8632.h ('k') | src/IceUtils.h » ('j') | src/IceUtils.h » ('J')

Powered by Google App Engine