zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit dd5b2d1b04197903489f5da9c178e17e61bb55e3 (tree)
parent 780e5674467ebac4534cd3d3f2199ccaf1d0922c
Author: Andrew Kelley <superjoe30@gmail.com>
Date:   Sun, 16 Sep 2018 11:23:38 -0400

fix crash when pointer casting a runtime extern function

Diffstat:
Msrc/analyze.cpp | 7++++---
Mtest/cases/align.zig | 9+++++++++
2 files changed, 13 insertions(+), 3 deletions(-)

diff --git a/src/analyze.cpp b/src/analyze.cpp @@ -3992,9 +3992,10 @@ uint32_t get_ptr_align(CodeGen *g, ZigType *type) { return (ptr_type->data.pointer.explicit_alignment == 0) ? get_abi_alignment(g, ptr_type->data.pointer.child_type) : ptr_type->data.pointer.explicit_alignment; } else if (ptr_type->id == ZigTypeIdFn) { - return (ptr_type->data.fn.fn_type_id.alignment == 0) ? - LLVMABIAlignmentOfType(g->target_data_ref, ptr_type->data.fn.raw_type_ref) : - ptr_type->data.fn.fn_type_id.alignment; + // I tried making this use LLVMABIAlignmentOfType but it trips this assertion in LLVM: + // "Cannot getTypeInfo() on a type that is unsized!" + // when getting the alignment of `?extern fn() void`. + return (ptr_type->data.fn.fn_type_id.alignment == 0) ? 1 : ptr_type->data.fn.fn_type_id.alignment; } else if (ptr_type->id == ZigTypeIdPromise) { return get_coro_frame_align_bytes(g); } else { diff --git a/test/cases/align.zig b/test/cases/align.zig @@ -219,3 +219,12 @@ test "alignment of structs" { b: *i32, }) == @alignOf(usize)); } + +test "alignment of extern() void" { + var runtime_nothing = nothing; + const casted1 = @ptrCast(*const u8, runtime_nothing); + const casted2 = @ptrCast(extern fn () void, casted1); + casted2(); +} + +extern fn nothing() void {}