1998-10-31 03:45:00 +08:00
|
|
|
/* This file is part of the Pablo Performance Analysis Environment
|
|
|
|
//
|
|
|
|
// (R)
|
|
|
|
// The Pablo Performance Analysis Environment software is NOT in
|
|
|
|
// the public domain. However, it is freely available without fee for
|
|
|
|
// education, research, and non-profit purposes. By obtaining copies
|
|
|
|
// of this and other files that comprise the Pablo Performance Analysis
|
|
|
|
// Environment, you, the Licensee, agree to abide by the following
|
|
|
|
// conditions and understandings with respect to the copyrighted software:
|
|
|
|
//
|
|
|
|
// 1. The software is copyrighted in the name of the Board of Trustees
|
|
|
|
// of the University of Illinois (UI), and ownership of the software
|
|
|
|
// remains with the UI.
|
|
|
|
//
|
|
|
|
// 2. Permission to use, copy, and modify this software and its documentation
|
|
|
|
// for education, research, and non-profit purposes is hereby granted
|
|
|
|
// to Licensee, provided that the copyright notice, the original author's
|
|
|
|
// names and unit identification, and this permission notice appear on
|
|
|
|
// all such copies, and that no charge be made for such copies. Any
|
|
|
|
// entity desiring permission to incorporate this software into commercial
|
|
|
|
// products should contact:
|
|
|
|
//
|
|
|
|
// Professor Daniel A. Reed reed@cs.uiuc.edu
|
|
|
|
// University of Illinois
|
|
|
|
// Department of Computer Science
|
|
|
|
// 2413 Digital Computer Laboratory
|
|
|
|
// 1304 West Springfield Avenue
|
|
|
|
// Urbana, Illinois 61801
|
|
|
|
// USA
|
|
|
|
//
|
|
|
|
// 3. Licensee may not use the name, logo, or any other symbol of the UI
|
|
|
|
// nor the names of any of its employees nor any adaptation thereof in
|
|
|
|
// advertizing or publicity pertaining to the software without specific
|
|
|
|
// prior written approval of the UI.
|
|
|
|
//
|
|
|
|
// 4. THE UI MAKES NO REPRESENTATIONS ABOUT THE SUITABILITY OF THE
|
|
|
|
// SOFTWARE FOR ANY PURPOSE. IT IS PROVIDED "AS IS" WITHOUT EXPRESS
|
|
|
|
// OR IMPLIED WARRANTY.
|
|
|
|
//
|
|
|
|
// 5. The UI shall not be liable for any damages suffered by Licensee from
|
|
|
|
// the use of this software.
|
|
|
|
//
|
|
|
|
// 6. The software was developed under agreements between the UI and the
|
|
|
|
// Federal Government which entitle the Government to certain rights.
|
|
|
|
//
|
|
|
|
// *************************************************************************
|
|
|
|
//
|
|
|
|
// Developed by: The Pablo Research Group
|
|
|
|
// University of Illinois at Urbana-Champaign
|
|
|
|
// Department of Computer Science
|
|
|
|
// 1304 W. Springfield Avenue
|
|
|
|
// Urbana, IL 61801
|
|
|
|
//
|
|
|
|
// http://www-pablo.cs.uiuc.edu
|
|
|
|
//
|
|
|
|
// Send comments to: pablo-feedback@guitar.cs.uiuc.edu
|
|
|
|
//
|
|
|
|
// Copyright (c) 1987-1998
|
|
|
|
// The University of Illinois Board of Trustees.
|
|
|
|
// All Rights Reserved.
|
|
|
|
//
|
|
|
|
// PABLO is a registered trademark of
|
|
|
|
// The Board of Trustees of the University of Illinois
|
|
|
|
// registered in the U.S. Patent and Trademark Office.
|
|
|
|
//
|
|
|
|
// Project Manager and Principal Investigator:
|
|
|
|
// Daniel A. Reed (reed@cs.uiuc.edu)
|
|
|
|
//
|
|
|
|
// Funded in part by the Defense Advanced Research Projects Agency under
|
|
|
|
// DARPA contracts DABT63-94-C0049 (SIO Initiative), F30602-96-C-0161,
|
|
|
|
// and DABT63-96-C-0027 by the National Science Foundation under the PACI
|
|
|
|
// program and grants NSF CDA 94-01124 and ASC 97-20202, and by the
|
|
|
|
// Department of Energy under contracts DOE B-341494, W-7405-ENG-48, and
|
|
|
|
// 1-B-333164.
|
|
|
|
//-------------------------------------------------------------------------*/
|
|
|
|
/*--------------------------------------------------------------------------
|
|
|
|
* File: ProcIDs.h
|
|
|
|
* Purpose: define IDs for identifying procedures in traces
|
|
|
|
*-------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
#ifndef PROCIDS_H /* avoid re-inclusion */
|
|
|
|
#define PROCIDS_H
|
|
|
|
|
1999-03-10 05:00:07 +08:00
|
|
|
extern int *procTrace;
|
1998-10-31 03:45:00 +08:00
|
|
|
/*
|
1999-03-10 05:00:07 +08:00
|
|
|
* Define the event IDs that will be used for the various HDF events
|
1998-10-31 03:45:00 +08:00
|
|
|
*/
|
1999-03-10 05:00:07 +08:00
|
|
|
#include "ProcTrace.h"
|
1998-10-31 03:45:00 +08:00
|
|
|
|
1999-04-15 05:20:11 +08:00
|
|
|
#include "ProcMasks.h"
|
1999-03-10 05:00:07 +08:00
|
|
|
|
|
|
|
#define ID_HDFprocName 9996
|
|
|
|
#define ID_malloc 9997
|
|
|
|
#define ID_free 9998
|
|
|
|
#define ID_timeStamp 9999
|
|
|
|
#define DUMMY_HDF 10000
|
1998-10-31 03:45:00 +08:00
|
|
|
|
|
|
|
#define BEGIN_HDF (DUMMY_HDF + 1)
|
1999-03-10 05:00:07 +08:00
|
|
|
#define END_HDF (ID_HDF_Last_Entry + DUMMY_HDF)
|
|
|
|
#define NumHDFProcs ( ID_HDF_Last_Entry )
|
|
|
|
|
1999-04-15 05:20:11 +08:00
|
|
|
enum MPIeventIDs {
|
|
|
|
BEGIN_MPIO = END_HDF+1,
|
|
|
|
HDFmpiOpenID = BEGIN_MPIO,
|
|
|
|
HDFmpiCloseID,
|
|
|
|
HDFmpiDeleteID,
|
|
|
|
HDFmpiSetSizeID,
|
|
|
|
HDFmpiPreallocateID,
|
|
|
|
HDFmpiGetSizeID,
|
|
|
|
HDFmpiGetGroupID,
|
|
|
|
HDFmpiGetAmodeID,
|
|
|
|
HDFmpiGetViewID,
|
|
|
|
HDFmpiSetViewID,
|
|
|
|
HDFmpiReadAtID,
|
|
|
|
HDFmpiReadAtAllID,
|
|
|
|
HDFmpiWriteAtID,
|
|
|
|
HDFmpiWriteAtAllID,
|
|
|
|
HDFmpiReadID,
|
|
|
|
HDFmpiReadAllID,
|
|
|
|
HDFmpiWriteID,
|
|
|
|
HDFmpiWriteAllID,
|
|
|
|
HDFmpiSeekID,
|
|
|
|
HDFmpiGetPositionID,
|
|
|
|
HDFmpiGetByteOffsetID,
|
|
|
|
HDFmpiGetTypeExtentID,
|
|
|
|
HDFmpiSetAtomicityID,
|
|
|
|
HDFmpiGetAtomicityID,
|
|
|
|
HDFmpiIreadID,
|
|
|
|
HDFmpiIwriteID,
|
|
|
|
HDFmpiIreadAtID,
|
|
|
|
HDFmpiIwriteAtID,
|
|
|
|
HDFmpiSyncID,
|
|
|
|
END_MPIO
|
|
|
|
};
|
|
|
|
|
1998-10-31 03:45:00 +08:00
|
|
|
/*======================================================================*/
|
|
|
|
/* Macros to tell if the ID is that of an HDF Entry or Exit */
|
|
|
|
/*======================================================================*/
|
1999-03-10 05:00:07 +08:00
|
|
|
#define isBeginHDFEvent( ID ) ( BEGIN_HDF <= (ID) && (ID) <= END_HDF )
|
1998-10-31 03:45:00 +08:00
|
|
|
#define isEndHDFEvent( ID ) isBeginHDFEvent(-(ID))
|
|
|
|
#define isBeginMPIOEvent( ID ) \
|
1999-04-15 05:20:11 +08:00
|
|
|
( BEGIN_MPIO <= (ID) && (ID) <= END_MPIO )
|
|
|
|
#define isEndMPIOEvent( ID ) isBeginMPIOEvent(-(ID))
|
1998-10-31 03:45:00 +08:00
|
|
|
#define isBeginIOEvent( ID ) \
|
|
|
|
( IOerrorID < (ID) && (ID) <= fsetposEndID && (ID)%2 == 1 )
|
|
|
|
#define isEndIOEvent( ID ) \
|
|
|
|
( IOerrorID < (ID) && (ID) <= fsetposEndID && (ID)%2 == 0 )
|
|
|
|
#define ProcIndex( ID ) ( (ID) - BEGIN_HDF )
|
|
|
|
#define ProcIndexForHDFEntry( ID ) ( (ID) - BEGIN_HDF )
|
|
|
|
#define ProcIndexForHDFExit( ID ) ProcIndexForHDFEntry(-ID)
|
1999-03-10 05:00:07 +08:00
|
|
|
#define HDFIXtoEventID( ID ) ( (ID) + BEGIN_HDF )
|
1998-10-31 03:45:00 +08:00
|
|
|
|
2001-07-05 23:07:00 +08:00
|
|
|
#ifdef PCF_BUILD
|
|
|
|
#define TRACE_ON(mask, ID) \
|
|
|
|
if ( procTrace[mask] || procTrace[ID] ) startHDFtraceEvent( ID )
|
|
|
|
#define TRACE_OFF(mask, ID ) \
|
|
|
|
if ( procTrace[mask] || procTrace[ID] ) endHDFtraceEvent( ID, 0, NULL, 0 )
|
|
|
|
#else
|
1999-03-10 05:00:07 +08:00
|
|
|
#define TRACE_ON(mask, ID) \
|
|
|
|
if ( procTrace[mask] || procTrace[ID] ) startHDFtraceEvent( HDFIXtoEventID( ID ) )
|
|
|
|
#define TRACE_OFF(mask, ID ) \
|
|
|
|
if ( procTrace[mask] || procTrace[ID] ) endHDFtraceEvent(-HDFIXtoEventID(ID), 0, NULL, 0 )
|
2001-07-05 23:07:00 +08:00
|
|
|
#endif /* PCF_BUILD */
|
1998-10-31 03:45:00 +08:00
|
|
|
|
|
|
|
#endif /* PROCIDS_H */
|