Thanks for letting us know, I added some additional error checking (soon to be) in master that will flag the use of incorrect NULL types for function pointers and thus prevent such crashes.
Barry > On Mar 20, 2017, at 7:46 AM, Praveen C <cprav...@gmail.com> wrote: > > It turns out the problem was with this > > call TSMonitorSet(ts, Monitor, ctx, PETSC_NULL_OBJECT, ierr); CHKERRQ(ierr) > > The correct way is > > call TSMonitorSet(ts, Monitor, ctx, PETSC_NULL_FUNCTION, ierr); > CHKERRQ(ierr) > > Thanks > praveen > > On Sat, Mar 18, 2017 at 9:30 PM, Satish Balay <ba...@mcs.anl.gov> wrote: > Perhaps there is some memory corruption - you can try runnng the code with > valgrind. > > Satish > > On Sat, 18 Mar 2017, Praveen C wrote: > > > Dear all > > > > I get a segmentation fault when I call TSDestroy. Without TSDestroy the > > code runs fine. I have included portion of my code below. > > > > subroutine runts(ctx) > > use userdata > > use comdata > > use mtsdata > > implicit none > > #include <petsc/finclude/petsc.h90> > > type(tsdata) :: ctx > > ! Local variables > > integer,parameter :: h = 100 ! File id for history file > > TS :: ts > > Vec :: u > > PetscErrorCode :: ierr > > external :: RHSFunction, Monitor > > > > call VecDuplicate(ctx%p%v_res, u, ierr); CHKERRQ(ierr) > > > > ! Copy initial condition into u > > call VecCopy(ctx%p%v_u, u, ierr); CHKERRQ(ierr) > > > > call TSCreate(PETSC_COMM_WORLD, ts, ierr); CHKERRQ(ierr) > > call TSSetProblemType(ts, TS_NONLINEAR, ierr); CHKERRQ(ierr) > > call TSSetRHSFunction(ts, PETSC_NULL_OBJECT, RHSFunction, ctx, ierr); > > CHKERRQ(ierr) > > call TSSetInitialTimeStep(ts, 0.0, dtg, ierr); CHKERRQ(ierr) > > call TSSetType(ts, TSRK, ierr); CHKERRQ(ierr); > > call TSSetDuration(ts, itmax, tfinal, ierr); CHKERRQ(ierr); > > call TSSetExactFinalTime(ts, TS_EXACTFINALTIME_MATCHSTEP, ierr); > > CHKERRQ(ierr); > > call TSMonitorSet(ts, Monitor, ctx, PETSC_NULL_OBJECT, ierr); > > CHKERRQ(ierr) > > call TSSetSolution(ts, u, ierr); CHKERRQ(ierr) > > call TSSetFromOptions(ts, ierr); CHKERRQ(ierr) > > call TSSetUp(ts, ierr); CHKERRQ(ierr) > > > > call TSSolve(ts, u, ierr); CHKERRQ(ierr) > > > > call VecCopy(u, ctx%p%v_u, ierr); CHKERRQ(ierr) > > call VecDestroy(u, ierr); CHKERRQ(ierr) > > call TSDestroy(ts, ierr); CHKERRQ(ierr) > > > > end subroutine runts > > > > Thanks > > praveen > > > >