mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-16 23:25:03 +00:00
Bug 1068725: More debugging and assertions for MoveGroups; r=sunfish
* * * Bug 1068725: Make the MoveGroup type spew debug only; r=bustage
This commit is contained in:
parent
dfd05f13b0
commit
01552c03d9
@ -348,6 +348,8 @@ static const char * const TypeChars[] =
|
|||||||
"s", // SLOTS
|
"s", // SLOTS
|
||||||
"f", // FLOAT32
|
"f", // FLOAT32
|
||||||
"d", // DOUBLE
|
"d", // DOUBLE
|
||||||
|
"i32x4", // INT32X4
|
||||||
|
"f32x4", // FLOAT32X4
|
||||||
#ifdef JS_NUNBOX32
|
#ifdef JS_NUNBOX32
|
||||||
"t", // TYPE
|
"t", // TYPE
|
||||||
"p" // PAYLOAD
|
"p" // PAYLOAD
|
||||||
@ -541,9 +543,25 @@ bool
|
|||||||
LMoveGroup::add(LAllocation *from, LAllocation *to, LDefinition::Type type)
|
LMoveGroup::add(LAllocation *from, LAllocation *to, LDefinition::Type type)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
JS_ASSERT(*from != *to);
|
MOZ_ASSERT(*from != *to);
|
||||||
for (size_t i = 0; i < moves_.length(); i++)
|
for (size_t i = 0; i < moves_.length(); i++)
|
||||||
JS_ASSERT(*to != *moves_[i].to());
|
MOZ_ASSERT(*to != *moves_[i].to());
|
||||||
|
|
||||||
|
// Check that SIMD moves are aligned according to ABI requirements.
|
||||||
|
if (LDefinition(type).isSimdType()) {
|
||||||
|
if (from->isMemory()) {
|
||||||
|
if (from->isArgument())
|
||||||
|
MOZ_ASSERT(from->toArgument()->index() % SimdStackAlignment == 0);
|
||||||
|
else
|
||||||
|
MOZ_ASSERT(from->toStackSlot()->slot() % SimdStackAlignment == 0);
|
||||||
|
}
|
||||||
|
if (to->isMemory()) {
|
||||||
|
if (to->isArgument())
|
||||||
|
MOZ_ASSERT(to->toArgument()->index() % SimdStackAlignment == 0);
|
||||||
|
else
|
||||||
|
MOZ_ASSERT(to->toStackSlot()->slot() % SimdStackAlignment == 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
return moves_.append(LMove(from, to, type));
|
return moves_.append(LMove(from, to, type));
|
||||||
}
|
}
|
||||||
@ -582,7 +600,11 @@ LMoveGroup::printOperands(FILE *fp)
|
|||||||
const LMove &move = getMove(i);
|
const LMove &move = getMove(i);
|
||||||
// Use two printfs, as LAllocation::toString is not reentrant.
|
// Use two printfs, as LAllocation::toString is not reentrant.
|
||||||
fprintf(fp, " [%s", move.from()->toString());
|
fprintf(fp, " [%s", move.from()->toString());
|
||||||
fprintf(fp, " -> %s]", move.to()->toString());
|
fprintf(fp, " -> %s", move.to()->toString());
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf(fp, ", %s", TypeChars[move.type()]);
|
||||||
|
#endif
|
||||||
|
fprintf(fp, "]");
|
||||||
if (i != numMoves() - 1)
|
if (i != numMoves() - 1)
|
||||||
fprintf(fp, ",");
|
fprintf(fp, ",");
|
||||||
}
|
}
|
||||||
|
@ -416,6 +416,7 @@ class LDefinition
|
|||||||
MUST_REUSE_INPUT
|
MUST_REUSE_INPUT
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// This should be kept in sync with LIR.cpp's TypeChars.
|
||||||
enum Type {
|
enum Type {
|
||||||
GENERAL, // Generic, integer or pointer-width data (GPR).
|
GENERAL, // Generic, integer or pointer-width data (GPR).
|
||||||
INT32, // int32 data (GPR).
|
INT32, // int32 data (GPR).
|
||||||
|
@ -407,7 +407,7 @@ AllocationIntegrityState::dump()
|
|||||||
if (ins->isMoveGroup()) {
|
if (ins->isMoveGroup()) {
|
||||||
LMoveGroup *group = ins->toMoveGroup();
|
LMoveGroup *group = ins->toMoveGroup();
|
||||||
for (int i = group->numMoves() - 1; i >= 0; i--) {
|
for (int i = group->numMoves() - 1; i >= 0; i--) {
|
||||||
// Use two printfs, as LAllocation::toString is not reentant.
|
// Use two printfs, as LAllocation::toString is not reentrant.
|
||||||
fprintf(stderr, " [%s", group->getMove(i).from()->toString());
|
fprintf(stderr, " [%s", group->getMove(i).from()->toString());
|
||||||
fprintf(stderr, " -> %s]", group->getMove(i).to()->toString());
|
fprintf(stderr, " -> %s]", group->getMove(i).to()->toString());
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user