GCC Code Coverage Report


Directory: ./
File: rad/sdl_module.f90
Date: 2022-01-11 19:19:34
Exec Total Coverage
Lines: 0 9 0.0%
Branches: 0 0 -%

Line Branch Exec Source
1 MODULE SDL_MODULE
2
3 ! Interface between user applications and system-dependent intrinsic
4 ! routines, provided by the computer vendors.
5
6 ! All routines which wish to call these routines must contain:
7 ! USE SDL_MODULE
8
9 ! Author :
10 ! ------
11 ! 11-Apr-2005 R. El Khatib *METEO-FRANCE*
12 ! 26-Apr-2006 S.T.Saarinen Dr.Hook trace, calls to EC_RAISE, Intel/ifort traceback
13
14 USE PARKIND1 ,ONLY : JPIM ,JPRB
15 USE YOMHOOK ,ONLY : LHOOK ,DR_HOOK
16 USE YOMOML, ONLY : OML_MY_THREAD
17
18 IMPLICIT NONE
19
20 SAVE
21
22 PRIVATE
23
24 INTEGER, parameter :: SIGABRT = 6 ! Hardcoded
25
26 PUBLIC :: SDL_SRLABORT, SDL_DISABORT, SDL_TRACEBACK
27
28 CONTAINS
29
30 !-----------------------------------------------------------------------------
31 SUBROUTINE SDL_TRACEBACK(KTID)
32
33 ! Purpose :
34 ! -------
35 ! Traceback
36
37 ! KTID : thread
38
39 INTEGER(KIND=JPIM), INTENT(IN), OPTIONAL :: KTID
40 CALL ABOR1('DANS SDL_TRACEBACK') ! MPL 8.12.08 et commente toute la suite
41 !INTEGER(KIND=JPIM) ITID, IPRINT_OPTION, ILEVEL
42 !#ifdef NECSX
43 !CHARACTER(LEN=*), PARAMETER :: CLNECMSG = '*** Calling NEC traceback ***'
44 !#endif
45 !
46 !IF (PRESENT(KTID)) THEN
47 ! ITID = KTID
48 !ELSE
49 ! ITID = OML_MY_THREAD()
50 !ENDIF
51 !
52 !IF (LHOOK) THEN
53 ! IPRINT_OPTION = 2
54 ! ILEVEL = 0
55 ! CALL C_DRHOOK_PRINT(0, ITID, IPRINT_OPTION, ILEVEL) ! from drhook.c
56 !ENDIF
57 !
58 !#ifdef VPP
59 ! CALL ERRTRA
60 ! IF (PRESENT(KTID)) CALL SLEEP(28)
61 !#elif RS6K
62 ! WRITE(0,*)'SDL_TRACEBACK: Calling XL_TRBK, THRD = ',ITID
63 ! CALL XL__TRBK()
64 ! WRITE(0,*)'SDL_TRACEBACK: Done XL_TRBK, THRD = ',ITID
65 !#elif __INTEL_COMPILER
66 ! WRITE(0,*)'SDL_TRACEBACK: Calling INTEL_TRBK, THRD = ',ITID
67 ! CALL INTEL_TRBK() ! See ifsaux/utilities/gentrbk.F90
68 ! WRITE(0,*)'SDL_TRACEBACK: Done INTEL_TRBK, THRD = ',ITID
69 !#elif defined(LINUX) || defined(SUN4)
70 ! WRITE(0,*)'SDL_TRACEBACK: Calling LINUX_TRBK, THRD = ',ITID
71 ! CALL LINUX_TRBK() ! See ifsaux/utilities/linuxtrbk.c
72 ! WRITE(0,*)'SDL_TRACEBACK: Done LINUX_TRBK, THRD = ',ITID
73 !#elif defined(NECSX)
74 ! WRITE(0,*)'SDL_TRACEBACK: Calling NEC/MESPUT, THRD = ',ITID
75 ! CALL MESPUT(CLNECMSG, LEN(CLNECMSG), 1)
76 ! WRITE(0,*)'SDL_TRACEBACK: Done NEC/MESPUT, THRD = ',ITID
77 !#else
78 ! WRITE(0,*)'SDL_TRACEBACK: No proper traceback implemented.'
79 ! ! A traceback using dbx-debugger, if available AND
80 ! ! activated via 'export DBXDEBUGGER=1'
81 ! WRITE(0,*)'SDL_TRACEBACK: Calling DBX_TRBK, THRD = ',ITID
82 ! CALL DBX_TRBK() ! See ifsaux/utilities/linuxtrbk.c
83 ! WRITE(0,*)'SDL_TRACEBACK: Done DBX_TRBK, THRD = ',ITID
84 ! ! A traceback using gdb-debugger, if available AND
85 ! ! activated via 'export GDBDEBUGGER=1'
86 ! WRITE(0,*)'SDL_TRACEBACK: Calling GDB_TRBK, THRD = ',ITID
87 ! CALL GDB_TRBK() ! See ifsaux/utilities/linuxtrbk.c
88 ! WRITE(0,*)'SDL_TRACEBACK: Done GDB_TRBK, THRD = ',ITID
89 !#endif
90
91 END SUBROUTINE SDL_TRACEBACK
92 !-----------------------------------------------------------------------------
93 SUBROUTINE SDL_SRLABORT
94
95 ! Purpose :
96 ! -------
97 ! To abort in serial environment
98
99 !CALL EC_RAISE(SIGABRT) ! EC_RAISE remplace par ABOR1 MPL 8.12.08
100 CALL ABOR1('DANS SRLABORT')
101 STOP 'SDL_SRLABORT'
102
103 END SUBROUTINE SDL_SRLABORT
104 !-----------------------------------------------------------------------------
105 SUBROUTINE SDL_DISABORT(KCOMM)
106
107 ! Purpose :
108 ! -------
109 ! To abort in distributed environment
110
111 ! KCOMM : communicator
112
113 INTEGER(KIND=JPIM), INTENT(IN) :: KCOMM
114
115 INTEGER(KIND=JPIM) :: IRETURN_CODE,IERROR
116
117 !MPL 4.12.08
118 !#ifdef VPP
119 !
120 !CALL VPP_ABORT()
121 !
122 !#else
123 !
124 !IRETURN_CODE=1
125 !CALL MPI_ABORT(KCOMM,IRETURN_CODE,IERROR)
126
127 !#endif
128
129 !CALL EC_RAISE(SIGABRT) ! In case ever ends up here
130 CALL ABOR1('DANS SRLDISABORT') ! EC_RAISE remplace par ABOR1 MPL 8.12.08
131 STOP 'SDL_DISABORT'
132
133 END SUBROUTINE SDL_DISABORT
134 !-----------------------------------------------------------------------------
135
136 END MODULE SDL_MODULE
137