chore(runtime/cpp/lean_runtime): add assertion to make sure we are satisfying alignment constraints
This commit is contained in:
parent
46f7123cc8
commit
1259f52fa8
1 changed files with 1 additions and 0 deletions
|
@ -68,6 +68,7 @@ void * alloc_obj(unsigned n) {
|
||||||
|
|
||||||
obj_cell::obj_cell(unsigned cidx, unsigned sz, obj const * fs):
|
obj_cell::obj_cell(unsigned cidx, unsigned sz, obj const * fs):
|
||||||
m_rc(0), m_kind(static_cast<unsigned>(obj_kind::Constructor)), m_size(sz), m_cidx(cidx) {
|
m_rc(0), m_kind(static_cast<unsigned>(obj_kind::Constructor)), m_size(sz), m_cidx(cidx) {
|
||||||
|
static_assert(sizeof(obj_cell) % sizeof(void*) == 0); // make sure the hack used to store obj_cell fields satisfies alignment constraints.
|
||||||
void ** mem = field_addr();
|
void ** mem = field_addr();
|
||||||
for (unsigned i = 0; i < sz; i++, mem++)
|
for (unsigned i = 0; i < sz; i++, mem++)
|
||||||
new (mem) obj(fs[i]);
|
new (mem) obj(fs[i]);
|
||||||
|
|
Loading…
Reference in a new issue