gallium: implement get_device_vendor() for existing drivers
The only hackish ones are llvmpipe and softpipe, which currently return the same string as for get_vendor(), while ideally they should return the CPU vendor. Signed-off-by: Giuseppe Bilotta <giuseppe.bilotta@gmail.com> Reviewed-by: Tom Stellard <thomas.stellard@amd.com>
This commit is contained in:

committed by
Tom Stellard

parent
31d4e6fbff
commit
76039b38f0
@@ -95,6 +95,13 @@ fd_screen_get_vendor(struct pipe_screen *pscreen)
|
|||||||
return "freedreno";
|
return "freedreno";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
fd_screen_get_device_vendor(struct pipe_screen *pscreen)
|
||||||
|
{
|
||||||
|
return "Qualcomm";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static uint64_t
|
static uint64_t
|
||||||
fd_screen_get_timestamp(struct pipe_screen *pscreen)
|
fd_screen_get_timestamp(struct pipe_screen *pscreen)
|
||||||
{
|
{
|
||||||
@@ -531,6 +538,7 @@ fd_screen_create(struct fd_device *dev)
|
|||||||
|
|
||||||
pscreen->get_name = fd_screen_get_name;
|
pscreen->get_name = fd_screen_get_name;
|
||||||
pscreen->get_vendor = fd_screen_get_vendor;
|
pscreen->get_vendor = fd_screen_get_vendor;
|
||||||
|
pscreen->get_device_vendor = fd_screen_get_device_vendor;
|
||||||
|
|
||||||
pscreen->get_timestamp = fd_screen_get_timestamp;
|
pscreen->get_timestamp = fd_screen_get_timestamp;
|
||||||
|
|
||||||
|
@@ -54,6 +54,12 @@ i915_get_vendor(struct pipe_screen *screen)
|
|||||||
return "Mesa Project";
|
return "Mesa Project";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
i915_get_device_vendor(struct pipe_screen *screen)
|
||||||
|
{
|
||||||
|
return "Intel";
|
||||||
|
}
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
i915_get_name(struct pipe_screen *screen)
|
i915_get_name(struct pipe_screen *screen)
|
||||||
{
|
{
|
||||||
@@ -548,6 +554,7 @@ i915_screen_create(struct i915_winsys *iws)
|
|||||||
|
|
||||||
is->base.get_name = i915_get_name;
|
is->base.get_name = i915_get_name;
|
||||||
is->base.get_vendor = i915_get_vendor;
|
is->base.get_vendor = i915_get_vendor;
|
||||||
|
is->base.get_device_vendor = i915_get_device_vendor;
|
||||||
is->base.get_param = i915_get_param;
|
is->base.get_param = i915_get_param;
|
||||||
is->base.get_shader_param = i915_get_shader_param;
|
is->base.get_shader_param = i915_get_shader_param;
|
||||||
is->base.get_paramf = i915_get_paramf;
|
is->base.get_paramf = i915_get_paramf;
|
||||||
|
@@ -514,6 +514,12 @@ ilo_get_vendor(struct pipe_screen *screen)
|
|||||||
return "LunarG, Inc.";
|
return "LunarG, Inc.";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
ilo_get_device_vendor(struct pipe_screen *screen)
|
||||||
|
{
|
||||||
|
return "Intel";
|
||||||
|
}
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
ilo_get_name(struct pipe_screen *screen)
|
ilo_get_name(struct pipe_screen *screen)
|
||||||
{
|
{
|
||||||
@@ -844,6 +850,7 @@ ilo_screen_create(struct intel_winsys *ws)
|
|||||||
is->base.destroy = ilo_screen_destroy;
|
is->base.destroy = ilo_screen_destroy;
|
||||||
is->base.get_name = ilo_get_name;
|
is->base.get_name = ilo_get_name;
|
||||||
is->base.get_vendor = ilo_get_vendor;
|
is->base.get_vendor = ilo_get_vendor;
|
||||||
|
is->base.get_device_vendor = ilo_get_device_vendor;
|
||||||
is->base.get_param = ilo_get_param;
|
is->base.get_param = ilo_get_param;
|
||||||
is->base.get_paramf = ilo_get_paramf;
|
is->base.get_paramf = ilo_get_paramf;
|
||||||
is->base.get_shader_param = ilo_get_shader_param;
|
is->base.get_shader_param = ilo_get_shader_param;
|
||||||
|
@@ -589,6 +589,7 @@ llvmpipe_create_screen(struct sw_winsys *winsys)
|
|||||||
|
|
||||||
screen->base.get_name = llvmpipe_get_name;
|
screen->base.get_name = llvmpipe_get_name;
|
||||||
screen->base.get_vendor = llvmpipe_get_vendor;
|
screen->base.get_vendor = llvmpipe_get_vendor;
|
||||||
|
screen->base.get_device_vendor = llvmpipe_get_vendor; // TODO should be the CPU vendor
|
||||||
screen->base.get_param = llvmpipe_get_param;
|
screen->base.get_param = llvmpipe_get_param;
|
||||||
screen->base.get_shader_param = llvmpipe_get_shader_param;
|
screen->base.get_shader_param = llvmpipe_get_shader_param;
|
||||||
screen->base.get_paramf = llvmpipe_get_paramf;
|
screen->base.get_paramf = llvmpipe_get_paramf;
|
||||||
|
@@ -305,6 +305,11 @@ static const char *noop_get_vendor(struct pipe_screen* pscreen)
|
|||||||
return "X.Org";
|
return "X.Org";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *noop_get_device_vendor(struct pipe_screen* pscreen)
|
||||||
|
{
|
||||||
|
return "NONE";
|
||||||
|
}
|
||||||
|
|
||||||
static const char *noop_get_name(struct pipe_screen* pscreen)
|
static const char *noop_get_name(struct pipe_screen* pscreen)
|
||||||
{
|
{
|
||||||
return "NOOP";
|
return "NOOP";
|
||||||
@@ -376,6 +381,7 @@ struct pipe_screen *noop_screen_create(struct pipe_screen *oscreen)
|
|||||||
screen->destroy = noop_destroy_screen;
|
screen->destroy = noop_destroy_screen;
|
||||||
screen->get_name = noop_get_name;
|
screen->get_name = noop_get_name;
|
||||||
screen->get_vendor = noop_get_vendor;
|
screen->get_vendor = noop_get_vendor;
|
||||||
|
screen->get_device_vendor = noop_get_device_vendor;
|
||||||
screen->get_param = noop_get_param;
|
screen->get_param = noop_get_param;
|
||||||
screen->get_shader_param = noop_get_shader_param;
|
screen->get_shader_param = noop_get_shader_param;
|
||||||
screen->get_paramf = noop_get_paramf;
|
screen->get_paramf = noop_get_paramf;
|
||||||
|
@@ -43,6 +43,12 @@ nouveau_screen_get_vendor(struct pipe_screen *pscreen)
|
|||||||
return "nouveau";
|
return "nouveau";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
nouveau_screen_get_device_vendor(struct pipe_screen *pscreen)
|
||||||
|
{
|
||||||
|
return "NVIDIA";
|
||||||
|
}
|
||||||
|
|
||||||
static uint64_t
|
static uint64_t
|
||||||
nouveau_screen_get_timestamp(struct pipe_screen *pscreen)
|
nouveau_screen_get_timestamp(struct pipe_screen *pscreen)
|
||||||
{
|
{
|
||||||
@@ -182,6 +188,7 @@ nouveau_screen_init(struct nouveau_screen *screen, struct nouveau_device *dev)
|
|||||||
|
|
||||||
pscreen->get_name = nouveau_screen_get_name;
|
pscreen->get_name = nouveau_screen_get_name;
|
||||||
pscreen->get_vendor = nouveau_screen_get_vendor;
|
pscreen->get_vendor = nouveau_screen_get_vendor;
|
||||||
|
pscreen->get_device_vendor = nouveau_screen_get_device_vendor;
|
||||||
|
|
||||||
pscreen->get_timestamp = nouveau_screen_get_timestamp;
|
pscreen->get_timestamp = nouveau_screen_get_timestamp;
|
||||||
|
|
||||||
|
@@ -47,6 +47,11 @@ static const char* r300_get_vendor(struct pipe_screen* pscreen)
|
|||||||
return "X.Org R300 Project";
|
return "X.Org R300 Project";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char* r300_get_device_vendor(struct pipe_screen* pscreen)
|
||||||
|
{
|
||||||
|
return "ATI";
|
||||||
|
}
|
||||||
|
|
||||||
static const char* chip_families[] = {
|
static const char* chip_families[] = {
|
||||||
"unknown",
|
"unknown",
|
||||||
"ATI R300",
|
"ATI R300",
|
||||||
@@ -695,6 +700,7 @@ struct pipe_screen* r300_screen_create(struct radeon_winsys *rws)
|
|||||||
r300screen->screen.destroy = r300_destroy_screen;
|
r300screen->screen.destroy = r300_destroy_screen;
|
||||||
r300screen->screen.get_name = r300_get_name;
|
r300screen->screen.get_name = r300_get_name;
|
||||||
r300screen->screen.get_vendor = r300_get_vendor;
|
r300screen->screen.get_vendor = r300_get_vendor;
|
||||||
|
r300screen->screen.get_device_vendor = r300_get_device_vendor;
|
||||||
r300screen->screen.get_param = r300_get_param;
|
r300screen->screen.get_param = r300_get_param;
|
||||||
r300screen->screen.get_shader_param = r300_get_shader_param;
|
r300screen->screen.get_shader_param = r300_get_shader_param;
|
||||||
r300screen->screen.get_paramf = r300_get_paramf;
|
r300screen->screen.get_paramf = r300_get_paramf;
|
||||||
|
@@ -332,6 +332,11 @@ static const char* r600_get_vendor(struct pipe_screen* pscreen)
|
|||||||
return "X.Org";
|
return "X.Org";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char* r600_get_device_vendor(struct pipe_screen* pscreen)
|
||||||
|
{
|
||||||
|
return "AMD";
|
||||||
|
}
|
||||||
|
|
||||||
static const char* r600_get_name(struct pipe_screen* pscreen)
|
static const char* r600_get_name(struct pipe_screen* pscreen)
|
||||||
{
|
{
|
||||||
struct r600_common_screen *rscreen = (struct r600_common_screen*)pscreen;
|
struct r600_common_screen *rscreen = (struct r600_common_screen*)pscreen;
|
||||||
@@ -825,6 +830,7 @@ bool r600_common_screen_init(struct r600_common_screen *rscreen,
|
|||||||
|
|
||||||
rscreen->b.get_name = r600_get_name;
|
rscreen->b.get_name = r600_get_name;
|
||||||
rscreen->b.get_vendor = r600_get_vendor;
|
rscreen->b.get_vendor = r600_get_vendor;
|
||||||
|
rscreen->b.get_device_vendor = r600_get_device_vendor;
|
||||||
rscreen->b.get_compute_param = r600_get_compute_param;
|
rscreen->b.get_compute_param = r600_get_compute_param;
|
||||||
rscreen->b.get_paramf = r600_get_paramf;
|
rscreen->b.get_paramf = r600_get_paramf;
|
||||||
rscreen->b.get_driver_query_info = r600_get_driver_query_info;
|
rscreen->b.get_driver_query_info = r600_get_driver_query_info;
|
||||||
|
@@ -68,6 +68,15 @@ rbug_screen_get_vendor(struct pipe_screen *_screen)
|
|||||||
return screen->get_vendor(screen);
|
return screen->get_vendor(screen);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
rbug_screen_get_device_vendor(struct pipe_screen *_screen)
|
||||||
|
{
|
||||||
|
struct rbug_screen *rb_screen = rbug_screen(_screen);
|
||||||
|
struct pipe_screen *screen = rb_screen->screen;
|
||||||
|
|
||||||
|
return screen->get_device_vendor(screen);
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
rbug_screen_get_param(struct pipe_screen *_screen,
|
rbug_screen_get_param(struct pipe_screen *_screen,
|
||||||
enum pipe_cap param)
|
enum pipe_cap param)
|
||||||
@@ -267,6 +276,7 @@ rbug_screen_create(struct pipe_screen *screen)
|
|||||||
rb_screen->base.destroy = rbug_screen_destroy;
|
rb_screen->base.destroy = rbug_screen_destroy;
|
||||||
rb_screen->base.get_name = rbug_screen_get_name;
|
rb_screen->base.get_name = rbug_screen_get_name;
|
||||||
rb_screen->base.get_vendor = rbug_screen_get_vendor;
|
rb_screen->base.get_vendor = rbug_screen_get_vendor;
|
||||||
|
rb_screen->base.get_device_vendor = rbug_screen_get_device_vendor;
|
||||||
rb_screen->base.get_param = rbug_screen_get_param;
|
rb_screen->base.get_param = rbug_screen_get_param;
|
||||||
rb_screen->base.get_shader_param = rbug_screen_get_shader_param;
|
rb_screen->base.get_shader_param = rbug_screen_get_shader_param;
|
||||||
rb_screen->base.get_paramf = rbug_screen_get_paramf;
|
rb_screen->base.get_paramf = rbug_screen_get_paramf;
|
||||||
|
@@ -427,6 +427,7 @@ softpipe_create_screen(struct sw_winsys *winsys)
|
|||||||
|
|
||||||
screen->base.get_name = softpipe_get_name;
|
screen->base.get_name = softpipe_get_name;
|
||||||
screen->base.get_vendor = softpipe_get_vendor;
|
screen->base.get_vendor = softpipe_get_vendor;
|
||||||
|
screen->base.get_device_vendor = softpipe_get_vendor; // TODO should be the CPU vendor
|
||||||
screen->base.get_param = softpipe_get_param;
|
screen->base.get_param = softpipe_get_param;
|
||||||
screen->base.get_shader_param = softpipe_get_shader_param;
|
screen->base.get_shader_param = softpipe_get_shader_param;
|
||||||
screen->base.get_paramf = softpipe_get_paramf;
|
screen->base.get_paramf = softpipe_get_paramf;
|
||||||
|
@@ -635,6 +635,7 @@ svga_screen_create(struct svga_winsys_screen *sws)
|
|||||||
screen->destroy = svga_destroy_screen;
|
screen->destroy = svga_destroy_screen;
|
||||||
screen->get_name = svga_get_name;
|
screen->get_name = svga_get_name;
|
||||||
screen->get_vendor = svga_get_vendor;
|
screen->get_vendor = svga_get_vendor;
|
||||||
|
screen->get_device_vendor = svga_get_vendor; // TODO actual device vendor
|
||||||
screen->get_param = svga_get_param;
|
screen->get_param = svga_get_param;
|
||||||
screen->get_shader_param = svga_get_shader_param;
|
screen->get_shader_param = svga_get_shader_param;
|
||||||
screen->get_paramf = svga_get_paramf;
|
screen->get_paramf = svga_get_paramf;
|
||||||
|
@@ -82,6 +82,27 @@ trace_screen_get_vendor(struct pipe_screen *_screen)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
trace_screen_get_device_vendor(struct pipe_screen *_screen)
|
||||||
|
{
|
||||||
|
struct trace_screen *tr_scr = trace_screen(_screen);
|
||||||
|
struct pipe_screen *screen = tr_scr->screen;
|
||||||
|
const char *result;
|
||||||
|
|
||||||
|
trace_dump_call_begin("pipe_screen", "get_device_vendor");
|
||||||
|
|
||||||
|
trace_dump_arg(ptr, screen);
|
||||||
|
|
||||||
|
result = screen->get_device_vendor(screen);
|
||||||
|
|
||||||
|
trace_dump_ret(string, result);
|
||||||
|
|
||||||
|
trace_dump_call_end();
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
trace_screen_get_param(struct pipe_screen *_screen,
|
trace_screen_get_param(struct pipe_screen *_screen,
|
||||||
enum pipe_cap param)
|
enum pipe_cap param)
|
||||||
@@ -470,6 +491,7 @@ trace_screen_create(struct pipe_screen *screen)
|
|||||||
tr_scr->base.destroy = trace_screen_destroy;
|
tr_scr->base.destroy = trace_screen_destroy;
|
||||||
tr_scr->base.get_name = trace_screen_get_name;
|
tr_scr->base.get_name = trace_screen_get_name;
|
||||||
tr_scr->base.get_vendor = trace_screen_get_vendor;
|
tr_scr->base.get_vendor = trace_screen_get_vendor;
|
||||||
|
tr_scr->base.get_device_vendor = trace_screen_get_device_vendor;
|
||||||
tr_scr->base.get_param = trace_screen_get_param;
|
tr_scr->base.get_param = trace_screen_get_param;
|
||||||
tr_scr->base.get_shader_param = trace_screen_get_shader_param;
|
tr_scr->base.get_shader_param = trace_screen_get_shader_param;
|
||||||
tr_scr->base.get_paramf = trace_screen_get_paramf;
|
tr_scr->base.get_paramf = trace_screen_get_paramf;
|
||||||
|
@@ -472,6 +472,7 @@ vc4_screen_create(int fd)
|
|||||||
|
|
||||||
pscreen->get_name = vc4_screen_get_name;
|
pscreen->get_name = vc4_screen_get_name;
|
||||||
pscreen->get_vendor = vc4_screen_get_vendor;
|
pscreen->get_vendor = vc4_screen_get_vendor;
|
||||||
|
pscreen->get_device_vendor = vc4_screen_get_vendor;
|
||||||
|
|
||||||
return pscreen;
|
return pscreen;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user