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_set_size = PMPI_File_set_size
00015 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00016 #pragma _HP_SECONDARY_DEF PMPI_File_set_size MPI_File_set_size
00017 #elif defined(HAVE_PRAGMA_CRI_DUP)
00018 #pragma _CRI duplicate MPI_File_set_size as PMPI_File_set_size
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 int MPI_File_set_size(MPI_File fh, MPI_Offset size)
00037 {
00038 int error_code;
00039 #ifndef PRINT_ERR_MSG
00040 static char myname[] = "MPI_FILE_SET_SIZE";
00041 #endif
00042 MPI_Offset tmp_sz;
00043 #ifdef MPI_hpux
00044 int fl_xmpi;
00045
00046 HPMP_IO_START(fl_xmpi, BLKMPIFILESETSIZE, TRDTBLOCK, fh,
00047 MPI_DATATYPE_NULL, -1);
00048 #endif
00049
00050 #ifdef PRINT_ERR_MSG
00051 if ((fh <= (MPI_File) 0) || (fh->cookie != ADIOI_FILE_COOKIE)) {
00052 FPRINTF(stderr, "MPI_File_set_size: Invalid file handle\n");
00053 MPI_Abort(MPI_COMM_WORLD, 1);
00054 }
00055 #else
00056 ADIOI_TEST_FILE_HANDLE(fh, myname);
00057 #endif
00058
00059 if (size < 0) {
00060 #ifdef PRINT_ERR_MSG
00061 FPRINTF(stderr, "MPI_File_set_size: Invalid size argument\n");
00062 MPI_Abort(MPI_COMM_WORLD, 1);
00063 #else
00064 error_code = MPIR_Err_setmsg(MPI_ERR_ARG, MPIR_ERR_SIZE_ARG,
00065 myname, (char *) 0, (char *) 0);
00066 return ADIOI_Error(fh, error_code, myname);
00067 #endif
00068 }
00069
00070 tmp_sz = size;
00071 MPI_Bcast(&tmp_sz, 1, ADIO_OFFSET, 0, fh->comm);
00072
00073 if (tmp_sz != size) {
00074 #ifdef PRINT_ERR_MSG
00075 FPRINTF(stderr, "MPI_File_set_size: size argument must be the same on all processes\n");
00076 MPI_Abort(MPI_COMM_WORLD, 1);
00077 #else
00078 error_code = MPIR_Err_setmsg(MPI_ERR_ARG, MPIR_ERR_SIZE_ARG_NOT_SAME,
00079 myname, (char *) 0, (char *) 0);
00080 return ADIOI_Error(fh, error_code, myname);
00081 #endif
00082 }
00083
00084 ADIO_Resize(fh, size, &error_code);
00085
00086 #ifdef MPI_hpux
00087 HPMP_IO_END(fl_xmpi, fh, MPI_DATATYPE_NULL, -1);
00088 #endif
00089
00090 return error_code;
00091 }