// -*- c++ -*- // // Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana // University Research and Technology // Corporation. All rights reserved. // Copyright (c) 2004-2005 The University of Tennessee and The University // of Tennessee Research Foundation. All rights // reserved. // Copyright (c) 2004-2005 High Performance Computing Center Stuttgart, // University of Stuttgart. All rights reserved. // Copyright (c) 2004-2005 The Regents of the University of California. // All rights reserved. // $COPYRIGHT$ // // Additional copyrights may follow // // $HEADER$ // // // Miscellany // inline MPI::Errhandler MPI::Win::Create_errhandler(MPI::Win::Errhandler_fn* function) { MPI_Errhandler errhandler; (void) MPI_Win_create_errhandler((MPI_Win_errhandler_fn *)function, &errhandler); return errhandler; } inline MPI::Errhandler MPI::Win:: Get_errhandler() const { MPI_Errhandler errhandler; (void) MPI_Win_get_errhandler(mpi_win, &errhandler); return errhandler; } inline void MPI::Win::Set_errhandler(const MPI::Errhandler& errhandler) { (void) MPI_Win_set_errhandler(mpi_win, errhandler); } // // One sided communication // inline void MPI::Win::Accumulate(const void* origin_addr, int origin_count, const MPI::Datatype& origin_datatype, int target_rank, MPI::Aint target_disp, int target_count, const MPI::Datatype& target_datatype, const MPI::Op& op) const { (void) MPI_Accumulate(const_cast(origin_addr), origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, op, mpi_win); } inline void MPI::Win::Complete() const { (void) MPI_Win_complete(mpi_win); } inline MPI::Win MPI::Win::Create(const void* base, MPI::Aint size, int disp_unit, const MPI::Info& info, const MPI::Intracomm& comm) { MPI_Win newwin; (void) MPI_Win_create(const_cast(base), size, disp_unit, info, comm, &newwin); return newwin; } inline void MPI::Win::Fence(int assert) const { (void) MPI_Win_fence(assert, mpi_win); } inline void MPI::Win::Free() { (void) MPI_Win_free(&mpi_win); } inline void MPI::Win::Get(const void *origin_addr, int origin_count, const MPI::Datatype& origin_datatype, int target_rank, MPI::Aint target_disp, int target_count, const MPI::Datatype& target_datatype) const { (void) MPI_Get(const_cast(origin_addr), origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, mpi_win); } inline MPI::Group MPI::Win::Get_group() const { MPI_Group mpi_group; (void) MPI_Win_get_group(mpi_win, &mpi_group); return mpi_group; } inline void MPI::Win::Lock(int lock_type, int rank, int assert) const { (void) MPI_Win_lock(lock_type, rank, assert, mpi_win); } inline void MPI::Win::Post(const MPI::Group& group, int assert) const { (void) MPI_Win_post(group, assert, mpi_win); } inline void MPI::Win::Put(const void* origin_addr, int origin_count, const MPI::Datatype& origin_datatype, int target_rank, MPI::Aint target_disp, int target_count, const MPI::Datatype& target_datatype) const { (void) MPI_Put(const_cast(origin_addr), origin_count, origin_datatype, target_rank, target_disp, target_count, target_datatype, mpi_win); } inline void MPI::Win::Start(const MPI::Group& group, int assert) const { (void) MPI_Win_start(group, assert, mpi_win); } inline bool MPI::Win::Test() const { int flag; MPI_Win_test(mpi_win, &flag); return (bool) flag; } inline void MPI::Win::Unlock(int rank) const { (void) MPI_Win_unlock(rank, mpi_win); } inline void MPI::Win::Wait() const { (void) MPI_Win_wait(mpi_win); } // // External Interfaces // inline void MPI::Win::Call_errhandler(int errorcode) const { (void) MPI_Win_call_errhandler(mpi_win, errorcode); } inline int MPI::Win::Create_keyval(MPI::Win::Copy_attr_function* win_copy_attr_fn, MPI::Win::Delete_attr_function* win_delete_attr_fn, void* extra_state) { int val; (void) MPI_Win_create_keyval((MPI_Win_copy_attr_function *)win_copy_attr_fn, (MPI_Win_delete_attr_function *) win_delete_attr_fn, &val,extra_state); return val; } inline void MPI::Win::Delete_attr(int win_keyval) { (void) MPI_Win_delete_attr(mpi_win, win_keyval); } inline void MPI::Win::Free_keyval(int& win_keyval) { (void) MPI_Win_free_keyval(&win_keyval); } inline bool MPI::Win::Get_attr(const Win& win, int win_keyval, void* attribute_val) const { int ret; (void) MPI_Win_get_attr(win, win_keyval, attribute_val, &ret); return (bool) ret; } inline void MPI::Win::Get_name(char* win_name, int& resultlen) const { (void) MPI_Win_get_name(mpi_win, win_name, &resultlen); } inline void MPI::Win::Set_attr(int win_keyval, const void* attribute_val) { (void) MPI_Win_set_attr(mpi_win, win_keyval, const_cast(attribute_val)); } inline void MPI::Win::Set_name(const char* win_name) { (void) MPI_Win_set_name(mpi_win, const_cast(win_name)); } #if 0 // // User defined functions // typedef int MPI::Win::Copy_attr_function(const Win& oldwin, int win_keyval, void* extra_state, void* attribute_val_in, void* attribute_val_out, bool& flag); typedef int MPI::Win::Delete_attr_function(&win, int win_keyval, void* attribute_val, void* extra_state); typedef void MPI::Win::Errhandler_fn(Win &, int *, ... ); #endif