nouveau: Move bootstrap code to targets
authorJakob Bornecrantz <jakob@vmware.com>
Wed, 23 Jun 2010 21:03:28 +0000 (23:03 +0200)
committerJakob Bornecrantz <jakob@vmware.com>
Wed, 23 Jun 2010 21:15:07 +0000 (23:15 +0200)
Well sorta, at least I removed the drm_api dependancy and the
target can layer anything it wants to now.

src/gallium/targets/dri-nouveau/target.c
src/gallium/targets/egl-nouveau/target.c
src/gallium/targets/xorg-nouveau/nouveau_target.c
src/gallium/winsys/nouveau/drm/nouveau_drm_public.h [new file with mode: 0644]
src/gallium/winsys/nouveau/drm/nouveau_drm_winsys.c
src/gallium/winsys/nouveau/drm/nouveau_drm_winsys.h

index e16e86cd3d83c9c3e55978fb4b138a1fb71765f5..ca3ec53029a464c06d18e3ed53eb5574dd0511bb 100644 (file)
@@ -1,4 +1,17 @@
 
-#include "target-helpers/drm_api_compat.h"
+#include "state_tracker/drm_driver.h"
+#include "nouveau/drm/nouveau_drm_public.h"
 
-DRM_API_COMPAT_STRUCT("nouveau", "nouveau")
+static struct pipe_screen *
+create_screen(int fd)
+{
+   struct pipe_screen *screen;
+
+   screen = nouveau_drm_screen_create(fd);
+   if (!screen)
+      return NULL;
+
+   return screen;
+}
+
+DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
index 49545c63e114fe5d43da9783a0be28de371dacc2..7d0b141e5a27e597ae54f5d4b26560d9fc22b109 100644 (file)
@@ -1,7 +1,20 @@
 
-#include "target-helpers/drm_api_compat.h"
+#include "state_tracker/drm_driver.h"
+#include "nouveau/drm/nouveau_drm_public.h"
 
-DRM_API_COMPAT_STRUCT("nouveau", "nouveau")
+static struct pipe_screen *
+create_screen(int fd)
+{
+   struct pipe_screen *screen;
+
+   screen = nouveau_drm_screen_create(fd);
+   if (!screen)
+      return NULL;
+
+   return screen;
+}
+
+DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
 
 /* A poor man's --whole-archive for EGL drivers */
 void *_eglMain(void *);
index e16e86cd3d83c9c3e55978fb4b138a1fb71765f5..ca3ec53029a464c06d18e3ed53eb5574dd0511bb 100644 (file)
@@ -1,4 +1,17 @@
 
-#include "target-helpers/drm_api_compat.h"
+#include "state_tracker/drm_driver.h"
+#include "nouveau/drm/nouveau_drm_public.h"
 
-DRM_API_COMPAT_STRUCT("nouveau", "nouveau")
+static struct pipe_screen *
+create_screen(int fd)
+{
+   struct pipe_screen *screen;
+
+   screen = nouveau_drm_screen_create(fd);
+   if (!screen)
+      return NULL;
+
+   return screen;
+}
+
+DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
diff --git a/src/gallium/winsys/nouveau/drm/nouveau_drm_public.h b/src/gallium/winsys/nouveau/drm/nouveau_drm_public.h
new file mode 100644 (file)
index 0000000..67b7c44
--- /dev/null
@@ -0,0 +1,9 @@
+
+#ifndef __NOUVEAU_DRM_PUBLIC_H__
+#define __NOUVEAU_DRM_PUBLIC_H__
+
+struct pipe_screen;
+
+struct pipe_screen *nouveau_drm_screen_create(int drmFD);
+
+#endif
index 418f1d708a7d1fa64d5744bc29e693956b699415..660dbd0c332e99244088bc2b1e596a847740bd6c 100644 (file)
@@ -5,6 +5,7 @@
 #include "util/u_inlines.h"
 
 #include "nouveau_drm_winsys.h"
+#include "nouveau_drm_public.h"
 
 #include "nouveau_drmif.h"
 #include "nouveau_channel.h"
@@ -22,8 +23,8 @@ nouveau_drm_destroy_winsys(struct pipe_winsys *s)
        FREE(nv_winsys);
 }
 
-static struct pipe_screen *
-nouveau_drm_create_screen(struct drm_api *api, int fd)
+struct pipe_screen *
+nouveau_drm_screen_create(int fd)
 {
        struct nouveau_winsys *nvws;
        struct pipe_winsys *ws;
@@ -70,16 +71,3 @@ nouveau_drm_create_screen(struct drm_api *api, int fd)
 
        return nvws->pscreen;
 }
-
-static struct drm_api nouveau_drm_api_hooks = {
-       .name = "nouveau",
-       .driver_name = "nouveau",
-       .create_screen = nouveau_drm_create_screen,
-       .destroy = NULL,
-};
-
-struct drm_api *
-drm_api_create() {
-       return &nouveau_drm_api_hooks;
-}
-
index ae3ab17d743bac5904a589046e943ab45f23dfee..9e529ecad3d297adc2f9f4f62a72360251329307 100644 (file)
@@ -1,8 +1,6 @@
 #ifndef __NOUVEAU_DRM_WINSYS_H__
 #define __NOUVEAU_DRM_WINSYS_H__
 
-#include "state_tracker/drm_api.h"
-
 #include "util/u_simple_screen.h"
 
 #include "nouveau_dri.h"