Commit 952d865bd2
Changed files (4)
src
stage1
test
behavior
bugs
src/stage1/all_types.hpp
@@ -1957,6 +1957,7 @@ struct ZigLLVMFnKey {
} bswap;
struct {
uint32_t bit_count;
+ uint32_t vector_len; // 0 means not a vector
} bit_reverse;
} data;
};
src/stage1/codegen.cpp
@@ -5175,11 +5175,13 @@ static LLVMValueRef get_int_builtin_fn(CodeGen *g, ZigType *expr_type, BuiltinFn
n_args = 2;
key.id = ZigLLVMFnIdCtz;
key.data.ctz.bit_count = (uint32_t)int_type->data.integral.bit_count;
+ key.data.ctz.vector_len = vector_len;
} else if (fn_id == BuiltinFnIdClz) {
fn_name = "ctlz";
n_args = 2;
key.id = ZigLLVMFnIdClz;
key.data.clz.bit_count = (uint32_t)int_type->data.integral.bit_count;
+ key.data.clz.vector_len = vector_len;
} else if (fn_id == BuiltinFnIdPopCount) {
fn_name = "ctpop";
n_args = 1;
@@ -5197,6 +5199,7 @@ static LLVMValueRef get_int_builtin_fn(CodeGen *g, ZigType *expr_type, BuiltinFn
n_args = 1;
key.id = ZigLLVMFnIdBitReverse;
key.data.bit_reverse.bit_count = (uint32_t)int_type->data.integral.bit_count;
+ key.data.bit_reverse.vector_len = vector_len;
} else {
zig_unreachable();
}
test/behavior/bugs/10147.zig
@@ -0,0 +1,12 @@
+const std = @import("std");
+
+test "uses correct LLVM builtin" {
+ var x: u32 = 0x1;
+ var y: @Vector(4, u32) = [_]u32{ 0x1, 0x1, 0x1, 0x1 };
+ // The stage1 compiler used to call the same builtin function for both
+ // scalar and vector inputs, causing the LLVM module verification to fail.
+ var a = @clz(u32, x);
+ var b = @clz(u32, y);
+ try std.testing.expectEqual(@as(u6, 31), a);
+ try std.testing.expectEqual([_]u6{ 31, 31, 31, 31 }, b);
+}
test/behavior.zig
@@ -128,6 +128,7 @@ test {
_ = @import("behavior/bugs/7250.zig");
_ = @import("behavior/bugs/9584.zig");
_ = @import("behavior/bugs/9967.zig");
+ _ = @import("behavior/bugs/10147.zig");
_ = @import("behavior/byteswap.zig");
_ = @import("behavior/byval_arg_var.zig");
_ = @import("behavior/call_stage1.zig");