1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
|
/*
* Copyright © 2019 Advanced Driver Information Technology GmbH
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice (including the
* next paragraph) shall be included in all copies or substantial
* portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
/*******************************************************************************
** **
** TARGET : linux **
** **
** PROJECT : waltham-receiver **
** **
** PURPOSE : Header file declare macros, extern functions, data types etc, **
** required to interface with waltham IPC library **
** **
*******************************************************************************/
#ifndef WTH_SERVER_WALTHAM_COMM_H_
#define WTH_SERVER_WALTHAM_COMM_H_
#include <stdio.h>
#include <stdbool.h>
#include <sys/epoll.h>
#include <errno.h>
#include <netinet/in.h>
#include <string.h>
#include <assert.h>
#include <getopt.h>
#include <unistd.h>
#include <GLES2/gl2.h>
#include <GLES2/gl2ext.h>
#include <EGL/egl.h>
#include <EGL/eglext.h>
#include "xdg-shell-client-protocol.h"
#include <wayland-egl.h>
#include <wayland-client.h>
#include <waltham-server.h>
#include <waltham-connection.h>
#define DEBUG 1
struct receiver;
struct client;
struct window;
/***** macros *******/
#define MAX_EPOLL_WATCHES 2
#ifndef container_of
#define container_of(ptr, type, member) ({ \
const __typeof__( ((type *)0)->member ) *__mptr = (ptr); \
(type *)( (char *)__mptr - offsetof(type,member) );})
#endif
#define wl_list_last_until_empty(pos, head, member) \
while (!wl_list_empty(head) && \
(pos = wl_container_of((head)->prev, pos, member), 1))
#ifndef ARRAY_LENGTH
#define ARRAY_LENGTH(a) (sizeof (a) / sizeof (a)[0])
#endif
#ifndef pr_fmt
# define pr_fmt(fmt) fmt
#endif
#define wth_error(fmt, ...) \
({ fprintf(stderr, pr_fmt(fmt), ## __VA_ARGS__); fflush(stderr); })
/****** incline functions *****/
static inline void *
zalloc(size_t size)
{
return calloc(1, size);
}
/***** Data types *****/
/* wthp_region protocol object */
struct region {
struct wthp_region *obj;
/* pixman_region32_t region; */
struct wl_list link; /* struct client::region_list */
};
/* wthp_compositor protocol object */
struct compositor {
struct wthp_compositor *obj;
struct client *client;
struct wl_list link; /* struct client::compositor_list */
};
/* wthp_surface protocol object */
struct surface {
struct wthp_surface *obj;
uint32_t ivi_id;
char *ivi_app_id;
struct ivisurface *ivisurf;
struct wthp_callback *cb;
struct window *shm_window;
struct wl_list link; /* struct client::surface_list */
};
/* wthp_ivi_surface protocol object */
struct ivisurface {
struct wthp_ivi_surface *obj;
struct wthp_callback *cb;
struct wl_list link; /* struct client::surface_list */
struct surface *surf;
};
/* wthp_ivi_application protocol object */
struct application {
struct wthp_ivi_application *obj;
struct client *client;
struct wl_list link; /* struct client::surface_list */
};
struct application_id {
struct wthp_ivi_app_id *obj;
struct client *client;
struct wl_list link; /* struct client::surface_list */
};
/* wthp_registry protocol object */
struct registry {
struct wthp_registry *obj;
struct client *client;
struct wl_list link; /* struct client::registry_list */
};
/* epoll structure */
struct watch {
struct receiver *receiver;
int fd;
void (*cb)(struct watch *w, uint32_t events);
};
struct client {
struct wl_list link; /* struct receiver::client_list */
struct receiver *receiver;
struct wth_connection *connection;
struct watch conn_watch;
/* client object lists for clean-up on disconnection */
struct wl_list registry_list; /* struct registry::link */
struct wl_list compositor_list; /* struct compositor::link */
struct wl_list region_list; /* struct region::link */
struct wl_list surface_list; /* struct surface::link */
struct wl_list buffer_list; /* struct buffer::link */
struct wl_list seat_list; /* struct seat::link */
struct wl_list pointer_list; /* struct pointer::link */
struct wl_list touch_list; /* struct touch::link */
};
/* receiver structure */
struct receiver {
int listen_fd;
struct watch listen_watch;
bool running;
int epoll_fd;
struct wl_list client_list; /* struct client::link */
};
struct shm_buffer {
struct wl_buffer *buffer;
void *shm_data;
int busy;
};
struct display {
struct wl_display *display;
struct wl_registry *registry;
struct wl_compositor *compositor;
struct wl_shm *shm;
bool has_xrgb;
struct xdg_wm_base *wm_base;
struct wl_seat *seat;
struct wl_pointer *wl_pointer;
struct wl_keyboard *wl_keyboard;
struct wl_touch *wl_touch;
struct window *window;
struct {
EGLDisplay dpy;
EGLContext ctx;
EGLConfig conf;
PFNEGLCREATEIMAGEKHRPROC create_image;
PFNEGLDESTROYIMAGEKHRPROC destroy_image;
PFNGLEGLIMAGETARGETTEXTURE2DOESPROC image_texture_2d;
} egl;
struct {
GLuint vertex_shader;
GLuint fragment_shader;
GLuint program_object;
GLuint texture;
} gl;
};
struct window {
struct display *display;
struct {
GLuint rotation_uniform;
GLuint pos;
GLuint col;
} gl;
int width, height;
int x, y;
struct wl_surface *surface;
struct ivi_surface *ivi_surface;
struct shm_buffer buffers[2];
struct shm_buffer *prev_buffer;
struct wl_callback *callback;
uint32_t window_frames;
uint32_t window_benchmark_time;
int wait;
struct surface *receiver_surf;
int frame_sync;
struct xdg_surface *xdg_surface;
struct xdg_toplevel *xdg_toplevel;
const char *app_id;
bool wait_for_configure;
int maximized, fullscreen, opaque;
struct wl_egl_window *native;
EGLSurface egl_surface;
EGLImageKHR egl_img;
struct seat *receiver_seat;
struct pointer *receiver_pointer;
bool ready;
uint32_t id_ivisurf;
};
/**
* receiver_accept_client
*
* Accepts new waltham client connection and instantiates client structure
*
* @param names struct receiver *srv
* @param value socket connection info and client data
* @return none
*/
void receiver_accept_client(struct receiver *srv);
/**
* receiver_flush_clients
*
* write all the pending requests from the clients to socket
*
* @param names struct receiver *srv
* @param value socket connection info and client data
* @return none
*/
void receiver_flush_clients(struct receiver *srv);
/**
* client_destroy
*
* Destroy client connection
*
* @param names struct client *c
* @param value client data
* @return none
*/
void client_destroy(struct client *c);
void
client_post_out_of_memory(struct client *c);
int
wth_receiver_weston_main(struct window *window, const char *app_id, int port);
#endif
|