diff options
author | Javier Celaya <javier.celaya@flexvm.es> | 2015-01-28 11:49:48 +0100 |
---|---|---|
committer | Christophe Fergeau <cfergeau@redhat.com> | 2015-02-03 10:46:34 +0100 |
commit | 9287e53b6c978a2c8eaf3d7f820276e34a678a92 (patch) | |
tree | 5074fa2d4dbf53fa53d4520202d353b3bc254ab4 | |
parent | d167e2ead84b62f7af08a153dc95365910796ae5 (diff) |
LZ4: Add support for 24bit pixman surfaces
-rw-r--r-- | common/canvas_base.c | 3 | ||||
-rw-r--r-- | common/canvas_utils.c | 8 |
2 files changed, 11 insertions, 0 deletions
diff --git a/common/canvas_base.c b/common/canvas_base.c index 2f22400..7394105 100644 --- a/common/canvas_base.c +++ b/common/canvas_base.c @@ -543,6 +543,9 @@ static pixman_image_t *canvas_get_lz4(CanvasBase *canvas, SpiceImage *image) stride_encoded *= 2; break; case SPICE_BITMAP_FMT_24BIT: + format = PIXMAN_r8g8b8; + stride_encoded *= 3; + break; case SPICE_BITMAP_FMT_32BIT: format = PIXMAN_x8r8g8b8; stride_encoded *= 4; diff --git a/common/canvas_utils.c b/common/canvas_utils.c index d52292b..0d1591a 100644 --- a/common/canvas_utils.c +++ b/common/canvas_utils.c @@ -165,6 +165,10 @@ pixman_image_t * surface_create(pixman_format_code_t format, int width, int heig bitmap_info.inf.bmiHeader.biBitCount = 32; nstride = width * 4; break; + case PIXMAN_r8g8b8: + bitmap_info.inf.bmiHeader.biBitCount = 24; + nstride = SPICE_ALIGN(width * 3, 4); + break; case PIXMAN_x1r5g5b5: case PIXMAN_r5g6b5: bitmap_info.inf.bmiHeader.biBitCount = 16; @@ -233,6 +237,10 @@ pixman_image_t * surface_create(pixman_format_code_t format, int width, int heig case PIXMAN_x8r8g8b8: stride = width * 4; break; + case PIXMAN_r8g8b8: + // NOTE: LZ4 also decodes to RGB24 + stride = SPICE_ALIGN(width * 3, 4); + break; case PIXMAN_x1r5g5b5: case PIXMAN_r5g6b5: stride = SPICE_ALIGN(width * 2, 4); |