Add cynara checks for socket communication
[platform/core/appfw/notification-service.git] / service_common.h
1 /*
2  * Copyright (c) 2000 - 2015 Samsung Electronics Co., Ltd. All rights reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16 */
17 enum tcb_type {
18         TCB_CLIENT_TYPE_APP     = 0x00,
19         TCB_CLIENT_TYPE_SERVICE = 0x01,
20         TCB_CLIENT_TYPE_UNKNOWN = 0xff,
21 };
22
23 struct tcb;
24 struct service_context;
25 struct service_event_item;
26
27 extern int tcb_fd(struct tcb *tcb);
28 extern struct service_context *tcb_svc_ctx(struct tcb *tcb);
29 extern int tcb_client_type(struct tcb *tcb);
30 extern int tcb_client_type_set(struct tcb *tcb, enum tcb_type type);
31
32 extern struct service_context *service_common_create(const char *addr, int (*service_thread_main)(struct tcb *tcb, struct packet *packet, void *data), void *data);
33 extern int service_common_destroy(struct service_context *svc_ctx);
34
35 extern int service_common_multicast_packet(struct tcb *tcb, struct packet *packet, int type);
36 extern int service_common_unicast_packet(struct tcb *tcb, struct packet *packet);
37
38 extern struct service_event_item *service_common_add_timer(struct service_context *svc_ctx, double timer, int (*timer_cb)(struct service_context *svc_cx, void *data), void *data);
39 extern int service_common_del_timer(struct service_context *svc_ctx, struct service_event_item *item);
40
41 void print_cynara_error(int ret, char *msg);
42 int check_cynara(struct tcb *tcb);
43
44 #define CRITICAL_SECTION_BEGIN(handle) \
45 do { \
46         int ret; \
47         ret = pthread_mutex_lock(handle); \
48         if (ret != 0) \
49                 fprintf(stderr, "Failed to lock: %s\n", strerror(ret)); \
50 } while (0)
51
52 #define CRITICAL_SECTION_END(handle) \
53 do { \
54         int ret; \
55         ret = pthread_mutex_unlock(handle); \
56         if (ret != 0) \
57                 fprintf(stderr, "Failed to unlock: %s\n", strerror(ret)); \
58 } while (0)
59
60 #define CANCEL_SECTION_BEGIN() do { \
61         int ret; \
62         ret = pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL); \
63         if (ret != 0) \
64                 fprintf(stderr, "Unable to set cancelate state: %s\n", strerror(ret)); \
65 } while (0)
66
67 #define CANCEL_SECTION_END() do { \
68         int ret; \
69         ret = pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, NULL); \
70         if (ret != 0) \
71                 fprintf(stderr, "Unable to set cancelate state: %s\n", strerror(ret)); \
72 } while (0)
73
74 #define CLOSE_PIPE(p)   do { \
75         int status; \
76         status = close(p[PIPE_READ]); \
77         if (status < 0) \
78                 fprintf(stderr, "close: %s\n", strerror(errno)); \
79         status = close(p[PIPE_WRITE]); \
80         if (status < 0) \
81                 fprintf(stderr, "close: %s\n", strerror(errno)); \
82 } while (0)
83
84 #define PIPE_READ 0
85 #define PIPE_WRITE 1
86 #define PIPE_MAX 2
87
88 /* End of a file */