Added few more stubs so that control reaches to DestroyDevice().
[mesa.git] / src / egl / wayland / wayland-drm / wayland-drm.h
index 72575d81cca6b1c917ca83b70c69171ab5023fca..8b7fd3b0b64092fe3aec05c9cfeb5302ce70e6ca 100644 (file)
@@ -3,7 +3,34 @@
 
 #include <wayland-server.h>
 
-struct wl_drm;
+struct wl_display;
+struct wl_resource;
+struct wl_drm_buffer;
+
+struct wayland_drm_callbacks {
+       int (*authenticate)(void *user_data, uint32_t id);
+
+       void (*reference_buffer)(void *user_data, uint32_t name, int fd,
+                                 struct wl_drm_buffer *buffer);
+
+       void (*release_buffer)(void *user_data, struct wl_drm_buffer *buffer);
+
+       bool (*is_format_supported)(void *user_data, uint32_t format);
+};
+
+
+struct wl_drm {
+       struct wl_display *display;
+       struct wl_global *wl_drm_global;
+
+       void *user_data;
+       char *device_name;
+       uint32_t flags;
+
+       struct wayland_drm_callbacks callbacks;
+
+       struct wl_buffer_interface buffer_interface;
+};
 
 struct wl_drm_buffer {
        struct wl_resource *resource;
@@ -16,32 +43,27 @@ struct wl_drm_buffer {
        void *driver_buffer;
 };
 
-struct wayland_drm_callbacks {
-       int (*authenticate)(void *user_data, uint32_t id);
-
-        void (*reference_buffer)(void *user_data, uint32_t name, int fd,
-                                 struct wl_drm_buffer *buffer);
-
-       void (*release_buffer)(void *user_data, struct wl_drm_buffer *buffer);
-};
-
 enum { WAYLAND_DRM_PRIME = 0x01 };
 
-struct wl_drm_buffer *
-wayland_drm_buffer_get(struct wl_drm *drm, struct wl_resource *resource);
+static inline struct wl_drm_buffer *
+wayland_drm_buffer_get(struct wl_drm *drm, struct wl_resource *resource)
+{
+       if (resource == NULL)
+               return NULL;
+
+       if (wl_resource_instance_of(resource, &wl_buffer_interface,
+                                   &drm->buffer_interface))
+               return wl_resource_get_user_data(resource);
+       else
+               return NULL;
+}
 
 struct wl_drm *
 wayland_drm_init(struct wl_display *display, char *device_name,
-                struct wayland_drm_callbacks *callbacks, void *user_data,
+                const struct wayland_drm_callbacks *callbacks, void *user_data,
                  uint32_t flags);
 
 void
 wayland_drm_uninit(struct wl_drm *drm);
 
-uint32_t
-wayland_drm_buffer_get_format(struct wl_drm_buffer *buffer);
-
-void *
-wayland_drm_buffer_get_buffer(struct wl_drm_buffer *buffer);
-
 #endif