2007-12-21 09:02:00 +03:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; -*- */
|
2004-01-16 02:57:16 +03:00
|
|
|
/*
|
2005-11-05 22:57:48 +03:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2007-12-21 09:02:00 +03:00
|
|
|
* Copyright (c) 2004-2007 The University of Tennessee and The University
|
2005-11-05 22:57:48 +03:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2004-11-28 23:09:25 +03:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 15:43:37 +03:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2009-02-24 20:17:33 +03:00
|
|
|
* Copyright (c) 2009 Sun Microsystems, Inc. All rights reserved.
|
2004-11-22 04:38:40 +03:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-01-16 02:57:16 +03:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-06-07 19:33:53 +04:00
|
|
|
#ifndef OMPI_FILE_H
|
|
|
|
#define OMPI_FILE_H
|
2004-01-16 02:57:16 +03:00
|
|
|
|
2009-03-04 18:35:54 +03:00
|
|
|
#include "ompi_config.h"
|
2004-01-16 02:57:16 +03:00
|
|
|
#include "mpi.h"
|
2005-07-03 20:22:16 +04:00
|
|
|
#include "opal/class/opal_list.h"
|
2006-02-12 04:33:29 +03:00
|
|
|
#include "ompi/errhandler/errhandler.h"
|
2005-07-04 02:45:48 +04:00
|
|
|
#include "opal/threads/mutex.h"
|
2006-02-12 04:33:29 +03:00
|
|
|
#include "ompi/mca/io/io.h"
|
2004-01-16 02:57:16 +03:00
|
|
|
|
2004-08-14 05:56:05 +04:00
|
|
|
/*
|
|
|
|
* Flags
|
|
|
|
*/
|
|
|
|
#define OMPI_FILE_ISCLOSED 0x00000001
|
|
|
|
#define OMPI_FILE_HIDDEN 0x00000002
|
|
|
|
|
2007-12-21 09:02:00 +03:00
|
|
|
BEGIN_C_DECLS
|
2004-08-14 05:56:05 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Back-end structure for MPI_File
|
|
|
|
*/
|
2004-06-07 19:33:53 +04:00
|
|
|
struct ompi_file_t {
|
2004-09-14 14:55:10 +04:00
|
|
|
/** Base of OBJ_* interface */
|
2005-07-03 20:06:07 +04:00
|
|
|
opal_object_t super;
|
2004-08-14 05:56:05 +04:00
|
|
|
|
2004-09-14 14:55:10 +04:00
|
|
|
/** Communicator that this file was created with */
|
2004-11-05 10:52:30 +03:00
|
|
|
struct ompi_communicator_t *f_comm;
|
2004-01-16 02:57:16 +03:00
|
|
|
|
2004-09-14 14:55:10 +04:00
|
|
|
/** Filename that this file was created with */
|
2004-08-14 05:56:05 +04:00
|
|
|
char *f_filename;
|
2004-01-16 02:57:16 +03:00
|
|
|
|
2004-09-14 14:55:10 +04:00
|
|
|
/** Amode that this file was created with */
|
2004-08-14 05:56:05 +04:00
|
|
|
int f_amode;
|
2004-09-14 14:55:10 +04:00
|
|
|
|
2006-06-13 01:45:48 +04:00
|
|
|
/** MPI_Info that this file was created with. Note that this is
|
|
|
|
*NOT* what should be returned from OMPI_FILE_GET_INFO! */
|
2004-11-05 10:52:30 +03:00
|
|
|
struct ompi_info_t *f_info;
|
2004-09-14 14:55:10 +04:00
|
|
|
|
|
|
|
/** Bit flags */
|
2004-08-14 05:56:05 +04:00
|
|
|
int32_t f_flags;
|
2004-01-16 02:57:16 +03:00
|
|
|
|
2004-09-14 14:55:10 +04:00
|
|
|
/** Index in Fortran <-> C translation array */
|
2004-08-14 05:56:05 +04:00
|
|
|
int f_f_to_c_index;
|
2004-03-19 03:00:09 +03:00
|
|
|
|
2004-09-14 14:55:10 +04:00
|
|
|
/** Error handler. This field does not have the "f_" prefix so
|
|
|
|
that the OMPI_ERRHDL_* macros can find it, regardless of
|
|
|
|
whether it's a comm, window, or file. */
|
2004-11-05 10:52:30 +03:00
|
|
|
struct ompi_errhandler_t *error_handler;
|
2004-09-14 14:55:10 +04:00
|
|
|
|
|
|
|
/** Type of the error handler. This field does not have the "f_"
|
|
|
|
prefix for the same reason as the field error_handler. */
|
|
|
|
ompi_errhandler_type_t errhandler_type;
|
2004-08-14 05:56:05 +04:00
|
|
|
|
2004-09-14 14:55:10 +04:00
|
|
|
/** Indicate what version of the IO component we're using (this
|
|
|
|
indicates what member to look at in the union, below) */
|
|
|
|
mca_io_base_version_t f_io_version;
|
|
|
|
|
2004-12-12 18:29:29 +03:00
|
|
|
/** The selected component (note that this is a union) -- we need
|
|
|
|
this to add and remove the component from the list of
|
|
|
|
components currently in use by the io framework for
|
|
|
|
progression porpoises. */
|
|
|
|
mca_io_base_components_t f_io_selected_component;
|
|
|
|
|
2004-09-14 14:55:10 +04:00
|
|
|
/** The selected module (note that this is a union) */
|
|
|
|
mca_io_base_modules_t f_io_selected_module;
|
|
|
|
|
|
|
|
/** Allow the selected module to cache data on the file */
|
|
|
|
struct mca_io_base_file_t *f_io_selected_data;
|
|
|
|
|
2004-12-12 18:29:29 +03:00
|
|
|
/** Per-module io request freelist */
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_t f_io_requests;
|
2004-12-12 18:29:29 +03:00
|
|
|
|
|
|
|
/** Lock for the per-module io request freelist */
|
2005-07-04 02:45:48 +04:00
|
|
|
opal_mutex_t f_io_requests_lock;
|
2004-01-16 02:57:16 +03:00
|
|
|
};
|
2004-08-14 05:56:05 +04:00
|
|
|
/**
|
|
|
|
* Convenience typedef
|
|
|
|
*/
|
2004-06-07 19:33:53 +04:00
|
|
|
typedef struct ompi_file_t ompi_file_t;
|
2004-01-16 02:57:16 +03:00
|
|
|
|
2009-02-24 20:17:33 +03:00
|
|
|
/**
|
|
|
|
* Padded struct to maintain back compatibiltiy.
|
|
|
|
* See ompi/communicator/communicator.h comments with struct ompi_communicator_t
|
|
|
|
* for full explanation why we chose the following padding construct for predefines.
|
|
|
|
*/
|
|
|
|
#define PREDEFINED_FILE_PAD (sizeof(void*) * 192)
|
|
|
|
|
|
|
|
struct ompi_predefined_file_t {
|
|
|
|
struct ompi_file_t file;
|
|
|
|
char padding[PREDEFINED_FILE_PAD - sizeof(ompi_file_t)];
|
|
|
|
};
|
|
|
|
typedef struct ompi_predefined_file_t ompi_predefined_file_t;
|
2004-08-14 05:56:05 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Back-end instances for MPI_FILE_NULL
|
|
|
|
*/
|
2009-02-24 20:17:33 +03:00
|
|
|
OMPI_DECLSPEC extern ompi_predefined_file_t ompi_mpi_file_null;
|
2004-08-14 05:56:05 +04:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fortran to C conversion table
|
|
|
|
*/
|
2007-12-21 09:02:00 +03:00
|
|
|
extern opal_pointer_array_t ompi_file_f_to_c_table;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize MPI_File handling.
|
|
|
|
*
|
|
|
|
* @retval OMPI_SUCCESS Always.
|
|
|
|
*
|
|
|
|
* Invoked during ompi_mpi_init().
|
|
|
|
*/
|
|
|
|
int ompi_file_init(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Back-end to MPI_FILE_OPEN: create a file handle, select an io
|
|
|
|
* component to use, and have that componet open the file.
|
|
|
|
*
|
|
|
|
* @param comm Communicator
|
|
|
|
* @param filename String filename
|
|
|
|
* @param amode Mode flags
|
|
|
|
* @param info Info
|
|
|
|
* @param fh Output file handle
|
|
|
|
*
|
|
|
|
* @retval OMPI_SUCCESS Upon success
|
|
|
|
* @retval OMPI_ERR* Upon error
|
|
|
|
*
|
|
|
|
* Create a file handle and select an io module to be paired with
|
|
|
|
* it. There is a corresponding ompi_file_close() function; it
|
|
|
|
* mainly calls OBJ_RELEASE() but also does some other error
|
|
|
|
* handling as well.
|
|
|
|
*/
|
|
|
|
int ompi_file_open(struct ompi_communicator_t *comm, char *filename,
|
|
|
|
int amode, struct ompi_info_t *info,
|
|
|
|
ompi_file_t **fh);
|
2004-08-14 05:56:05 +04:00
|
|
|
|
2007-12-21 09:02:00 +03:00
|
|
|
/**
|
|
|
|
* Atomicly set a name on a file handle.
|
|
|
|
*
|
|
|
|
* @param file MPI_File handle to set the name on
|
|
|
|
* @param name NULL-terminated string to use
|
|
|
|
*
|
|
|
|
* @returns OMPI_SUCCESS Always.
|
|
|
|
*
|
|
|
|
* At most (MPI_MAX_OBJECT_NAME-1) characters will be copied over to
|
|
|
|
* the file name's name. This function is performed atomically -- a
|
|
|
|
* lock is used to ensure that there are not multiple writers to the
|
|
|
|
* name to ensure that we don't end up with an erroneous name (e.g.,
|
|
|
|
* a name without a \0 at the end). After invoking this function,
|
|
|
|
* ompi_file_is_name_set() will return true.
|
|
|
|
*/
|
|
|
|
int ompi_file_set_name(ompi_file_t *file, char *name);
|
2004-08-14 05:56:05 +04:00
|
|
|
|
2007-12-21 09:02:00 +03:00
|
|
|
/**
|
|
|
|
* Back-end to MPI_FILE_CLOSE: destroy an ompi_file_t handle and
|
|
|
|
* close the file.
|
|
|
|
*
|
|
|
|
* @param file Pointer to ompi_file_t
|
|
|
|
*
|
|
|
|
* @returns OMPI_SUCCESS Always.
|
|
|
|
*
|
|
|
|
* This is the preferred mechanism for freeing an ompi_file_t.
|
|
|
|
* Although the main action that it performs is OBJ_RELEASE(), it
|
|
|
|
* also does some additional handling for error checking, etc.
|
|
|
|
*/
|
|
|
|
int ompi_file_close(ompi_file_t **file);
|
2004-08-14 05:56:05 +04:00
|
|
|
|
2007-12-21 09:02:00 +03:00
|
|
|
/**
|
|
|
|
* Tear down MPI_File handling.
|
|
|
|
*
|
|
|
|
* @retval OMPI_SUCCESS Always.
|
|
|
|
*
|
|
|
|
* Invoked during ompi_mpi_finalize().
|
|
|
|
*/
|
|
|
|
int ompi_file_finalize(void);
|
|
|
|
|
2004-08-14 05:56:05 +04:00
|
|
|
/**
|
|
|
|
* Check to see if an MPI_File handle is valid.
|
|
|
|
*
|
|
|
|
* @param file The MPI file handle
|
|
|
|
*
|
|
|
|
* @retval true If the file handle is not valid
|
|
|
|
* @retval false If the file handle is valid
|
|
|
|
*
|
|
|
|
* This is a convenience function, mainly for error checking in
|
|
|
|
* top-level MPI API functions.
|
|
|
|
*/
|
|
|
|
static inline bool ompi_file_invalid(ompi_file_t *file)
|
|
|
|
{
|
|
|
|
return (NULL == file ||
|
2009-02-24 20:17:33 +03:00
|
|
|
&ompi_mpi_file_null.file == file ||
|
2004-08-14 05:56:05 +04:00
|
|
|
0 != (file->f_flags & OMPI_FILE_ISCLOSED));
|
|
|
|
}
|
|
|
|
|
2007-12-21 09:02:00 +03:00
|
|
|
END_C_DECLS
|
|
|
|
|
2004-06-07 19:33:53 +04:00
|
|
|
#endif /* OMPI_FILE_H */
|