X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/111a3da5058ade0ddcfb01173504a46ff24c8429..ae9ea58c48e0049739c4efaa84753e8bd81cf03e:/src/smpi/mpi/smpi_file.cpp diff --git a/src/smpi/mpi/smpi_file.cpp b/src/smpi/mpi/smpi_file.cpp index abf21aaa23..a7d4c60283 100644 --- a/src/smpi/mpi/smpi_file.cpp +++ b/src/smpi/mpi/smpi_file.cpp @@ -11,27 +11,26 @@ #include "smpi_win.hpp" #include "smpi_request.hpp" -//setup here, because we have templates in smpi_file we want to log -XBT_LOG_NEW_DEFAULT_SUBCATEGORY(smpi_io, smpi, "Logging specific to SMPI (RMA operations)"); - #include "smpi_file.hpp" #include "smpi_status.hpp" #include "simgrid/plugins/file_system.h" #define FP_SIZE sizeof(MPI_Offset) +XBT_LOG_NEW_DEFAULT_SUBCATEGORY(smpi_io, smpi, "Logging specific to SMPI (RMA operations)"); namespace simgrid{ namespace smpi{ - File::File(MPI_Comm comm, char *filename, int amode, MPI_Info info): comm_(comm), flags_(amode), info_(info) { + File::File(MPI_Comm comm, const char *filename, int amode, MPI_Info info): comm_(comm), flags_(amode), info_(info) { file_= new simgrid::s4u::File(filename, nullptr); list_=nullptr; if (comm_->rank() == 0) { int size= comm_->size() + FP_SIZE; list_ = new char[size]; + errhandler_=MPI_ERRORS_RETURN; memset(list_, 0, size); - shared_file_pointer_ = new MPI_Offset[1]; + shared_file_pointer_ = new MPI_Offset(); shared_mutex_ = s4u::Mutex::create(); *shared_file_pointer_ = 0; win_=new Win(list_, size, 1, MPI_INFO_NULL, comm_); @@ -45,6 +44,11 @@ namespace smpi{ } File::~File(){ + if(comm_->rank() == 0){ + delete shared_file_pointer_; + delete[] list_; + } + delete win_; delete file_; } @@ -57,7 +61,8 @@ namespace smpi{ return MPI_SUCCESS; } - int File::del(char *filename, MPI_Info info){ + int File::del(const char* filename, MPI_Info) + { //get the file with MPI_MODE_DELETE_ON_CLOSE and then close it File* f = new File(MPI_COMM_SELF,filename,MPI_MODE_DELETE_ON_CLOSE|MPI_MODE_RDWR, nullptr); close(&f); @@ -104,7 +109,8 @@ namespace smpi{ return MPI_SUCCESS; } - int File::read(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status){ + int File::read(MPI_File fh, void* /*buf*/, int count, MPI_Datatype datatype, MPI_Status* status) + { //get position first as we may be doing non contiguous reads and it will probably be updated badly MPI_Offset position = fh->file_->tell(); MPI_Offset movesize = datatype->get_extent()*count; @@ -162,13 +168,14 @@ namespace smpi{ return ret; } - int File::write(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status){ + int File::write(MPI_File fh, void* /*buf*/, int count, MPI_Datatype datatype, MPI_Status* status) + { //get position first as we may be doing non contiguous reads and it will probably be updated badly MPI_Offset position = fh->file_->tell(); MPI_Offset movesize = datatype->get_extent()*count; MPI_Offset writesize = datatype->size()*count; XBT_DEBUG("Position before write in MPI_File %s : %llu",fh->file_->get_path(),fh->file_->tell()); - MPI_Offset write = fh->file_->write(writesize); + MPI_Offset write = fh->file_->write(writesize, 1); XBT_VERB("Write in MPI_File %s, %lld bytes written, readsize %lld bytes, movesize %lld", fh->file_->get_path(), write, writesize, movesize); if(writesize!=movesize){ fh->file_->seek(position+movesize, SEEK_SET); @@ -178,16 +185,16 @@ namespace smpi{ return MPI_SUCCESS; } - int File::write_shared(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status){ + int File::write_shared(MPI_File fh, const void *buf, int count, MPI_Datatype datatype, MPI_Status *status){ fh->shared_mutex_->lock(); fh->seek(*(fh->shared_file_pointer_),MPI_SEEK_SET); - write(fh, buf, count, datatype, status); + write(fh, const_cast(buf), count, datatype, status); *(fh->shared_file_pointer_)=fh->file_->tell(); fh->shared_mutex_->unlock(); return MPI_SUCCESS; } - int File::write_ordered(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status){ + int File::write_ordered(MPI_File fh, const void *buf, int count, MPI_Datatype datatype, MPI_Status *status){ //0 needs to get the shared pointer value MPI_Offset val; if(fh->comm_->rank()==0){ @@ -198,7 +205,7 @@ namespace smpi{ MPI_Offset result; simgrid::smpi::Colls::scan(&val, &result, 1, MPI_OFFSET, MPI_SUM, fh->comm_); fh->seek(result, MPI_SEEK_SET); - int ret = fh->op_all(buf, count, datatype, status); + int ret = fh->op_all(const_cast(buf), count, datatype, status); if(fh->comm_->rank()==fh->comm_->size()-1){ fh->shared_mutex_->lock(); *(fh->shared_file_pointer_)=fh->file_->tell(); @@ -222,18 +229,31 @@ namespace smpi{ return simgrid::smpi::Colls::barrier(comm_); } -MPI_Info File::info(){ - if(info_== MPI_INFO_NULL) - info_ = new Info(); - info_->ref(); - return info_; -} + MPI_Info File::info(){ + if(info_== MPI_INFO_NULL) + info_ = new Info(); + info_->ref(); + return info_; + } -void File::set_info(MPI_Info info){ - if(info_!= MPI_INFO_NULL) - info->ref(); - info_=info; -} + void File::set_info(MPI_Info info){ + if(info_!= MPI_INFO_NULL) + info->ref(); + info_=info; + } + + MPI_Comm File::comm(){ + return comm_; + } + MPI_Errhandler File::errhandler(){ + return errhandler_; + } + + void File::set_errhandler(MPI_Errhandler errhandler){ + errhandler_=errhandler; + if(errhandler_!= MPI_ERRHANDLER_NULL) + errhandler->ref(); + } } }