xref: /petsc/src/dm/impls/forest/p4est/petsc_p4est_package.c (revision feff33ee0b5b037fa8f9f294dede656a2f85cc47)
1 #include <petscdmforest.h>
2 #include <petsc/private/petscimpl.h>
3 #include <p4est_base.h>
4 #include "petsc_p4est_package.h"
5 
6 static const char*const SCLogTypes[] = {"DEFAULT","ALWAYS","TRACE","DEBUG","VERBOSE","INFO","STATISTICS","PRODUCTION","ESSENTIAL","ERROR","SILENT","SCLogTypes","SC_LP_",0};
7 
8 static PetscBool    PetscP4estInitialized = PETSC_FALSE;
9 static PetscBool    PetscBeganSc          = PETSC_FALSE;
10 static PetscClassId P4ESTLOGGING_CLASSID;
11 
12 PetscObject P4estLoggingObject; /* Just a vehicle for its classid */
13 
14 static void PetscScLogHandler(FILE *log_stream, const char *filename, int lineno,int package, int category,int priority, const char *msg)
15 {
16   PetscInfo_Private(filename,P4estLoggingObject,":%d{%s} %s",lineno,package == sc_package_id ? "sc" : package == p4est_package_id ? "p4est" : "",msg);
17 }
18 
19 /* p4est tries to abort: if possible, use setjmp to enable at least a little unwinding */
20 #if defined(PETSC_HAVE_SETJMP_H) && defined(PETSC_USE_ERRORCHECKING)
21 #include <setjmp.h>
22 PETSC_VISIBILITY_INTERNAL jmp_buf PetscScJumpBuf;
23 PETSC_INTERN void PetscScAbort_longjmp(void)
24 {
25   PetscError(PETSC_COMM_SELF,-1,"p4est function","p4est file",PETSC_ERR_LIB,PETSC_ERROR_INITIAL,"Error in p4est stack call\n");
26   longjmp(PetscScJumpBuf,1);
27   return;
28 }
29 
30 #define PetscScAbort PetscScAbort_longjmp
31 #else
32 #define PetscScAbort NULL
33 #endif
34 
35 static PetscErrorCode PetscP4estFinalize(void)
36 {
37   PetscErrorCode ierr;
38 
39   PetscFunctionBegin;
40   if (PetscBeganSc) {
41     /* We do not want libsc to abort on a mismatched allocation and prevent further Petsc unwinding */
42     PetscStackCallP4est(sc_package_set_abort_alloc_mismatch,(sc_package_id,0));
43     PetscStackCallP4est(sc_package_set_abort_alloc_mismatch,(p4est_package_id,0));
44     PetscStackCallP4est(sc_package_set_abort_alloc_mismatch,(-1,0));
45     PetscStackCallP4est(sc_finalize,());
46   }
47   ierr = PetscHeaderDestroy(&P4estLoggingObject);CHKERRQ(ierr);
48   PetscFunctionReturn(0);
49 }
50 
51 PetscErrorCode PetscP4estInitialize(void)
52 {
53   PetscBool      psc_catch_signals    = PETSC_FALSE;
54   PetscBool      psc_print_backtrace  = PETSC_TRUE;
55   int            psc_log_threshold    = SC_LP_DEFAULT;
56   int            pp4est_log_threshold = SC_LP_DEFAULT;
57   char           logList[256];
58   PetscBool      opt,pkg;
59   PetscErrorCode ierr;
60 
61   PetscFunctionBegin;
62   if (PetscP4estInitialized) PetscFunctionReturn(0);
63   PetscP4estInitialized = PETSC_TRUE;
64 
65   /* Register Classes */
66   ierr = PetscClassIdRegister("p4est logging",&P4ESTLOGGING_CLASSID);CHKERRQ(ierr);
67   /* Process info exclusions */
68   ierr = PetscOptionsGetString(NULL,NULL,"-info_exclude",logList,sizeof(logList),&opt);CHKERRQ(ierr);
69   if (opt) {
70     ierr = PetscStrInList("p4est",logList,',',&pkg);CHKERRQ(ierr);
71     if (pkg) {ierr = PetscInfoDeactivateClass(P4ESTLOGGING_CLASSID);CHKERRQ(ierr);}
72   }
73   /* Process summary exclusions */
74   ierr = PetscOptionsGetString(NULL,NULL,"-log_exclude",logList,sizeof(logList),&opt);CHKERRQ(ierr);
75   if (opt) {
76     ierr = PetscStrInList("p4est",logList,',',&pkg);CHKERRQ(ierr);
77     if (pkg) {ierr = PetscLogEventDeactivateClass(P4ESTLOGGING_CLASSID);CHKERRQ(ierr);}
78   }
79   ierr = PetscHeaderCreate(P4estLoggingObject,P4ESTLOGGING_CLASSID,"p4est","p4est logging","DM",PETSC_COMM_WORLD,NULL,PetscObjectView);CHKERRQ(ierr);
80   if (sc_package_id == -1) {
81     int       log_threshold_shifted = psc_log_threshold + 1;
82     PetscBool set;
83 
84     PetscBeganSc = PETSC_TRUE;
85     ierr         = PetscOptionsGetBool(NULL,NULL,"-petsc_sc_catch_signals",&psc_catch_signals,NULL);CHKERRQ(ierr);
86     ierr         = PetscOptionsGetBool(NULL,NULL,"-petsc_sc_print_backtrace",&psc_print_backtrace,NULL);CHKERRQ(ierr);
87     ierr         = PetscOptionsGetEnum(NULL,NULL,"-petsc_sc_log_threshold",SCLogTypes,(PetscEnum*)&log_threshold_shifted,&set);CHKERRQ(ierr);
88     if (set) psc_log_threshold = log_threshold_shifted - 1;
89     sc_init(PETSC_COMM_WORLD,(int)psc_catch_signals,(int)psc_print_backtrace,PetscScLogHandler,psc_log_threshold);
90     if (sc_package_id == -1) SETERRQ(PETSC_COMM_WORLD,PETSC_ERR_LIB,"Could not initialize libsc package used by p4est");
91     sc_set_abort_handler(PetscScAbort);
92   }
93   if (p4est_package_id == -1) {
94     int       log_threshold_shifted = pp4est_log_threshold + 1;
95     PetscBool set;
96 
97     ierr = PetscOptionsGetEnum(NULL,NULL,"-petsc_p4est_log_threshold",SCLogTypes,(PetscEnum*)&log_threshold_shifted,&set);CHKERRQ(ierr);
98     if (set) pp4est_log_threshold = log_threshold_shifted - 1;
99     PetscStackCallP4est(p4est_init,(PetscScLogHandler,pp4est_log_threshold));
100     if (p4est_package_id == -1) SETERRQ(PETSC_COMM_WORLD,PETSC_ERR_LIB,"Could not initialize p4est");
101   }
102   ierr = DMForestRegisterType(DMP4EST);CHKERRQ(ierr);
103   ierr = DMForestRegisterType(DMP8EST);CHKERRQ(ierr);
104   ierr = PetscRegisterFinalize(PetscP4estFinalize);CHKERRQ(ierr);
105   PetscFunctionReturn(0);
106 }
107