Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 1 | /* |
Jonathan Peyton | de4749b | 2016-12-14 23:01:24 +0000 | [diff] [blame] | 2 | * kmp_stub.cpp -- stub versions of user-callable OpenMP RT functions. |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 3 | */ |
| 4 | |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 5 | //===----------------------------------------------------------------------===// |
| 6 | // |
| 7 | // The LLVM Compiler Infrastructure |
| 8 | // |
| 9 | // This file is dual licensed under the MIT and the University of Illinois Open |
| 10 | // Source Licenses. See LICENSE.txt for details. |
| 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 14 | #include <errno.h> |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 15 | #include <limits.h> |
| 16 | #include <stdlib.h> |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 17 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 18 | #include "kmp.h" // KMP_DEFAULT_STKSIZE |
Jim Cownie | 4cc4bb4 | 2014-10-07 16:25:50 +0000 | [diff] [blame] | 19 | #include "kmp_stub.h" |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 20 | #include "omp.h" // Function renamings. |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 21 | |
| 22 | #if KMP_OS_WINDOWS |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 23 | #include <windows.h> |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 24 | #else |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 25 | #include <sys/time.h> |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 26 | #endif |
| 27 | |
Jim Cownie | 181b4bb | 2013-12-23 17:28:57 +0000 | [diff] [blame] | 28 | // Moved from omp.h |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 29 | #define omp_set_max_active_levels ompc_set_max_active_levels |
| 30 | #define omp_set_schedule ompc_set_schedule |
| 31 | #define omp_get_ancestor_thread_num ompc_get_ancestor_thread_num |
| 32 | #define omp_get_team_size ompc_get_team_size |
Jim Cownie | 181b4bb | 2013-12-23 17:28:57 +0000 | [diff] [blame] | 33 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 34 | #define omp_set_num_threads ompc_set_num_threads |
| 35 | #define omp_set_dynamic ompc_set_dynamic |
| 36 | #define omp_set_nested ompc_set_nested |
| 37 | #define kmp_set_stacksize kmpc_set_stacksize |
| 38 | #define kmp_set_stacksize_s kmpc_set_stacksize_s |
| 39 | #define kmp_set_blocktime kmpc_set_blocktime |
| 40 | #define kmp_set_library kmpc_set_library |
| 41 | #define kmp_set_defaults kmpc_set_defaults |
| 42 | #define kmp_set_disp_num_buffers kmpc_set_disp_num_buffers |
| 43 | #define kmp_malloc kmpc_malloc |
| 44 | #define kmp_aligned_malloc kmpc_aligned_malloc |
| 45 | #define kmp_calloc kmpc_calloc |
| 46 | #define kmp_realloc kmpc_realloc |
| 47 | #define kmp_free kmpc_free |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 48 | |
| 49 | static double frequency = 0.0; |
| 50 | |
| 51 | // Helper functions. |
| 52 | static size_t __kmps_init() { |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 53 | static int initialized = 0; |
| 54 | static size_t dummy = 0; |
| 55 | if (!initialized) { |
| 56 | // TODO: Analyze KMP_VERSION environment variable, print |
| 57 | // __kmp_version_copyright and __kmp_version_build_time. |
| 58 | // WARNING: Do not use "fprintf(stderr, ...)" because it will cause |
| 59 | // unresolved "__iob" symbol (see C70080). We need to extract __kmp_printf() |
| 60 | // stuff from kmp_runtime.cpp and use it. |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 61 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 62 | // Trick with dummy variable forces linker to keep __kmp_version_copyright |
| 63 | // and __kmp_version_build_time strings in executable file (in case of |
| 64 | // static linkage). When KMP_VERSION analysis is implemented, dummy |
| 65 | // variable should be deleted, function should return void. |
| 66 | dummy = __kmp_version_copyright - __kmp_version_build_time; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 67 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 68 | #if KMP_OS_WINDOWS |
| 69 | LARGE_INTEGER freq; |
| 70 | BOOL status = QueryPerformanceFrequency(&freq); |
| 71 | if (status) { |
| 72 | frequency = double(freq.QuadPart); |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 73 | } |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 74 | #endif |
| 75 | |
| 76 | initialized = 1; |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 77 | } |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 78 | return dummy; |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 79 | } // __kmps_init |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 80 | |
| 81 | #define i __kmps_init(); |
| 82 | |
| 83 | /* set API functions */ |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 84 | void omp_set_num_threads(omp_int_t num_threads) { i; } |
| 85 | void omp_set_dynamic(omp_int_t dynamic) { |
| 86 | i; |
| 87 | __kmps_set_dynamic(dynamic); |
| 88 | } |
| 89 | void omp_set_nested(omp_int_t nested) { |
| 90 | i; |
| 91 | __kmps_set_nested(nested); |
| 92 | } |
| 93 | void omp_set_max_active_levels(omp_int_t max_active_levels) { i; } |
| 94 | void omp_set_schedule(omp_sched_t kind, omp_int_t modifier) { |
| 95 | i; |
| 96 | __kmps_set_schedule((kmp_sched_t)kind, modifier); |
| 97 | } |
| 98 | int omp_get_ancestor_thread_num(omp_int_t level) { |
| 99 | i; |
| 100 | return (level) ? (-1) : (0); |
| 101 | } |
| 102 | int omp_get_team_size(omp_int_t level) { |
| 103 | i; |
| 104 | return (level) ? (-1) : (1); |
| 105 | } |
| 106 | int kmpc_set_affinity_mask_proc(int proc, void **mask) { |
| 107 | i; |
| 108 | return -1; |
| 109 | } |
| 110 | int kmpc_unset_affinity_mask_proc(int proc, void **mask) { |
| 111 | i; |
| 112 | return -1; |
| 113 | } |
| 114 | int kmpc_get_affinity_mask_proc(int proc, void **mask) { |
| 115 | i; |
| 116 | return -1; |
| 117 | } |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 118 | |
| 119 | /* kmp API functions */ |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 120 | void kmp_set_stacksize(omp_int_t arg) { |
| 121 | i; |
| 122 | __kmps_set_stacksize(arg); |
| 123 | } |
| 124 | void kmp_set_stacksize_s(size_t arg) { |
| 125 | i; |
| 126 | __kmps_set_stacksize(arg); |
| 127 | } |
| 128 | void kmp_set_blocktime(omp_int_t arg) { |
| 129 | i; |
| 130 | __kmps_set_blocktime(arg); |
| 131 | } |
| 132 | void kmp_set_library(omp_int_t arg) { |
| 133 | i; |
| 134 | __kmps_set_library(arg); |
| 135 | } |
| 136 | void kmp_set_defaults(char const *str) { i; } |
| 137 | void kmp_set_disp_num_buffers(omp_int_t arg) { i; } |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 138 | |
| 139 | /* KMP memory management functions. */ |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 140 | void *kmp_malloc(size_t size) { |
| 141 | i; |
| 142 | return malloc(size); |
| 143 | } |
| 144 | void *kmp_aligned_malloc(size_t sz, size_t a) { |
| 145 | i; |
Jonathan Peyton | f83ae31 | 2016-05-12 22:00:37 +0000 | [diff] [blame] | 146 | #if KMP_OS_WINDOWS |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 147 | errno = ENOSYS; // not supported |
| 148 | return NULL; // no standard aligned allocator on Windows (pre - C11) |
Jonathan Peyton | f83ae31 | 2016-05-12 22:00:37 +0000 | [diff] [blame] | 149 | #else |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 150 | void *res; |
| 151 | int err; |
| 152 | if (err = posix_memalign(&res, a, sz)) { |
| 153 | errno = err; // can be EINVAL or ENOMEM |
| 154 | return NULL; |
| 155 | } |
| 156 | return res; |
Jonathan Peyton | f83ae31 | 2016-05-12 22:00:37 +0000 | [diff] [blame] | 157 | #endif |
| 158 | } |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 159 | void *kmp_calloc(size_t nelem, size_t elsize) { |
| 160 | i; |
| 161 | return calloc(nelem, elsize); |
| 162 | } |
| 163 | void *kmp_realloc(void *ptr, size_t size) { |
| 164 | i; |
| 165 | return realloc(ptr, size); |
| 166 | } |
| 167 | void kmp_free(void *ptr) { |
| 168 | i; |
| 169 | free(ptr); |
| 170 | } |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 171 | |
| 172 | static int __kmps_blocktime = INT_MAX; |
| 173 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 174 | void __kmps_set_blocktime(int arg) { |
| 175 | i; |
| 176 | __kmps_blocktime = arg; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 177 | } // __kmps_set_blocktime |
| 178 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 179 | int __kmps_get_blocktime(void) { |
| 180 | i; |
| 181 | return __kmps_blocktime; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 182 | } // __kmps_get_blocktime |
| 183 | |
| 184 | static int __kmps_dynamic = 0; |
| 185 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 186 | void __kmps_set_dynamic(int arg) { |
| 187 | i; |
| 188 | __kmps_dynamic = arg; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 189 | } // __kmps_set_dynamic |
| 190 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 191 | int __kmps_get_dynamic(void) { |
| 192 | i; |
| 193 | return __kmps_dynamic; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 194 | } // __kmps_get_dynamic |
| 195 | |
| 196 | static int __kmps_library = 1000; |
| 197 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 198 | void __kmps_set_library(int arg) { |
| 199 | i; |
| 200 | __kmps_library = arg; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 201 | } // __kmps_set_library |
| 202 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 203 | int __kmps_get_library(void) { |
| 204 | i; |
| 205 | return __kmps_library; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 206 | } // __kmps_get_library |
| 207 | |
| 208 | static int __kmps_nested = 0; |
| 209 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 210 | void __kmps_set_nested(int arg) { |
| 211 | i; |
| 212 | __kmps_nested = arg; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 213 | } // __kmps_set_nested |
| 214 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 215 | int __kmps_get_nested(void) { |
| 216 | i; |
| 217 | return __kmps_nested; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 218 | } // __kmps_get_nested |
| 219 | |
| 220 | static size_t __kmps_stacksize = KMP_DEFAULT_STKSIZE; |
| 221 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 222 | void __kmps_set_stacksize(int arg) { |
| 223 | i; |
| 224 | __kmps_stacksize = arg; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 225 | } // __kmps_set_stacksize |
| 226 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 227 | int __kmps_get_stacksize(void) { |
| 228 | i; |
| 229 | return __kmps_stacksize; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 230 | } // __kmps_get_stacksize |
| 231 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 232 | static kmp_sched_t __kmps_sched_kind = kmp_sched_default; |
| 233 | static int __kmps_sched_modifier = 0; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 234 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 235 | void __kmps_set_schedule(kmp_sched_t kind, int modifier) { |
| 236 | i; |
| 237 | __kmps_sched_kind = kind; |
| 238 | __kmps_sched_modifier = modifier; |
| 239 | } // __kmps_set_schedule |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 240 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 241 | void __kmps_get_schedule(kmp_sched_t *kind, int *modifier) { |
| 242 | i; |
| 243 | *kind = __kmps_sched_kind; |
| 244 | *modifier = __kmps_sched_modifier; |
| 245 | } // __kmps_get_schedule |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 246 | |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 247 | #if OMP_40_ENABLED |
| 248 | |
| 249 | static kmp_proc_bind_t __kmps_proc_bind = proc_bind_false; |
| 250 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 251 | void __kmps_set_proc_bind(kmp_proc_bind_t arg) { |
| 252 | i; |
| 253 | __kmps_proc_bind = arg; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 254 | } // __kmps_set_proc_bind |
| 255 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 256 | kmp_proc_bind_t __kmps_get_proc_bind(void) { |
| 257 | i; |
| 258 | return __kmps_proc_bind; |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 259 | } // __kmps_get_proc_bind |
| 260 | |
| 261 | #endif /* OMP_40_ENABLED */ |
| 262 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 263 | double __kmps_get_wtime(void) { |
| 264 | // Elapsed wall clock time (in second) from "sometime in the past". |
| 265 | double wtime = 0.0; |
| 266 | i; |
| 267 | #if KMP_OS_WINDOWS |
| 268 | if (frequency > 0.0) { |
| 269 | LARGE_INTEGER now; |
| 270 | BOOL status = QueryPerformanceCounter(&now); |
| 271 | if (status) { |
| 272 | wtime = double(now.QuadPart) / frequency; |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 273 | } |
| 274 | } |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 275 | #else |
| 276 | // gettimeofday() returns seconds and microseconds since the Epoch. |
| 277 | struct timeval tval; |
| 278 | int rc; |
| 279 | rc = gettimeofday(&tval, NULL); |
| 280 | if (rc == 0) { |
| 281 | wtime = (double)(tval.tv_sec) + 1.0E-06 * (double)(tval.tv_usec); |
| 282 | } else { |
| 283 | // TODO: Assert or abort here. |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 284 | } |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 285 | #endif |
| 286 | return wtime; |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 287 | } // __kmps_get_wtime |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 288 | |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 289 | double __kmps_get_wtick(void) { |
| 290 | // Number of seconds between successive clock ticks. |
| 291 | double wtick = 0.0; |
| 292 | i; |
| 293 | #if KMP_OS_WINDOWS |
| 294 | { |
| 295 | DWORD increment; |
| 296 | DWORD adjustment; |
| 297 | BOOL disabled; |
| 298 | BOOL rc; |
| 299 | rc = GetSystemTimeAdjustment(&adjustment, &increment, &disabled); |
| 300 | if (rc) { |
| 301 | wtick = 1.0E-07 * (double)(disabled ? increment : adjustment); |
| 302 | } else { |
| 303 | // TODO: Assert or abort here. |
| 304 | wtick = 1.0E-03; |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 305 | } |
Jonathan Peyton | 3041982 | 2017-05-12 18:01:32 +0000 | [diff] [blame] | 306 | } |
| 307 | #else |
| 308 | // TODO: gettimeofday() returns in microseconds, but what the precision? |
| 309 | wtick = 1.0E-06; |
| 310 | #endif |
| 311 | return wtick; |
Jonathan Peyton | bd3a763 | 2017-09-27 20:36:27 +0000 | [diff] [blame] | 312 | } // __kmps_get_wtick |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 313 | |
Jim Cownie | 5e8470a | 2013-09-27 10:38:44 +0000 | [diff] [blame] | 314 | // end of file // |