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_write_ordered_end = PMPI_File_write_ordered_end
00014 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00015 #pragma _HP_SECONDARY_DEF PMPI_File_write_ordered_end MPI_File_write_ordered_end
00016 #elif defined(HAVE_PRAGMA_CRI_DUP)
00017 #pragma _CRI duplicate MPI_File_write_ordered_end as PMPI_File_write_ordered_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 int MPI_File_write_ordered_end(MPI_File mpi_fh, void *buf, MPI_Status *status)
00039 {
00040 int error_code;
00041 static char myname[] = "MPI_FILE_WRITE_ORDERED_END";
00042 ADIO_File fh;
00043
00044 MPIU_UNREFERENCED_ARG(buf);
00045
00046 MPIU_THREAD_CS_ENTER(ALLFUNC,);
00047
00048 fh = MPIO_File_resolve(mpi_fh);
00049
00050
00051 MPIO_CHECK_FILE_HANDLE(fh, myname, error_code);
00052
00053 if (!(fh->split_coll_count))
00054 {
00055 error_code = MPIO_Err_create_code(MPI_SUCCESS, MPIR_ERR_RECOVERABLE,
00056 myname, __LINE__, MPI_ERR_IO,
00057 "**iosplitcollnone", 0);
00058 error_code = MPIO_Err_return_file(fh, error_code);
00059 goto fn_exit;
00060 }
00061
00062
00063 #ifdef HAVE_STATUS_SET_BYTES
00064 if (status != MPI_STATUS_IGNORE)
00065 *status = fh->split_status;
00066 #endif
00067 fh->split_coll_count = 0;
00068
00069
00070 fn_exit:
00071 MPIU_THREAD_CS_EXIT(ALLFUNC,);
00072 return MPI_SUCCESS;
00073 }