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