summaryrefslogtreecommitdiff
path: root/lib/mesa/src/gallium
diff options
context:
space:
mode:
authorJonathan Gray <jsg@cvs.openbsd.org>2019-01-29 11:03:59 +0000
committerJonathan Gray <jsg@cvs.openbsd.org>2019-01-29 11:03:59 +0000
commit577c1a78c1ab321c4df5b5f8b402820e577dc301 (patch)
tree188bcdd93c705f4c5f18bd57befdd182ca8b8c50 /lib/mesa/src/gallium
parent8c790d282ea10b253ddcb20649fcdcc54c1a003f (diff)
Import Mesa 18.3.2
Diffstat (limited to 'lib/mesa/src/gallium')
-rw-r--r--lib/mesa/src/gallium/auxiliary/driver_rbug/README2
-rw-r--r--lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_context.c157
-rw-r--r--lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_core.c45
-rw-r--r--lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.c8
-rw-r--r--lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.h2
-rw-r--r--lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_public.h2
-rw-r--r--lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_screen.c180
7 files changed, 63 insertions, 333 deletions
diff --git a/lib/mesa/src/gallium/auxiliary/driver_rbug/README b/lib/mesa/src/gallium/auxiliary/driver_rbug/README
index 6db94810f..0edf0ad89 100644
--- a/lib/mesa/src/gallium/auxiliary/driver_rbug/README
+++ b/lib/mesa/src/gallium/auxiliary/driver_rbug/README
@@ -22,7 +22,7 @@ information is in that directory. Also for a gui see:
= Integrating =
-You can integrate the rbug pipe driver either inside the gallium frontend or the
+You can integrate the rbug pipe driver either inside the state tracker or the
target. The procedure on both cases is the same. Let's assume you have a
pipe_screen obtained by the usual means (variable and function names are just
for illustration purposes):
diff --git a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_context.c b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_context.c
index b0c283d9b..e1f3c4f28 100644
--- a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_context.c
+++ b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_context.c
@@ -63,7 +63,7 @@ rbug_draw_block_locked(struct rbug_context *rb_pipe, int flag)
} else if ((rb_pipe->draw_rule.blocker & flag) &&
(rb_pipe->draw_blocker & RBUG_BLOCK_RULE)) {
unsigned k;
- bool block = false;
+ boolean block = FALSE;
unsigned sh;
debug_printf("%s (%p %p) (%p %p) (%p %u) (%p %u)\n", __FUNCTION__,
@@ -76,21 +76,21 @@ rbug_draw_block_locked(struct rbug_context *rb_pipe, int flag)
for (sh = 0; sh < PIPE_SHADER_TYPES; sh++) {
if (rb_pipe->draw_rule.shader[sh] &&
rb_pipe->draw_rule.shader[sh] == rb_pipe->curr.shader[sh])
- block = true;
+ block = TRUE;
}
if (rb_pipe->draw_rule.surf &&
rb_pipe->draw_rule.surf == rb_pipe->curr.zsbuf)
- block = true;
+ block = TRUE;
if (rb_pipe->draw_rule.surf)
for (k = 0; k < rb_pipe->curr.nr_cbufs; k++)
if (rb_pipe->draw_rule.surf == rb_pipe->curr.cbufs[k])
- block = true;
+ block = TRUE;
if (rb_pipe->draw_rule.texture) {
for (sh = 0; sh < ARRAY_SIZE(rb_pipe->curr.num_views); sh++) {
for (k = 0; k < rb_pipe->curr.num_views[sh]; k++) {
if (rb_pipe->draw_rule.texture == rb_pipe->curr.texs[sh][k]) {
- block = true;
+ block = TRUE;
sh = PIPE_SHADER_TYPES; /* to break out of both loops */
break;
}
@@ -114,19 +114,10 @@ rbug_draw_block_locked(struct rbug_context *rb_pipe, int flag)
}
static void
-rbug_draw_vbo(struct pipe_context *_pipe, const struct pipe_draw_info *_info,
- unsigned _drawid_offset,
- const struct pipe_draw_indirect_info *_indirect,
- const struct pipe_draw_start_count_bias *draws,
- unsigned num_draws)
+rbug_draw_vbo(struct pipe_context *_pipe, const struct pipe_draw_info *info)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
struct pipe_context *pipe = rb_pipe->pipe;
- struct pipe_draw_info info;
-
- info = *_info;
- if(_info->index_size && !_info->has_user_indices)
- info.index.resource = rbug_resource_unwrap(_info->index.resource);
mtx_lock(&rb_pipe->draw_mutex);
rbug_draw_block_locked(rb_pipe, RBUG_BLOCK_BEFORE);
@@ -136,7 +127,7 @@ rbug_draw_vbo(struct pipe_context *_pipe, const struct pipe_draw_info *_info,
if (!(rb_pipe->curr.shader[PIPE_SHADER_FRAGMENT] && rb_pipe->curr.shader[PIPE_SHADER_FRAGMENT]->disabled) &&
!(rb_pipe->curr.shader[PIPE_SHADER_GEOMETRY] && rb_pipe->curr.shader[PIPE_SHADER_GEOMETRY]->disabled) &&
!(rb_pipe->curr.shader[PIPE_SHADER_VERTEX] && rb_pipe->curr.shader[PIPE_SHADER_VERTEX]->disabled))
- pipe->draw_vbo(pipe, &info, _drawid_offset, _indirect, draws, num_draws);
+ pipe->draw_vbo(pipe, info);
mtx_unlock(&rb_pipe->call_mutex);
rbug_draw_block_locked(rb_pipe, RBUG_BLOCK_AFTER);
@@ -173,13 +164,13 @@ rbug_destroy_query(struct pipe_context *_pipe,
mtx_unlock(&rb_pipe->call_mutex);
}
-static bool
+static boolean
rbug_begin_query(struct pipe_context *_pipe,
struct pipe_query *query)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
struct pipe_context *pipe = rb_pipe->pipe;
- bool ret;
+ boolean ret;
mtx_lock(&rb_pipe->call_mutex);
ret = pipe->begin_query(pipe, query);
@@ -203,15 +194,15 @@ rbug_end_query(struct pipe_context *_pipe,
return ret;
}
-static bool
+static boolean
rbug_get_query_result(struct pipe_context *_pipe,
struct pipe_query *query,
- bool wait,
+ boolean wait,
union pipe_query_result *result)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
struct pipe_context *pipe = rb_pipe->pipe;
- bool ret;
+ boolean ret;
mtx_lock(&rb_pipe->call_mutex);
ret = pipe->get_query_result(pipe,
@@ -224,7 +215,7 @@ rbug_get_query_result(struct pipe_context *_pipe,
}
static void
-rbug_set_active_query_state(struct pipe_context *_pipe, bool enable)
+rbug_set_active_query_state(struct pipe_context *_pipe, boolean enable)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
struct pipe_context *pipe = rb_pipe->pipe;
@@ -494,7 +485,7 @@ rbug_delete_vs_state(struct pipe_context *_pipe,
struct rbug_context *rb_pipe = rbug_context(_pipe);
struct rbug_shader *rb_shader = rbug_shader(_vs);
- mtx_lock(&rb_pipe->call_mutex);
+ mtx_unlock(&rb_pipe->call_mutex);
rbug_shader_destroy(rb_pipe, rb_shader);
mtx_unlock(&rb_pipe->call_mutex);
}
@@ -606,7 +597,7 @@ rbug_set_blend_color(struct pipe_context *_pipe,
static void
rbug_set_stencil_ref(struct pipe_context *_pipe,
- const struct pipe_stencil_ref stencil_ref)
+ const struct pipe_stencil_ref *stencil_ref)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
struct pipe_context *pipe = rb_pipe->pipe;
@@ -633,7 +624,7 @@ rbug_set_clip_state(struct pipe_context *_pipe,
static void
rbug_set_constant_buffer(struct pipe_context *_pipe,
enum pipe_shader_type shader,
- uint index, bool take_ownership,
+ uint index,
const struct pipe_constant_buffer *_cb)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
@@ -649,7 +640,7 @@ rbug_set_constant_buffer(struct pipe_context *_pipe,
mtx_lock(&rb_pipe->call_mutex);
pipe->set_constant_buffer(pipe,
shader,
- index, take_ownership,
+ index,
_cb ? &cb : NULL);
mtx_unlock(&rb_pipe->call_mutex);
}
@@ -739,8 +730,6 @@ rbug_set_sampler_views(struct pipe_context *_pipe,
enum pipe_shader_type shader,
unsigned start,
unsigned num,
- unsigned unbind_num_trailing_slots,
- bool take_ownership,
struct pipe_sampler_view **_views)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
@@ -769,8 +758,7 @@ rbug_set_sampler_views(struct pipe_context *_pipe,
views = unwrapped_views;
}
- pipe->set_sampler_views(pipe, shader, start, num,
- unbind_num_trailing_slots, take_ownership, views);
+ pipe->set_sampler_views(pipe, shader, start, num, views);
mtx_unlock(&rb_pipe->call_mutex);
}
@@ -778,8 +766,6 @@ rbug_set_sampler_views(struct pipe_context *_pipe,
static void
rbug_set_vertex_buffers(struct pipe_context *_pipe,
unsigned start_slot, unsigned num_buffers,
- unsigned unbind_num_trailing_slots,
- bool take_ownership,
const struct pipe_vertex_buffer *_buffers)
{
struct rbug_context *rb_pipe = rbug_context(_pipe);
@@ -801,8 +787,8 @@ rbug_set_vertex_buffers(struct pipe_context *_pipe,
}
pipe->set_vertex_buffers(pipe, start_slot,
- num_buffers, unbind_num_trailing_slots,
- take_ownership, buffers);
+ num_buffers,
+ buffers);
mtx_unlock(&rb_pipe->call_mutex);
}
@@ -930,7 +916,6 @@ rbug_flush_resource(struct pipe_context *_pipe,
static void
rbug_clear(struct pipe_context *_pipe,
unsigned buffers,
- const struct pipe_scissor_state *scissor_state,
const union pipe_color_union *color,
double depth,
unsigned stencil)
@@ -941,7 +926,6 @@ rbug_clear(struct pipe_context *_pipe,
mtx_lock(&rb_pipe->call_mutex);
pipe->clear(pipe,
buffers,
- scissor_state,
color,
depth,
stencil);
@@ -1015,31 +999,6 @@ rbug_flush(struct pipe_context *_pipe,
mtx_unlock(&rb_pipe->call_mutex);
}
-static void
-rbug_create_fence_fd(struct pipe_context *_pipe,
- struct pipe_fence_handle **fence, int fd,
- enum pipe_fd_type type)
-{
- struct rbug_context *rb_pipe = rbug_context(_pipe);
- struct pipe_context *pipe = rb_pipe->pipe;
-
- mtx_lock(&rb_pipe->call_mutex);
- pipe->create_fence_fd(pipe, fence, fd, type);
- mtx_unlock(&rb_pipe->call_mutex);
-}
-
-static void
-rbug_fence_server_sync(struct pipe_context *_pipe,
- struct pipe_fence_handle *fence)
-{
- struct rbug_context *rb_pipe = rbug_context(_pipe);
- struct pipe_context *pipe = rb_pipe->pipe;
-
- mtx_lock(&rb_pipe->call_mutex);
- pipe->fence_server_sync(pipe, fence);
- mtx_unlock(&rb_pipe->call_mutex);
-}
-
static struct pipe_sampler_view *
rbug_context_create_sampler_view(struct pipe_context *_pipe,
struct pipe_resource *_resource,
@@ -1108,7 +1067,7 @@ rbug_context_surface_destroy(struct pipe_context *_pipe,
static void *
-rbug_context_buffer_map(struct pipe_context *_context,
+rbug_context_transfer_map(struct pipe_context *_context,
struct pipe_resource *_resource,
unsigned level,
unsigned usage,
@@ -1123,34 +1082,7 @@ rbug_context_buffer_map(struct pipe_context *_context,
void *map;
mtx_lock(&rb_pipe->call_mutex);
- map = context->buffer_map(context,
- resource,
- level,
- usage,
- box, &result);
- mtx_unlock(&rb_pipe->call_mutex);
-
- *transfer = rbug_transfer_create(rb_pipe, rb_resource, result);
- return *transfer ? map : NULL;
-}
-
-static void *
-rbug_context_texture_map(struct pipe_context *_context,
- struct pipe_resource *_resource,
- unsigned level,
- unsigned usage,
- const struct pipe_box *box,
- struct pipe_transfer **transfer)
-{
- struct rbug_context *rb_pipe = rbug_context(_context);
- struct rbug_resource *rb_resource = rbug_resource(_resource);
- struct pipe_context *context = rb_pipe->pipe;
- struct pipe_resource *resource = rb_resource->resource;
- struct pipe_transfer *result;
- void *map;
-
- mtx_lock(&rb_pipe->call_mutex);
- map = context->texture_map(context,
+ map = context->transfer_map(context,
resource,
level,
usage,
@@ -1180,7 +1112,7 @@ rbug_context_transfer_flush_region(struct pipe_context *_context,
static void
-rbug_context_buffer_unmap(struct pipe_context *_context,
+rbug_context_transfer_unmap(struct pipe_context *_context,
struct pipe_transfer *_transfer)
{
struct rbug_context *rb_pipe = rbug_context(_context);
@@ -1189,24 +1121,7 @@ rbug_context_buffer_unmap(struct pipe_context *_context,
struct pipe_transfer *transfer = rb_transfer->transfer;
mtx_lock(&rb_pipe->call_mutex);
- context->buffer_unmap(context,
- transfer);
- rbug_transfer_destroy(rb_pipe,
- rb_transfer);
- mtx_unlock(&rb_pipe->call_mutex);
-}
-
-static void
-rbug_context_texture_unmap(struct pipe_context *_context,
- struct pipe_transfer *_transfer)
-{
- struct rbug_context *rb_pipe = rbug_context(_context);
- struct rbug_transfer *rb_transfer = rbug_transfer(_transfer);
- struct pipe_context *context = rb_pipe->pipe;
- struct pipe_transfer *transfer = rb_transfer->transfer;
-
- mtx_lock(&rb_pipe->call_mutex);
- context->texture_unmap(context,
+ context->transfer_unmap(context,
transfer);
rbug_transfer_destroy(rb_pipe,
rb_transfer);
@@ -1258,17 +1173,6 @@ rbug_context_texture_subdata(struct pipe_context *_context,
mtx_unlock(&rb_pipe->call_mutex);
}
-static void
-rbug_context_texture_barrier(struct pipe_context *_context, unsigned flags)
-{
- struct rbug_context *rb_pipe = rbug_context(_context);
- struct pipe_context *context = rb_pipe->pipe;
-
- mtx_lock(&rb_pipe->call_mutex);
- context->texture_barrier(context,
- flags);
- mtx_unlock(&rb_pipe->call_mutex);
-}
struct pipe_context *
rbug_context_create(struct pipe_screen *_screen, struct pipe_context *pipe)
@@ -1343,31 +1247,26 @@ rbug_context_create(struct pipe_screen *_screen, struct pipe_context *pipe)
rb_pipe->base.set_stream_output_targets = rbug_set_stream_output_targets;
rb_pipe->base.resource_copy_region = rbug_resource_copy_region;
rb_pipe->base.blit = rbug_blit;
+ rb_pipe->base.flush_resource = rbug_flush_resource;
rb_pipe->base.clear = rbug_clear;
rb_pipe->base.clear_render_target = rbug_clear_render_target;
rb_pipe->base.clear_depth_stencil = rbug_clear_depth_stencil;
rb_pipe->base.flush = rbug_flush;
- rb_pipe->base.create_fence_fd = rbug_create_fence_fd;
- rb_pipe->base.fence_server_sync = rbug_fence_server_sync;
rb_pipe->base.create_sampler_view = rbug_context_create_sampler_view;
rb_pipe->base.sampler_view_destroy = rbug_context_sampler_view_destroy;
rb_pipe->base.create_surface = rbug_context_create_surface;
rb_pipe->base.surface_destroy = rbug_context_surface_destroy;
- rb_pipe->base.buffer_map = rbug_context_buffer_map;
- rb_pipe->base.buffer_unmap = rbug_context_buffer_unmap;
- rb_pipe->base.texture_map = rbug_context_texture_map;
- rb_pipe->base.texture_unmap = rbug_context_texture_unmap;
+ rb_pipe->base.transfer_map = rbug_context_transfer_map;
+ rb_pipe->base.transfer_unmap = rbug_context_transfer_unmap;
rb_pipe->base.transfer_flush_region = rbug_context_transfer_flush_region;
rb_pipe->base.buffer_subdata = rbug_context_buffer_subdata;
rb_pipe->base.texture_subdata = rbug_context_texture_subdata;
- rb_pipe->base.texture_barrier = rbug_context_texture_barrier;
- rb_pipe->base.flush_resource = rbug_flush_resource;
rb_pipe->pipe = pipe;
rbug_screen_add_to_list(rb_screen, contexts, rb_pipe);
- if (debug_get_bool_option("GALLIUM_RBUG_START_BLOCKED", false)) {
+ if (debug_get_bool_option("GALLIUM_RBUG_START_BLOCKED", FALSE)) {
rb_pipe->draw_blocked = RBUG_BLOCK_BEFORE;
}
diff --git a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_core.c b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_core.c
index aad4487f4..76394039b 100644
--- a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_core.c
+++ b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_core.c
@@ -27,7 +27,7 @@
#include "os/os_thread.h"
-#include "util/format/u_format.h"
+#include "util/u_format.h"
#include "util/u_string.h"
#include "util/u_inlines.h"
#include "util/u_memory.h"
@@ -44,15 +44,18 @@
#include <errno.h>
-#define U642VOID(x) ((void *)(uintptr_t)(x))
-#define VOID2U64(x) ((uint64_t)(uintptr_t)(x))
+#define U642VOID(x) ((void *)(unsigned long)(x))
+#define VOID2U64(x) ((uint64_t)(unsigned long)(x))
+
+#define container_of(ptr, type, field) \
+ (type*)((char*)ptr - offsetof(type, field))
struct rbug_rbug
{
struct rbug_screen *rb_screen;
struct rbug_connection *con;
thrd_t thread;
- bool running;
+ boolean running;
};
int
@@ -267,9 +270,9 @@ rbug_texture_read(struct rbug_rbug *tr_rbug, struct rbug_header *header, uint32_
}
tex = tr_tex->resource;
- map = pipe_texture_map(context, tex,
+ map = pipe_transfer_map(context, tex,
gptr->level, gptr->face + gptr->zslice,
- PIPE_MAP_READ,
+ PIPE_TRANSFER_READ,
gptr->x, gptr->y, gptr->w, gptr->h, &t);
rbug_send_texture_read_reply(tr_rbug->con, serial,
@@ -283,7 +286,7 @@ rbug_texture_read(struct rbug_rbug *tr_rbug, struct rbug_header *header, uint32_
t->stride,
NULL);
- context->texture_unmap(context, t);
+ context->transfer_unmap(context, t);
mtx_unlock(&rb_screen->list_mutex);
@@ -574,19 +577,17 @@ rbug_shader_info(struct rbug_rbug *tr_rbug, struct rbug_header *header, uint32_t
/* just in case */
assert(sizeof(struct tgsi_token) == 4);
- if (tr_shdr->tokens) {
- original_len = tgsi_num_tokens(tr_shdr->tokens);
- if (tr_shdr->replaced_tokens)
- replaced_len = tgsi_num_tokens(tr_shdr->replaced_tokens);
- else
- replaced_len = 0;
+ original_len = tgsi_num_tokens(tr_shdr->tokens);
+ if (tr_shdr->replaced_tokens)
+ replaced_len = tgsi_num_tokens(tr_shdr->replaced_tokens);
+ else
+ replaced_len = 0;
- rbug_send_shader_info_reply(tr_rbug->con, serial,
- (uint32_t*)tr_shdr->tokens, original_len,
- (uint32_t*)tr_shdr->replaced_tokens, replaced_len,
- tr_shdr->disabled,
- NULL);
- }
+ rbug_send_shader_info_reply(tr_rbug->con, serial,
+ (uint32_t*)tr_shdr->tokens, original_len,
+ (uint32_t*)tr_shdr->replaced_tokens, replaced_len,
+ tr_shdr->disabled,
+ NULL);
mtx_unlock(&rb_context->list_mutex);
mtx_unlock(&rb_screen->list_mutex);
@@ -712,7 +713,7 @@ err:
return -EINVAL;
}
-static bool
+static boolean
rbug_header(struct rbug_rbug *tr_rbug, struct rbug_header *header, uint32_t serial)
{
int ret = 0;
@@ -773,7 +774,7 @@ rbug_header(struct rbug_rbug *tr_rbug, struct rbug_header *header, uint32_t seri
if (ret)
rbug_send_error_reply(tr_rbug->con, serial, ret, NULL);
- return true;
+ return TRUE;
}
static void
@@ -855,7 +856,7 @@ rbug_start(struct rbug_screen *rb_screen)
return NULL;
tr_rbug->rb_screen = rb_screen;
- tr_rbug->running = true;
+ tr_rbug->running = TRUE;
tr_rbug->thread = u_thread_create(rbug_thread, tr_rbug);
return tr_rbug;
diff --git a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.c b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.c
index 09455cf6f..2aa4e123f 100644
--- a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.c
+++ b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.c
@@ -186,10 +186,7 @@ rbug_transfer_create(struct rbug_context *rb_context,
return &rb_transfer->base;
error:
- if (rb_resource->base.target == PIPE_BUFFER)
- rb_context->pipe->buffer_unmap(rb_context->pipe, transfer);
- else
- rb_context->pipe->texture_unmap(rb_context->pipe, transfer);
+ rb_context->pipe->transfer_unmap(rb_context->pipe, transfer);
return NULL;
}
@@ -210,8 +207,7 @@ rbug_shader_create(struct rbug_context *rb_context,
rb_shader->type = type;
rb_shader->shader = result;
- if (state->tokens)
- rb_shader->tokens = tgsi_dup_tokens(state->tokens);
+ rb_shader->tokens = tgsi_dup_tokens(state->tokens);
/* works on context as well since its just a macro */
rbug_screen_add_to_list(rb_context, shaders, rb_shader);
diff --git a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.h b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.h
index 1a16eb416..02973e079 100644
--- a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.h
+++ b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_objects.h
@@ -64,7 +64,7 @@ struct rbug_shader
void *replaced_tokens;
enum rbug_shader_type type;
- bool disabled;
+ boolean disabled;
};
diff --git a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_public.h b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_public.h
index d17cf98b8..83f9c94e3 100644
--- a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_public.h
+++ b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_public.h
@@ -38,7 +38,7 @@ struct pipe_context;
struct pipe_screen *
rbug_screen_create(struct pipe_screen *screen);
-bool
+boolean
rbug_enabled(void);
#ifdef __cplusplus
diff --git a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_screen.c b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_screen.c
index 9ddb6dfa7..693e7fab9 100644
--- a/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_screen.c
+++ b/lib/mesa/src/gallium/auxiliary/driver_rbug/rbug_screen.c
@@ -37,7 +37,7 @@
#include "rbug_context.h"
#include "rbug_objects.h"
-DEBUG_GET_ONCE_BOOL_OPTION(rbug, "GALLIUM_RBUG", false)
+DEBUG_GET_ONCE_BOOL_OPTION(rbug, "GALLIUM_RBUG", FALSE)
static void
rbug_screen_destroy(struct pipe_screen *_screen)
@@ -77,16 +77,6 @@ rbug_screen_get_device_vendor(struct pipe_screen *_screen)
return screen->get_device_vendor(screen);
}
-static const void *
-rbug_screen_get_compiler_options(struct pipe_screen *_screen,
- enum pipe_shader_ir ir,
- enum pipe_shader_type shader)
-{
- struct pipe_screen *screen = rbug_screen(_screen)->screen;
-
- return screen->get_compiler_options(screen, ir, shader);
-}
-
static struct disk_cache *
rbug_screen_get_disk_shader_cache(struct pipe_screen *_screen)
{
@@ -129,7 +119,7 @@ rbug_screen_get_paramf(struct pipe_screen *_screen,
param);
}
-static bool
+static boolean
rbug_screen_is_format_supported(struct pipe_screen *_screen,
enum pipe_format format,
enum pipe_texture_target target,
@@ -148,64 +138,6 @@ rbug_screen_is_format_supported(struct pipe_screen *_screen,
tex_usage);
}
-static void
-rbug_screen_query_dmabuf_modifiers(struct pipe_screen *_screen,
- enum pipe_format format, int max,
- uint64_t *modifiers,
- unsigned int *external_only, int *count)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct pipe_screen *screen = rb_screen->screen;
-
- screen->query_dmabuf_modifiers(screen,
- format,
- max,
- modifiers,
- external_only,
- count);
-}
-
-static bool
-rbug_screen_is_dmabuf_modifier_supported(struct pipe_screen *_screen,
- uint64_t modifier,
- enum pipe_format format,
- bool *external_only)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct pipe_screen *screen = rb_screen->screen;
-
- return screen->is_dmabuf_modifier_supported(screen,
- modifier,
- format,
- external_only);
-}
-
-static unsigned int
-rbug_screen_get_dmabuf_modifier_planes(struct pipe_screen *_screen,
- uint64_t modifier,
- enum pipe_format format)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct pipe_screen *screen = rb_screen->screen;
-
- return screen->get_dmabuf_modifier_planes(screen, modifier, format);
-}
-
-static int
-rbug_screen_get_sparse_texture_virtual_page_size(struct pipe_screen *_screen,
- enum pipe_texture_target target,
- bool multi_sample,
- enum pipe_format format,
- unsigned offset, unsigned size,
- int *x, int *y, int *z)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct pipe_screen *screen = rb_screen->screen;
-
- return screen->get_sparse_texture_virtual_page_size(screen, target, multi_sample,
- format, offset, size, x, y, z);
-}
-
static struct pipe_context *
rbug_screen_context_create(struct pipe_screen *_screen,
void *priv, unsigned flags)
@@ -220,17 +152,6 @@ rbug_screen_context_create(struct pipe_screen *_screen,
return NULL;
}
-static bool
-rbug_screen_can_create_resource(struct pipe_screen *_screen,
- const struct pipe_resource *templat)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct pipe_screen *screen = rb_screen->screen;
-
- return screen->can_create_resource(screen,
- templat);
-}
-
static struct pipe_resource *
rbug_screen_resource_create(struct pipe_screen *_screen,
const struct pipe_resource *templat)
@@ -248,25 +169,6 @@ rbug_screen_resource_create(struct pipe_screen *_screen,
}
static struct pipe_resource *
-rbug_screen_resource_create_with_modifiers(struct pipe_screen *_screen,
- const struct pipe_resource *templat,
- const uint64_t *modifiers, int count)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct pipe_screen *screen = rb_screen->screen;
- struct pipe_resource *result;
-
- result = screen->resource_create_with_modifiers(screen,
- templat,
- modifiers,
- count);
-
- if (result)
- return rbug_resource_create(rb_screen, result);
- return NULL;
-}
-
-static struct pipe_resource *
rbug_screen_resource_from_handle(struct pipe_screen *_screen,
const struct pipe_resource *templ,
struct winsys_handle *handle,
@@ -296,7 +198,7 @@ rbug_screen_check_resource_capability(struct pipe_screen *_screen,
return screen->check_resource_capability(screen, resource, bind);
}
-static bool
+static boolean
rbug_screen_resource_get_handle(struct pipe_screen *_screen,
struct pipe_context *_pipe,
struct pipe_resource *_resource,
@@ -313,43 +215,6 @@ rbug_screen_resource_get_handle(struct pipe_screen *_screen,
resource, handle, usage);
}
-static bool
-rbug_screen_resource_get_param(struct pipe_screen *_screen,
- struct pipe_context *_pipe,
- struct pipe_resource *_resource,
- unsigned plane,
- unsigned layer,
- unsigned level,
- enum pipe_resource_param param,
- unsigned handle_usage,
- uint64_t *value)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct rbug_context *rb_pipe = rbug_context(_pipe);
- struct rbug_resource *rb_resource = rbug_resource(_resource);
- struct pipe_screen *screen = rb_screen->screen;
- struct pipe_resource *resource = rb_resource->resource;
-
- return screen->resource_get_param(screen, rb_pipe ? rb_pipe->pipe : NULL,
- resource, plane, layer, level, param,
- handle_usage, value);
-}
-
-
-static void
-rbug_screen_resource_get_info(struct pipe_screen *_screen,
- struct pipe_resource *_resource,
- unsigned *stride,
- unsigned *offset)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct rbug_resource *rb_resource = rbug_resource(_resource);
- struct pipe_screen *screen = rb_screen->screen;
- struct pipe_resource *resource = rb_resource->resource;
-
- screen->resource_get_info(screen, resource, stride, offset);
-}
-
static void
rbug_screen_resource_changed(struct pipe_screen *_screen,
struct pipe_resource *_resource)
@@ -359,7 +224,8 @@ rbug_screen_resource_changed(struct pipe_screen *_screen,
struct pipe_screen *screen = rb_screen->screen;
struct pipe_resource *resource = rb_resource->resource;
- screen->resource_changed(screen, resource);
+ if (screen->resource_changed)
+ screen->resource_changed(screen, resource);
}
static void
@@ -371,7 +237,6 @@ rbug_screen_resource_destroy(struct pipe_screen *screen,
static void
rbug_screen_flush_frontbuffer(struct pipe_screen *_screen,
- struct pipe_context *_ctx,
struct pipe_resource *_resource,
unsigned level, unsigned layer,
void *context_private, struct pipe_box *sub_box)
@@ -380,10 +245,8 @@ rbug_screen_flush_frontbuffer(struct pipe_screen *_screen,
struct rbug_resource *rb_resource = rbug_resource(_resource);
struct pipe_screen *screen = rb_screen->screen;
struct pipe_resource *resource = rb_resource->resource;
- struct pipe_context *ctx = _ctx ? rbug_context(_ctx)->pipe : NULL;
screen->flush_frontbuffer(screen,
- ctx,
resource,
level, layer,
context_private, sub_box);
@@ -402,7 +265,7 @@ rbug_screen_fence_reference(struct pipe_screen *_screen,
fence);
}
-static bool
+static boolean
rbug_screen_fence_finish(struct pipe_screen *_screen,
struct pipe_context *_ctx,
struct pipe_fence_handle *fence,
@@ -415,25 +278,7 @@ rbug_screen_fence_finish(struct pipe_screen *_screen,
return screen->fence_finish(screen, ctx, fence, timeout);
}
-static int
-rbug_screen_fence_get_fd(struct pipe_screen *_screen,
- struct pipe_fence_handle *fence)
-{
- struct rbug_screen *rb_screen = rbug_screen(_screen);
- struct pipe_screen *screen = rb_screen->screen;
-
- return screen->fence_get_fd(screen, fence);
-}
-
-static char *
-rbug_screen_finalize_nir(struct pipe_screen *_screen, void *nir)
-{
- struct pipe_screen *screen = rbug_screen(_screen)->screen;
-
- return screen->finalize_nir(screen, nir);
-}
-
-bool
+boolean
rbug_enabled()
{
return debug_get_option_rbug();
@@ -463,33 +308,22 @@ rbug_screen_create(struct pipe_screen *screen)
rb_screen->base.destroy = rbug_screen_destroy;
rb_screen->base.get_name = rbug_screen_get_name;
rb_screen->base.get_vendor = rbug_screen_get_vendor;
- SCR_INIT(get_compiler_options);
SCR_INIT(get_disk_shader_cache);
rb_screen->base.get_device_vendor = rbug_screen_get_device_vendor;
rb_screen->base.get_param = rbug_screen_get_param;
rb_screen->base.get_shader_param = rbug_screen_get_shader_param;
rb_screen->base.get_paramf = rbug_screen_get_paramf;
rb_screen->base.is_format_supported = rbug_screen_is_format_supported;
- SCR_INIT(query_dmabuf_modifiers);
- SCR_INIT(is_dmabuf_modifier_supported);
- SCR_INIT(get_dmabuf_modifier_planes);
rb_screen->base.context_create = rbug_screen_context_create;
- SCR_INIT(can_create_resource);
rb_screen->base.resource_create = rbug_screen_resource_create;
- SCR_INIT(resource_create_with_modifiers);
rb_screen->base.resource_from_handle = rbug_screen_resource_from_handle;
SCR_INIT(check_resource_capability);
rb_screen->base.resource_get_handle = rbug_screen_resource_get_handle;
- SCR_INIT(resource_get_param);
- SCR_INIT(resource_get_info);
SCR_INIT(resource_changed);
rb_screen->base.resource_destroy = rbug_screen_resource_destroy;
rb_screen->base.flush_frontbuffer = rbug_screen_flush_frontbuffer;
rb_screen->base.fence_reference = rbug_screen_fence_reference;
rb_screen->base.fence_finish = rbug_screen_fence_finish;
- rb_screen->base.fence_get_fd = rbug_screen_fence_get_fd;
- SCR_INIT(finalize_nir);
- SCR_INIT(get_sparse_texture_virtual_page_size);
rb_screen->screen = screen;