Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openjdk-multiarch-jdk8u
Path: blob/aarch64-shenandoah-jdk8u272-b10/hotspot/agent/src/os/linux/libproc.h
38833 views
1
/*
2
* Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation.
8
*
9
* This code is distributed in the hope that it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12
* version 2 for more details (a copy is included in the LICENSE file that
13
* accompanied this code).
14
*
15
* You should have received a copy of the GNU General Public License version
16
* 2 along with this work; if not, write to the Free Software Foundation,
17
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18
*
19
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20
* or visit www.oracle.com if you need additional information or have any
21
* questions.
22
*
23
*/
24
25
#ifndef _LIBPROC_H_
26
#define _LIBPROC_H_
27
28
#include <jni.h>
29
#include <unistd.h>
30
#include <stdint.h>
31
#include "proc_service.h"
32
33
#ifdef ALT_SASRCDIR
34
#include "libproc_md.h"
35
#endif
36
37
#include <sys/ptrace.h>
38
39
#if defined(aarch64)
40
#include "asm/ptrace.h"
41
#endif
42
43
/************************************************************************************
44
45
0. This is very minimal subset of Solaris libproc just enough for current application.
46
Please note that the bulk of the functionality is from proc_service interface. This
47
adds Pgrab__ and some missing stuff. We hide the difference b/w live process and core
48
file by this interface.
49
50
1. pthread_id unique in both NPTL & LinuxThreads. We store this in
51
OSThread::_pthread_id in JVM code.
52
53
2. All threads see the same pid when they call getpid() under NPTL.
54
Threads receive different pid under LinuxThreads. We used to save the result of
55
::getpid() call in OSThread::_thread_id. This way uniqueness of OSThread::_thread_id
56
was lost under NPTL. Now, we store the result of ::gettid() call in
57
OSThread::_thread_id. Because gettid returns actual pid of thread (lwp id), this is
58
unique again. We therefore use OSThread::_thread_id as unique identifier.
59
60
3. There is a unique LWP id under both thread libraries. libthread_db maps pthread_id
61
to its underlying lwp_id under both the thread libraries. thread_info.lwp_id stores
62
lwp_id of the thread. The lwp id is nothing but the actual pid of clone'd processes. But
63
unfortunately libthread_db does not work very well for core dumps. So, we get pthread_id
64
only for processes. For core dumps, we don't use libthread_db at all (like gdb).
65
66
4. ptrace operates on this LWP id under both the thread libraries. When we say 'pid' for
67
ptrace call, we refer to lwp_id of the thread.
68
69
5. for core file, we parse ELF files and read data from them. For processes we use
70
combination of ptrace and /proc calls.
71
72
*************************************************************************************/
73
74
75
#if defined(sparc) || defined(sparcv9) || defined(ppc64)
76
#include <asm/ptrace.h>
77
#define user_regs_struct pt_regs
78
#endif
79
#if defined(aarch64)
80
#define user_regs_struct user_pt_regs
81
#endif
82
83
// This C bool type must be int for compatibility with Linux calls and
84
// it would be a mistake to equivalence it to C++ bool on many platforms
85
86
typedef int bool;
87
#define true 1
88
#define false 0
89
90
struct ps_prochandle;
91
92
// attach to a process
93
struct ps_prochandle* Pgrab(pid_t pid, char* err_buf, size_t err_buf_len);
94
95
// attach to a core dump
96
struct ps_prochandle* Pgrab_core(const char* execfile, const char* corefile);
97
98
// release a process or core
99
void Prelease(struct ps_prochandle* ph);
100
101
// functions not directly available in Solaris libproc
102
103
// initialize libproc (call this only once per app)
104
// pass true to make library verbose
105
bool init_libproc(bool verbose);
106
107
// get number of threads
108
int get_num_threads(struct ps_prochandle* ph);
109
110
// get lwp_id of n'th thread
111
lwpid_t get_lwp_id(struct ps_prochandle* ph, int index);
112
113
// get regs for a given lwp
114
bool get_lwp_regs(struct ps_prochandle* ph, lwpid_t lid, struct user_regs_struct* regs);
115
116
// get number of shared objects
117
int get_num_libs(struct ps_prochandle* ph);
118
119
// get name of n'th lib
120
const char* get_lib_name(struct ps_prochandle* ph, int index);
121
122
// get base of lib
123
uintptr_t get_lib_base(struct ps_prochandle* ph, int index);
124
125
// returns true if given library is found in lib list
126
bool find_lib(struct ps_prochandle* ph, const char *lib_name);
127
128
// symbol lookup
129
uintptr_t lookup_symbol(struct ps_prochandle* ph, const char* object_name,
130
const char* sym_name);
131
132
// address->nearest symbol lookup. return NULL for no symbol
133
const char* symbol_for_pc(struct ps_prochandle* ph, uintptr_t addr, uintptr_t* poffset);
134
135
struct ps_prochandle* get_proc_handle(JNIEnv* env, jobject this_obj);
136
137
void throw_new_debugger_exception(JNIEnv* env, const char* errMsg);
138
139
#endif //__LIBPROC_H_
140
141