src/jdk.hotspot.agent/linux/native/libsaproc/LinuxDebuggerLocal.c
author herrick
Tue, 09 Apr 2019 10:57:04 -0400
branchJDK-8200758-branch
changeset 57314 23da9e6f446f
parent 53379 e47074d2d8cc
child 55069 6e0786d8451b
permissions -rw-r--r--
8221641: Follow up code clean up for JDK-8221582 Reviewed-by: almatvee
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
53379
e47074d2d8cc 8181313: SA: Remove libthread_db dependency on Linux
ysuenaga
parents: 51203
diff changeset
     2
 * Copyright (c) 2002, 2019, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
#include <jni.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
#include "libproc.h"
53379
e47074d2d8cc 8181313: SA: Remove libthread_db dependency on Linux
ysuenaga
parents: 51203
diff changeset
    27
#include "proc_service.h"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
15850
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
    29
#include <elf.h>
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
    30
#include <sys/types.h>
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
    31
#include <sys/stat.h>
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
    32
#include <fcntl.h>
20295
a5dd1b071c32 8025613: clang: remove -Wno-unused-value
twisti
parents: 15850
diff changeset
    33
#include <stdlib.h>
15850
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
    34
#include <string.h>
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
    35
#include <limits.h>
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
    36
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
#if defined(x86_64) && !defined(amd64)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
#define amd64 1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
#ifdef i386
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
#include "sun_jvm_hotspot_debugger_x86_X86ThreadContext.h"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
#ifdef amd64
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
#include "sun_jvm_hotspot_debugger_amd64_AMD64ThreadContext.h"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
#if defined(sparc) || defined(sparcv9)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
#include "sun_jvm_hotspot_debugger_sparc_SPARCThreadContext.h"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
35075
ca79cbf3f106 8073139: PPC64: User-visible arch directory and os.arch value on ppc64le cause issues with Java tooling
asmundak
parents: 35049
diff changeset
    53
#if defined(ppc64) || defined(ppc64le)
28369
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
    54
#include "sun_jvm_hotspot_debugger_ppc64_PPC64ThreadContext.h"
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
    55
#endif
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
    56
31399
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
    57
#ifdef aarch64
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
    58
#include "sun_jvm_hotspot_debugger_aarch64_AARCH64ThreadContext.h"
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
    59
#endif
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
    60
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
static jfieldID p_ps_prochandle_ID = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
static jfieldID threadList_ID = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
static jfieldID loadObjectList_ID = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
static jmethodID createClosestSymbol_ID = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
static jmethodID createLoadObject_ID = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
static jmethodID getThreadForThreadId_ID = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
static jmethodID listAdd_ID = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
51203
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
    70
/*
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
    71
 * SA_ALTROOT environment variable.
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
    72
 * This memory holds env string for putenv(3).
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
    73
 */
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
    74
static char *saaltroot = NULL;
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
    75
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
#define CHECK_EXCEPTION_(value) if ((*env)->ExceptionOccurred(env)) { return value; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
#define CHECK_EXCEPTION if ((*env)->ExceptionOccurred(env)) { return;}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
#define THROW_NEW_DEBUGGER_EXCEPTION_(str, value) { throw_new_debugger_exception(env, str); return value; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
#define THROW_NEW_DEBUGGER_EXCEPTION(str) { throw_new_debugger_exception(env, str); return;}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
13529
dc25e69fd16d 7154641: Servicability agent should work on platforms other than x86, sparc
bpittore
parents: 5547
diff changeset
    81
void throw_new_debugger_exception(JNIEnv* env, const char* errMsg) {
26411
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
    82
  jclass clazz;
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
    83
  clazz = (*env)->FindClass(env, "sun/jvm/hotspot/debugger/DebuggerException");
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
    84
  CHECK_EXCEPTION;
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
    85
  (*env)->ThrowNew(env, clazz, errMsg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
13529
dc25e69fd16d 7154641: Servicability agent should work on platforms other than x86, sparc
bpittore
parents: 5547
diff changeset
    88
struct ps_prochandle* get_proc_handle(JNIEnv* env, jobject this_obj) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
  jlong ptr = (*env)->GetLongField(env, this_obj, p_ps_prochandle_ID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
  return (struct ps_prochandle*)(intptr_t)ptr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
 * Method:    init0
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
 * Signature: ()V
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
JNIEXPORT void JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_init0
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
  (JNIEnv *env, jclass cls) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
  jclass listClass;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
20295
a5dd1b071c32 8025613: clang: remove -Wno-unused-value
twisti
parents: 15850
diff changeset
   102
  if (init_libproc(getenv("LIBSAPROC_DEBUG") != NULL) != true) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
     THROW_NEW_DEBUGGER_EXCEPTION("can't initialize libproc");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
  // fields we use
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
  p_ps_prochandle_ID = (*env)->GetFieldID(env, cls, "p_ps_prochandle", "J");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
  threadList_ID = (*env)->GetFieldID(env, cls, "threadList", "Ljava/util/List;");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
  loadObjectList_ID = (*env)->GetFieldID(env, cls, "loadObjectList", "Ljava/util/List;");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
  // methods we use
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
  createClosestSymbol_ID = (*env)->GetMethodID(env, cls, "createClosestSymbol",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
                    "(Ljava/lang/String;J)Lsun/jvm/hotspot/debugger/cdbg/ClosestSymbol;");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
  createLoadObject_ID = (*env)->GetMethodID(env, cls, "createLoadObject",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
                    "(Ljava/lang/String;JJ)Lsun/jvm/hotspot/debugger/cdbg/LoadObject;");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
  getThreadForThreadId_ID = (*env)->GetMethodID(env, cls, "getThreadForThreadId",
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
                                                     "(J)Lsun/jvm/hotspot/debugger/ThreadProxy;");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
  // java.util.List method we call
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
  listClass = (*env)->FindClass(env, "java/util/List");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
  listAdd_ID = (*env)->GetMethodID(env, listClass, "add", "(Ljava/lang/Object;)Z");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
JNIEXPORT jint JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_getAddressSize
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
  (JNIEnv *env, jclass cls)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
#ifdef _LP64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
 return 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
 return 4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
static void fillThreadsAndLoadObjects(JNIEnv* env, jobject this_obj, struct ps_prochandle* ph) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
  int n = 0, i = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
  // add threads
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
  n = get_num_threads(ph);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
  for (i = 0; i < n; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
    jobject thread;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
    jobject threadList;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
    lwpid_t lwpid;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
    lwpid = get_lwp_id(ph, i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
    thread = (*env)->CallObjectMethod(env, this_obj, getThreadForThreadId_ID,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
                                      (jlong)lwpid);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
    CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
    threadList = (*env)->GetObjectField(env, this_obj, threadList_ID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
    CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
    (*env)->CallBooleanMethod(env, threadList, listAdd_ID, thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
    CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
  // add load objects
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
  n = get_num_libs(ph);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
  for (i = 0; i < n; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
     uintptr_t base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
     const char* name;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
     jobject loadObject;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
     jobject loadObjectList;
26411
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   170
     jstring str;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
     base = get_lib_base(ph, i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
     name = get_lib_name(ph, i);
26411
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   174
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   175
     str = (*env)->NewStringUTF(env, name);
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   176
     CHECK_EXCEPTION;
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   177
     loadObject = (*env)->CallObjectMethod(env, this_obj, createLoadObject_ID, str, (jlong)0, (jlong)base);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
     CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
     loadObjectList = (*env)->GetObjectField(env, this_obj, loadObjectList_ID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
     CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
     (*env)->CallBooleanMethod(env, loadObjectList, listAdd_ID, loadObject);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
     CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
15850
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   186
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   187
/*
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   188
 * Verify that a named ELF binary file (core or executable) has the same
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   189
 * bitness as ourselves.
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   190
 * Throw an exception if there is a mismatch or other problem.
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   191
 *
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   192
 * If we proceed using a mismatched debugger/debuggee, the best to hope
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   193
 * for is a missing symbol, the worst is a crash searching for debug symbols.
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   194
 */
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   195
void verifyBitness(JNIEnv *env, const char *binaryName) {
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   196
  int fd = open(binaryName, O_RDONLY);
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   197
  if (fd < 0) {
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   198
    THROW_NEW_DEBUGGER_EXCEPTION("cannot open binary file");
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   199
  }
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   200
  unsigned char elf_ident[EI_NIDENT];
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   201
  int i = read(fd, &elf_ident, sizeof(elf_ident));
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   202
  close(fd);
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   203
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   204
  if (i < 0) {
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   205
    THROW_NEW_DEBUGGER_EXCEPTION("cannot read binary file");
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   206
  }
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   207
#ifndef _LP64
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   208
  if (elf_ident[EI_CLASS] == ELFCLASS64) {
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   209
    THROW_NEW_DEBUGGER_EXCEPTION("debuggee is 64 bit, use 64-bit java for debugger");
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   210
  }
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   211
#else
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   212
  if (elf_ident[EI_CLASS] != ELFCLASS64) {
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   213
    THROW_NEW_DEBUGGER_EXCEPTION("debuggee is 32 bit, use 32 bit java for debugger");
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   214
  }
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   215
#endif
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   216
}
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   217
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   218
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   219
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
51203
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   221
 * Method:    setSAAltRoot0
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   222
 * Signature: (Ljava/lang/String;)V
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
 */
51203
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   224
JNIEXPORT void JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_setSAAltRoot0
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   225
  (JNIEnv *env, jobject this_obj, jstring altroot) {
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   226
  if (saaltroot != NULL) {
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   227
    free(saaltroot);
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   228
  }
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   229
  const char *path = (*env)->GetStringUTFChars(env, altroot, JNI_FALSE);
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   230
  /*
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   231
   * `saaltroot` is used for putenv().
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   232
   * So we need to keep this memory.
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   233
   */
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   234
  static const char *PREFIX = "SA_ALTROOT=";
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   235
  size_t len = strlen(PREFIX) + strlen(path) + 1;
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   236
  saaltroot = (char *)malloc(len);
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   237
  snprintf(saaltroot, len, "%s%s", PREFIX, path);
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   238
  putenv(saaltroot);
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   239
  (*env)->ReleaseStringUTFChars(env, altroot, path);
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   240
}
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   241
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   242
/*
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   243
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   244
 * Method:    attach0
53379
e47074d2d8cc 8181313: SA: Remove libthread_db dependency on Linux
ysuenaga
parents: 51203
diff changeset
   245
 * Signature: (I)V
51203
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   246
 */
53379
e47074d2d8cc 8181313: SA: Remove libthread_db dependency on Linux
ysuenaga
parents: 51203
diff changeset
   247
JNIEXPORT void JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_attach0__I
e47074d2d8cc 8181313: SA: Remove libthread_db dependency on Linux
ysuenaga
parents: 51203
diff changeset
   248
  (JNIEnv *env, jobject this_obj, jint jpid) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
15850
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   250
  // For bitness checking, locate binary at /proc/jpid/exe
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   251
  char buf[PATH_MAX];
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   252
  snprintf((char *) &buf, PATH_MAX, "/proc/%d/exe", jpid);
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   253
  verifyBitness(env, (char *) &buf);
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   254
  CHECK_EXCEPTION;
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   255
35049
5a30aa672689 8145099: Better error message when SA can't attach to a process
sla
parents: 31399
diff changeset
   256
  char err_buf[200];
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
  struct ps_prochandle* ph;
53379
e47074d2d8cc 8181313: SA: Remove libthread_db dependency on Linux
ysuenaga
parents: 51203
diff changeset
   258
  if ((ph = Pgrab(jpid, err_buf, sizeof(err_buf))) == NULL) {
35049
5a30aa672689 8145099: Better error message when SA can't attach to a process
sla
parents: 31399
diff changeset
   259
    char msg[230];
5a30aa672689 8145099: Better error message when SA can't attach to a process
sla
parents: 31399
diff changeset
   260
    snprintf(msg, sizeof(msg), "Can't attach to the process: %s", err_buf);
5a30aa672689 8145099: Better error message when SA can't attach to a process
sla
parents: 31399
diff changeset
   261
    THROW_NEW_DEBUGGER_EXCEPTION(msg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
  (*env)->SetLongField(env, this_obj, p_ps_prochandle_ID, (jlong)(intptr_t)ph);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
  fillThreadsAndLoadObjects(env, this_obj, ph);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
 * Method:    attach0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
 * Signature: (Ljava/lang/String;Ljava/lang/String;)V
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
JNIEXPORT void JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_attach0__Ljava_lang_String_2Ljava_lang_String_2
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
  (JNIEnv *env, jobject this_obj, jstring execName, jstring coreName) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
  const char *execName_cstr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
  const char *coreName_cstr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
  jboolean isCopy;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
  struct ps_prochandle* ph;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
  execName_cstr = (*env)->GetStringUTFChars(env, execName, &isCopy);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
  coreName_cstr = (*env)->GetStringUTFChars(env, coreName, &isCopy);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
  CHECK_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
15850
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   284
  verifyBitness(env, execName_cstr);
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   285
  CHECK_EXCEPTION;
0d2f541fd6ed 8008807: SA: jstack crash when target has mismatched bitness (Linux)
kevinw
parents: 15475
diff changeset
   286
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
  if ( (ph = Pgrab_core(execName_cstr, coreName_cstr)) == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
    (*env)->ReleaseStringUTFChars(env, execName, execName_cstr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
    (*env)->ReleaseStringUTFChars(env, coreName, coreName_cstr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
    THROW_NEW_DEBUGGER_EXCEPTION("Can't attach to the core file");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
  (*env)->SetLongField(env, this_obj, p_ps_prochandle_ID, (jlong)(intptr_t)ph);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
  (*env)->ReleaseStringUTFChars(env, execName, execName_cstr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
  (*env)->ReleaseStringUTFChars(env, coreName, coreName_cstr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
  fillThreadsAndLoadObjects(env, this_obj, ph);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
 * Method:    detach0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
 * Signature: ()V
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
JNIEXPORT void JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_detach0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
  (JNIEnv *env, jobject this_obj) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
  struct ps_prochandle* ph = get_proc_handle(env, this_obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
  if (ph != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
     Prelease(ph);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
  }
51203
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   309
  if (saaltroot != NULL) {
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   310
    free(saaltroot);
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   311
    saaltroot = NULL;
220c9188db4f 8205992: jhsdb cannot attach to Java processes running in Docker containers
ysuenaga
parents: 47216
diff changeset
   312
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
489c9b5090e2 Initial load
duke
parents:
diff changeset
   315
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
 * Method:    lookupByName0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
 * Signature: (Ljava/lang/String;Ljava/lang/String;)J
489c9b5090e2 Initial load
duke
parents:
diff changeset
   319
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
JNIEXPORT jlong JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_lookupByName0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
  (JNIEnv *env, jobject this_obj, jstring objectName, jstring symbolName) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
  const char *objectName_cstr, *symbolName_cstr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
  jlong addr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
  jboolean isCopy;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
  struct ps_prochandle* ph = get_proc_handle(env, this_obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
  objectName_cstr = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
  if (objectName != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
    objectName_cstr = (*env)->GetStringUTFChars(env, objectName, &isCopy);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
    CHECK_EXCEPTION_(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
  symbolName_cstr = (*env)->GetStringUTFChars(env, symbolName, &isCopy);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
  CHECK_EXCEPTION_(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   334
489c9b5090e2 Initial load
duke
parents:
diff changeset
   335
  addr = (jlong) lookup_symbol(ph, objectName_cstr, symbolName_cstr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   336
489c9b5090e2 Initial load
duke
parents:
diff changeset
   337
  if (objectName_cstr != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   338
    (*env)->ReleaseStringUTFChars(env, objectName, objectName_cstr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   339
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
  (*env)->ReleaseStringUTFChars(env, symbolName, symbolName_cstr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   341
  return addr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   342
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
489c9b5090e2 Initial load
duke
parents:
diff changeset
   344
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   345
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
 * Method:    lookupByAddress0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
 * Signature: (J)Lsun/jvm/hotspot/debugger/cdbg/ClosestSymbol;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
JNIEXPORT jobject JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_lookupByAddress0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   350
  (JNIEnv *env, jobject this_obj, jlong addr) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   351
  uintptr_t offset;
26411
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   352
  jobject obj;
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   353
  jstring str;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   354
  const char* sym = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   355
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
  struct ps_prochandle* ph = get_proc_handle(env, this_obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
  sym = symbol_for_pc(ph, (uintptr_t) addr, &offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
  if (sym == NULL) return 0;
26411
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   359
  str = (*env)->NewStringUTF(env, sym);
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   360
  CHECK_EXCEPTION_(NULL);
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   361
  obj = (*env)->CallObjectMethod(env, this_obj, createClosestSymbol_ID, str, (jlong)offset);
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   362
  CHECK_EXCEPTION_(NULL);
8daa5fdf642f 8029172: warnings from b117 for hotspot.agent.src.os.linux: JNI exception pending
dsamersoff
parents: 20295
diff changeset
   363
  return obj;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   365
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   367
 * Class:     sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   368
 * Method:    readBytesFromProcess0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   369
 * Signature: (JJ)Lsun/jvm/hotspot/debugger/ReadResult;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   370
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   371
JNIEXPORT jbyteArray JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_readBytesFromProcess0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   372
  (JNIEnv *env, jobject this_obj, jlong addr, jlong numBytes) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
  jboolean isCopy;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
  jbyteArray array;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   376
  jbyte *bufPtr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
  ps_err_e err;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
  array = (*env)->NewByteArray(env, numBytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   380
  CHECK_EXCEPTION_(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   381
  bufPtr = (*env)->GetByteArrayElements(env, array, &isCopy);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   382
  CHECK_EXCEPTION_(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
  err = ps_pdread(get_proc_handle(env, this_obj), (psaddr_t) (uintptr_t)addr, bufPtr, numBytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   385
  (*env)->ReleaseByteArrayElements(env, array, bufPtr, 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
  return (err == PS_OK)? array : 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   387
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   388
35075
ca79cbf3f106 8073139: PPC64: User-visible arch directory and os.arch value on ppc64le cause issues with Java tooling
asmundak
parents: 35049
diff changeset
   389
#if defined(i386) || defined(amd64) || defined(sparc) || defined(sparcv9) | defined(ppc64) || defined(ppc64le) || defined(aarch64)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
JNIEXPORT jlongArray JNICALL Java_sun_jvm_hotspot_debugger_linux_LinuxDebuggerLocal_getThreadIntegerRegisterSet0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
  (JNIEnv *env, jobject this_obj, jint lwp_id) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
  struct user_regs_struct gregs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
  jboolean isCopy;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   395
  jlongArray array;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   396
  jlong *regs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   397
  int i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
489c9b5090e2 Initial load
duke
parents:
diff changeset
   399
  struct ps_prochandle* ph = get_proc_handle(env, this_obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   400
  if (get_lwp_regs(ph, lwp_id, &gregs) != true) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
     THROW_NEW_DEBUGGER_EXCEPTION_("get_thread_regs failed for a lwp", 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
#undef NPRGREG
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
#ifdef i386
489c9b5090e2 Initial load
duke
parents:
diff changeset
   406
#define NPRGREG sun_jvm_hotspot_debugger_x86_X86ThreadContext_NPRGREG
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   408
#ifdef amd64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
#define NPRGREG sun_jvm_hotspot_debugger_amd64_AMD64ThreadContext_NPRGREG
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
#endif
29180
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   411
#ifdef aarch64
31399
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   412
#define NPRGREG sun_jvm_hotspot_debugger_aarch64_AARCH64ThreadContext_NPRGREG
29180
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   413
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
#if defined(sparc) || defined(sparcv9)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   415
#define NPRGREG sun_jvm_hotspot_debugger_sparc_SPARCThreadContext_NPRGREG
489c9b5090e2 Initial load
duke
parents:
diff changeset
   416
#endif
35075
ca79cbf3f106 8073139: PPC64: User-visible arch directory and os.arch value on ppc64le cause issues with Java tooling
asmundak
parents: 35049
diff changeset
   417
#if defined(ppc64) || defined(ppc64le)
28369
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   418
#define NPRGREG sun_jvm_hotspot_debugger_ppc64_PPC64ThreadContext_NPRGREG
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   419
#endif
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   420
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
  array = (*env)->NewLongArray(env, NPRGREG);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
  CHECK_EXCEPTION_(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
  regs = (*env)->GetLongArrayElements(env, array, &isCopy);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   425
489c9b5090e2 Initial load
duke
parents:
diff changeset
   426
#undef REG_INDEX
489c9b5090e2 Initial load
duke
parents:
diff changeset
   427
489c9b5090e2 Initial load
duke
parents:
diff changeset
   428
#ifdef i386
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
#define REG_INDEX(reg) sun_jvm_hotspot_debugger_x86_X86ThreadContext_##reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
489c9b5090e2 Initial load
duke
parents:
diff changeset
   431
  regs[REG_INDEX(GS)]  = (uintptr_t) gregs.xgs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   432
  regs[REG_INDEX(FS)]  = (uintptr_t) gregs.xfs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
  regs[REG_INDEX(ES)]  = (uintptr_t) gregs.xes;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
  regs[REG_INDEX(DS)]  = (uintptr_t) gregs.xds;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   435
  regs[REG_INDEX(EDI)] = (uintptr_t) gregs.edi;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   436
  regs[REG_INDEX(ESI)] = (uintptr_t) gregs.esi;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   437
  regs[REG_INDEX(FP)] = (uintptr_t) gregs.ebp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
  regs[REG_INDEX(SP)] = (uintptr_t) gregs.esp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
  regs[REG_INDEX(EBX)] = (uintptr_t) gregs.ebx;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
  regs[REG_INDEX(EDX)] = (uintptr_t) gregs.edx;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   441
  regs[REG_INDEX(ECX)] = (uintptr_t) gregs.ecx;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
  regs[REG_INDEX(EAX)] = (uintptr_t) gregs.eax;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
  regs[REG_INDEX(PC)] = (uintptr_t) gregs.eip;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
  regs[REG_INDEX(CS)]  = (uintptr_t) gregs.xcs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   445
  regs[REG_INDEX(SS)]  = (uintptr_t) gregs.xss;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
489c9b5090e2 Initial load
duke
parents:
diff changeset
   447
#endif /* i386 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   448
489c9b5090e2 Initial load
duke
parents:
diff changeset
   449
#ifdef amd64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   450
#define REG_INDEX(reg) sun_jvm_hotspot_debugger_amd64_AMD64ThreadContext_##reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
   451
489c9b5090e2 Initial load
duke
parents:
diff changeset
   452
  regs[REG_INDEX(R15)] = gregs.r15;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   453
  regs[REG_INDEX(R14)] = gregs.r14;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
  regs[REG_INDEX(R13)] = gregs.r13;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
  regs[REG_INDEX(R12)] = gregs.r12;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   456
  regs[REG_INDEX(RBP)] = gregs.rbp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   457
  regs[REG_INDEX(RBX)] = gregs.rbx;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
  regs[REG_INDEX(R11)] = gregs.r11;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   459
  regs[REG_INDEX(R10)] = gregs.r10;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   460
  regs[REG_INDEX(R9)] = gregs.r9;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   461
  regs[REG_INDEX(R8)] = gregs.r8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   462
  regs[REG_INDEX(RAX)] = gregs.rax;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
  regs[REG_INDEX(RCX)] = gregs.rcx;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
  regs[REG_INDEX(RDX)] = gregs.rdx;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   465
  regs[REG_INDEX(RSI)] = gregs.rsi;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   466
  regs[REG_INDEX(RDI)] = gregs.rdi;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
  regs[REG_INDEX(RIP)] = gregs.rip;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   468
  regs[REG_INDEX(CS)] = gregs.cs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
  regs[REG_INDEX(RSP)] = gregs.rsp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   470
  regs[REG_INDEX(SS)] = gregs.ss;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   471
  regs[REG_INDEX(FSBASE)] = gregs.fs_base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   472
  regs[REG_INDEX(GSBASE)] = gregs.gs_base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   473
  regs[REG_INDEX(DS)] = gregs.ds;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   474
  regs[REG_INDEX(ES)] = gregs.es;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   475
  regs[REG_INDEX(FS)] = gregs.fs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
  regs[REG_INDEX(GS)] = gregs.gs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
489c9b5090e2 Initial load
duke
parents:
diff changeset
   478
#endif /* amd64 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   479
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
#if defined(sparc) || defined(sparcv9)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
#define REG_INDEX(reg) sun_jvm_hotspot_debugger_sparc_SPARCThreadContext_##reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
489c9b5090e2 Initial load
duke
parents:
diff changeset
   484
#ifdef _LP64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
  regs[REG_INDEX(R_PSR)] = gregs.tstate;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
  regs[REG_INDEX(R_PC)]  = gregs.tpc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
  regs[REG_INDEX(R_nPC)] = gregs.tnpc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   488
  regs[REG_INDEX(R_Y)]   = gregs.y;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   489
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
  regs[REG_INDEX(R_PSR)] = gregs.psr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
  regs[REG_INDEX(R_PC)]  = gregs.pc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   492
  regs[REG_INDEX(R_nPC)] = gregs.npc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
  regs[REG_INDEX(R_Y)]   = gregs.y;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   494
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   495
  regs[REG_INDEX(R_G0)]  =            0 ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   496
  regs[REG_INDEX(R_G1)]  = gregs.u_regs[0];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   497
  regs[REG_INDEX(R_G2)]  = gregs.u_regs[1];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   498
  regs[REG_INDEX(R_G3)]  = gregs.u_regs[2];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
  regs[REG_INDEX(R_G4)]  = gregs.u_regs[3];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   500
  regs[REG_INDEX(R_G5)]  = gregs.u_regs[4];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   501
  regs[REG_INDEX(R_G6)]  = gregs.u_regs[5];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   502
  regs[REG_INDEX(R_G7)]  = gregs.u_regs[6];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   503
  regs[REG_INDEX(R_O0)]  = gregs.u_regs[7];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   504
  regs[REG_INDEX(R_O1)]  = gregs.u_regs[8];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   505
  regs[REG_INDEX(R_O2)]  = gregs.u_regs[ 9];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   506
  regs[REG_INDEX(R_O3)]  = gregs.u_regs[10];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   507
  regs[REG_INDEX(R_O4)]  = gregs.u_regs[11];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   508
  regs[REG_INDEX(R_O5)]  = gregs.u_regs[12];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
  regs[REG_INDEX(R_O6)]  = gregs.u_regs[13];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
  regs[REG_INDEX(R_O7)]  = gregs.u_regs[14];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   511
#endif /* sparc */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   512
29180
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   513
#if defined(aarch64)
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   514
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   515
#define REG_INDEX(reg) sun_jvm_hotspot_debugger_aarch64_AARCH64ThreadContext_##reg
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   516
31399
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   517
  {
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   518
    int i;
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   519
    for (i = 0; i < 31; i++)
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   520
      regs[i] = gregs.regs[i];
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   521
    regs[REG_INDEX(SP)] = gregs.sp;
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   522
    regs[REG_INDEX(PC)] = gregs.pc;
167037a29ab4 8078521: AARCH64: Add AArch64 SA support
aph
parents: 29185
diff changeset
   523
  }
29180
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   524
#endif /* aarch64 */
50369728b00e 8064611: AARCH64: Changes to HotSpot shared code
aph
parents: 26411
diff changeset
   525
35075
ca79cbf3f106 8073139: PPC64: User-visible arch directory and os.arch value on ppc64le cause issues with Java tooling
asmundak
parents: 35049
diff changeset
   526
#if defined(ppc64) || defined(ppc64le)
28369
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   527
#define REG_INDEX(reg) sun_jvm_hotspot_debugger_ppc64_PPC64ThreadContext_##reg
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   528
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   529
  regs[REG_INDEX(LR)] = gregs.link;
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   530
  regs[REG_INDEX(NIP)] = gregs.nip;
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   531
  regs[REG_INDEX(R0)]  = gregs.gpr[0];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   532
  regs[REG_INDEX(R1)]  = gregs.gpr[1];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   533
  regs[REG_INDEX(R2)]  = gregs.gpr[2];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   534
  regs[REG_INDEX(R3)]  = gregs.gpr[3];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   535
  regs[REG_INDEX(R4)]  = gregs.gpr[4];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   536
  regs[REG_INDEX(R5)]  = gregs.gpr[5];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   537
  regs[REG_INDEX(R6)]  = gregs.gpr[6];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   538
  regs[REG_INDEX(R7)]  = gregs.gpr[7];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   539
  regs[REG_INDEX(R8)]  = gregs.gpr[8];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   540
  regs[REG_INDEX(R9)]  = gregs.gpr[9];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   541
  regs[REG_INDEX(R10)] = gregs.gpr[10];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   542
  regs[REG_INDEX(R11)] = gregs.gpr[11];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   543
  regs[REG_INDEX(R12)] = gregs.gpr[12];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   544
  regs[REG_INDEX(R13)] = gregs.gpr[13];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   545
  regs[REG_INDEX(R14)] = gregs.gpr[14];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   546
  regs[REG_INDEX(R15)] = gregs.gpr[15];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   547
  regs[REG_INDEX(R16)] = gregs.gpr[16];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   548
  regs[REG_INDEX(R17)] = gregs.gpr[17];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   549
  regs[REG_INDEX(R18)] = gregs.gpr[18];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   550
  regs[REG_INDEX(R19)] = gregs.gpr[19];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   551
  regs[REG_INDEX(R20)] = gregs.gpr[20];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   552
  regs[REG_INDEX(R21)] = gregs.gpr[21];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   553
  regs[REG_INDEX(R22)] = gregs.gpr[22];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   554
  regs[REG_INDEX(R23)] = gregs.gpr[23];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   555
  regs[REG_INDEX(R24)] = gregs.gpr[24];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   556
  regs[REG_INDEX(R25)] = gregs.gpr[25];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   557
  regs[REG_INDEX(R26)] = gregs.gpr[26];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   558
  regs[REG_INDEX(R27)] = gregs.gpr[27];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   559
  regs[REG_INDEX(R28)] = gregs.gpr[28];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   560
  regs[REG_INDEX(R29)] = gregs.gpr[29];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   561
  regs[REG_INDEX(R30)] = gregs.gpr[30];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   562
  regs[REG_INDEX(R31)] = gregs.gpr[31];
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   563
a62a208f18de 8049716: PPC64: Implement SA on Linux/PPC64
simonis
parents: 26411
diff changeset
   564
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   565
489c9b5090e2 Initial load
duke
parents:
diff changeset
   566
  (*env)->ReleaseLongArrayElements(env, array, regs, JNI_COMMIT);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   567
  return array;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   568
}
13529
dc25e69fd16d 7154641: Servicability agent should work on platforms other than x86, sparc
bpittore
parents: 5547
diff changeset
   569
#endif