4 * Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved.
8 * Nikita Kalyazin <n.kalyazin@samsung.com>
9 * Anastasia Lyupa <a.lyupa@samsung.com>
11 * This library is free software; you can redistribute it and/or modify it under
12 * the terms of the GNU Lesser General Public License as published by the
13 * Free Software Foundation; either version 2.1 of the License, or (at your option)
16 * This library is distributed in the hope that it will be useful, but WITHOUT ANY
17 * WARRANTY; without even the implied warranty of MERCHANTABILITY or
18 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
19 * License for more details.
21 * You should have received a copy of the GNU Lesser General Public License
22 * along with this library; if not, write to the Free Software Foundation, Inc., 51
23 * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
26 * - Samsung RnD Institute Russia
30 #ifndef __BIN_PROTO_H__
31 #define __BIN_PROTO_H__
42 #include <sys/types.h>
46 #include <sys/types.h>
48 #include <sys/syscall.h>
52 #include <sys/socket.h>
54 #include "api_id_mapping.h"
56 #define MSG_PROBE_MEMORY 0x3001
57 #define MSG_PROBE_UICONTROL 0x3002
58 #define MSG_PROBE_UIEVENT 0x3003
59 #define MSG_PROBE_RESOURCE 0x3004
60 #define MSG_PROBE_LIFECYCLE 0x3005
61 #define MSG_PROBE_SCREENSHOT 0x3006
62 #define MSG_PROBE_SCENE 0x3007
63 #define MSG_PROBE_THREAD 0x3008
64 #define MSG_PROBE_CUSTOM 0x3009
65 #define MSG_PROBE_SYNC 0x3010
67 // TODO: remove this copy-paste
68 #define CALLER_ADDRESS \
69 ((void*) __builtin_extract_return_addr(__builtin_return_address(0)))
74 static inline char *pack_int32(char *to, uint32_t val)
76 *(uint32_t *)to = val;
77 return to + sizeof(uint32_t);
80 static inline char *pack_int64(char *to, uint64_t val)
82 *(uint64_t *)to = val;
83 return to + sizeof(uint64_t);
86 static inline char *pack_string(char *to, const char *str)
88 size_t len = strlen(str) + 1;
89 strncpy(to, str, len);
93 static inline char *pack_double(char *to, double val)
96 return to + sizeof(double);
99 static inline char *pack_timestamp(char *to)
103 gettimeofday(&tv, NULL);
104 to = pack_int32(to, tv.tv_sec);
105 to = pack_int32(to, tv.tv_usec * 1000);
110 static inline char *pack_args(char *to, const char *fmt, ...)
113 uint32_t num = strlen(fmt);
120 memcpy(to, &num, sizeof(num));
134 for (t = fmt; *t != '\0'; t++) {
137 c = (uint8_t)va_arg(args, uint32_t);
139 memcpy(to, &c, sizeof(c));
143 d = va_arg(args, uint32_t);
145 memcpy(to, &d, sizeof(d));
149 x = (uint64_t)va_arg(args, uint64_t);
151 memcpy(to, &x, sizeof(x));
155 p = (uintptr_t)va_arg(args, uint64_t);
157 memcpy(to, &p, sizeof(p));
161 f = (float)va_arg(args, double);
163 memcpy(to, &f, sizeof(f));
167 w = va_arg(args, double);
169 memcpy(to, &w, sizeof(w));
173 s = va_arg(args, char *);
190 #define RET_PTR ret_p
191 #define PACK_INT32(val) \
192 BUF_PTR = pack_int32(BUF_PTR, val);
193 #define PACK_INT64(val) \
194 BUF_PTR = pack_int64(BUF_PTR, val);
195 #define PACK_STRING(str) \
196 BUF_PTR = pack_string(BUF_PTR, str);
198 #define PACK_COMMON_BEGIN(msg_id, api_id, fmt, ...) \
200 BUF_PTR = pack_int32(BUF_PTR, msg_id); \
201 BUF_PTR = pack_int32(BUF_PTR, 0); \
202 BUF_PTR = pack_timestamp(BUF_PTR); \
203 BUF_PTR = pack_int32(BUF_PTR, 0); \
204 BUF_PTR = pack_int32(BUF_PTR, api_id); \
205 BUF_PTR = pack_int32(BUF_PTR, getpid()); \
206 BUF_PTR = pack_int32(BUF_PTR, syscall(__NR_gettid)); \
207 BUF_PTR = pack_args(BUF_PTR, fmt, __VA_ARGS__); \
211 #define PACK_COMMON_END(ret, errn, intern_call) \
213 BUF_PTR = pack_int64(BUF_PTR, (uintptr_t)(ret)); \
214 BUF_PTR = pack_int32(BUF_PTR, (uint32_t)errn); \
215 BUF_PTR = pack_int32(BUF_PTR, (uint32_t)intern_call); \
216 BUF_PTR = pack_int64(BUF_PTR, (uintptr_t)CALLER_ADDRESS); \
217 BUF_PTR = pack_int32(BUF_PTR, 0); \
218 BUF_PTR = pack_int32(BUF_PTR, 0); \
221 #define PACK_RETURN_END(ret) \
222 RET_PTR = pack_int64(RET_PTR, (uintptr_t)(ret));
224 #define PACK_MEMORY(size, memory_api_type, addr) \
226 BUF_PTR = pack_int64(BUF_PTR, size); \
227 BUF_PTR = pack_int32(BUF_PTR, memory_api_type); \
228 BUF_PTR = pack_int64(BUF_PTR, (uintptr_t)addr); \
231 #define PACK_UICONTROL(control) \
233 if (unlikely(control == NULL)) { \
234 BUF_PTR = pack_string(BUF_PTR, ""); \
235 BUF_PTR = pack_string(BUF_PTR, ""); \
236 BUF_PTR = pack_int64(BUF_PTR, 0); \
238 char *type = NULL, *name = NULL; \
239 if (find_object_hash((void*)(control), \
240 &type, &name) == 1) { \
241 BUF_PTR = pack_string(BUF_PTR, type); \
242 BUF_PTR = pack_string(BUF_PTR, name); \
244 BUF_PTR = pack_string(BUF_PTR, ""); \
245 BUF_PTR = pack_string(BUF_PTR, ""); \
247 BUF_PTR = pack_int64(BUF_PTR, (uintptr_t)(control)); \
251 #define PACK_UIEVENT(event_type, detail_type, x, y, info1, info2) \
253 BUF_PTR = pack_int32(BUF_PTR, event_type); \
254 BUF_PTR = pack_int32(BUF_PTR, detail_type); \
255 BUF_PTR = pack_int32(BUF_PTR, x); \
256 BUF_PTR = pack_int32(BUF_PTR, y); \
257 BUF_PTR = pack_string(BUF_PTR, info1); \
258 BUF_PTR = pack_int32(BUF_PTR, info2); \
261 #define PACK_RESOURCE(size, fd_value, fd_type, fd_api_type, file_size, \
264 BUF_PTR = pack_int64(BUF_PTR, size); \
265 BUF_PTR = pack_int64(BUF_PTR, fd_value); \
266 BUF_PTR = pack_int32(BUF_PTR, fd_type); \
267 BUF_PTR = pack_int32(BUF_PTR, fd_api_type); \
268 BUF_PTR = pack_int64(BUF_PTR, file_size); \
269 BUF_PTR = pack_string(BUF_PTR, file_path); \
272 #define PACK_SCREENSHOT(image_file_path, orientation) \
274 BUF_PTR = pack_string(BUF_PTR, image_file_path); \
275 BUF_PTR = pack_int32(BUF_PTR, orientation); \
278 #define PACK_SCENE(scene_name, formid, pform, panelid, ppanel, transition, user) \
280 BUF_PTR = pack_string(BUF_PTR, scene_name); \
281 if (unlikely(pform == NULL)) { \
282 BUF_PTR = pack_string(BUF_PTR, ""); \
283 BUF_PTR = pack_int64(BUF_PTR, 0); \
285 char *type = NULL, *name = NULL; \
286 if (find_object_hash((void*)(pform), &type, &name) == 1) { \
287 BUF_PTR = pack_string(BUF_PTR, name); \
289 BUF_PTR = pack_string(BUF_PTR, ""); \
291 BUF_PTR = pack_int64(BUF_PTR, (uintptr_t)pform); \
293 if (unlikely(ppanel == NULL)) { \
294 BUF_PTR = pack_string(BUF_PTR, ""); \
295 BUF_PTR = pack_int64(BUF_PTR, 0); \
297 char *type = NULL, *name = NULL; \
298 if (find_object_hash((void*)(ppanel), &type, &name) == 1) { \
299 BUF_PTR = pack_string(BUF_PTR, name); \
301 BUF_PTR = pack_string(BUF_PTR, ""); \
303 BUF_PTR = pack_int64(BUF_PTR, (uintptr_t)(ppanel)); \
305 BUF_PTR = pack_int64(BUF_PTR, transition); \
306 BUF_PTR = pack_int64(BUF_PTR, user); \
309 #define PACK_THREAD(thread_id, thread_type, api_type) \
311 BUF_PTR = pack_int64(BUF_PTR, thread_id); \
312 BUF_PTR = pack_int32(BUF_PTR, thread_type); \
313 BUF_PTR = pack_int32(BUF_PTR, api_type); \
316 #define PACK_CUSTOM(handle, type, name, color, value) \
318 BUF_PTR = pack_int32(BUF_PTR, handle); \
319 BUF_PTR = pack_int32(BUF_PTR, type); \
320 BUF_PTR = pack_string(BUF_PTR, name); \
321 BUF_PTR = pack_int32(BUF_PTR, color); \
322 BUF_PTR = pack_double(BUF_PTR, value); \
325 #define PACK_SYNC(sync_val, sync_type, api_type) \
327 BUF_PTR = pack_int64(BUF_PTR, (uintptr_t)sync_val); \
328 BUF_PTR = pack_int32(BUF_PTR, sync_type); \
329 BUF_PTR = pack_int32(BUF_PTR, api_type); \
332 #define LOCAL_BUF_SIZE 1024
333 #define PREPARE_LOCAL_BUF() \
334 char buf[LOCAL_BUF_SIZE]; \
338 #define MSG_LEN_OFFSET 16
339 #define MSG_HDR_LEN 20
340 #define FLUSH_LOCAL_BUF() \
341 *(uint32_t *)(buf + MSG_LEN_OFFSET) = (p - buf) - MSG_HDR_LEN; \
342 send(gTraceInfo.socket.daemonSock, buf, (p - buf), 0);
344 // =========================== post block macro ===========================
346 #define POST_PACK_PROBEBLOCK_BEGIN() \
348 if(postBlockBegin(blockresult)) {
350 #define POST_PACK_PROBEBLOCK_END() \
353 errno = (newerrno != 0) ? newerrno : olderrno
355 /* int main(int argc, char **argv) */
357 /* char buf[1024]; */
360 /* p = PACK_COMMON_BEGIN(p, 42, "cdxpfws", 'a', 10, (uint64_t)80, */
361 /* (uint64_t)0, 0.19, 0.33, "hello!"); */
362 /* p = PACK_COMMON_END(p, 0); */
364 /* int fd = creat("out.bin", 0644); */
365 /* if (fd == -1) { */
366 /* printf("error\n"); */
370 /* write(fd, buf, p - buf); */
376 #endif /* __BIN_PROTO_H__ */