mirror of
https://github.com/ziglang/zig.git
synced 2024-11-27 07:32:44 +00:00
2897641fb9
These are supported using %[ident:mod] syntax. This allows requesting, e.g., the "w" (32-bit) vs. "x" (64-bit) views of AArch64 registers. See https://llvm.org/docs/LangRef.html#asm-template-argument-modifiers
152 lines
4.2 KiB
Zig
152 lines
4.2 KiB
Zig
const std = @import("std");
|
|
const builtin = @import("builtin");
|
|
const expect = std.testing.expect;
|
|
|
|
const is_x86_64_linux = builtin.cpu.arch == .x86_64 and builtin.os.tag == .linux;
|
|
|
|
comptime {
|
|
if (builtin.zig_backend != .stage2_arm and
|
|
builtin.zig_backend != .stage2_aarch64 and
|
|
is_x86_64_linux)
|
|
{
|
|
asm (
|
|
\\.globl this_is_my_alias;
|
|
\\.type this_is_my_alias, @function;
|
|
\\.set this_is_my_alias, derp;
|
|
);
|
|
}
|
|
}
|
|
|
|
test "module level assembly" {
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_x86_64) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
|
|
|
|
if (is_x86_64_linux) {
|
|
try expect(this_is_my_alias() == 1234);
|
|
}
|
|
}
|
|
|
|
test "output constraint modifiers" {
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_x86_64) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
|
|
|
|
// This is only testing compilation.
|
|
var a: u32 = 3;
|
|
asm volatile (""
|
|
: [_] "=m,r" (a),
|
|
:
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
: [_] "=r,m" (a),
|
|
:
|
|
: ""
|
|
);
|
|
}
|
|
|
|
test "alternative constraints" {
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_x86_64) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
|
|
|
|
// Make sure we allow commas as a separator for alternative constraints.
|
|
var a: u32 = 3;
|
|
asm volatile (""
|
|
: [_] "=r,m" (a),
|
|
: [_] "r,m" (a),
|
|
: ""
|
|
);
|
|
}
|
|
|
|
test "sized integer/float in asm input" {
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_x86_64) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
|
|
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(usize, 3)),
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(i15, -3)),
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(u3, 3)),
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(i3, 3)),
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(u121, 3)),
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(i121, 3)),
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(f32, 3.17)),
|
|
: ""
|
|
);
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(f64, 3.17)),
|
|
: ""
|
|
);
|
|
}
|
|
|
|
test "struct/array/union types as input values" {
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_x86_64) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
|
|
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as([1]u32, undefined)),
|
|
); // fails
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(struct { x: u32, y: u8 }, undefined)),
|
|
); // fails
|
|
asm volatile (""
|
|
:
|
|
: [_] "m" (@as(union { x: u32, y: u8 }, undefined)),
|
|
); // fails
|
|
}
|
|
|
|
extern fn this_is_my_alias() i32;
|
|
|
|
export fn derp() i32 {
|
|
return 1234;
|
|
}
|
|
|
|
test "asm modifiers (AArch64)" {
|
|
if (builtin.target.cpu.arch != .aarch64) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
|
|
if (builtin.zig_backend == .stage2_c) return error.SkipZigTest; // TODO
|
|
|
|
var x: u32 = 15;
|
|
const double = asm ("add %[ret:w], %[in:w], %[in:w]"
|
|
: [ret] "=r" (-> u32),
|
|
: [in] "r" (x),
|
|
);
|
|
try expect(double == 2 * x);
|
|
}
|