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_ordered = PMPI_File_read_ordered
00015 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00016 #pragma _HP_SECONDARY_DEF PMPI_File_read_ordered MPI_File_read_ordered
00017 #elif defined(HAVE_PRAGMA_CRI_DUP)
00018 #pragma _CRI duplicate MPI_File_read_ordered as PMPI_File_read_ordered
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
00040
00041
00042
00043 int MPI_File_read_ordered(MPI_File fh, void *buf, int count,
00044 MPI_Datatype datatype, MPI_Status *status)
00045 {
00046 int error_code, datatype_size, nprocs, myrank, i, incr;
00047 #ifndef PRINT_ERR_MSG
00048 static char myname[] = "MPI_FILE_READ_ORDERED";
00049 #endif
00050 ADIO_Offset shared_fp;
00051
00052 #ifdef PRINT_ERR_MSG
00053 if ((fh <= (MPI_File) 0) || (fh->cookie != ADIOI_FILE_COOKIE)) {
00054 FPRINTF(stderr, "MPI_File_read_ordered: Invalid file handle\n");
00055 MPI_Abort(MPI_COMM_WORLD, 1);
00056 }
00057 #else
00058 ADIOI_TEST_FILE_HANDLE(fh, myname);
00059 #endif
00060
00061 if (count < 0) {
00062 #ifdef PRINT_ERR_MSG
00063 FPRINTF(stderr, "MPI_File_read_ordered: Invalid count argument\n");
00064 MPI_Abort(MPI_COMM_WORLD, 1);
00065 #else
00066 error_code = MPIR_Err_setmsg(MPI_ERR_ARG, MPIR_ERR_COUNT_ARG,
00067 myname, (char *) 0, (char *) 0);
00068 return ADIOI_Error(fh, error_code, myname);
00069 #endif
00070 }
00071
00072 if (datatype == MPI_DATATYPE_NULL) {
00073 #ifdef PRINT_ERR_MSG
00074 FPRINTF(stderr, "MPI_File_read_ordered: Invalid datatype\n");
00075 MPI_Abort(MPI_COMM_WORLD, 1);
00076 #else
00077 error_code = MPIR_Err_setmsg(MPI_ERR_TYPE, MPIR_ERR_TYPE_NULL,
00078 myname, (char *) 0, (char *) 0);
00079 return ADIOI_Error(fh, error_code, myname);
00080 #endif
00081 }
00082
00083 MPI_Type_size(datatype, &datatype_size);
00084 if ((count*datatype_size) % fh->etype_size != 0) {
00085 #ifdef PRINT_ERR_MSG
00086 FPRINTF(stderr, "MPI_File_read_ordered: Only an integral number of etypes can be accessed\n");
00087 MPI_Abort(MPI_COMM_WORLD, 1);
00088 #else
00089 error_code = MPIR_Err_setmsg(MPI_ERR_IO, MPIR_ERR_ETYPE_FRACTIONAL,
00090 myname, (char *) 0, (char *) 0);
00091 return ADIOI_Error(fh, error_code, myname);
00092 #endif
00093 }
00094
00095 if ((fh->file_system == ADIO_PIOFS) || (fh->file_system == ADIO_PVFS)) {
00096 #ifdef PRINT_ERR_MSG
00097 FPRINTF(stderr, "MPI_File_read_ordered: Shared file pointer not supported on PIOFS and PVFS\n");
00098 MPI_Abort(MPI_COMM_WORLD, 1);
00099 #else
00100 error_code = MPIR_Err_setmsg(MPI_ERR_UNSUPPORTED_OPERATION,
00101 MPIR_ERR_NO_SHARED_FP, myname, (char *) 0, (char *) 0);
00102 return ADIOI_Error(fh, error_code, myname);
00103 #endif
00104 }
00105
00106 MPI_Comm_size(fh->comm, &nprocs);
00107 MPI_Comm_rank(fh->comm, &myrank);
00108
00109 incr = (count*datatype_size)/fh->etype_size;
00110 for (i=0; i<nprocs; i++) {
00111 if (i == myrank) {
00112 ADIO_Get_shared_fp(fh, incr, &shared_fp, &error_code);
00113 if (error_code != MPI_SUCCESS) {
00114 FPRINTF(stderr, "MPI_File_read_ordered: Error! Could not access shared file pointer.\n");
00115 MPI_Abort(MPI_COMM_WORLD, 1);
00116 }
00117 }
00118 MPI_Barrier(fh->comm);
00119 }
00120
00121 ADIO_ReadStridedColl(fh, buf, count, datatype, ADIO_EXPLICIT_OFFSET,
00122 shared_fp, status, &error_code);
00123
00124 return error_code;
00125 }