wlroots/include/wlr/backend/session.h

108 lines
2.5 KiB
C
Raw Normal View History

#ifndef WLR_BACKEND_SESSION_H
#define WLR_BACKEND_SESSION_H
2017-05-03 02:11:22 +00:00
2017-08-26 02:02:04 +00:00
#include <libudev.h>
2018-02-12 20:29:23 +00:00
#include <stdbool.h>
2017-05-14 01:07:34 +00:00
#include <sys/types.h>
#include <wayland-server-core.h>
2017-05-13 11:56:40 +00:00
struct libseat;
2017-05-13 13:12:47 +00:00
struct wlr_device {
int fd;
int device_id;
dev_t dev;
struct wl_list link;
struct {
struct wl_signal change;
struct wl_signal remove;
} events;
};
2017-05-13 13:12:47 +00:00
struct wlr_session {
2017-07-09 11:02:41 +00:00
/*
* Signal for when the session becomes active/inactive.
* It's called when we swap virtual terminal.
*/
2017-07-09 05:53:13 +00:00
bool active;
2018-06-14 08:46:16 +00:00
/*
* 0 if virtual terminals are not supported
* i.e. seat != "seat0"
*/
2017-07-09 05:53:13 +00:00
unsigned vtnr;
2018-06-14 08:46:16 +00:00
char seat[256];
2017-08-26 02:02:04 +00:00
struct udev *udev;
struct udev_monitor *mon;
struct wl_event_source *udev_event;
struct libseat *seat_handle;
struct wl_event_source *libseat_event;
2017-08-26 02:02:04 +00:00
struct wl_list devices;
struct wl_display *display;
struct wl_listener display_destroy;
struct {
struct wl_signal active;
struct wl_signal add_drm_card; // struct wlr_session_add_event
struct wl_signal destroy;
} events;
2017-05-13 13:12:47 +00:00
};
2017-05-03 02:11:22 +00:00
struct wlr_session_add_event {
const char *path;
};
2017-07-09 11:02:41 +00:00
/*
* Opens a session, taking control of the current virtual terminal.
* This should not be called if another program is already in control
* of the terminal (Xorg, another Wayland compositor, etc.).
*
* If libseat support is not enabled, or if a standalone backend is to be used,
* then you must have CAP_SYS_ADMIN or be root. It is safe to drop privileges
* after this is called.
2017-07-09 11:02:41 +00:00
*
* Returns NULL on error.
*/
struct wlr_session *wlr_session_create(struct wl_display *disp);
2017-07-09 11:02:41 +00:00
/*
* Closes a previously opened session and restores the virtual terminal.
* You should call wlr_session_close_file on each files you opened
* with wlr_session_open_file before you call this.
*/
void wlr_session_destroy(struct wlr_session *session);
2017-07-09 11:02:41 +00:00
/*
* Opens the file at path.
* This can only be used to open DRM or evdev (input) devices.
*
* When the session becomes inactive:
* - DRM files lose their DRM master status
* - evdev files become invalid and should be closed
*
* Returns -errno on error.
*/
struct wlr_device *wlr_session_open_file(struct wlr_session *session,
const char *path);
2017-07-09 11:02:41 +00:00
/*
* Closes a file previously opened with wlr_session_open_file.
*/
void wlr_session_close_file(struct wlr_session *session,
struct wlr_device *device);
2017-07-09 11:02:41 +00:00
/*
* Changes the virtual terminal.
*/
2017-07-09 05:53:13 +00:00
bool wlr_session_change_vt(struct wlr_session *session, unsigned vt);
2017-05-03 02:11:22 +00:00
ssize_t wlr_session_find_gpus(struct wlr_session *session,
size_t ret_len, struct wlr_device **ret);
2017-08-26 02:02:04 +00:00
2017-05-03 02:11:22 +00:00
#endif