Path: blob/master/runtime/gc_trace/TgcExclusiveaccess.cpp
5985 views
1/*******************************************************************************2* Copyright (c) 1991, 2019 IBM Corp. and others3*4* This program and the accompanying materials are made available under5* the terms of the Eclipse Public License 2.0 which accompanies this6* distribution and is available at https://www.eclipse.org/legal/epl-2.0/7* or the Apache License, Version 2.0 which accompanies this distribution and8* is available at https://www.apache.org/licenses/LICENSE-2.0.9*10* This Source Code may also be made available under the following11* Secondary Licenses when the conditions for such availability set12* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU13* General Public License, version 2 with the GNU Classpath14* Exception [1] and GNU General Public License, version 2 with the15* OpenJDK Assembly Exception [2].16*17* [1] https://www.gnu.org/software/classpath/license.html18* [2] http://openjdk.java.net/legal/assembly-exception.html19*20* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception21*******************************************************************************/2223#include "j9.h"24#include "j9cfg.h"25#include "TgcExclusiveaccess.hpp"26#include "j9port.h"27#include "modronopt.h"28#include "mmhook.h"2930#include "EnvironmentBase.hpp"31#include "GCExtensions.hpp"32#include "TgcExtensions.hpp"3334/**35* @todo Provide function documentation36*/37static void38printExclusiveAccessTimes(J9VMThread *vmThread)39{40MM_EnvironmentBase *env = MM_EnvironmentBase::getEnvironment(vmThread->omrVMThread);41PORT_ACCESS_FROM_ENVIRONMENT(env);42MM_TgcExtensions *tgcExtensions = MM_TgcExtensions::getExtensions(vmThread);4344U_64 exlusiveAccessTime = j9time_hires_delta(0, env->getExclusiveAccessTime(), J9PORT_TIME_DELTA_IN_MICROSECONDS);45/* Note that these values were not being calculated in the GC and have been returning 0 for some time. */46U_64 preAcquireExclusiveTime = (U_64)0;47U_64 postAcquireExclusiveTime = (U_64)0;4849tgcExtensions->printf("ExclusiveAccess Time(ms): total=\"%llu.%03.3llu\", preAcquire=\"%llu.%03.3llu\", postAcquire=\"%llu.%03.3llu\"\n",50exlusiveAccessTime /1000, exlusiveAccessTime % 1000,51preAcquireExclusiveTime /1000, preAcquireExclusiveTime % 1000,52postAcquireExclusiveTime /1000, postAcquireExclusiveTime % 1000);53}5455/**56* @todo Provide function documentation57*/58static void59tgcHookExclusiveAccess(J9HookInterface** hook, UDATA eventNum, void* eventData, void* userData)60{61MM_ExclusiveAccessEvent* event = (MM_ExclusiveAccessEvent*)eventData;62J9VMThread* vmThread = static_cast<J9VMThread*>(event->currentThread->_language_vmthread);63printExclusiveAccessTimes(vmThread);64}6566/**67* @todo Provide function documentation68*/69bool70tgcExclusiveAccessInitialize(J9JavaVM *javaVM)71{72MM_GCExtensions *extensions = MM_GCExtensions::getExtensions(javaVM);73bool result = true;7475J9HookInterface** privateHooks = J9_HOOK_INTERFACE(extensions->privateHookInterface);76(*privateHooks)->J9HookRegisterWithCallSite(privateHooks, J9HOOK_MM_PRIVATE_EXCLUSIVE_ACCESS, tgcHookExclusiveAccess, OMR_GET_CALLSITE(), NULL);7778return result;79}808182