Getting deeper into valgrind- and debugger-identified errors is somewhat 
outside the scope of this mailing list -- we're really here to talk about Open 
MPI-related things.

I suggest you read the valgrind documentation and/or google around for other 
memory debugging resources.

Good luck.


On Mar 18, 2011, at 2:07 AM, Jack Bryan wrote:

> Hi, 
> 
> I am running a C++ program with OMPI.
> I got error: 
> 
> *** glibc detected *** /nsga2b: free(): invalid next size (fast): 
> 0x0000000001817a90 ***
> 
> I used GDB: 
> 
> ======= Backtrace: =========
> Program received signal SIGABRT, Aborted.
> 0x00000038b8830265 in raise () from /lib64/libc.so.6
> (gdb) bt
> #0  0x00000038b8830265 in raise () from /lib64/libc.so.6
> #1  0x00000038b8831d10 in abort () from /lib64/libc.so.6
> #2  0x00000038b886a99b in __libc_message () from /lib64/libc.so.6
> #3  0x00000038b887245f in _int_free () from /lib64/libc.so.6
> #4  0x00000038b88728bb in free () from /lib64/libc.so.6
> #5  0x000000000044a4e3 in workerRunTask (message_to_master_type=0x38c06efe18, 
>     nodeSize=2, myRank=1, xVSize=84, objSize=7, 
>     xdata_to_workers_type=0x1206350, 
>     recvXDataVec=std::vector of length 0, capacity 84, myNsga2=..., 
>     Mpara_to_workers_type=0x1205390, events=0x7fffffffb1f0, netplan=...)
>     at src/nsga2/workerRunTask.cpp:447
> #6  0x00000000004514d9 in main (argc=1, argv=0x7fffffffcb48)
>     at src/nsga2/main-parallel2.cpp:425
> -------------------------------------------------
> 
> In valgrind, 
> 
> there are some invalid read and write butno errors about this 
>  free(): invalid next size .
> 
> -----------------------------------------------
> (populp.ind)->xreal   = new double[nreal];
>               (populp.ind)->obj       = new double[nobj];
>               (populp.ind)->constr    = new double[ncon];
>               (populp.ind)->xbin      = new double[nbin];
>               if ((populp.ind)->xreal == NULL || (populp.ind)->obj == NULL || 
> (populp.ind)->constr == NULL || (populp.ind)->xbin == NULL )
>               {
>                       #ifdef DEBUG_workerRunTask
>                       cout << "In workerRunTask(), I am rank "<< myRank << " 
> (populp.ind)->xreal or (populp.ind)->obj or (populp.ind)->constr or 
> (populp.ind)->xbin is NULL .\n\n" << endl;  
>                       #endif
>               }       
> 
> delete [] (populp.ind)->xreal ;
>               delete [] (populp.ind)->xbin ;
>               delete [] (populp.ind)->obj ;
>               delete [] (populp.ind)->constr ;
>               delete [] sendResultArrayPr;
> 
> ----------------------------------------
> 
> thanks
> 
> Any help is really appreciated. 
> 
> _______________________________________________
> users mailing list
> us...@open-mpi.org
> http://www.open-mpi.org/mailman/listinfo.cgi/users


-- 
Jeff Squyres
jsquy...@cisco.com
For corporate legal information go to:
http://www.cisco.com/web/about/doing_business/legal/cri/


Reply via email to