diff options
author | whitequark <whitequark@whitequark.org> | 2021-11-27 07:57:15 +0000 |
---|---|---|
committer | whitequark <whitequark@whitequark.org> | 2021-11-27 07:57:15 +0000 |
commit | 264dfc7ed414476438e4a858258f5516d7b863c6 (patch) | |
tree | 0c3ff28e48071a2c921b7ed1fe7218124c1df629 | |
parent | f6fa2ddcfc89099726d60386befba874c7ac1e0d (diff) | |
download | abc-264dfc7ed414476438e4a858258f5516d7b863c6.tar.gz abc-264dfc7ed414476438e4a858258f5516d7b863c6.tar.bz2 abc-264dfc7ed414476438e4a858258f5516d7b863c6.zip |
Extend WASI platform support for glucose2.
Abort on OOM since there are no C++ exceptions yet.
-rw-r--r-- | src/sat/glucose2/Alloc.h | 8 | ||||
-rw-r--r-- | src/sat/glucose2/Vec.h | 8 | ||||
-rw-r--r-- | src/sat/glucose2/XAlloc.h | 4 |
3 files changed, 20 insertions, 0 deletions
diff --git a/src/sat/glucose2/Alloc.h b/src/sat/glucose2/Alloc.h index b7bebaca..427cd323 100644 --- a/src/sat/glucose2/Alloc.h +++ b/src/sat/glucose2/Alloc.h @@ -100,7 +100,11 @@ void RegionAllocator<T>::capacity(uint32_t min_cap) cap += delta; if (cap <= prev_cap) +#ifdef __wasm + abort(); +#else throw OutOfMemoryException(); +#endif } //printf(" .. (%p) cap = %u\n", this, cap); @@ -122,7 +126,11 @@ RegionAllocator<T>::alloc(int size) // Handle overflow: if (sz < prev_sz) +#ifdef __wasm + abort(); +#else throw OutOfMemoryException(); +#endif return prev_sz; } diff --git a/src/sat/glucose2/Vec.h b/src/sat/glucose2/Vec.h index eaeed207..bc989217 100644 --- a/src/sat/glucose2/Vec.h +++ b/src/sat/glucose2/Vec.h @@ -102,14 +102,22 @@ void vec<T>::capacity(int min_cap) { if (cap >= min_cap) return; int add = imax((min_cap - cap + 1) & ~1, ((cap >> 1) + 2) & ~1); // NOTE: grow by approximately 3/2 if (add > INT_MAX - cap || (((data = (T*)::realloc(data, (cap += add) * sizeof(T))) == NULL) && errno == ENOMEM)) +#ifdef __wasm + abort(); +#else throw OutOfMemoryException(); +#endif } template<class T> void vec<T>::prelocate(int ext_cap) { if (cap >= ext_cap) return; if (ext_cap > INT_MAX || (((data = (T*)::realloc(data, ext_cap * sizeof(T))) == NULL) && errno == ENOMEM)) +#ifdef __wasm + abort(); +#else throw OutOfMemoryException(); +#endif cap = ext_cap; } diff --git a/src/sat/glucose2/XAlloc.h b/src/sat/glucose2/XAlloc.h index 716643ef..86e65a49 100644 --- a/src/sat/glucose2/XAlloc.h +++ b/src/sat/glucose2/XAlloc.h @@ -39,7 +39,11 @@ static inline void* xrealloc(void *ptr, size_t size) { void* mem = realloc(ptr, size); if (mem == NULL && errno == ENOMEM){ +#ifdef __wasm + abort(); +#else throw OutOfMemoryException(); +#endif }else { return mem; } |