[mvapich-discuss] MPIDI_CH3I_Win_allocate_shm segfaults
Jeff Hammond
jeff.science at gmail.com
Tue Apr 29 14:34:30 EDT 2014
I am having issues with ARMCI-MPI3 using MVAPICH 2.0rc1 associated
with win_allocate. If I use win_create, the errors go away (for the
most part).
The details are below. The test is the simplest one that fails. Lots
of tests fail, apparently all because of win_allocate.
I am running with debug=all because I am debugging...
Thanks,
Jeff
Running:
/home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug/bin/mpiexec -n 1 -ppn 1
./test_win_model
GDB:
Core was generated by `./test_win_model'.
Program terminated with signal 11, Segmentation fault.
#0 0x00007f4dc9ae5a57 in MPIDI_CH3I_Win_allocate_shm () from
/home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug/lib/libmpich.so.12
Missing separate debuginfos, use: debuginfo-install
glibc-2.12-1.80.el6_3.7.x86_64 hwloc-1.1-0.1.el6.x86_64
libcxgb3-1.3.1-1.x86_64 libibmad-1.3.8.MLNX_20120424-0.1.x86_64
libibumad-1.3.7.MLNX_20110814-0.1.x86_64
libibverbs-1.1.5mlnx2-1.x86_64 libipathverbs-1.2mlnx1-1.x86_64
libmlx4-1.0.2mlnx6-1.x86_64 libmthca-1.0.6mlnx1-0.1.gbe5eef3.x86_64
libnes-1.1.1mlnx1-1.x86_64 librdmacm-1.0.15-1.x86_64
libxml2-2.7.6-8.el6_3.4.x86_64 numactl-2.0.7-3.el6.x86_64
zlib-1.2.3-27.el6.x86_64
(gdb) bt
#0 0x00007f4dc9ae5a57 in MPIDI_CH3I_Win_allocate_shm () from
/home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug/lib/libmpich.so.12
#1 0x00007f4dc9ab941c in MPIDI_CH3U_Win_allocate () from
/home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug/lib/libmpich.so.12
#2 0x00007f4dc9acb064 in MPID_Win_allocate () from
/home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug/lib/libmpich.so.12
#3 0x00007f4dc9cc541a in PMPI_Win_allocate () from
/home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug/lib/libmpich.so.12
#4 0x0000000000400c11 in main ()
Build info:
[jhammond at vs64 mpi]$ /home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug/bin/mpichversion
MVAPICH2 Version: 2.0rc1
MVAPICH2 Release date: Sun Mar 23 21:35:26 EDT 2014
MVAPICH2 Device: ch3:mrail
MVAPICH2 configure: CC=gcc CXX=g++ --enable-fc FC=gfortran
--enable-f77 F77=gfortran --with-pm=hydra
--prefix=/home/jhammond/TUKEY/MPI/mv2-2.0rc1-debug --enable-static
--enable-g=all --enable-threads
MVAPICH2 CC: gcc -DNDEBUG -DNVALGRIND -g -O2
MVAPICH2 CXX: g++ -DNDEBUG -DNVALGRIND -g
MVAPICH2 F77: gfortran -g -O2
MVAPICH2 FC: gfortran -g
Test source:
#include <stdio.h>
#include <stdlib.h>
#include <mpi.h>
int main(int argc, char ** argv) {
int rank, nproc;
void *ptr;
MPI_Win win;
int wsize = 1024*1024;
void *attr_ptr;
int *attr_val;
int attr_flag;
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &nproc);
if (rank == 0) printf("Starting MPI window attribute test with %d
processes\n", nproc);
/* WIN_CREATE */
MPI_Alloc_mem(wsize, MPI_INFO_NULL, &ptr);
MPI_Win_create(ptr, wsize, 1, MPI_INFO_NULL, MPI_COMM_WORLD, &win);
/* this function will always return flag=false in MPI-2 */
MPI_Win_get_attr(win, MPI_WIN_MODEL, (void *)&attr_ptr, &attr_flag);
if (!attr_flag && rank==0)
printf("MPI_WIN_MODEL flag missing! \n");
attr_val = (int*)attr_ptr;
if (attr_flag && (*attr_val)!=MPI_WIN_UNIFIED && rank==0)
printf("MPI_WIN_MODEL = MPI_WIN_SEPARATE \n" );
MPI_Win_free(&win);
MPI_Free_mem(ptr);
/* WIN_ALLOCATE */
MPI_Win_allocate(wsize, 1, MPI_INFO_NULL, MPI_COMM_WORLD, &ptr, &win);
/* this function will always return flag=false in MPI-2 */
MPI_Win_get_attr(win, MPI_WIN_MODEL, (void *)&attr_ptr, &attr_flag);
if (!attr_flag && rank==0)
printf("MPI_WIN_MODEL flag missing! \n");
attr_val = (int*)attr_ptr;
if (attr_flag && (*attr_val)!=MPI_WIN_UNIFIED && rank==0)
printf("MPI_WIN_MODEL = MPI_WIN_SEPARATE \n" );
MPI_Win_free(&win);
if (rank == 0) printf("ALL DONE\n");
/* WIN_ALLOCATE */
MPI_Finalize();
return 0;
}
--
Jeff Hammond
jeff.science at gmail.com
More information about the mvapich-discuss
mailing list