00001
00002
00003
00004
00005
00006
00007
00008
00009 #include "mpioimpl.h"
00010
00011 #ifdef HAVE_WEAK_SYMBOLS
00012
00013 #if defined(HAVE_PRAGMA_WEAK)
00014 #pragma weak MPI_File_read_at_all_end = PMPI_File_read_at_all_end
00015 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00016 #pragma _HP_SECONDARY_DEF PMPI_File_read_at_all_end MPI_File_read_at_all_end
00017 #elif defined(HAVE_PRAGMA_CRI_DUP)
00018 #pragma _CRI duplicate MPI_File_read_at_all_end as PMPI_File_read_at_all_end
00019
00020 #endif
00021
00022
00023 #define MPIO_BUILD_PROFILING
00024 #include "mpioprof.h"
00025 #endif
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039 int MPI_File_read_at_all_end(MPI_File fh, void *buf, MPI_Status *status)
00040 {
00041 #ifndef PRINT_ERR_MSG
00042 int error_code;
00043 static char myname[] = "MPI_FILE_READ_AT_ALL_END";
00044 #endif
00045
00046 #ifdef PRINT_ERR_MSG
00047 if ((fh <= (MPI_File) 0) || (fh->cookie != ADIOI_FILE_COOKIE)) {
00048 FPRINTF(stderr, "MPI_File_read_at_all_end: Invalid file handle\n");
00049 MPI_Abort(MPI_COMM_WORLD, 1);
00050 }
00051 #else
00052 ADIOI_TEST_FILE_HANDLE(fh, myname);
00053 #endif
00054
00055 if (!(fh->split_coll_count)) {
00056 #ifdef PRINT_ERR_MSG
00057 FPRINTF(stderr, "MPI_File_read_at_all_end: Does not match a previous MPI_File_read_at_all_begin\n");
00058 MPI_Abort(MPI_COMM_WORLD, 1);
00059 #else
00060 error_code = MPIR_Err_setmsg(MPI_ERR_IO, MPIR_ERR_NO_SPLIT_COLL,
00061 myname, (char *) 0, (char *) 0);
00062 return ADIOI_Error(fh, error_code, myname);
00063 #endif
00064 }
00065
00066 fh->split_coll_count = 0;
00067
00068 return MPI_SUCCESS;
00069 }