-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmkl_service.f90
117 lines (100 loc) · 3.45 KB
/
mkl_service.f90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
!*******************************************************************************
! INTEL CONFIDENTIAL
! Copyright(C) 1999-2008 Intel Corporation. All Rights Reserved.
! The source code contained or described herein and all documents related to
! the source code ("Material") are owned by Intel Corporation or its suppliers
! or licensors. Title to the Material remains with Intel Corporation or its
! suppliers and licensors. The Material contains trade secrets and proprietary
! and confidential information of Intel or its suppliers and licensors. The
! Material is protected by worldwide copyright and trade secret laws and
! treaty provisions. No part of the Material may be used, copied, reproduced,
! modified, published, uploaded, posted, transmitted, distributed or disclosed
! in any way without Intel's prior express written permission.
! No license under any patent, copyright, trade secret or other intellectual
! property right is granted to or conferred upon you by disclosure or delivery
! of the Materials, either expressly, by implication, inducement, estoppel or
! otherwise. Any license under such intellectual property rights must be
! express and approved by Intel in writing.
!
!*******************************************************************************
! Content:
! Intel(R) Math Kernel Library (MKL) FORTRAN interface for service routines
!*******************************************************************************
INTEGER*4 MKL_ALL
INTEGER*4 MKL_BLAS
INTEGER*4 MKL_FFT
INTEGER*4 MKL_VML
INTEGER*4 MKL_DYNAMIC_TRUE
INTEGER*4 MKL_DYNAMIC_FALSE
PARAMETER (MKL_ALL = 0)
PARAMETER (MKL_BLAS = 1)
PARAMETER (MKL_FFT = 2)
PARAMETER (MKL_VML = 3)
PARAMETER (MKL_DYNAMIC_TRUE = 1)
PARAMETER (MKL_DYNAMIC_FALSE = 0)
INTERFACE
subroutine MKLGETVERSIONSTRING(buf)
character*(*) buf
END
END INTERFACE
INTERFACE
double precision function GETCPUFREQUENCY()
END
END INTERFACE
INTERFACE
subroutine SETCPUFREQUENCY(freq)
double precision freq
END
END INTERFACE
INTERFACE
subroutine GETCPUCLOCKS(cpu_clocks)
integer*8 cpu_clocks
END
END INTERFACE
! Threading control functions
INTERFACE
integer*4 function MKL_GET_MAX_THREADS()
END
END INTERFACE
INTERFACE
integer*4 function MKL_DOMAIN_GET_MAX_THREADS(domain)
integer*4 domain
END
END INTERFACE
INTERFACE
subroutine MKL_SET_NUM_THREADS(nthrs)
integer*4 nthrs
END
END INTERFACE
INTERFACE
integer*4 function MKL_DOMAIN_SET_NUM_THREADS(nthrs,domain)
integer*4 nthrs
integer*4 domain
END
END INTERFACE
INTERFACE
integer*4 function MKL_GET_DYNAMIC()
END
END INTERFACE
INTERFACE
subroutine MKL_SET_DYNAMIC(mkl_dynamic)
integer*4 mkl_dynamic
END
END INTERFACE
! Memory functions
INTERFACE
subroutine MKL_FREE(ptr)
pointer (ptr,mkl_dummy_var)
integer*8 mkl_dummy_var(1)
END
END INTERFACE
INTERFACE
integer*8 function MKL_MEMSTAT(n_buff)
integer*4 n_buff
END
END INTERFACE
INTERFACE
subroutine MKL_FREEBUFFERS()
END
END INTERFACE
!*******************************************************************************