• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright © 2016 Benoit Gschwind
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining
5  * a copy of this software and associated documentation files (the
6  * "Software"), to deal in the Software without restriction, including
7  * without limitation the rights to use, copy, modify, merge, publish,
8  * distribute, sublicense, and/or sell copies of the Software, and to
9  * permit persons to whom the Software is furnished to do so, subject to
10  * the following conditions:
11  *
12  * The above copyright notice and this permission notice (including the
13  * next paragraph) shall be included in all copies or substantial
14  * portions of the Software.
15  *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19  * NONINFRINGEMENT.  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
20  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
21  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23  * SOFTWARE.
24  */
25 
26 #ifndef WESTON_COMPOSITOR_FBDEV_H
27 #define WESTON_COMPOSITOR_FBDEV_H
28 
29 #ifdef  __cplusplus
30 extern "C" {
31 #endif
32 
33 #include <stdint.h>
34 
35 #include <libweston/libweston.h>
36 
37 #define WESTON_FBDEV_BACKEND_CONFIG_VERSION 2
38 
39 struct libinput_device;
40 
41 struct weston_fbdev_backend_config {
42 	struct weston_backend_config base;
43 
44 	int tty;
45 	char *device;
46 
47 	/** Callback used to configure input devices.
48 	 *
49 	 * This function will be called by the backend when a new input device
50 	 * needs to be configured.
51 	 * If NULL the device will use the default configuration.
52 	 */
53 	void (*configure_device)(struct weston_compositor *compositor,
54 				 struct libinput_device *device);
55 
56 	/** The seat to be used for input and output.
57 	 *
58 	 * If seat_id is NULL, the seat is taken from XDG_SEAT environment
59 	 * variable. If neither is set, "seat0" is used. The backend will
60 	 * take ownership of the seat_id pointer and will free it on
61 	 * backend destruction.
62 	 */
63 	char *seat_id;
64 };
65 
66 #ifdef  __cplusplus
67 }
68 #endif
69 
70 #endif /* WESTON_COMPOSITOR_FBDEV_H */
71