diff options
author | Christian König <[email protected]> | 2012-07-13 11:23:10 +0200 |
---|---|---|
committer | Christian König <[email protected]> | 2012-08-02 15:15:23 +0200 |
commit | 41625afa2f7f30e5076c695ab3a16eabb5fe69f8 (patch) | |
tree | 9de6502725bc565b4d52af99c0dd58a3ea5eabee /src/gallium | |
parent | a3c6607be19af895ed6857c0a82b9b0821893dc6 (diff) |
radeonsi: initial VDPAU target
Windowed speed is of course way to slow, but fullscreen
works like a charm now.
Signed-off-by: Christian König <[email protected]>
Reviewed-by: Michel Dänzer <[email protected]>
Diffstat (limited to 'src/gallium')
-rw-r--r-- | src/gallium/targets/vdpau-radeonsi/Makefile | 30 | ||||
-rw-r--r-- | src/gallium/targets/vdpau-radeonsi/target.c | 24 |
2 files changed, 54 insertions, 0 deletions
diff --git a/src/gallium/targets/vdpau-radeonsi/Makefile b/src/gallium/targets/vdpau-radeonsi/Makefile new file mode 100644 index 00000000000..6dd2be9fc0f --- /dev/null +++ b/src/gallium/targets/vdpau-radeonsi/Makefile @@ -0,0 +1,30 @@ +TOP = ../../../.. +include $(TOP)/configs/current + +LIBBASENAME = vdpau_radeonsi + +DRIVER_INCLUDES = $(shell $(PKG_CONFIG) libdrm --cflags-only-I) + +PIPE_DRIVERS = \ + $(TOP)/src/gallium/drivers/radeonsi/libradeonsi.a \ + $(TOP)/src/gallium/state_trackers/dri/drm/libdridrm.a \ + $(TOP)/src/gallium/winsys/radeon/drm/libradeonwinsys.a \ + $(TOP)/src/gallium/drivers/trace/libtrace.a \ + $(TOP)/src/gallium/drivers/rbug/librbug.a \ + $(TOP)/src/gallium/drivers/noop/libnoop.a \ + $(TOP)/src/gallium/auxiliary/libgallium.a + +C_SOURCES = \ + target.c \ + $(TOP)/src/gallium/auxiliary/vl/vl_winsys_dri.c \ + $(COMMON_GALLIUM_SOURCES) \ + $(DRIVER_SOURCES) + +DRIVER_DEFINES = \ + -DGALLIUM_RBUG -DGALLIUM_TRACE -DGALLIUM_NOOP + +DRIVER_LIBS = $(shell $(PKG_CONFIG) libdrm --libs) -lXfixes -ldrm_radeon + +include ../Makefile.vdpau + +symlinks: diff --git a/src/gallium/targets/vdpau-radeonsi/target.c b/src/gallium/targets/vdpau-radeonsi/target.c new file mode 100644 index 00000000000..ffb66623b2b --- /dev/null +++ b/src/gallium/targets/vdpau-radeonsi/target.c @@ -0,0 +1,24 @@ +#include "state_tracker/drm_driver.h" +#include "target-helpers/inline_debug_helper.h" +#include "radeon/drm/radeon_drm_public.h" +#include "radeonsi/radeonsi_public.h" + +static struct pipe_screen *create_screen(int fd) +{ + struct radeon_winsys *radeon; + struct pipe_screen *screen; + + radeon = radeon_drm_winsys_create(fd); + if (!radeon) + return NULL; + + screen = radeonsi_screen_create(radeon); + if (!screen) + return NULL; + + screen = debug_screen_wrap(screen); + + return screen; +} + +DRM_DRIVER_DESCRIPTOR("radeonsi", "radeon", create_screen, NULL) |