Commit e09465fc49

Robin Voetter <robin@voetter.nl>
2021-08-29 03:18:23
Address Spaces: Chaining tests
1 parent 2f43749
Changed files (2)
src
codegen
test
stage2
src/codegen/llvm/bindings.zig
@@ -973,3 +973,62 @@ pub const TypeKind = enum(c_int) {
     BFloat,
     X86_AMX,
 };
+
+pub const address_space = struct {
+    // See llvm/lib/Target/X86/X86.h
+    pub const x86_64 = x86;
+    pub const x86 = struct {
+        pub const gs = 256;
+        pub const fs = 257;
+        pub const ss = 258;
+
+        pub const ptr32_sptr = 270;
+        pub const ptr32_uptr = 271;
+        pub const ptr64 = 272;
+    };
+
+    // See llvm/lib/Target/AVR/AVR.h
+    pub const avr = struct {
+        pub const data_memory = 0;
+        pub const program_memory = 1;
+    };
+
+    // See llvm/lib/Target/NVPTX/NVPTX.h
+    pub const nvptx = struct {
+        pub const generic = 0;
+        pub const global = 1;
+        pub const constant = 2;
+        pub const shared = 3;
+        pub const param = 4;
+        pub const local = 5;
+    };
+
+    // See llvm/lib/Target/AMDGPU/AMDGPU.h
+    pub const amdgpu = struct {
+        pub const flat = 0;
+        pub const global = 1;
+        pub const region = 2;
+        pub const local = 3;
+        pub const constant = 4;
+        pub const constant_32bit = 6;
+        pub const buffer_fat_pointer = 7;
+        pub const param_d = 6;
+        pub const param_i = 7;
+        pub const constant_buffer_0 = 8;
+        pub const constant_buffer_1 = 9;
+        pub const constant_buffer_2 = 10;
+        pub const constant_buffer_3 = 11;
+        pub const constant_buffer_4 = 12;
+        pub const constant_buffer_5 = 13;
+        pub const constant_buffer_6 = 14;
+        pub const constant_buffer_7 = 15;
+        pub const constant_buffer_8 = 16;
+        pub const constant_buffer_9 = 17;
+        pub const constant_buffer_10 = 18;
+        pub const constant_buffer_11 = 19;
+        pub const constant_buffer_12 = 20;
+        pub const constant_buffer_13 = 21;
+        pub const constant_buffer_14 = 22;
+        pub const constant_buffer_15 = 23;
+    };
+};
test/stage2/llvm.zig
@@ -302,4 +302,56 @@ pub fn addCases(ctx: *TestContext) !void {
             \\pub export fn main() void { _ = entry; }
         );
     }
+
+    {
+        var case = ctx.exeUsingLlvmBackend("address spaces pointer access chaining: array pointer", linux_x64);
+        case.compiles(
+            \\fn entry(a: *addrspace(.gs) [1]i32) *addrspace(.gs) i32 {
+            \\    return &a[0];
+            \\}
+            \\pub export fn main() void { _ = entry; }
+        );
+    }
+
+    {
+        var case = ctx.exeUsingLlvmBackend("address spaces pointer access chaining: pointer to optional array", linux_x64);
+        case.compiles(
+            \\fn entry(a: *addrspace(.gs) ?[1]i32) *addrspace(.gs) i32 {
+            \\    return &a.*.?[0];
+            \\}
+            \\pub export fn main() void { _ = entry; }
+        );
+    }
+
+    {
+        var case = ctx.exeUsingLlvmBackend("address spaces pointer access chaining: struct pointer", linux_x64);
+        case.compiles(
+            \\const A = struct{ a: i32 };
+            \\fn entry(a: *addrspace(.gs) A) *addrspace(.gs) i32 {
+            \\    return &a.a;
+            \\}
+            \\pub export fn main() void { _ = entry; }
+        );
+    }
+
+    {
+        var case = ctx.exeUsingLlvmBackend("address spaces pointer access chaining: complex", linux_x64);
+        case.compiles(
+            \\const A = struct{ a: ?[1]i32 };
+            \\fn entry(a: *addrspace(.gs) [1]A) *addrspace(.gs) i32 {
+            \\    return &a[0].a.?[0];
+            \\}
+            \\pub export fn main() void { _ = entry; }
+        );
+    }
+
+    {
+        var case = ctx.exeUsingLlvmBackend("dereferencing through multiple pointers with address spaces", linux_x64);
+        case.compiles(
+            \\fn entry(a: *addrspace(.fs) *addrspace(.gs) *i32) *i32 {
+            \\    return a.*.*;
+            \\}
+            \\pub export fn main() void { _ = entry; }
+        );
+    }
 }