-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathstackFrame.h
89 lines (70 loc) · 2.26 KB
/
stackFrame.h
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
/*
* Copyright 2017 Andrei Pangin
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef _STACKFRAME_H
#define _STACKFRAME_H
#include "arch.h"
#include <stdint.h>
#include <ucontext.h>
class NMethod;
class StackFrame {
private:
ucontext_t *_ucontext;
static bool withinCurrentStack(uintptr_t address) {
// Check that the address is not too far from the stack pointer of current
// context
void *real_sp;
return address - (uintptr_t)&real_sp <= 0xffff;
}
public:
explicit StackFrame(void *ucontext) { _ucontext = (ucontext_t *)ucontext; }
void restore(uintptr_t saved_pc, uintptr_t saved_sp, uintptr_t saved_fp) {
if (_ucontext != NULL) {
pc() = saved_pc;
sp() = saved_sp;
fp() = saved_fp;
}
}
uintptr_t stackAt(int slot) { return ((uintptr_t *)sp())[slot]; }
uintptr_t &pc();
uintptr_t &sp();
uintptr_t &fp();
uintptr_t &retval();
uintptr_t link();
uintptr_t arg0();
uintptr_t arg1();
uintptr_t arg2();
uintptr_t arg3();
uintptr_t jarg0();
uintptr_t method();
uintptr_t senderSP();
void ret();
bool unwindStub(instruction_t *entry, const char *name) {
return unwindStub(entry, name, pc(), sp(), fp());
}
bool unwindCompiled(NMethod *nm) {
return unwindCompiled(nm, pc(), sp(), fp());
}
bool unwindStub(instruction_t *entry, const char *name, uintptr_t &pc,
uintptr_t &sp, uintptr_t &fp);
bool unwindCompiled(NMethod *nm, uintptr_t &pc, uintptr_t &sp, uintptr_t &fp);
bool unwindAtomicStub(const void*& pc);
void adjustSP(const void *entry, const void *pc, uintptr_t &sp);
bool skipFaultInstruction();
bool checkInterruptedSyscall();
// Check if PC points to a syscall instruction
static bool isSyscall(instruction_t *pc);
};
#endif // _STACKFRAME_H