17d0a6c19SBarry Smith 2e5c89e4eSSatish Balay /* 3e5c89e4eSSatish Balay Code that allows one to set the error handlers 4e5c89e4eSSatish Balay */ 5af0996ceSBarry Smith #include <petsc/private/petscimpl.h> /*I "petscsys.h" I*/ 6665c2dedSJed Brown #include <petscviewer.h> 7e5c89e4eSSatish Balay 87c66cc67SJunchao Zhang /* A table of Petsc source files containing calls to PETSCABORT. We assume this table will 97c66cc67SJunchao Zhang stay stable for a while. When things changed, we just need to add new files to the table. 107c66cc67SJunchao Zhang */ 117c66cc67SJunchao Zhang static const char* PetscAbortSourceFiles[] = { 127233276eSBarry Smith "Souce code of main", /* 0 */ 137233276eSBarry Smith "Not Found", /* 1, not found in petsc, but may be in users' code if they called PETSCABORT. */ 147c66cc67SJunchao Zhang "sys/error/adebug.c", 157c66cc67SJunchao Zhang "src/sys/error/errstop.c", 167c66cc67SJunchao Zhang "sys/error/fp.c", 177c66cc67SJunchao Zhang "sys/error/signal.c", /* 5 */ 187c66cc67SJunchao Zhang "sys/ftn-custom/zutils.c", 197c66cc67SJunchao Zhang "sys/logging/utils/stagelog.c", 207c66cc67SJunchao Zhang "sys/mpiuni/mpitime.c", 217c66cc67SJunchao Zhang "sys/objects/init.c", 227c66cc67SJunchao Zhang "sys/objects/pinit.c", /* 10 */ 237c66cc67SJunchao Zhang "vec/vec/interface/dlregisvec.c", 247c66cc67SJunchao Zhang "vec/vec/utils/comb.c" 257c66cc67SJunchao Zhang }; 267c66cc67SJunchao Zhang 277c66cc67SJunchao Zhang /* Find index of the soure file where a PETSCABORT was called. */ 287c66cc67SJunchao Zhang PetscErrorCode PetscAbortFindSourceFile_Private(const char* filepath, PetscInt *idx) 297c66cc67SJunchao Zhang { 307c66cc67SJunchao Zhang PetscErrorCode ierr; 317c66cc67SJunchao Zhang PetscInt i,n = sizeof(PetscAbortSourceFiles)/sizeof(PetscAbortSourceFiles[0]); 327c66cc67SJunchao Zhang PetscBool match; 337c66cc67SJunchao Zhang char subpath[256]; 347c66cc67SJunchao Zhang 357c66cc67SJunchao Zhang PetscFunctionBegin; 3627104ee2SJacob Faibussowitsch PetscValidCharPointer(filepath,1); 377c66cc67SJunchao Zhang PetscValidIntPointer(idx,2); 3827104ee2SJacob Faibussowitsch ierr = PetscStackView(stderr);CHKERRQ(ierr); 397233276eSBarry Smith *idx = 1; 407233276eSBarry Smith for (i=2; i<n; i++) { 417c66cc67SJunchao Zhang ierr = PetscFixFilename(PetscAbortSourceFiles[i],subpath);CHKERRQ(ierr); 427c66cc67SJunchao Zhang ierr = PetscStrendswith(filepath,subpath,&match);CHKERRQ(ierr); 437c66cc67SJunchao Zhang if (match) {*idx = i; break;} 447c66cc67SJunchao Zhang } 457c66cc67SJunchao Zhang PetscFunctionReturn(0); 467c66cc67SJunchao Zhang } 477c66cc67SJunchao Zhang 48e5c89e4eSSatish Balay typedef struct _EH *EH; 49e5c89e4eSSatish Balay struct _EH { 50efca3c55SSatish Balay PetscErrorCode (*handler)(MPI_Comm,int,const char*,const char*,PetscErrorCode,PetscErrorType,const char*,void*); 51e5c89e4eSSatish Balay void *ctx; 52e5c89e4eSSatish Balay EH previous; 53e5c89e4eSSatish Balay }; 54e5c89e4eSSatish Balay 5502c9f0b5SLisandro Dalcin static EH eh = NULL; 56e5c89e4eSSatish Balay 57e5c89e4eSSatish Balay /*@C 58e5c89e4eSSatish Balay PetscEmacsClientErrorHandler - Error handler that uses the emacsclient program to 59a5b23f4aSJose E. Roman load the file where the error occurred. Then calls the "previous" error handler. 60e5c89e4eSSatish Balay 61e5c89e4eSSatish Balay Not Collective 62e5c89e4eSSatish Balay 63e5c89e4eSSatish Balay Input Parameters: 64a5b23f4aSJose E. Roman + comm - communicator over which error occurred 65e32f2f54SBarry Smith . line - the line number of the error (indicated by __LINE__) 66e5c89e4eSSatish Balay . file - the file in which the error was detected (indicated by __FILE__) 67e5c89e4eSSatish Balay . mess - an error text string, usually just printed to the screen 68e5c89e4eSSatish Balay . n - the generic error number 69e5c89e4eSSatish Balay . p - specific error number 70e5c89e4eSSatish Balay - ctx - error handler context 71e5c89e4eSSatish Balay 72e5c89e4eSSatish Balay Options Database Key: 7310699b91SBarry Smith . -on_error_emacs <machinename> - will contact machinename to open the Emacs client there 74e5c89e4eSSatish Balay 75e5c89e4eSSatish Balay Level: developer 76e5c89e4eSSatish Balay 77e5c89e4eSSatish Balay Notes: 78e5c89e4eSSatish Balay You must put (server-start) in your .emacs file for the emacsclient software to work 79e5c89e4eSSatish Balay 80cc12936aSPatrick Sanan Developer Note: 81cc12936aSPatrick Sanan Since this is an error handler it cannot call CHKERRQ(); thus we just return if an error is detected. 823bf036e2SBarry Smith 8345b666d6SBarry Smith .seealso: PetscError(), PetscPushErrorHandler(), PetscPopErrorHandler(), PetscAttachDebuggerErrorHandler(), 8445b666d6SBarry Smith PetscAbortErrorHandler(), PetscMPIAbortErrorHandler(), PetscTraceBackErrorHandler(), PetscReturnErrorHandler() 85e5c89e4eSSatish Balay @*/ 86efca3c55SSatish Balay PetscErrorCode PetscEmacsClientErrorHandler(MPI_Comm comm,int line,const char *fun,const char *file,PetscErrorCode n,PetscErrorType p,const char *mess,void *ctx) 87e5c89e4eSSatish Balay { 88e5c89e4eSSatish Balay PetscErrorCode ierr; 89e5c89e4eSSatish Balay char command[PETSC_MAX_PATH_LEN]; 90e5c89e4eSSatish Balay const char *pdir; 91e5c89e4eSSatish Balay FILE *fp; 92e5c89e4eSSatish Balay 93e5c89e4eSSatish Balay PetscFunctionBegin; 943bf036e2SBarry Smith ierr = PetscGetPetscDir(&pdir);if (ierr) PetscFunctionReturn(ierr); 95efca3c55SSatish Balay sprintf(command,"cd %s; emacsclient --no-wait +%d %s\n",pdir,line,file); 96e5c89e4eSSatish Balay #if defined(PETSC_HAVE_POPEN) 973bf036e2SBarry Smith ierr = PetscPOpen(MPI_COMM_WORLD,(char*)ctx,command,"r",&fp);if (ierr) PetscFunctionReturn(ierr); 98016831caSBarry Smith ierr = PetscPClose(MPI_COMM_WORLD,fp);if (ierr) PetscFunctionReturn(ierr); 99e5c89e4eSSatish Balay #else 100e32f2f54SBarry Smith SETERRQ(PETSC_COMM_SELF,PETSC_ERR_SUP_SYS,"Cannot run external programs on this machine"); 101e5c89e4eSSatish Balay #endif 1023bf036e2SBarry Smith ierr = PetscPopErrorHandler();if (ierr) PetscFunctionReturn(ierr); /* remove this handler from the stack of handlers */ 1033bf036e2SBarry Smith if (!eh) { 10402c9f0b5SLisandro Dalcin ierr = PetscTraceBackErrorHandler(comm,line,fun,file,n,p,mess,NULL);if (ierr) PetscFunctionReturn(ierr); 1053bf036e2SBarry Smith } else { 106efca3c55SSatish Balay ierr = (*eh->handler)(comm,line,fun,file,n,p,mess,eh->ctx);if (ierr) PetscFunctionReturn(ierr); 1073bf036e2SBarry Smith } 108e5c89e4eSSatish Balay PetscFunctionReturn(ierr); 109e5c89e4eSSatish Balay } 110e5c89e4eSSatish Balay 111e5c89e4eSSatish Balay /*@C 112e5c89e4eSSatish Balay PetscPushErrorHandler - Sets a routine to be called on detection of errors. 113e5c89e4eSSatish Balay 114e5c89e4eSSatish Balay Not Collective 115e5c89e4eSSatish Balay 116e5c89e4eSSatish Balay Input Parameters: 117e5c89e4eSSatish Balay + handler - error handler routine 118e5c89e4eSSatish Balay - ctx - optional handler context that contains information needed by the handler (for 119e5c89e4eSSatish Balay example file pointers for error messages etc.) 120e5c89e4eSSatish Balay 121e5c89e4eSSatish Balay Calling sequence of handler: 122efca3c55SSatish Balay $ int handler(MPI_Comm comm,int line,char *func,char *file,PetscErrorCode n,int p,char *mess,void *ctx); 123e5c89e4eSSatish Balay 124a5b23f4aSJose E. Roman + comm - communicator over which error occurred 125e5c89e4eSSatish Balay . line - the line number of the error (indicated by __LINE__) 126e5c89e4eSSatish Balay . file - the file in which the error was detected (indicated by __FILE__) 127e5c89e4eSSatish Balay . n - the generic error number (see list defined in include/petscerror.h) 128668f157eSBarry Smith . p - PETSC_ERROR_INITIAL if error just detected, otherwise PETSC_ERROR_REPEAT 129e5c89e4eSSatish Balay . mess - an error text string, usually just printed to the screen 130e5c89e4eSSatish Balay - ctx - the error handler context 131e5c89e4eSSatish Balay 132e5c89e4eSSatish Balay Options Database Keys: 13310699b91SBarry Smith + -on_error_attach_debugger <noxterm,gdb or dbx> - starts up the debugger if an error occurs 13410699b91SBarry Smith - -on_error_abort - aborts the program if an error occurs 135e5c89e4eSSatish Balay 136e5c89e4eSSatish Balay Level: intermediate 137e5c89e4eSSatish Balay 138e93bc3c1Svictor Notes: 1397850c7c0SBarry Smith The currently available PETSc error handlers include PetscTraceBackErrorHandler(), 140e8fb0fc0SBarry Smith PetscAttachDebuggerErrorHandler(), PetscAbortErrorHandler(), and PetscMPIAbortErrorHandler(), PetscReturnErrorHandler(). 141e93bc3c1Svictor 14295452b02SPatrick Sanan Fortran Notes: 14395452b02SPatrick Sanan You can only push one error handler from Fortran before poping it. 1447850c7c0SBarry Smith 14534b9b2edSBarry Smith .seealso: PetscPopErrorHandler(), PetscAttachDebuggerErrorHandler(), PetscAbortErrorHandler(), PetscTraceBackErrorHandler(), PetscPushSignalHandler() 146e5c89e4eSSatish Balay 147e5c89e4eSSatish Balay @*/ 148efca3c55SSatish Balay PetscErrorCode PetscPushErrorHandler(PetscErrorCode (*handler)(MPI_Comm comm,int,const char*,const char*,PetscErrorCode,PetscErrorType,const char*,void*),void *ctx) 149e5c89e4eSSatish Balay { 150e5c89e4eSSatish Balay EH neweh; 151e5c89e4eSSatish Balay PetscErrorCode ierr; 152e5c89e4eSSatish Balay 153e5c89e4eSSatish Balay PetscFunctionBegin; 154b00a9115SJed Brown ierr = PetscNew(&neweh);CHKERRQ(ierr); 155a297a907SKarl Rupp if (eh) neweh->previous = eh; 15602c9f0b5SLisandro Dalcin else neweh->previous = NULL; 157e5c89e4eSSatish Balay neweh->handler = handler; 158e5c89e4eSSatish Balay neweh->ctx = ctx; 159e5c89e4eSSatish Balay eh = neweh; 160e5c89e4eSSatish Balay PetscFunctionReturn(0); 161e5c89e4eSSatish Balay } 162e5c89e4eSSatish Balay 163e30d2299SSatish Balay /*@ 164e5c89e4eSSatish Balay PetscPopErrorHandler - Removes the latest error handler that was 165e5c89e4eSSatish Balay pushed with PetscPushErrorHandler(). 166e5c89e4eSSatish Balay 167e5c89e4eSSatish Balay Not Collective 168e5c89e4eSSatish Balay 169e5c89e4eSSatish Balay Level: intermediate 170e5c89e4eSSatish Balay 171e5c89e4eSSatish Balay .seealso: PetscPushErrorHandler() 172e5c89e4eSSatish Balay @*/ 1737087cfbeSBarry Smith PetscErrorCode PetscPopErrorHandler(void) 174e5c89e4eSSatish Balay { 175e5c89e4eSSatish Balay EH tmp; 176e5c89e4eSSatish Balay PetscErrorCode ierr; 177e5c89e4eSSatish Balay 178e5c89e4eSSatish Balay PetscFunctionBegin; 179e5c89e4eSSatish Balay if (!eh) PetscFunctionReturn(0); 180e5c89e4eSSatish Balay tmp = eh; 181e5c89e4eSSatish Balay eh = eh->previous; 182e5c89e4eSSatish Balay ierr = PetscFree(tmp);CHKERRQ(ierr); 183e5c89e4eSSatish Balay PetscFunctionReturn(0); 184e5c89e4eSSatish Balay } 185e5c89e4eSSatish Balay 186e93bc3c1Svictor /*@C 18745b666d6SBarry Smith PetscReturnErrorHandler - Error handler that causes a return without printing an error message. 188e93bc3c1Svictor 189e93bc3c1Svictor Not Collective 190e93bc3c1Svictor 191e93bc3c1Svictor Input Parameters: 192e32f2f54SBarry Smith + comm - communicator over which error occurred 193e32f2f54SBarry Smith . line - the line number of the error (indicated by __LINE__) 194e93bc3c1Svictor . file - the file in which the error was detected (indicated by __FILE__) 195e93bc3c1Svictor . mess - an error text string, usually just printed to the screen 196e93bc3c1Svictor . n - the generic error number 197e93bc3c1Svictor . p - specific error number 198e93bc3c1Svictor - ctx - error handler context 199e93bc3c1Svictor 200e93bc3c1Svictor Level: developer 201e93bc3c1Svictor 202e93bc3c1Svictor Notes: 203e93bc3c1Svictor Most users need not directly employ this routine and the other error 204e93bc3c1Svictor handlers, but can instead use the simplified interface SETERRQ, which has 205e93bc3c1Svictor the calling sequence 206e32f2f54SBarry Smith $ SETERRQ(comm,number,mess) 207e93bc3c1Svictor 20845b666d6SBarry Smith PetscIgnoreErrorHandler() does the same thing as this function, but is deprecated, you should use this function. 209e93bc3c1Svictor 21045b666d6SBarry Smith Use PetscPushErrorHandler() to set the desired error handler. 211e93bc3c1Svictor 21245b666d6SBarry Smith .seealso: PetscPushErrorHandler(), PetscPopErrorHandler(), PetscError(), PetscAbortErrorHandler(), PetscMPIAbortErrorHandler(), PetscTraceBackErrorHandler(), 21345b666d6SBarry Smith PetscAttachDebuggerErrorHandler(), PetscEmacsClientErrorHandler() 214e93bc3c1Svictor @*/ 215efca3c55SSatish Balay PetscErrorCode PetscReturnErrorHandler(MPI_Comm comm,int line,const char *fun,const char *file,PetscErrorCode n,PetscErrorType p,const char *mess,void *ctx) 216e93bc3c1Svictor { 217362febeeSStefano Zampini return n; 218e93bc3c1Svictor } 219e93bc3c1Svictor 220e5c89e4eSSatish Balay static char PetscErrorBaseMessage[1024]; 221e5c89e4eSSatish Balay /* 222e5c89e4eSSatish Balay The numerical values for these are defined in include/petscerror.h; any changes 223e5c89e4eSSatish Balay there must also be made here 224e5c89e4eSSatish Balay */ 225e5c89e4eSSatish Balay static const char *PetscErrorStrings[] = { 226e5c89e4eSSatish Balay /*55 */ "Out of memory", 227e5c89e4eSSatish Balay "No support for this operation for this object type", 228e5c89e4eSSatish Balay "No support for this operation on this system", 229e5c89e4eSSatish Balay /*58 */ "Operation done in wrong order", 230e5c89e4eSSatish Balay /*59 */ "Signal received", 231e5c89e4eSSatish Balay /*60 */ "Nonconforming object sizes", 232e5c89e4eSSatish Balay "Argument aliasing not permitted", 233e5c89e4eSSatish Balay "Invalid argument", 234e5c89e4eSSatish Balay /*63 */ "Argument out of range", 235a17b96a8SKyle Gerard Felker "Corrupt argument: https://petsc.org/release/faq/#valgrind", 236e5c89e4eSSatish Balay "Unable to open file", 237e5c89e4eSSatish Balay "Read from file failed", 238e5c89e4eSSatish Balay "Write to file failed", 239e5c89e4eSSatish Balay "Invalid pointer", 240e5c89e4eSSatish Balay /*69 */ "Arguments must have same type", 241a8b45ee7SBarry Smith /*70 */ "Attempt to use a pointer that does not point to a valid accessible location", 242a17b96a8SKyle Gerard Felker /*71 */ "Zero pivot in LU factorization: https://petsc.org/release/faq/#zeropivot", 243e5c89e4eSSatish Balay /*72 */ "Floating point exception", 244e5c89e4eSSatish Balay /*73 */ "Object is in wrong state", 245e5c89e4eSSatish Balay "Corrupted Petsc object", 246e5c89e4eSSatish Balay "Arguments are incompatible", 247e5c89e4eSSatish Balay "Error in external library", 248e5c89e4eSSatish Balay /*77 */ "Petsc has generated inconsistent data", 249a17b96a8SKyle Gerard Felker "Memory corruption: https://petsc.org/release/faq/#valgrind", 250e5c89e4eSSatish Balay "Unexpected data in file", 251e5c89e4eSSatish Balay /*80 */ "Arguments must have same communicators", 252a17b96a8SKyle Gerard Felker /*81 */ "Zero pivot in Cholesky factorization: https://petsc.org/release/faq/#zeropivot", 253e5c89e4eSSatish Balay " ", 254e5c89e4eSSatish Balay " ", 255a17b96a8SKyle Gerard Felker "Overflow in integer operation: https://petsc.org/release/faq/#64-bit-indices", 256e5c89e4eSSatish Balay /*85 */ "Null argument, when expecting valid pointer", 257a17b96a8SKyle Gerard Felker /*86 */ "Unknown type. Check for miss-spelling or missing package: https://petsc.org/release/install/install/#external-packages", 2583d96e996SBarry Smith /*87 */ "MPI library at runtime is not compatible with MPI used at compile time", 2598cda6cd7SBarry Smith /*88 */ "Error in system call", 260a17b96a8SKyle Gerard Felker /*89 */ "Object Type not set: https://petsc.org/release/faq/#object-type-not-set", 26173260a9bSLisandro Dalcin /*90 */ " ", 26273260a9bSLisandro Dalcin /* */ " ", 263a17b96a8SKyle Gerard Felker /*92 */ "See https://petsc.org/release/overview/linear_solve_table/ for possible LU and Cholesky solvers", 264f560318cSPatrick Sanan /*93 */ "You cannot overwrite this option since that will conflict with other previously set options", 265691b26d3SBarry Smith /*94 */ "Example/application run with number of MPI ranks it does not support", 266691b26d3SBarry Smith /*95 */ "Missing or incorrect user input ", 267e57d7714SBarry Smith /*96 */ "GPU resources unavailable ", 268764761abSStefano Zampini /*97 */ "GPU error ", 269764761abSStefano Zampini /*98 */ "General MPI error " 27073260a9bSLisandro Dalcin }; 271e5c89e4eSSatish Balay 272e5c89e4eSSatish Balay /*@C 273e5c89e4eSSatish Balay PetscErrorMessage - returns the text string associated with a PETSc error code. 274e5c89e4eSSatish Balay 275e5c89e4eSSatish Balay Not Collective 276e5c89e4eSSatish Balay 277e5c89e4eSSatish Balay Input Parameter: 278e5c89e4eSSatish Balay . errnum - the error code 279e5c89e4eSSatish Balay 280d8d19677SJose E. Roman Output Parameters: 2810298fd71SBarry Smith + text - the error message (NULL if not desired) 2820298fd71SBarry Smith - specific - the specific error message that was set with SETERRxxx() or PetscError(). (NULL if not desired) 283e5c89e4eSSatish Balay 284e5c89e4eSSatish Balay Level: developer 285e5c89e4eSSatish Balay 28678179f8bSBarry Smith .seealso: PetscPushErrorHandler(), PetscAttachDebuggerErrorHandler(), PetscError(), SETERRQ(), CHKERRQ() 287e5c89e4eSSatish Balay PetscAbortErrorHandler(), PetscTraceBackErrorHandler() 288e5c89e4eSSatish Balay @*/ 2897087cfbeSBarry Smith PetscErrorCode PetscErrorMessage(int errnum,const char *text[],char **specific) 290e5c89e4eSSatish Balay { 291e5c89e4eSSatish Balay PetscFunctionBegin; 292a297a907SKarl Rupp if (text && errnum > PETSC_ERR_MIN_VALUE && errnum < PETSC_ERR_MAX_VALUE) *text = PetscErrorStrings[errnum-PETSC_ERR_MIN_VALUE-1]; 29302c9f0b5SLisandro Dalcin else if (text) *text = NULL; 294e5c89e4eSSatish Balay 295a297a907SKarl Rupp if (specific) *specific = PetscErrorBaseMessage; 296e5c89e4eSSatish Balay PetscFunctionReturn(0); 297e5c89e4eSSatish Balay } 298e5c89e4eSSatish Balay 299984a1229SMatthew G. Knepley #if defined(PETSC_CLANGUAGE_CXX) 300984a1229SMatthew G. Knepley /* C++ exceptions are formally not allowed to propagate through extern "C" code. In practice, far too much software 301984a1229SMatthew G. Knepley * would be broken if implementations did not handle it it some common cases. However, keep in mind 302984a1229SMatthew G. Knepley * 303984a1229SMatthew G. Knepley * Rule 62. Don't allow exceptions to propagate across module boundaries 304984a1229SMatthew G. Knepley * 305984a1229SMatthew G. Knepley * in "C++ Coding Standards" by Sutter and Alexandrescu. (This accounts for part of the ongoing C++ binary interface 306984a1229SMatthew G. Knepley * instability.) Having PETSc raise errors as C++ exceptions was probably misguided and should eventually be removed. 307984a1229SMatthew G. Knepley * 308984a1229SMatthew G. Knepley * Here is the problem: You have a C++ function call a PETSc function, and you would like to maintain the error message 309984a1229SMatthew G. Knepley * and stack information from the PETSc error. You could make everyone write exactly this code in their C++, but that 310984a1229SMatthew G. Knepley * seems crazy to me. 311984a1229SMatthew G. Knepley */ 312984a1229SMatthew G. Knepley #include <sstream> 3134c94c282SMatthew G. Knepley #include <stdexcept> 31470a7d78aSStefano Zampini static void PetscCxxErrorThrow() 31570a7d78aSStefano Zampini { 316984a1229SMatthew G. Knepley const char *str; 317984a1229SMatthew G. Knepley if (eh && eh->ctx) { 318984a1229SMatthew G. Knepley std::ostringstream *msg; 319984a1229SMatthew G. Knepley msg = (std::ostringstream*) eh->ctx; 320984a1229SMatthew G. Knepley str = msg->str().c_str(); 321984a1229SMatthew G. Knepley } else str = "Error detected in C PETSc"; 322984a1229SMatthew G. Knepley 323984a1229SMatthew G. Knepley throw std::runtime_error(str); 324984a1229SMatthew G. Knepley } 325984a1229SMatthew G. Knepley #endif 326984a1229SMatthew G. Knepley 327e5c89e4eSSatish Balay /*@C 32845b666d6SBarry Smith PetscError - Routine that is called when an error has been detected, usually called through the macro SETERRQ(PETSC_COMM_SELF,). 329e5c89e4eSSatish Balay 33045b666d6SBarry Smith Collective on comm 331e5c89e4eSSatish Balay 332e5c89e4eSSatish Balay Input Parameters: 333e32f2f54SBarry Smith + comm - communicator over which error occurred. ALL ranks of this communicator MUST call this routine 334e32f2f54SBarry Smith . line - the line number of the error (indicated by __LINE__) 3353de71b31SHong Zhang . func - the function name in which the error was detected 336e5c89e4eSSatish Balay . file - the file in which the error was detected (indicated by __FILE__) 337e5c89e4eSSatish Balay . n - the generic error number 338d736bfebSBarry Smith . p - PETSC_ERROR_INITIAL indicates the error was initially detected, PETSC_ERROR_REPEAT indicates this is a traceback from a previously detected error 339e5c89e4eSSatish Balay - mess - formatted message string - aka printf 340e5c89e4eSSatish Balay 34145b666d6SBarry Smith Options Database: 34245b666d6SBarry Smith + -error_output_stdout - output the error messages to stdout instead of the default stderr 34345b666d6SBarry Smith - -error_output_none - do not output the error messages 34445b666d6SBarry Smith 345e5c89e4eSSatish Balay Level: intermediate 346e5c89e4eSSatish Balay 347e5c89e4eSSatish Balay Notes: 34845b666d6SBarry Smith PETSc error handling is done with error return codes. A non-zero return indicates an error was detected. Errors are generally not something that the code 34945b666d6SBarry Smith can recover from. Note that numerical errors (potential divide by zero, for example) are not managed by the error return codes; they are managed via, for example, 35045b666d6SBarry Smith KSPGetConvergedReason() that indicates if the solve was successful or not. The option -ksp_error_if_not_converged, for example, turns numerical failures into 35145b666d6SBarry Smith hard errors managed via PetscError(). 35245b666d6SBarry Smith 35345b666d6SBarry Smith PETSc provides a rich supply of error handlers, see the list below, and users can also provide their own error handlers. 35445b666d6SBarry Smith 355e5c89e4eSSatish Balay Most users need not directly use this routine and the error handlers, but 356e5c89e4eSSatish Balay can instead use the simplified interface SETERRQ, which has the calling 357e5c89e4eSSatish Balay sequence 358e32f2f54SBarry Smith $ SETERRQ(comm,n,mess) 359e5c89e4eSSatish Balay 360e3081792SBarry Smith Fortran Note: 361e3081792SBarry Smith This routine is used differently from Fortran 362e3081792SBarry Smith $ PetscError(MPI_Comm comm,PetscErrorCode n,PetscErrorType p,char *message) 363e3081792SBarry Smith 36445b666d6SBarry Smith Set the error handler with PetscPushErrorHandler(). 365e5c89e4eSSatish Balay 3663bf036e2SBarry Smith Developer Note: Since this is called after an error condition it should not be calling any error handlers (currently it ignores any error codes) 3673bf036e2SBarry Smith BUT this routine does call regular PETSc functions that may call error handlers, this is problematic and could be fixed by never calling other PETSc routines 3683bf036e2SBarry Smith but this annoying. 3693bf036e2SBarry Smith 37045b666d6SBarry Smith .seealso: PetscErrorCode, PetscPushErrorHandler(), PetscPopErrorHandler(), PetscTraceBackErrorHandler(), PetscAbortErrorHandler(), PetscMPIAbortErrorHandler(), 37145b666d6SBarry Smith PetscReturnErrorHandler(), PetscAttachDebuggerErrorHandler(), PetscEmacsClientErrorHandler(), 37245b666d6SBarry Smith SETERRQ(), CHKERRQ(), CHKMEMQ, SETERRQ1(), SETERRQ2(), PetscErrorMessage(), PETSCABORT() 373e5c89e4eSSatish Balay @*/ 374efca3c55SSatish Balay PetscErrorCode PetscError(MPI_Comm comm,int line,const char *func,const char *file,PetscErrorCode n,PetscErrorType p,const char *mess,...) 375e5c89e4eSSatish Balay { 376e5c89e4eSSatish Balay va_list Argp; 377c9a19010SBarry Smith size_t fullLength; 37802c9f0b5SLisandro Dalcin char buf[2048],*lbuf = NULL; 379fbfcfee5SBarry Smith PetscBool ismain; 3803bf036e2SBarry Smith PetscErrorCode ierr; 381e5c89e4eSSatish Balay 382e5c89e4eSSatish Balay if (!func) func = "User provided function"; 383e5c89e4eSSatish Balay if (!file) file = "User file"; 3840d577829SBarry Smith if (comm == MPI_COMM_NULL) comm = PETSC_COMM_SELF; 385e5c89e4eSSatish Balay 386e5c89e4eSSatish Balay /* Compose the message evaluating the print format */ 387e5c89e4eSSatish Balay if (mess) { 388e5c89e4eSSatish Balay va_start(Argp,mess); 3892d609e63SMatthew Knepley PetscVSNPrintf(buf,2048,mess,&fullLength,Argp); 390e5c89e4eSSatish Balay va_end(Argp); 391e5c89e4eSSatish Balay lbuf = buf; 39278179f8bSBarry Smith if (p == PETSC_ERROR_INITIAL) PetscStrncpy(PetscErrorBaseMessage,lbuf,1023); 393e5c89e4eSSatish Balay } 394e5c89e4eSSatish Balay 3954ed0ab5bSBarry Smith if (p == PETSC_ERROR_INITIAL && n != PETSC_ERR_MEMC) PetscMallocValidate(__LINE__,PETSC_FUNCTION_NAME,__FILE__); 3964ed0ab5bSBarry Smith 39702c9f0b5SLisandro Dalcin if (!eh) ierr = PetscTraceBackErrorHandler(comm,line,func,file,n,p,lbuf,NULL); 398efca3c55SSatish Balay else ierr = (*eh->handler)(comm,line,func,file,n,p,lbuf,eh->ctx); 399362febeeSStefano Zampini PetscStackClearTop; 400e5c89e4eSSatish Balay 401e5c89e4eSSatish Balay /* 4027233276eSBarry Smith If this is called from the main() routine we call MPI_Abort() instead of 403e5c89e4eSSatish Balay return to allow the parallel program to be properly shutdown. 404e5c89e4eSSatish Balay 4057233276eSBarry Smith Does not call PETSCABORT() since that would provide the wrong source file and line number information 406e5c89e4eSSatish Balay */ 407e5c89e4eSSatish Balay PetscStrncmp(func,"main",4,&ismain); 4087233276eSBarry Smith if (ismain) { 409a0760fecSJunchao Zhang PetscMPIInt errcode; 41065f093c6SBarry Smith errcode = (PetscMPIInt)(0 + 0*line*1000 + ierr); 411baae8e41SSatish Balay if (petscwaitonerrorflg) { PetscSleep(1000); } 41265f093c6SBarry Smith MPI_Abort(MPI_COMM_WORLD,errcode); 4137233276eSBarry Smith } 414a297a907SKarl Rupp 4152c280183SJed Brown #if defined(PETSC_CLANGUAGE_CXX) 416d736bfebSBarry Smith if (p == PETSC_ERROR_IN_CXX) { 4172c280183SJed Brown PetscCxxErrorThrow(); 418d736bfebSBarry Smith } 419d736bfebSBarry Smith #endif 420362febeeSStefano Zampini return ierr; 421e5c89e4eSSatish Balay } 422e5c89e4eSSatish Balay 423e5c89e4eSSatish Balay /* -------------------------------------------------------------------------*/ 424e5c89e4eSSatish Balay 425e5c89e4eSSatish Balay /*@C 426e5c89e4eSSatish Balay PetscIntView - Prints an array of integers; useful for debugging. 427e5c89e4eSSatish Balay 428e5c89e4eSSatish Balay Collective on PetscViewer 429e5c89e4eSSatish Balay 430e5c89e4eSSatish Balay Input Parameters: 431e5c89e4eSSatish Balay + N - number of integers in array 432e5c89e4eSSatish Balay . idx - array of integers 433e5c89e4eSSatish Balay - viewer - location to print array, PETSC_VIEWER_STDOUT_WORLD, PETSC_VIEWER_STDOUT_SELF or 0 434e5c89e4eSSatish Balay 435e5c89e4eSSatish Balay Level: intermediate 436e5c89e4eSSatish Balay 43795452b02SPatrick Sanan Developer Notes: 43895452b02SPatrick Sanan idx cannot be const because may be passed to binary viewer where byte swapping is done 439300a7f5bSBarry Smith 440e5c89e4eSSatish Balay .seealso: PetscRealView() 441e5c89e4eSSatish Balay @*/ 4427087cfbeSBarry Smith PetscErrorCode PetscIntView(PetscInt N,const PetscInt idx[],PetscViewer viewer) 443e5c89e4eSSatish Balay { 444e5c89e4eSSatish Balay PetscErrorCode ierr; 445ca0c3be5SJacob Faibussowitsch PetscMPIInt rank,size; 446e5c89e4eSSatish Balay PetscInt j,i,n = N/20,p = N % 20; 447ace3abfcSBarry Smith PetscBool iascii,isbinary; 448e5c89e4eSSatish Balay MPI_Comm comm; 449e5c89e4eSSatish Balay 450e5c89e4eSSatish Balay PetscFunctionBegin; 451e5c89e4eSSatish Balay if (!viewer) viewer = PETSC_VIEWER_STDOUT_SELF; 4520700a824SBarry Smith PetscValidHeaderSpecific(viewer,PETSC_VIEWER_CLASSID,3); 4535ab33896SBarry Smith if (N) PetscValidIntPointer(idx,2); 454e5c89e4eSSatish Balay ierr = PetscObjectGetComm((PetscObject)viewer,&comm);CHKERRQ(ierr); 455ffc4695bSBarry Smith ierr = MPI_Comm_size(comm,&size);CHKERRMPI(ierr); 456ffc4695bSBarry Smith ierr = MPI_Comm_rank(comm,&rank);CHKERRMPI(ierr); 457e5c89e4eSSatish Balay 458251f4c67SDmitry Karpeev ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&iascii);CHKERRQ(ierr); 459251f4c67SDmitry Karpeev ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERBINARY,&isbinary);CHKERRQ(ierr); 460e5c89e4eSSatish Balay if (iascii) { 4611575c14dSBarry Smith ierr = PetscViewerASCIIPushSynchronized(viewer);CHKERRQ(ierr); 462e5c89e4eSSatish Balay for (i=0; i<n; i++) { 463ca0c3be5SJacob Faibussowitsch if (size > 1) { 464ca0c3be5SJacob Faibussowitsch ierr = PetscViewerASCIISynchronizedPrintf(viewer,"[%d] %D:", rank, 20*i);CHKERRQ(ierr); 465ca0c3be5SJacob Faibussowitsch } else { 466e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"%D:",20*i);CHKERRQ(ierr); 467ca0c3be5SJacob Faibussowitsch } 468e5c89e4eSSatish Balay for (j=0; j<20; j++) { 469e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer," %D",idx[i*20+j]);CHKERRQ(ierr); 470e5c89e4eSSatish Balay } 471e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"\n");CHKERRQ(ierr); 472e5c89e4eSSatish Balay } 473e5c89e4eSSatish Balay if (p) { 474ca0c3be5SJacob Faibussowitsch if (size > 1) { 475ca0c3be5SJacob Faibussowitsch ierr = PetscViewerASCIISynchronizedPrintf(viewer,"[%d] %D:",rank ,20*n);CHKERRQ(ierr); 476ca0c3be5SJacob Faibussowitsch } else { 477e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"%D:",20*n);CHKERRQ(ierr); 478ca0c3be5SJacob Faibussowitsch } 479e5c89e4eSSatish Balay for (i=0; i<p; i++) { ierr = PetscViewerASCIISynchronizedPrintf(viewer," %D",idx[20*n+i]);CHKERRQ(ierr);} 480e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"\n");CHKERRQ(ierr); 481e5c89e4eSSatish Balay } 482e5c89e4eSSatish Balay ierr = PetscViewerFlush(viewer);CHKERRQ(ierr); 4831575c14dSBarry Smith ierr = PetscViewerASCIIPopSynchronized(viewer);CHKERRQ(ierr); 4846805f65bSBarry Smith } else if (isbinary) { 485ca0c3be5SJacob Faibussowitsch PetscMPIInt *sizes,Ntotal,*displs,NN; 486e5c89e4eSSatish Balay PetscInt *array; 487783b601eSJed Brown 4884dc2109aSBarry Smith ierr = PetscMPIIntCast(N,&NN);CHKERRQ(ierr); 489e5c89e4eSSatish Balay 490e5c89e4eSSatish Balay if (size > 1) { 491e5c89e4eSSatish Balay if (rank) { 492ffc4695bSBarry Smith ierr = MPI_Gather(&NN,1,MPI_INT,NULL,0,MPI_INT,0,comm);CHKERRMPI(ierr); 493ffc4695bSBarry Smith ierr = MPI_Gatherv((void*)idx,NN,MPIU_INT,NULL,NULL,NULL,MPIU_INT,0,comm);CHKERRMPI(ierr); 494e5c89e4eSSatish Balay } else { 495785e854fSJed Brown ierr = PetscMalloc1(size,&sizes);CHKERRQ(ierr); 49655b25c41SPierre Jolivet ierr = MPI_Gather(&NN,1,MPI_INT,sizes,1,MPI_INT,0,comm);CHKERRMPI(ierr); 497e5c89e4eSSatish Balay Ntotal = sizes[0]; 498785e854fSJed Brown ierr = PetscMalloc1(size,&displs);CHKERRQ(ierr); 499e5c89e4eSSatish Balay displs[0] = 0; 500e5c89e4eSSatish Balay for (i=1; i<size; i++) { 501e5c89e4eSSatish Balay Ntotal += sizes[i]; 502e5c89e4eSSatish Balay displs[i] = displs[i-1] + sizes[i-1]; 503e5c89e4eSSatish Balay } 504785e854fSJed Brown ierr = PetscMalloc1(Ntotal,&array);CHKERRQ(ierr); 505ffc4695bSBarry Smith ierr = MPI_Gatherv((void*)idx,NN,MPIU_INT,array,sizes,displs,MPIU_INT,0,comm);CHKERRMPI(ierr); 506f253e43cSLisandro Dalcin ierr = PetscViewerBinaryWrite(viewer,array,Ntotal,PETSC_INT);CHKERRQ(ierr); 507e5c89e4eSSatish Balay ierr = PetscFree(sizes);CHKERRQ(ierr); 508e5c89e4eSSatish Balay ierr = PetscFree(displs);CHKERRQ(ierr); 509e5c89e4eSSatish Balay ierr = PetscFree(array);CHKERRQ(ierr); 510e5c89e4eSSatish Balay } 511e5c89e4eSSatish Balay } else { 512f253e43cSLisandro Dalcin ierr = PetscViewerBinaryWrite(viewer,idx,N,PETSC_INT);CHKERRQ(ierr); 513e5c89e4eSSatish Balay } 514e5c89e4eSSatish Balay } else { 515e5c89e4eSSatish Balay const char *tname; 516e5c89e4eSSatish Balay ierr = PetscObjectGetName((PetscObject)viewer,&tname);CHKERRQ(ierr); 517e32f2f54SBarry Smith SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_SUP,"Cannot handle that PetscViewer of type %s",tname); 518e5c89e4eSSatish Balay } 519e5c89e4eSSatish Balay PetscFunctionReturn(0); 520e5c89e4eSSatish Balay } 521e5c89e4eSSatish Balay 522e5c89e4eSSatish Balay /*@C 523e5c89e4eSSatish Balay PetscRealView - Prints an array of doubles; useful for debugging. 524e5c89e4eSSatish Balay 525e5c89e4eSSatish Balay Collective on PetscViewer 526e5c89e4eSSatish Balay 527e5c89e4eSSatish Balay Input Parameters: 528cba51d77SBarry Smith + N - number of PetscReal in array 529cba51d77SBarry Smith . idx - array of PetscReal 530e5c89e4eSSatish Balay - viewer - location to print array, PETSC_VIEWER_STDOUT_WORLD, PETSC_VIEWER_STDOUT_SELF or 0 531e5c89e4eSSatish Balay 532e5c89e4eSSatish Balay Level: intermediate 533e5c89e4eSSatish Balay 53495452b02SPatrick Sanan Developer Notes: 53595452b02SPatrick Sanan idx cannot be const because may be passed to binary viewer where byte swapping is done 536300a7f5bSBarry Smith 537e5c89e4eSSatish Balay .seealso: PetscIntView() 538e5c89e4eSSatish Balay @*/ 5397087cfbeSBarry Smith PetscErrorCode PetscRealView(PetscInt N,const PetscReal idx[],PetscViewer viewer) 540e5c89e4eSSatish Balay { 541e5c89e4eSSatish Balay PetscErrorCode ierr; 542ca0c3be5SJacob Faibussowitsch PetscMPIInt rank,size; 543e5c89e4eSSatish Balay PetscInt j,i,n = N/5,p = N % 5; 544ace3abfcSBarry Smith PetscBool iascii,isbinary; 545e5c89e4eSSatish Balay MPI_Comm comm; 546e5c89e4eSSatish Balay 547e5c89e4eSSatish Balay PetscFunctionBegin; 548e5c89e4eSSatish Balay if (!viewer) viewer = PETSC_VIEWER_STDOUT_SELF; 5490700a824SBarry Smith PetscValidHeaderSpecific(viewer,PETSC_VIEWER_CLASSID,3); 550064a246eSJacob Faibussowitsch PetscValidRealPointer(idx,2); 551e5c89e4eSSatish Balay ierr = PetscObjectGetComm((PetscObject)viewer,&comm);CHKERRQ(ierr); 552ffc4695bSBarry Smith ierr = MPI_Comm_size(comm,&size);CHKERRMPI(ierr); 553ffc4695bSBarry Smith ierr = MPI_Comm_rank(comm,&rank);CHKERRMPI(ierr); 554e5c89e4eSSatish Balay 555251f4c67SDmitry Karpeev ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&iascii);CHKERRQ(ierr); 556251f4c67SDmitry Karpeev ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERBINARY,&isbinary);CHKERRQ(ierr); 557e5c89e4eSSatish Balay if (iascii) { 5581a989b97SToby Isaac PetscInt tab; 5591a989b97SToby Isaac 5601575c14dSBarry Smith ierr = PetscViewerASCIIPushSynchronized(viewer);CHKERRQ(ierr); 5611a989b97SToby Isaac ierr = PetscViewerASCIIGetTab(viewer, &tab);CHKERRQ(ierr); 562e5c89e4eSSatish Balay for (i=0; i<n; i++) { 5631a989b97SToby Isaac ierr = PetscViewerASCIISetTab(viewer, tab);CHKERRQ(ierr); 564ca0c3be5SJacob Faibussowitsch if (size > 1) { 565ca0c3be5SJacob Faibussowitsch ierr = PetscViewerASCIISynchronizedPrintf(viewer,"[%d] %2d:",rank ,(int)5*i);CHKERRQ(ierr); 566ca0c3be5SJacob Faibussowitsch } else { 5677824ef9bSBarry Smith ierr = PetscViewerASCIISynchronizedPrintf(viewer,"%2d:",(int)5*i);CHKERRQ(ierr); 568ca0c3be5SJacob Faibussowitsch } 5691a989b97SToby Isaac ierr = PetscViewerASCIISetTab(viewer, 0);CHKERRQ(ierr); 570e5c89e4eSSatish Balay for (j=0; j<5; j++) { 571cba51d77SBarry Smith ierr = PetscViewerASCIISynchronizedPrintf(viewer," %12.4e",(double)idx[i*5+j]);CHKERRQ(ierr); 572e5c89e4eSSatish Balay } 573e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"\n");CHKERRQ(ierr); 574e5c89e4eSSatish Balay } 575e5c89e4eSSatish Balay if (p) { 5761a989b97SToby Isaac ierr = PetscViewerASCIISetTab(viewer, tab);CHKERRQ(ierr); 577ca0c3be5SJacob Faibussowitsch if (size > 1) { 578ca0c3be5SJacob Faibussowitsch ierr = PetscViewerASCIISynchronizedPrintf(viewer,"[%d] %2d:",rank ,(int)5*n);CHKERRQ(ierr); 579ca0c3be5SJacob Faibussowitsch } else { 5807824ef9bSBarry Smith ierr = PetscViewerASCIISynchronizedPrintf(viewer,"%2d:",(int)5*n);CHKERRQ(ierr); 581ca0c3be5SJacob Faibussowitsch } 5821a989b97SToby Isaac ierr = PetscViewerASCIISetTab(viewer, 0);CHKERRQ(ierr); 583*2f613bf5SBarry Smith for (i=0; i<p; i++) {ierr = PetscViewerASCIISynchronizedPrintf(viewer," %12.4e",(double)idx[5*n+i]);CHKERRQ(ierr);} 584e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"\n");CHKERRQ(ierr); 585e5c89e4eSSatish Balay } 586e5c89e4eSSatish Balay ierr = PetscViewerFlush(viewer);CHKERRQ(ierr); 5871a989b97SToby Isaac ierr = PetscViewerASCIISetTab(viewer, tab);CHKERRQ(ierr); 5881575c14dSBarry Smith ierr = PetscViewerASCIIPopSynchronized(viewer);CHKERRQ(ierr); 5896805f65bSBarry Smith } else if (isbinary) { 590ca0c3be5SJacob Faibussowitsch PetscMPIInt *sizes,*displs, Ntotal,NN; 591e5c89e4eSSatish Balay PetscReal *array; 592e5c89e4eSSatish Balay 5934dc2109aSBarry Smith ierr = PetscMPIIntCast(N,&NN);CHKERRQ(ierr); 594e5c89e4eSSatish Balay 595e5c89e4eSSatish Balay if (size > 1) { 596e5c89e4eSSatish Balay if (rank) { 597ffc4695bSBarry Smith ierr = MPI_Gather(&NN,1,MPI_INT,NULL,0,MPI_INT,0,comm);CHKERRMPI(ierr); 598ffc4695bSBarry Smith ierr = MPI_Gatherv((PetscReal*)idx,NN,MPIU_REAL,NULL,NULL,NULL,MPIU_REAL,0,comm);CHKERRMPI(ierr); 599e5c89e4eSSatish Balay } else { 600785e854fSJed Brown ierr = PetscMalloc1(size,&sizes);CHKERRQ(ierr); 60155b25c41SPierre Jolivet ierr = MPI_Gather(&NN,1,MPI_INT,sizes,1,MPI_INT,0,comm);CHKERRMPI(ierr); 602e5c89e4eSSatish Balay Ntotal = sizes[0]; 603785e854fSJed Brown ierr = PetscMalloc1(size,&displs);CHKERRQ(ierr); 604e5c89e4eSSatish Balay displs[0] = 0; 605e5c89e4eSSatish Balay for (i=1; i<size; i++) { 606e5c89e4eSSatish Balay Ntotal += sizes[i]; 607e5c89e4eSSatish Balay displs[i] = displs[i-1] + sizes[i-1]; 608e5c89e4eSSatish Balay } 609785e854fSJed Brown ierr = PetscMalloc1(Ntotal,&array);CHKERRQ(ierr); 610ffc4695bSBarry Smith ierr = MPI_Gatherv((PetscReal*)idx,NN,MPIU_REAL,array,sizes,displs,MPIU_REAL,0,comm);CHKERRMPI(ierr); 611f253e43cSLisandro Dalcin ierr = PetscViewerBinaryWrite(viewer,array,Ntotal,PETSC_REAL);CHKERRQ(ierr); 612e5c89e4eSSatish Balay ierr = PetscFree(sizes);CHKERRQ(ierr); 613e5c89e4eSSatish Balay ierr = PetscFree(displs);CHKERRQ(ierr); 614e5c89e4eSSatish Balay ierr = PetscFree(array);CHKERRQ(ierr); 615e5c89e4eSSatish Balay } 616e5c89e4eSSatish Balay } else { 617f253e43cSLisandro Dalcin ierr = PetscViewerBinaryWrite(viewer,(void*) idx,N,PETSC_REAL);CHKERRQ(ierr); 618e5c89e4eSSatish Balay } 619e5c89e4eSSatish Balay } else { 620e5c89e4eSSatish Balay const char *tname; 621e5c89e4eSSatish Balay ierr = PetscObjectGetName((PetscObject)viewer,&tname);CHKERRQ(ierr); 622e32f2f54SBarry Smith SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_SUP,"Cannot handle that PetscViewer of type %s",tname); 623e5c89e4eSSatish Balay } 624e5c89e4eSSatish Balay PetscFunctionReturn(0); 625e5c89e4eSSatish Balay } 626e5c89e4eSSatish Balay 627e5c89e4eSSatish Balay /*@C 628e5c89e4eSSatish Balay PetscScalarView - Prints an array of scalars; useful for debugging. 629e5c89e4eSSatish Balay 630e5c89e4eSSatish Balay Collective on PetscViewer 631e5c89e4eSSatish Balay 632e5c89e4eSSatish Balay Input Parameters: 633e5c89e4eSSatish Balay + N - number of scalars in array 634e5c89e4eSSatish Balay . idx - array of scalars 635e5c89e4eSSatish Balay - viewer - location to print array, PETSC_VIEWER_STDOUT_WORLD, PETSC_VIEWER_STDOUT_SELF or 0 636e5c89e4eSSatish Balay 637e5c89e4eSSatish Balay Level: intermediate 638e5c89e4eSSatish Balay 63995452b02SPatrick Sanan Developer Notes: 64095452b02SPatrick Sanan idx cannot be const because may be passed to binary viewer where byte swapping is done 641300a7f5bSBarry Smith 642e5c89e4eSSatish Balay .seealso: PetscIntView(), PetscRealView() 643e5c89e4eSSatish Balay @*/ 6447087cfbeSBarry Smith PetscErrorCode PetscScalarView(PetscInt N,const PetscScalar idx[],PetscViewer viewer) 645e5c89e4eSSatish Balay { 646e5c89e4eSSatish Balay PetscErrorCode ierr; 647ca0c3be5SJacob Faibussowitsch PetscMPIInt rank,size; 648e5c89e4eSSatish Balay PetscInt j,i,n = N/3,p = N % 3; 649ace3abfcSBarry Smith PetscBool iascii,isbinary; 650e5c89e4eSSatish Balay MPI_Comm comm; 651e5c89e4eSSatish Balay 652e5c89e4eSSatish Balay PetscFunctionBegin; 653e5c89e4eSSatish Balay if (!viewer) viewer = PETSC_VIEWER_STDOUT_SELF; 654e5c89e4eSSatish Balay PetscValidHeader(viewer,3); 6558c34849bSStefano Zampini if (N) PetscValidScalarPointer(idx,2); 656e5c89e4eSSatish Balay ierr = PetscObjectGetComm((PetscObject)viewer,&comm);CHKERRQ(ierr); 657ffc4695bSBarry Smith ierr = MPI_Comm_size(comm,&size);CHKERRMPI(ierr); 658ffc4695bSBarry Smith ierr = MPI_Comm_rank(comm,&rank);CHKERRMPI(ierr); 659e5c89e4eSSatish Balay 660251f4c67SDmitry Karpeev ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&iascii);CHKERRQ(ierr); 661251f4c67SDmitry Karpeev ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERBINARY,&isbinary);CHKERRQ(ierr); 662e5c89e4eSSatish Balay if (iascii) { 6631575c14dSBarry Smith ierr = PetscViewerASCIIPushSynchronized(viewer);CHKERRQ(ierr); 664e5c89e4eSSatish Balay for (i=0; i<n; i++) { 665ca0c3be5SJacob Faibussowitsch if (size > 1) { 666ca0c3be5SJacob Faibussowitsch ierr = PetscViewerASCIISynchronizedPrintf(viewer,"[%d] %2d:",rank ,3*i);CHKERRQ(ierr); 667ca0c3be5SJacob Faibussowitsch } else { 668e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"%2d:",3*i);CHKERRQ(ierr); 669ca0c3be5SJacob Faibussowitsch } 670e5c89e4eSSatish Balay for (j=0; j<3; j++) { 671e5c89e4eSSatish Balay #if defined(PETSC_USE_COMPLEX) 672cba51d77SBarry Smith ierr = PetscViewerASCIISynchronizedPrintf(viewer," (%12.4e,%12.4e)", (double)PetscRealPart(idx[i*3+j]),(double)PetscImaginaryPart(idx[i*3+j]));CHKERRQ(ierr); 673e5c89e4eSSatish Balay #else 674cba51d77SBarry Smith ierr = PetscViewerASCIISynchronizedPrintf(viewer," %12.4e",(double)idx[i*3+j]);CHKERRQ(ierr); 675e5c89e4eSSatish Balay #endif 676e5c89e4eSSatish Balay } 677e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"\n");CHKERRQ(ierr); 678e5c89e4eSSatish Balay } 679e5c89e4eSSatish Balay if (p) { 680ca0c3be5SJacob Faibussowitsch if (size > 1) { 681ca0c3be5SJacob Faibussowitsch ierr = PetscViewerASCIISynchronizedPrintf(viewer,"[%d] %2d:",rank ,3*n);CHKERRQ(ierr); 682ca0c3be5SJacob Faibussowitsch } else { 683e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"%2d:",3*n);CHKERRQ(ierr); 684ca0c3be5SJacob Faibussowitsch } 685e5c89e4eSSatish Balay for (i=0; i<p; i++) { 686e5c89e4eSSatish Balay #if defined(PETSC_USE_COMPLEX) 687cba51d77SBarry Smith ierr = PetscViewerASCIISynchronizedPrintf(viewer," (%12.4e,%12.4e)", (double)PetscRealPart(idx[n*3+i]),(double)PetscImaginaryPart(idx[n*3+i]));CHKERRQ(ierr); 688e5c89e4eSSatish Balay #else 689cba51d77SBarry Smith ierr = PetscViewerASCIISynchronizedPrintf(viewer," %12.4e",(double)idx[3*n+i]);CHKERRQ(ierr); 690e5c89e4eSSatish Balay #endif 691e5c89e4eSSatish Balay } 692e5c89e4eSSatish Balay ierr = PetscViewerASCIISynchronizedPrintf(viewer,"\n");CHKERRQ(ierr); 693e5c89e4eSSatish Balay } 694e5c89e4eSSatish Balay ierr = PetscViewerFlush(viewer);CHKERRQ(ierr); 6951575c14dSBarry Smith ierr = PetscViewerASCIIPopSynchronized(viewer);CHKERRQ(ierr); 6966805f65bSBarry Smith } else if (isbinary) { 697ca0c3be5SJacob Faibussowitsch PetscMPIInt *sizes,Ntotal,*displs,NN; 698e5c89e4eSSatish Balay PetscScalar *array; 699e5c89e4eSSatish Balay 7004dc2109aSBarry Smith ierr = PetscMPIIntCast(N,&NN);CHKERRQ(ierr); 701e5c89e4eSSatish Balay 702e5c89e4eSSatish Balay if (size > 1) { 703e5c89e4eSSatish Balay if (rank) { 704ffc4695bSBarry Smith ierr = MPI_Gather(&NN,1,MPI_INT,NULL,0,MPI_INT,0,comm);CHKERRMPI(ierr); 705ffc4695bSBarry Smith ierr = MPI_Gatherv((void*)idx,NN,MPIU_SCALAR,NULL,NULL,NULL,MPIU_SCALAR,0,comm);CHKERRMPI(ierr); 706e5c89e4eSSatish Balay } else { 707785e854fSJed Brown ierr = PetscMalloc1(size,&sizes);CHKERRQ(ierr); 70855b25c41SPierre Jolivet ierr = MPI_Gather(&NN,1,MPI_INT,sizes,1,MPI_INT,0,comm);CHKERRMPI(ierr); 709e5c89e4eSSatish Balay Ntotal = sizes[0]; 710785e854fSJed Brown ierr = PetscMalloc1(size,&displs);CHKERRQ(ierr); 711e5c89e4eSSatish Balay displs[0] = 0; 712e5c89e4eSSatish Balay for (i=1; i<size; i++) { 713e5c89e4eSSatish Balay Ntotal += sizes[i]; 714e5c89e4eSSatish Balay displs[i] = displs[i-1] + sizes[i-1]; 715e5c89e4eSSatish Balay } 716785e854fSJed Brown ierr = PetscMalloc1(Ntotal,&array);CHKERRQ(ierr); 717ffc4695bSBarry Smith ierr = MPI_Gatherv((void*)idx,NN,MPIU_SCALAR,array,sizes,displs,MPIU_SCALAR,0,comm);CHKERRMPI(ierr); 718f253e43cSLisandro Dalcin ierr = PetscViewerBinaryWrite(viewer,array,Ntotal,PETSC_SCALAR);CHKERRQ(ierr); 719e5c89e4eSSatish Balay ierr = PetscFree(sizes);CHKERRQ(ierr); 720e5c89e4eSSatish Balay ierr = PetscFree(displs);CHKERRQ(ierr); 721e5c89e4eSSatish Balay ierr = PetscFree(array);CHKERRQ(ierr); 722e5c89e4eSSatish Balay } 723e5c89e4eSSatish Balay } else { 724f253e43cSLisandro Dalcin ierr = PetscViewerBinaryWrite(viewer,(void*) idx,N,PETSC_SCALAR);CHKERRQ(ierr); 725e5c89e4eSSatish Balay } 726e5c89e4eSSatish Balay } else { 727e5c89e4eSSatish Balay const char *tname; 728e5c89e4eSSatish Balay ierr = PetscObjectGetName((PetscObject)viewer,&tname);CHKERRQ(ierr); 729e32f2f54SBarry Smith SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_SUP,"Cannot handle that PetscViewer of type %s",tname); 730e5c89e4eSSatish Balay } 731e5c89e4eSSatish Balay PetscFunctionReturn(0); 732e5c89e4eSSatish Balay } 733e5c89e4eSSatish Balay 734e22e20c5SJunchao Zhang #if defined(PETSC_HAVE_CUDA) 735030f984aSJacob Faibussowitsch #include <petscdevice.h> 736e22e20c5SJunchao Zhang PETSC_EXTERN const char* PetscCUBLASGetErrorName(cublasStatus_t status) 737e22e20c5SJunchao Zhang { 738e22e20c5SJunchao Zhang switch(status) { 739e22e20c5SJunchao Zhang #if (CUDART_VERSION >= 8000) /* At least CUDA 8.0 of Sep. 2016 had these */ 740e22e20c5SJunchao Zhang case CUBLAS_STATUS_SUCCESS: return "CUBLAS_STATUS_SUCCESS"; 741e22e20c5SJunchao Zhang case CUBLAS_STATUS_NOT_INITIALIZED: return "CUBLAS_STATUS_NOT_INITIALIZED"; 742e22e20c5SJunchao Zhang case CUBLAS_STATUS_ALLOC_FAILED: return "CUBLAS_STATUS_ALLOC_FAILED"; 743e22e20c5SJunchao Zhang case CUBLAS_STATUS_INVALID_VALUE: return "CUBLAS_STATUS_INVALID_VALUE"; 744e22e20c5SJunchao Zhang case CUBLAS_STATUS_ARCH_MISMATCH: return "CUBLAS_STATUS_ARCH_MISMATCH"; 745e22e20c5SJunchao Zhang case CUBLAS_STATUS_MAPPING_ERROR: return "CUBLAS_STATUS_MAPPING_ERROR"; 746e22e20c5SJunchao Zhang case CUBLAS_STATUS_EXECUTION_FAILED: return "CUBLAS_STATUS_EXECUTION_FAILED"; 747e22e20c5SJunchao Zhang case CUBLAS_STATUS_INTERNAL_ERROR: return "CUBLAS_STATUS_INTERNAL_ERROR"; 748e22e20c5SJunchao Zhang case CUBLAS_STATUS_NOT_SUPPORTED: return "CUBLAS_STATUS_NOT_SUPPORTED"; 749e22e20c5SJunchao Zhang case CUBLAS_STATUS_LICENSE_ERROR: return "CUBLAS_STATUS_LICENSE_ERROR"; 750e22e20c5SJunchao Zhang #endif 751e22e20c5SJunchao Zhang default: return "unknown error"; 752e22e20c5SJunchao Zhang } 753e22e20c5SJunchao Zhang } 754a4b895e1SBarry Smith PETSC_EXTERN const char* PetscCUSolverGetErrorName(cusolverStatus_t status) 755a4b895e1SBarry Smith { 756a4b895e1SBarry Smith switch(status) { 757a4b895e1SBarry Smith #if (CUDART_VERSION >= 8000) /* At least CUDA 8.0 of Sep. 2016 had these */ 758a4b895e1SBarry Smith case CUSOLVER_STATUS_SUCCESS: return "CUSOLVER_STATUS_SUCCESS"; 759a4b895e1SBarry Smith case CUSOLVER_STATUS_NOT_INITIALIZED: return "CUSOLVER_STATUS_NOT_INITIALIZED"; 760a4b895e1SBarry Smith case CUSOLVER_STATUS_INVALID_VALUE: return "CUSOLVER_STATUS_INVALID_VALUE"; 761a4b895e1SBarry Smith case CUSOLVER_STATUS_ARCH_MISMATCH: return "CUSOLVER_STATUS_ARCH_MISMATCH"; 762a4b895e1SBarry Smith case CUSOLVER_STATUS_INTERNAL_ERROR: return "CUSOLVER_STATUS_INTERNAL_ERROR"; 763030f984aSJacob Faibussowitsch #if (CUDART_VERSION >= 9000) /* CUDA 9.0 had these defined on June 2021 */ 764030f984aSJacob Faibussowitsch case CUSOLVER_STATUS_ALLOC_FAILED: return "CUSOLVER_STATUS_ALLOC_FAILED"; 765030f984aSJacob Faibussowitsch case CUSOLVER_STATUS_MAPPING_ERROR: return "CUSOLVER_STATUS_MAPPING_ERROR"; 766030f984aSJacob Faibussowitsch case CUSOLVER_STATUS_EXECUTION_FAILED: return "CUSOLVER_STATUS_EXECUTION_FAILED"; 767030f984aSJacob Faibussowitsch case CUSOLVER_STATUS_MATRIX_TYPE_NOT_SUPPORTED: return "CUSOLVER_STATUS_MATRIX_TYPE_NOT_SUPPORTED"; 768030f984aSJacob Faibussowitsch case CUSOLVER_STATUS_NOT_SUPPORTED : return "CUSOLVER_STATUS_NOT_SUPPORTED "; 769030f984aSJacob Faibussowitsch case CUSOLVER_STATUS_ZERO_PIVOT: return "CUSOLVER_STATUS_ZERO_PIVOT"; 770030f984aSJacob Faibussowitsch case CUSOLVER_STATUS_INVALID_LICENSE: return "CUSOLVER_STATUS_INVALID_LICENSE"; 771a4b895e1SBarry Smith #endif 772030f984aSJacob Faibussowitsch #endif 773030f984aSJacob Faibussowitsch default: return "unknown error"; 774030f984aSJacob Faibussowitsch } 775030f984aSJacob Faibussowitsch } 776030f984aSJacob Faibussowitsch PETSC_EXTERN const char* PetscCUFFTGetErrorName(cufftResult result) 777030f984aSJacob Faibussowitsch { 778030f984aSJacob Faibussowitsch switch (result) { 779030f984aSJacob Faibussowitsch case CUFFT_SUCCESS: return "CUFFT_SUCCESS"; 780030f984aSJacob Faibussowitsch case CUFFT_INVALID_PLAN: return "CUFFT_INVALID_PLAN"; 781030f984aSJacob Faibussowitsch case CUFFT_ALLOC_FAILED: return "CUFFT_ALLOC_FAILED"; 782030f984aSJacob Faibussowitsch case CUFFT_INVALID_TYPE: return "CUFFT_INVALID_TYPE"; 783030f984aSJacob Faibussowitsch case CUFFT_INVALID_VALUE: return "CUFFT_INVALID_VALUE"; 784030f984aSJacob Faibussowitsch case CUFFT_INTERNAL_ERROR: return "CUFFT_INTERNAL_ERROR"; 785030f984aSJacob Faibussowitsch case CUFFT_EXEC_FAILED: return "CUFFT_EXEC_FAILED"; 786030f984aSJacob Faibussowitsch case CUFFT_SETUP_FAILED: return "CUFFT_SETUP_FAILED"; 787030f984aSJacob Faibussowitsch case CUFFT_INVALID_SIZE: return "CUFFT_INVALID_SIZE"; 788030f984aSJacob Faibussowitsch case CUFFT_UNALIGNED_DATA: return "CUFFT_UNALIGNED_DATA"; 789030f984aSJacob Faibussowitsch case CUFFT_INCOMPLETE_PARAMETER_LIST: return "CUFFT_INCOMPLETE_PARAMETER_LIST"; 790030f984aSJacob Faibussowitsch case CUFFT_INVALID_DEVICE: return "CUFFT_INVALID_DEVICE"; 791030f984aSJacob Faibussowitsch case CUFFT_PARSE_ERROR: return "CUFFT_PARSE_ERROR"; 792030f984aSJacob Faibussowitsch case CUFFT_NO_WORKSPACE: return "CUFFT_NO_WORKSPACE"; 793030f984aSJacob Faibussowitsch case CUFFT_NOT_IMPLEMENTED: return "CUFFT_NOT_IMPLEMENTED"; 794030f984aSJacob Faibussowitsch case CUFFT_LICENSE_ERROR: return "CUFFT_LICENSE_ERROR"; 795030f984aSJacob Faibussowitsch case CUFFT_NOT_SUPPORTED: return "CUFFT_NOT_SUPPORTED"; 796a4b895e1SBarry Smith default: return "unknown error"; 797a4b895e1SBarry Smith } 798a4b895e1SBarry Smith } 799e22e20c5SJunchao Zhang #endif 80059af0bd3SScott Kruger 80159af0bd3SScott Kruger #if defined(PETSC_HAVE_HIP) 802030f984aSJacob Faibussowitsch #include <petscdevice.h> 80359af0bd3SScott Kruger PETSC_EXTERN const char* PetscHIPBLASGetErrorName(hipblasStatus_t status) 80459af0bd3SScott Kruger { 80559af0bd3SScott Kruger switch(status) { 80659af0bd3SScott Kruger case HIPBLAS_STATUS_SUCCESS: return "HIPBLAS_STATUS_SUCCESS"; 80759af0bd3SScott Kruger case HIPBLAS_STATUS_NOT_INITIALIZED: return "HIPBLAS_STATUS_NOT_INITIALIZED"; 80859af0bd3SScott Kruger case HIPBLAS_STATUS_ALLOC_FAILED: return "HIPBLAS_STATUS_ALLOC_FAILED"; 80959af0bd3SScott Kruger case HIPBLAS_STATUS_INVALID_VALUE: return "HIPBLAS_STATUS_INVALID_VALUE"; 81059af0bd3SScott Kruger case HIPBLAS_STATUS_ARCH_MISMATCH: return "HIPBLAS_STATUS_ARCH_MISMATCH"; 81159af0bd3SScott Kruger case HIPBLAS_STATUS_MAPPING_ERROR: return "HIPBLAS_STATUS_MAPPING_ERROR"; 81259af0bd3SScott Kruger case HIPBLAS_STATUS_EXECUTION_FAILED: return "HIPBLAS_STATUS_EXECUTION_FAILED"; 81359af0bd3SScott Kruger case HIPBLAS_STATUS_INTERNAL_ERROR: return "HIPBLAS_STATUS_INTERNAL_ERROR"; 81459af0bd3SScott Kruger case HIPBLAS_STATUS_NOT_SUPPORTED: return "HIPBLAS_STATUS_NOT_SUPPORTED"; 81559af0bd3SScott Kruger default: return "unknown error"; 81659af0bd3SScott Kruger } 81759af0bd3SScott Kruger } 81859af0bd3SScott Kruger #endif 819