Actual source code: dlregis.c
1: /*$Id: dlregis.c,v 1.19 2001/03/23 23:24:34 balay Exp $*/
3: #include petscvec.h
4: #include petscpf.h
6: /*@C
7: VecInitializePackage - This function initializes everything in the Vec package. It is called
8: from PetscDLLibraryRegister() when using dynamic libraries, and on the first call to VecCreate()
9: when using static libraries.
11: Input Parameter:
12: path - The dynamic library path, or PETSC_NULL
14: Level: developer
16: .keywords: Vec, initialize, package
17: .seealso: PetscInitialize()
18: @*/
19: int VecInitializePackage(char *path) {
20: static PetscTruth initialized = PETSC_FALSE;
21: char logList[256];
22: char *className;
23: PetscTruth opt;
24: int ierr;
27: if (initialized == PETSC_TRUE) return(0);
28: initialized = PETSC_TRUE;
29: /* Register Classes */
30: PetscLogClassRegister(&IS_COOKIE, "Index Set");
31: PetscLogClassRegister(&MAP_COOKIE, "Map");
32: PetscLogClassRegister(&VEC_COOKIE, "Vec");
33: PetscLogClassRegister(&VEC_SCATTER_COOKIE, "Vec Scatter");
34: PetscLogClassRegister(&PF_COOKIE, "PointFunction");
35: /* Register Constructors and Serializers */
36: PetscMapRegisterAll(path);
37: VecRegisterAll(path);
38: PFRegisterAll(path);
39: /* Register Events */
40: PetscLogEventRegister(&VEC_View, "VecView", VEC_COOKIE);
41: PetscLogEventRegister(&VEC_Max, "VecMax", VEC_COOKIE);
42: PetscLogEventRegister(&VEC_Min, "VecMin", VEC_COOKIE);
43: PetscLogEventRegister(&VEC_DotBarrier, "VecDotBarrier", VEC_COOKIE);
44: PetscLogEventRegister(&VEC_Dot, "VecDot", VEC_COOKIE);
45: PetscLogEventRegister(&VEC_MDotBarrier, "VecMDotBarrier", VEC_COOKIE);
46: PetscLogEventRegister(&VEC_MDot, "VecMDot", VEC_COOKIE);
47: PetscLogEventRegister(&VEC_TDot, "VecTDot", VEC_COOKIE);
48: PetscLogEventRegister(&VEC_MTDot, "VecMTDot", VEC_COOKIE);
49: PetscLogEventRegister(&VEC_NormBarrier, "VecNormBarrier", VEC_COOKIE);
50: PetscLogEventRegister(&VEC_Norm, "VecNorm", VEC_COOKIE);
51: PetscLogEventRegister(&VEC_Scale, "VecScale", VEC_COOKIE);
52: PetscLogEventRegister(&VEC_Copy, "VecCopy", VEC_COOKIE);
53: PetscLogEventRegister(&VEC_Set, "VecSet", VEC_COOKIE);
54: PetscLogEventRegister(&VEC_AXPY, "VecAXPY", VEC_COOKIE);
55: PetscLogEventRegister(&VEC_AYPX, "VecAYPX", VEC_COOKIE);
56: PetscLogEventRegister(&VEC_WAXPY, "VecWAXPY", VEC_COOKIE);
57: PetscLogEventRegister(&VEC_MAXPY, "VecMAXPY", VEC_COOKIE);
58: PetscLogEventRegister(&VEC_Swap, "VecSwap", VEC_COOKIE);
59: PetscLogEventRegister(&VEC_AssemblyBegin, "VecAssemblyBegin", VEC_COOKIE);
60: PetscLogEventRegister(&VEC_AssemblyEnd, "VecAssemblyEnd", VEC_COOKIE);
61: PetscLogEventRegister(&VEC_PointwiseMult, "VecPointwiseMult", VEC_COOKIE);
62: PetscLogEventRegister(&VEC_SetValues, "VecSetValues", VEC_COOKIE);
63: PetscLogEventRegister(&VEC_Load, "VecLoad", VEC_COOKIE);
64: PetscLogEventRegister(&VEC_ScatterBarrier, "VecScatterBarrie", VEC_COOKIE);
65: PetscLogEventRegister(&VEC_ScatterBegin, "VecScatterBegin", VEC_COOKIE);
66: PetscLogEventRegister(&VEC_ScatterEnd, "VecScatterEnd", VEC_COOKIE);
67: PetscLogEventRegister(&VEC_SetRandom, "VecSetRandom", VEC_COOKIE);
68: PetscLogEventRegister(&VEC_ReduceArithmetic, "VecReduceArith", VEC_COOKIE);
69: PetscLogEventRegister(&VEC_ReduceBarrier, "VecReduceBarrier", VEC_COOKIE);
70: PetscLogEventRegister(&VEC_ReduceCommunication, "VecReduceComm", VEC_COOKIE);
71: /* Turn off high traffic events by default */
72: PetscLogEventSetActiveAll(VEC_DotBarrier, PETSC_FALSE);
73: PetscLogEventSetActiveAll(VEC_MDotBarrier, PETSC_FALSE);
74: PetscLogEventSetActiveAll(VEC_NormBarrier, PETSC_FALSE);
75: PetscLogEventSetActiveAll(VEC_SetValues, PETSC_FALSE);
76: PetscLogEventSetActiveAll(VEC_ScatterBarrier, PETSC_FALSE);
77: PetscLogEventSetActiveAll(VEC_ReduceBarrier, PETSC_FALSE);
78: /* Process info exclusions */
79: PetscOptionsGetString(PETSC_NULL, "-log_info_exclude", logList, 256, &opt);
80: if (opt == PETSC_TRUE) {
81: PetscStrstr(logList, "is", &className);
82: if (className) {
83: PetscLogInfoDeactivateClass(IS_COOKIE);
84: }
85: PetscStrstr(logList, "map", &className);
86: if (className) {
87: PetscLogInfoDeactivateClass(MAP_COOKIE);
88: }
89: PetscStrstr(logList, "vec", &className);
90: if (className) {
91: PetscLogInfoDeactivateClass(VEC_COOKIE);
92: }
93: }
94: /* Process summary exclusions */
95: PetscOptionsGetString(PETSC_NULL, "-log_summary_exclude", logList, 256, &opt);
96: if (opt == PETSC_TRUE) {
97: PetscStrstr(logList, "is", &className);
98: if (className) {
99: PetscLogEventDeactivateClass(IS_COOKIE);
100: }
101: PetscStrstr(logList, "map", &className);
102: if (className) {
103: PetscLogEventDeactivateClass(MAP_COOKIE);
104: }
105: PetscStrstr(logList, "vec", &className);
106: if (className) {
107: PetscLogEventDeactivateClass(VEC_COOKIE);
108: }
109: }
110: /* Special processing */
111: PetscOptionsHasName(PETSC_NULL, "-log_sync", &opt);
112: if (opt == PETSC_TRUE) {
113: PetscLogEventActivate(VEC_ScatterBarrier);
114: PetscLogEventActivate(VEC_NormBarrier);
115: PetscLogEventActivate(VEC_DotBarrier);
116: PetscLogEventActivate(VEC_MDotBarrier);
117: PetscLogEventActivate(VEC_ReduceBarrier);
118: }
119: return(0);
120: }
122: #ifdef PETSC_USE_DYNAMIC_LIBRARIES
123: EXTERN_C_BEGIN
124: /*
125: PetscDLLibraryRegister - This function is called when the dynamic library it is in is opened.
127: This one registers all the methods that are in the basic PETSc Vec library.
129: Input Parameter:
130: path - library path
131: */
132: int PetscDLLibraryRegister(char *path)
133: {
136: PetscInitializeNoArguments(); if (ierr) return 1;
139: /*
140: If we got here then PETSc was properly loaded
141: */
142: VecInitializePackage(path);
143: return(0);
144: }
145: EXTERN_C_END
147: /* --------------------------------------------------------------------------*/
148: static char *contents = "PETSc Vector library. n";
149: static char *authors = PETSC_AUTHOR_INFO;
151: #include src/sys/src/utils/dlregis.h
153: #endif /* PETSC_USE_DYNAMIC_LIBRARIES */