summaryrefslogtreecommitdiff
path: root/lib/mesa/src/gallium/winsys/lima/drm/lima_drm_winsys.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/mesa/src/gallium/winsys/lima/drm/lima_drm_winsys.c')
-rw-r--r--lib/mesa/src/gallium/winsys/lima/drm/lima_drm_winsys.c75
1 files changed, 6 insertions, 69 deletions
diff --git a/lib/mesa/src/gallium/winsys/lima/drm/lima_drm_winsys.c b/lib/mesa/src/gallium/winsys/lima/drm/lima_drm_winsys.c
index 9c8cd933e..589f15014 100644
--- a/lib/mesa/src/gallium/winsys/lima/drm/lima_drm_winsys.c
+++ b/lib/mesa/src/gallium/winsys/lima/drm/lima_drm_winsys.c
@@ -21,87 +21,24 @@
* IN THE SOFTWARE.
*/
-#include <unistd.h>
-#include <fcntl.h>
-#include <sys/stat.h>
-
-#include "c11/threads.h"
#include "util/os_file.h"
-#include "util/u_hash_table.h"
-#include "util/u_pointer.h"
+#include "util/u_screen.h"
#include "renderonly/renderonly.h"
#include "lima_drm_public.h"
#include "lima/lima_screen.h"
-static struct hash_table *fd_tab = NULL;
-static mtx_t lima_screen_mutex = _MTX_INITIALIZER_NP;
-
-static void
-lima_drm_screen_destroy(struct pipe_screen *pscreen)
-{
- struct lima_screen *screen = lima_screen(pscreen);
- boolean destroy;
- int fd = screen->fd;
-
- mtx_lock(&lima_screen_mutex);
- destroy = --screen->refcnt == 0;
- if (destroy) {
- _mesa_hash_table_remove_key(fd_tab, intptr_to_pointer(fd));
-
- if (!fd_tab->entries) {
- _mesa_hash_table_destroy(fd_tab, NULL);
- fd_tab = NULL;
- }
- }
- mtx_unlock(&lima_screen_mutex);
-
- if (destroy) {
- pscreen->destroy = screen->winsys_priv;
- pscreen->destroy(pscreen);
- close(fd);
- }
-}
-
struct pipe_screen *
lima_drm_screen_create(int fd)
{
- struct pipe_screen *pscreen = NULL;
-
- mtx_lock(&lima_screen_mutex);
- if (!fd_tab) {
- fd_tab = util_hash_table_create_fd_keys();
- if (!fd_tab)
- goto unlock;
- }
-
- pscreen = util_hash_table_get(fd_tab, intptr_to_pointer(fd));
- if (pscreen) {
- lima_screen(pscreen)->refcnt++;
- } else {
- int dup_fd = os_dupfd_cloexec(fd);
-
- pscreen = lima_screen_create(dup_fd, NULL);
- if (pscreen) {
- _mesa_hash_table_insert(fd_tab, intptr_to_pointer(dup_fd), pscreen);
-
- /* Bit of a hack, to avoid circular linkage dependency,
- * ie. pipe driver having to call in to winsys, we
- * override the pipe drivers screen->destroy():
- */
- lima_screen(pscreen)->winsys_priv = pscreen->destroy;
- pscreen->destroy = lima_drm_screen_destroy;
- }
- }
-
-unlock:
- mtx_unlock(&lima_screen_mutex);
- return pscreen;
+ return u_pipe_screen_lookup_or_create(os_dupfd_cloexec(fd), NULL,
+ NULL, lima_screen_create);
}
struct pipe_screen *
-lima_drm_screen_create_renderonly(struct renderonly *ro)
+lima_drm_screen_create_renderonly(int fd, struct renderonly *ro,
+ const struct pipe_screen_config *config)
{
- return lima_screen_create(os_dupfd_cloexec(ro->gpu_fd), ro);
+ return lima_screen_create(os_dupfd_cloexec(fd), config, ro);
}