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_write_all = PMPI_File_write_all
00015 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00016 #pragma _HP_SECONDARY_DEF PMPI_File_write_all MPI_File_write_all
00017 #elif defined(HAVE_PRAGMA_CRI_DUP)
00018 #pragma _CRI duplicate MPI_File_write_all as PMPI_File_write_all
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_write_all(MPI_File fh, void *buf, int count,
00044 MPI_Datatype datatype, MPI_Status *status)
00045 {
00046 int error_code, datatype_size;
00047 #ifndef PRINT_ERR_MSG
00048 static char myname[] = "MPI_FILE_WRITE_ALL";
00049 #endif
00050 #ifdef MPI_hpux
00051 int fl_xmpi;
00052
00053 HPMP_IO_START(fl_xmpi, BLKMPIFILEWRITEALL, TRDTBLOCK, fh, datatype, count);
00054 #endif
00055
00056 #ifdef PRINT_ERR_MSG
00057 if ((fh <= (MPI_File) 0) || (fh->cookie != ADIOI_FILE_COOKIE)) {
00058 FPRINTF(stderr, "MPI_File_write_all: Invalid file handle\n");
00059 MPI_Abort(MPI_COMM_WORLD, 1);
00060 }
00061 #else
00062 ADIOI_TEST_FILE_HANDLE(fh, myname);
00063 #endif
00064
00065 if (count < 0) {
00066 #ifdef PRINT_ERR_MSG
00067 FPRINTF(stderr, "MPI_File_write_all: Invalid count argument\n");
00068 MPI_Abort(MPI_COMM_WORLD, 1);
00069 #else
00070 error_code = MPIR_Err_setmsg(MPI_ERR_ARG, MPIR_ERR_COUNT_ARG,
00071 myname, (char *) 0, (char *) 0);
00072 return ADIOI_Error(fh, error_code, myname);
00073 #endif
00074 }
00075
00076 if (datatype == MPI_DATATYPE_NULL) {
00077 #ifdef PRINT_ERR_MSG
00078 FPRINTF(stderr, "MPI_File_write_all: Invalid datatype\n");
00079 MPI_Abort(MPI_COMM_WORLD, 1);
00080 #else
00081 error_code = MPIR_Err_setmsg(MPI_ERR_TYPE, MPIR_ERR_TYPE_NULL,
00082 myname, (char *) 0, (char *) 0);
00083 return ADIOI_Error(fh, error_code, myname);
00084 #endif
00085 }
00086
00087 MPI_Type_size(datatype, &datatype_size);
00088 if ((count*datatype_size) % fh->etype_size != 0) {
00089 #ifdef PRINT_ERR_MSG
00090 FPRINTF(stderr, "MPI_File_write_all: Only an integral number of etypes can be accessed\n");
00091 MPI_Abort(MPI_COMM_WORLD, 1);
00092 #else
00093 error_code = MPIR_Err_setmsg(MPI_ERR_IO, MPIR_ERR_ETYPE_FRACTIONAL,
00094 myname, (char *) 0, (char *) 0);
00095 return ADIOI_Error(fh, error_code, myname);
00096 #endif
00097 }
00098
00099 if (fh->access_mode & MPI_MODE_SEQUENTIAL) {
00100 #ifdef PRINT_ERR_MSG
00101 FPRINTF(stderr, "MPI_File_write_all: Can't use this function because file was opened with MPI_MODE_SEQUENTIAL\n");
00102 MPI_Abort(MPI_COMM_WORLD, 1);
00103 #else
00104 error_code = MPIR_Err_setmsg(MPI_ERR_UNSUPPORTED_OPERATION,
00105 MPIR_ERR_AMODE_SEQ, myname, (char *) 0, (char *) 0);
00106 return ADIOI_Error(fh, error_code, myname);
00107 #endif
00108 }
00109
00110 ADIO_WriteStridedColl(fh, buf, count, datatype, ADIO_INDIVIDUAL,
00111 0, status, &error_code);
00112 #ifdef MPI_hpux
00113 HPMP_IO_END(fl_xmpi, fh, datatype, count);
00114 #endif
00115 return error_code;
00116 }