xref: /petsc/src/sys/error/errstop.c (revision 10450e9e44b354a0a3da7bbd573407bdf051df10)
1e5c89e4eSSatish Balay 
2c6db04a5SJed Brown #include <petscsys.h> /*I "petscsys.h" I*/
3e5c89e4eSSatish Balay 
4e5c89e4eSSatish Balay /*@C
541e02c4dSJunchao Zhang   PetscMPIAbortErrorHandler - Calls PETSCABORT and exits.
6e5c89e4eSSatish Balay 
7e5c89e4eSSatish Balay   Not Collective
8e5c89e4eSSatish Balay 
9e5c89e4eSSatish Balay   Input Parameters:
10e32f2f54SBarry Smith + comm - communicator over which error occurred
11e32f2f54SBarry Smith . line - the line number of the error (indicated by __LINE__)
12*10450e9eSJacob Faibussowitsch . fun  - the function name
13e5c89e4eSSatish Balay . file - the file in which the error was detected (indicated by __FILE__)
14e5c89e4eSSatish Balay . mess - an error text string, usually just printed to the screen
15e5c89e4eSSatish Balay . n    - the generic error number
16811af0c4SBarry Smith . p    - `PETSC_ERROR_INITIAL` if error just detected, otherwise `PETSC_ERROR_REPEAT`
17e5c89e4eSSatish Balay - ctx  - error handler context
18e5c89e4eSSatish Balay 
19e5c89e4eSSatish Balay   Level: developer
20e5c89e4eSSatish Balay 
21811af0c4SBarry Smith   Note:
22811af0c4SBarry Smith   Users do not directly call this routine
23e5c89e4eSSatish Balay 
24811af0c4SBarry Smith   Use `PetscPushErrorHandler()` to set the desired error handler.  The
25811af0c4SBarry Smith   currently available PETSc error handlers include `PetscTraceBackErrorHandler()`,
26811af0c4SBarry Smith   `PetscMPIAbortErrorHandler()`, `PetscAttachDebuggerErrorHandler()`, and `PetscAbortErrorHandler()`.
27e5c89e4eSSatish Balay 
28db781477SPatrick Sanan .seealso: `PetscError()`, `PetscPushErrorHandler()`, `PetscPopErrorHandler()`, `PetscAttachDebuggerErrorHandler()`,
29db781477SPatrick Sanan           `PetscAbortErrorHandler()`, `PetscMPIAbortErrorHandler()`, `PetscTraceBackErrorHandler()`, `PetscEmacsClientErrorHandler()`, `PetscReturnErrorHandler()`
30e5c89e4eSSatish Balay  @*/
31d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscMPIAbortErrorHandler(MPI_Comm comm, int line, const char *fun, const char *file, PetscErrorCode n, PetscErrorType p, const char *mess, void *ctx)
32d71ae5a4SJacob Faibussowitsch {
333ba16761SJacob Faibussowitsch   PetscErrorCode ierr;
34574034a9SJed Brown   PetscBool      flg1 = PETSC_FALSE, flg2 = PETSC_FALSE, flg3 = PETSC_FALSE;
35e5c89e4eSSatish Balay   PetscLogDouble mem, rss;
36e5c89e4eSSatish Balay 
37e5c89e4eSSatish Balay   PetscFunctionBegin;
38e5c89e4eSSatish Balay   if (!mess) mess = " ";
39e5c89e4eSSatish Balay 
40e5c89e4eSSatish Balay   if (n == PETSC_ERR_MEM) {
413ba16761SJacob Faibussowitsch     ierr = (*PetscErrorPrintf)("%s() at %s:%d\n", fun, file, line);
423ba16761SJacob Faibussowitsch     ierr = (*PetscErrorPrintf)("Out of memory. This could be due to allocating\n");
433ba16761SJacob Faibussowitsch     ierr = (*PetscErrorPrintf)("too large an object or bleeding by not properly\n");
443ba16761SJacob Faibussowitsch     ierr = (*PetscErrorPrintf)("destroying unneeded objects.\n");
453ba16761SJacob Faibussowitsch     ierr = PetscMallocGetCurrentUsage(&mem);
463ba16761SJacob Faibussowitsch     ierr = PetscMemoryGetCurrentUsage(&rss);
473ba16761SJacob Faibussowitsch     ierr = PetscOptionsGetBool(NULL, NULL, "-malloc_dump", &flg1, NULL);
483ba16761SJacob Faibussowitsch     ierr = PetscOptionsGetBool(NULL, NULL, "-malloc_view", &flg2, NULL);
493ba16761SJacob Faibussowitsch     ierr = PetscOptionsHasName(NULL, NULL, "-malloc_view_threshold", &flg3);
503ba16761SJacob Faibussowitsch     if (flg2 || flg3) ierr = PetscMallocView(stdout);
51a297a907SKarl Rupp     else {
523ba16761SJacob Faibussowitsch       ierr = (*PetscErrorPrintf)("Memory allocated %.0f Memory used by process %.0f\n", mem, rss);
533ba16761SJacob Faibussowitsch       if (flg1) ierr = PetscMallocDump(stdout);
543ba16761SJacob Faibussowitsch       else ierr = (*PetscErrorPrintf)("Try running with -malloc_dump or -malloc_view for info.\n");
55e5c89e4eSSatish Balay     }
56e5c89e4eSSatish Balay   } else if (n == PETSC_ERR_SUP) {
573ba16761SJacob Faibussowitsch     ierr = (*PetscErrorPrintf)("%s() at %s:%d\n", fun, file, line);
583ba16761SJacob Faibussowitsch     ierr = (*PetscErrorPrintf)("No support for this operation for this object type!\n");
593ba16761SJacob Faibussowitsch     ierr = (*PetscErrorPrintf)("%s\n", mess);
603ba16761SJacob Faibussowitsch   } else if (n == PETSC_ERR_SIG) ierr = (*PetscErrorPrintf)("%s() at %s:%d %s\n", fun, file, line, mess);
613ba16761SJacob Faibussowitsch   else ierr = (*PetscErrorPrintf)("%s() at %s:%d\n    %s\n", fun, file, line, mess);
62a297a907SKarl Rupp 
633ba16761SJacob Faibussowitsch   (void)ierr;
6441e02c4dSJunchao Zhang   PETSCABORT(PETSC_COMM_WORLD, n);
653ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
66e5c89e4eSSatish Balay }
67