summaryrefslogtreecommitdiffstats
path: root/src/gallium/targets/xorg-r600/target.c
diff options
context:
space:
mode:
authorMichel Dänzer <[email protected]>2011-08-22 15:44:42 +0200
committerMichel Dänzer <[email protected]>2011-08-26 18:21:38 +0200
commit433c740c1a2c173445c0bb161522bf7a76fa49c6 (patch)
tree2f94d2e40c53fb51d2c12f8871e0cd56668f2bed /src/gallium/targets/xorg-r600/target.c
parent702838a7061cde91a6bcdd3382817deb61218bf1 (diff)
r600g: Hook up xorg state tracker.
Mostly copied from r300g. Signed-off-by: Michel Dänzer <[email protected]> Reviewed-by: Alex Deucher <[email protected]>
Diffstat (limited to 'src/gallium/targets/xorg-r600/target.c')
-rw-r--r--src/gallium/targets/xorg-r600/target.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/src/gallium/targets/xorg-r600/target.c b/src/gallium/targets/xorg-r600/target.c
new file mode 100644
index 00000000000..60424359a7b
--- /dev/null
+++ b/src/gallium/targets/xorg-r600/target.c
@@ -0,0 +1,26 @@
+
+#include "target-helpers/inline_debug_helper.h"
+#include "state_tracker/drm_driver.h"
+#include "radeon/drm/radeon_drm_public.h"
+#include "r600/r600_public.h"
+
+static struct pipe_screen *
+create_screen(int fd)
+{
+ struct radeon_winsys *sws;
+ struct pipe_screen *screen;
+
+ sws = radeon_drm_winsys_create(fd);
+ if (!sws)
+ return NULL;
+
+ screen = r600_screen_create(sws);
+ if (!screen)
+ return NULL;
+
+ screen = debug_screen_wrap(screen);
+
+ return screen;
+}
+
+DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)