File: xray_trampoline_riscv32.S

package info (click to toggle)
llvm-toolchain-20 1%3A20.1.6-1~exp1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 2,111,304 kB
  • sloc: cpp: 7,438,677; ansic: 1,393,822; asm: 1,012,926; python: 241,650; f90: 86,635; objc: 75,479; lisp: 42,144; pascal: 17,286; sh: 10,027; ml: 5,082; perl: 4,730; awk: 3,523; makefile: 3,349; javascript: 2,251; xml: 892; fortran: 672
file content (89 lines) | stat: -rw-r--r-- 1,922 bytes parent folder | download | duplicates (9)
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
//===-- xray_trampoline_riscv32.s ----------------------------------*- ASM -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// This file is a part of XRay, a dynamic runtime instrumentation system.
//
// This implements the riscv32-specific assembler for the trampolines.
//
//===----------------------------------------------------------------------===//

#include "../sanitizer_common/sanitizer_asm.h"

.macro SAVE_ARG_REGISTERS
	// Push argument registers to stack
	addi	sp, sp, -112
        CFI_DEF_CFA_OFFSET(112)
	sw	ra, 108(sp)
	sw	a7, 104(sp)
	sw	a6, 100(sp)
	sw	a5, 96(sp)
	sw	a4, 92(sp)
	sw	a3, 88(sp)
	sw	a2, 84(sp)
	sw	a1, 80(sp)
	sw	a0, 76(sp)
	fsd	fa7, 64(sp)
	fsd	fa6, 56(sp)
	fsd	fa5, 48(sp)
	fsd	fa4, 40(sp)
	fsd	fa3, 32(sp)
	fsd	fa2, 24(sp)
	fsd	fa1, 16(sp)
	fsd	fa0, 8(sp)
.endm

.macro RESTORE_ARG_REGISTERS
	// Restore argument registers
	fld	fa0, 8(sp)
	fld	fa1, 16(sp)
	fld	fa2, 24(sp)
	fld	fa3, 32(sp)
	fld	fa4, 40(sp)
	fld	fa5, 48(sp)
	fld	fa6, 56(sp)
	fld	fa7, 64(sp)
	lw	a0, 76(sp)
	lw	a1, 80(sp)
	lw	a2, 84(sp)
	lw	a3, 88(sp)
	lw	a4, 92(sp)
	lw	a5, 96(sp)
	lw	a6, 100(sp)
	lw	a7, 104(sp)
	lw	ra, 108(sp)
	addi	sp, sp, 112
        CFI_DEF_CFA_OFFSET(0)
.endm

.macro SAVE_RET_REGISTERS
	// Push return registers to stack
	addi	sp, sp, -32
        CFI_DEF_CFA_OFFSET(32)
	sw	ra, 28(sp)
	sw	a1, 24(sp)
	sw	a0, 20(sp)
	fsd	fa1, 8(sp)
	fsd	fa0, 0(sp)
.endm

.macro RESTORE_RET_REGISTERS
	// Restore return registers
	fld	fa0, 0(sp)
	fld	fa1, 8(sp)
	lw	a0, 20(sp)
	lw	a1, 24(sp)
	lw	ra, 28(sp)
	addi	sp, sp, 32
        CFI_DEF_CFA_OFFSET(0)
.endm

.macro LOAD_XLEN, rd, src
        lw      \rd, \src
.endm

#include "xray_trampoline_riscv_common.S"