aboutsummaryrefslogtreecommitdiff
path: root/src/link/aarch64.zig
blob: c9defc27b319344e8e7f6d574cfb7625bcceffcd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
pub const encoding = @import("../codegen.zig").aarch64.encoding;

pub fn writeAddImmInst(value: u12, code: *[4]u8) void {
    var inst: encoding.Instruction = .read(code);
    inst.data_processing_immediate.add_subtract_immediate.group.imm12 = value;
    inst.write(code);
}

pub fn writeLoadStoreRegInst(value: u12, code: *[4]u8) void {
    var inst: encoding.Instruction = .read(code);
    inst.load_store.register_unsigned_immediate.group.imm12 = value;
    inst.write(code);
}

pub fn calcNumberOfPages(saddr: i64, taddr: i64) error{Overflow}!i33 {
    return math.cast(i21, (taddr >> 12) - (saddr >> 12)) orelse error.Overflow;
}

pub fn writeAdrInst(imm: i33, code: *[4]u8) void {
    var inst: encoding.Instruction = .read(code);
    inst.data_processing_immediate.pc_relative_addressing.group.immhi = @intCast(imm >> 2);
    inst.data_processing_immediate.pc_relative_addressing.group.immlo = @bitCast(@as(i2, @truncate(imm)));
    inst.write(code);
}

pub fn writeBranchImm(disp: i28, code: *[4]u8) void {
    var inst: encoding.Instruction = .read(code);
    inst.branch_exception_generating_system.unconditional_branch_immediate.group.imm26 = @intCast(@shrExact(disp, 2));
    inst.write(code);
}

const assert = std.debug.assert;
const builtin = @import("builtin");
const math = std.math;
const mem = std.mem;
const std = @import("std");