summaryrefslogtreecommitdiffstats
path: root/src/gallium/targets/r300/drm_target.c
diff options
context:
space:
mode:
authorChristian König <[email protected]>2013-09-25 13:59:56 +0200
committerChristian König <[email protected]>2013-09-25 19:41:31 +0200
commit4871128e58402385dc6f920884273c003a1124e1 (patch)
tree90abea06f7ff8f5b8a0b519de6f1d8e53dfea023 /src/gallium/targets/r300/drm_target.c
parentf6e2aa0e12e4ce91dc6f8ac5140d6e1f511ea468 (diff)
radeon/winsys: keep screen pointer in winsys v2
Only create one screen for each winsys instance. This helps with buffer sharing and interop handling. v2: rebased and some minor cleanup Signed-off-by: Christian König <[email protected]> Reviewed-by: Marek Olšák <[email protected]>
Diffstat (limited to 'src/gallium/targets/r300/drm_target.c')
-rw-r--r--src/gallium/targets/r300/drm_target.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/src/gallium/targets/r300/drm_target.c b/src/gallium/targets/r300/drm_target.c
index 111abd41856..2c10bbd7bb1 100644
--- a/src/gallium/targets/r300/drm_target.c
+++ b/src/gallium/targets/r300/drm_target.c
@@ -28,25 +28,27 @@
#include "target-helpers/inline_debug_helper.h"
#include "state_tracker/drm_driver.h"
#include "radeon/drm/radeon_drm_public.h"
+#include "radeon/drm/radeon_winsys.h"
#include "r300/r300_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 = r300_screen_create(sws);
- if (!screen)
- return NULL;
+ if (!sws->screen) {
+ sws->screen = r300_screen_create(sws);
+ if (!sws->screen)
+ return NULL;
- screen = debug_screen_wrap(screen);
+ sws->screen = debug_screen_wrap(sws->screen);
+ }
- return screen;
+ return sws->screen;
}
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)