diff options
author | Dan Wells <dwells@cs.uiuc.edu> | 1999-04-14 21:17:56 (GMT) |
---|---|---|
committer | Dan Wells <dwells@cs.uiuc.edu> | 1999-04-14 21:17:56 (GMT) |
commit | 92cc3fe39fcf1862cb87a3e417167124730ee27e (patch) | |
tree | 801d7a92e006d4ec5e8ca1dcedc6547ce1d80b02 /pablo/HDFrecord_RT.h | |
parent | 31ac7445865c583ab56fbd75022ee52e908527de (diff) | |
download | hdf5-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.h | 176 |
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 */ |