diff options
author | Marek Olšák <[email protected]> | 2015-03-09 21:20:03 +0100 |
---|---|---|
committer | Marek Olšák <[email protected]> | 2015-03-09 21:22:22 +0100 |
commit | c939231e7223510408a446400ad23b8b5ce2922e (patch) | |
tree | 0aa9c6cfb2a4a80312b54c287266aa160636b167 | |
parent | 9953586af2254f83a610d4cd284f52f37fa18b98 (diff) |
r300g: fix sRGB->sRGB blits
Cc: 10.5 10.4 <[email protected]>
-rw-r--r-- | src/gallium/drivers/r300/r300_blit.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/gallium/drivers/r300/r300_blit.c b/src/gallium/drivers/r300/r300_blit.c index 4e7efc560a4..baf05cea965 100644 --- a/src/gallium/drivers/r300/r300_blit.c +++ b/src/gallium/drivers/r300/r300_blit.c @@ -803,6 +803,15 @@ static void r300_blit(struct pipe_context *pipe, (struct pipe_framebuffer_state*)r300->fb_state.state; struct pipe_blit_info info = *blit; + /* The driver supports sRGB textures but not framebuffers. Blitting + * from sRGB to sRGB should be the same as blitting from linear + * to linear, so use that, This avoids incorrect linearization. + */ + if (util_format_is_srgb(info.src.format)) { + info.src.format = util_format_linear(info.src.format); + info.dst.format = util_format_linear(info.dst.format); + } + /* MSAA resolve. */ if (info.src.resource->nr_samples > 1 && !util_format_is_depth_or_stencil(info.src.resource->format)) { |