annotate liboffloadmic/runtime/offload_common.cpp @ 136:4627f235cf2a

fix c-next example
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 08 Nov 2018 14:11:56 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /*
kono
parents:
diff changeset
2 Copyright (c) 2014-2016 Intel Corporation. All Rights Reserved.
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 Redistribution and use in source and binary forms, with or without
kono
parents:
diff changeset
5 modification, are permitted provided that the following conditions
kono
parents:
diff changeset
6 are met:
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 * Redistributions of source code must retain the above copyright
kono
parents:
diff changeset
9 notice, this list of conditions and the following disclaimer.
kono
parents:
diff changeset
10 * Redistributions in binary form must reproduce the above copyright
kono
parents:
diff changeset
11 notice, this list of conditions and the following disclaimer in the
kono
parents:
diff changeset
12 documentation and/or other materials provided with the distribution.
kono
parents:
diff changeset
13 * Neither the name of Intel Corporation nor the names of its
kono
parents:
diff changeset
14 contributors may be used to endorse or promote products derived
kono
parents:
diff changeset
15 from this software without specific prior written permission.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
kono
parents:
diff changeset
18 "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
kono
parents:
diff changeset
19 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
kono
parents:
diff changeset
20 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
kono
parents:
diff changeset
21 HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
kono
parents:
diff changeset
22 SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
kono
parents:
diff changeset
23 LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
kono
parents:
diff changeset
24 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
kono
parents:
diff changeset
25 THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
kono
parents:
diff changeset
26 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
kono
parents:
diff changeset
27 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
kono
parents:
diff changeset
28 */
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 #if defined(LINUX) || defined(FREEBSD)
kono
parents:
diff changeset
32 #include <mm_malloc.h>
kono
parents:
diff changeset
33 #endif
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 #include "offload_common.h"
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 // The debug routines
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 #if OFFLOAD_DEBUG > 0
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 void __dump_bytes(
kono
parents:
diff changeset
42 int trace_level,
kono
parents:
diff changeset
43 const void *data,
kono
parents:
diff changeset
44 int len
kono
parents:
diff changeset
45 )
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 if (console_enabled > trace_level) {
kono
parents:
diff changeset
48 const uint8_t *arr = (const uint8_t*) data;
kono
parents:
diff changeset
49 char buffer[4096];
kono
parents:
diff changeset
50 char *bufferp;
kono
parents:
diff changeset
51 int count = 0;
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 bufferp = buffer;
kono
parents:
diff changeset
54 while (len--) {
kono
parents:
diff changeset
55 sprintf(bufferp, "%02x", *arr++);
kono
parents:
diff changeset
56 bufferp += 2;
kono
parents:
diff changeset
57 count++;
kono
parents:
diff changeset
58 if ((count&3) == 0) {
kono
parents:
diff changeset
59 sprintf(bufferp, " ");
kono
parents:
diff changeset
60 bufferp++;
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62 if ((count&63) == 0) {
kono
parents:
diff changeset
63 OFFLOAD_DEBUG_TRACE(trace_level, "%s\n", buffer);
kono
parents:
diff changeset
64 bufferp = buffer;
kono
parents:
diff changeset
65 count = 0;
kono
parents:
diff changeset
66 }
kono
parents:
diff changeset
67 }
kono
parents:
diff changeset
68 if (count) {
kono
parents:
diff changeset
69 OFFLOAD_DEBUG_TRACE(trace_level, "%s\n", buffer);
kono
parents:
diff changeset
70 }
kono
parents:
diff changeset
71 }
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73 #endif // OFFLOAD_DEBUG
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 // The Marshaller and associated routines
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 void Marshaller::send_data(
kono
parents:
diff changeset
78 const void *data,
kono
parents:
diff changeset
79 int64_t length
kono
parents:
diff changeset
80 )
kono
parents:
diff changeset
81 {
kono
parents:
diff changeset
82 OFFLOAD_DEBUG_TRACE(2, "send_data(%p, %lld)\n",
kono
parents:
diff changeset
83 data, length);
kono
parents:
diff changeset
84 memcpy(buffer_ptr, data, (size_t)length);
kono
parents:
diff changeset
85 buffer_ptr += length;
kono
parents:
diff changeset
86 tfr_size += length;
kono
parents:
diff changeset
87 }
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 void Marshaller::receive_data(
kono
parents:
diff changeset
90 void *data,
kono
parents:
diff changeset
91 int64_t length
kono
parents:
diff changeset
92 )
kono
parents:
diff changeset
93 {
kono
parents:
diff changeset
94 OFFLOAD_DEBUG_TRACE(2, "receive_data(%p, %lld)\n",
kono
parents:
diff changeset
95 data, length);
kono
parents:
diff changeset
96 memcpy(data, buffer_ptr, (size_t)length);
kono
parents:
diff changeset
97 buffer_ptr += length;
kono
parents:
diff changeset
98 tfr_size += length;
kono
parents:
diff changeset
99 }
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 // Send function pointer
kono
parents:
diff changeset
102 void Marshaller::send_func_ptr(
kono
parents:
diff changeset
103 const void* data
kono
parents:
diff changeset
104 )
kono
parents:
diff changeset
105 {
kono
parents:
diff changeset
106 const char* name;
kono
parents:
diff changeset
107 size_t length;
kono
parents:
diff changeset
108
kono
parents:
diff changeset
109 if (data != 0) {
kono
parents:
diff changeset
110 name = __offload_funcs.find_name(data);
kono
parents:
diff changeset
111 if (name == 0) {
kono
parents:
diff changeset
112 #if OFFLOAD_DEBUG > 0
kono
parents:
diff changeset
113 if (console_enabled > 2) {
kono
parents:
diff changeset
114 __offload_funcs.dump();
kono
parents:
diff changeset
115 }
kono
parents:
diff changeset
116 #endif // OFFLOAD_DEBUG > 0
kono
parents:
diff changeset
117
kono
parents:
diff changeset
118 LIBOFFLOAD_ERROR(c_send_func_ptr, data);
kono
parents:
diff changeset
119 exit(1);
kono
parents:
diff changeset
120 }
kono
parents:
diff changeset
121 length = strlen(name) + 1;
kono
parents:
diff changeset
122 }
kono
parents:
diff changeset
123 else {
kono
parents:
diff changeset
124 name = "";
kono
parents:
diff changeset
125 length = 1;
kono
parents:
diff changeset
126 }
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 memcpy(buffer_ptr, name, length);
kono
parents:
diff changeset
129 buffer_ptr += length;
kono
parents:
diff changeset
130 tfr_size += length;
kono
parents:
diff changeset
131 }
kono
parents:
diff changeset
132
kono
parents:
diff changeset
133 // Receive function pointer
kono
parents:
diff changeset
134 void Marshaller::receive_func_ptr(
kono
parents:
diff changeset
135 const void** data
kono
parents:
diff changeset
136 )
kono
parents:
diff changeset
137 {
kono
parents:
diff changeset
138 const char* name;
kono
parents:
diff changeset
139 size_t length;
kono
parents:
diff changeset
140
kono
parents:
diff changeset
141 name = (const char*) buffer_ptr;
kono
parents:
diff changeset
142 if (name[0] != '\0') {
kono
parents:
diff changeset
143 *data = __offload_funcs.find_addr(name);
kono
parents:
diff changeset
144 if (*data == 0) {
kono
parents:
diff changeset
145 #if OFFLOAD_DEBUG > 0
kono
parents:
diff changeset
146 if (console_enabled > 2) {
kono
parents:
diff changeset
147 __offload_funcs.dump();
kono
parents:
diff changeset
148 }
kono
parents:
diff changeset
149 #endif // OFFLOAD_DEBUG > 0
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 LIBOFFLOAD_ERROR(c_receive_func_ptr, name);
kono
parents:
diff changeset
152 exit(1);
kono
parents:
diff changeset
153 }
kono
parents:
diff changeset
154 length = strlen(name) + 1;
kono
parents:
diff changeset
155 }
kono
parents:
diff changeset
156 else {
kono
parents:
diff changeset
157 *data = 0;
kono
parents:
diff changeset
158 length = 1;
kono
parents:
diff changeset
159 }
kono
parents:
diff changeset
160
kono
parents:
diff changeset
161 buffer_ptr += length;
kono
parents:
diff changeset
162 tfr_size += length;
kono
parents:
diff changeset
163 }
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 // End of the Marshaller and associated routines
kono
parents:
diff changeset
166
kono
parents:
diff changeset
167 extern void *OFFLOAD_MALLOC(
kono
parents:
diff changeset
168 size_t size,
kono
parents:
diff changeset
169 size_t align
kono
parents:
diff changeset
170 )
kono
parents:
diff changeset
171 {
kono
parents:
diff changeset
172 void *ptr;
kono
parents:
diff changeset
173 int err;
kono
parents:
diff changeset
174
kono
parents:
diff changeset
175 OFFLOAD_DEBUG_TRACE(2, "%s(%lld, %lld)\n", __func__, size, align);
kono
parents:
diff changeset
176
kono
parents:
diff changeset
177 if (align < sizeof(void*)) {
kono
parents:
diff changeset
178 align = sizeof(void*);
kono
parents:
diff changeset
179 }
kono
parents:
diff changeset
180
kono
parents:
diff changeset
181 ptr = _mm_malloc(size, align);
kono
parents:
diff changeset
182 if (ptr == NULL) {
kono
parents:
diff changeset
183 LIBOFFLOAD_ERROR(c_offload_malloc, size, align);
kono
parents:
diff changeset
184 exit(1);
kono
parents:
diff changeset
185 }
kono
parents:
diff changeset
186
kono
parents:
diff changeset
187 OFFLOAD_DEBUG_TRACE(2, "%s returned %p\n", __func__, ptr);
kono
parents:
diff changeset
188
kono
parents:
diff changeset
189 return ptr;
kono
parents:
diff changeset
190 }