00001
00002
00003
00004
00005
00006
00007
00008 #include "mpioimpl.h"
00009
00010 #ifdef HAVE_WEAK_SYMBOLS
00011
00012 #if defined(HAVE_PRAGMA_WEAK)
00013 #pragma weak MPI_File_read_all_end = PMPI_File_read_all_end
00014 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00015 #pragma _HP_SECONDARY_DEF PMPI_File_read_all_end MPI_File_read_all_end
00016 #elif defined(HAVE_PRAGMA_CRI_DUP)
00017 #pragma _CRI duplicate MPI_File_read_all_end as PMPI_File_read_all_end
00018
00019 #endif
00020
00021
00022 #define MPIO_BUILD_PROFILING
00023 #include "mpioprof.h"
00024 #endif
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039 int MPI_File_read_all_end(MPI_File mpi_fh, void *buf, MPI_Status *status)
00040 {
00041 int error_code;
00042 static char myname[] = "MPI_FILE_IREAD";
00043
00044 error_code = MPIOI_File_read_all_end(mpi_fh, buf, myname, status);
00045
00046 return error_code;
00047 }
00048
00049
00050
00051 int MPIOI_File_read_all_end(MPI_File mpi_fh,
00052 void *buf,
00053 char *myname,
00054 MPI_Status *status)
00055 {
00056 int error_code;
00057 ADIO_File fh;
00058
00059 MPIU_UNREFERENCED_ARG(buf);
00060
00061 MPIU_THREAD_CS_ENTER(ALLFUNC,);
00062
00063 fh = MPIO_File_resolve(mpi_fh);
00064
00065
00066 MPIO_CHECK_FILE_HANDLE(fh, myname, error_code);
00067
00068 if (!(fh->split_coll_count)) {
00069 error_code = MPIO_Err_create_code(MPI_SUCCESS, MPIR_ERR_RECOVERABLE,
00070 myname, __LINE__, MPI_ERR_IO,
00071 "**iosplitcollnone", 0);
00072 error_code = MPIO_Err_return_file(fh, error_code);
00073 goto fn_exit;
00074 }
00075
00076
00077 #ifdef HAVE_STATUS_SET_BYTES
00078 if (status != MPI_STATUS_IGNORE)
00079 *status = fh->split_status;
00080 #endif
00081 fh->split_coll_count = 0;
00082
00083 fn_exit:
00084 MPIU_THREAD_CS_EXIT(ALLFUNC,);
00085
00086 return MPI_SUCCESS;
00087 }
00088