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_ordered_end = PMPI_File_read_ordered_end
00014 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00015 #pragma _HP_SECONDARY_DEF PMPI_File_read_ordered_end MPI_File_read_ordered_end
00016 #elif defined(HAVE_PRAGMA_CRI_DUP)
00017 #pragma _CRI duplicate MPI_File_read_ordered_end as PMPI_File_read_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_read_ordered_end(MPI_File mpi_fh, void *buf, MPI_Status *status)
00039 {
00040     int error_code=MPI_SUCCESS;
00041     ADIO_File fh;
00042     static char myname[] = "MPI_FILE_READ_ORDERED_END";
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 fn_exit:
00070     MPIU_THREAD_CS_EXIT(ALLFUNC,);
00071 
00072     return error_code;
00073 }