xref: /petsc/src/sys/error/err.c (revision 35f00c147f54e333863026c4b3407d5f5899c648)
17d0a6c19SBarry Smith 
2e5c89e4eSSatish Balay /*
3e5c89e4eSSatish Balay       Code that allows one to set the error handlers
447d993e7Ssuyashtn       Portions of this code are under:
547d993e7Ssuyashtn       Copyright (c) 2022 Advanced Micro Devices, Inc. All rights reserved.
6e5c89e4eSSatish Balay */
7af0996ceSBarry Smith #include <petsc/private/petscimpl.h> /*I "petscsys.h" I*/
8665c2dedSJed Brown #include <petscviewer.h>
9e5c89e4eSSatish Balay 
10e5c89e4eSSatish Balay typedef struct _EH *EH;
11e5c89e4eSSatish Balay struct _EH {
12efca3c55SSatish Balay   PetscErrorCode (*handler)(MPI_Comm, int, const char *, const char *, PetscErrorCode, PetscErrorType, const char *, void *);
13e5c89e4eSSatish Balay   void *ctx;
14e5c89e4eSSatish Balay   EH    previous;
15e5c89e4eSSatish Balay };
16e5c89e4eSSatish Balay 
17*35f00c14SToby Isaac /* This is here to allow the traceback error handler (or potentially other error handlers)
18*35f00c14SToby Isaac    to certify that PETSCABORT is being called on all MPI processes, and that it should be possible to call
19*35f00c14SToby Isaac    MPI_Finalize() and exit().  This should only be used when `PetscCIEnabledPortabeErrorOutput == PETSC_TRUE`
20*35f00c14SToby Isaac    to allow testing of error messages.  Do not rely on this for clean exit in production. */
21*35f00c14SToby Isaac PetscBool petscabortmpifinalize = PETSC_FALSE;
22*35f00c14SToby Isaac 
2302c9f0b5SLisandro Dalcin static EH eh = NULL;
24e5c89e4eSSatish Balay 
25e5c89e4eSSatish Balay /*@C
26e5c89e4eSSatish Balay   PetscEmacsClientErrorHandler - Error handler that uses the emacsclient program to
27a5b23f4aSJose E. Roman   load the file where the error occurred. Then calls the "previous" error handler.
28e5c89e4eSSatish Balay 
29e5c89e4eSSatish Balay   Not Collective
30e5c89e4eSSatish Balay 
31e5c89e4eSSatish Balay   Input Parameters:
32a5b23f4aSJose E. Roman + comm - communicator over which error occurred
33e32f2f54SBarry Smith . line - the line number of the error (indicated by __LINE__)
34e5c89e4eSSatish Balay . file - the file in which the error was detected (indicated by __FILE__)
3510450e9eSJacob Faibussowitsch . fun  - the function name
36e5c89e4eSSatish Balay . mess - an error text string, usually just printed to the screen
37e5c89e4eSSatish Balay . n    - the generic error number
38e5c89e4eSSatish Balay . p    - specific error number
39e5c89e4eSSatish Balay - ctx  - error handler context
40e5c89e4eSSatish Balay 
41e5c89e4eSSatish Balay   Options Database Key:
4210699b91SBarry Smith . -on_error_emacs <machinename> - will contact machinename to open the Emacs client there
43e5c89e4eSSatish Balay 
44e5c89e4eSSatish Balay   Level: developer
45e5c89e4eSSatish Balay 
46811af0c4SBarry Smith   Note:
47e5c89e4eSSatish Balay   You must put (server-start) in your .emacs file for the emacsclient software to work
48e5c89e4eSSatish Balay 
49aec76313SJacob Faibussowitsch   Developer Notes:
50811af0c4SBarry Smith   Since this is an error handler it cannot call `PetscCall()`; thus we just return if an error is detected.
51811af0c4SBarry Smith   But some of the functions it calls do perform error checking that may not be appropriate in a error handler call.
523bf036e2SBarry Smith 
53db781477SPatrick Sanan .seealso: `PetscError()`, `PetscPushErrorHandler()`, `PetscPopErrorHandler()`, `PetscAttachDebuggerErrorHandler()`,
54db781477SPatrick Sanan           `PetscAbortErrorHandler()`, `PetscMPIAbortErrorHandler()`, `PetscTraceBackErrorHandler()`, `PetscReturnErrorHandler()`
55e5c89e4eSSatish Balay  @*/
56d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscEmacsClientErrorHandler(MPI_Comm comm, int line, const char *fun, const char *file, PetscErrorCode n, PetscErrorType p, const char *mess, void *ctx)
57d71ae5a4SJacob Faibussowitsch {
58e5c89e4eSSatish Balay   PetscErrorCode ierr;
59e5c89e4eSSatish Balay   char           command[PETSC_MAX_PATH_LEN];
60e5c89e4eSSatish Balay   const char    *pdir;
61e5c89e4eSSatish Balay   FILE          *fp;
62e5c89e4eSSatish Balay 
639371c9d4SSatish Balay   ierr = PetscGetPetscDir(&pdir);
6411cc89d2SBarry Smith   if (ierr) return ierr;
65a364092eSJacob Faibussowitsch   ierr = PetscSNPrintf(command, PETSC_STATIC_ARRAY_LENGTH(command), "cd %s; emacsclient --no-wait +%d %s\n", pdir, line, file);
66a364092eSJacob Faibussowitsch   if (ierr) return ierr;
67e5c89e4eSSatish Balay #if defined(PETSC_HAVE_POPEN)
689371c9d4SSatish Balay   ierr = PetscPOpen(MPI_COMM_WORLD, (char *)ctx, command, "r", &fp);
6911cc89d2SBarry Smith   if (ierr) return ierr;
709371c9d4SSatish Balay   ierr = PetscPClose(MPI_COMM_WORLD, fp);
7111cc89d2SBarry Smith   if (ierr) return ierr;
72e5c89e4eSSatish Balay #else
73e32f2f54SBarry Smith   SETERRQ(PETSC_COMM_SELF, PETSC_ERR_SUP_SYS, "Cannot run external programs on this machine");
74e5c89e4eSSatish Balay #endif
759371c9d4SSatish Balay   ierr = PetscPopErrorHandler();
7611cc89d2SBarry Smith   if (ierr) return ierr; /* remove this handler from the stack of handlers */
773bf036e2SBarry Smith   if (!eh) {
789371c9d4SSatish Balay     ierr = PetscTraceBackErrorHandler(comm, line, fun, file, n, p, mess, NULL);
7911cc89d2SBarry Smith     if (ierr) return ierr;
803bf036e2SBarry Smith   } else {
819371c9d4SSatish Balay     ierr = (*eh->handler)(comm, line, fun, file, n, p, mess, eh->ctx);
8211cc89d2SBarry Smith     if (ierr) return ierr;
833bf036e2SBarry Smith   }
843ba16761SJacob Faibussowitsch   return PETSC_SUCCESS;
85e5c89e4eSSatish Balay }
86e5c89e4eSSatish Balay 
87e5c89e4eSSatish Balay /*@C
88e5c89e4eSSatish Balay   PetscPushErrorHandler - Sets a routine to be called on detection of errors.
89e5c89e4eSSatish Balay 
90e5c89e4eSSatish Balay   Not Collective
91e5c89e4eSSatish Balay 
92e5c89e4eSSatish Balay   Input Parameters:
93e5c89e4eSSatish Balay + handler - error handler routine
94e5c89e4eSSatish Balay - ctx     - optional handler context that contains information needed by the handler (for
95e5c89e4eSSatish Balay             example file pointers for error messages etc.)
96e5c89e4eSSatish Balay 
9720f4b53cSBarry Smith   Calling sequence of `handler`:
98a5b23f4aSJose E. Roman + comm - communicator over which error occurred
99e5c89e4eSSatish Balay . line - the line number of the error (indicated by __LINE__)
100e5c89e4eSSatish Balay . file - the file in which the error was detected (indicated by __FILE__)
10110450e9eSJacob Faibussowitsch . fun  - the function name
102e5c89e4eSSatish Balay . n    - the generic error number (see list defined in include/petscerror.h)
10320f4b53cSBarry Smith . p    - `PETSC_ERROR_INITIAL` if error just detected, otherwise `PETSC_ERROR_REPEAT`
104e5c89e4eSSatish Balay . mess - an error text string, usually just printed to the screen
105e5c89e4eSSatish Balay - ctx  - the error handler context
106e5c89e4eSSatish Balay 
107e5c89e4eSSatish Balay   Options Database Keys:
10810699b91SBarry Smith + -on_error_attach_debugger <noxterm,gdb or dbx> - starts up the debugger if an error occurs
10910699b91SBarry Smith - -on_error_abort                                - aborts the program if an error occurs
110e5c89e4eSSatish Balay 
111e5c89e4eSSatish Balay   Level: intermediate
112e5c89e4eSSatish Balay 
113811af0c4SBarry Smith   Note:
114811af0c4SBarry Smith   The currently available PETSc error handlers include `PetscTraceBackErrorHandler()`,
115811af0c4SBarry Smith   `PetscAttachDebuggerErrorHandler()`, `PetscAbortErrorHandler()`, and `PetscMPIAbortErrorHandler()`, `PetscReturnErrorHandler()`.
116e93bc3c1Svictor 
117aec76313SJacob Faibussowitsch   Fortran Notes:
118aaa8cc7dSPierre Jolivet   You can only push one error handler from Fortran before popping it.
1197850c7c0SBarry Smith 
120db781477SPatrick Sanan .seealso: `PetscPopErrorHandler()`, `PetscAttachDebuggerErrorHandler()`, `PetscAbortErrorHandler()`, `PetscTraceBackErrorHandler()`, `PetscPushSignalHandler()`
121e5c89e4eSSatish Balay @*/
12210450e9eSJacob Faibussowitsch PetscErrorCode PetscPushErrorHandler(PetscErrorCode (*handler)(MPI_Comm comm, int line, const char *fun, const char *file, PetscErrorCode n, PetscErrorType p, const char *mess, void *ctx), void *ctx)
123d71ae5a4SJacob Faibussowitsch {
124e5c89e4eSSatish Balay   EH neweh;
125e5c89e4eSSatish Balay 
126e5c89e4eSSatish Balay   PetscFunctionBegin;
1279566063dSJacob Faibussowitsch   PetscCall(PetscNew(&neweh));
128a297a907SKarl Rupp   if (eh) neweh->previous = eh;
12902c9f0b5SLisandro Dalcin   else neweh->previous = NULL;
130e5c89e4eSSatish Balay   neweh->handler = handler;
131e5c89e4eSSatish Balay   neweh->ctx     = ctx;
132e5c89e4eSSatish Balay   eh             = neweh;
1333ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
134e5c89e4eSSatish Balay }
135e5c89e4eSSatish Balay 
136e30d2299SSatish Balay /*@
137e5c89e4eSSatish Balay   PetscPopErrorHandler - Removes the latest error handler that was
138811af0c4SBarry Smith   pushed with `PetscPushErrorHandler()`.
139e5c89e4eSSatish Balay 
140e5c89e4eSSatish Balay   Not Collective
141e5c89e4eSSatish Balay 
142e5c89e4eSSatish Balay   Level: intermediate
143e5c89e4eSSatish Balay 
144db781477SPatrick Sanan .seealso: `PetscPushErrorHandler()`
145e5c89e4eSSatish Balay @*/
146d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscPopErrorHandler(void)
147d71ae5a4SJacob Faibussowitsch {
148e5c89e4eSSatish Balay   EH tmp;
149e5c89e4eSSatish Balay 
150e5c89e4eSSatish Balay   PetscFunctionBegin;
1513ba16761SJacob Faibussowitsch   if (!eh) PetscFunctionReturn(PETSC_SUCCESS);
152e5c89e4eSSatish Balay   tmp = eh;
153e5c89e4eSSatish Balay   eh  = eh->previous;
1549566063dSJacob Faibussowitsch   PetscCall(PetscFree(tmp));
1553ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
156e5c89e4eSSatish Balay }
157e5c89e4eSSatish Balay 
158e93bc3c1Svictor /*@C
15945b666d6SBarry Smith   PetscReturnErrorHandler - Error handler that causes a return without printing an error message.
160e93bc3c1Svictor 
161e93bc3c1Svictor   Not Collective
162e93bc3c1Svictor 
163e93bc3c1Svictor   Input Parameters:
164e32f2f54SBarry Smith + comm - communicator over which error occurred
165e32f2f54SBarry Smith . line - the line number of the error (indicated by __LINE__)
16610450e9eSJacob Faibussowitsch . fun  - the function name
167e93bc3c1Svictor . file - the file in which the error was detected (indicated by __FILE__)
168e93bc3c1Svictor . mess - an error text string, usually just printed to the screen
169e93bc3c1Svictor . n    - the generic error number
170e93bc3c1Svictor . p    - specific error number
171e93bc3c1Svictor - ctx  - error handler context
172e93bc3c1Svictor 
173e93bc3c1Svictor   Level: developer
174e93bc3c1Svictor 
175e93bc3c1Svictor   Notes:
176e93bc3c1Svictor   Most users need not directly employ this routine and the other error
177811af0c4SBarry Smith   handlers, but can instead use the simplified interface `SETERRQ()`, which has
178e93bc3c1Svictor   the calling sequence
179e32f2f54SBarry Smith $     SETERRQ(comm, number, mess)
180e93bc3c1Svictor 
181811af0c4SBarry Smith   `PetscIgnoreErrorHandler()` does the same thing as this function, but is deprecated, you should use this function.
182e93bc3c1Svictor 
183811af0c4SBarry Smith   Use `PetscPushErrorHandler()` to set the desired error handler.
184e93bc3c1Svictor 
185db781477SPatrick Sanan .seealso: `PetscPushErrorHandler()`, `PetscPopErrorHandler()`, `PetscError()`, `PetscAbortErrorHandler()`, `PetscMPIAbortErrorHandler()`, `PetscTraceBackErrorHandler()`,
186db781477SPatrick Sanan           `PetscAttachDebuggerErrorHandler()`, `PetscEmacsClientErrorHandler()`
187e93bc3c1Svictor  @*/
188d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscReturnErrorHandler(MPI_Comm comm, int line, const char *fun, const char *file, PetscErrorCode n, PetscErrorType p, const char *mess, void *ctx)
189d71ae5a4SJacob Faibussowitsch {
19010450e9eSJacob Faibussowitsch   (void)comm;
19110450e9eSJacob Faibussowitsch   (void)line;
19210450e9eSJacob Faibussowitsch   (void)fun;
19310450e9eSJacob Faibussowitsch   (void)file;
19410450e9eSJacob Faibussowitsch   (void)p;
19510450e9eSJacob Faibussowitsch   (void)mess;
19610450e9eSJacob Faibussowitsch   (void)ctx;
197362febeeSStefano Zampini   return n;
198e93bc3c1Svictor }
199e93bc3c1Svictor 
200e5c89e4eSSatish Balay static char PetscErrorBaseMessage[1024];
201e5c89e4eSSatish Balay /*
202e5c89e4eSSatish Balay        The numerical values for these are defined in include/petscerror.h; any changes
203e5c89e4eSSatish Balay    there must also be made here
204e5c89e4eSSatish Balay */
205e5c89e4eSSatish Balay static const char *PetscErrorStrings[] = {
206e5c89e4eSSatish Balay   /*55 */ "Out of memory",
207e5c89e4eSSatish Balay   "No support for this operation for this object type",
208e5c89e4eSSatish Balay   "No support for this operation on this system",
209e5c89e4eSSatish Balay   /*58 */ "Operation done in wrong order",
210e5c89e4eSSatish Balay   /*59 */ "Signal received",
211e5c89e4eSSatish Balay   /*60 */ "Nonconforming object sizes",
212e5c89e4eSSatish Balay   "Argument aliasing not permitted",
213e5c89e4eSSatish Balay   "Invalid argument",
214e5c89e4eSSatish Balay   /*63 */ "Argument out of range",
215a17b96a8SKyle Gerard Felker   "Corrupt argument: https://petsc.org/release/faq/#valgrind",
216e5c89e4eSSatish Balay   "Unable to open file",
217e5c89e4eSSatish Balay   "Read from file failed",
218e5c89e4eSSatish Balay   "Write to file failed",
219e5c89e4eSSatish Balay   "Invalid pointer",
220e5c89e4eSSatish Balay   /*69 */ "Arguments must have same type",
221a8b45ee7SBarry Smith   /*70 */ "Attempt to use a pointer that does not point to a valid accessible location",
222a17b96a8SKyle Gerard Felker   /*71 */ "Zero pivot in LU factorization: https://petsc.org/release/faq/#zeropivot",
223e5c89e4eSSatish Balay   /*72 */ "Floating point exception",
224e5c89e4eSSatish Balay   /*73 */ "Object is in wrong state",
225e5c89e4eSSatish Balay   "Corrupted Petsc object",
226e5c89e4eSSatish Balay   "Arguments are incompatible",
227e5c89e4eSSatish Balay   "Error in external library",
228e5c89e4eSSatish Balay   /*77 */ "Petsc has generated inconsistent data",
229a17b96a8SKyle Gerard Felker   "Memory corruption: https://petsc.org/release/faq/#valgrind",
230e5c89e4eSSatish Balay   "Unexpected data in file",
231e5c89e4eSSatish Balay   /*80 */ "Arguments must have same communicators",
232a17b96a8SKyle Gerard Felker   /*81 */ "Zero pivot in Cholesky factorization: https://petsc.org/release/faq/#zeropivot",
233e5c89e4eSSatish Balay   "",
234e5c89e4eSSatish Balay   "",
235a17b96a8SKyle Gerard Felker   "Overflow in integer operation: https://petsc.org/release/faq/#64-bit-indices",
236e5c89e4eSSatish Balay   /*85 */ "Null argument, when expecting valid pointer",
237a17b96a8SKyle Gerard Felker   /*86 */ "Unknown type. Check for miss-spelling or missing package: https://petsc.org/release/install/install/#external-packages",
2383d96e996SBarry Smith   /*87 */ "MPI library at runtime is not compatible with MPI used at compile time",
2398cda6cd7SBarry Smith   /*88 */ "Error in system call",
240a17b96a8SKyle Gerard Felker   /*89 */ "Object Type not set: https://petsc.org/release/faq/#object-type-not-set",
24173260a9bSLisandro Dalcin   /*90 */ "",
24273260a9bSLisandro Dalcin   /*   */ "",
243a17b96a8SKyle Gerard Felker   /*92 */ "See https://petsc.org/release/overview/linear_solve_table/ for possible LU and Cholesky solvers",
244f560318cSPatrick Sanan   /*93 */ "You cannot overwrite this option since that will conflict with other previously set options",
245691b26d3SBarry Smith   /*94 */ "Example/application run with number of MPI ranks it does not support",
246691b26d3SBarry Smith   /*95 */ "Missing or incorrect user input",
247e57d7714SBarry Smith   /*96 */ "GPU resources unavailable",
248764761abSStefano Zampini   /*97 */ "GPU error",
249e809461dSJacob Faibussowitsch   /*98 */ "General MPI error",
250e809461dSJacob Faibussowitsch   /*99 */ "PetscError() incorrectly returned an error code of 0"};
251e5c89e4eSSatish Balay 
252e5c89e4eSSatish Balay /*@C
2533ba16761SJacob Faibussowitsch   PetscErrorMessage - Returns the text string associated with a PETSc error code.
254e5c89e4eSSatish Balay 
255e5c89e4eSSatish Balay   Not Collective
256e5c89e4eSSatish Balay 
257e5c89e4eSSatish Balay   Input Parameter:
258e5c89e4eSSatish Balay . errnum - the error code
259e5c89e4eSSatish Balay 
260d8d19677SJose E. Roman   Output Parameters:
2613ba16761SJacob Faibussowitsch + text     - the error message (`NULL` if not desired)
2623ba16761SJacob Faibussowitsch - specific - the specific error message that was set with `SETERRQ()` or
2633ba16761SJacob Faibussowitsch              `PetscError()`. (`NULL` if not desired)
264e5c89e4eSSatish Balay 
265e5c89e4eSSatish Balay   Level: developer
266e5c89e4eSSatish Balay 
2673ba16761SJacob Faibussowitsch .seealso: `PetscErrorCode`, `PetscPushErrorHandler()`, `PetscAttachDebuggerErrorHandler()`,
2683ba16761SJacob Faibussowitsch `PetscError()`, `SETERRQ()`, `PetscCall()` `PetscAbortErrorHandler()`,
2693ba16761SJacob Faibussowitsch `PetscTraceBackErrorHandler()`
270e5c89e4eSSatish Balay @*/
2713ba16761SJacob Faibussowitsch PetscErrorCode PetscErrorMessage(PetscErrorCode errnum, const char *text[], char **specific)
272d71ae5a4SJacob Faibussowitsch {
2733ba16761SJacob Faibussowitsch   PetscFunctionBegin;
2743ba16761SJacob Faibussowitsch   if (text) {
2753ba16761SJacob Faibussowitsch     if (errnum > PETSC_ERR_MIN_VALUE && errnum < PETSC_ERR_MAX_VALUE) {
276c35ec7c7SPierre Jolivet       size_t len;
277c35ec7c7SPierre Jolivet 
278c35ec7c7SPierre Jolivet       *text = PetscErrorStrings[errnum - PETSC_ERR_MIN_VALUE - 1];
279c35ec7c7SPierre Jolivet       PetscCall(PetscStrlen(*text, &len));
280c35ec7c7SPierre Jolivet       if (!len) *text = NULL;
2813ba16761SJacob Faibussowitsch     } else if (errnum == PETSC_ERR_BOOLEAN_MACRO_FAILURE) {
2823ba16761SJacob Faibussowitsch       /* this "error code" arises from failures in boolean macros, where the || operator is
2833ba16761SJacob Faibussowitsch          used to short-circuit the macro call in case of error. This has the side effect of
2843ba16761SJacob Faibussowitsch          "returning" either 0 (PETSC_SUCCESS) or 1 (PETSC_ERR_UNKNONWN):
285e5c89e4eSSatish Balay 
2863ba16761SJacob Faibussowitsch          #define PETSC_FOO(x) ((PetscErrorCode)(PetscBar(x) || PetscBaz(x)))
2873ba16761SJacob Faibussowitsch 
2883ba16761SJacob Faibussowitsch          If PetscBar() fails (returns nonzero) PetscBaz() is not executed but the result of
2893ba16761SJacob Faibussowitsch          this expression is boolean false, hence PETSC_ERR_UNNOWN
2903ba16761SJacob Faibussowitsch        */
2913ba16761SJacob Faibussowitsch       *text = "Error occurred in boolean shortcuit in macro";
2923ba16761SJacob Faibussowitsch     } else {
2933ba16761SJacob Faibussowitsch       *text = NULL;
2943ba16761SJacob Faibussowitsch     }
2953ba16761SJacob Faibussowitsch   }
296a297a907SKarl Rupp   if (specific) *specific = PetscErrorBaseMessage;
2973ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
298e5c89e4eSSatish Balay }
299e5c89e4eSSatish Balay 
300984a1229SMatthew G. Knepley #if defined(PETSC_CLANGUAGE_CXX)
301984a1229SMatthew G. Knepley   /* C++ exceptions are formally not allowed to propagate through extern "C" code. In practice, far too much software
302984a1229SMatthew G. Knepley  * would be broken if implementations did not handle it it some common cases. However, keep in mind
303984a1229SMatthew G. Knepley  *
304984a1229SMatthew G. Knepley  *   Rule 62. Don't allow exceptions to propagate across module boundaries
305984a1229SMatthew G. Knepley  *
306984a1229SMatthew G. Knepley  * in "C++ Coding Standards" by Sutter and Alexandrescu. (This accounts for part of the ongoing C++ binary interface
307984a1229SMatthew G. Knepley  * instability.) Having PETSc raise errors as C++ exceptions was probably misguided and should eventually be removed.
308984a1229SMatthew G. Knepley  *
309984a1229SMatthew G. Knepley  * Here is the problem: You have a C++ function call a PETSc function, and you would like to maintain the error message
310984a1229SMatthew G. Knepley  * and stack information from the PETSc error. You could make everyone write exactly this code in their C++, but that
311984a1229SMatthew G. Knepley  * seems crazy to me.
312984a1229SMatthew G. Knepley  */
313984a1229SMatthew G. Knepley   #include <sstream>
3144c94c282SMatthew G. Knepley   #include <stdexcept>
315d71ae5a4SJacob Faibussowitsch static void PetscCxxErrorThrow()
316d71ae5a4SJacob Faibussowitsch {
317984a1229SMatthew G. Knepley   const char *str;
318984a1229SMatthew G. Knepley   if (eh && eh->ctx) {
319984a1229SMatthew G. Knepley     std::ostringstream *msg;
320984a1229SMatthew G. Knepley     msg = (std::ostringstream *)eh->ctx;
321984a1229SMatthew G. Knepley     str = msg->str().c_str();
322984a1229SMatthew G. Knepley   } else str = "Error detected in C PETSc";
323984a1229SMatthew G. Knepley 
324984a1229SMatthew G. Knepley   throw std::runtime_error(str);
325984a1229SMatthew G. Knepley }
326984a1229SMatthew G. Knepley #endif
327984a1229SMatthew G. Knepley 
328e5c89e4eSSatish Balay /*@C
32945b666d6SBarry Smith   PetscError - Routine that is called when an error has been detected, usually called through the macro SETERRQ(PETSC_COMM_SELF,).
330e5c89e4eSSatish Balay 
331811af0c4SBarry Smith   Collective
332e5c89e4eSSatish Balay 
333e5c89e4eSSatish Balay   Input Parameters:
334e32f2f54SBarry Smith + comm - communicator over which error occurred.  ALL ranks of this communicator MUST call this routine
335e32f2f54SBarry Smith . line - the line number of the error (indicated by __LINE__)
3363de71b31SHong Zhang . func - the function name in which the error was detected
337e5c89e4eSSatish Balay . file - the file in which the error was detected (indicated by __FILE__)
338e5c89e4eSSatish Balay . n    - the generic error number
339811af0c4SBarry Smith . p    - `PETSC_ERROR_INITIAL` indicates the error was initially detected, `PETSC_ERROR_REPEAT` indicates this is a traceback from a previously detected error
340e5c89e4eSSatish Balay - mess - formatted message string - aka printf
341e5c89e4eSSatish Balay 
342811af0c4SBarry Smith   Options Database Keys:
34345b666d6SBarry Smith + -error_output_stdout - output the error messages to stdout instead of the default stderr
34445b666d6SBarry Smith - -error_output_none   - do not output the error messages
34545b666d6SBarry Smith 
346e5c89e4eSSatish Balay   Level: intermediate
347e5c89e4eSSatish Balay 
348e5c89e4eSSatish Balay   Notes:
349e809461dSJacob Faibussowitsch   PETSc error handling is done with error return codes. A non-zero return indicates an error
350e809461dSJacob Faibussowitsch   was detected. The return-value of this routine is what is ultimately returned by
351e809461dSJacob Faibussowitsch   `SETERRQ()`.
35245b666d6SBarry Smith 
353e809461dSJacob Faibussowitsch   Note that numerical errors (potential divide by zero, for example) are not managed by the
354e809461dSJacob Faibussowitsch   error return codes; they are managed via, for example, `KSPGetConvergedReason()` that
355e809461dSJacob Faibussowitsch   indicates if the solve was successful or not. The option `-ksp_error_if_not_converged`, for
356e809461dSJacob Faibussowitsch   example, turns numerical failures into hard errors managed via `PetscError()`.
35745b666d6SBarry Smith 
358e809461dSJacob Faibussowitsch   PETSc provides a rich supply of error handlers, see the list below, and users can also
359e809461dSJacob Faibussowitsch   provide their own error handlers.
360811af0c4SBarry Smith 
361e809461dSJacob Faibussowitsch   If the user sets their own error handler (via `PetscPushErrorHandler()`) they may return any
362e809461dSJacob Faibussowitsch   arbitrary value from it, but are encouraged to return nonzero values. If the return value is
363e809461dSJacob Faibussowitsch   zero, `SETERRQ()` will ignore the value and return `PETSC_ERR_RETURN` (a nonzero value)
364e809461dSJacob Faibussowitsch   instead.
365e809461dSJacob Faibussowitsch 
366e809461dSJacob Faibussowitsch   Most users need not directly use this routine and the error handlers, but can instead use
367e809461dSJacob Faibussowitsch   the simplified interface `PetscCall()` or `SETERRQ()`.
368e5c89e4eSSatish Balay 
369aec76313SJacob Faibussowitsch   Fortran Notes:
370e3081792SBarry Smith   This routine is used differently from Fortran
371e3081792SBarry Smith $    PetscError(MPI_Comm comm, PetscErrorCode n, PetscErrorType p, char *message)
372e3081792SBarry Smith 
373aec76313SJacob Faibussowitsch   Developer Notes:
374811af0c4SBarry Smith   Since this is called after an error condition it should not be calling any error handlers (currently it ignores any error codes)
3753bf036e2SBarry 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
3763bf036e2SBarry Smith   but this annoying.
3773bf036e2SBarry Smith 
378db781477SPatrick Sanan .seealso: `PetscErrorCode`, `PetscPushErrorHandler()`, `PetscPopErrorHandler()`, `PetscTraceBackErrorHandler()`, `PetscAbortErrorHandler()`, `PetscMPIAbortErrorHandler()`,
379db781477SPatrick Sanan           `PetscReturnErrorHandler()`, `PetscAttachDebuggerErrorHandler()`, `PetscEmacsClientErrorHandler()`,
380aec76313SJacob Faibussowitsch           `SETERRQ()`, `PetscCall()`, `CHKMEMQ`, `PetscErrorMessage()`, `PETSCABORT()`
381e5c89e4eSSatish Balay @*/
382d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscError(MPI_Comm comm, int line, const char *func, const char *file, PetscErrorCode n, PetscErrorType p, const char *mess, ...)
383d71ae5a4SJacob Faibussowitsch {
384e5c89e4eSSatish Balay   va_list        Argp;
385c9a19010SBarry Smith   size_t         fullLength;
38602c9f0b5SLisandro Dalcin   char           buf[2048], *lbuf = NULL;
387fbfcfee5SBarry Smith   PetscBool      ismain;
3883bf036e2SBarry Smith   PetscErrorCode ierr;
389e5c89e4eSSatish Balay 
39039a651e2SJacob Faibussowitsch   if (!PetscErrorHandlingInitialized) return n;
3910d577829SBarry Smith   if (comm == MPI_COMM_NULL) comm = PETSC_COMM_SELF;
392e5c89e4eSSatish Balay 
393e5c89e4eSSatish Balay   /* Compose the message evaluating the print format */
394e5c89e4eSSatish Balay   if (mess) {
395e5c89e4eSSatish Balay     va_start(Argp, mess);
3963ba16761SJacob Faibussowitsch     ierr = PetscVSNPrintf(buf, 2048, mess, &fullLength, Argp);
397e5c89e4eSSatish Balay     va_end(Argp);
398e5c89e4eSSatish Balay     lbuf = buf;
3999b15cf9aSJacob Faibussowitsch     if (p == PETSC_ERROR_INITIAL) ierr = PetscStrncpy(PetscErrorBaseMessage, lbuf, sizeof(PetscErrorBaseMessage));
400e5c89e4eSSatish Balay   }
401e5c89e4eSSatish Balay 
4023ba16761SJacob Faibussowitsch   if (p == PETSC_ERROR_INITIAL && n != PETSC_ERR_MEMC) ierr = PetscMallocValidate(__LINE__, PETSC_FUNCTION_NAME, __FILE__);
4034ed0ab5bSBarry Smith 
40402c9f0b5SLisandro Dalcin   if (!eh) ierr = PetscTraceBackErrorHandler(comm, line, func, file, n, p, lbuf, NULL);
405efca3c55SSatish Balay   else ierr = (*eh->handler)(comm, line, func, file, n, p, lbuf, eh->ctx);
406362febeeSStefano Zampini   PetscStackClearTop;
407e5c89e4eSSatish Balay 
408e5c89e4eSSatish Balay   /*
409989c49a2SBarry Smith       If this is called from the main() routine we abort the program.
410989c49a2SBarry Smith       We cannot just return because them some MPI processes may continue to attempt to run
411989c49a2SBarry Smith       while this process simply exits.
412e5c89e4eSSatish Balay   */
41349c86fc7SBarry Smith   if (func) {
4143ba16761SJacob Faibussowitsch     PetscErrorCode cmp_ierr = PetscStrncmp(func, "main", 4, &ismain);
4157233276eSBarry Smith     if (ismain) {
4163ba16761SJacob Faibussowitsch       if (petscwaitonerrorflg) cmp_ierr = PetscSleep(1000);
4173ba16761SJacob Faibussowitsch       (void)cmp_ierr;
418660278c0SBarry Smith       PETSCABORT(comm, ierr);
4197233276eSBarry Smith     }
42049c86fc7SBarry Smith   }
4212c280183SJed Brown #if defined(PETSC_CLANGUAGE_CXX)
422ad540459SPierre Jolivet   if (p == PETSC_ERROR_IN_CXX) PetscCxxErrorThrow();
423d736bfebSBarry Smith #endif
424362febeeSStefano Zampini   return ierr;
425e5c89e4eSSatish Balay }
426e5c89e4eSSatish Balay 
427e5c89e4eSSatish Balay /* -------------------------------------------------------------------------*/
428e5c89e4eSSatish Balay 
429e5c89e4eSSatish Balay /*@C
430e5c89e4eSSatish Balay   PetscIntView - Prints an array of integers; useful for debugging.
431e5c89e4eSSatish Balay 
432c3339decSBarry Smith   Collective
433e5c89e4eSSatish Balay 
434e5c89e4eSSatish Balay   Input Parameters:
435e5c89e4eSSatish Balay + N      - number of integers in array
436e5c89e4eSSatish Balay . idx    - array of integers
437811af0c4SBarry Smith - viewer - location to print array, `PETSC_VIEWER_STDOUT_WORLD`, `PETSC_VIEWER_STDOUT_SELF` or 0
438e5c89e4eSSatish Balay 
439e5c89e4eSSatish Balay   Level: intermediate
440e5c89e4eSSatish Balay 
441811af0c4SBarry Smith   Note:
442811af0c4SBarry Smith   This may be called from within the debugger
443300a7f5bSBarry Smith 
444aec76313SJacob Faibussowitsch   Developer Notes:
445811af0c4SBarry Smith   idx cannot be const because may be passed to binary viewer where temporary byte swapping may be done
446811af0c4SBarry Smith 
447811af0c4SBarry Smith .seealso: `PetscViewer`, `PetscRealView()`
448e5c89e4eSSatish Balay @*/
449d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscIntView(PetscInt N, const PetscInt idx[], PetscViewer viewer)
450d71ae5a4SJacob Faibussowitsch {
451ca0c3be5SJacob Faibussowitsch   PetscMPIInt rank, size;
452e5c89e4eSSatish Balay   PetscInt    j, i, n = N / 20, p = N % 20;
453ace3abfcSBarry Smith   PetscBool   iascii, isbinary;
454e5c89e4eSSatish Balay   MPI_Comm    comm;
455e5c89e4eSSatish Balay 
456e5c89e4eSSatish Balay   PetscFunctionBegin;
457e5c89e4eSSatish Balay   if (!viewer) viewer = PETSC_VIEWER_STDOUT_SELF;
4580700a824SBarry Smith   PetscValidHeaderSpecific(viewer, PETSC_VIEWER_CLASSID, 3);
4594f572ea9SToby Isaac   if (N) PetscAssertPointer(idx, 2);
4609566063dSJacob Faibussowitsch   PetscCall(PetscObjectGetComm((PetscObject)viewer, &comm));
4619566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Comm_size(comm, &size));
4629566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Comm_rank(comm, &rank));
463e5c89e4eSSatish Balay 
4649566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERASCII, &iascii));
4659566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERBINARY, &isbinary));
466e5c89e4eSSatish Balay   if (iascii) {
4679566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIIPushSynchronized(viewer));
468e5c89e4eSSatish Balay     for (i = 0; i < n; i++) {
469ca0c3be5SJacob Faibussowitsch       if (size > 1) {
4709566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "[%d] %" PetscInt_FMT ":", rank, 20 * i));
471ca0c3be5SJacob Faibussowitsch       } else {
4729566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "%" PetscInt_FMT ":", 20 * i));
473ca0c3be5SJacob Faibussowitsch       }
47448a46eb9SPierre Jolivet       for (j = 0; j < 20; j++) PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " %" PetscInt_FMT, idx[i * 20 + j]));
4759566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "\n"));
476e5c89e4eSSatish Balay     }
477e5c89e4eSSatish Balay     if (p) {
478ca0c3be5SJacob Faibussowitsch       if (size > 1) {
4799566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "[%d] %" PetscInt_FMT ":", rank, 20 * n));
480ca0c3be5SJacob Faibussowitsch       } else {
4819566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "%" PetscInt_FMT ":", 20 * n));
482ca0c3be5SJacob Faibussowitsch       }
4839566063dSJacob Faibussowitsch       for (i = 0; i < p; i++) PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " %" PetscInt_FMT, idx[20 * n + i]));
4849566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "\n"));
485e5c89e4eSSatish Balay     }
4869566063dSJacob Faibussowitsch     PetscCall(PetscViewerFlush(viewer));
4879566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIIPopSynchronized(viewer));
4886805f65bSBarry Smith   } else if (isbinary) {
489ca0c3be5SJacob Faibussowitsch     PetscMPIInt *sizes, Ntotal, *displs, NN;
490e5c89e4eSSatish Balay     PetscInt    *array;
491783b601eSJed Brown 
4929566063dSJacob Faibussowitsch     PetscCall(PetscMPIIntCast(N, &NN));
493e5c89e4eSSatish Balay 
494e5c89e4eSSatish Balay     if (size > 1) {
495e5c89e4eSSatish Balay       if (rank) {
4969566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gather(&NN, 1, MPI_INT, NULL, 0, MPI_INT, 0, comm));
4979566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gatherv((void *)idx, NN, MPIU_INT, NULL, NULL, NULL, MPIU_INT, 0, comm));
498e5c89e4eSSatish Balay       } else {
4999566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(size, &sizes));
5009566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gather(&NN, 1, MPI_INT, sizes, 1, MPI_INT, 0, comm));
501e5c89e4eSSatish Balay         Ntotal = sizes[0];
5029566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(size, &displs));
503e5c89e4eSSatish Balay         displs[0] = 0;
504e5c89e4eSSatish Balay         for (i = 1; i < size; i++) {
505e5c89e4eSSatish Balay           Ntotal += sizes[i];
506e5c89e4eSSatish Balay           displs[i] = displs[i - 1] + sizes[i - 1];
507e5c89e4eSSatish Balay         }
5089566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(Ntotal, &array));
5099566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gatherv((void *)idx, NN, MPIU_INT, array, sizes, displs, MPIU_INT, 0, comm));
5109566063dSJacob Faibussowitsch         PetscCall(PetscViewerBinaryWrite(viewer, array, Ntotal, PETSC_INT));
5119566063dSJacob Faibussowitsch         PetscCall(PetscFree(sizes));
5129566063dSJacob Faibussowitsch         PetscCall(PetscFree(displs));
5139566063dSJacob Faibussowitsch         PetscCall(PetscFree(array));
514e5c89e4eSSatish Balay       }
515e5c89e4eSSatish Balay     } else {
5169566063dSJacob Faibussowitsch       PetscCall(PetscViewerBinaryWrite(viewer, idx, N, PETSC_INT));
517e5c89e4eSSatish Balay     }
518e5c89e4eSSatish Balay   } else {
519e5c89e4eSSatish Balay     const char *tname;
5209566063dSJacob Faibussowitsch     PetscCall(PetscObjectGetName((PetscObject)viewer, &tname));
52198921bdaSJacob Faibussowitsch     SETERRQ(PETSC_COMM_SELF, PETSC_ERR_SUP, "Cannot handle that PetscViewer of type %s", tname);
522e5c89e4eSSatish Balay   }
5233ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
524e5c89e4eSSatish Balay }
525e5c89e4eSSatish Balay 
526e5c89e4eSSatish Balay /*@C
527e5c89e4eSSatish Balay   PetscRealView - Prints an array of doubles; useful for debugging.
528e5c89e4eSSatish Balay 
529c3339decSBarry Smith   Collective
530e5c89e4eSSatish Balay 
531e5c89e4eSSatish Balay   Input Parameters:
532811af0c4SBarry Smith + N      - number of `PetscReal` in array
533811af0c4SBarry Smith . idx    - array of `PetscReal`
534811af0c4SBarry Smith - viewer - location to print array, `PETSC_VIEWER_STDOUT_WORLD`, `PETSC_VIEWER_STDOUT_SELF` or 0
535e5c89e4eSSatish Balay 
536e5c89e4eSSatish Balay   Level: intermediate
537e5c89e4eSSatish Balay 
538811af0c4SBarry Smith   Note:
539811af0c4SBarry Smith   This may be called from within the debugger
540300a7f5bSBarry Smith 
541aec76313SJacob Faibussowitsch   Developer Notes:
542811af0c4SBarry Smith   idx cannot be const because may be passed to binary viewer where temporary byte swapping may be done
543811af0c4SBarry Smith 
544811af0c4SBarry Smith .seealso: `PetscViewer`, `PetscIntView()`
545e5c89e4eSSatish Balay @*/
546d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscRealView(PetscInt N, const PetscReal idx[], PetscViewer viewer)
547d71ae5a4SJacob Faibussowitsch {
548ca0c3be5SJacob Faibussowitsch   PetscMPIInt rank, size;
549e5c89e4eSSatish Balay   PetscInt    j, i, n = N / 5, p = N % 5;
550ace3abfcSBarry Smith   PetscBool   iascii, isbinary;
551e5c89e4eSSatish Balay   MPI_Comm    comm;
552e5c89e4eSSatish Balay 
553e5c89e4eSSatish Balay   PetscFunctionBegin;
554e5c89e4eSSatish Balay   if (!viewer) viewer = PETSC_VIEWER_STDOUT_SELF;
5550700a824SBarry Smith   PetscValidHeaderSpecific(viewer, PETSC_VIEWER_CLASSID, 3);
5564f572ea9SToby Isaac   PetscAssertPointer(idx, 2);
5579566063dSJacob Faibussowitsch   PetscCall(PetscObjectGetComm((PetscObject)viewer, &comm));
5589566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Comm_size(comm, &size));
5599566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Comm_rank(comm, &rank));
560e5c89e4eSSatish Balay 
5619566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERASCII, &iascii));
5629566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERBINARY, &isbinary));
563e5c89e4eSSatish Balay   if (iascii) {
5641a989b97SToby Isaac     PetscInt tab;
5651a989b97SToby Isaac 
5669566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIIPushSynchronized(viewer));
5679566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIIGetTab(viewer, &tab));
568e5c89e4eSSatish Balay     for (i = 0; i < n; i++) {
5699566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISetTab(viewer, tab));
570ca0c3be5SJacob Faibussowitsch       if (size > 1) {
5719566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "[%d] %2" PetscInt_FMT ":", rank, 5 * i));
572ca0c3be5SJacob Faibussowitsch       } else {
5739566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "%2" PetscInt_FMT ":", 5 * i));
574ca0c3be5SJacob Faibussowitsch       }
5759566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISetTab(viewer, 0));
57648a46eb9SPierre Jolivet       for (j = 0; j < 5; j++) PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " %12.4e", (double)idx[i * 5 + j]));
5779566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "\n"));
578e5c89e4eSSatish Balay     }
579e5c89e4eSSatish Balay     if (p) {
5809566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISetTab(viewer, tab));
581ca0c3be5SJacob Faibussowitsch       if (size > 1) {
5829566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "[%d] %2" PetscInt_FMT ":", rank, 5 * n));
583ca0c3be5SJacob Faibussowitsch       } else {
5849566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "%2" PetscInt_FMT ":", 5 * n));
585ca0c3be5SJacob Faibussowitsch       }
5869566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISetTab(viewer, 0));
5879566063dSJacob Faibussowitsch       for (i = 0; i < p; i++) PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " %12.4e", (double)idx[5 * n + i]));
5889566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "\n"));
589e5c89e4eSSatish Balay     }
5909566063dSJacob Faibussowitsch     PetscCall(PetscViewerFlush(viewer));
5919566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIISetTab(viewer, tab));
5929566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIIPopSynchronized(viewer));
5936805f65bSBarry Smith   } else if (isbinary) {
594ca0c3be5SJacob Faibussowitsch     PetscMPIInt *sizes, *displs, Ntotal, NN;
595e5c89e4eSSatish Balay     PetscReal   *array;
596e5c89e4eSSatish Balay 
5979566063dSJacob Faibussowitsch     PetscCall(PetscMPIIntCast(N, &NN));
598e5c89e4eSSatish Balay 
599e5c89e4eSSatish Balay     if (size > 1) {
600e5c89e4eSSatish Balay       if (rank) {
6019566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gather(&NN, 1, MPI_INT, NULL, 0, MPI_INT, 0, comm));
6029566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gatherv((PetscReal *)idx, NN, MPIU_REAL, NULL, NULL, NULL, MPIU_REAL, 0, comm));
603e5c89e4eSSatish Balay       } else {
6049566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(size, &sizes));
6059566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gather(&NN, 1, MPI_INT, sizes, 1, MPI_INT, 0, comm));
606e5c89e4eSSatish Balay         Ntotal = sizes[0];
6079566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(size, &displs));
608e5c89e4eSSatish Balay         displs[0] = 0;
609e5c89e4eSSatish Balay         for (i = 1; i < size; i++) {
610e5c89e4eSSatish Balay           Ntotal += sizes[i];
611e5c89e4eSSatish Balay           displs[i] = displs[i - 1] + sizes[i - 1];
612e5c89e4eSSatish Balay         }
6139566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(Ntotal, &array));
6149566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gatherv((PetscReal *)idx, NN, MPIU_REAL, array, sizes, displs, MPIU_REAL, 0, comm));
6159566063dSJacob Faibussowitsch         PetscCall(PetscViewerBinaryWrite(viewer, array, Ntotal, PETSC_REAL));
6169566063dSJacob Faibussowitsch         PetscCall(PetscFree(sizes));
6179566063dSJacob Faibussowitsch         PetscCall(PetscFree(displs));
6189566063dSJacob Faibussowitsch         PetscCall(PetscFree(array));
619e5c89e4eSSatish Balay       }
620e5c89e4eSSatish Balay     } else {
6219566063dSJacob Faibussowitsch       PetscCall(PetscViewerBinaryWrite(viewer, (void *)idx, N, PETSC_REAL));
622e5c89e4eSSatish Balay     }
623e5c89e4eSSatish Balay   } else {
624e5c89e4eSSatish Balay     const char *tname;
6259566063dSJacob Faibussowitsch     PetscCall(PetscObjectGetName((PetscObject)viewer, &tname));
62698921bdaSJacob Faibussowitsch     SETERRQ(PETSC_COMM_SELF, PETSC_ERR_SUP, "Cannot handle that PetscViewer of type %s", tname);
627e5c89e4eSSatish Balay   }
6283ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
629e5c89e4eSSatish Balay }
630e5c89e4eSSatish Balay 
631e5c89e4eSSatish Balay /*@C
632811af0c4SBarry Smith   PetscScalarView - Prints an array of `PetscScalar`; useful for debugging.
633e5c89e4eSSatish Balay 
634c3339decSBarry Smith   Collective
635e5c89e4eSSatish Balay 
636e5c89e4eSSatish Balay   Input Parameters:
637e5c89e4eSSatish Balay + N      - number of scalars in array
638e5c89e4eSSatish Balay . idx    - array of scalars
639811af0c4SBarry Smith - viewer - location to print array, `PETSC_VIEWER_STDOUT_WORLD`, `PETSC_VIEWER_STDOUT_SELF` or 0
640e5c89e4eSSatish Balay 
641e5c89e4eSSatish Balay   Level: intermediate
642e5c89e4eSSatish Balay 
643811af0c4SBarry Smith   Note:
644811af0c4SBarry Smith   This may be called from within the debugger
645300a7f5bSBarry Smith 
646aec76313SJacob Faibussowitsch   Developer Notes:
647811af0c4SBarry Smith   idx cannot be const because may be passed to binary viewer where byte swapping may be done
648811af0c4SBarry Smith 
649811af0c4SBarry Smith .seealso: `PetscViewer`, `PetscIntView()`, `PetscRealView()`
650e5c89e4eSSatish Balay @*/
651d71ae5a4SJacob Faibussowitsch PetscErrorCode PetscScalarView(PetscInt N, const PetscScalar idx[], PetscViewer viewer)
652d71ae5a4SJacob Faibussowitsch {
653ca0c3be5SJacob Faibussowitsch   PetscMPIInt rank, size;
654e5c89e4eSSatish Balay   PetscInt    j, i, n = N / 3, p = N % 3;
655ace3abfcSBarry Smith   PetscBool   iascii, isbinary;
656e5c89e4eSSatish Balay   MPI_Comm    comm;
657e5c89e4eSSatish Balay 
658e5c89e4eSSatish Balay   PetscFunctionBegin;
659e5c89e4eSSatish Balay   if (!viewer) viewer = PETSC_VIEWER_STDOUT_SELF;
660e5c89e4eSSatish Balay   PetscValidHeader(viewer, 3);
6614f572ea9SToby Isaac   if (N) PetscAssertPointer(idx, 2);
6629566063dSJacob Faibussowitsch   PetscCall(PetscObjectGetComm((PetscObject)viewer, &comm));
6639566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Comm_size(comm, &size));
6649566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Comm_rank(comm, &rank));
665e5c89e4eSSatish Balay 
6669566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERASCII, &iascii));
6679566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERBINARY, &isbinary));
668e5c89e4eSSatish Balay   if (iascii) {
6699566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIIPushSynchronized(viewer));
670e5c89e4eSSatish Balay     for (i = 0; i < n; i++) {
671ca0c3be5SJacob Faibussowitsch       if (size > 1) {
6729566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "[%d] %2" PetscInt_FMT ":", rank, 3 * i));
673ca0c3be5SJacob Faibussowitsch       } else {
6749566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "%2" PetscInt_FMT ":", 3 * i));
675ca0c3be5SJacob Faibussowitsch       }
676e5c89e4eSSatish Balay       for (j = 0; j < 3; j++) {
677e5c89e4eSSatish Balay #if defined(PETSC_USE_COMPLEX)
6789566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " (%12.4e,%12.4e)", (double)PetscRealPart(idx[i * 3 + j]), (double)PetscImaginaryPart(idx[i * 3 + j])));
679e5c89e4eSSatish Balay #else
6809566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " %12.4e", (double)idx[i * 3 + j]));
681e5c89e4eSSatish Balay #endif
682e5c89e4eSSatish Balay       }
6839566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "\n"));
684e5c89e4eSSatish Balay     }
685e5c89e4eSSatish Balay     if (p) {
686ca0c3be5SJacob Faibussowitsch       if (size > 1) {
6879566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "[%d] %2" PetscInt_FMT ":", rank, 3 * n));
688ca0c3be5SJacob Faibussowitsch       } else {
6899566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "%2" PetscInt_FMT ":", 3 * n));
690ca0c3be5SJacob Faibussowitsch       }
691e5c89e4eSSatish Balay       for (i = 0; i < p; i++) {
692e5c89e4eSSatish Balay #if defined(PETSC_USE_COMPLEX)
6939566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " (%12.4e,%12.4e)", (double)PetscRealPart(idx[n * 3 + i]), (double)PetscImaginaryPart(idx[n * 3 + i])));
694e5c89e4eSSatish Balay #else
6959566063dSJacob Faibussowitsch         PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, " %12.4e", (double)idx[3 * n + i]));
696e5c89e4eSSatish Balay #endif
697e5c89e4eSSatish Balay       }
6989566063dSJacob Faibussowitsch       PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "\n"));
699e5c89e4eSSatish Balay     }
7009566063dSJacob Faibussowitsch     PetscCall(PetscViewerFlush(viewer));
7019566063dSJacob Faibussowitsch     PetscCall(PetscViewerASCIIPopSynchronized(viewer));
7026805f65bSBarry Smith   } else if (isbinary) {
703ca0c3be5SJacob Faibussowitsch     PetscMPIInt *sizes, Ntotal, *displs, NN;
704e5c89e4eSSatish Balay     PetscScalar *array;
705e5c89e4eSSatish Balay 
7069566063dSJacob Faibussowitsch     PetscCall(PetscMPIIntCast(N, &NN));
707e5c89e4eSSatish Balay 
708e5c89e4eSSatish Balay     if (size > 1) {
709e5c89e4eSSatish Balay       if (rank) {
7109566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gather(&NN, 1, MPI_INT, NULL, 0, MPI_INT, 0, comm));
7119566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gatherv((void *)idx, NN, MPIU_SCALAR, NULL, NULL, NULL, MPIU_SCALAR, 0, comm));
712e5c89e4eSSatish Balay       } else {
7139566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(size, &sizes));
7149566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gather(&NN, 1, MPI_INT, sizes, 1, MPI_INT, 0, comm));
715e5c89e4eSSatish Balay         Ntotal = sizes[0];
7169566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(size, &displs));
717e5c89e4eSSatish Balay         displs[0] = 0;
718e5c89e4eSSatish Balay         for (i = 1; i < size; i++) {
719e5c89e4eSSatish Balay           Ntotal += sizes[i];
720e5c89e4eSSatish Balay           displs[i] = displs[i - 1] + sizes[i - 1];
721e5c89e4eSSatish Balay         }
7229566063dSJacob Faibussowitsch         PetscCall(PetscMalloc1(Ntotal, &array));
7239566063dSJacob Faibussowitsch         PetscCallMPI(MPI_Gatherv((void *)idx, NN, MPIU_SCALAR, array, sizes, displs, MPIU_SCALAR, 0, comm));
7249566063dSJacob Faibussowitsch         PetscCall(PetscViewerBinaryWrite(viewer, array, Ntotal, PETSC_SCALAR));
7259566063dSJacob Faibussowitsch         PetscCall(PetscFree(sizes));
7269566063dSJacob Faibussowitsch         PetscCall(PetscFree(displs));
7279566063dSJacob Faibussowitsch         PetscCall(PetscFree(array));
728e5c89e4eSSatish Balay       }
729e5c89e4eSSatish Balay     } else {
7309566063dSJacob Faibussowitsch       PetscCall(PetscViewerBinaryWrite(viewer, (void *)idx, N, PETSC_SCALAR));
731e5c89e4eSSatish Balay     }
732e5c89e4eSSatish Balay   } else {
733e5c89e4eSSatish Balay     const char *tname;
7349566063dSJacob Faibussowitsch     PetscCall(PetscObjectGetName((PetscObject)viewer, &tname));
73598921bdaSJacob Faibussowitsch     SETERRQ(PETSC_COMM_SELF, PETSC_ERR_SUP, "Cannot handle that PetscViewer of type %s", tname);
736e5c89e4eSSatish Balay   }
7373ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
738e5c89e4eSSatish Balay }
739e5c89e4eSSatish Balay 
740e22e20c5SJunchao Zhang #if defined(PETSC_HAVE_CUDA)
7410e6b6b59SJacob Faibussowitsch   #include <petscdevice_cuda.h>
742d71ae5a4SJacob Faibussowitsch PETSC_EXTERN const char *PetscCUBLASGetErrorName(cublasStatus_t status)
743d71ae5a4SJacob Faibussowitsch {
744e22e20c5SJunchao Zhang   switch (status) {
745e22e20c5SJunchao Zhang   #if (CUDART_VERSION >= 8000) /* At least CUDA 8.0 of Sep. 2016 had these */
746d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_SUCCESS:
747d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_SUCCESS";
748d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_NOT_INITIALIZED:
749d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_NOT_INITIALIZED";
750d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_ALLOC_FAILED:
751d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_ALLOC_FAILED";
752d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_INVALID_VALUE:
753d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_INVALID_VALUE";
754d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_ARCH_MISMATCH:
755d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_ARCH_MISMATCH";
756d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_MAPPING_ERROR:
757d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_MAPPING_ERROR";
758d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_EXECUTION_FAILED:
759d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_EXECUTION_FAILED";
760d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_INTERNAL_ERROR:
761d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_INTERNAL_ERROR";
762d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_NOT_SUPPORTED:
763d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_NOT_SUPPORTED";
764d71ae5a4SJacob Faibussowitsch   case CUBLAS_STATUS_LICENSE_ERROR:
765d71ae5a4SJacob Faibussowitsch     return "CUBLAS_STATUS_LICENSE_ERROR";
766e22e20c5SJunchao Zhang   #endif
767d71ae5a4SJacob Faibussowitsch   default:
768d71ae5a4SJacob Faibussowitsch     return "unknown error";
769e22e20c5SJunchao Zhang   }
770e22e20c5SJunchao Zhang }
771d71ae5a4SJacob Faibussowitsch PETSC_EXTERN const char *PetscCUSolverGetErrorName(cusolverStatus_t status)
772d71ae5a4SJacob Faibussowitsch {
773a4b895e1SBarry Smith   switch (status) {
774a4b895e1SBarry Smith   #if (CUDART_VERSION >= 8000) /* At least CUDA 8.0 of Sep. 2016 had these */
775d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_SUCCESS:
776d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_SUCCESS";
777d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_NOT_INITIALIZED:
778d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_NOT_INITIALIZED";
779d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_INVALID_VALUE:
780d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_INVALID_VALUE";
781d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_ARCH_MISMATCH:
782d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_ARCH_MISMATCH";
783d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_INTERNAL_ERROR:
784d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_INTERNAL_ERROR";
785030f984aSJacob Faibussowitsch     #if (CUDART_VERSION >= 9000) /* CUDA 9.0 had these defined on June 2021 */
786d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_ALLOC_FAILED:
787d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_ALLOC_FAILED";
788d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_MAPPING_ERROR:
789d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_MAPPING_ERROR";
790d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_EXECUTION_FAILED:
791d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_EXECUTION_FAILED";
792d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_MATRIX_TYPE_NOT_SUPPORTED:
793d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_MATRIX_TYPE_NOT_SUPPORTED";
794d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_NOT_SUPPORTED:
795d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_NOT_SUPPORTED ";
796d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_ZERO_PIVOT:
797d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_ZERO_PIVOT";
798d71ae5a4SJacob Faibussowitsch   case CUSOLVER_STATUS_INVALID_LICENSE:
799d71ae5a4SJacob Faibussowitsch     return "CUSOLVER_STATUS_INVALID_LICENSE";
800a4b895e1SBarry Smith     #endif
801030f984aSJacob Faibussowitsch   #endif
802d71ae5a4SJacob Faibussowitsch   default:
803d71ae5a4SJacob Faibussowitsch     return "unknown error";
804030f984aSJacob Faibussowitsch   }
805030f984aSJacob Faibussowitsch }
806d71ae5a4SJacob Faibussowitsch PETSC_EXTERN const char *PetscCUFFTGetErrorName(cufftResult result)
807d71ae5a4SJacob Faibussowitsch {
808030f984aSJacob Faibussowitsch   switch (result) {
809d71ae5a4SJacob Faibussowitsch   case CUFFT_SUCCESS:
810d71ae5a4SJacob Faibussowitsch     return "CUFFT_SUCCESS";
811d71ae5a4SJacob Faibussowitsch   case CUFFT_INVALID_PLAN:
812d71ae5a4SJacob Faibussowitsch     return "CUFFT_INVALID_PLAN";
813d71ae5a4SJacob Faibussowitsch   case CUFFT_ALLOC_FAILED:
814d71ae5a4SJacob Faibussowitsch     return "CUFFT_ALLOC_FAILED";
815d71ae5a4SJacob Faibussowitsch   case CUFFT_INVALID_TYPE:
816d71ae5a4SJacob Faibussowitsch     return "CUFFT_INVALID_TYPE";
817d71ae5a4SJacob Faibussowitsch   case CUFFT_INVALID_VALUE:
818d71ae5a4SJacob Faibussowitsch     return "CUFFT_INVALID_VALUE";
819d71ae5a4SJacob Faibussowitsch   case CUFFT_INTERNAL_ERROR:
820d71ae5a4SJacob Faibussowitsch     return "CUFFT_INTERNAL_ERROR";
821d71ae5a4SJacob Faibussowitsch   case CUFFT_EXEC_FAILED:
822d71ae5a4SJacob Faibussowitsch     return "CUFFT_EXEC_FAILED";
823d71ae5a4SJacob Faibussowitsch   case CUFFT_SETUP_FAILED:
824d71ae5a4SJacob Faibussowitsch     return "CUFFT_SETUP_FAILED";
825d71ae5a4SJacob Faibussowitsch   case CUFFT_INVALID_SIZE:
826d71ae5a4SJacob Faibussowitsch     return "CUFFT_INVALID_SIZE";
827d71ae5a4SJacob Faibussowitsch   case CUFFT_UNALIGNED_DATA:
828d71ae5a4SJacob Faibussowitsch     return "CUFFT_UNALIGNED_DATA";
829d71ae5a4SJacob Faibussowitsch   case CUFFT_INCOMPLETE_PARAMETER_LIST:
830d71ae5a4SJacob Faibussowitsch     return "CUFFT_INCOMPLETE_PARAMETER_LIST";
831d71ae5a4SJacob Faibussowitsch   case CUFFT_INVALID_DEVICE:
832d71ae5a4SJacob Faibussowitsch     return "CUFFT_INVALID_DEVICE";
833d71ae5a4SJacob Faibussowitsch   case CUFFT_PARSE_ERROR:
834d71ae5a4SJacob Faibussowitsch     return "CUFFT_PARSE_ERROR";
835d71ae5a4SJacob Faibussowitsch   case CUFFT_NO_WORKSPACE:
836d71ae5a4SJacob Faibussowitsch     return "CUFFT_NO_WORKSPACE";
837d71ae5a4SJacob Faibussowitsch   case CUFFT_NOT_IMPLEMENTED:
838d71ae5a4SJacob Faibussowitsch     return "CUFFT_NOT_IMPLEMENTED";
839d71ae5a4SJacob Faibussowitsch   case CUFFT_LICENSE_ERROR:
840d71ae5a4SJacob Faibussowitsch     return "CUFFT_LICENSE_ERROR";
841d71ae5a4SJacob Faibussowitsch   case CUFFT_NOT_SUPPORTED:
842d71ae5a4SJacob Faibussowitsch     return "CUFFT_NOT_SUPPORTED";
843d71ae5a4SJacob Faibussowitsch   default:
844d71ae5a4SJacob Faibussowitsch     return "unknown error";
845a4b895e1SBarry Smith   }
846a4b895e1SBarry Smith }
847e22e20c5SJunchao Zhang #endif
84859af0bd3SScott Kruger 
84959af0bd3SScott Kruger #if defined(PETSC_HAVE_HIP)
8500e6b6b59SJacob Faibussowitsch   #include <petscdevice_hip.h>
851d71ae5a4SJacob Faibussowitsch PETSC_EXTERN const char *PetscHIPBLASGetErrorName(hipblasStatus_t status)
852d71ae5a4SJacob Faibussowitsch {
85359af0bd3SScott Kruger   switch (status) {
854d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_SUCCESS:
855d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_SUCCESS";
856d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_NOT_INITIALIZED:
857d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_NOT_INITIALIZED";
858d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_ALLOC_FAILED:
859d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_ALLOC_FAILED";
860d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_INVALID_VALUE:
861d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_INVALID_VALUE";
862d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_ARCH_MISMATCH:
863d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_ARCH_MISMATCH";
864d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_MAPPING_ERROR:
865d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_MAPPING_ERROR";
866d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_EXECUTION_FAILED:
867d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_EXECUTION_FAILED";
868d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_INTERNAL_ERROR:
869d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_INTERNAL_ERROR";
870d71ae5a4SJacob Faibussowitsch   case HIPBLAS_STATUS_NOT_SUPPORTED:
871d71ae5a4SJacob Faibussowitsch     return "HIPBLAS_STATUS_NOT_SUPPORTED";
872d71ae5a4SJacob Faibussowitsch   default:
873d71ae5a4SJacob Faibussowitsch     return "unknown error";
87459af0bd3SScott Kruger   }
87559af0bd3SScott Kruger }
87647d993e7Ssuyashtn PETSC_EXTERN const char *PetscHIPSPARSEGetErrorName(hipsparseStatus_t status)
87747d993e7Ssuyashtn {
87847d993e7Ssuyashtn   switch (status) {
87947d993e7Ssuyashtn   case HIPSPARSE_STATUS_SUCCESS:
88047d993e7Ssuyashtn     return "HIPSPARSE_STATUS_SUCCESS";
88147d993e7Ssuyashtn   case HIPSPARSE_STATUS_NOT_INITIALIZED:
88247d993e7Ssuyashtn     return "HIPSPARSE_STATUS_NOT_INITIALIZED";
88347d993e7Ssuyashtn   case HIPSPARSE_STATUS_ALLOC_FAILED:
88447d993e7Ssuyashtn     return "HIPSPARSE_STATUS_ALLOC_FAILED";
88547d993e7Ssuyashtn   case HIPSPARSE_STATUS_INVALID_VALUE:
88647d993e7Ssuyashtn     return "HIPSPARSE_STATUS_INVALID_VALUE";
88747d993e7Ssuyashtn   case HIPSPARSE_STATUS_ARCH_MISMATCH:
88847d993e7Ssuyashtn     return "HIPSPARSE_STATUS_ARCH_MISMATCH";
88947d993e7Ssuyashtn   case HIPSPARSE_STATUS_MAPPING_ERROR:
89047d993e7Ssuyashtn     return "HIPSPARSE_STATUS_MAPPING_ERROR";
89147d993e7Ssuyashtn   case HIPSPARSE_STATUS_EXECUTION_FAILED:
89247d993e7Ssuyashtn     return "HIPSPARSE_STATUS_EXECUTION_FAILED";
89347d993e7Ssuyashtn   case HIPSPARSE_STATUS_INTERNAL_ERROR:
89447d993e7Ssuyashtn     return "HIPSPARSE_STATUS_INTERNAL_ERROR";
89547d993e7Ssuyashtn   case HIPSPARSE_STATUS_MATRIX_TYPE_NOT_SUPPORTED:
89647d993e7Ssuyashtn     return "HIPSPARSE_STATUS_MATRIX_TYPE_NOT_SUPPORTED";
89747d993e7Ssuyashtn   case HIPSPARSE_STATUS_ZERO_PIVOT:
89847d993e7Ssuyashtn     return "HIPSPARSE_STATUS_ZERO_PIVOT";
89947d993e7Ssuyashtn   case HIPSPARSE_STATUS_NOT_SUPPORTED:
90047d993e7Ssuyashtn     return "HIPSPARSE_STATUS_NOT_SUPPORTED";
90147d993e7Ssuyashtn   case HIPSPARSE_STATUS_INSUFFICIENT_RESOURCES:
90247d993e7Ssuyashtn     return "HIPSPARSE_STATUS_INSUFFICIENT_RESOURCES";
90347d993e7Ssuyashtn   default:
90447d993e7Ssuyashtn     return "unknown error";
90547d993e7Ssuyashtn   }
90647d993e7Ssuyashtn }
90747d993e7Ssuyashtn PETSC_EXTERN const char *PetscHIPSolverGetErrorName(hipsolverStatus_t status)
90847d993e7Ssuyashtn {
90947d993e7Ssuyashtn   switch (status) {
91047d993e7Ssuyashtn   case HIPSOLVER_STATUS_SUCCESS:
91147d993e7Ssuyashtn     return "HIPSOLVER_STATUS_SUCCESS";
91247d993e7Ssuyashtn   case HIPSOLVER_STATUS_NOT_INITIALIZED:
91347d993e7Ssuyashtn     return "HIPSOLVER_STATUS_NOT_INITIALIZED";
91447d993e7Ssuyashtn   case HIPSOLVER_STATUS_ALLOC_FAILED:
91547d993e7Ssuyashtn     return "HIPSOLVER_STATUS_ALLOC_FAILED";
91647d993e7Ssuyashtn   case HIPSOLVER_STATUS_MAPPING_ERROR:
91747d993e7Ssuyashtn     return "HIPSOLVER_STATUS_MAPPING_ERROR";
91847d993e7Ssuyashtn   case HIPSOLVER_STATUS_INVALID_VALUE:
91947d993e7Ssuyashtn     return "HIPSOLVER_STATUS_INVALID_VALUE";
92047d993e7Ssuyashtn   case HIPSOLVER_STATUS_EXECUTION_FAILED:
92147d993e7Ssuyashtn     return "HIPSOLVER_STATUS_EXECUTION_FAILED";
92247d993e7Ssuyashtn   case HIPSOLVER_STATUS_INTERNAL_ERROR:
92347d993e7Ssuyashtn     return "HIPSOLVER_STATUS_INTERNAL_ERROR";
92447d993e7Ssuyashtn   case HIPSOLVER_STATUS_NOT_SUPPORTED:
92547d993e7Ssuyashtn     return "HIPSOLVER_STATUS_NOT_SUPPORTED ";
92647d993e7Ssuyashtn   case HIPSOLVER_STATUS_ARCH_MISMATCH:
92747d993e7Ssuyashtn     return "HIPSOLVER_STATUS_ARCH_MISMATCH";
92847d993e7Ssuyashtn   case HIPSOLVER_STATUS_HANDLE_IS_NULLPTR:
92947d993e7Ssuyashtn     return "HIPSOLVER_STATUS_HANDLE_IS_NULLPTR";
93047d993e7Ssuyashtn   case HIPSOLVER_STATUS_INVALID_ENUM:
93147d993e7Ssuyashtn     return "HIPSOLVER_STATUS_INVALID_ENUM";
93247d993e7Ssuyashtn   case HIPSOLVER_STATUS_UNKNOWN:
93347d993e7Ssuyashtn   default:
93447d993e7Ssuyashtn     return "HIPSOLVER_STATUS_UNKNOWN";
93547d993e7Ssuyashtn   }
93647d993e7Ssuyashtn }
93759af0bd3SScott Kruger #endif
938db9cea48SBarry Smith 
939aec76313SJacob Faibussowitsch /*@C
940811af0c4SBarry Smith   PetscMPIErrorString - Given an MPI error code returns the `MPI_Error_string()` appropriately
941db9cea48SBarry Smith   formatted for displaying with the PETSc error handlers.
942db9cea48SBarry Smith 
943db9cea48SBarry Smith   Input Parameter:
944db9cea48SBarry Smith . err - the MPI error code
945db9cea48SBarry Smith 
946db9cea48SBarry Smith   Output Parameter:
947811af0c4SBarry Smith . string - the MPI error message, should declare its length to be larger than `MPI_MAX_ERROR_STRING`
948db9cea48SBarry Smith 
94949c86fc7SBarry Smith   Level: developer
95049c86fc7SBarry Smith 
951811af0c4SBarry Smith   Note:
952db9cea48SBarry Smith   Does not return an error code or do error handling because it may be called from inside an error handler
953db9cea48SBarry Smith 
95410450e9eSJacob Faibussowitsch .seealso: `PetscErrorCode` `PetscErrorMessage()`
955db9cea48SBarry Smith @*/
956d71ae5a4SJacob Faibussowitsch void PetscMPIErrorString(PetscMPIInt err, char *string)
957d71ae5a4SJacob Faibussowitsch {
958db9cea48SBarry Smith   char        errorstring[MPI_MAX_ERROR_STRING];
959db9cea48SBarry Smith   PetscMPIInt len, j = 0;
960db9cea48SBarry Smith 
961db9cea48SBarry Smith   MPI_Error_string(err, (char *)errorstring, &len);
962db9cea48SBarry Smith   for (PetscMPIInt i = 0; i < len; i++) {
963db9cea48SBarry Smith     string[j++] = errorstring[i];
964db9cea48SBarry Smith     if (errorstring[i] == '\n') {
965db9cea48SBarry Smith       for (PetscMPIInt k = 0; k < 16; k++) string[j++] = ' ';
966db9cea48SBarry Smith     }
967db9cea48SBarry Smith   }
968db9cea48SBarry Smith   string[j] = 0;
969db9cea48SBarry Smith }
970