test/hotspot/jtreg/serviceability/jvmti/GenerateEvents/libGenerateEvents2.cpp
author sspitsyn
Wed, 10 Apr 2019 17:29:03 -0700
changeset 54497 96230a5ef2ec
permissions -rw-r--r--
8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv Summary: Fix GenerateEvents() to send CompiledMethodLoad events to requesting agent only Reviewed-by: jcbeyler, amenkov
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
54497
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     1
/*
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     2
 * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     4
 *
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     7
 * published by the Free Software Foundation.
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     8
 *
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    13
 * accompanied this code).
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    14
 *
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    18
 *
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    21
 * questions.
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    22
 */
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    23
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    24
#include <string.h>
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    25
#include "jvmti.h"
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    26
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    27
extern "C" {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    28
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    29
#define AGENT_NAME "agent2"
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    30
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    31
static JavaVM *java_vm = NULL;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    32
static jthread exp_thread = NULL;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    33
static jvmtiEnv *jvmti2 = NULL;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    34
static jint agent2_event_count = 0;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    35
static bool fail_status = false;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    36
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    37
static void
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    38
check_jvmti_status(JNIEnv* env, jvmtiError err, const char* msg) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    39
  if (err != JVMTI_ERROR_NONE) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    40
    printf("check_jvmti_status: JVMTI function returned error: %d\n", err);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    41
    fail_status = true;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    42
    env->FatalError(msg);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    43
  }
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    44
}
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    45
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    46
static void JNICALL
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    47
CompiledMethodLoad(jvmtiEnv* jvmti, jmethodID method,
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    48
                   jint code_size, const void* code_addr,
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    49
                   jint map_length, const jvmtiAddrLocationMap* map,
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    50
                   const void* compile_info) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    51
  JNIEnv* env = NULL;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    52
  jthread thread = NULL;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    53
  char* name = NULL;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    54
  char* sign = NULL;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    55
  jvmtiError err;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    56
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    57
  // Posted on JavaThread's, so it is legal to obtain JNIEnv*
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    58
  if (java_vm->GetEnv((void **) (&env), JNI_VERSION_9) != JNI_OK) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    59
    fail_status = true;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    60
    return;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    61
  }
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    62
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    63
  err = jvmti->GetCurrentThread(&thread);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    64
  check_jvmti_status(env, err, "CompiledMethodLoad: Error in JVMTI GetCurrentThread");
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    65
  if (!env->IsSameObject(thread, exp_thread)) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    66
    return; // skip events from unexpected threads
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    67
  }
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    68
  agent2_event_count++;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    69
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    70
  err = jvmti->GetMethodName(method, &name, &sign, NULL);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    71
  check_jvmti_status(env, err, "CompiledMethodLoad: Error in JVMTI GetMethodName");
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    72
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    73
  printf("%s: CompiledMethodLoad: %s%s\n", AGENT_NAME, name, sign);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    74
  fflush(0);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    75
}
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    76
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    77
JNIEXPORT jint JNICALL
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    78
Agent_OnLoad(JavaVM *jvm, char *options, void *reserved) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    79
  jvmtiEventCallbacks callbacks;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    80
  jvmtiCapabilities caps;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    81
  jvmtiError err;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    82
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    83
  java_vm = jvm;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    84
  if (jvm->GetEnv((void **) (&jvmti2), JVMTI_VERSION_9) != JNI_OK) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    85
    return JNI_ERR;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    86
  }
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    87
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    88
  memset(&callbacks, 0, sizeof(callbacks));
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    89
  callbacks.CompiledMethodLoad = &CompiledMethodLoad;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    90
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    91
  err = jvmti2->SetEventCallbacks(&callbacks, sizeof(jvmtiEventCallbacks));
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    92
  if (err != JVMTI_ERROR_NONE) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    93
    printf("Agent_OnLoad: Error in JVMTI SetEventCallbacks: %d\n", err);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    94
    fail_status = true;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    95
    return JNI_ERR;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    96
  }
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    97
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    98
  memset(&caps, 0, sizeof(caps));
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
    99
  caps.can_generate_compiled_method_load_events = 1;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   100
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   101
  err = jvmti2->AddCapabilities(&caps);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   102
  if (err != JVMTI_ERROR_NONE) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   103
    printf("Agent_OnLoad: Error in JVMTI AddCapabilities: %d\n", err);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   104
    fail_status = true;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   105
    return JNI_ERR;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   106
  }
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   107
  return JNI_OK;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   108
}
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   109
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   110
JNIEXPORT void JNICALL
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   111
Java_MyPackage_GenerateEventsTest_agent2SetThread(JNIEnv *env, jclass cls, jthread thread) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   112
  jvmtiError err;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   113
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   114
  exp_thread = (jthread)env->NewGlobalRef(thread);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   115
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   116
  err = jvmti2->SetEventNotificationMode(JVMTI_ENABLE, JVMTI_EVENT_COMPILED_METHOD_LOAD, NULL);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   117
  check_jvmti_status(env, err, "setThread2: Error in JVMTI SetEventNotificationMode: JVMTI_ENABLE");
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   118
}
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   119
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   120
JNIEXPORT jboolean JNICALL
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   121
Java_MyPackage_GenerateEventsTest_agent2FailStatus(JNIEnv *env, jclass cls) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   122
  jvmtiError err;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   123
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   124
  err = jvmti2->SetEventNotificationMode(JVMTI_DISABLE, JVMTI_EVENT_COMPILED_METHOD_LOAD, NULL);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   125
  check_jvmti_status(env, err, "check2: Error in JVMTI SetEventNotificationMode: JVMTI_DISABLE");
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   126
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   127
  printf("\n");
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   128
  if (agent2_event_count == 0) {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   129
    printf("check2: Zero events in agent2 as expected\n");
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   130
  } else {
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   131
    fail_status = true;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   132
    printf("check2: Unexpected non-zero event count in agent2: %d\n", agent2_event_count);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   133
  }
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   134
  printf("\n");
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   135
  fflush(0);
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   136
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   137
  return fail_status;
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   138
}
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   139
96230a5ef2ec 8222072: JVMTI GenerateEvents() sends CompiledMethodLoad events to wrong jvmtiEnv
sspitsyn
parents:
diff changeset
   140
} // extern "C"