diff --git a/include/avian/system/system.h b/include/avian/system/system.h index a65efae5f6..8eb0e498de 100644 --- a/include/avian/system/system.h +++ b/include/avian/system/system.h @@ -168,18 +168,18 @@ sysAbort(System* s) // #ifdef NDEBUG -// # define assert(a, b) +// # define assertT(a, b) // # define vm_assert(a, b) // #else // not NDEBUG // inline void -// assert(System* s, bool v) +// assertT(System* s, bool v) // { // expect(s, v); // } -// # define vm_assert(a, b) vm::assert(a, b) +// # define vm_assert(a, b) vm::assertT(a, b) // #endif // not NDEBUG diff --git a/include/avian/util/abort.h b/include/avian/util/abort.h index 2619492141..261c3374aa 100644 --- a/include/avian/util/abort.h +++ b/include/avian/util/abort.h @@ -42,10 +42,10 @@ inline void expect(T t, bool v) { } #ifdef NDEBUG -#define assert(t, v) +#define assertT(t, v) #else template -inline void assert(T t, bool v) { +inline void assertT(T t, bool v) { expect(t, v); } #endif diff --git a/src/avian/alloc-vector.h b/src/avian/alloc-vector.h index c7aa0d1ddd..fce6f724b0 100644 --- a/src/avian/alloc-vector.h +++ b/src/avian/alloc-vector.h @@ -50,7 +50,7 @@ class Vector { void ensure(size_t space) { if (position + space > data.count) { - assert(a, minimumCapacity > 0); + assertT(a, minimumCapacity > 0); size_t newCapacity = avian::util::max( position + space, avian::util::max(minimumCapacity, data.count * 2)); @@ -64,13 +64,13 @@ class Vector { void get(size_t offset, void* dst, size_t size) { - assert(a, offset + size <= position); + assertT(a, offset + size <= position); memcpy(dst, data.begin() + offset, size); } void set(size_t offset, const void* src, size_t size) { - assert(a, offset + size <= position); + assertT(a, offset + size <= position); memcpy(data.begin() + offset, src, size); } @@ -121,7 +121,7 @@ class Vector { void set2(size_t offset, uint16_t v) { - assert(a, offset <= position - 2); + assertT(a, offset <= position - 2); memcpy(data.begin() + offset, &v, 2); } @@ -157,7 +157,7 @@ class Vector { template T* peek(size_t offset) { - assert(a, offset + sizeof(T) <= position); + assertT(a, offset + sizeof(T) <= position); return reinterpret_cast(data.begin() + offset); } diff --git a/src/avian/machine.h b/src/avian/machine.h index 686bf38d34..7fc31e7be9 100644 --- a/src/avian/machine.h +++ b/src/avian/machine.h @@ -1872,7 +1872,7 @@ allocate3(Thread* t, Allocator* allocator, Machine::AllocationType type, inline object allocateSmall(Thread* t, unsigned sizeInBytes) { - assert(t, t->heapIndex + ceilingDivide(sizeInBytes, BytesPerWord) + assertT(t, t->heapIndex + ceilingDivide(sizeInBytes, BytesPerWord) <= ThreadHeapSizeInWords); object o = reinterpret_cast(t->heap + t->heapIndex); @@ -1891,7 +1891,7 @@ allocate(Thread* t, unsigned sizeInBytes, bool objectMask) { return allocate2(t, sizeInBytes, objectMask); } else { - assert(t, t->criticalLevel == 0); + assertT(t, t->criticalLevel == 0); return allocateSmall(t, sizeInBytes); } } @@ -1957,7 +1957,7 @@ instanceOf(Thread* t, GcClass* class_, object o); template T* GcObject::as(Thread* t UNUSED) { - assert(t, + assertT(t, t->m->unsafe || instanceOf(t, reinterpret_cast(arrayBodyUnsafe(t, t->m->types, T::Type)), reinterpret_cast(this))); return static_cast(this); @@ -1975,7 +1975,7 @@ T* cast(Thread* t UNUSED, object o) if(o == 0) { return 0; } - assert(t, + assertT(t, t->m->unsafe || instanceOf(t, reinterpret_cast(arrayBodyUnsafe( t, t->m->types, T::Type)), @@ -2037,7 +2037,7 @@ addThread(Thread* t, Thread* p) { ACQUIRE_RAW(t, t->m->stateLock); - assert(t, p->state == Thread::NoState); + assertT(t, p->state == Thread::NoState); expect(t, t->state == Thread::ActiveState || t->state == Thread::ExclusiveState || t->state == Thread::NoState); p->state = Thread::IdleState; @@ -2057,7 +2057,7 @@ removeThread(Thread* t, Thread* p) { ACQUIRE_RAW(t, t->m->stateLock); - assert(t, p->state == Thread::IdleState); + assertT(t, p->state == Thread::IdleState); -- t->m->liveCount; -- t->m->threadCount; @@ -2205,7 +2205,7 @@ hashTaken(Thread*, object o) inline unsigned baseSize(Thread* t UNUSED, object o, GcClass* class_) { - assert(t, class_->fixedSize() >= BytesPerWord); + assertT(t, class_->fixedSize() >= BytesPerWord); return ceilingDivide(class_->fixedSize(), BytesPerWord) + ceilingDivide(class_->arrayElementSize() @@ -2228,11 +2228,11 @@ makeTrace(Thread* t) inline object makeNew(Thread* t, GcClass* class_) { - assert(t, t->state == Thread::NoState or t->state == Thread::ActiveState); + assertT(t, t->state == Thread::NoState or t->state == Thread::ActiveState); PROTECT(t, class_); unsigned sizeInBytes = pad(class_->fixedSize()); - assert(t, sizeInBytes); + assertT(t, sizeInBytes); object instance = allocate(t, sizeInBytes, class_->objectMask()); setObjectClass(t, instance, class_); @@ -2357,7 +2357,7 @@ frameMethod(Thread* t, int frame); inline uintptr_t& extendedWord(Thread* t UNUSED, object o, unsigned baseSize) { - assert(t, objectExtended(t, o)); + assertT(t, objectExtended(t, o)); return fieldAtOffset(o, baseSize * BytesPerWord); } @@ -2370,8 +2370,8 @@ extendedSize(Thread* t, object o, unsigned baseSize) inline void markHashTaken(Thread* t, object o) { - assert(t, not objectExtended(t, o)); - assert(t, not objectFixed(t, o)); + assertT(t, not objectExtended(t, o)); + assertT(t, not objectFixed(t, o)); ACQUIRE_RAW(t, t->m->heapLock); @@ -2498,7 +2498,7 @@ class MethodSpecIterator { { } const char* next() { - assert(t, *s != ')'); + assertT(t, *s != ')'); const char* p = s; @@ -2535,7 +2535,7 @@ class MethodSpecIterator { } const char* returnSpec() { - assert(t, *s == ')'); + assertT(t, *s == ')'); return s + 1; } @@ -2786,8 +2786,8 @@ dumpHeap(Thread* t, FILE* out); inline void NO_RETURN throw_(Thread* t, object e) { - assert(t, t->exception == 0); - assert(t, e); + assertT(t, t->exception == 0); + assertT(t, e); expect(t, not t->checkpoint->noThrow); @@ -2897,7 +2897,7 @@ findVirtualMethod(Thread* t, GcMethod* method, GcClass* class_) inline GcMethod* findInterfaceMethod(Thread* t, GcMethod* method, GcClass* class_) { - assert(t, (class_->vmFlags() & BootstrapFlag) == 0); + assertT(t, (class_->vmFlags() & BootstrapFlag) == 0); object interface = method->class_(); object itable = class_->interfaceTable(); @@ -2913,17 +2913,17 @@ findInterfaceMethod(Thread* t, GcMethod* method, GcClass* class_) inline unsigned objectArrayLength(Thread* t UNUSED, object array) { - assert(t, objectClass(t, array)->fixedSize() == BytesPerWord * 2); - assert(t, objectClass(t, array)->arrayElementSize() == BytesPerWord); + assertT(t, objectClass(t, array)->fixedSize() == BytesPerWord * 2); + assertT(t, objectClass(t, array)->arrayElementSize() == BytesPerWord); return fieldAtOffset(array, BytesPerWord); } inline object& objectArrayBody(Thread* t UNUSED, object array, unsigned index) { - assert(t, objectClass(t, array)->fixedSize() == BytesPerWord * 2); - assert(t, objectClass(t, array)->arrayElementSize() == BytesPerWord); - assert(t, objectClass(t, array)->objectMask() + assertT(t, objectClass(t, array)->fixedSize() == BytesPerWord * 2); + assertT(t, objectClass(t, array)->arrayElementSize() == BytesPerWord); + assertT(t, objectClass(t, array)->objectMask() == classObjectMask(t, arrayBody (t, t->m->types, GcArray::Type))); return fieldAtOffset(array, ArrayBody + (index * BytesPerWord)); @@ -2953,7 +2953,7 @@ releaseSystem(Thread* t, Thread* target) { ACQUIRE_RAW(t, t->m->stateLock); - assert(t, t->state != Thread::JoinedState); + assertT(t, t->state != Thread::JoinedState); atomicAnd(&(target->flags), ~Thread::SystemFlag); } @@ -3093,7 +3093,7 @@ monitorAcquire(Thread* t, object monitor, object node = 0) ++ monitorDepth(t, monitor); } - assert(t, monitorOwner(t, monitor) == t); + assertT(t, monitorOwner(t, monitor) == t); } inline void @@ -3121,7 +3121,7 @@ monitorRelease(Thread* t, object monitor) inline void monitorAppendWait(Thread* t, object monitor) { - assert(t, monitorOwner(t, monitor) == t); + assertT(t, monitorOwner(t, monitor) == t); expect(t, (t->flags & Thread::WaitingFlag) == 0); expect(t, t->waitNext == 0); @@ -3140,7 +3140,7 @@ monitorAppendWait(Thread* t, object monitor) inline void monitorRemoveWait(Thread* t, object monitor) { - assert(t, monitorOwner(t, monitor) == t); + assertT(t, monitorOwner(t, monitor) == t); Thread* previous = 0; for (Thread* current = static_cast(monitorWaitHead(t, monitor)); @@ -3154,7 +3154,7 @@ monitorRemoveWait(Thread* t, object monitor) } if (t == monitorWaitTail(t, monitor)) { - assert(t, t->waitNext == 0); + assertT(t, t->waitNext == 0); monitorWaitTail(t, monitor) = previous; } @@ -3173,7 +3173,7 @@ monitorRemoveWait(Thread* t, object monitor) inline bool monitorFindWait(Thread* t, object monitor) { - assert(t, monitorOwner(t, monitor) == t); + assertT(t, monitorOwner(t, monitor) == t); for (Thread* current = static_cast(monitorWaitHead(t, monitor)); current; current = current->waitNext) @@ -3225,7 +3225,7 @@ monitorWait(Thread* t, object monitor, int64_t time) expect(t, not monitorFindWait(t, monitor)); } - assert(t, monitorOwner(t, monitor) == t); + assertT(t, monitorOwner(t, monitor) == t); return interrupted; } @@ -3233,7 +3233,7 @@ monitorWait(Thread* t, object monitor, int64_t time) inline Thread* monitorPollWait(Thread* t, object monitor) { - assert(t, monitorOwner(t, monitor) == t); + assertT(t, monitorOwner(t, monitor) == t); Thread* next = static_cast(monitorWaitHead(t, monitor)); @@ -3245,7 +3245,7 @@ monitorPollWait(Thread* t, object monitor) monitorWaitTail(t, monitor) = 0; } } else { - assert(t, monitorWaitTail(t, monitor) == 0); + assertT(t, monitorWaitTail(t, monitor) == 0); } return next; @@ -3502,7 +3502,7 @@ singletonCount(Thread* t, GcSingleton* singleton) inline uint32_t* singletonMask(Thread* t, GcSingleton* singleton) { - assert(t, singleton->length()); + assertT(t, singleton->length()); return reinterpret_cast (&singletonBody(t, reinterpret_cast(singleton), singletonCount(t, singleton))); } @@ -3523,7 +3523,7 @@ singletonMarkObject(Thread* t, GcSingleton* singleton, unsigned index) inline bool singletonIsObject(Thread* t, GcSingleton* singleton, unsigned index) { - assert(t, index < singletonCount(t, singleton)); + assertT(t, index < singletonCount(t, singleton)); return (singletonMask(t, singleton)[(index + 2) / 32] & (static_cast(1) << ((index + 2) % 32))) != 0; @@ -3532,14 +3532,14 @@ singletonIsObject(Thread* t, GcSingleton* singleton, unsigned index) inline object& singletonObject(Thread* t, GcSingleton* singleton, unsigned index) { - assert(t, singletonIsObject(t, singleton, index)); + assertT(t, singletonIsObject(t, singleton, index)); return reinterpret_cast(singletonBody(t, reinterpret_cast(singleton), index)); } inline uintptr_t& singletonValue(Thread* t, GcSingleton* singleton, unsigned index) { - assert(t, not singletonIsObject(t, singleton, index)); + assertT(t, not singletonIsObject(t, singleton, index)); return singletonBody(t, reinterpret_cast(singleton), index); } @@ -3547,7 +3547,7 @@ inline GcSingleton* makeSingletonOfSize(Thread* t, unsigned count) { GcSingleton* o = makeSingleton(t, count + singletonMaskSize(count)); - assert(t, o->length() == count + singletonMaskSize(t, o)); + assertT(t, o->length() == count + singletonMaskSize(t, o)); if (count) { singletonMask(t, o)[0] = 1; } diff --git a/src/classpath-android.cpp b/src/classpath-android.cpp index f3db02c6bb..ee1f6ab4da 100644 --- a/src/classpath-android.cpp +++ b/src/classpath-android.cpp @@ -1556,7 +1556,7 @@ Avian_dalvik_system_VMStack_getClasses object c = getJClass(t, cast(t, walker->method()->class_())); - assert(t, counter - 2 < objectArrayLength(t, array)); + assertT(t, counter - 2 < objectArrayLength(t, array)); set(t, array, ArrayBody + ((counter - 2) * BytesPerWord), c); diff --git a/src/classpath-openjdk.cpp b/src/classpath-openjdk.cpp index f79885309b..ae3af3c4bd 100644 --- a/src/classpath-openjdk.cpp +++ b/src/classpath-openjdk.cpp @@ -4283,7 +4283,7 @@ jvmGetClassDeclaredMethods(Thread* t, uintptr_t* arguments) { object method = makeJmethod(t, vmMethod, i); - assert(t, ai < objectArrayLength(t, array)); + assertT(t, ai < objectArrayLength(t, array)); set(t, array, ArrayBody + ((ai++) * BytesPerWord), method); } @@ -4328,12 +4328,12 @@ jvmGetClassDeclaredFields(Thread* t, uintptr_t* arguments) if ((not publicOnly) or (fieldFlags(t, vmField) & ACC_PUBLIC)) { object field = makeJfield(t, vmField, i); - assert(t, ai < objectArrayLength(t, array)); + assertT(t, ai < objectArrayLength(t, array)); set(t, array, ArrayBody + ((ai++) * BytesPerWord), field); } } - assert(t, ai == objectArrayLength(t, array)); + assertT(t, ai == objectArrayLength(t, array)); return reinterpret_cast(makeLocalReference(t, array)); } else { @@ -4381,7 +4381,7 @@ jvmGetClassDeclaredConstructors(Thread* t, uintptr_t* arguments) { object method = makeJconstructor(t, vmMethod, i); - assert(t, ai < objectArrayLength(t, array)); + assertT(t, ai < objectArrayLength(t, array)); set(t, array, ArrayBody + ((ai++) * BytesPerWord), method); } diff --git a/src/codegen/compiler.cpp b/src/codegen/compiler.cpp index 16972c61c7..5ffca214b4 100644 --- a/src/codegen/compiler.cpp +++ b/src/codegen/compiler.cpp @@ -74,7 +74,7 @@ class ConstantPoolNode { Read* live(Context* c UNUSED, Value* v) { - assert(c, v->buddy->hasBuddy(c, v)); + assertT(c, v->buddy->hasBuddy(c, v)); Value* p = v; do { @@ -94,7 +94,7 @@ void deadWord(Context* c, Value* v) { Value* nextWord = v->nextWord; - assert(c, nextWord != v); + assertT(c, nextWord != v); for (SiteIterator it(c, v, true, false); it.hasMore();) { Site* s = it.next(); @@ -109,8 +109,8 @@ deadWord(Context* c, Value* v) void deadBuddy(Context* c, Value* v, Read* r UNUSED) { - assert(c, v->buddy != v); - assert(c, r); + assertT(c, v->buddy != v); + assertT(c, r); if (DebugBuddies) { fprintf(stderr, "remove dead buddy %p from", v); @@ -120,7 +120,7 @@ deadBuddy(Context* c, Value* v, Read* r UNUSED) fprintf(stderr, "\n"); } - assert(c, v->buddy); + assertT(c, v->buddy); Value* next = v->buddy; v->buddy = v; @@ -128,7 +128,7 @@ deadBuddy(Context* c, Value* v, Read* r UNUSED) while (p->buddy != v) p = p->buddy; p->buddy = next; - assert(c, p->buddy); + assertT(c, p->buddy); for (SiteIterator it(c, v, false, false); it.hasMore();) { Site* s = it.next(); @@ -141,7 +141,7 @@ deadBuddy(Context* c, Value* v, Read* r UNUSED) void popRead(Context* c, Event* e UNUSED, Value* v) { - assert(c, e == v->reads->event); + assertT(c, e == v->reads->event); if (DebugReads) { fprintf(stderr, "pop read %p from %p next %p event %p (%s)\n", @@ -197,13 +197,13 @@ sitesToString(Context* c, Site* sites, char* buffer, unsigned size) total += s->toString(c, buffer + total, size - total); if (s->next) { - assert(c, size > total + 2); + assertT(c, size > total + 2); memcpy(buffer + total, ", ", 2); total += 2; } } - assert(c, size > total); + assertT(c, size > total); buffer[total] = 0; return total; @@ -216,7 +216,7 @@ sitesToString(Context* c, Value* v, char* buffer, unsigned size) Value* p = v; do { if (total) { - assert(c, size > total + 2); + assertT(c, size > total + 2); memcpy(buffer + total, "; ", 2); total += 2; } @@ -586,7 +586,7 @@ acceptForResolve(Context* c, Site* s, Read* read, const SiteMask& mask) if (s->type(c) == lir::RegisterOperand) { return c->availableGeneralRegisterCount > ResolveRegisterReserveCount; } else { - assert(c, s->match(c, SiteMask(1 << lir::MemoryOperand, 0, AnyFrameIndex))); + assertT(c, s->match(c, SiteMask(1 << lir::MemoryOperand, 0, AnyFrameIndex))); return isHome(read->value, offsetToFrameIndex (c, static_cast(s)->offset)); @@ -606,7 +606,7 @@ move(Context* c, Value* value, Site* src, Site* dst) srcb, dstb, value, value); } - assert(c, value->findSite(dst)); + assertT(c, value->findSite(dst)); src->freeze(c, value); dst->freeze(c, value); @@ -662,7 +662,7 @@ void apply(Context* c, lir::UnaryOperation op, unsigned s1Size, Site* s1Low, Site* s1High) { - assert(c, s1Low->type(c) == s1High->type(c)); + assertT(c, s1Low->type(c) == s1High->type(c)); lir::OperandType s1Type = s1Low->type(c); OperandUnion s1Union; asAssemblerOperand(c, s1Low, s1High, &s1Union); @@ -676,8 +676,8 @@ apply(Context* c, lir::BinaryOperation op, unsigned s1Size, Site* s1Low, Site* s1High, unsigned s2Size, Site* s2Low, Site* s2High) { - assert(c, s1Low->type(c) == s1High->type(c)); - assert(c, s2Low->type(c) == s2High->type(c)); + assertT(c, s1Low->type(c) == s1High->type(c)); + assertT(c, s2Low->type(c) == s2High->type(c)); lir::OperandType s1Type = s1Low->type(c); OperandUnion s1Union; asAssemblerOperand(c, s1Low, s1High, &s1Union); @@ -696,9 +696,9 @@ apply(Context* c, lir::TernaryOperation op, unsigned s2Size, Site* s2Low, Site* s2High, unsigned s3Size, Site* s3Low, Site* s3High) { - assert(c, s1Low->type(c) == s1High->type(c)); - assert(c, s2Low->type(c) == s2High->type(c)); - assert(c, s3Low->type(c) == s3High->type(c)); + assertT(c, s1Low->type(c) == s1High->type(c)); + assertT(c, s2Low->type(c) == s2High->type(c)); + assertT(c, s3Low->type(c) == s3High->type(c)); lir::OperandType s1Type = s1Low->type(c); OperandUnion s1Union; asAssemblerOperand(c, s1Low, s1High, &s1Union); @@ -819,8 +819,8 @@ void maybeMove(Context* c, src.registerMask &= c->regFile->generalRegisters.mask; } - assert(c, thunk == 0); - assert(c, dstMask.typeMask & src.typeMask & (1 << lir::RegisterOperand)); + assertT(c, thunk == 0); + assertT(c, dstMask.typeMask & src.typeMask & (1 << lir::RegisterOperand)); Site* tmpTarget = freeRegisterSite (c, dstMask.registerMask & src.registerMask); @@ -927,7 +927,7 @@ pickSiteOrMove(Context* c, Value* src, Value* dst, Site* nextWord, s = maybeMove(c, read, false, true); } } - assert(c, s); + assertT(c, s); addBuddy(src, dst); @@ -965,7 +965,7 @@ removeBuddy(Context* c, Value* v) fprintf(stderr, "\n"); } - assert(c, v->buddy); + assertT(c, v->buddy); Value* next = v->buddy; v->buddy = v; @@ -973,7 +973,7 @@ removeBuddy(Context* c, Value* v) while (p->buddy != v) p = p->buddy; p->buddy = next; - assert(c, p->buddy); + assertT(c, p->buddy); if (not live(c, next)) { next->clearSites(c); @@ -1063,7 +1063,7 @@ pushWord(Context* c, Value* v) void push(Context* c, unsigned footprint, Value* v) { - assert(c, footprint); + assertT(c, footprint); bool bigEndian = c->arch->bigEndian(); @@ -1075,7 +1075,7 @@ push(Context* c, unsigned footprint, Value* v) Value* high; if (footprint > 1) { - assert(c, footprint == 2); + assertT(c, footprint == 2); if (TargetBytesPerWord == 4) { low->maybeSplit(c); @@ -1102,7 +1102,7 @@ void popWord(Context* c) { Stack* s = c->stack; - assert(c, s->value == 0 or s->value->home >= 0); + assertT(c, s->value == 0 or s->value->home >= 0); if (DebugFrame) { fprintf(stderr, "pop %p\n", s->value); @@ -1114,7 +1114,7 @@ popWord(Context* c) Value* pop(Context* c, unsigned footprint) { - assert(c, footprint); + assertT(c, footprint); Stack* s = 0; @@ -1125,7 +1125,7 @@ pop(Context* c, unsigned footprint) } if (footprint > 1) { - assert(c, footprint == 2); + assertT(c, footprint == 2); #ifndef NDEBUG Stack* low; @@ -1138,7 +1138,7 @@ pop(Context* c, unsigned footprint) high = low->next; } - assert(c, (TargetBytesPerWord == 8 + assertT(c, (TargetBytesPerWord == 8 and low->value->nextWord == low->value and high->value == 0) or (TargetBytesPerWord == 4 and low->value->nextWord == high->value)); #endif // not NDEBUG @@ -1158,7 +1158,7 @@ pop(Context* c, unsigned footprint) Value* storeLocal(Context* c, unsigned footprint, Value* v, unsigned index, bool copy) { - assert(c, index + footprint <= c->localFootprint); + assertT(c, index + footprint <= c->localFootprint); if (copy) { unsigned sizeInBytes = sizeof(Local) * c->localFootprint; @@ -1169,7 +1169,7 @@ storeLocal(Context* c, unsigned footprint, Value* v, unsigned index, bool copy) Value* high; if (footprint > 1) { - assert(c, footprint == 2); + assertT(c, footprint == 2); unsigned highIndex; unsigned lowIndex; @@ -1182,7 +1182,7 @@ storeLocal(Context* c, unsigned footprint, Value* v, unsigned index, bool copy) } if (TargetBytesPerWord == 4) { - assert(c, v->nextWord != v); + assertT(c, v->nextWord != v); high = storeLocal(c, 1, v->nextWord, highIndex, false); } else { @@ -1235,18 +1235,18 @@ unsigned typeFootprint(Context* c, ir::Type type) Value* loadLocal(Context* c, ir::Type type, unsigned index) { unsigned footprint = typeFootprint(c, type); - assert(c, index + footprint <= c->localFootprint); + assertT(c, index + footprint <= c->localFootprint); if (footprint > 1) { - assert(c, footprint == 2); + assertT(c, footprint == 2); if (not c->arch->bigEndian()) { ++ index; } } - assert(c, c->locals[index].value); - assert(c, c->locals[index].value->home >= 0); + assertT(c, c->locals[index].value); + assertT(c, c->locals[index].value->home >= 0); if (DebugFrame) { fprintf(stderr, "load local %p at %d\n", c->locals[index].value, index); @@ -1295,7 +1295,7 @@ visit(Context* c, Link* link) StubReadPair* p = junctionState->reads + i; if (p->value and p->value->reads) { - assert(c, p->value->reads == p->read); + assertT(c, p->value->reads == p->read); popRead(c, 0, p->value); } } @@ -1319,10 +1319,10 @@ class BuddyEvent: public Event { fprintf(stderr, "original %p buddy %p\n", original, buddy); } - assert(c, original->hasSite(c)); + assertT(c, original->hasSite(c)); - assert(c, original); - assert(c, buddy); + assertT(c, original); + assertT(c, buddy); addBuddy(original, buddy); @@ -1466,7 +1466,7 @@ class SiteRecordList { void freeze(Context* c, SiteRecordList* frozen, Site* s, Value* v) { - assert(c, frozen->index < frozen->capacity); + assertT(c, frozen->index < frozen->capacity); s->freeze(c, v); init(new (frozen->records + (frozen->index ++)) SiteRecord, s, v); @@ -1667,7 +1667,7 @@ populateSiteTables(Context* c, Event* e, SiteRecordList* frozen) void setSites(Context* c, Value* v, Site* s) { - assert(c, live(c, v)); + assertT(c, live(c, v)); for (; s; s = s->next) { v->addSite(c, s->copy(c)); @@ -1738,7 +1738,7 @@ restore(Context* c, Event* e, Snapshot* snapshots) } for (Snapshot* s = snapshots; s; s = s->next) { - assert(c, s->buddy); + assertT(c, s->buddy); s->value->buddy = s->buddy; } @@ -2109,9 +2109,9 @@ class Client: public Assembler::Client { virtual void save(int r) { RegisterResource* reg = c->registerResources + r; - assert(c, reg->referenceCount == 0); - assert(c, reg->freezeCount == 0); - assert(c, not reg->reserved); + assertT(c, reg->referenceCount == 0); + assertT(c, reg->freezeCount == 0); + assertT(c, not reg->reserved); if (reg->value) { steal(c, reg, 0); @@ -2177,7 +2177,7 @@ class MyCompiler: public Compiler { } virtual void visitLogicalIp(unsigned logicalIp) { - assert(&c, logicalIp < c.logicalCode.count()); + assertT(&c, logicalIp < c.logicalCode.count()); if (c.logicalCode[c.logicalIp]->lastEvent == 0) { appendDummy(&c); @@ -2213,8 +2213,8 @@ class MyCompiler: public Compiler { } virtual void startLogicalIp(unsigned logicalIp) { - assert(&c, logicalIp < c.logicalCode.count()); - assert(&c, c.logicalCode[logicalIp] == 0); + assertT(&c, logicalIp < c.logicalCode.count()); + assertT(&c, c.logicalCode[logicalIp] == 0); if (c.logicalCode[c.logicalIp]->lastEvent == 0) { appendDummy(&c); @@ -2298,22 +2298,22 @@ class MyCompiler: public Compiler { virtual void push(ir::Type type, ir::Value* value) { - // TODO: once type information is flowed properly, enable this assert. + // TODO: once type information is flowed properly, enable this assertT. // Some time later, we can remove the parameter. - // assert(&c, value->type == type); + // assertT(&c, value->type == type); compiler::push(&c, typeFootprint(&c, type), static_cast(value)); } virtual void save(ir::Type type, ir::Value* value) { - // TODO: once type information is flowed properly, enable this assert. + // TODO: once type information is flowed properly, enable this assertT. // Some time later, we can remove the parameter. - // assert(&c, value->type == type); + // assertT(&c, value->type == type); unsigned footprint = typeFootprint(&c, type); c.saved = cons(&c, static_cast(value), c.saved); if (TargetBytesPerWord == 4 and footprint > 1) { - assert(&c, footprint == 2); - assert(&c, static_cast(value)->nextWord); + assertT(&c, footprint == 2); + assertT(&c, static_cast(value)->nextWord); save(ir::Type::i4(), static_cast(value)->nextWord); } @@ -2322,9 +2322,9 @@ class MyCompiler: public Compiler { virtual ir::Value* pop(ir::Type type) { ir::Value* value = compiler::pop(&c, typeFootprint(&c, type)); - // TODO: once type information is flowed properly, enable this assert. + // TODO: once type information is flowed properly, enable this assertT. // Some time later, we can remove the parameter. - // assert(&c, static_cast(value)->type == type); + // assertT(&c, static_cast(value)->type == type); return value; } @@ -2342,7 +2342,7 @@ class MyCompiler: public Compiler { virtual void popped(unsigned footprint) { for (; footprint; -- footprint) { - assert(&c, c.stack->value == 0 or c.stack->value->home >= 0); + assertT(&c, c.stack->value == 0 or c.stack->value->home >= 0); if (DebugFrame) { fprintf(stderr, "popped %p\n", c.stack->value); @@ -2364,7 +2364,7 @@ class MyCompiler: public Compiler { } if (footprint > 1) { - assert(&c, footprint == 2); + assertT(&c, footprint == 2); bool bigEndian = c.arch->bigEndian(); @@ -2379,7 +2379,7 @@ class MyCompiler: public Compiler { high = s->next; } - assert(&c, (TargetBytesPerWord == 8 + assertT(&c, (TargetBytesPerWord == 8 and low->value->nextWord == low->value and high->value == 0) or (TargetBytesPerWord == 4 and low->value->nextWord == high->value)); @@ -2455,13 +2455,13 @@ class MyCompiler: public Compiler { traceHandler, result, arguments); - assert(&c, c.stack == b); + assertT(&c, c.stack == b); return result; } virtual void return_(ir::Value* a) { - assert(&c, a); + assertT(&c, a); appendReturn(&c, static_cast(a)); } @@ -2493,12 +2493,12 @@ class MyCompiler: public Compiler { { unsigned footprint = typeFootprint(&c, type); - assert(&c, index + footprint <= c.localFootprint); + assertT(&c, index + footprint <= c.localFootprint); Value* v = value(&c, type); if (footprint > 1) { - assert(&c, footprint == 2); + assertT(&c, footprint == 2); unsigned highIndex; unsigned lowIndex; @@ -2534,7 +2534,7 @@ class MyCompiler: public Compiler { } virtual void initLocalsFromLogicalIp(unsigned logicalIp) { - assert(&c, logicalIp < c.logicalCode.count()); + assertT(&c, logicalIp < c.logicalCode.count()); unsigned footprint = sizeof(Local) * c.localFootprint; Local* newLocals = static_cast(c.zone->allocate(footprint)); @@ -2565,7 +2565,7 @@ class MyCompiler: public Compiler { virtual void saveLocals() { int oldIp UNUSED = c.logicalIp; appendSaveLocals(&c); - assert(&c, oldIp == c.logicalIp); + assertT(&c, oldIp == c.logicalIp); } virtual void checkBounds(ir::Value* object, @@ -2579,9 +2579,9 @@ class MyCompiler: public Compiler { virtual ir::Value* truncate(ir::Type type, ir::Value* src) { - assert(&c, src->type.flavor() == type.flavor()); - assert(&c, type.flavor() != ir::Type::Float); - assert(&c, type.rawSize() < src->type.rawSize()); + assertT(&c, src->type.flavor() == type.flavor()); + assertT(&c, type.flavor() != ir::Type::Float); + assertT(&c, type.rawSize() < src->type.rawSize()); Value* dst = value(&c, type); appendMove(&c, lir::Move, @@ -2613,7 +2613,7 @@ class MyCompiler: public Compiler { virtual void store(ir::Value* src, ir::Value* dst) { - assert(&c, src->type.flavor() == dst->type.flavor()); + assertT(&c, src->type.flavor() == dst->type.flavor()); appendMove(&c, lir::Move, @@ -2628,7 +2628,7 @@ class MyCompiler: public Compiler { ir::Value* src, ir::Type dstType) { - assert(&c, src->type.flavor() == dstType.flavor()); + assertT(&c, src->type.flavor() == dstType.flavor()); Value* dst = value(&c, dstType); appendMove(&c, @@ -2648,12 +2648,12 @@ class MyCompiler: public Compiler { ir::Value* b, ir::Value* addr) { - assert(&c, + assertT(&c, (isGeneralBranch(op) and isGeneralValue(a) and isGeneralValue(b))or( isFloatBranch(op) and isFloatValue(a) and isFloatValue(b))); - assert(&c, a->type == b->type); - assert(&c, addr->type == ir::Type::iptr()); + assertT(&c, a->type == b->type); + assertT(&c, addr->type == ir::Type::iptr()); appendBranch(&c, op, @@ -2677,7 +2677,7 @@ class MyCompiler: public Compiler { ir::Value* a, ir::Value* b) { - assert(&c, + assertT(&c, (isGeneralBinaryOp(op) and isGeneralValue(a) and isGeneralValue(b)) or(isFloatBinaryOp(op) and isFloatValue(a) and isFloatValue(b))); @@ -2694,7 +2694,7 @@ class MyCompiler: public Compiler { virtual ir::Value* unaryOp(lir::BinaryOperation op, ir::Value* a) { - assert(&c, + assertT(&c, (isGeneralUnaryOp(op) and isGeneralValue(a))or(isFloatUnaryOp(op) and isFloatValue(a))); Value* result = value(&c, a->type); @@ -2705,8 +2705,8 @@ class MyCompiler: public Compiler { virtual ir::Value* f2f(ir::Type resType, ir::Value* a) { - assert(&c, isFloatValue(a)); - assert(&c, resType.flavor() == ir::Type::Float); + assertT(&c, isFloatValue(a)); + assertT(&c, resType.flavor() == ir::Type::Float); Value* result = value(&c, resType); appendTranslate(&c, lir::Float2Float, @@ -2717,8 +2717,8 @@ class MyCompiler: public Compiler { virtual ir::Value* f2i(ir::Type resType, ir::Value* a) { - assert(&c, isFloatValue(a)); - assert(&c, resType.flavor() != ir::Type::Float); + assertT(&c, isFloatValue(a)); + assertT(&c, resType.flavor() != ir::Type::Float); Value* result = value(&c, resType); appendTranslate(&c, lir::Float2Int, @@ -2729,8 +2729,8 @@ class MyCompiler: public Compiler { virtual ir::Value* i2f(ir::Type resType, ir::Value* a) { - assert(&c, isGeneralValue(a)); - assert(&c, resType.flavor() == ir::Type::Float); + assertT(&c, isGeneralValue(a)); + assertT(&c, resType.flavor() == ir::Type::Float); Value* result = value(&c, resType); appendTranslate(&c, lir::Int2Float, diff --git a/src/codegen/compiler/context.h b/src/codegen/compiler/context.h index 03708f39c1..22cb043ee7 100644 --- a/src/codegen/compiler/context.h +++ b/src/codegen/compiler/context.h @@ -73,7 +73,7 @@ class LogicalCode { = logicalCode.cloneAndSet(zone, logicalCode.count + more, 0); for (size_t i = 0; i < logicalCode.count; i++) { - assert((vm::System*)0, logicalCode[i] == newCode[i]); + assertT((vm::System*)0, logicalCode[i] == newCode[i]); } logicalCode = newCode; diff --git a/src/codegen/compiler/event.cpp b/src/codegen/compiler/event.cpp index a1dc94d95a..cfb5c711d8 100644 --- a/src/codegen/compiler/event.cpp +++ b/src/codegen/compiler/event.cpp @@ -235,7 +235,7 @@ Value* slicePushWord(Context* c, size_t index UNUSED = slice.count; - assert(c, slice.count < slice.capacity); + assertT(c, slice.count < slice.capacity); slice.push(v); // if (DebugFrame) { @@ -255,7 +255,7 @@ void slicePush(Context* c, size_t stackBase, SliceStack& slice) { - assert(c, footprint); + assertT(c, footprint); bool bigEndian = c->arch->bigEndian(); @@ -267,7 +267,7 @@ void slicePush(Context* c, Value* high; if (footprint > 1) { - assert(c, footprint == 2); + assertT(c, footprint == 2); if (c->targetInfo.pointerSize == 4) { low->maybeSplit(c); @@ -315,8 +315,8 @@ class CallEvent: public Event { uint32_t registerMask = c->regFile->generalRegisters.mask; if (callingConvention == ir::NativeCallingConvention) { - assert(c, (flags & Compiler::TailJump) == 0); - assert(c, stackArgumentFootprint == 0); + assertT(c, (flags & Compiler::TailJump) == 0); + assertT(c, stackArgumentFootprint == 0); unsigned index = 0; unsigned argumentIndex = 0; @@ -381,7 +381,7 @@ class CallEvent: public Event { op, &thunk); - assert(c, not thunk); + assertT(c, not thunk); this->addRead(c, address, SiteMask (op.typeMask, registerMask & op.registerMask, AnyFrameIndex)); @@ -399,7 +399,7 @@ class CallEvent: public Event { if ((c->targetInfo.pointerSize == 8 && (v == 0 || (i >= 1 && arguments[i - 1] == 0))) || (c->targetInfo.pointerSize == 4 && v->nextWord != v)) { - assert(c, + assertT(c, c->targetInfo.pointerSize == 8 or v->nextWord == arguments[i - 1]); @@ -414,7 +414,7 @@ class CallEvent: public Event { int frameOffset; if (TailCalls and (flags & Compiler::TailJump)) { - assert(c, arguments.count == 0); + assertT(c, arguments.count == 0); int base = frameBase(c); returnAddressIndex = base + c->arch->returnAddressOffset(); @@ -467,7 +467,7 @@ class CallEvent: public Event { - c->arch->frameFooterSize() - stackArgumentIndex; - assert(c, static_cast(popIndex) >= 0); + assertT(c, static_cast(popIndex) >= 0); while (stack) { if (stack->value) { @@ -512,9 +512,9 @@ class CallEvent: public Event { op = lir::Jump; } - assert(c, returnAddressSurrogate == 0 + assertT(c, returnAddressSurrogate == 0 or returnAddressSurrogate->source->type(c) == lir::RegisterOperand); - assert(c, framePointerSurrogate == 0 + assertT(c, framePointerSurrogate == 0 or framePointerSurrogate->source->type(c) == lir::RegisterOperand); int ras; @@ -677,7 +677,7 @@ class MoveEvent: public Event { dstSize(dstSize), dstValue(dstValue) { - assert(c, srcSelectSize <= srcSize); + assertT(c, srcSelectSize <= srcSize); bool noop = srcSelectSize >= dstSize; @@ -783,11 +783,11 @@ class MoveEvent: public Event { dstValue, dstLowMask); } else { - assert(c, srcSize == c->targetInfo.pointerSize); - assert(c, srcSelectSize == c->targetInfo.pointerSize); + assertT(c, srcSize == c->targetInfo.pointerSize); + assertT(c, srcSelectSize == c->targetInfo.pointerSize); if (dstValue->nextWord->target or live(c, dstValue->nextWord)) { - assert(c, dstLowMask.typeMask & (1 << lir::RegisterOperand)); + assertT(c, dstLowMask.typeMask & (1 << lir::RegisterOperand)); Site* low = freeRegisterSite(c, dstLowMask.registerMask); @@ -817,7 +817,7 @@ class MoveEvent: public Event { srcValue->source->thaw(c, srcValue); - assert(c, dstHighMask.typeMask & (1 << lir::RegisterOperand)); + assertT(c, dstHighMask.typeMask & (1 << lir::RegisterOperand)); Site* high = freeRegisterSite(c, dstHighMask.registerMask); @@ -877,7 +877,7 @@ void appendMove(Context* c, c->arch->planSource(op, srcSelectSize, src, dstSize, &thunk); - assert(c, not thunk); + assertT(c, not thunk); append(c, new (c->zone) MoveEvent(c, @@ -911,7 +911,7 @@ thawSource(Context* c, unsigned size, Value* v) } Read* liveNext(Context* c, Value* v) { - assert(c, v->buddy->hasBuddy(c, v)); + assertT(c, v->buddy->hasBuddy(c, v)); Read* r = v->reads->next(c); if (valid(r)) return r; @@ -1004,7 +1004,7 @@ class CombineEvent: public Event { } virtual void compile(Context* c) { - assert(c, firstValue->source->type(c) == firstValue->nextWord->source->type(c)); + assertT(c, firstValue->source->type(c) == firstValue->nextWord->source->type(c)); // if (secondValue->source->type(c) != secondValue->nextWord->source->type(c)) { // fprintf(stderr, "%p %p %d : %p %p %d\n", @@ -1013,7 +1013,7 @@ class CombineEvent: public Event { // secondValue->nextWord->source->type(c)); // } - assert(c, secondValue->source->type(c) == secondValue->nextWord->source->type(c)); + assertT(c, secondValue->source->type(c) == secondValue->nextWord->source->type(c)); freezeSource(c, firstValue->type.size(c->targetInfo), firstValue); @@ -1197,7 +1197,7 @@ class TranslateEvent: public Event { } virtual void compile(Context* c) { - assert(c, firstValue->source->type(c) == firstValue->nextWord->source->type(c)); + assertT(c, firstValue->source->type(c) == firstValue->nextWord->source->type(c)); OperandMask bMask; @@ -1265,10 +1265,10 @@ void appendTranslate(Context* c, Value* firstValue, Value* resultValue) { - assert(c, + assertT(c, firstValue->type.size(c->targetInfo) == firstValue->type.size(c->targetInfo)); - assert(c, + assertT(c, resultValue->type.size(c->targetInfo) == resultValue->type.size(c->targetInfo)); @@ -1391,13 +1391,13 @@ class MemoryEvent: public Event { displacement += (constant->value->value() * scale); scale = 1; } else { - assert(c, index->source->type(c) == lir::RegisterOperand); + assertT(c, index->source->type(c) == lir::RegisterOperand); indexRegister = static_cast(index->source)->number; } } else { indexRegister = lir::NoRegister; } - assert(c, base->source->type(c) == lir::RegisterOperand); + assertT(c, base->source->type(c) == lir::RegisterOperand); int baseRegister = static_cast(base->source)->number; popRead(c, this, base); @@ -1693,7 +1693,7 @@ void appendBranch(Context* c, firstValue->type.size(c->targetInfo), &threadParameter); - assert(c, not threadParameter); + assertT(c, not threadParameter); slicePush(c, ceilingDivide(firstValue->type.size(c->targetInfo), @@ -1786,7 +1786,7 @@ class JumpEvent: public Event { OperandMask mask; c->arch->plan(op, c->targetInfo.pointerSize, mask, &thunk); - assert(c, not thunk); + assertT(c, not thunk); this->addRead(c, address, SiteMask::lowPart(mask)); } @@ -1881,7 +1881,7 @@ class BoundsCheckEvent: public Event { } if (constant == 0 or constant->value->value() >= 0) { - assert(c, object->source->type(c) == lir::RegisterOperand); + assertT(c, object->source->type(c) == lir::RegisterOperand); MemorySite length(static_cast(object->source)->number, lengthOffset, lir::NoRegister, 1); length.acquired = true; diff --git a/src/codegen/compiler/frame.cpp b/src/codegen/compiler/frame.cpp index 223d036e9d..f82502e2b7 100644 --- a/src/codegen/compiler/frame.cpp +++ b/src/codegen/compiler/frame.cpp @@ -26,7 +26,7 @@ unsigned totalFrameSize(Context* c) { } int frameIndex(Context* c, int localIndex) { - assert(c, localIndex >= 0); + assertT(c, localIndex >= 0); int index = c->alignedFrameSize + c->parameterFootprint - localIndex - 1; @@ -36,23 +36,23 @@ int frameIndex(Context* c, int localIndex) { index -= c->arch->frameFooterSize(); } - assert(c, index >= 0); - assert(c, static_cast(index) < totalFrameSize(c)); + assertT(c, index >= 0); + assertT(c, static_cast(index) < totalFrameSize(c)); return index; } unsigned frameIndexToOffset(Context* c, unsigned frameIndex) { - assert(c, frameIndex < totalFrameSize(c)); + assertT(c, frameIndex < totalFrameSize(c)); return (frameIndex + c->arch->frameFooterSize()) * c->targetInfo.pointerSize; } unsigned offsetToFrameIndex(Context* c, unsigned offset) { - assert(c, + assertT(c, static_cast((offset / c->targetInfo.pointerSize) - c->arch->frameFooterSize()) >= 0); - assert(c, + assertT(c, ((offset / c->targetInfo.pointerSize) - c->arch->frameFooterSize()) < totalFrameSize(c)); diff --git a/src/codegen/compiler/read.cpp b/src/codegen/compiler/read.cpp index 7e3e972f96..e5653e91e8 100644 --- a/src/codegen/compiler/read.cpp +++ b/src/codegen/compiler/read.cpp @@ -44,7 +44,7 @@ bool SingleRead::valid() { } void SingleRead::append(Context* c UNUSED, Read* r) { - assert(c, next_ == 0); + assertT(c, next_ == 0); next_ = r; } @@ -170,7 +170,7 @@ bool StubRead::valid() { } void StubRead::append(Context* c UNUSED, Read* r) { - assert(c, next_ == 0); + assertT(c, next_ == 0); next_ = r; } @@ -181,7 +181,7 @@ Read* StubRead::next(Context*) { SingleRead* read(Context* c, const SiteMask& mask, Value* successor) { - assert(c, (mask.typeMask != 1 << lir::MemoryOperand) or mask.frameIndex >= 0); + assertT(c, (mask.typeMask != 1 << lir::MemoryOperand) or mask.frameIndex >= 0); return new(c->zone) SingleRead(mask, successor); } diff --git a/src/codegen/compiler/regalloc.cpp b/src/codegen/compiler/regalloc.cpp index 8699838900..b6ab6dd043 100644 --- a/src/codegen/compiler/regalloc.cpp +++ b/src/codegen/compiler/regalloc.cpp @@ -40,7 +40,7 @@ resourceCost(Context* c, Value* v, Resource* r, SiteMask mask, costCalculator ? costCalculator->cost(c, mask) : 0; if (r->value) { - assert(c, r->value->findSite(r->site)); + assertT(c, r->value->findSite(r->site)); if (v and r->value->isBuddyOf(v)) { return baseCost; @@ -285,7 +285,7 @@ pickTarget(Context* c, Read* read, bool intersectRead, // memory isn't an option - try harder to find an available frame // site: best = pickAnyFrameTarget(c, value, costCalculator); - assert(c, best.cost <= 3); + assertT(c, best.cost <= 3); } if (best.cost == Target::Impossible) { diff --git a/src/codegen/compiler/resource.cpp b/src/codegen/compiler/resource.cpp index 674db90333..903c55c4ef 100644 --- a/src/codegen/compiler/resource.cpp +++ b/src/codegen/compiler/resource.cpp @@ -22,7 +22,7 @@ const bool DebugResources = false; void steal(Context* c, Resource* r, Value* thief); void decrementAvailableGeneralRegisterCount(Context* c) { - assert(c, c->availableGeneralRegisterCount); + assertT(c, c->availableGeneralRegisterCount); -- c->availableGeneralRegisterCount; if (DebugResources) { @@ -56,7 +56,7 @@ void thawResource(Context* c, Resource* r, Value* v) { fprintf(stderr, "%p thaw %s to %d\n", v, buffer, r->freezeCount - 1); } - assert(c, r->freezeCount); + assertT(c, r->freezeCount); -- r->freezeCount; } @@ -128,7 +128,7 @@ void RegisterResource::decrement(Context* c) { fprintf(stderr, "decrement %s to %d\n", buffer, this->referenceCount - 1); } - assert(c, this->referenceCount > 0); + assertT(c, this->referenceCount > 0); -- this->referenceCount; @@ -160,8 +160,8 @@ unsigned FrameResource::index(Context* c) { void acquire(Context* c, Resource* resource, Value* value, Site* site) { - assert(c, value); - assert(c, site); + assertT(c, value); + assertT(c, site); if (not resource->reserved) { if (DebugResources) { @@ -170,8 +170,8 @@ void acquire(Context* c, Resource* resource, Value* value, Site* site) { } if (resource->value) { - assert(c, resource->value->findSite(resource->site)); - assert(c, not value->findSite(resource->site)); + assertT(c, resource->value->findSite(resource->site)); + assertT(c, not value->findSite(resource->site)); steal(c, resource, value); } @@ -194,11 +194,11 @@ void release(Context* c, Resource* resource, Value* value UNUSED, Site* site UNU fprintf(stderr, "%p release %s\n", resource->value, buffer); } - assert(c, resource->value); - assert(c, resource->site); + assertT(c, resource->value); + assertT(c, resource->site); - assert(c, resource->value->isBuddyOf(value)); - assert(c, site == resource->site); + assertT(c, resource->value->isBuddyOf(value)); + assertT(c, site == resource->site); Resource* next = resource->nextAcquired; if (next) { @@ -211,7 +211,7 @@ void release(Context* c, Resource* resource, Value* value UNUSED, Site* site UNU previous->nextAcquired = next; resource->previousAcquired = 0; } else { - assert(c, c->acquiredResources == resource); + assertT(c, c->acquiredResources == resource); c->acquiredResources = next; } diff --git a/src/codegen/compiler/site.cpp b/src/codegen/compiler/site.cpp index b1ddcee1d7..2aec9578e3 100644 --- a/src/codegen/compiler/site.cpp +++ b/src/codegen/compiler/site.cpp @@ -154,7 +154,7 @@ class AddressSite: public Site { virtual void asAssemblerOperand(Context* c UNUSED, Site* high UNUSED, lir::Operand* result) { - assert(c, high == this); + assertT(c, high == this); new (result) lir::Address(address); } @@ -205,7 +205,7 @@ unsigned RegisterSite::toString(Context*, char* buffer, unsigned bufferSize) { } unsigned RegisterSite::copyCost(Context* c, Site* s) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); if (s and (this == s or @@ -219,7 +219,7 @@ unsigned RegisterSite::copyCost(Context* c, Site* s) { } bool RegisterSite::match(Context* c UNUSED, const SiteMask& mask) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); if ((mask.typeMask & (1 << lir::RegisterOperand))) { return ((static_cast(1) << number) & mask.registerMask); @@ -229,7 +229,7 @@ bool RegisterSite::match(Context* c UNUSED, const SiteMask& mask) { } bool RegisterSite::loneMatch(Context* c UNUSED, const SiteMask& mask) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); if ((mask.typeMask & (1 << lir::RegisterOperand))) { return ((static_cast(1) << number) == mask.registerMask); @@ -239,7 +239,7 @@ bool RegisterSite::loneMatch(Context* c UNUSED, const SiteMask& mask) { } bool RegisterSite::matchNextWord(Context* c, Site* s, unsigned) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); if (s->type(c) != lir::RegisterOperand) { return false; @@ -248,7 +248,7 @@ bool RegisterSite::matchNextWord(Context* c, Site* s, unsigned) { RegisterSite* rs = static_cast(s); unsigned size = rs->registerSize(c); if (size > c->targetInfo.pointerSize) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); return number == rs->number; } else { uint32_t mask = c->regFile->generalRegisters.mask; @@ -272,25 +272,25 @@ void RegisterSite::acquire(Context* c, Value* v) { } void RegisterSite::release(Context* c, Value* v) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); compiler::release(c, c->registerResources + number, v, this); } void RegisterSite::freeze(Context* c, Value* v) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); c->registerResources[number].freeze(c, v); } void RegisterSite::thaw(Context* c, Value* v) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); c->registerResources[number].thaw(c, v); } bool RegisterSite::frozen(Context* c UNUSED) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); return c->registerResources[number].freezeCount != 0; } @@ -302,12 +302,12 @@ lir::OperandType RegisterSite::type(Context*) { void RegisterSite::asAssemblerOperand(Context* c UNUSED, Site* high, lir::Operand* result) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); int highNumber; if (high != this) { highNumber = static_cast(high)->number; - assert(c, highNumber != lir::NoRegister); + assertT(c, highNumber != lir::NoRegister); } else { highNumber = lir::NoRegister; } @@ -336,8 +336,8 @@ Site* RegisterSite::copyHigh(Context* c) { } Site* RegisterSite::makeNextWord(Context* c, unsigned) { - assert(c, number != lir::NoRegister); - assert(c, ((1 << number) & c->regFile->generalRegisters.mask)); + assertT(c, number != lir::NoRegister); + assertT(c, ((1 << number) & c->regFile->generalRegisters.mask)); return freeRegisterSite(c, c->regFile->generalRegisters.mask); } @@ -347,7 +347,7 @@ SiteMask RegisterSite::mask(Context* c UNUSED) { } SiteMask RegisterSite::nextWordMask(Context* c, unsigned) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); if (registerSize(c) > c->targetInfo.pointerSize) { return SiteMask @@ -359,7 +359,7 @@ SiteMask RegisterSite::nextWordMask(Context* c, unsigned) { } unsigned RegisterSite::registerSize(Context* c) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); if ((1 << number) & c->regFile->floatRegisters.mask) { return c->arch->floatRegisterSize(); @@ -369,7 +369,7 @@ unsigned RegisterSite::registerSize(Context* c) { } unsigned RegisterSite::registerMask(Context* c UNUSED) { - assert(c, number != lir::NoRegister); + assertT(c, number != lir::NoRegister); return 1 << number; } @@ -377,8 +377,8 @@ unsigned RegisterSite::registerMask(Context* c UNUSED) { Site* registerSite(Context* c, int number) { - assert(c, number >= 0); - assert(c, (1 << number) & (c->regFile->generalRegisters.mask + assertT(c, number >= 0); + assertT(c, (1 << number) & (c->regFile->generalRegisters.mask | c->regFile->floatRegisters.mask)); return new(c->zone) RegisterSite(1 << number, number); @@ -402,7 +402,7 @@ unsigned MemorySite::toString(Context*, char* buffer, unsigned bufferSize) { } unsigned MemorySite::copyCost(Context* c, Site* s) { - assert(c, acquired); + assertT(c, acquired); if (s and (this == s or @@ -426,12 +426,12 @@ bool MemorySite::conflicts(const SiteMask& mask) { } bool MemorySite::match(Context* c, const SiteMask& mask) { - assert(c, acquired); + assertT(c, acquired); if (mask.typeMask & (1 << lir::MemoryOperand)) { if (mask.frameIndex >= 0) { if (base == c->arch->stack()) { - assert(c, index == lir::NoRegister); + assertT(c, index == lir::NoRegister); return static_cast(frameIndexToOffset(c, mask.frameIndex)) == offset; } else { @@ -446,11 +446,11 @@ bool MemorySite::match(Context* c, const SiteMask& mask) { } bool MemorySite::loneMatch(Context* c, const SiteMask& mask) { - assert(c, acquired); + assertT(c, acquired); if (mask.typeMask & (1 << lir::MemoryOperand)) { if (base == c->arch->stack()) { - assert(c, index == lir::NoRegister); + assertT(c, index == lir::NoRegister); if (mask.frameIndex == AnyFrameIndex) { return false; @@ -487,8 +487,8 @@ void MemorySite::acquire(Context* c, Value* v) { } if (base == c->arch->stack()) { - assert(c, index == lir::NoRegister); - assert + assertT(c, index == lir::NoRegister); + assertT (c, not c->frameResources[offsetToFrameIndex(c, offset)].reserved); compiler::acquire @@ -500,8 +500,8 @@ void MemorySite::acquire(Context* c, Value* v) { void MemorySite::release(Context* c, Value* v) { if (base == c->arch->stack()) { - assert(c, index == lir::NoRegister); - assert + assertT(c, index == lir::NoRegister); + assertT (c, not c->frameResources[offsetToFrameIndex(c, offset)].reserved); compiler::release @@ -551,7 +551,7 @@ void MemorySite::asAssemblerOperand(Context* c UNUSED, Site* high UNUSED, lir::Operand* result) { // todo: endianness? - assert(c, + assertT(c, high == this or (static_cast(high)->base == base and static_cast(high)->offset @@ -559,7 +559,7 @@ void MemorySite::asAssemblerOperand(Context* c UNUSED, Site* high UNUSED, and static_cast(high)->index == index and static_cast(high)->scale == scale)); - assert(c, acquired); + assertT(c, acquired); new (result) lir::Memory(base, offset, index, scale); } @@ -604,7 +604,7 @@ SiteMask MemorySite::mask(Context* c) { SiteMask MemorySite::nextWordMask(Context* c, unsigned index) { int frameIndex; if (base == c->arch->stack()) { - assert(c, this->index == lir::NoRegister); + assertT(c, this->index == lir::NoRegister); frameIndex = static_cast(offsetToFrameIndex(c, offset)) + ((index == 1) xor c->arch->bigEndian() ? 1 : -1); } else { @@ -623,7 +623,7 @@ MemorySite* memorySite(Context* c, int base, int offset, int index, unsigned sca } MemorySite* frameSite(Context* c, int frameIndex) { - assert(c, frameIndex >= 0); + assertT(c, frameIndex >= 0); return memorySite (c, c->arch->stack(), frameIndexToOffset(c, frameIndex), lir::NoRegister, 0); } diff --git a/src/codegen/compiler/value.cpp b/src/codegen/compiler/value.cpp index 411cbe37ee..d0c4ec7776 100644 --- a/src/codegen/compiler/value.cpp +++ b/src/codegen/compiler/value.cpp @@ -61,7 +61,7 @@ void Value::addSite(Context* c, Site* s) { void Value::grow(Context* c) { - assert(c, this->nextWord == this); + assertT(c, this->nextWord == this); Value* next = value(c, this->type); this->nextWord = next; @@ -101,7 +101,7 @@ void Value::removeSite(Context* c, Site* s) { if (DebugSites) { fprintf(stderr, "%p has more: %d\n", this, this->hasSite(c)); } - assert(c, not this->findSite(s)); + assertT(c, not this->findSite(s)); } bool Value::hasSite(Context* c) { @@ -128,7 +128,7 @@ bool Value::uniqueSite(Context* c, Site* s) { return false; } } else { - assert(c, p == s); + assertT(c, p == s); return true; } } diff --git a/src/codegen/target/arm/assembler.cpp b/src/codegen/target/arm/assembler.cpp index b817ef1ae2..a7e678e39d 100644 --- a/src/codegen/target/arm/assembler.cpp +++ b/src/codegen/target/arm/assembler.cpp @@ -85,8 +85,8 @@ nextFrame(ArchitectureContext* con, uint32_t* start, unsigned size UNUSED, unsigned footprint, void* link, bool, int targetParameterFootprint UNUSED, void** ip, void** stack) { - assert(con, *ip >= start); - assert(con, *ip <= start + (size / TargetBytesPerWord)); + assertT(con, *ip >= start); + assertT(con, *ip <= start + (size / TargetBytesPerWord)); uint32_t* instruction = static_cast(*ip); @@ -235,7 +235,7 @@ class MyArchitecture: public Architecture { } virtual int argumentRegister(unsigned index) { - assert(&con, index < argumentRegisterCount()); + assertT(&con, index < argumentRegisterCount()); return index; } @@ -576,7 +576,7 @@ class MyAssembler: public Assembler { { } virtual void setClient(Client* client) { - assert(&con, con.client == 0); + assertT(&con, con.client == 0); con.client = client; } @@ -660,7 +660,7 @@ class MyAssembler: public Assembler { // larger frames may require multiple subtract/add instructions // to allocate/deallocate, and nextFrame will need to be taught // how to handle them: - assert(&con, footprint < 256); + assertT(&con, footprint < 256); lir::Register stack(StackRegister); ResolvedPromise footprintPromise(footprint * TargetBytesPerWord); @@ -701,7 +701,7 @@ class MyAssembler: public Assembler { int returnAddressSurrogate, int framePointerSurrogate UNUSED) { - assert(&con, framePointerSurrogate == lir::NoRegister); + assertT(&con, framePointerSurrogate == lir::NoRegister); if (TailCalls) { if (offset) { @@ -720,7 +720,7 @@ class MyAssembler: public Assembler { addC(&con, TargetBytesPerWord, &footprintConstant, &stack, &stack); if (returnAddressSurrogate != lir::NoRegister) { - assert(&con, offset > 0); + assertT(&con, offset > 0); lir::Register ras(returnAddressSurrogate); lir::Memory dst(StackRegister, (offset - 1) * TargetBytesPerWord); @@ -739,8 +739,8 @@ class MyAssembler: public Assembler { { popFrame(frameFootprint); - assert(&con, argumentFootprint >= StackAlignmentInWords); - assert(&con, (argumentFootprint % StackAlignmentInWords) == 0); + assertT(&con, argumentFootprint >= StackAlignmentInWords); + assertT(&con, (argumentFootprint % StackAlignmentInWords) == 0); unsigned offset; if (TailCalls and argumentFootprint > StackAlignmentInWords) { @@ -788,16 +788,16 @@ class MyAssembler: public Assembler { virtual void apply(lir::TernaryOperation op, OperandInfo a, OperandInfo b, OperandInfo c) { if (isBranch(op)) { - assert(&con, a.size == b.size); - assert(&con, c.size == TargetBytesPerWord); - assert(&con, c.type == lir::ConstantOperand); + assertT(&con, a.size == b.size); + assertT(&con, c.size == TargetBytesPerWord); + assertT(&con, c.type == lir::ConstantOperand); arch_->con.branchOperations[branchIndex(&(arch_->con), a.type, b.type)] (&con, op, a.size, a.operand, b.operand, c.operand); } else { - assert(&con, b.size == c.size); - assert(&con, b.type == lir::RegisterOperand); - assert(&con, c.type == lir::RegisterOperand); + assertT(&con, b.size == c.size); + assertT(&con, b.type == lir::RegisterOperand); + assertT(&con, c.type == lir::RegisterOperand); arch_->con.ternaryOperations[index(&(arch_->con), op, a.type)] (&con, b.size, a.operand, b.operand, c.operand); diff --git a/src/codegen/target/arm/fixup.cpp b/src/codegen/target/arm/fixup.cpp index 011cb62988..96f96228c5 100644 --- a/src/codegen/target/arm/fixup.cpp +++ b/src/codegen/target/arm/fixup.cpp @@ -29,7 +29,7 @@ bool OffsetPromise::resolved() { } int64_t OffsetPromise::value() { - assert(con, resolved()); + assertT(con, resolved()); unsigned o = offset - block->offset; return block->start + padding @@ -99,7 +99,7 @@ ConstantPoolEntry::ConstantPoolEntry(Context* con, Promise* constant, ConstantPo { } int64_t ConstantPoolEntry::value() { - assert(con, resolved()); + assertT(con, resolved()); return reinterpret_cast(address); } diff --git a/src/codegen/target/arm/multimethod.cpp b/src/codegen/target/arm/multimethod.cpp index 65c84438f1..cf350d0179 100644 --- a/src/codegen/target/arm/multimethod.cpp +++ b/src/codegen/target/arm/multimethod.cpp @@ -34,7 +34,7 @@ unsigned index(ArchitectureContext* con UNUSED, lir::TernaryOperation operation, lir::OperandType operand1) { - assert(con, not isBranch(operation)); + assertT(con, not isBranch(operation)); return operation + (lir::NonBranchTernaryOperationCount * operand1); } diff --git a/src/codegen/target/arm/operations.cpp b/src/codegen/target/arm/operations.cpp index 3d23082373..11a0b27ad6 100644 --- a/src/codegen/target/arm/operations.cpp +++ b/src/codegen/target/arm/operations.cpp @@ -61,7 +61,7 @@ void moveRR(Context* con, unsigned srcSize, lir::Register* src, void shiftLeftC(Context* con, unsigned size UNUSED, lir::Constant* a, lir::Register* b, lir::Register* t) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); if (getValue(a) & 0x1F) { emit(con, lsli(t->low, b->low, getValue(a) & 0x1F)); } else { @@ -98,7 +98,7 @@ void shiftRightR(Context* con, unsigned size, lir::Register* a, lir::Register* b void shiftRightC(Context* con, unsigned size UNUSED, lir::Constant* a, lir::Register* b, lir::Register* t) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); if (getValue(a) & 0x1F) { emit(con, asri(t->low, b->low, getValue(a) & 0x1F)); } else { @@ -130,7 +130,7 @@ void unsignedShiftRightR(Context* con, unsigned size, lir::Register* a, lir::Reg void unsignedShiftRightC(Context* con, unsigned size UNUSED, lir::Constant* a, lir::Register* b, lir::Register* t) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); if (getValue(a) & 0x1F) { emit(con, lsri(t->low, b->low, getValue(a) & 0x1F)); } else { @@ -223,15 +223,15 @@ void resolve(MyBlock* b) void jumpR(Context* con, unsigned size UNUSED, lir::Register* target) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); emit(con, bx(target->low)); } void swapRR(Context* con, unsigned aSize, lir::Register* a, unsigned bSize, lir::Register* b) { - assert(con, aSize == vm::TargetBytesPerWord); - assert(con, bSize == vm::TargetBytesPerWord); + assertT(con, aSize == vm::TargetBytesPerWord); + assertT(con, bSize == vm::TargetBytesPerWord); lir::Register tmp(con->client->acquireTemporary(GPR_MASK)); moveRR(con, aSize, a, bSize, &tmp); @@ -246,7 +246,7 @@ void moveRR(Context* con, unsigned srcSize, lir::Register* src, bool srcIsFpr = isFpr(src); bool dstIsFpr = isFpr(dst); if (srcIsFpr || dstIsFpr) { // FPR(s) involved - assert(con, srcSize == dstSize); + assertT(con, srcSize == dstSize); const bool dprec = srcSize == 8; if (srcIsFpr && dstIsFpr) { // FPR to FPR if (dprec) emit(con, fcpyd(fpr64(dst), fpr64(src))); // double @@ -370,7 +370,7 @@ void subR(Context* con, unsigned size, lir::Register* a, lir::Register* b, lir:: void addC(Context* con, unsigned size, lir::Constant* a, lir::Register* b, lir::Register* dst) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); int32_t v = a->value->value(); if (v) { @@ -390,7 +390,7 @@ void addC(Context* con, unsigned size, lir::Constant* a, void subC(Context* con, unsigned size, lir::Constant* a, lir::Register* b, lir::Register* dst) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); int32_t v = a->value->value(); if (v) { @@ -654,7 +654,7 @@ void store(Context* con, unsigned size, lir::Register* src, void moveRM(Context* con, unsigned srcSize, lir::Register* src, unsigned dstSize UNUSED, lir::Memory* dst) { - assert(con, srcSize == dstSize); + assertT(con, srcSize == dstSize); store(con, srcSize, src, dst->base, dst->offset, dst->index, dst->scale, true); } @@ -866,7 +866,7 @@ void xorR(Context* con, unsigned size, lir::Register* a, void moveAR2(Context* con, unsigned srcSize, lir::Address* src, unsigned dstSize, lir::Register* dst) { - assert(con, srcSize == 4 and dstSize == 4); + assertT(con, srcSize == 4 and dstSize == 4); lir::Constant constant(src->address); moveCR(con, srcSize, &constant, dstSize, dst); @@ -884,14 +884,14 @@ void moveAR(Context* con, unsigned srcSize, lir::Address* src, void compareRR(Context* con, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(con, !(isFpr(a) ^ isFpr(b))); // regs must be of the same type + assertT(con, !(isFpr(a) ^ isFpr(b))); // regs must be of the same type if (!isFpr(a)) { // GPR compare - assert(con, aSize == 4 && bSize == 4); - /**///assert(con, b->low != a->low); + assertT(con, aSize == 4 && bSize == 4); + /**///assertT(con, b->low != a->low); emit(con, cmp(b->low, a->low)); } else { // FPR compare - assert(con, aSize == bSize); + assertT(con, aSize == bSize); if (aSize == 8) emit(con, fcmpd(fpr64(b), fpr64(a))); // double else emit(con, fcmps(fpr32(b), fpr32(a))); // single emit(con, fmstat()); @@ -901,7 +901,7 @@ void compareRR(Context* con, unsigned aSize, lir::Register* a, void compareCR(Context* con, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(con, aSize == 4 and bSize == 4); + assertT(con, aSize == 4 and bSize == 4); if (!isFpr(b) && a->value->resolved() && isOfWidth(a->value->value(), 8)) { @@ -917,7 +917,7 @@ void compareCR(Context* con, unsigned aSize, lir::Constant* a, void compareCM(Context* con, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Memory* b) { - assert(con, aSize == 4 and bSize == 4); + assertT(con, aSize == 4 and bSize == 4); lir::Register tmp(con->client->acquireTemporary(GPR_MASK)); moveMR(con, bSize, b, bSize, &tmp); @@ -928,7 +928,7 @@ void compareCM(Context* con, unsigned aSize, lir::Constant* a, void compareRM(Context* con, unsigned aSize, lir::Register* a, unsigned bSize, lir::Memory* b) { - assert(con, aSize == 4 and bSize == 4); + assertT(con, aSize == 4 and bSize == 4); lir::Register tmp(con->client->acquireTemporary(GPR_MASK)); moveMR(con, bSize, b, bSize, &tmp); @@ -1092,7 +1092,7 @@ void branchCR(Context* con, lir::TernaryOperation op, unsigned size, lir::Constant* a, lir::Register* b, lir::Constant* target) { - assert(con, !isFloatBranch(op)); + assertT(con, !isFloatBranch(op)); if (size > vm::TargetBytesPerWord) { int64_t v = a->value->value(); @@ -1117,8 +1117,8 @@ void branchRM(Context* con, lir::TernaryOperation op, unsigned size, lir::Register* a, lir::Memory* b, lir::Constant* target) { - assert(con, !isFloatBranch(op)); - assert(con, size <= vm::TargetBytesPerWord); + assertT(con, !isFloatBranch(op)); + assertT(con, size <= vm::TargetBytesPerWord); compareRM(con, size, a, size, b); branch(con, op, target); @@ -1128,8 +1128,8 @@ void branchCM(Context* con, lir::TernaryOperation op, unsigned size, lir::Constant* a, lir::Memory* b, lir::Constant* target) { - assert(con, !isFloatBranch(op)); - assert(con, size <= vm::TargetBytesPerWord); + assertT(con, !isFloatBranch(op)); + assertT(con, size <= vm::TargetBytesPerWord); compareCM(con, size, a, size, b); branch(con, op, target); @@ -1169,7 +1169,7 @@ void moveCM(Context* con, unsigned srcSize, lir::Constant* src, void negateRR(Context* con, unsigned srcSize, lir::Register* src, unsigned dstSize UNUSED, lir::Register* dst) { - assert(con, srcSize == dstSize); + assertT(con, srcSize == dstSize); emit(con, mvn(dst->low, src->low)); emit(con, SETS(addi(dst->low, dst->low, 1))); @@ -1181,13 +1181,13 @@ void negateRR(Context* con, unsigned srcSize, lir::Register* src, void callR(Context* con, unsigned size UNUSED, lir::Register* target) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); emit(con, blx(target->low)); } void callC(Context* con, unsigned size UNUSED, lir::Constant* target) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); appendOffsetTask(con, target->value, offsetPromise(con)); emit(con, bl(0)); @@ -1195,7 +1195,7 @@ void callC(Context* con, unsigned size UNUSED, lir::Constant* target) void longCallC(Context* con, unsigned size UNUSED, lir::Constant* target) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); lir::Register tmp(4); moveCR2(con, vm::TargetBytesPerWord, target, &tmp, offsetPromise(con)); @@ -1204,7 +1204,7 @@ void longCallC(Context* con, unsigned size UNUSED, lir::Constant* target) void longJumpC(Context* con, unsigned size UNUSED, lir::Constant* target) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); lir::Register tmp(4); // a non-arg reg that we don't mind clobbering moveCR2(con, vm::TargetBytesPerWord, target, &tmp, offsetPromise(con)); @@ -1213,7 +1213,7 @@ void longJumpC(Context* con, unsigned size UNUSED, lir::Constant* target) void jumpC(Context* con, unsigned size UNUSED, lir::Constant* target) { - assert(con, size == vm::TargetBytesPerWord); + assertT(con, size == vm::TargetBytesPerWord); appendOffsetTask(con, target->value, offsetPromise(con)); emit(con, b(0)); diff --git a/src/codegen/target/x86/assembler.cpp b/src/codegen/target/x86/assembler.cpp index 4791f65681..b1b0855655 100644 --- a/src/codegen/target/x86/assembler.cpp +++ b/src/codegen/target/x86/assembler.cpp @@ -74,8 +74,8 @@ nextFrame(ArchitectureContext* c UNUSED, uint8_t* start, unsigned size UNUSED, unsigned footprint, void*, bool mostRecent, int targetParameterFootprint, void** ip, void** stack) { - assert(c, *ip >= start); - assert(c, *ip <= start + size); + assertT(c, *ip >= start); + assertT(c, *ip <= start + size); uint8_t* instruction = static_cast(*ip); @@ -89,7 +89,7 @@ nextFrame(ArchitectureContext* c UNUSED, uint8_t* start, unsigned size UNUSED, } if (instruction <= start) { - assert(c, mostRecent); + assertT(c, mostRecent); *ip = static_cast(*stack)[0]; return; } @@ -99,7 +99,7 @@ nextFrame(ArchitectureContext* c UNUSED, uint8_t* start, unsigned size UNUSED, start += (TargetBytesPerWord == 4 ? 3 : 4); if (instruction <= start or *instruction == 0x5d) { - assert(c, mostRecent); + assertT(c, mostRecent); *ip = static_cast(*stack)[1]; *stack = static_cast(*stack) + 1; @@ -143,10 +143,10 @@ nextFrame(ArchitectureContext* c UNUSED, uint8_t* start, unsigned size UNUSED, } if (UseFramePointer and not mostRecent) { - assert(c, static_cast(*stack)[-1] + 1 + assertT(c, static_cast(*stack)[-1] + 1 == static_cast(*stack) + offset); - assert(c, static_cast(*stack)[-1][1] + assertT(c, static_cast(*stack)[-1][1] == static_cast(*stack)[offset]); } @@ -263,7 +263,7 @@ class MyArchitecture: public Architecture { } virtual int argumentRegister(unsigned index) { - assert(&c, TargetBytesPerWord == 8); + assertT(&c, TargetBytesPerWord == 8); switch (index) { #if AVIAN_TARGET_FORMAT == AVIAN_FORMAT_PE case 0: @@ -312,45 +312,45 @@ class MyArchitecture: public Architecture { virtual void updateCall(lir::UnaryOperation op, void* returnAddress, void* newTarget) { - bool assertAlignment UNUSED; + bool assertTAlignment UNUSED; switch (op) { case lir::AlignedCall: op = lir::Call; - assertAlignment = true; + assertTAlignment = true; break; case lir::AlignedJump: op = lir::Jump; - assertAlignment = true; + assertTAlignment = true; break; case lir::AlignedLongCall: op = lir::LongCall; - assertAlignment = true; + assertTAlignment = true; break; case lir::AlignedLongJump: op = lir::LongJump; - assertAlignment = true; + assertTAlignment = true; break; default: - assertAlignment = false; + assertTAlignment = false; } if (TargetBytesPerWord == 4 or op == lir::Call or op == lir::Jump) { uint8_t* instruction = static_cast(returnAddress) - 5; - assert(&c, ((op == lir::Call or op == lir::LongCall) and *instruction == 0xE8) + assertT(&c, ((op == lir::Call or op == lir::LongCall) and *instruction == 0xE8) or ((op == lir::Jump or op == lir::LongJump) and *instruction == 0xE9)); - assert(&c, (not assertAlignment) + assertT(&c, (not assertTAlignment) or reinterpret_cast(instruction + 1) % 4 == 0); intptr_t v = static_cast(newTarget) - static_cast(returnAddress); - assert(&c, vm::fitsInInt32(v)); + assertT(&c, vm::fitsInInt32(v)); int32_t v32 = v; @@ -358,12 +358,12 @@ class MyArchitecture: public Architecture { } else { uint8_t* instruction = static_cast(returnAddress) - 13; - assert(&c, instruction[0] == 0x49 and instruction[1] == 0xBA); - assert(&c, instruction[10] == 0x41 and instruction[11] == 0xFF); - assert(&c, (op == lir::LongCall and instruction[12] == 0xD2) + assertT(&c, instruction[0] == 0x49 and instruction[1] == 0xBA); + assertT(&c, instruction[10] == 0x41 and instruction[11] == 0xFF); + assertT(&c, (op == lir::LongCall and instruction[12] == 0xD2) or (op == lir::LongJump and instruction[12] == 0xE2)); - assert(&c, (not assertAlignment) + assertT(&c, (not assertTAlignment) or reinterpret_cast(instruction + 2) % 8 == 0); memcpy(instruction + 2, &newTarget, 8); @@ -827,7 +827,7 @@ class MyAssembler: public Assembler { { } virtual void setClient(Client* client) { - assert(&c, c.client == 0); + assertT(&c, c.client == 0); c.client = client; } @@ -989,7 +989,7 @@ class MyAssembler: public Assembler { addCR(&c, TargetBytesPerWord, &footprint, TargetBytesPerWord, &stack); if (returnAddressSurrogate != lir::NoRegister) { - assert(&c, offset > 0); + assertT(&c, offset > 0); lir::Register ras(returnAddressSurrogate); lir::Memory dst(rsp, offset * TargetBytesPerWord); @@ -997,7 +997,7 @@ class MyAssembler: public Assembler { } if (framePointerSurrogate != lir::NoRegister) { - assert(&c, offset > 0); + assertT(&c, offset > 0); lir::Register fps(framePointerSurrogate); lir::Memory dst(rsp, (offset - 1) * TargetBytesPerWord); @@ -1016,8 +1016,8 @@ class MyAssembler: public Assembler { { popFrame(frameFootprint); - assert(&c, argumentFootprint >= StackAlignmentInWords); - assert(&c, (argumentFootprint % StackAlignmentInWords) == 0); + assertT(&c, argumentFootprint >= StackAlignmentInWords); + assertT(&c, (argumentFootprint % StackAlignmentInWords) == 0); if (TailCalls and argumentFootprint > StackAlignmentInWords) { lir::Register returnAddress(rcx); @@ -1069,15 +1069,15 @@ class MyAssembler: public Assembler { virtual void apply(lir::TernaryOperation op, OperandInfo a, OperandInfo b, OperandInfo c) { if (isBranch(op)) { - assert(&this->c, a.size == b.size); - assert(&this->c, c.size == TargetBytesPerWord); - assert(&this->c, c.type == lir::ConstantOperand); + assertT(&this->c, a.size == b.size); + assertT(&this->c, c.size == TargetBytesPerWord); + assertT(&this->c, c.type == lir::ConstantOperand); arch_->c.branchOperations[branchIndex(&(arch_->c), a.type, b.type)] (&this->c, op, a.size, a.operand, b.operand, c.operand); } else { - assert(&this->c, b.size == c.size); - assert(&this->c, b.type == c.type); + assertT(&this->c, b.size == c.size); + assertT(&this->c, b.type == c.type); arch_->c.binaryOperations[index(&(arch_->c), op, a.type, b.type)] (&this->c, a.size, a.operand, b.size, b.operand); diff --git a/src/codegen/target/x86/encode.cpp b/src/codegen/target/x86/encode.cpp index 190810d463..04f2abcdb1 100644 --- a/src/codegen/target/x86/encode.cpp +++ b/src/codegen/target/x86/encode.cpp @@ -154,8 +154,8 @@ void conditional(Context* c, unsigned condition, lir::Constant* a) { void sseMoveRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize >= 4); - assert(c, aSize == bSize); + assertT(c, aSize >= 4); + assertT(c, aSize == bSize); if (isFloatReg(a) and isFloatReg(b)) { if (aSize == 4) { @@ -185,7 +185,7 @@ void sseMoveRR(Context* c, unsigned aSize, lir::Register* a, void sseMoveCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize <= vm::TargetBytesPerWord); + assertT(c, aSize <= vm::TargetBytesPerWord); lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask)); moveCR2(c, aSize, a, aSize, &tmp, 0); sseMoveRR(c, aSize, &tmp, bSize, b); @@ -195,7 +195,7 @@ void sseMoveCR(Context* c, unsigned aSize, lir::Constant* a, void sseMoveMR(Context* c, unsigned aSize, lir::Memory* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize >= 4); + assertT(c, aSize >= 4); if (vm::TargetBytesPerWord == 4 and aSize == 8) { opcode(c, 0xf3); @@ -212,8 +212,8 @@ void sseMoveMR(Context* c, unsigned aSize, lir::Memory* a, void sseMoveRM(Context* c, unsigned aSize, lir::Register* a, UNUSED unsigned bSize, lir::Memory* b) { - assert(c, aSize >= 4); - assert(c, aSize == bSize); + assertT(c, aSize >= 4); + assertT(c, aSize == bSize); if (vm::TargetBytesPerWord == 4 and aSize == 8) { opcode(c, 0x66); diff --git a/src/codegen/target/x86/fixup.cpp b/src/codegen/target/x86/fixup.cpp index 7bf1b78a9d..8e32669a5b 100644 --- a/src/codegen/target/x86/fixup.cpp +++ b/src/codegen/target/x86/fixup.cpp @@ -42,7 +42,7 @@ bool OffsetPromise::resolved() { } int64_t OffsetPromise::value() { - assert(c, resolved()); + assertT(c, resolved()); if (value_ == -1) { value_ = block->start + (offset - block->offset) diff --git a/src/codegen/target/x86/multimethod.cpp b/src/codegen/target/x86/multimethod.cpp index a71f02c04a..d72da5483f 100644 --- a/src/codegen/target/x86/multimethod.cpp +++ b/src/codegen/target/x86/multimethod.cpp @@ -39,7 +39,7 @@ unsigned index(ArchitectureContext*, lir::BinaryOperation operation, unsigned index(ArchitectureContext* c UNUSED, lir::TernaryOperation operation, lir::OperandType operand1, lir::OperandType operand2) { - assert(c, not isBranch(operation)); + assertT(c, not isBranch(operation)); return lir::BinaryOperationCount + operation + ((lir::BinaryOperationCount + lir::NonBranchTernaryOperationCount) * operand1) diff --git a/src/codegen/target/x86/operations.cpp b/src/codegen/target/x86/operations.cpp index 8523bdb032..66972f36d1 100644 --- a/src/codegen/target/x86/operations.cpp +++ b/src/codegen/target/x86/operations.cpp @@ -62,13 +62,13 @@ void storeLoadBarrier(Context* c) { } void callC(Context* c, unsigned size UNUSED, lir::Constant* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); unconditional(c, 0xe8, a); } void longCallC(Context* c, unsigned size, lir::Constant* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); if (vm::TargetBytesPerWord == 8) { lir::Register r(LongJumpRegister); @@ -80,20 +80,20 @@ void longCallC(Context* c, unsigned size, lir::Constant* a) { } void jumpR(Context* c, unsigned size UNUSED, lir::Register* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); maybeRex(c, 4, a); opcode(c, 0xff, 0xe0 + regCode(a)); } void jumpC(Context* c, unsigned size UNUSED, lir::Constant* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); unconditional(c, 0xe9, a); } void jumpM(Context* c, unsigned size UNUSED, lir::Memory* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); maybeRex(c, 4, a); opcode(c, 0xff); @@ -101,7 +101,7 @@ void jumpM(Context* c, unsigned size UNUSED, lir::Memory* a) { } void longJumpC(Context* c, unsigned size, lir::Constant* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); if (vm::TargetBytesPerWord == 8) { lir::Register r(LongJumpRegister); @@ -113,7 +113,7 @@ void longJumpC(Context* c, unsigned size, lir::Constant* a) { } void callR(Context* c, unsigned size UNUSED, lir::Register* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); // maybeRex.W has no meaning here so we disable it maybeRex(c, 4, a); @@ -121,7 +121,7 @@ void callR(Context* c, unsigned size UNUSED, lir::Register* a) { } void callM(Context* c, unsigned size UNUSED, lir::Memory* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); maybeRex(c, 4, a); opcode(c, 0xff); @@ -134,7 +134,7 @@ void alignedCallC(Context* c, unsigned size, lir::Constant* a) { } void alignedLongCallC(Context* c, unsigned size, lir::Constant* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); if (vm::TargetBytesPerWord == 8) { new (c->zone) AlignmentPadding(c, 2, 8); @@ -150,7 +150,7 @@ void alignedJumpC(Context* c, unsigned size, lir::Constant* a) { } void alignedLongJumpC(Context* c, unsigned size, lir::Constant* a) { - assert(c, size == vm::TargetBytesPerWord); + assertT(c, size == vm::TargetBytesPerWord); if (vm::TargetBytesPerWord == 8) { new (c->zone) AlignmentPadding(c, 2, 8); @@ -192,7 +192,7 @@ void popR(Context* c, unsigned size, lir::Register* a) void negateR(Context* c, unsigned size, lir::Register* a) { if (vm::TargetBytesPerWord == 4 and size == 8) { - assert(c, a->low == rax and a->high == rdx); + assertT(c, a->low == rax and a->high == rdx); ResolvedPromise zeroPromise(0); lir::Constant zero(&zeroPromise); @@ -211,7 +211,7 @@ void negateR(Context* c, unsigned size, lir::Register* a) void negateRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b UNUSED) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); negateR(c, aSize, a); } @@ -229,10 +229,10 @@ void moveCR(Context* c, unsigned aSize, lir::Constant* a, void moveZCR(Context* c, unsigned aSize UNUSED, lir::Constant* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, not isFloatReg(b)); - assert(c, aSize == 2); - assert(c, bSize == vm::TargetBytesPerWord); - assert(c, a->value->resolved()); + assertT(c, not isFloatReg(b)); + assertT(c, aSize == 2); + assertT(c, bSize == vm::TargetBytesPerWord); + assertT(c, a->value->resolved()); maybeRex(c, vm::TargetBytesPerWord, b); opcode(c, 0xb8 + regCode(b)); @@ -242,8 +242,8 @@ void moveZCR(Context* c, unsigned aSize UNUSED, lir::Constant* a, void swapRR(Context* c, unsigned aSize UNUSED, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); - assert(c, aSize == vm::TargetBytesPerWord); + assertT(c, aSize == bSize); + assertT(c, aSize == vm::TargetBytesPerWord); alwaysRex(c, aSize, a, b); opcode(c, 0x87); @@ -277,7 +277,7 @@ void moveRR(Context* c, unsigned aSize, lir::Register* a, switch (aSize) { case 1: if (vm::TargetBytesPerWord == 4 and a->low > rbx) { - assert(c, b->low <= rbx); + assertT(c, b->low <= rbx); moveRR(c, vm::TargetBytesPerWord, a, vm::TargetBytesPerWord, b); moveRR(c, 1, b, vm::TargetBytesPerWord, b); @@ -304,7 +304,7 @@ void moveRR(Context* c, unsigned aSize, lir::Register* a, if (a->low == rax and b->low == rax and b->high == rdx) { opcode(c, 0x99); //cdq } else { - assert(c, b->low == rax and b->high == rdx); + assertT(c, b->low == rax and b->high == rdx); moveRR(c, 4, a, 4, b); moveRR(c, 4, b, 8, b); @@ -358,7 +358,7 @@ void moveMR(Context* c, unsigned aSize, lir::Memory* a, modrmSibImm(c, b, a); } else { if (bSize == 8) { - assert(c, b->low == rax and b->high == rdx); + assertT(c, b->low == rax and b->high == rdx); moveMR(c, 4, a, 4, b); moveRR(c, 4, b, 8, b); @@ -391,7 +391,7 @@ void moveMR(Context* c, unsigned aSize, lir::Memory* a, void moveRM(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Memory* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (isFloatReg(a)) { sseMoveRM(c, aSize, a, bSize, b); @@ -445,7 +445,7 @@ void moveRM(Context* c, unsigned aSize, lir::Register* a, void moveAR(Context* c, unsigned aSize, lir::Address* a, unsigned bSize, lir::Register* b) { - assert(c, vm::TargetBytesPerWord == 8 or (aSize == 4 and bSize == 4)); + assertT(c, vm::TargetBytesPerWord == 8 or (aSize == 4 and bSize == 4)); lir::Constant constant(a->address); lir::Memory memory(b->low, 0, -1, 0); @@ -531,8 +531,8 @@ void moveZRR(Context* c, unsigned aSize, lir::Register* a, void moveZMR(Context* c, unsigned aSize UNUSED, lir::Memory* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, bSize == vm::TargetBytesPerWord); - assert(c, aSize == 2); + assertT(c, bSize == vm::TargetBytesPerWord); + assertT(c, aSize == 2); maybeRex(c, bSize, b, a); opcode(c, 0x0f, 0xb7); @@ -542,7 +542,7 @@ void moveZMR(Context* c, unsigned aSize UNUSED, lir::Memory* a, void addCarryRR(Context* c, unsigned size, lir::Register* a, lir::Register* b) { - assert(c, vm::TargetBytesPerWord == 8 or size == 4); + assertT(c, vm::TargetBytesPerWord == 8 or size == 4); maybeRex(c, size, a, b); opcode(c, 0x11); @@ -552,7 +552,7 @@ void addCarryRR(Context* c, unsigned size, lir::Register* a, void addRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (vm::TargetBytesPerWord == 4 and aSize == 8) { lir::Register ah(a->high); @@ -585,7 +585,7 @@ void addCarryCR(Context* c, unsigned size, lir::Constant* a, void addCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); int64_t v = a->value->value(); if (v) { @@ -624,7 +624,7 @@ void addCR(Context* c, unsigned aSize, lir::Constant* a, void subtractBorrowCR(Context* c, unsigned size UNUSED, lir::Constant* a, lir::Register* b) { - assert(c, vm::TargetBytesPerWord == 8 or size == 4); + assertT(c, vm::TargetBytesPerWord == 8 or size == 4); int64_t v = a->value->value(); if (vm::fitsInInt8(v)) { @@ -639,7 +639,7 @@ void subtractBorrowCR(Context* c, unsigned size UNUSED, lir::Constant* a, void subtractCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); int64_t v = a->value->value(); if (v) { @@ -678,7 +678,7 @@ void subtractCR(Context* c, unsigned aSize, lir::Constant* a, void subtractBorrowRR(Context* c, unsigned size, lir::Register* a, lir::Register* b) { - assert(c, vm::TargetBytesPerWord == 8 or size == 4); + assertT(c, vm::TargetBytesPerWord == 8 or size == 4); maybeRex(c, size, a, b); opcode(c, 0x19); @@ -688,7 +688,7 @@ void subtractBorrowRR(Context* c, unsigned size, lir::Register* a, void subtractRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (vm::TargetBytesPerWord == 4 and aSize == 8) { lir::Register ah(a->high); @@ -706,7 +706,7 @@ void subtractRR(Context* c, unsigned aSize, lir::Register* a, void andRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (vm::TargetBytesPerWord == 4 and aSize == 8) { @@ -725,7 +725,7 @@ void andRR(Context* c, unsigned aSize, lir::Register* a, void andCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); int64_t v = a->value->value(); @@ -763,7 +763,7 @@ void andCR(Context* c, unsigned aSize, lir::Constant* a, void orRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (vm::TargetBytesPerWord == 4 and aSize == 8) { lir::Register ah(a->high); @@ -781,7 +781,7 @@ void orRR(Context* c, unsigned aSize, lir::Register* a, void orCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); int64_t v = a->value->value(); if (v) { @@ -836,7 +836,7 @@ void xorRR(Context* c, unsigned aSize, lir::Register* a, void xorCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); int64_t v = a->value->value(); if (v) { @@ -875,14 +875,14 @@ void xorCR(Context* c, unsigned aSize, lir::Constant* a, void multiplyRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (vm::TargetBytesPerWord == 4 and aSize == 8) { - assert(c, b->high == rdx); - assert(c, b->low != rax); - assert(c, a->low != rax); - assert(c, a->high != rax); + assertT(c, b->high == rdx); + assertT(c, b->low != rax); + assertT(c, a->low != rax); + assertT(c, a->high != rax); c->client->save(rax); @@ -925,8 +925,8 @@ void multiplyRR(Context* c, unsigned aSize, lir::Register* a, void compareRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); - assert(c, aSize <= vm::TargetBytesPerWord); + assertT(c, aSize == bSize); + assertT(c, aSize <= vm::TargetBytesPerWord); maybeRex(c, aSize, a, b); opcode(c, 0x39); @@ -936,8 +936,8 @@ void compareRR(Context* c, unsigned aSize, lir::Register* a, void compareCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize == bSize); - assert(c, vm::TargetBytesPerWord == 8 or aSize == 4); + assertT(c, aSize == bSize); + assertT(c, vm::TargetBytesPerWord == 8 or aSize == 4); if (a->value->resolved() and vm::fitsInInt32(a->value->value())) { int64_t v = a->value->value(); @@ -960,8 +960,8 @@ void compareCR(Context* c, unsigned aSize, lir::Constant* a, void compareRM(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Memory* b) { - assert(c, aSize == bSize); - assert(c, vm::TargetBytesPerWord == 8 or aSize == 4); + assertT(c, aSize == bSize); + assertT(c, vm::TargetBytesPerWord == 8 or aSize == 4); if (vm::TargetBytesPerWord == 8 and aSize == 4) { moveRR(c, 4, a, 8, a); @@ -974,8 +974,8 @@ void compareRM(Context* c, unsigned aSize, lir::Register* a, void compareCM(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Memory* b) { - assert(c, aSize == bSize); - assert(c, vm::TargetBytesPerWord == 8 or aSize == 4); + assertT(c, aSize == bSize); + assertT(c, vm::TargetBytesPerWord == 8 or aSize == 4); if (a->value->resolved()) { int64_t v = a->value->value(); @@ -1001,7 +1001,7 @@ void compareCM(Context* c, unsigned aSize, lir::Constant* a, void compareFloatRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (aSize == 8) { opcode(c, 0x66); @@ -1113,7 +1113,7 @@ void branchCR(Context* c, lir::TernaryOperation op, unsigned size, lir::Constant* a, lir::Register* b, lir::Constant* target) { - assert(c, not isFloatBranch(op)); + assertT(c, not isFloatBranch(op)); if (size > vm::TargetBytesPerWord) { int64_t v = a->value->value(); @@ -1137,8 +1137,8 @@ void branchRM(Context* c, lir::TernaryOperation op, unsigned size, lir::Register* a, lir::Memory* b, lir::Constant* target) { - assert(c, not isFloatBranch(op)); - assert(c, size <= vm::TargetBytesPerWord); + assertT(c, not isFloatBranch(op)); + assertT(c, size <= vm::TargetBytesPerWord); compareRM(c, size, a, size, b); branch(c, op, target); @@ -1148,8 +1148,8 @@ void branchCM(Context* c, lir::TernaryOperation op, unsigned size, lir::Constant* a, lir::Memory* b, lir::Constant* target) { - assert(c, not isFloatBranch(op)); - assert(c, size <= vm::TargetBytesPerWord); + assertT(c, not isFloatBranch(op)); + assertT(c, size <= vm::TargetBytesPerWord); compareCM(c, size, a, size, b); branch(c, op, target); @@ -1158,7 +1158,7 @@ void branchCM(Context* c, lir::TernaryOperation op, unsigned size, void multiplyCR(Context* c, unsigned aSize, lir::Constant* a, unsigned bSize, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); if (vm::TargetBytesPerWord == 4 and aSize == 8) { const uint32_t mask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx)); @@ -1197,10 +1197,10 @@ void multiplyCR(Context* c, unsigned aSize, lir::Constant* a, void divideRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b UNUSED) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); - assert(c, b->low == rax); - assert(c, a->low != rdx); + assertT(c, b->low == rax); + assertT(c, a->low != rdx); c->client->save(rdx); @@ -1213,10 +1213,10 @@ void divideRR(Context* c, unsigned aSize, lir::Register* a, void remainderRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, aSize == bSize); + assertT(c, aSize == bSize); - assert(c, b->low == rax); - assert(c, a->low != rdx); + assertT(c, b->low == rax); + assertT(c, a->low != rdx); c->client->save(rdx); @@ -1290,7 +1290,7 @@ void shiftLeftRR(Context* c, UNUSED unsigned aSize, lir::Register* a, moveRR(c, 4, b, 4, &bh); // 2 bytes xorRR(c, 4, b, 4, b); // 2 bytes } else { - assert(c, a->low == rcx); + assertT(c, a->low == rcx); maybeRex(c, bSize, a, b); opcode(c, 0xd3, 0xe0 + regCode(b)); @@ -1338,7 +1338,7 @@ void shiftRightRR(Context* c, UNUSED unsigned aSize, lir::Register* a, opcode(c, 0xc1, 0xf8 + b->high); c->code.append(31); } else { - assert(c, a->low == rcx); + assertT(c, a->low == rcx); maybeRex(c, bSize, a, b); opcode(c, 0xd3, 0xf8 + regCode(b)); @@ -1383,7 +1383,7 @@ void unsignedShiftRightRR(Context* c, UNUSED unsigned aSize, lir::Register* a, moveRR(c, 4, &bh, 4, b); // 2 bytes xorRR(c, 4, &bh, 4, &bh); // 2 bytes } else { - assert(c, a->low == rcx); + assertT(c, a->low == rcx); maybeRex(c, bSize, a, b); opcode(c, 0xd3, 0xe8 + regCode(b)); @@ -1471,7 +1471,7 @@ void float2FloatMR(Context* c, unsigned aSize, lir::Memory* a, void float2IntRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize, lir::Register* b) { - assert(c, not isFloatReg(b)); + assertT(c, not isFloatReg(b)); floatRegOp(c, aSize, a, bSize, b, 0x2c); } @@ -1496,10 +1496,10 @@ void int2FloatMR(Context* c, unsigned aSize, lir::Memory* a, void floatNegateRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, isFloatReg(a) and isFloatReg(b)); + assertT(c, isFloatReg(a) and isFloatReg(b)); // unlike most of the other floating point code, this does NOT // support doubles: - assert(c, aSize == 4); + assertT(c, aSize == 4); ResolvedPromise pcon(0x80000000); lir::Constant con(&pcon); if (a->low == b->low) { @@ -1521,10 +1521,10 @@ void floatNegateRR(Context* c, unsigned aSize, lir::Register* a, void floatAbsoluteRR(Context* c, unsigned aSize UNUSED, lir::Register* a, unsigned bSize UNUSED, lir::Register* b) { - assert(c, isFloatReg(a) and isFloatReg(b)); + assertT(c, isFloatReg(a) and isFloatReg(b)); // unlike most of the other floating point code, this does NOT // support doubles: - assert(c, aSize == 4); + assertT(c, aSize == 4); ResolvedPromise pcon(0x7fffffff); lir::Constant con(&pcon); if (a->low == b->low) { @@ -1545,7 +1545,7 @@ void floatAbsoluteRR(Context* c, unsigned aSize UNUSED, lir::Register* a, void absoluteRR(Context* c, unsigned aSize, lir::Register* a, unsigned bSize UNUSED, lir::Register* b UNUSED) { - assert(c, aSize == bSize and a->low == rax and b->low == rax); + assertT(c, aSize == bSize and a->low == rax and b->low == rax); lir::Register d (c->client->acquireTemporary(static_cast(1) << rdx)); maybeRex(c, aSize, a, b); diff --git a/src/compile.cpp b/src/compile.cpp index 578af74148..afdf3c5946 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -135,7 +135,7 @@ class MyThread: public Thread { } ~CallTrace() { - assert(t, t->stack == 0); + assertT(t, t->stack == 0); t->scratch = scratch; @@ -225,7 +225,7 @@ class MyThread: public Thread { // interrupt us at any time and still get a consistent, accurate // stack trace. See MyProcessor::getStackTrace for details. - assert(t, t->transition == 0); + assertT(t, t->transition == 0); Context c(t, ip, stack, continuation, trace); @@ -710,7 +710,7 @@ localOffset(MyThread* t, int v, GcMethod* method) + parameterFootprint - v - 1)); - assert(t, offset >= 0); + assertT(t, offset >= 0); return offset; } @@ -746,7 +746,7 @@ class PoolElement: public avian::codegen::Promise { { } virtual int64_t value() { - assert(t, resolved()); + assertT(t, resolved()); return address; } @@ -837,7 +837,7 @@ class TraceElementPromise: public avian::codegen::Promise { TraceElementPromise(System* s, TraceElement* trace): s(s), trace(trace) { } virtual int64_t value() { - assert(s, resolved()); + assertT(s, resolved()); return trace->address->value(); } @@ -960,26 +960,26 @@ class Context { if (size == 8) { switch(op) { case avian::codegen::lir::Absolute: - assert(t, resultSize == 8); + assertT(t, resultSize == 8); return local::getThunk(t, absoluteLongThunk); case avian::codegen::lir::FloatNegate: - assert(t, resultSize == 8); + assertT(t, resultSize == 8); return local::getThunk(t, negateDoubleThunk); case avian::codegen::lir::FloatSquareRoot: - assert(t, resultSize == 8); + assertT(t, resultSize == 8); return local::getThunk(t, squareRootDoubleThunk); case avian::codegen::lir::Float2Float: - assert(t, resultSize == 4); + assertT(t, resultSize == 4); return local::getThunk(t, doubleToFloatThunk); case avian::codegen::lir::Float2Int: if (resultSize == 8) { return local::getThunk(t, doubleToLongThunk); } else { - assert(t, resultSize == 4); + assertT(t, resultSize == 4); return local::getThunk(t, doubleToIntThunk); } @@ -987,37 +987,37 @@ class Context { if (resultSize == 8) { return local::getThunk(t, longToDoubleThunk); } else { - assert(t, resultSize == 4); + assertT(t, resultSize == 4); return local::getThunk(t, longToFloatThunk); } default: abort(t); } } else { - assert(t, size == 4); + assertT(t, size == 4); switch(op) { case avian::codegen::lir::Absolute: - assert(t, resultSize == 4); + assertT(t, resultSize == 4); return local::getThunk(t, absoluteIntThunk); case avian::codegen::lir::FloatNegate: - assert(t, resultSize == 4); + assertT(t, resultSize == 4); return local::getThunk(t, negateFloatThunk); case avian::codegen::lir::FloatAbsolute: - assert(t, resultSize == 4); + assertT(t, resultSize == 4); return local::getThunk(t, absoluteFloatThunk); case avian::codegen::lir::Float2Float: - assert(t, resultSize == 8); + assertT(t, resultSize == 8); return local::getThunk(t, floatToDoubleThunk); case avian::codegen::lir::Float2Int: if (resultSize == 4) { return local::getThunk(t, floatToIntThunk); } else { - assert(t, resultSize == 8); + assertT(t, resultSize == 8); return local::getThunk(t, floatToLongThunk); } @@ -1025,7 +1025,7 @@ class Context { if (resultSize == 4) { return local::getThunk(t, intToFloatThunk); } else { - assert(t, resultSize == 8); + assertT(t, resultSize == 8); return local::getThunk(t, intToDoubleThunk); } @@ -1081,7 +1081,7 @@ class Context { default: abort(t); } } else { - assert(t, size == 4); + assertT(t, size == 4); switch (op) { case avian::codegen::lir::Divide: *threadParameter = true; @@ -1268,7 +1268,7 @@ ir::Value* loadLocal(Context* context, ir::Value* result = context->compiler->loadLocal( type, translateLocalIndex(context, footprint, index)); - assert(context->thread, type == result->type); + assertT(context->thread, type == result->type); return result; } @@ -1278,7 +1278,7 @@ void storeLocal(Context* context, ir::Value* value, unsigned index) { - assert(context->thread, type == value->type); + assertT(context->thread, type == value->type); context->compiler->storeLocal(value, translateLocalIndex(context, footprint, index)); } @@ -1432,7 +1432,7 @@ class Frame { void set(unsigned index, ir::Type type) { - assert(t, index < frameSize()); + assertT(t, index < frameSize()); if (type == ir::Type::object()) { context->eventLog.append(MarkEvent); @@ -1450,15 +1450,15 @@ class Frame { ir::Type get(unsigned index) { - assert(t, index < frameSize()); + assertT(t, index < frameSize()); int si = index - localSize(); - assert(t, si >= 0); + assertT(t, si >= 0); return stackMap[si]; } void popped(unsigned count) { - assert(t, sp >= count); - assert(t, sp - count >= localSize()); + assertT(t, sp >= count); + assertT(t, sp - count >= localSize()); while (count) { set(--sp, ir::Type::i4()); -- count; @@ -1539,24 +1539,24 @@ class Frame { void push(ir::Type type, ir::Value* o) { - assert(t, type == o->type); + assertT(t, type == o->type); c->push(o->type, o); - assert(t, sp + 1 <= frameSize()); + assertT(t, sp + 1 <= frameSize()); set(sp++, type); } void pushObject() { c->pushed(ir::Type::object()); - assert(t, sp + 1 <= frameSize()); + assertT(t, sp + 1 <= frameSize()); set(sp++, ir::Type::object()); } void pushLarge(ir::Type type, ir::Value* o) { - assert(t, o->type == type); + assertT(t, o->type == type); c->push(type, o); - assert(t, sp + 2 <= frameSize()); + assertT(t, sp + 2 <= frameSize()); set(sp++, type); set(sp++, type); } @@ -1569,49 +1569,49 @@ class Frame { ir::Value* pop(ir::Type type) { - assert(t, sp >= 1); - assert(t, sp - 1 >= localSize()); - assert(t, get(sp - 1) == type); + assertT(t, sp >= 1); + assertT(t, sp - 1 >= localSize()); + assertT(t, get(sp - 1) == type); set(--sp, ir::Type::i4()); return c->pop(type); } ir::Value* popLarge(ir::Type type) { - assert(t, sp >= 1); - assert(t, sp - 2 >= localSize()); - assert(t, get(sp - 1) == type); - assert(t, get(sp - 2) == type); + assertT(t, sp >= 1); + assertT(t, sp - 2 >= localSize()); + assertT(t, get(sp - 1) == type); + assertT(t, get(sp - 2) == type); sp -= 2; return c->pop(type); } void load(ir::Type type, unsigned index) { - assert(t, index < localSize()); + assertT(t, index < localSize()); push(type, loadLocal(context, 1, type, index)); } void loadLarge(ir::Type type, unsigned index) { - assert(t, index < static_cast(localSize() - 1)); + assertT(t, index < static_cast(localSize() - 1)); pushLarge(type, loadLocal(context, 2, type, index)); } void store(ir::Type type, unsigned index) { - assert(t, + assertT(t, type == ir::Type::i4() || type == ir::Type::f4() || type == ir::Type::object()); storeLocal(context, 1, type, pop(type), index); unsigned ti = translateLocalIndex(context, 1, index); - assert(t, ti < localSize()); + assertT(t, ti < localSize()); set(ti, type); } void storeLarge(ir::Type type, unsigned index) { storeLocal(context, 2, type, popLarge(type), index); unsigned ti = translateLocalIndex(context, 2, index); - assert(t, ti + 1 < localSize()); + assertT(t, ti + 1 < localSize()); set(ti, type); set(ti + 1, type); } @@ -1619,8 +1619,8 @@ class Frame { void dup() { c->push(ir::Type::i4(), c->peek(1, 0)); - assert(t, sp + 1 <= frameSize()); - assert(t, sp - 1 >= localSize()); + assertT(t, sp + 1 <= frameSize()); + assertT(t, sp - 1 >= localSize()); set(sp, get(sp - 1)); ++ sp; } @@ -1633,8 +1633,8 @@ class Frame { c->push(ir::Type::i4(), s1); c->push(ir::Type::i4(), s0); - assert(t, sp + 1 <= frameSize()); - assert(t, sp - 2 >= localSize()); + assertT(t, sp + 1 <= frameSize()); + assertT(t, sp - 2 >= localSize()); ir::Type b2 = get(sp - 2); ir::Type b1 = get(sp - 1); @@ -1665,8 +1665,8 @@ class Frame { c->push(ir::Type::i4(), s0); } - assert(t, sp + 1 <= frameSize()); - assert(t, sp - 3 >= localSize()); + assertT(t, sp + 1 <= frameSize()); + assertT(t, sp - 3 >= localSize()); ir::Type b3 = get(sp - 3); ir::Type b2 = get(sp - 2); @@ -1693,8 +1693,8 @@ class Frame { c->push(ir::Type::i4(), s0); } - assert(t, sp + 2 <= frameSize()); - assert(t, sp - 2 >= localSize()); + assertT(t, sp + 2 <= frameSize()); + assertT(t, sp - 2 >= localSize()); ir::Type b2 = get(sp - 2); ir::Type b1 = get(sp - 1); @@ -1725,8 +1725,8 @@ class Frame { c->push(ir::Type::i4(), s0); } - assert(t, sp + 2 <= frameSize()); - assert(t, sp - 3 >= localSize()); + assertT(t, sp + 2 <= frameSize()); + assertT(t, sp - 3 >= localSize()); ir::Type b3 = get(sp - 3); ir::Type b2 = get(sp - 2); @@ -1774,8 +1774,8 @@ class Frame { c->push(ir::Type::i4(), s0); } - assert(t, sp + 2 <= frameSize()); - assert(t, sp - 4 >= localSize()); + assertT(t, sp + 2 <= frameSize()); + assertT(t, sp - 4 >= localSize()); ir::Type b4 = get(sp - 4); ir::Type b3 = get(sp - 3); @@ -1799,7 +1799,7 @@ class Frame { c->push(ir::Type::i4(), s0); c->push(ir::Type::i4(), s1); - assert(t, sp - 2 >= localSize()); + assertT(t, sp - 2 >= localSize()); ir::Type saved = get(sp - 1); @@ -3028,7 +3028,7 @@ useLongJump(MyThread* t, uintptr_t target) uintptr_t start = reinterpret_cast(a->memory.begin()); uintptr_t end = reinterpret_cast(a->memory.begin()) + a->memory.count; - assert(t, end - start < reach); + assertT(t, end - start < reach); return (target > end && (target - start) > reach) or (target < start && (end - target) > reach); @@ -3315,7 +3315,7 @@ returnsNext(MyThread* t, object code, unsigned ip) case goto_: { uint32_t offset = codeReadInt16(t, code, ++ip); uint32_t newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); return returnsNext(t, code, newIp); } @@ -3323,7 +3323,7 @@ returnsNext(MyThread* t, object code, unsigned ip) case goto_w: { uint32_t offset = codeReadInt32(t, code, ++ip); uint32_t newIp = (ip - 5) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); return returnsNext(t, code, newIp); } @@ -3417,7 +3417,7 @@ bool integerBranch(MyThread* t, unsigned instruction = codeBody(t, code, ip++); uint32_t offset = codeReadInt16(t, code, ip); uint32_t newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); ir::Value* target = frame->machineIpValue(newIp); @@ -3495,7 +3495,7 @@ bool floatBranch(MyThread* t, unsigned instruction = codeBody(t, code, ip++); uint32_t offset = codeReadInt16(t, code, ip); uint32_t newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); ir::Value* target = frame->machineIpValue(newIp); @@ -4611,7 +4611,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case goto_: { uint32_t offset = codeReadInt16(t, code, ip); uint32_t newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); if(newIp <= ip) { compileSafePoint(t, c, frame); @@ -4624,7 +4624,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case goto_w: { uint32_t offset = codeReadInt32(t, code, ip); uint32_t newIp = (ip - 5) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); if(newIp <= ip) { compileSafePoint(t, c, frame); @@ -4738,7 +4738,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case if_acmpne: { uint32_t offset = codeReadInt16(t, code, ip); newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); if(newIp <= ip) { compileSafePoint(t, c, frame); @@ -4759,7 +4759,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case if_icmple: { uint32_t offset = codeReadInt16(t, code, ip); newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); if(newIp <= ip) { compileSafePoint(t, c, frame); @@ -4780,7 +4780,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case ifle: { uint32_t offset = codeReadInt16(t, code, ip); newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); ir::Value* target = frame->machineIpValue(newIp); @@ -4798,7 +4798,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case ifnonnull: { uint32_t offset = codeReadInt16(t, code, ip); newIp = (ip - 3) + offset; - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); if(newIp <= ip) { compileSafePoint(t, c, frame); @@ -5161,7 +5161,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, newIp = thisIp + offset; } - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); frame->startSubroutine(newIp, ip); @@ -5365,7 +5365,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, ir::Value* key = frame->pop(ir::Type::i4()); uint32_t defaultIp = base + codeReadInt32(t, code, ip); - assert(t, defaultIp < codeLength(t, code)); + assertT(t, defaultIp < codeLength(t, code)); int32_t pairCount = codeReadInt32(t, code, ip); @@ -5380,7 +5380,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, unsigned index = ip + (i * 8); int32_t key = codeReadInt32(t, code, index); uint32_t newIp = base + codeReadInt32(t, code, index); - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); ipTable[i] = newIp; @@ -5390,7 +5390,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, } c->poolAppendPromise(frame->addressPromise(frame->machineIp(newIp))); } - assert(t, start); + assertT(t, start); ir::Value* address = c->call( c->constant(getThunk(t, lookUpAddressThunk), ir::Type::iptr()), @@ -5925,7 +5925,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, ip = (ip + 3) & ~3; // pad to four byte boundary uint32_t defaultIp = base + codeReadInt32(t, code, ip); - assert(t, defaultIp < codeLength(t, code)); + assertT(t, defaultIp < codeLength(t, code)); int32_t bottom = codeReadInt32(t, code, ip); int32_t top = codeReadInt32(t, code, ip); @@ -5937,7 +5937,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, for (int32_t i = 0; i < top - bottom + 1; ++i) { unsigned index = ip + (i * 4); uint32_t newIp = base + codeReadInt32(t, code, index); - assert(t, newIp < codeLength(t, code)); + assertT(t, newIp < codeLength(t, code)); ipTable[i] = newIp; @@ -5947,7 +5947,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, start = p; } } - assert(t, start); + assertT(t, start); ir::Value* key = frame->pop(ir::Type::i4()); @@ -6280,7 +6280,7 @@ object translateExceptionHandlerTable(MyThread* t, duplicatedBaseIp + exceptionHandlerEnd(oldHandler)); if (LIKELY(handlerStart >= 0)) { - assert( + assertT( t, handlerStart < static_cast(codeLength(t, context->method->code()) @@ -6291,8 +6291,8 @@ object translateExceptionHandlerTable(MyThread* t, duplicatedBaseIp + exceptionHandlerEnd(oldHandler), duplicatedBaseIp + exceptionHandlerStart(oldHandler)); - assert(t, handlerEnd >= 0); - assert(t, + assertT(t, handlerEnd >= 0); + assertT(t, handlerEnd <= static_cast( codeLength(t, context->method->code()) * (context->subroutineCount + 1))); @@ -6486,7 +6486,7 @@ unsigned calculateFrameMaps(MyThread* t, fprintf(stderr, "\n"); } - assert(context->thread, ip * mapSize <= context->rootTable.count); + assertT(context->thread, ip * mapSize <= context->rootTable.count); uintptr_t* tableRoots = context->rootTable.begin() + (ip * mapSize); if (context->visitTable[ip] > 1) { @@ -6718,7 +6718,7 @@ makeSimpleFrameMapTable(MyThread* t, Context* context, uint8_t* start, object table = reinterpret_cast(makeIntArray (t, elementCount + ceilingDivide(elementCount * mapSize, 32))); - assert(t, intArrayLength(t, table) == elementCount + assertT(t, intArrayLength(t, table) == elementCount + simpleFrameMapTableSize(t, context->method, table)); for (unsigned i = 0; i < elementCount; ++i) { @@ -6727,7 +6727,7 @@ makeSimpleFrameMapTable(MyThread* t, Context* context, uint8_t* start, intArrayBody(t, table, i) = static_cast(p->address->value()) - reinterpret_cast(start); - assert(t, elementCount + ceilingDivide((i + 1) * mapSize, 32) + assertT(t, elementCount + ceilingDivide((i + 1) * mapSize, 32) <= intArrayLength(t, table)); if (mapSize) { @@ -6857,7 +6857,7 @@ finish(MyThread* t, FixedAllocator* allocator, Context* context) // unsigned pathFootprint = 0; // unsigned mapCount = 0; for (TraceElement* p = context->traceLog; p; p = p->next) { - assert(t, index < context->traceLogCount); + assertT(t, index < context->traceLogCount); if (p->address) { @@ -7325,7 +7325,7 @@ invokeNative(MyThread* t) t->trace->nativeMethod = target; } - assert(t, t->tailAddress == 0); + assertT(t, t->tailAddress == 0); uint64_t result = 0; @@ -7609,7 +7609,7 @@ void callContinuation(MyThread* t, object continuation, object result, object exception, void* ip, void* stack) { - assert(t, t->exception == 0); + assertT(t, t->exception == 0); if (exception) { t->exception = exception; @@ -7651,8 +7651,8 @@ returnClass(MyThread* t, GcMethod* method) name = reinterpret_cast(makeByteArray(t, length + 1)); memcpy(&byteArrayBody(t, name, 0), spec, length); } else { - assert(t, *spec == 'L'); - assert(t, spec[length - 1] == ';'); + assertT(t, *spec == 'L'); + assertT(t, spec[length - 1] == ';'); name = reinterpret_cast(makeByteArray(t, length - 1)); memcpy(&byteArrayBody(t, name, 0), spec + 1, length - 2); } @@ -7703,7 +7703,7 @@ jumpAndInvoke(MyThread* t, GcMethod* method, void* stack, ...) } va_end(a); - assert(t, t->exception == 0); + assertT(t, t->exception == 0); popResources(t); @@ -8030,7 +8030,7 @@ class ArgumentList { } void addObject(object v) { - assert(t, position < size); + assertT(t, position < size); array[position] = reinterpret_cast(v); objectMask[position] = true; @@ -8038,7 +8038,7 @@ class ArgumentList { } void addInt(uintptr_t v) { - assert(t, position < size); + assertT(t, position < size); array[position] = v; objectMask[position] = false; @@ -8046,7 +8046,7 @@ class ArgumentList { } void addLong(uint64_t v) { - assert(t, position < size - 1); + assertT(t, position < size - 1); memcpy(array + position, &v, 8); @@ -8114,7 +8114,7 @@ invoke(Thread* thread, GcMethod* method, ArgumentList* arguments) MyCheckpoint checkpoint(t); - assert(t, arguments->position == arguments->size); + assertT(t, arguments->position == arguments->size); result = vmInvoke (t, reinterpret_cast(methodAddress(t, method)), @@ -8616,12 +8616,12 @@ class MyProcessor: public Processor { virtual object invokeArray(Thread* t, GcMethod* method, object this_, object arguments) { - assert(t, t->exception == 0); + assertT(t, t->exception == 0); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); method = findMethod(t, method, this_); @@ -8646,12 +8646,12 @@ class MyProcessor: public Processor { virtual object invokeArray(Thread* t, GcMethod* method, object this_, const jvalue* arguments) { - assert(t, t->exception == 0); + assertT(t, t->exception == 0); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); method = findMethod(t, method, this_); @@ -8677,12 +8677,12 @@ class MyProcessor: public Processor { invokeList(Thread* t, GcMethod* method, object this_, bool indirectObjects, va_list arguments) { - assert(t, t->exception == 0); + assertT(t, t->exception == 0); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); method = findMethod(t, method, this_); @@ -8709,9 +8709,9 @@ class MyProcessor: public Processor { const char* methodName, const char* methodSpec, object this_, va_list arguments) { - assert(t, t->exception == 0); + assertT(t, t->exception == 0); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); unsigned size = parameterFootprint(t, methodSpec, this_ == 0); @@ -8724,7 +8724,7 @@ class MyProcessor: public Processor { GcMethod* method = resolveMethod (t, loader, className, methodName, methodSpec); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); PROTECT(t, method); @@ -9398,7 +9398,7 @@ fixupHeap(MyThread* t UNUSED, uintptr_t* map, unsigned size, uintptr_t* heap) unsigned index = indexOf(word, bit); uintptr_t* p = heap + index; - assert(t, *p); + assertT(t, *p); uintptr_t number = *p & BootMask; uintptr_t mark = *p >> BootShift; @@ -9472,7 +9472,7 @@ fixupMethods(Thread* t, GcHashMap* map, BootImage* image UNUSED, uint8_t* code) for (unsigned i = 0; i < arrayLength(t, classMethodTable(t, c)); ++i) { GcMethod* method = cast(t, arrayBody(t, classMethodTable(t, c), i)); if (method->code()) { - assert(t, methodCompiled(t, method) + assertT(t, methodCompiled(t, method) <= static_cast(image->codeSize)); codeCompiled(t, method->code()) @@ -9536,7 +9536,7 @@ fixupVirtualThunks(MyThread* t, uint8_t* code) void boot(MyThread* t, BootImage* image, uint8_t* code) { - assert(t, image->magic == BootImage::Magic); + assertT(t, image->magic == BootImage::Magic); unsigned* bootClassTable = reinterpret_cast(image + 1); unsigned* appClassTable = bootClassTable + image->bootClassCount; @@ -10014,7 +10014,7 @@ compile(MyThread* t, FixedAllocator* allocator, BootContext* bootContext, return; } - assert(t, (method->flags() & ACC_NATIVE) == 0); + assertT(t, (method->flags() & ACC_NATIVE) == 0); // We must avoid acquiring any locks until after the first pass of // compilation, since this pass may trigger classloading operations diff --git a/src/heap/heap.cpp b/src/heap/heap.cpp index fa11086b65..ebdd8cb0b3 100644 --- a/src/heap/heap.cpp +++ b/src/heap/heap.cpp @@ -115,9 +115,9 @@ class Segment { Iterator(Map* map, unsigned start, unsigned end): map(map) { - assert(map->segment->context, map->bitsPerRecord == 1); - assert(map->segment->context, map->segment); - assert(map->segment->context, start <= map->segment->position()); + assertT(map->segment->context, map->bitsPerRecord == 1); + assertT(map->segment->context, map->segment); + assertT(map->segment->context, start <= map->segment->position()); if (end > map->segment->position()) end = map->segment->position(); @@ -159,8 +159,8 @@ class Segment { } unsigned next() { - assert(map->segment->context, hasMore()); - assert(map->segment->context, map->segment); + assertT(map->segment->context, hasMore()); + assertT(map->segment->context, map->segment); return (index++) * map->scale; } @@ -194,9 +194,9 @@ class Segment { { } void init() { - assert(segment->context, bitsPerRecord); - assert(segment->context, scale); - assert(segment->context, powerOfTwo(scale)); + assertT(segment->context, bitsPerRecord); + assertT(segment->context, scale); + assertT(segment->context, powerOfTwo(scale)); if (data == 0) { data = segment->data + segment->capacity() @@ -223,7 +223,7 @@ class Segment { { unsigned result = ceilingDivide(ceilingDivide(capacity, scale) * bitsPerRecord, BitsPerWord); - assert(c, result); + assertT(c, result); return result; } @@ -242,8 +242,8 @@ class Segment { } void replaceWith(Map* m) { - assert(segment->context, bitsPerRecord == m->bitsPerRecord); - assert(segment->context, scale == m->scale); + assertT(segment->context, bitsPerRecord == m->bitsPerRecord); + assertT(segment->context, scale == m->scale); data = m->data; @@ -258,19 +258,19 @@ class Segment { } unsigned indexOf(void* p) { - assert(segment->context, segment->almostContains(p)); - assert(segment->context, segment->capacity()); + assertT(segment->context, segment->almostContains(p)); + assertT(segment->context, segment->capacity()); return indexOf(segment->indexOf(p)); } void clearBit(unsigned i) { - assert(segment->context, wordOf(i) < size()); + assertT(segment->context, wordOf(i) < size()); vm::clearBit(data, i); } void setBit(unsigned i) { - assert(segment->context, wordOf(i) < size()); + assertT(segment->context, wordOf(i) < size()); vm::markBit(data, i); } @@ -306,15 +306,15 @@ class Segment { void set(void* p, unsigned v = 1) { setOnly(p, v); - assert(segment->context, get(p) == v); + assertT(segment->context, get(p) == v); if (child) child->set(p, v); } #ifdef USE_ATOMIC_OPERATIONS void markAtomic(void* p) { - assert(segment->context, bitsPerRecord == 1); + assertT(segment->context, bitsPerRecord == 1); markBitAtomic(data, indexOf(p)); - assert(segment->context, getBit(data, indexOf(p))); + assertT(segment->context, getBit(data, indexOf(p))); if (child) child->markAtomic(p); } #endif @@ -343,7 +343,7 @@ class Segment { minimum = 1; } - assert(context, desired >= minimum); + assertT(context, desired >= minimum); capacity_ = desired; @@ -453,7 +453,7 @@ class Segment { abort(context); } } else { - assert(context, map == 0); + assertT(context, map == 0); } } @@ -466,18 +466,18 @@ class Segment { } void* get(unsigned offset) { - assert(context, offset <= position()); + assertT(context, offset <= position()); return data + offset; } unsigned indexOf(void* p) { - assert(context, almostContains(p)); + assertT(context, almostContains(p)); return static_cast(p) - data; } void* allocate(unsigned size) { - assert(context, size); - assert(context, position() + size <= capacity()); + assertT(context, size); + assertT(context, position() + size <= capacity()); void* p = data + position(); position_ += size; @@ -520,8 +520,8 @@ class Fixie { } void add(Context* c UNUSED, Fixie** handle) { - assert(c, this->handle == 0); - assert(c, next == 0); + assertT(c, this->handle == 0); + assertT(c, next == 0); this->handle = handle; if (handle) { @@ -535,7 +535,7 @@ class Fixie { void remove(Context* c UNUSED) { if (handle) { - assert(c, *handle == this); + assertT(c, *handle == this); *handle = next; } if (next) { @@ -878,21 +878,21 @@ wasCollected(Context* c, void* o) inline void* follow(Context* c UNUSED, void* o) { - assert(c, wasCollected(c, o)); + assertT(c, wasCollected(c, o)); return fieldAtOffset(o, 0); } inline void*& parent(Context* c UNUSED, void* o) { - assert(c, wasCollected(c, o)); + assertT(c, wasCollected(c, o)); return fieldAtOffset(o, BytesPerWord); } inline uintptr_t* bitset(Context* c UNUSED, void* o) { - assert(c, wasCollected(c, o)); + assertT(c, wasCollected(c, o)); return &fieldAtOffset(o, BytesPerWord * 2); } @@ -939,7 +939,7 @@ kill(Fixie* fixies) void killFixies(Context* c) { - assert(c, c->markedFixies == 0); + assertT(c, c->markedFixies == 0); if (c->mode == Heap::MajorCollection) { kill(c->tenuredFixies); @@ -951,7 +951,7 @@ killFixies(Context* c) void sweepFixies(Context* c) { - assert(c, c->markedFixies == 0); + assertT(c, c->markedFixies == 0); if (c->mode == Heap::MajorCollection) { free(c, &(c->tenuredFixies)); @@ -1007,7 +1007,7 @@ sweepFixies(Context* c) inline void* copyTo(Context* c, Segment* s, void* o, unsigned size) { - assert(c, s->remaining() >= size); + assertT(c, s->remaining() >= size); void* dst = s->allocate(size); c->client->copy(o, dst); return dst; @@ -1025,14 +1025,14 @@ copy2(Context* c, void* o) unsigned size = c->client->copiedSizeInWords(o); if (c->gen2.contains(o)) { - assert(c, c->mode == Heap::MajorCollection); + assertT(c, c->mode == Heap::MajorCollection); return copyTo(c, &(c->nextGen2), o, size); } else if (c->gen1.contains(o)) { unsigned age = c->ageMap.get(o); if (age == TenureThreshold) { if (c->mode == Heap::MinorCollection) { - assert(c, c->gen2.remaining() >= size); + assertT(c, c->gen2.remaining() >= size); if (c->gen2Base == Top) { c->gen2Base = c->gen2.position(); @@ -1053,9 +1053,9 @@ copy2(Context* c, void* o) return o; } } else { - assert(c, not c->nextGen1.contains(o)); - assert(c, not c->nextGen2.contains(o)); - assert(c, not immortalHeapContains(c, o)); + assertT(c, not c->nextGen1.contains(o)); + assertT(c, not c->nextGen2.contains(o)); + assertT(c, not immortalHeapContains(c, o)); o = copyTo(c, &(c->nextGen1), o, size); @@ -1171,7 +1171,7 @@ updateHeapMap(Context* c, void* p, void* target, unsigned offset, void* result) { if (target and c->client->isFixed(target)) { Fixie* f = fixie(target); - assert(c, offset == 0 or f->hasMask()); + assertT(c, offset == 0 or f->hasMask()); if (static_cast(f->age + 1) >= FixieTenureThreshold) { if (DebugFixies) { @@ -1280,7 +1280,7 @@ unsigned bitsetNext(Context* c, uintptr_t* p) { bool more UNUSED = bitsetHasMore(p); - assert(c, more); + assertT(c, more); switch (*p) { case 0: abort(c); @@ -1288,7 +1288,7 @@ bitsetNext(Context* c, uintptr_t* p) case BitsetExtensionBit: { uintptr_t i = p[1]; uintptr_t word = wordOf(i); - assert(c, word < p[2]); + assertT(c, word < p[2]); for (uintptr_t bit = bitOf(i); bit < BitsPerWord; ++bit) { if (p[word + 3] & (static_cast(1) << bit)) { p[1] = indexOf(word, bit) + 1; @@ -1477,7 +1477,7 @@ collect(Context* c, void** p, void* target, unsigned offset) c->client->walk(copy, &walker); - assert(c, walker.total > 1); + assertT(c, walker.total > 1); if (walker.total == 3 and bitsetHasMore(bitset(c, original))) { parent_ = original; @@ -1568,7 +1568,7 @@ visitDirtyFixies(Context* c, Fixie** p) fprintf(stderr, "done cleaning fixie %p\n", f); } - assert(c, wasDirty); + assertT(c, wasDirty); if (clean) { markClean(c, f); @@ -1618,7 +1618,7 @@ collect(Context* c, Segment::Map* map, unsigned start, unsigned end, for (Segment::Map::Iterator it(map, start, end); it.hasMore();) { wasDirty = true; if (map->child) { - assert(c, map->scale > 1); + assertT(c, map->scale > 1); unsigned s = it.next(); unsigned e = s + map->scale; @@ -1630,7 +1630,7 @@ collect(Context* c, Segment::Map* map, unsigned start, unsigned end, *dirty = true; } } else { - assert(c, map->scale == 1); + assertT(c, map->scale == 1); void** p = reinterpret_cast(map->segment->get(it.next())); map->clearOnly(p); @@ -1648,7 +1648,7 @@ collect(Context* c, Segment::Map* map, unsigned start, unsigned end, } } - assert(c, wasDirty or not expectDirty); + assertT(c, wasDirty or not expectDirty); } void @@ -1879,7 +1879,7 @@ class MyHeap: public Heap { { } virtual void setClient(Heap::Client* client) { - assert(&c, c.client == 0); + assertT(&c, c.client == 0); c.client = client; } @@ -1954,7 +1954,7 @@ class MyHeap: public Heap { } bool needsMark(void* p) { - assert(&c, c.client->isFixed(p) or (not immortalHeapContains(&c, p))); + assertT(&c, c.client->isFixed(p) or (not immortalHeapContains(&c, p))); if (c.client->isFixed(p)) { return fixie(p)->age >= FixieTenureThreshold; @@ -1980,7 +1980,7 @@ class MyHeap: public Heap { if (c.client->isFixed(p)) { Fixie* f = fixie(p); - assert(&c, offset == 0 or f->hasMask()); + assertT(&c, offset == 0 or f->hasMask()); bool dirty = false; for (unsigned i = 0; i < count; ++i) { @@ -1997,7 +1997,7 @@ class MyHeap: public Heap { #else markBit(f->mask(), offset + i); #endif - assert(&c, getBit(f->mask(), offset + i)); + assertT(&c, getBit(f->mask(), offset + i)); } } @@ -2007,7 +2007,7 @@ class MyHeap: public Heap { if (c.gen2.contains(p)) { map = &(c.heapMap); } else { - assert(&c, c.nextGen2.contains(p)); + assertT(&c, c.nextGen2.contains(p)); map = &(c.nextHeapMap); } @@ -2097,7 +2097,7 @@ class MyHeap: public Heap { virtual void dispose() { c.dispose(); - assert(&c, c.count == 0); + assertT(&c, c.count == 0); c.system->free(this); } diff --git a/src/heapwalk.cpp b/src/heapwalk.cpp index d40f568104..b086245ab9 100644 --- a/src/heapwalk.cpp +++ b/src/heapwalk.cpp @@ -176,7 +176,7 @@ Set::dispose() Set::Entry* add(Context* c UNUSED, Set* set, object p, uint32_t number) { - assert(c->thread, set->size < set->capacity); + assertT(c->thread, set->size < set->capacity); unsigned index = hash(p, set->capacity); diff --git a/src/interpret.cpp b/src/interpret.cpp index 7c8a9b076c..f236848149 100644 --- a/src/interpret.cpp +++ b/src/interpret.cpp @@ -59,7 +59,7 @@ pushObject(Thread* t, object o) fprintf(stderr, "push object %p at %d\n", o, t->sp); } - assert(t, t->sp + 1 < stackSizeInWords(t) / 2); + assertT(t, t->sp + 1 < stackSizeInWords(t) / 2); t->stack[(t->sp * 2) ] = ObjectTag; t->stack[(t->sp * 2) + 1] = reinterpret_cast(o); ++ t->sp; @@ -72,7 +72,7 @@ pushInt(Thread* t, uint32_t v) fprintf(stderr, "push int %d at %d\n", v, t->sp); } - assert(t, t->sp + 1 < stackSizeInWords(t) / 2); + assertT(t, t->sp + 1 < stackSizeInWords(t) / 2); t->stack[(t->sp * 2) ] = IntTag; t->stack[(t->sp * 2) + 1] = v; ++ t->sp; @@ -111,7 +111,7 @@ popObject(Thread* t) t->sp - 1); } - assert(t, t->stack[(t->sp - 1) * 2] == ObjectTag); + assertT(t, t->stack[(t->sp - 1) * 2] == ObjectTag); return reinterpret_cast(t->stack[((-- t->sp) * 2) + 1]); } @@ -124,7 +124,7 @@ popInt(Thread* t) t->sp - 1); } - assert(t, t->stack[(t->sp - 1) * 2] == IntTag); + assertT(t, t->stack[(t->sp - 1) * 2] == IntTag); return t->stack[((-- t->sp) * 2) + 1]; } @@ -165,8 +165,8 @@ peekObject(Thread* t, unsigned index) index); } - assert(t, index < stackSizeInWords(t) / 2); - assert(t, t->stack[index * 2] == ObjectTag); + assertT(t, index < stackSizeInWords(t) / 2); + assertT(t, t->stack[index * 2] == ObjectTag); return reinterpret_cast(t->stack[(index * 2) + 1]); } @@ -179,8 +179,8 @@ peekInt(Thread* t, unsigned index) index); } - assert(t, index < stackSizeInWords(t) / 2); - assert(t, t->stack[index * 2] == IntTag); + assertT(t, index < stackSizeInWords(t) / 2); + assertT(t, t->stack[index * 2] == IntTag); return t->stack[(index * 2) + 1]; } @@ -1465,7 +1465,7 @@ interpret3(Thread* t, const int base) object field = resolveField(t, frameMethod(t, frame), index - 1); - assert(t, (fieldFlags(t, field) & ACC_STATIC) == 0); + assertT(t, (fieldFlags(t, field) & ACC_STATIC) == 0); PROTECT(t, field); @@ -1483,7 +1483,7 @@ interpret3(Thread* t, const int base) object field = resolveField(t, frameMethod(t, frame), index - 1); - assert(t, fieldFlags(t, field) & ACC_STATIC); + assertT(t, fieldFlags(t, field) & ACC_STATIC); PROTECT(t, field); @@ -2436,7 +2436,7 @@ interpret3(Thread* t, const int base) object field = resolveField(t, frameMethod(t, frame), index - 1); - assert(t, (fieldFlags(t, field) & ACC_STATIC) == 0); + assertT(t, (fieldFlags(t, field) & ACC_STATIC) == 0); PROTECT(t, field); { ACQUIRE_FIELD_FOR_WRITE(t, field); @@ -2507,7 +2507,7 @@ interpret3(Thread* t, const int base) object field = resolveField(t, frameMethod(t, frame), index - 1); - assert(t, fieldFlags(t, field) & ACC_STATIC); + assertT(t, fieldFlags(t, field) & ACC_STATIC); PROTECT(t, field); @@ -2657,10 +2657,10 @@ interpret3(Thread* t, const int base) // bootstrap class, so we need to load the real class to get the // real method and call it. - assert(t, frameNext(t, frame) >= base); + assertT(t, frameNext(t, frame) >= base); popFrame(t); - assert(t, codeBody(t, code, ip - 3) == invokevirtual); + assertT(t, codeBody(t, code, ip - 3) == invokevirtual); ip -= 2; uint16_t index = codeReadInt16(t, code, ip); @@ -2668,7 +2668,7 @@ interpret3(Thread* t, const int base) unsigned parameterFootprint = method->parameterFootprint(); GcClass* class_ = objectClass(t, peekObject(t, sp - parameterFootprint)); - assert(t, class_->vmFlags() & BootstrapFlag); + assertT(t, class_->vmFlags() & BootstrapFlag); resolveClass(t, classLoader(t, frameMethod(t, frame)->class_()), class_->name()); @@ -3121,10 +3121,10 @@ class MyProcessor: public Processor { { Thread* t = static_cast(vmt); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); if (UNLIKELY(t->sp + method->parameterFootprint() + 1 > stackSizeInWords(t) / 2)) @@ -3145,10 +3145,10 @@ class MyProcessor: public Processor { { Thread* t = static_cast(vmt); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); if (UNLIKELY(t->sp + method->parameterFootprint() + 1 > stackSizeInWords(t) / 2)) @@ -3169,10 +3169,10 @@ class MyProcessor: public Processor { { Thread* t = static_cast(vmt); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); if (UNLIKELY(t->sp + method->parameterFootprint() + 1 > stackSizeInWords(t) / 2)) @@ -3194,7 +3194,7 @@ class MyProcessor: public Processor { { Thread* t = static_cast(vmt); - assert(t, t->state == Thread::ActiveState + assertT(t, t->state == Thread::ActiveState or t->state == Thread::ExclusiveState); if (UNLIKELY(t->sp + parameterFootprint(vmt, methodSpec, false) @@ -3208,7 +3208,7 @@ class MyProcessor: public Processor { GcMethod* method = resolveMethod (t, loader, className, methodName, methodSpec); - assert(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); + assertT(t, ((method->flags() & ACC_STATIC) == 0) xor (this_ == 0)); return local::invoke(t, method); } diff --git a/src/jnienv.cpp b/src/jnienv.cpp index 3b622cfa86..0c48b5bd21 100644 --- a/src/jnienv.cpp +++ b/src/jnienv.cpp @@ -564,7 +564,7 @@ getMethodID(Thread* t, uintptr_t* arguments) GcMethod* method = findMethod(t, c, name, spec); - assert(t, (method->flags() & ACC_STATIC) == 0); + assertT(t, (method->flags() & ACC_STATIC) == 0); return methodID(t, method); } @@ -588,7 +588,7 @@ getStaticMethodID(Thread* t, uintptr_t* arguments) GcMethod* method = findMethod(t, c, name, spec); - assert(t, method->flags() & ACC_STATIC); + assertT(t, method->flags() & ACC_STATIC); return methodID(t, method); } @@ -606,11 +606,11 @@ GetStaticMethodID(Thread* t, jclass c, const char* name, const char* spec) GcMethod* getMethod(Thread* t, jmethodID m) { - assert(t, m); + assertT(t, m); GcMethod* method = cast(t, vectorBody(t, root(t, Machine::JNIMethodTable), m - 1)); - assert(t, (method->flags() & ACC_STATIC) == 0); + assertT(t, (method->flags() & ACC_STATIC) == 0); return method; } @@ -1101,11 +1101,11 @@ CallVoidMethodA(Thread* t, jobject o, jmethodID m, const jvalue* a) GcMethod* getStaticMethod(Thread* t, jmethodID m) { - assert(t, m); + assertT(t, m); GcMethod* method = cast(t, vectorBody(t, root(t, Machine::JNIMethodTable), m - 1)); - assert(t, method->flags() & ACC_STATIC); + assertT(t, method->flags() & ACC_STATIC); return method; } @@ -1540,11 +1540,11 @@ GetStaticFieldID(Thread* t, jclass c, const char* name, const char* spec) object getField(Thread* t, jfieldID f) { - assert(t, f); + assertT(t, f); object field = vectorBody(t, root(t, Machine::JNIFieldTable), f - 1); - assert(t, (fieldFlags(t, field) & ACC_STATIC) == 0); + assertT(t, (fieldFlags(t, field) & ACC_STATIC) == 0); return field; } @@ -1969,11 +1969,11 @@ SetDoubleField(Thread* t, jobject o, jfieldID field, jdouble v) object getStaticField(Thread* t, jfieldID f) { - assert(t, f); + assertT(t, f); object field = vectorBody(t, root(t, Machine::JNIFieldTable), f - 1); - assert(t, fieldFlags(t, field) & ACC_STATIC); + assertT(t, fieldFlags(t, field) & ACC_STATIC); return field; } diff --git a/src/machine.cpp b/src/machine.cpp index 2cb9f88fa7..eb92ed8132 100644 --- a/src/machine.cpp +++ b/src/machine.cpp @@ -49,8 +49,8 @@ void join(Thread* t, Thread* o) { if (t != o) { - assert(t, o->state != Thread::JoinedState); - assert(t, (o->flags & Thread::SystemFlag) == 0); + assertT(t, o->state != Thread::JoinedState); + assertT(t, (o->flags & Thread::SystemFlag) == 0); if (o->flags & Thread::JoinFlag) { o->systemThread->join(); } @@ -508,7 +508,7 @@ postVisit(Thread* t, Heap::Visitor* v) Machine* m = t->m; bool major = m->heap->collectionType() == Heap::MajorCollection; - assert(t, m->finalizeQueue == 0); + assertT(t, m->finalizeQueue == 0); m->heap->postVisit(); @@ -796,7 +796,7 @@ parseUtf8NonAscii(Thread* t, AbstractStream& s, object bytesSoFar, if (a & 0x20) { // 3 bytes si += 2; - assert(t, si < length); + assertT(t, si < length); unsigned b = readByte(s, &byteB); unsigned c = s.read1(); charArrayBody(t, value, vi++) @@ -804,7 +804,7 @@ parseUtf8NonAscii(Thread* t, AbstractStream& s, object bytesSoFar, } else { // 2 bytes ++ si; - assert(t, si < length); + assertT(t, si < length); unsigned b = readByte(s, &byteB); if (a == 0xC0 and b == 0x80) { @@ -846,7 +846,7 @@ parseUtf8(Thread* t, AbstractStream& s, unsigned length) if (a == 0xC0 and b == 0x80) { ++ si; - assert(t, si < length); + assertT(t, si < length); byteArrayBody(t, value, vi++) = 0; } else { return parseUtf8NonAscii(t, s, value, vi, si, a, b); @@ -2281,7 +2281,7 @@ parseMethodTable(Thread* t, Stream& s, GcClass* class_, GcSingleton* pool) for (HashMapIterator it(t, virtualMap); it.hasMore();) { object method = tripleFirst(t, it.next()); - assert(t, arrayBody(t, vtable, methodOffset(t, method)) == 0); + assertT(t, arrayBody(t, vtable, methodOffset(t, method)) == 0); set(t, vtable, ArrayBody + (methodOffset(t, method) * BytesPerWord), method); ++ i; @@ -2340,12 +2340,12 @@ parseMethodTable(Thread* t, Stream& s, GcClass* class_, GcSingleton* pool) } } - assert(t, arrayLength(t, newMethodTable) == mti); + assertT(t, arrayLength(t, newMethodTable) == mti); set(t, reinterpret_cast(class_), ClassMethodTable, newMethodTable); } - assert(t, arrayLength(t, vtable) == i); + assertT(t, arrayLength(t, vtable) == i); set(t, reinterpret_cast(class_), ClassVirtualTable, vtable); } @@ -2365,7 +2365,7 @@ parseMethodTable(Thread* t, Stream& s, GcClass* class_, GcSingleton* pool) object method = arrayBody(t, ivtable, j); method = hashMapFind (t, virtualMap, method, methodHash, methodEqual); - assert(t, method); + assertT(t, method); set(t, vtable, ArrayBody + (j * BytesPerWord), method); } @@ -2980,7 +2980,7 @@ class HeapClient: public Heap::Client { Thread* t = m->rootThread; object o = static_cast(m->heap->follow(maskAlignedPointer(p))); - assert(t, not objectFixed(t, o)); + assertT(t, not objectFixed(t, o)); unsigned n = baseSize(t, o, cast(t, static_cast (m->heap->follow(objectClass(t, o))))); @@ -2996,7 +2996,7 @@ class HeapClient: public Heap::Client { Thread* t = m->rootThread; object src = static_cast(m->heap->follow(maskAlignedPointer(srcp))); - assert(t, not objectFixed(t, src)); + assertT(t, not objectFixed(t, src)); GcClass* class_ = cast(t, static_cast (m->heap->follow(objectClass(t, src)))); @@ -3379,8 +3379,8 @@ Thread::init() memset(backupHeap, 0, ThreadBackupHeapSizeInBytes); if (parent == 0) { - assert(this, m->rootThread == 0); - assert(this, javaThread == 0); + assertT(this, m->rootThread == 0); + assertT(this, javaThread == 0); m->rootThread = this; m->unsafe = true; @@ -3612,7 +3612,7 @@ enter(Thread* t, Thread::State s) case Thread::IdleState: if (LIKELY(t->state == Thread::ActiveState)) { // fast path - assert(t, t->m->activeCount > 0); + assertT(t, t->m->activeCount > 0); INCREMENT(&(t->m->activeCount), -1); t->state = s; @@ -3633,7 +3633,7 @@ enter(Thread* t, Thread::State s) switch (t->state) { case Thread::ExclusiveState: { - assert(t, t->m->exclusive == t); + assertT(t, t->m->exclusive == t); t->m->exclusive = 0; } break; @@ -3642,11 +3642,11 @@ enter(Thread* t, Thread::State s) default: abort(t); } - assert(t, t->m->activeCount > 0); + assertT(t, t->m->activeCount > 0); INCREMENT(&(t->m->activeCount), -1); if (s == Thread::ZombieState) { - assert(t, t->m->liveCount > 0); + assertT(t, t->m->liveCount > 0); -- t->m->liveCount; if (t->flags & Thread::DaemonFlag) { @@ -3679,7 +3679,7 @@ enter(Thread* t, Thread::State s) switch (t->state) { case Thread::ExclusiveState: { - assert(t, t->m->exclusive == t); + assertT(t, t->m->exclusive == t); t->state = s; t->m->exclusive = 0; @@ -3710,7 +3710,7 @@ enter(Thread* t, Thread::State s) switch (t->state) { case Thread::ExclusiveState: { - assert(t, t->m->exclusive == t); + assertT(t, t->m->exclusive == t); // exit state should also be exclusive, so don't set exclusive = 0 t->m->stateLock->notifyAll(t->systemThread); @@ -3721,7 +3721,7 @@ enter(Thread* t, Thread::State s) default: abort(t); } - assert(t, t->m->activeCount > 0); + assertT(t, t->m->activeCount > 0); INCREMENT(&(t->m->activeCount), -1); t->state = s; @@ -3888,7 +3888,7 @@ collect(Thread* t, Heap::CollectionType type, int pendingAllocation) object makeNewGeneral(Thread* t, GcClass* class_) { - assert(t, t->state == Thread::ActiveState); + assertT(t, t->state == Thread::ActiveState); PROTECT(t, class_); @@ -4039,7 +4039,7 @@ void stringUTFChars(Thread* t, object string, unsigned start, unsigned length, char* chars, unsigned charsLength UNUSED) { - assert(t, static_cast + assertT(t, static_cast (stringUTFLength(t, string, start, length)) == charsLength); object data = stringData(t, string); @@ -4083,8 +4083,8 @@ resolveBootstrap(Thread* t, uintptr_t* arguments) bool isAssignableFrom(Thread* t, GcClass* a, GcClass* b) { - assert(t, a); - assert(t, b); + assertT(t, a); + assertT(t, b); if (a == b) return true; @@ -4872,7 +4872,7 @@ addFinalizer(Thread* t, object target, void (*finalize)(Thread*, object)) object objectMonitor(Thread* t, object o, bool createNew) { - assert(t, t->state == Thread::ActiveState); + assertT(t, t->state == Thread::ActiveState); object m = hashMapFind (t, cast(t, root(t, Machine::MonitorMap)), o, objectHash, objectEqual); @@ -5106,11 +5106,11 @@ makeTrace(Thread* t, Processor::StackWalker* walker) virtual bool visit(Processor::StackWalker* walker) { if (trace == 0) { trace = makeObjectArray(t, walker->count()); - assert(t, trace); + assertT(t, trace); } object e = reinterpret_cast(makeTraceElement(t, reinterpret_cast(walker->method()), walker->ip())); - assert(t, index < objectArrayLength(t, trace)); + assertT(t, index < objectArrayLength(t, trace)); set(t, trace, ArrayBody + (index * BytesPerWord), e); ++ index; return true; diff --git a/src/process.cpp b/src/process.cpp index e5d33cce5f..48cc3aaa13 100644 --- a/src/process.cpp +++ b/src/process.cpp @@ -230,7 +230,7 @@ resolveNative(Thread* t, GcMethod* method) { PROTECT(t, method); - assert(t, method->flags() & ACC_NATIVE); + assertT(t, method->flags() & ACC_NATIVE); initClass(t, cast(t, method->class_())); diff --git a/src/system/posix.cpp b/src/system/posix.cpp index 3ccec3b372..60eb4aadce 100644 --- a/src/system/posix.cpp +++ b/src/system/posix.cpp @@ -686,7 +686,7 @@ class MySystem: public System { virtual Status visit(System::Thread* st UNUSED, System::Thread* sTarget, ThreadVisitor* visitor) { - assert(this, st != sTarget); + assertT(this, st != sTarget); Thread* target = static_cast(sTarget); diff --git a/src/system/windows.cpp b/src/system/windows.cpp index a8e565ce55..18eff120d3 100644 --- a/src/system/windows.cpp +++ b/src/system/windows.cpp @@ -103,12 +103,12 @@ class MutexResource { public: MutexResource(System* s, HANDLE m): s(s), m(m) { int r UNUSED = WaitForSingleObject(m, INFINITE); - assert(s, r == WAIT_OBJECT_0); + assertT(s, r == WAIT_OBJECT_0); } ~MutexResource() { bool success UNUSED = ReleaseMutex(m); - assert(s, success); + assertT(s, success); } private: @@ -142,10 +142,10 @@ class MySystem: public System { flags(0) { mutex = CreateMutex(0, false, 0); - assert(s, mutex); + assertT(s, mutex); event = CreateEvent(0, true, false, 0); - assert(s, event); + assertT(s, event); } virtual void interrupt() { @@ -155,7 +155,7 @@ class MySystem: public System { if (flags & Waiting) { int r UNUSED = SetEvent(event); - assert(s, r != 0); + assertT(s, r != 0); } } @@ -171,7 +171,7 @@ class MySystem: public System { virtual void join() { int r UNUSED = WaitForSingleObject(thread, INFINITE); - assert(s, r == WAIT_OBJECT_0); + assertT(s, r == WAIT_OBJECT_0); } virtual void dispose() { @@ -194,17 +194,17 @@ class MySystem: public System { public: Mutex(System* s): s(s) { mutex = CreateMutex(0, false, 0); - assert(s, mutex); + assertT(s, mutex); } virtual void acquire() { int r UNUSED = WaitForSingleObject(mutex, INFINITE); - assert(s, r == WAIT_OBJECT_0); + assertT(s, r == WAIT_OBJECT_0); } virtual void release() { bool success UNUSED = ReleaseMutex(mutex); - assert(s, success); + assertT(s, success); } virtual void dispose() { @@ -220,12 +220,12 @@ class MySystem: public System { public: Monitor(System* s): s(s), owner_(0), first(0), last(0), depth(0) { mutex = CreateMutex(0, false, 0); - assert(s, mutex); + assertT(s, mutex); } virtual bool tryAcquire(System::Thread* context) { Thread* t = static_cast(context); - assert(s, t); + assertT(s, t); if (owner_ == t) { ++ depth; @@ -248,11 +248,11 @@ class MySystem: public System { virtual void acquire(System::Thread* context) { Thread* t = static_cast(context); - assert(s, t); + assertT(s, t); if (owner_ != t) { int r UNUSED = WaitForSingleObject(mutex, INFINITE); - assert(s, r == WAIT_OBJECT_0); + assertT(s, r == WAIT_OBJECT_0); owner_ = t; } ++ depth; @@ -260,13 +260,13 @@ class MySystem: public System { virtual void release(System::Thread* context) { Thread* t = static_cast(context); - assert(s, t); + assertT(s, t); if (owner_ == t) { if (-- depth == 0) { owner_ = 0; bool success UNUSED = ReleaseMutex(mutex); - assert(s, success); + assertT(s, success); } } else { sysAbort(s); @@ -329,7 +329,7 @@ class MySystem: public System { bool wait(System::Thread* context, int64_t time, bool clearInterrupted) { Thread* t = static_cast(context); - assert(s, t); + assertT(s, t); if (owner_ == t) { // Initialized here to make gcc 4.2 a happy compiler @@ -357,20 +357,20 @@ class MySystem: public System { owner_ = 0; bool success UNUSED = ReleaseMutex(mutex); - assert(s, success); + assertT(s, success); if (not interrupted) { success = ResetEvent(t->event); - assert(s, success); + assertT(s, success); success = ReleaseMutex(t->mutex); - assert(s, success); + assertT(s, success); r = WaitForSingleObject(t->event, (time ? time : INFINITE)); - assert(s, r == WAIT_OBJECT_0 or r == WAIT_TIMEOUT); + assertT(s, r == WAIT_OBJECT_0 or r == WAIT_TIMEOUT); r = WaitForSingleObject(t->mutex, INFINITE); - assert(s, r == WAIT_OBJECT_0); + assertT(s, r == WAIT_OBJECT_0); interrupted = t->r->interrupted(); if (interrupted and clearInterrupted) { @@ -382,7 +382,7 @@ class MySystem: public System { } r = WaitForSingleObject(mutex, INFINITE); - assert(s, r == WAIT_OBJECT_0); + assertT(s, r == WAIT_OBJECT_0); { ACQUIRE(s, t->mutex); t->flags = 0; @@ -415,12 +415,12 @@ class MySystem: public System { t->flags |= Notified; bool success UNUSED = SetEvent(t->event); - assert(s, success); + assertT(s, success); } virtual void notify(System::Thread* context) { Thread* t = static_cast(context); - assert(s, t); + assertT(s, t); if (owner_ == t) { if (first) { @@ -440,7 +440,7 @@ class MySystem: public System { virtual void notifyAll(System::Thread* context) { Thread* t = static_cast(context); - assert(s, t); + assertT(s, t); if (owner_ == t) { for (Thread* t = first; t; t = t->next) { @@ -457,7 +457,7 @@ class MySystem: public System { } virtual void dispose() { - assert(s, owner_ == 0); + assertT(s, owner_ == 0); CloseHandle(mutex); ::free(this); } @@ -474,7 +474,7 @@ class MySystem: public System { public: Local(System* s): s(s) { key = TlsAlloc(); - assert(s, key != TLS_OUT_OF_INDEXES); + assertT(s, key != TLS_OUT_OF_INDEXES); } virtual void* get() { @@ -483,12 +483,12 @@ class MySystem: public System { virtual void set(void* p) { bool r UNUSED = TlsSetValue(key, p); - assert(s, r); + assertT(s, r); } virtual void dispose() { bool r UNUSED = TlsFree(key); - assert(s, r); + assertT(s, r); ::free(this); } @@ -623,7 +623,7 @@ class MySystem: public System { system = this; mutex = CreateMutex(0, false, 0); - assert(this, mutex); + assertT(this, mutex); } virtual void* tryAllocate(unsigned sizeInBytes) { @@ -642,7 +642,7 @@ class MySystem: public System { virtual void freeExecutable(const void* p, unsigned) { int r UNUSED = VirtualFree(const_cast(p), 0, MEM_RELEASE); - assert(this, r); + assertT(this, r); } #endif @@ -655,7 +655,7 @@ class MySystem: public System { bool success UNUSED = DuplicateHandle (GetCurrentProcess(), GetCurrentThread(), GetCurrentProcess(), &(t->thread), 0, false, DUPLICATE_SAME_ACCESS); - assert(this, success); + assertT(this, success); r->attach(t); return 0; } @@ -665,7 +665,7 @@ class MySystem: public System { r->attach(t); DWORD id; t->thread = CreateThread(0, 0, run, r, 0, &id); - assert(this, t->thread); + assertT(this, t->thread); return 0; } @@ -688,7 +688,7 @@ class MySystem: public System { ThreadVisitor* visitor) { #if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) - assert(this, st != sTarget); + assertT(this, st != sTarget); Thread* target = static_cast(sTarget); @@ -873,7 +873,7 @@ class MySystem: public System { handle = GetModuleHandle(0); #else // Most of WinRT/WP8 applications can not host native object files inside main executable - assert(this, false); + assertT(this, false); #endif } diff --git a/src/tools/type-generator/main.cpp b/src/tools/type-generator/main.cpp index 46d4f1972f..6cf8957ac5 100644 --- a/src/tools/type-generator/main.cpp +++ b/src/tools/type-generator/main.cpp @@ -1219,7 +1219,7 @@ writeAccessor(Output* out, Object* member, Object* offset, bool unsafe = false) if (memberOwner(member)->type == Object::Type) { if (not unsafe) { - out->write(" assert(t, t->m->unsafe or "); + out->write(" assertT(t, t->m->unsafe or "); out->write("instanceOf(t, reinterpret_cast(arrayBodyUnsafe"); out->write("(t, t->m->types, Gc::"); out->write(capitalize(local::typeName(memberOwner(member)))); @@ -1227,7 +1227,7 @@ writeAccessor(Output* out, Object* member, Object* offset, bool unsafe = false) out->write(", o));\n"); if (member->type != Object::Scalar) { - out->write(" assert(t, i < "); + out->write(" assertT(t, i < "); out->write(local::typeName(memberOwner(member))); out->write("Length(t, o));\n"); }