Path: blob/master/runtime/bcutil/ROMClassVerbosePhase.hpp
5985 views
/*******************************************************************************1* Copyright (c) 2001, 2017 IBM Corp. and others2*3* This program and the accompanying materials are made available under4* the terms of the Eclipse Public License 2.0 which accompanies this5* distribution and is available at https://www.eclipse.org/legal/epl-2.0/6* or the Apache License, Version 2.0 which accompanies this distribution and7* is available at https://www.apache.org/licenses/LICENSE-2.0.8*9* This Source Code may also be made available under the following10* Secondary Licenses when the conditions for such availability set11* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU12* General Public License, version 2 with the GNU Classpath13* Exception [1] and GNU General Public License, version 2 with the14* OpenJDK Assembly Exception [2].15*16* [1] https://www.gnu.org/software/classpath/license.html17* [2] http://openjdk.java.net/legal/assembly-exception.html18*19* 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-exception20*******************************************************************************/212223#ifndef ROMCLASSVERBOSEPHASE_HPP_24#define ROMCLASSVERBOSEPHASE_HPP_2526/* @ddr_namespace: default */27#include "BuildResult.hpp"28#include "ROMClassCreationContext.hpp"29#include "ROMClassCreationPhase.hpp"3031/*32* ROMClassVerbosePhase is a helper class for -verbose:romclass reporting.33* Instances are intended to be stack allocated and their lifetimes correspond to phases of ROM class creation.34*/35class ROMClassVerbosePhase36{37public:38ROMClassVerbosePhase(ROMClassCreationContext *context, ROMClassCreationPhase phase) :39_context(context),40_phase(phase),41_result(NULL)42{43_context->recordPhaseStart(_phase);44}4546ROMClassVerbosePhase(ROMClassCreationContext *context, ROMClassCreationPhase phase, BuildResult *result) :47_context(context),48_phase(phase),49_result(result)50{51_context->recordPhaseStart(_phase);52}5354~ROMClassVerbosePhase()55{56_context->recordPhaseEnd(_phase, NULL == _result ? OK : *_result);57}5859private:60ROMClassCreationContext *_context;61ROMClassCreationPhase _phase;62BuildResult *_result;63};6465/*66* Set RECORD_HOT_PHASES to 1 to enable recording of hot verbose phases, for detailed67* ROM class performance analysis at the cost of extra overhead.68*/69#define RECORD_HOT_PHASES 07071#if RECORD_HOT_PHASES72#define ROMCLASS_VERBOSE_PHASE_HOT(context, phase) ROMClassVerbosePhase v(context, phase)73#else74#define ROMCLASS_VERBOSE_PHASE_HOT(context, phase)75#endif7677#endif /* ROMCLASSVERBOSEPHASE_HPP_ */787980