aboutsummaryrefslogtreecommitdiff
path: root/test/behavior/basic.zig
diff options
context:
space:
mode:
authorAndrew Kelley <andrew@ziglang.org>2023-04-21 23:05:36 -0700
committerAndrew Kelley <andrew@ziglang.org>2023-04-25 11:23:41 -0700
commit057c950093085e392fcdd6d6c8e7fb4356dd9959 (patch)
treef47a5292c6a6cba0800a0ab6ee8ed6cfdfd7c6bc /test/behavior/basic.zig
parent25d11283b7b79edd383163cb2a72bd79dcf02dba (diff)
downloadzig-057c950093085e392fcdd6d6c8e7fb4356dd9959.tar.gz
zig-057c950093085e392fcdd6d6c8e7fb4356dd9959.zip
LLVM backend: support non-byte-sized memset
Also introduce memset_safe AIR tag and support it in C backend and LLVM backend.
Diffstat (limited to 'test/behavior/basic.zig')
-rw-r--r--test/behavior/basic.zig44
1 files changed, 44 insertions, 0 deletions
diff --git a/test/behavior/basic.zig b/test/behavior/basic.zig
index 28328446c4..19ef38717a 100644
--- a/test/behavior/basic.zig
+++ b/test/behavior/basic.zig
@@ -353,6 +353,50 @@ fn f2(x: bool) []const u8 {
return (if (x) &fA else &fB)();
}
+test "@memset on array pointers" {
+ if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest;
+ if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest;
+ if (builtin.zig_backend == .stage2_sparc64) return error.SkipZigTest;
+
+ try testMemsetArray();
+ // TODO this doesn't pass yet
+ // try comptime testMemsetArray();
+}
+
+fn testMemsetArray() !void {
+ {
+ // memset array to non-undefined, ABI size == 1
+ var foo: [20]u8 = undefined;
+ @memset(&foo, 'A');
+ try expect(foo[0] == 'A');
+ try expect(foo[11] == 'A');
+ try expect(foo[19] == 'A');
+
+ // memset array to undefined, ABI size == 1
+ @setRuntimeSafety(true);
+ @memset(&foo, undefined);
+ try expect(foo[0] == 0xaa);
+ try expect(foo[11] == 0xaa);
+ try expect(foo[19] == 0xaa);
+ }
+
+ {
+ // memset array to non-undefined, ABI size > 1
+ var foo: [20]u32 = undefined;
+ @memset(&foo, 1234);
+ try expect(foo[0] == 1234);
+ try expect(foo[11] == 1234);
+ try expect(foo[19] == 1234);
+
+ // memset array to undefined, ABI size > 1
+ @setRuntimeSafety(true);
+ @memset(&foo, undefined);
+ try expect(foo[0] == 0xaaaaaaaa);
+ try expect(foo[11] == 0xaaaaaaaa);
+ try expect(foo[19] == 0xaaaaaaaa);
+ }
+}
+
test "memcpy and memset intrinsics" {
if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest;
if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest;