/*
 * 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) 1991-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:  Ruth A. Aydt (aydt@cs.uiuc.edu)
 * Author:  Tara M. Madhyastha (tara@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
 */

/*
 * HDFIOTrace.h:  This header file can be included in c source files to
 *	       automatically redefine the I/O function calls to the
 *	       tracing versions when "IOTRACE" is defined.   
 *
 *	       It also contains function declarations for the I/O trace
 *	       routines called from user code and constant values that may
 *	       be needed by the user.
 *
 */
#ifndef HDFIOTrace_h
#define HDFIOTrace_h

 
/************************************************************************/
/* These defines and the external variable OUTPUT_SWITCH are used in    */
/* for HDF and MPI-IO tracing to govern the type of output produced.    */
/************************************************************************/
extern int OUTPUT_SWITCH;        /* default is SDDF records      */
 
#if defined(__STDC__) || defined(__cplusplus)
#define PROTO(x) x
#else
#define PROTO(x) ()
#endif

#ifdef __cplusplus
extern "C" {
#endif

/* #include <stdio.h> */
#include <sys/types.h>

void startHDFtraceEvent (int );
void endHDFtraceEvent (int , int , char *, int );

FILE *HDFtraceFOPEN( const char *filename, const char *type ) ;
#ifndef HDFtrace3OPEN__
	int HDFtrace3OPEN( const char *path, int flags, ... ) ;
#endif
int HDFtraceCREAT( const char *path, mode_t mode );
int HDFtraceFFLUSH( FILE *stream ) ;
int HDFtraceFCLOSE( FILE *stream ) ;
int HDFtraceCLOSE( int fd ) ;
ssize_t HDFtraceREAD( int fd, void *buf, size_t nbyte );
size_t HDFtraceFREAD( void *ptr, size_t size, size_t nitems, FILE *stream );
void *HDFtraceMALLOC( size_t );
off_t HDFtraceLSEEK( int fd, off_t offset, int whence ) ;
int HDFtraceFSEEK( FILE *stream, long offset, int whence ) ;
int HDFtraceFSETPOS( FILE *stream, const fpos_t *position ) ;
void HDFtraceREWIND( FILE *stream ) ;
ssize_t HDFtraceWRITE( int fd, const void *buf, size_t nbytes );
size_t HDFtraceFWRITE( const void *, size_t , size_t , FILE * );
int HDFtracePUTS( const char *s ) ;
int HDFtraceFPUTC( int c, FILE *stream ) ;
int HDFtraceFPUTS( const char *s, FILE *stream ) ;

#ifdef HDFIOTRACE
/*
 * If IOTRACE is defined, then redefine standard I/O routines to tracing
 * versions.  Also include the appropriate .h files so the function
 * declarations from them will be redefined to traced versions.
 */

#ifdef fopen 
#   undef fopen
#endif
#ifdef open 
#   undef open
#endif
#ifdef creat 
#   undef creat
#endif
 
#ifdef fflush 
#   undef fflush
#endif
#ifdef fclose 
#   undef fclose
#endif
#ifdef close 
#   undef close
#endif
 
#ifdef read 
#   undef read
#endif
#ifdef fread 
#   undef fread
#endif
#ifdef fgetc 
#   undef fgetc
#endif
#ifdef fgets 
#   undef fgets
#endif
#ifdef gets 
#   undef gets
#endif
#ifdef getw 
#   undef getw
#endif
 
#ifdef lseek 
#   undef lseek
#endif
#ifdef fseek 
#   undef fseek
#endif
#ifdef rewind 
#   undef rewind
#endif
#ifdef fsetpos 
#   undef fsetpos
#endif
 
#ifdef write 
#   undef write
#endif
#ifdef fwrite 
#   undef fwrite
#endif
#ifdef fputc 
#   undef fputc
#endif
#ifdef fputs 
#   undef fputs
#endif
#ifdef puts 
#   undef puts
#endif
#ifdef putw 
#   undef putw
#endif
 
#ifdef malloc 
#   undef malloc
#endif

#define fopen		(FILE *)HDFtraceFOPEN
#define open		HDFtrace3OPEN
#define creat		HDFtraceCREAT

#define fflush		HDFtraceFFLUSH
#define fclose		HDFtraceFCLOSE
#define close		HDFtraceCLOSE

#define read		HDFtraceREAD
#define fread		HDFtraceFREAD
#define fgetc		HDFtraceFGETC
#define fgets		HDFtraceFGETS
#define gets		HDFtraceGETS
#define getw		HDFtraceGETW

#define lseek		HDFtraceLSEEK
#define fseek		HDFtraceFSEEK
#define rewind		HDFtraceREWIND
#define fsetpos		HDFtraceFSETPOS

#define write		HDFtraceWRITE
#define fwrite		HDFtraceFWRITE
#define fputc		HDFtraceFPUTC
#define fputs		HDFtraceFPUTS
#define puts		HDFtracePUTS
#define putw		HDFtracePUTW

#define malloc		HDFtraceMALLOC

#include <stdio.h>
#include <fcntl.h>

/*
 * On the iPSC/860 we don't include unistd.h or we get warnings about
 * SEEK_* multiply defined.
 */
#ifndef __NX
#include <unistd.h>
#endif


#include <stdio.h>
/*
 * Function declarations for routines that can be called from user code.
 */
void  enableIOtracing( void );
void  disableIOtracing( void );

void  enableIOdetail( void );
void  disableIOdetail( void );

void  enableLifetimeSummaries( void );
void  disableLifetimeSummaries( void );

void  enableTimeWindowSummaries ( double );
void  disableTimeWindowSummaries( void );
void  setTimeWindowSize ( double );
void  outputTimeWindowSummaries( void );

void  enableFileRegionSummaries ( int );
void  disableFileRegionSummaries( void );
void  setFileRegionSize ( int );
void  outputFileRegionSummaries( void );

int   HDFtrace2OPEN ( char*, int );
void  HDFtraceReadBegin ( int, int, int );
void  HDFtraceReadEnd ( int );
void  HDFtraceWriteBegin ( int, int, int );
void  HDFtraceWriteEnd ( int );
void  HDFtraceIOBegin ( int, int );
void  HDFtraceIOEnd ( int, double, char * );

#ifdef HAVE_PARALLEL

#include "HDFmpioProtos.h"

/*
#ifdef MPI_File_open 		
#undef MPI_File_open 		
#endif
#ifdef MPI_File_close 		
#undef MPI_File_close 		
#endif
#ifdef MPI_File_delete 	
#undef MPI_File_delete 	
#endif
#ifdef MPI_File_set_size 	
#undef MPI_File_set_size 	
#endif
#ifdef MPI_File_preallocate 	
#undef MPI_File_preallocate 	
#endif
#ifdef MPI_File_get_size 	
#undef MPI_File_get_size 	
#endif
#ifdef MPI_File_get_group 	
#undef MPI_File_get_group 	
#endif
#ifdef MPI_File_get_amode 	
#undef MPI_File_get_amode 	
#endif
#ifdef MPI_File_set_view 	
#undef MPI_File_set_view 	
#endif
#ifdef MPI_File_get_view 	
#undef MPI_File_get_view 	
#endif
#ifdef MPI_File_read_at 	
#undef MPI_File_read_at 	
#endif
#ifdef MPI_File_read_at_all 	
#undef MPI_File_read_at_all 	
#endif
#ifdef MPI_File_write_at 	
#undef MPI_File_write_at 	
#endif
#ifdef MPI_File_write_at_all 	
#undef MPI_File_write_at_all 	
#endif
#ifdef MPI_File_iread_at 	
#undef MPI_File_iread_at 	
#endif
#ifdef MPI_File_iwrite_at 	
#undef MPI_File_iwrite_at 	
#endif
#ifdef MPI_File_read 		
#undef MPI_File_read 		
#endif
#ifdef MPI_File_read_all 	
#undef MPI_File_read_all 	
#endif
#ifdef MPI_File_write 		
#undef MPI_File_write 		
#endif
#ifdef MPI_File_write_all 	
#undef MPI_File_write_all 	
#endif
#ifdef MPI_File_iread 		
#undef MPI_File_iread 		
#endif
#ifdef MPI_File_iwrite 	
#undef MPI_File_iwrite 	
#endif
#ifdef MPI_File_seek 		
#undef MPI_File_seek 		
#endif
#ifdef MPI_File_get_position 	
#undef MPI_File_get_position 	
#endif
#ifdef MPI_File_get_byte_offset
#undef MPI_File_get_byte_offset
#endif
#ifdef MPI_File_get_type_extent
#undef MPI_File_get_type_extent
#endif
#ifdef MPI_File_set_atomicity 	
#undef MPI_File_set_atomicity 	
#endif
#ifdef MPI_File_get_atomicity 	
#undef MPI_File_get_atomicity 	
#endif
#ifdef MPI_File_sync 		
#undef MPI_File_sync 		
#endif

#define MPI_File_open 		 HDF_MPI_File_open
#define MPI_File_close 		 HDF_MPI_File_close
#define MPI_File_delete 	 HDF_MPI_File_delete
#define MPI_File_set_size 	 HDF_MPI_File_set_size
#define MPI_File_preallocate 	 HDF_MPI_File_preallocate
#define MPI_File_get_size 	 HDF_MPI_File_get_size
#define MPI_File_get_group 	 HDF_MPI_File_get_group
#define MPI_File_get_amode 	 HDF_MPI_File_get_amode
#define MPI_File_set_view 	 HDF_MPI_File_set_view
#define MPI_File_get_view 	 HDF_MPI_File_get_view
#define MPI_File_read_at 	 HDF_MPI_File_read_at
#define MPI_File_read_at_all 	 HDF_MPI_File_read_at_all
#define MPI_File_write_at 	 HDF_MPI_File_write_at
#define MPI_File_write_at_all 	 HDF_MPI_File_write_at_all
#define MPI_File_iread_at 	 HDF_MPI_File_iread_at
#define MPI_File_iwrite_at 	 HDF_MPI_File_iwrite_at
#define MPI_File_read 		 HDF_MPI_File_read
#define MPI_File_read_all 	 HDF_MPI_File_read_all
#define MPI_File_write 		 HDF_MPI_File_write
#define MPI_File_write_all 	 HDF_MPI_File_write_all
#define MPI_File_iread 		 HDF_MPI_File_iread
#define MPI_File_iwrite 	 HDF_MPI_File_iwrite
#define MPI_File_seek 		 HDF_MPI_File_seek
#define MPI_File_get_position 	 HDF_MPI_File_get_position
#define MPI_File_get_byte_offset HDF_MPI_File_get_byte_offset
#define MPI_File_get_type_extent HDF_MPI_File_get_type_extent
#define MPI_File_set_atomicity 	 HDF_MPI_File_set_atomicity
#define MPI_File_get_atomicity 	 HDF_MPI_File_get_atomicity
#define MPI_File_sync 		 HDF_MPI_File_sync
#endif 
*/
#endif 
#endif 
#ifdef __cplusplus
}

#endif /* HAVE_PARALLEL */

#endif		/* HDFIOTRACE conditional */