2015-05-12 Pierre-Marie de Rodat <derodat@adacore.com>
[official-gcc.git] / liboffloadmic / runtime / offload_myo_target.cpp
blobbd5ad17adbc4e72d374693c76ed7ba3b639476ad
1 /*
2 Copyright (c) 2014 Intel Corporation. All Rights Reserved.
4 Redistribution and use in source and binary forms, with or without
5 modification, are permitted provided that the following conditions
6 are met:
8 * Redistributions of source code must retain the above copyright
9 notice, this list of conditions and the following disclaimer.
10 * Redistributions in binary form must reproduce the above copyright
11 notice, this list of conditions and the following disclaimer in the
12 documentation and/or other materials provided with the distribution.
13 * Neither the name of Intel Corporation nor the names of its
14 contributors may be used to endorse or promote products derived
15 from this software without specific prior written permission.
17 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21 HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22 SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23 LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 #include "offload_myo_target.h"
32 #include "offload_target.h"
34 extern "C" void __cilkrts_cilk_for_32(void*, void*, uint32_t, int32_t);
35 extern "C" void __cilkrts_cilk_for_64(void*, void*, uint64_t, int32_t);
37 #pragma weak __cilkrts_cilk_for_32
38 #pragma weak __cilkrts_cilk_for_64
40 static void CheckResult(const char *func, MyoError error) {
41 if (error != MYO_SUCCESS) {
42 LIBOFFLOAD_ERROR(c_myotarget_checkresult, func, error);
43 exit(1);
47 static void __offload_myo_shared_table_register(SharedTableEntry *entry)
49 int entries = 0;
50 SharedTableEntry *t_start;
52 OFFLOAD_DEBUG_TRACE(3, "%s(%p)\n", __func__, entry);
54 t_start = entry;
55 while (t_start->varName != 0) {
56 OFFLOAD_DEBUG_TRACE_1(4, 0, c_offload_mic_myo_shared,
57 "myo shared entry name = \"%s\" addr = %p\n",
58 t_start->varName, t_start->sharedAddr);
59 t_start++;
60 entries++;
63 if (entries > 0) {
64 OFFLOAD_DEBUG_TRACE(3, "myoiMicVarTableRegister(%p, %d)\n", entry,
65 entries);
66 CheckResult("myoiMicVarTableRegister",
67 myoiMicVarTableRegister(entry, entries));
71 static void __offload_myo_fptr_table_register(
72 FptrTableEntry *entry
75 int entries = 0;
76 FptrTableEntry *t_start;
78 OFFLOAD_DEBUG_TRACE(3, "%s(%p)\n", __func__, entry);
80 t_start = entry;
81 while (t_start->funcName != 0) {
82 OFFLOAD_DEBUG_TRACE_1(4, 0, c_offload_mic_myo_fptr,
83 "myo fptr entry name = \"%s\" addr = %p\n",
84 t_start->funcName, t_start->funcAddr);
85 t_start++;
86 entries++;
89 if (entries > 0) {
90 OFFLOAD_DEBUG_TRACE(3, "myoiTargetFptrTableRegister(%p, %d, 0)\n",
91 entry, entries);
92 CheckResult("myoiTargetFptrTableRegister",
93 myoiTargetFptrTableRegister(entry, entries, 0));
97 extern "C" void __offload_myoAcquire(void)
99 OFFLOAD_DEBUG_TRACE(3, "%s\n", __func__);
100 CheckResult("myoAcquire", myoAcquire());
103 extern "C" void __offload_myoRelease(void)
105 OFFLOAD_DEBUG_TRACE(3, "%s\n", __func__);
106 CheckResult("myoRelease", myoRelease());
109 extern "C" void __intel_cilk_for_32_offload_wrapper(void *args_)
111 OFFLOAD_DEBUG_TRACE(3, "%s\n", __func__);
113 struct S {
114 void *M1;
115 unsigned int M2;
116 unsigned int M3;
117 char closure[];
118 } *args = (struct S*) args_;
120 __cilkrts_cilk_for_32(args->M1, args->closure, args->M2, args->M3);
123 extern "C" void __intel_cilk_for_64_offload_wrapper(void *args_)
125 OFFLOAD_DEBUG_TRACE(3, "%s\n", __func__);
127 struct S {
128 void *M1;
129 uint64_t M2;
130 uint64_t M3;
131 char closure[];
132 } *args = (struct S*) args_;
134 __cilkrts_cilk_for_64(args->M1, args->closure, args->M2, args->M3);
137 static void __offload_myo_once_init(void)
139 CheckResult("myoiRemoteFuncRegister",
140 myoiRemoteFuncRegister(
141 (MyoiRemoteFuncType) __intel_cilk_for_32_offload_wrapper,
142 "__intel_cilk_for_32_offload"));
143 CheckResult("myoiRemoteFuncRegister",
144 myoiRemoteFuncRegister(
145 (MyoiRemoteFuncType) __intel_cilk_for_64_offload_wrapper,
146 "__intel_cilk_for_64_offload"));
149 extern "C" void __offload_myoRegisterTables(
150 SharedTableEntry *shared_table,
151 FptrTableEntry *fptr_table
154 OFFLOAD_DEBUG_TRACE(3, "%s\n", __func__);
156 // one time registration of Intel(R) Cilk(TM) language entries
157 static pthread_once_t once_control = PTHREAD_ONCE_INIT;
158 pthread_once(&once_control, __offload_myo_once_init);
160 // register module's tables
161 if (shared_table->varName == 0 && fptr_table->funcName == 0) {
162 return;
165 __offload_myo_shared_table_register(shared_table);
166 __offload_myo_fptr_table_register(fptr_table);
169 extern "C" void* _Offload_shared_malloc(size_t size)
171 OFFLOAD_DEBUG_TRACE(3, "%s(%lld)\n", __func__, size);
172 return myoSharedMalloc(size);
175 extern "C" void _Offload_shared_free(void *ptr)
177 OFFLOAD_DEBUG_TRACE(3, "%s(%p)\n", __func__, ptr);
178 myoSharedFree(ptr);
181 extern "C" void* _Offload_shared_aligned_malloc(size_t size, size_t align)
183 OFFLOAD_DEBUG_TRACE(3, "%s(%lld, %lld)\n", __func__, size, align);
184 return myoSharedAlignedMalloc(size, align);
187 extern "C" void _Offload_shared_aligned_free(void *ptr)
189 OFFLOAD_DEBUG_TRACE(3, "%s(%p)\n", __func__, ptr);
190 myoSharedAlignedFree(ptr);
193 // temporary workaround for blocking behavior of myoiLibInit/Fini calls
194 extern "C" void __offload_myoLibInit()
196 OFFLOAD_DEBUG_TRACE(3, "%s()\n", __func__);
197 CheckResult("myoiLibInit", myoiLibInit(0, 0));
200 extern "C" void __offload_myoLibFini()
202 OFFLOAD_DEBUG_TRACE(3, "%s()\n", __func__);
203 myoiLibFini();