mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-03 23:01:31 +00:00
Bug 949171 - SpiderMonkey: Tighten up various assertions. r=nbp
This commit is contained in:
parent
bf65a5665c
commit
9f4e4d2fef
@ -835,6 +835,7 @@ BacktrackingAllocator::spill(LiveInterval *interval)
|
||||
IonSpew(IonSpew_RegAlloc, "Spilling interval");
|
||||
|
||||
JS_ASSERT(interval->requirement()->kind() == Requirement::NONE);
|
||||
JS_ASSERT(!interval->getAllocation()->isStackSlot());
|
||||
|
||||
// We can't spill bogus intervals.
|
||||
JS_ASSERT(interval->hasVreg());
|
||||
|
@ -58,7 +58,7 @@ class BitSet : private TempObject
|
||||
// O(1): Check if this set contains the given value.
|
||||
bool contains(unsigned int value) const {
|
||||
JS_ASSERT(bits_);
|
||||
JS_ASSERT(value <= max_);
|
||||
JS_ASSERT(value < max_);
|
||||
|
||||
return !!(bits_[wordForValue(value)] & bitForValue(value));
|
||||
}
|
||||
@ -69,7 +69,7 @@ class BitSet : private TempObject
|
||||
// O(1): Insert the given value into this set.
|
||||
void insert(unsigned int value) {
|
||||
JS_ASSERT(bits_);
|
||||
JS_ASSERT(value <= max_);
|
||||
JS_ASSERT(value < max_);
|
||||
|
||||
bits_[wordForValue(value)] |= bitForValue(value);
|
||||
}
|
||||
@ -80,7 +80,7 @@ class BitSet : private TempObject
|
||||
// O(1): Remove the given value from this set.
|
||||
void remove(unsigned int value) {
|
||||
JS_ASSERT(bits_);
|
||||
JS_ASSERT(value <= max_);
|
||||
JS_ASSERT(value < max_);
|
||||
|
||||
bits_[wordForValue(value)] &= ~bitForValue(value);
|
||||
}
|
||||
@ -137,7 +137,7 @@ class BitSet::Iterator
|
||||
|
||||
inline Iterator& operator++(int dummy) {
|
||||
JS_ASSERT(more());
|
||||
JS_ASSERT(index_ <= set_.max_);
|
||||
JS_ASSERT(index_ < set_.max_);
|
||||
|
||||
index_++;
|
||||
value_ >>= 1;
|
||||
@ -158,12 +158,12 @@ class BitSet::Iterator
|
||||
index_ += numZeros;
|
||||
value_ >>= numZeros;
|
||||
|
||||
JS_ASSERT_IF(index_ <= set_.max_, set_.contains(index_));
|
||||
JS_ASSERT_IF(index_ < set_.max_, set_.contains(index_));
|
||||
return *this;
|
||||
}
|
||||
|
||||
unsigned int operator *() {
|
||||
JS_ASSERT(index_ <= set_.max_);
|
||||
JS_ASSERT(index_ < set_.max_);
|
||||
return index_;
|
||||
}
|
||||
};
|
||||
|
@ -1139,6 +1139,7 @@ CodeGenerator::visitStackArgT(LStackArgT *lir)
|
||||
const LAllocation *arg = lir->getArgument();
|
||||
MIRType argType = lir->mir()->getArgument()->type();
|
||||
uint32_t argslot = lir->argslot();
|
||||
JS_ASSERT(argslot - 1u < graph.argumentSlotCount());
|
||||
|
||||
int32_t stack_offset = StackOffsetOfPassedArg(argslot);
|
||||
Address dest(StackPointer, stack_offset);
|
||||
@ -1150,7 +1151,9 @@ CodeGenerator::visitStackArgT(LStackArgT *lir)
|
||||
else
|
||||
masm.storeValue(*(arg->toConstant()), dest);
|
||||
|
||||
return pushedArgumentSlots_.append(StackOffsetToSlot(stack_offset));
|
||||
uint32_t slot = StackOffsetToSlot(stack_offset);
|
||||
JS_ASSERT(slot - 1u < graph.totalSlotCount());
|
||||
return pushedArgumentSlots_.append(slot);
|
||||
}
|
||||
|
||||
bool
|
||||
@ -1158,10 +1161,15 @@ CodeGenerator::visitStackArgV(LStackArgV *lir)
|
||||
{
|
||||
ValueOperand val = ToValue(lir, 0);
|
||||
uint32_t argslot = lir->argslot();
|
||||
JS_ASSERT(argslot - 1u < graph.argumentSlotCount());
|
||||
|
||||
int32_t stack_offset = StackOffsetOfPassedArg(argslot);
|
||||
|
||||
masm.storeValue(val, Address(StackPointer, stack_offset));
|
||||
return pushedArgumentSlots_.append(StackOffsetToSlot(stack_offset));
|
||||
|
||||
uint32_t slot = StackOffsetToSlot(stack_offset);
|
||||
JS_ASSERT(slot - 1u < graph.totalSlotCount());
|
||||
return pushedArgumentSlots_.append(slot);
|
||||
}
|
||||
|
||||
bool
|
||||
|
@ -73,8 +73,9 @@ LBlock::lastId()
|
||||
{
|
||||
LInstruction *last = *instructions_.rbegin();
|
||||
JS_ASSERT(last->id());
|
||||
if (last->numDefs())
|
||||
return last->getDef(last->numDefs() - 1)->virtualRegister();
|
||||
// The last instruction is a control flow instruction which does not have
|
||||
// any output.
|
||||
JS_ASSERT(last->numDefs() == 0);
|
||||
return last->id();
|
||||
}
|
||||
|
||||
|
@ -305,6 +305,7 @@ LIRGenerator::visitPassArg(MPassArg *arg)
|
||||
{
|
||||
MDefinition *opd = arg->getArgument();
|
||||
uint32_t argslot = getArgumentSlot(arg->getArgnum());
|
||||
JS_ASSERT(arg->getArgnum() < prepareCallStack_.back()->argc());
|
||||
|
||||
// Pass through the virtual register of the operand.
|
||||
// This causes snapshots to correctly copy the operand on the stack.
|
||||
|
@ -2829,6 +2829,7 @@ class MPassArg
|
||||
// Set by the MCall.
|
||||
void setArgnum(uint32_t argnum) {
|
||||
argnum_ = argnum;
|
||||
JS_ASSERT(argnum_ >= 0);
|
||||
}
|
||||
uint32_t getArgnum() const {
|
||||
JS_ASSERT(argnum_ >= 0);
|
||||
|
@ -763,6 +763,7 @@ MBasicBlock::discardAllResumePoints(bool discardEntry)
|
||||
void
|
||||
MBasicBlock::insertBefore(MInstruction *at, MInstruction *ins)
|
||||
{
|
||||
JS_ASSERT(at->block() == this);
|
||||
ins->setBlock(this);
|
||||
graph().allocDefinitionId(ins);
|
||||
instructions_.insertBefore(at, ins);
|
||||
@ -772,6 +773,7 @@ MBasicBlock::insertBefore(MInstruction *at, MInstruction *ins)
|
||||
void
|
||||
MBasicBlock::insertAfter(MInstruction *at, MInstruction *ins)
|
||||
{
|
||||
JS_ASSERT(at->block() == this);
|
||||
ins->setBlock(this);
|
||||
graph().allocDefinitionId(ins);
|
||||
instructions_.insertAfter(at, ins);
|
||||
|
@ -994,7 +994,7 @@ MPhi::computeRange(TempAllocator &alloc)
|
||||
return;
|
||||
|
||||
Range *range = nullptr;
|
||||
JS_ASSERT(getOperand(0)->op() != MDefinition::Op_OsrValue);
|
||||
JS_ASSERT(!isOSRLikeValue(getOperand(0)));
|
||||
for (size_t i = 0, e = numOperands(); i < e; i++) {
|
||||
if (getOperand(i)->block()->unreachable()) {
|
||||
IonSpew(IonSpew_Range, "Ignoring unreachable input %d", getOperand(i)->id());
|
||||
|
Loading…
Reference in New Issue
Block a user