11153da11SBarry Smith #define PETSCSNES_DLL 21153da11SBarry Smith 3*b9147fbbSdalcinl #include "include/private/snesimpl.h" 41153da11SBarry Smith 51153da11SBarry Smith #undef __FUNCT__ 61153da11SBarry Smith #define __FUNCT__ "SNESInitializePackage" 71153da11SBarry Smith /*@C 81153da11SBarry Smith SNESInitializePackage - This function initializes everything in the SNES package. It is called 91153da11SBarry Smith from PetscDLLibraryRegister() when using dynamic libraries, and on the first call to SNESCreate() 101153da11SBarry Smith when using static libraries. 111153da11SBarry Smith 121153da11SBarry Smith Input Parameter: 131153da11SBarry Smith path - The dynamic library path, or PETSC_NULL 141153da11SBarry Smith 151153da11SBarry Smith Level: developer 161153da11SBarry Smith 171153da11SBarry Smith .keywords: SNES, initialize, package 181153da11SBarry Smith .seealso: PetscInitialize() 191153da11SBarry Smith @*/ 201153da11SBarry Smith PetscErrorCode PETSCSNES_DLLEXPORT SNESInitializePackage(const char path[]) { 211153da11SBarry Smith static PetscTruth initialized = PETSC_FALSE; 221153da11SBarry Smith char logList[256]; 231153da11SBarry Smith char *className; 241153da11SBarry Smith PetscTruth opt; 251153da11SBarry Smith PetscErrorCode ierr; 261153da11SBarry Smith 271153da11SBarry Smith PetscFunctionBegin; 281153da11SBarry Smith if (initialized) PetscFunctionReturn(0); 291153da11SBarry Smith initialized = PETSC_TRUE; 301153da11SBarry Smith /* Register Classes */ 311153da11SBarry Smith ierr = PetscLogClassRegister(&SNES_COOKIE, "SNES");CHKERRQ(ierr); 321153da11SBarry Smith ierr = PetscLogClassRegister(&MATSNESMFCTX_COOKIE, "MatSNESMFCtx");CHKERRQ(ierr); 331153da11SBarry Smith /* Register Constructors */ 341153da11SBarry Smith ierr = SNESRegisterAll(path);CHKERRQ(ierr); 351153da11SBarry Smith /* Register Events */ 361153da11SBarry Smith ierr = PetscLogEventRegister(&SNES_Solve, "SNESSolve", SNES_COOKIE);CHKERRQ(ierr); 371153da11SBarry Smith ierr = PetscLogEventRegister(&SNES_LineSearch, "SNESLineSearch", SNES_COOKIE);CHKERRQ(ierr); 381153da11SBarry Smith ierr = PetscLogEventRegister(&SNES_FunctionEval, "SNESFunctionEval", SNES_COOKIE);CHKERRQ(ierr); 391153da11SBarry Smith ierr = PetscLogEventRegister(&SNES_JacobianEval, "SNESJacobianEval", SNES_COOKIE);CHKERRQ(ierr); 401153da11SBarry Smith ierr = PetscLogEventRegister(&MATSNESMF_Mult, "MatMultMatrixFre", MAT_COOKIE);CHKERRQ(ierr); 411153da11SBarry Smith /* Process info exclusions */ 426cf91177SBarry Smith ierr = PetscOptionsGetString(PETSC_NULL, "-info_exclude", logList, 256, &opt);CHKERRQ(ierr); 431153da11SBarry Smith if (opt) { 441153da11SBarry Smith ierr = PetscStrstr(logList, "snes", &className);CHKERRQ(ierr); 451153da11SBarry Smith if (className) { 466cf91177SBarry Smith ierr = PetscInfoDeactivateClass(SNES_COOKIE);CHKERRQ(ierr); 471153da11SBarry Smith } 481153da11SBarry Smith } 491153da11SBarry Smith /* Process summary exclusions */ 501153da11SBarry Smith ierr = PetscOptionsGetString(PETSC_NULL, "-log_summary_exclude", logList, 256, &opt);CHKERRQ(ierr); 511153da11SBarry Smith if (opt) { 521153da11SBarry Smith ierr = PetscStrstr(logList, "snes", &className);CHKERRQ(ierr); 531153da11SBarry Smith if (className) { 541153da11SBarry Smith ierr = PetscLogEventDeactivateClass(SNES_COOKIE);CHKERRQ(ierr); 551153da11SBarry Smith } 561153da11SBarry Smith } 571153da11SBarry Smith PetscFunctionReturn(0); 581153da11SBarry Smith } 591153da11SBarry Smith 601153da11SBarry Smith #ifdef PETSC_USE_DYNAMIC_LIBRARIES 611153da11SBarry Smith EXTERN_C_BEGIN 621153da11SBarry Smith #undef __FUNCT__ 631153da11SBarry Smith #define __FUNCT__ "PetscDLLibraryRegister_petscsnes" 641153da11SBarry Smith /* 651153da11SBarry Smith PetscDLLibraryRegister - This function is called when the dynamic library it is in is opened. 661153da11SBarry Smith 671153da11SBarry Smith This registers all of the SNES methods that are in the basic PETSc libpetscsnes library. 681153da11SBarry Smith 691153da11SBarry Smith Input Parameter: 701153da11SBarry Smith path - library path 711153da11SBarry Smith 721153da11SBarry Smith */ 731153da11SBarry Smith PetscErrorCode PETSCSNES_DLLEXPORT PetscDLLibraryRegister_petscsnes(char *path) 741153da11SBarry Smith { 751153da11SBarry Smith PetscErrorCode ierr; 761153da11SBarry Smith 771153da11SBarry Smith ierr = PetscInitializeNoArguments(); if (ierr) return 1; 781153da11SBarry Smith PetscFunctionBegin; 791153da11SBarry Smith /* 801153da11SBarry Smith If we got here then PETSc was properly loaded 811153da11SBarry Smith */ 821153da11SBarry Smith ierr = SNESInitializePackage(path);CHKERRQ(ierr); 831153da11SBarry Smith PetscFunctionReturn(0); 841153da11SBarry Smith } 851153da11SBarry Smith EXTERN_C_END 861153da11SBarry Smith 871153da11SBarry Smith #endif /* PETSC_USE_DYNAMIC_LIBRARIES */ 88