summaryrefslogtreecommitdiffstats
path: root/pablo/HDFrecord_RT.h
diff options
context:
space:
mode:
authorDan Wells <dwells@cs.uiuc.edu>1999-04-14 21:17:56 (GMT)
committerDan Wells <dwells@cs.uiuc.edu>1999-04-14 21:17:56 (GMT)
commit92cc3fe39fcf1862cb87a3e417167124730ee27e (patch)
tree801d7a92e006d4ec5e8ca1dcedc6547ce1d80b02 /pablo/HDFrecord_RT.h
parent31ac7445865c583ab56fbd75022ee52e908527de (diff)
downloadhdf5-92cc3fe39fcf1862cb87a3e417167124730ee27e.zip
hdf5-92cc3fe39fcf1862cb87a3e417167124730ee27e.tar.gz
hdf5-92cc3fe39fcf1862cb87a3e417167124730ee27e.tar.bz2
[svn-r1180] Changes to allow automatic building of tables of event IDs and to make HDF 4 and HDF 5 output compatible.
Diffstat (limited to 'pablo/HDFrecord_RT.h')
-rw-r--r--pablo/HDFrecord_RT.h176
1 files changed, 176 insertions, 0 deletions
diff --git a/pablo/HDFrecord_RT.h b/pablo/HDFrecord_RT.h
new file mode 100644
index 0000000..808eaef
--- /dev/null
+++ b/pablo/HDFrecord_RT.h
@@ -0,0 +1,176 @@
+/*
+ * 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-1996
+ * 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.
+ *
+ * Author: Dan Wells (dwells@cs.uiuc.edu)
+ *
+ * Project Manager and Principal Investigator:
+ * Daniel A. Reed (reed@cs.uiuc.edu)
+ *
+ * Funded in part by National Science Foundation grants NSF CCR87-06653
+ * and NSF CDA87-22836 (Tapestry), DARPA contracts DABT63-91-K-0004,
+ * DABT63-93-C-0040, DABT63-94-C-0049 (SIO), and F30602-96-C-0161, NASA
+ * contracts NAG-1-613 (ICLASS), USRA 5555-22, and NGT-51023, and a
+ * collaborative research agreement with the Intel Supercomputer
+ * Systems Division
+ */
+/*
+ * HDFrecord.h: Class to represent HDF records.
+ *
+ * $Header$
+ */
+
+#ifndef HDFRECORD_RT_H
+#define HDFRECORD_RT_H
+#ifndef NULL
+#define NULL 0
+#endif
+
+#include <string.h>
+#include <stdlib.h>
+#include <limits.h>
+#include "ProcIDs.h"
+
+#ifndef min
+#define min( x , y ) ( x <= y ? x : y )
+#endif
+#ifndef max
+#define max( x , y ) ( x >= y ? x : y )
+#endif
+/*======================================================================*
+// Enumeration of time fields in an HDFrec_t below *
+//======================================================================*/
+enum TimeFields { HDF_, MPI, Malloc, AllIO, Open, Close, Read, Write, ARead,
+ AWrite, Seek, Wait, Misc, nTallyFields };
+/*======================================================================*
+// Enumeration of byte fields in an HDFrec_t below *
+//======================================================================*/
+enum ByteFields{ MallocBytes, ReadBytes, WriteBytes, AReadBytes, AWriteBytes,
+ nByteFields };
+/*======================================================================*
+// Definition of first and last IO event. *
+//======================================================================*/
+#define FirstIO Open
+#define LastIO Misc
+#define nBkts 4
+#define ONEK 1024
+int BktLim[] = { 1, 4*ONEK, 64*ONEK, 256*ONEK, INT_MAX } ;
+/*======================================================================*
+// Definition of structure used to account activity in an HDF call *
+//======================================================================*/
+typedef struct {
+ int nCalls; /* number of proc calls */
+ CLOCK lastCall; /* time of last call */
+ CLOCK incDur; /* inclusive duration */
+ CLOCK excDur; /* exclusive duration */
+ CLOCK times[nTallyFields]; /* Tally op/calls times */
+ int counts[nTallyFields]; /* Tally op/calls counts */
+ int bytes[nByteFields]; /* Tally bytes transferred */
+ int Hists[nByteFields][nBkts]; /* Historgrams */
+ long hdfID; /* data set ID */
+ long xRef; /* data set cross reference */
+} HDFrec_t;
+/*======================================================================*
+// Node used to maintain linked lists of HDF procedure activity. *
+//======================================================================*/
+typedef struct HDFnode {
+ CLOCK lastIOtime; /* last IO time stamp */
+ HDFrec_t record; /* data */
+ struct HDFnode *ptr; /* link pointer */
+ int eventID; /* event ID */
+} HDFnode_t;
+/*======================================================================*
+// Structure used to produce SDDF packets for Named identifiers. *
+//======================================================================*/
+typedef struct {
+ int packetLength; /* bytes in packet */
+ int packetType; /* == PKT_DATA */
+ int packetTag; /* == FAMILY_<name> */
+ int fileType; /* Type of data set */
+ int fileID; /* File ID */
+ int nameLen; /* length of file */
+} HDFNamePacket_t;
+/*======================================================================*
+// Node used to form linked lists to track named identifiers. *
+//======================================================================*/
+typedef struct fileRec {
+ struct fileRec *ptr;
+ long hdfID;
+ long PabloID;
+ char *fileName;
+} fileRec_t;
+/*=======================================================================
+// Utility programs to determine field index for a given eventID *
+//=====================================================================*/
+int getHDFFieldIndex( int eventID );
+int getHDFByteFieldIndex( int eventID );
+
+/*
+ * Define flags to distinguish misc i/o begin from misc i/o end
+ */
+#define MISC_BEGIN 0
+#define MISC_END 1
+
+#endif /* HDFRECORD_RT_H */