X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=src%2Fmesa%2Fmain%2Fviewport.c;h=bd580446f7620d174530493e211721c739f2d616;hb=e70d0d22a2dccc1df2c88890a2964491cdafac94;hp=f6eaa0f30a9e23a99bc587c5f64d23a3dfe1e07a;hpb=411a72d4a2eb69e45701c5e19049f6c543a78f24;p=mesa.git diff --git a/src/mesa/main/viewport.c b/src/mesa/main/viewport.c index f6eaa0f30a9..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, @@ -333,7 +335,24 @@ _mesa_DepthRangeArrayv(GLuint first, GLsizei count, const GLclampd *v) 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); } /** @@ -367,7 +386,7 @@ _mesa_DepthRangeIndexed(GLuint index, GLclampd nearval, GLclampd farval) void GLAPIENTRY _mesa_DepthRangeIndexedfOES(GLuint index, GLfloat nearval, GLfloat farval) { - + _mesa_DepthRangeIndexed(index, nearval, farval); } /**