summaryrefslogtreecommitdiffstats
path: root/common
diff options
context:
space:
mode:
authorPierre Ossman <ossman@cendio.se>2014-09-25 15:02:11 +0200
committerPierre Ossman <ossman@cendio.se>2014-09-25 15:03:44 +0200
commitfcaf0e43ac42e3dc457f1f996a3deac0de74b7cd (patch)
tree5e9b4e892a89e6d96de5c5e87a1da6fdbdaad03c /common
parent41deb88359d96b782f8da7126c8060bd285686e6 (diff)
downloadtigervnc-fcaf0e43ac42e3dc457f1f996a3deac0de74b7cd.tar.gz
tigervnc-fcaf0e43ac42e3dc457f1f996a3deac0de74b7cd.zip
Fix endian conversion
This was just plain wrong, so redo it properly.
Diffstat (limited to 'common')
-rw-r--r--common/rfb/PixelFormat.cxx34
1 files changed, 22 insertions, 12 deletions
diff --git a/common/rfb/PixelFormat.cxx b/common/rfb/PixelFormat.cxx
index 918e215f..9ec6b469 100644
--- a/common/rfb/PixelFormat.cxx
+++ b/common/rfb/PixelFormat.cxx
@@ -373,21 +373,31 @@ void PixelFormat::bufferFromBuffer(rdr::U8* dst, const PixelFormat &srcPF,
}
} else if (is888() && srcPF.is888()) {
// Optimised common case A: byte shuffling (e.g. endian conversion)
- rdr::U8 *d[4];
+ rdr::U8 *d[4], *s[4];
int dstPad, srcPad;
- if (bigEndian != srcPF.bigEndian) {
- d[(24 - srcPF.redShift)/8] = dst + (24 - redShift)/8;
- d[(24 - srcPF.greenShift)/8] = dst + (24 - greenShift)/8;
- d[(24 - srcPF.blueShift)/8] = dst + (24 - blueShift)/8;
- d[(24 - (48 - srcPF.redShift - srcPF.greenShift - srcPF.blueShift))/8] =
- dst + (24 - (48 - redShift - greenShift - blueShift))/8;
+ if (bigEndian) {
+ s[0] = dst + (24 - redShift)/8;
+ s[1] = dst + (24 - greenShift)/8;
+ s[2] = dst + (24 - blueShift)/8;
+ s[3] = dst + (24 - (48 - redShift - greenShift - blueShift))/8;
+ } else {
+ s[0] = dst + redShift/8;
+ s[1] = dst + greenShift/8;
+ s[2] = dst + blueShift/8;
+ s[3] = dst + (48 - redShift - greenShift - blueShift)/8;
+ }
+
+ if (srcPF.bigEndian) {
+ d[(24 - srcPF.redShift)/8] = s[0];
+ d[(24 - srcPF.greenShift)/8] = s[1];
+ d[(24 - srcPF.blueShift)/8] = s[2];
+ d[(24 - (48 - srcPF.redShift - srcPF.greenShift - srcPF.blueShift))/8] = s[3];
} else {
- d[srcPF.redShift/8] = dst + redShift/8;
- d[srcPF.greenShift/8] = dst + greenShift/8;
- d[srcPF.blueShift/8] = dst + blueShift/8;
- d[(48 - srcPF.redShift - srcPF.greenShift - srcPF.blueShift)/8] =
- dst + (48 - redShift - greenShift - blueShift)/8;
+ d[srcPF.redShift/8] = s[0];
+ d[srcPF.greenShift/8] = s[1];
+ d[srcPF.blueShift/8] = s[2];
+ d[(48 - srcPF.redShift - srcPF.greenShift - srcPF.blueShift)/8] = s[3];
}
dstPad = (dstStride - w) * 4;