Skip to content

Commit

Permalink
Revert "fix #8156"
Browse files Browse the repository at this point in the history
Revert "allow more kinds of fields to take 0 space. fixes #8156"

This reverts commits 662cd0a,
                     6667e5d.
  • Loading branch information
kmsquire committed Sep 3, 2014
1 parent d69c193 commit 115a8b4
Show file tree
Hide file tree
Showing 7 changed files with 33 additions and 54 deletions.
21 changes: 9 additions & 12 deletions src/alloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -129,8 +129,6 @@ static jl_value_t *jl_new_bits_internal(jl_value_t *dt, void *data, size_t *len)

jl_datatype_t *bt = (jl_datatype_t*)dt;
size_t nb = jl_datatype_size(bt);
if (nb == 0)
return jl_new_struct_uninit(bt);
*len = LLT_ALIGN(*len, bt->alignment);
data = (char*)data + (*len);
*len += nb;
Expand Down Expand Up @@ -177,7 +175,6 @@ DLLEXPORT jl_value_t *jl_pointerref(jl_value_t *p, jl_value_t *i)
void jl_assign_bits(void *dest, jl_value_t *bits)
{
size_t nb = jl_datatype_size(jl_typeof(bits));
if (nb == 0) return;
switch (nb) {
case 1: *(int8_t*)dest = *(int8_t*)jl_data_ptr(bits); break;
case 2: *(int16_t*)dest = *(int16_t*)jl_data_ptr(bits); break;
Expand Down Expand Up @@ -273,6 +270,7 @@ DLLEXPORT jl_value_t *jl_new_struct(jl_datatype_t *type, ...)
for(size_t i=0; i < nf; i++) {
jl_set_nth_field(jv, i, va_arg(args, jl_value_t*));
}
if (type->size == 0) type->instance = jv;
va_end(args);
return jv;
}
Expand All @@ -289,15 +287,16 @@ DLLEXPORT jl_value_t *jl_new_structv(jl_datatype_t *type, jl_value_t **args, uin
if (type->fields[i].isptr)
*(jl_value_t**)((char*)jv+jl_field_offset(type,i)+sizeof(void*)) = NULL;
}
if (type->size == 0) type->instance = jv;
return jv;
}

DLLEXPORT jl_value_t *jl_new_struct_uninit(jl_datatype_t *type)
{
if (type->instance != NULL) return type->instance;
jl_value_t *jv = newstruct(type);
if (type->size > 0)
memset(&((void**)jv)[1], 0, type->size);
if (type->size == 0) type->instance = jv;
else memset(&((void**)jv)[1], 0, type->size);
return jv;
}

Expand Down Expand Up @@ -662,9 +661,9 @@ void jl_compute_field_offsets(jl_datatype_t *st)
for(size_t i=0; i < jl_tuple_len(st->types); i++) {
jl_value_t *ty = jl_tupleref(st->types, i);
size_t fsz, al;
if (jl_isbits(ty) && jl_is_leaf_type(ty)) {
if (jl_isbits(ty) && (al=((jl_datatype_t*)ty)->alignment)!=0 &&
jl_is_leaf_type(ty)) {
fsz = jl_datatype_size(ty);
al = ((jl_datatype_t*)ty)->alignment;
st->fields[i].isptr = 0;
}
else {
Expand All @@ -673,11 +672,9 @@ void jl_compute_field_offsets(jl_datatype_t *st)
st->fields[i].isptr = 1;
ptrfree = 0;
}
if (al != 0) {
sz = LLT_ALIGN(sz, al);
if (al > alignm)
alignm = al;
}
sz = LLT_ALIGN(sz, al);
if (al > alignm)
alignm = al;
st->fields[i].offset = sz;
st->fields[i].size = fsz;
sz += fsz;
Expand Down
25 changes: 12 additions & 13 deletions src/cgutils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -476,7 +476,10 @@ DLLEXPORT Type *julia_type_to_llvm(jl_value_t *jt)
}
if (jl_isbits(jt)) {
if (((jl_datatype_t*)jt)->size == 0) {
return T_void;
// TODO: come up with a representation for a 0-size value,
// and make this 0 size everywhere. as an argument, simply
// skip passing it.
return jl_pvalue_llvmt;
}
return julia_struct_to_llvm(jt);
}
Expand All @@ -492,7 +495,7 @@ static Type *julia_struct_to_llvm(jl_value_t *jt)
jl_datatype_t *jst = (jl_datatype_t*)jt;
if (jst->struct_decl == NULL) {
size_t ntypes = jl_tuple_len(jst->types);
if (ntypes == 0 || jst->size == 0)
if (ntypes == 0)
return T_void;
StructType *structdecl = StructType::create(getGlobalContext(), jst->name->name->name);
jst->struct_decl = structdecl;
Expand All @@ -505,8 +508,6 @@ static Type *julia_struct_to_llvm(jl_value_t *jt)
lty = jl_pvalue_llvmt;
else
lty = ty==(jl_value_t*)jl_bool_type ? T_int8 : julia_type_to_llvm(ty);
if (lty == T_void || lty->isEmptyTy())
continue;
latypes.push_back(lty);
}
structdecl->setBody(latypes);
Expand Down Expand Up @@ -880,16 +881,12 @@ static Value *emit_nthptr_recast(Value *v, size_t n, MDNode *tbaa, Type* ptype)
Value *vptr = emit_nthptr_addr(v, n);
return tbaa_decorate(tbaa,builder.CreateLoad(builder.CreateBitCast(vptr,ptype), false));
}

static Value *ghostValue(jl_value_t *ty);

static Value *typed_load(Value *ptr, Value *idx_0based, jl_value_t *jltype,
jl_codectx_t *ctx)
{
Type *elty = julia_type_to_llvm(jltype);
assert(elty != NULL);
if (elty == T_void)
return ghostValue(jltype);
bool isbool=false;
if (elty==T_int1) { elty = T_int8; isbool=true; }
Value *data;
Expand All @@ -908,13 +905,11 @@ static Value *typed_load(Value *ptr, Value *idx_0based, jl_value_t *jltype,

static Value *emit_unbox(Type *to, Value *x, jl_value_t *jt);

static void typed_store(Value *ptr, Value *idx_0based, Value *rhs,
jl_value_t *jltype, jl_codectx_t *ctx)
static Value *typed_store(Value *ptr, Value *idx_0based, Value *rhs,
jl_value_t *jltype, jl_codectx_t *ctx)
{
Type *elty = julia_type_to_llvm(jltype);
assert(elty != NULL);
if (elty == T_void)
return;
if (elty==T_int1) { elty = T_int8; }
if (jl_isbits(jltype) && ((jl_datatype_t*)jltype)->size > 0)
rhs = emit_unbox(elty, rhs, jltype);
Expand All @@ -925,7 +920,7 @@ static void typed_store(Value *ptr, Value *idx_0based, Value *rhs,
data = builder.CreateBitCast(ptr, PointerType::get(elty, 0));
else
data = ptr;
tbaa_decorate(tbaa_user, builder.CreateStore(rhs, builder.CreateGEP(data, idx_0based)));
return tbaa_decorate(tbaa_user, builder.CreateStore(rhs, builder.CreateGEP(data, idx_0based)));
}

// --- convert boolean value to julia ---
Expand Down Expand Up @@ -1448,6 +1443,8 @@ static jl_value_t *static_void_instance(jl_value_t *jt)
}
if (jl_is_datatype(jt)) {
jl_datatype_t *jb = (jl_datatype_t*)jt;
if (jb->instance == NULL)
jl_new_struct_uninit(jb);
if (jb->instance == NULL)
// if we can't get an instance then this was an UndefValue due
// to throwing an error.
Expand Down Expand Up @@ -1615,6 +1612,8 @@ static Value *boxed(Value *v, jl_codectx_t *ctx, jl_value_t *jt)
}

if (!jb->abstract && jb->size == 0) {
if (jb->instance == NULL)
jl_new_struct_uninit(jb);
assert(jb->instance != NULL);
return literal_pointer_val(jb->instance);
}
Expand Down
13 changes: 6 additions & 7 deletions src/codegen.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2048,8 +2048,8 @@ static Value *emit_known_call(jl_value_t *ff, jl_value_t **args, size_t nargs,
JL_GC_POP();
if (jl_array_store_unboxed(ety) &&
((jl_datatype_t*)ety)->size == 0) {
jl_new_struct_uninit((jl_datatype_t*)ety);
assert(jl_is_datatype(ety));
assert(((jl_datatype_t*)ety)->instance != NULL);
return literal_pointer_val(((jl_datatype_t*)ety)->instance);
}
return typed_load(emit_arrayptr(ary, args[1], ctx), idx, ety, ctx);
Expand Down Expand Up @@ -2456,10 +2456,9 @@ static Value *ghostValue(jl_value_t *ty)
{
if (jl_is_datatype(ty)) {
Type *llvmty = julia_struct_to_llvm(ty);
if (llvmty == T_void)
return mark_julia_type(UndefValue::get(NoopType),ty);
assert(llvmty != T_void);
return UndefValue::get(llvmty);
}
}
else {
return mark_julia_type(UndefValue::get(NoopType),ty);
}
Expand Down Expand Up @@ -2836,8 +2835,7 @@ static Value *emit_expr(jl_value_t *expr, jl_codectx_t *ctx, bool isboxed,
if (nf > 0) {
if (jl_isbits(sty)) {
Type *lt = julia_type_to_llvm(ty);
if (lt == T_void)
return mark_julia_type(UndefValue::get(NoopType),ty);
assert(lt != T_void);
Value *strct = UndefValue::get(lt);
size_t na = nargs-1 < nf ? nargs-1 : nf;
unsigned idx = 0;
Expand Down Expand Up @@ -3241,7 +3239,8 @@ static Function *gen_jlcall_wrapper(jl_lambda_info_t *lam, jl_expr_t *ast, Funct
Value *theArg = builder.CreateLoad(argPtr, false);
Value *theNewArg = theArg;
argIdx++;
if (jl_is_leaf_type(ty) && jl_isbits(ty)) {
if ((jl_is_leaf_type(ty) && jl_isbits(ty) &&
((jl_datatype_t*)ty)->size > 0)) {
Type *lty = julia_struct_to_llvm(ty);
assert(lty != NULL);
if (lty == T_void || lty->isEmptyTy())
Expand Down
2 changes: 0 additions & 2 deletions src/interpreter.c
Original file line number Diff line number Diff line change
Expand Up @@ -405,8 +405,6 @@ static jl_value_t *eval(jl_value_t *e, jl_value_t **locals, size_t nl)
((jl_tvar_t*)jl_tupleref(para,i))->bound = 0;
}
jl_compute_field_offsets(dt);
if (para == (jl_value_t*)jl_null && jl_is_datatype_singleton(dt))
dt->instance = newstruct(dt);

b->value = temp;
if (temp==NULL || !equiv_type(dt, (jl_datatype_t*)temp)) {
Expand Down
2 changes: 1 addition & 1 deletion src/intrinsics.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -800,7 +800,7 @@ static Value *emit_pointerset(jl_value_t *e, jl_value_t *x, jl_value_t *i, jl_co
else
val = emit_unboxed(x,ctx);
}
typed_store(thePtr, im1, val, ety, ctx);
(void)typed_store(thePtr, im1, val, ety, ctx);
}
return mark_julia_type(thePtr, aty);
}
Expand Down
14 changes: 5 additions & 9 deletions src/jltypes.c
Original file line number Diff line number Diff line change
Expand Up @@ -1949,22 +1949,18 @@ static jl_value_t *inst_type_w_(jl_value_t *t, jl_value_t **env, size_t n,
// recursively instantiate the types of the fields
ndt->types = (jl_tuple_t*)inst_type_w_((jl_value_t*)ftypes, env, n, stack, 1);
if (!isabstract) {
if (jl_tuple_len(ftypes) == 0) {
ndt->alignment = ndt->size = dt->size;
ndt->pointerfree = dt->pointerfree;
}
else {
jl_compute_field_offsets(ndt);
}
if (jl_is_datatype_singleton(ndt) && tn != jl_array_typename)
ndt->instance = newstruct(ndt);
jl_compute_field_offsets(ndt);
}
else {
ndt->size = 0;
ndt->pointerfree = 0;
}
if (tn == jl_array_typename)
ndt->pointerfree = 0;
if (jl_tuple_len(ftypes) == 0) {
ndt->alignment = ndt->size = dt->size;
ndt->pointerfree = dt->pointerfree;
}
}
if (cacheable) cache_type_((jl_value_t*)ndt);
result = (jl_value_t*)ndt;
Expand Down
10 changes: 0 additions & 10 deletions test/core.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1830,16 +1830,6 @@ end
# issue #7582
aₜ = "a variable using Unicode 6"

immutable My8156{A, B}
a::A
b::B
end
let m = My8156(nothing, 1)
@test sizeof(m) == sizeof(1)
@test m.a === nothing
@test m.b === 1
end

# issue #8184
immutable Foo8184
x::Nothing
Expand Down

0 comments on commit 115a8b4

Please sign in to comment.