00001
00002
00003
00004
00005
00006
00007
00008
00009 #include "ad_pfs.h"
00010 #ifdef PROFILE
00011 #include "mpe.h"
00012 #endif
00013
00014 void ADIOI_PFS_WriteContig(ADIO_File fd, void *buf, int count,
00015 MPI_Datatype datatype, int file_ptr_type,
00016 ADIO_Offset offset, ADIO_Status *status, int *error_code)
00017 {
00018 int err=-1, datatype_size, len;
00019 #ifndef PRINT_ERR_MSG
00020 static char myname[] = "ADIOI_PFS_WRITECONTIG";
00021 #endif
00022
00023 MPI_Type_size(datatype, &datatype_size);
00024 len = datatype_size * count;
00025
00026 if (file_ptr_type == ADIO_EXPLICIT_OFFSET) {
00027 if (fd->fp_sys_posn != offset) {
00028 #ifdef PROFILE
00029 MPE_Log_event(11, 0, "start seek");
00030 #endif
00031 lseek(fd->fd_sys, offset, SEEK_SET);
00032 #ifdef PROFILE
00033 MPE_Log_event(12, 0, "end seek");
00034 #endif
00035 }
00036 #ifdef PROFILE
00037 MPE_Log_event(5, 0, "start write");
00038 #endif
00039 err = _cwrite(fd->fd_sys, buf, len);
00040 #ifdef PROFILE
00041 MPE_Log_event(6, 0, "end write");
00042 #endif
00043 fd->fp_sys_posn = offset + err;
00044
00045 }
00046 else {
00047 if (fd->fp_sys_posn != fd->fp_ind) {
00048 #ifdef PROFILE
00049 MPE_Log_event(11, 0, "start seek");
00050 #endif
00051 lseek(fd->fd_sys, fd->fp_ind, SEEK_SET);
00052 #ifdef PROFILE
00053 MPE_Log_event(12, 0, "end seek");
00054 #endif
00055 }
00056 #ifdef PROFILE
00057 MPE_Log_event(5, 0, "start write");
00058 #endif
00059 err = _cwrite(fd->fd_sys, buf, len);
00060 #ifdef PROFILE
00061 MPE_Log_event(6, 0, "end write");
00062 #endif
00063 fd->fp_ind += err;
00064 fd->fp_sys_posn = fd->fp_ind;
00065 }
00066
00067 #ifdef HAVE_STATUS_SET_BYTES
00068 if (err != -1) MPIR_Status_set_bytes(status, datatype, err);
00069 #endif
00070
00071 #ifdef PRINT_ERR_MSG
00072 *error_code = (err == -1) ? MPI_ERR_UNKNOWN : MPI_SUCCESS;
00073 #else
00074 if (err == -1) {
00075 *error_code = MPIR_Err_setmsg(MPI_ERR_IO, MPIR_ADIO_ERROR,
00076 myname, "I/O Error", "%s", strerror(errno));
00077 ADIOI_Error(fd, *error_code, myname);
00078 }
00079 else *error_code = MPI_SUCCESS;
00080 #endif
00081 }
00082
00083
00084 void ADIOI_PFS_WriteStrided(ADIO_File fd, void *buf, int count,
00085 MPI_Datatype datatype, int file_ptr_type,
00086 ADIO_Offset offset, ADIO_Status *status, int
00087 *error_code)
00088 {
00089 ADIOI_GEN_WriteStrided(fd, buf, count, datatype, file_ptr_type,
00090 offset, status, error_code);
00091 }