master
 1const std = @import("../../std.zig");
 2
 3const bits = switch (@import("builtin").cpu.arch) {
 4    .mips,
 5    .mipsel,
 6    .mips64,
 7    .mips64el,
 8    .powerpc,
 9    .powerpcle,
10    .powerpc64,
11    .powerpc64le,
12    .sparc,
13    .sparc64,
14    => .{ .size = 13, .dir = 3, .none = 1, .read = 2, .write = 4 },
15    else => .{ .size = 14, .dir = 2, .none = 0, .read = 2, .write = 1 },
16};
17
18const Direction = std.meta.Int(.unsigned, bits.dir);
19
20pub const Request = packed struct {
21    nr: u8,
22    io_type: u8,
23    size: std.meta.Int(.unsigned, bits.size),
24    dir: Direction,
25};
26
27fn io_impl(dir: Direction, io_type: u8, nr: u8, comptime T: type) u32 {
28    const request = Request{
29        .dir = dir,
30        .size = @sizeOf(T),
31        .io_type = io_type,
32        .nr = nr,
33    };
34    return @as(u32, @bitCast(request));
35}
36
37pub fn IO(io_type: u8, nr: u8) u32 {
38    return io_impl(bits.none, io_type, nr, void);
39}
40
41pub fn IOR(io_type: u8, nr: u8, comptime T: type) u32 {
42    return io_impl(bits.read, io_type, nr, T);
43}
44
45pub fn IOW(io_type: u8, nr: u8, comptime T: type) u32 {
46    return io_impl(bits.write, io_type, nr, T);
47}
48
49pub fn IOWR(io_type: u8, nr: u8, comptime T: type) u32 {
50    return io_impl(bits.read | bits.write, io_type, nr, T);
51}
52
53comptime {
54    std.debug.assert(@bitSizeOf(Request) == 32);
55}