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