[Mesa-dev] [PATCH 13/14] st/mesa: set default tessellation levels
Roland Scheidegger
sroland at vmware.com
Tue Jun 23 06:32:46 PDT 2015
Another option would be to provide (no-op) implementations for all
drivers. But I think generally we indeed check if the function is
available in the state tracker before calling it for such things.
Roland
Am 23.06.2015 um 06:11 schrieb Ilia Mirkin:
> This needs to be guarded on availability of tessellation. I'm guessing
> that something ends up setting st.dirty to ~0, and this gets called
> even when the driver doesn't support tess. Just hit this playing back
> a trace with llvmpipe but with the tess patches:
>
> #1 0x00007ffff37dcf49 in update_tess (st=0x7fffe8116530)
> at state_tracker/st_atom_tess.c:46
> #2 0x00007ffff37d7afb in st_validate_state (st=0x7fffe8116530)
> at state_tracker/st_atom.c:223
> #3 0x00007ffff37e4291 in st_Clear (ctx=0x7fffe80e1f10, mask=2)
> at state_tracker/st_cb_clear.c:469
> #4 0x00007ffff35f5c48 in _mesa_Clear (mask=16384) at main/clear.c:224
> #5 0x00007ffff57ec452 in glClear (mask=16384) at glapi/glapi_mapi_tmp.h:3064
> #6 0x00000000004d4c0f in retrace_glClear(trace::Call&) ()
> #7 0x000000000040f488 in retrace::Retracer::retrace(trace::Call&) ()
>
> On Tue, Jun 16, 2015 at 7:04 PM, Marek Olšák <maraeo at gmail.com> wrote:
>> From: Marek Olšák <marek.olsak at amd.com>
>>
>> ---
>> src/mesa/Makefile.sources | 1 +
>> src/mesa/state_tracker/st_atom.c | 1 +
>> src/mesa/state_tracker/st_atom.h | 1 +
>> src/mesa/state_tracker/st_atom_tess.c | 59 +++++++++++++++++++++++++++++++++++
>> src/mesa/state_tracker/st_context.c | 1 +
>> src/mesa/state_tracker/st_context.h | 2 +-
>> 6 files changed, 64 insertions(+), 1 deletion(-)
>> create mode 100644 src/mesa/state_tracker/st_atom_tess.c
>>
>> diff --git a/src/mesa/Makefile.sources b/src/mesa/Makefile.sources
>> index 83f500f..ed9848c 100644
>> --- a/src/mesa/Makefile.sources
>> +++ b/src/mesa/Makefile.sources
>> @@ -407,6 +407,7 @@ STATETRACKER_FILES = \
>> state_tracker/st_atom_shader.c \
>> state_tracker/st_atom_shader.h \
>> state_tracker/st_atom_stipple.c \
>> + state_tracker/st_atom_tess.c \
>> state_tracker/st_atom_texture.c \
>> state_tracker/st_atom_viewport.c \
>> state_tracker/st_cache.h \
>> diff --git a/src/mesa/state_tracker/st_atom.c b/src/mesa/state_tracker/st_atom.c
>> index c97cd84..5fc1a77 100644
>> --- a/src/mesa/state_tracker/st_atom.c
>> +++ b/src/mesa/state_tracker/st_atom.c
>> @@ -78,6 +78,7 @@ static const struct st_tracked_state *atoms[] =
>> &st_bind_fs_ubos,
>> &st_bind_gs_ubos,
>> &st_update_pixel_transfer,
>> + &st_update_tess,
>>
>> /* this must be done after the vertex program update */
>> &st_update_array
>> diff --git a/src/mesa/state_tracker/st_atom.h b/src/mesa/state_tracker/st_atom.h
>> index bbfbd2d..5735ca6 100644
>> --- a/src/mesa/state_tracker/st_atom.h
>> +++ b/src/mesa/state_tracker/st_atom.h
>> @@ -80,6 +80,7 @@ extern const struct st_tracked_state st_bind_gs_ubos;
>> extern const struct st_tracked_state st_bind_tcs_ubos;
>> extern const struct st_tracked_state st_bind_tes_ubos;
>> extern const struct st_tracked_state st_update_pixel_transfer;
>> +extern const struct st_tracked_state st_update_tess;
>>
>>
>> GLuint st_compare_func_to_pipe(GLenum func);
>> diff --git a/src/mesa/state_tracker/st_atom_tess.c b/src/mesa/state_tracker/st_atom_tess.c
>> new file mode 100644
>> index 0000000..f3aaaae
>> --- /dev/null
>> +++ b/src/mesa/state_tracker/st_atom_tess.c
>> @@ -0,0 +1,59 @@
>> +/**************************************************************************
>> + *
>> + * Copyright 2015 Advanced Micro Devices, Inc.
>> + * All Rights Reserved.
>> + *
>> + * Permission is hereby granted, free of charge, to any person obtaining a
>> + * copy of this software and associated documentation files (the
>> + * "Software"), to deal in the Software without restriction, including
>> + * without limitation the rights to use, copy, modify, merge, publish,
>> + * distribute, sub license, and/or sell copies of the Software, and to
>> + * permit persons to whom the Software is furnished to do so, subject to
>> + * the following conditions:
>> + *
>> + * The above copyright notice and this permission notice (including the
>> + * next paragraph) shall be included in all copies or substantial portions
>> + * of the Software.
>> + *
>> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
>> + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
>> + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
>> + * IN NO EVENT SHALL THE AUTHORS AND/OR ITS SUPPLIERS BE LIABLE FOR
>> + * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
>> + * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
>> + * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
>> + *
>> + **************************************************************************/
>> +
>> +/*
>> + * Authors:
>> + * Marek Olšák <maraeo at gmail.com>
>> + */
>> +
>> +
>> +#include "main/macros.h"
>> +#include "st_context.h"
>> +#include "pipe/p_context.h"
>> +#include "st_atom.h"
>> +
>> +
>> +static void
>> +update_tess(struct st_context *st)
>> +{
>> + const struct gl_context *ctx = st->ctx;
>> + struct pipe_context *pipe = st->pipe;
>> +
>> + pipe->set_tess_state(pipe,
>> + ctx->TessCtrlProgram.patch_default_outer_level,
>> + ctx->TessCtrlProgram.patch_default_inner_level);
>> +}
>> +
>> +
>> +const struct st_tracked_state st_update_tess = {
>> + "update_tess", /* name */
>> + { /* dirty */
>> + 0, /* mesa */
>> + ST_NEW_TESS_STATE, /* st */
>> + },
>> + update_tess /* update */
>> +};
>> diff --git a/src/mesa/state_tracker/st_context.c b/src/mesa/state_tracker/st_context.c
>> index ef4ad1b..06280bc 100644
>> --- a/src/mesa/state_tracker/st_context.c
>> +++ b/src/mesa/state_tracker/st_context.c
>> @@ -308,6 +308,7 @@ static void st_init_driver_flags(struct gl_driver_flags *f)
>> f->NewArray = ST_NEW_VERTEX_ARRAYS;
>> f->NewRasterizerDiscard = ST_NEW_RASTERIZER;
>> f->NewUniformBuffer = ST_NEW_UNIFORM_BUFFER;
>> + f->NewDefaultTessLevels = ST_NEW_TESS_STATE;
>> }
>>
>> struct st_context *st_create_context(gl_api api, struct pipe_context *pipe,
>> diff --git a/src/mesa/state_tracker/st_context.h b/src/mesa/state_tracker/st_context.h
>> index 3010727..8183412 100644
>> --- a/src/mesa/state_tracker/st_context.h
>> +++ b/src/mesa/state_tracker/st_context.h
>> @@ -53,7 +53,7 @@ struct u_upload_mgr;
>> #define ST_NEW_FRAGMENT_PROGRAM (1 << 1)
>> #define ST_NEW_VERTEX_PROGRAM (1 << 2)
>> #define ST_NEW_FRAMEBUFFER (1 << 3)
>> -/* gap, re-use it */
>> +#define ST_NEW_TESS_STATE (1 << 4)
>> #define ST_NEW_GEOMETRY_PROGRAM (1 << 5)
>> #define ST_NEW_VERTEX_ARRAYS (1 << 6)
>> #define ST_NEW_RASTERIZER (1 << 7)
>> --
>> 2.1.0
>>
>> _______________________________________________
>> mesa-dev mailing list
>> mesa-dev at lists.freedesktop.org
>> https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.freedesktop.org_mailman_listinfo_mesa-2Ddev&d=BQIGaQ&c=Sqcl0Ez6M0X8aeM67LKIiDJAXVeAw-YihVMNtXt-uEs&r=Vjtt0vs_iqoI31UfJxBl7yv9I2FeiaeAYgMTLKRBc_I&m=Vnpp8mi3-mnjZlyydXaJcmHBVA0UulSpJvSzL-WSARo&s=let7qdX4x6EzIvxABUGqFVNg-rGEsWaeodjI_q7Q8Qw&e=
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.freedesktop.org_mailman_listinfo_mesa-2Ddev&d=BQIGaQ&c=Sqcl0Ez6M0X8aeM67LKIiDJAXVeAw-YihVMNtXt-uEs&r=Vjtt0vs_iqoI31UfJxBl7yv9I2FeiaeAYgMTLKRBc_I&m=Vnpp8mi3-mnjZlyydXaJcmHBVA0UulSpJvSzL-WSARo&s=let7qdX4x6EzIvxABUGqFVNg-rGEsWaeodjI_q7Q8Qw&e=
>
More information about the mesa-dev
mailing list