pipe-loader: introduce pipe_loader_sw_probe_dri helper
Will be used in the following commits. v2: Link gallium tests against the library. v3: Handle dri_create_sw_winsys failure v4: Rebase on top of the targets/xa changes Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com> Reviewed-by: Jakob Bornecrantz <jakob@vmware.com> (v2)
This commit is contained in:
parent
cc3aeacab6
commit
969e8d15b7
|
@ -44,6 +44,7 @@ extern "C" {
|
|||
#endif
|
||||
|
||||
struct pipe_screen;
|
||||
struct drisw_loader_funcs;
|
||||
|
||||
enum pipe_loader_device_type {
|
||||
PIPE_LOADER_DEVICE_SOFTWARE,
|
||||
|
@ -118,6 +119,18 @@ pipe_loader_sw_probe_xlib(struct pipe_loader_device **devs, Display *display);
|
|||
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Initialize sw dri device give the drisw_loader_funcs.
|
||||
*
|
||||
* This function is platform-specific.
|
||||
*
|
||||
* \sa pipe_loader_probe
|
||||
*/
|
||||
bool
|
||||
pipe_loader_sw_probe_dri(struct pipe_loader_device **devs,
|
||||
struct drisw_loader_funcs *drisw_lf);
|
||||
|
||||
|
||||
/**
|
||||
* Get a list of known software devices.
|
||||
*
|
||||
|
|
|
@ -29,9 +29,11 @@
|
|||
|
||||
#include "util/u_memory.h"
|
||||
#include "util/u_dl.h"
|
||||
#include "sw/dri/dri_sw_winsys.h"
|
||||
#include "sw/null/null_sw_winsys.h"
|
||||
#include "sw/xlib/xlib_sw_winsys.h"
|
||||
#include "target-helpers/inline_sw_helper.h"
|
||||
#include "state_tracker/drisw_api.h"
|
||||
|
||||
struct pipe_loader_sw_device {
|
||||
struct pipe_loader_device base;
|
||||
|
@ -70,6 +72,27 @@ pipe_loader_sw_probe_xlib(struct pipe_loader_device **devs, Display *display)
|
|||
}
|
||||
#endif
|
||||
|
||||
bool
|
||||
pipe_loader_sw_probe_dri(struct pipe_loader_device **devs, struct drisw_loader_funcs *drisw_lf)
|
||||
{
|
||||
struct pipe_loader_sw_device *sdev = CALLOC_STRUCT(pipe_loader_sw_device);
|
||||
|
||||
if (!sdev)
|
||||
return false;
|
||||
|
||||
sdev->base.type = PIPE_LOADER_DEVICE_SOFTWARE;
|
||||
sdev->base.driver_name = "swrast";
|
||||
sdev->base.ops = &pipe_loader_sw_ops;
|
||||
sdev->ws = dri_create_sw_winsys(drisw_lf);
|
||||
if (!sdev->ws) {
|
||||
FREE(sdev);
|
||||
return false;
|
||||
}
|
||||
*devs = &sdev->base;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
int
|
||||
pipe_loader_sw_probe(struct pipe_loader_device **devs, int ndev)
|
||||
{
|
||||
|
|
|
@ -13,6 +13,7 @@ AM_CPPFLAGS = \
|
|||
|
||||
LDADD = $(GALLIUM_PIPE_LOADER_CLIENT_LIBS) \
|
||||
$(top_builddir)/src/gallium/auxiliary/pipe-loader/libpipe_loader_client.la \
|
||||
$(top_builddir)/src/gallium/winsys/sw/dri/libswdri.la \
|
||||
$(top_builddir)/src/gallium/winsys/sw/null/libws_null.la \
|
||||
$(top_builddir)/src/gallium/auxiliary/libgallium.la \
|
||||
$(DLOPEN_LIBS) \
|
||||
|
|
Loading…
Reference in New Issue