X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=src%2Fmesa%2Fmain%2Fviewport.c;h=bd580446f7620d174530493e211721c739f2d616;hb=e70d0d22a2dccc1df2c88890a2964491cdafac94;hp=681e46bfcf71562d82d3cb40d1f5e2030ffdcfbe;hpb=768bd7f272e0dfd8cc17c49750fe8aaab78bb420;p=mesa.git diff --git a/src/mesa/main/viewport.c b/src/mesa/main/viewport.c index 681e46bfcf7..bd580446f76 100644 --- a/src/mesa/main/viewport.c +++ b/src/mesa/main/viewport.c @@ -52,7 +52,9 @@ set_viewport_no_notify(struct gl_context *ctx, unsigned idx, * determined by calling GetFloatv with the symbolic constant * VIEWPORT_BOUNDS_RANGE (see section 6.1)." */ - if (ctx->Extensions.ARB_viewport_array) { + if (ctx->Extensions.ARB_viewport_array || + (ctx->Extensions.OES_viewport_array && + _mesa_is_gles31(ctx))) { x = CLAMP(x, ctx->Const.ViewportBounds.Min, ctx->Const.ViewportBounds.Max); y = CLAMP(y, @@ -330,6 +332,29 @@ _mesa_DepthRangeArrayv(GLuint first, GLsizei count, const GLclampd *v) ctx->Driver.DepthRange(ctx); } +void GLAPIENTRY +_mesa_DepthRangeArrayfvOES(GLuint first, GLsizei count, const GLfloat *v) +{ + int i; + GET_CURRENT_CONTEXT(ctx); + + if (MESA_VERBOSE & VERBOSE_API) + _mesa_debug(ctx, "glDepthRangeArrayfv %d %d\n", first, count); + + if ((first + count) > ctx->Const.MaxViewports) { + _mesa_error(ctx, GL_INVALID_VALUE, + "glDepthRangeArrayfv: first (%d) + count (%d) >= MaxViewports (%d)", + first, count, ctx->Const.MaxViewports); + return; + } + + for (i = 0; i < count; i++) + set_depth_range_no_notify(ctx, i + first, v[i * 2], v[i * 2 + 1]); + + if (ctx->Driver.DepthRange) + ctx->Driver.DepthRange(ctx); +} + /** * Update a single DepthRange * @@ -358,6 +383,12 @@ _mesa_DepthRangeIndexed(GLuint index, GLclampd nearval, GLclampd farval) _mesa_set_depth_range(ctx, index, nearval, farval); } +void GLAPIENTRY +_mesa_DepthRangeIndexedfOES(GLuint index, GLfloat nearval, GLfloat farval) +{ + _mesa_DepthRangeIndexed(index, nearval, farval); +} + /** * Initialize the context viewport attribute group. * \param ctx the GL context.