summaryrefslogtreecommitdiffstats
path: root/common
diff options
context:
space:
mode:
authorDRC <dcommander@users.sourceforge.net>2011-11-04 04:51:17 +0000
committerDRC <dcommander@users.sourceforge.net>2011-11-04 04:51:17 +0000
commita5004a3439317c7115d13fa2b37bf6a0b256d329 (patch)
treeab92aec167a194f668c121c97bda507339128968 /common
parent4f24c1a731dd812d14dac0a504a8033f6247a2fe (diff)
downloadtigervnc-a5004a3439317c7115d13fa2b37bf6a0b256d329.tar.gz
tigervnc-a5004a3439317c7115d13fa2b37bf6a0b256d329.zip
Further optimizations (avoiding single-byte copies and InStream processing overhead)
git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@4763 3789f03b-4d11-0410-bbf8-ca57d06f2519
Diffstat (limited to 'common')
-rw-r--r--common/rfb/TightDecoder.h16
-rw-r--r--common/rfb/tightDecode.h77
2 files changed, 40 insertions, 53 deletions
diff --git a/common/rfb/TightDecoder.h b/common/rfb/TightDecoder.h
index 9a28fb9b..5cdf873b 100644
--- a/common/rfb/TightDecoder.h
+++ b/common/rfb/TightDecoder.h
@@ -41,14 +41,14 @@ namespace rfb {
void DecompressJpegRect16(const Rect& r);
void DecompressJpegRect32(const Rect& r);
- void FilterGradient8(rdr::InStream* is, rdr::U8* buf, int stride,
- const Rect& r, int dataSize);
- void FilterGradient16(rdr::InStream* is, rdr::U16* buf, int stride,
- const Rect& r, int dataSize);
- void FilterGradient24(rdr::InStream* is, rdr::U32* buf, int stride,
- const Rect& r, int dataSize);
- void FilterGradient32(rdr::InStream* is, rdr::U32* buf, int stride,
- const Rect& r, int dataSize);
+ void FilterGradient8(rdr::U8 *netbuf, rdr::U8* buf, int stride,
+ const Rect& r);
+ void FilterGradient16(rdr::U8 *netbuf, rdr::U16* buf, int stride,
+ const Rect& r);
+ void FilterGradient24(rdr::U8 *netbuf, rdr::U32* buf, int stride,
+ const Rect& r);
+ void FilterGradient32(rdr::U8 *netbuf, rdr::U32* buf, int stride,
+ const Rect& r);
void directFillRect8(const Rect& r, Pixel pix);
void directFillRect16(const Rect& r, Pixel pix);
diff --git a/common/rfb/tightDecode.h b/common/rfb/tightDecode.h
index 32bb4f15..2c5f7e40 100644
--- a/common/rfb/tightDecode.h
+++ b/common/rfb/tightDecode.h
@@ -108,14 +108,11 @@ void TIGHT_DECODE (const Rect& r)
case rfbTightFilterPalette:
palSize = is->readU8() + 1;
if (cutZeros) {
- rdr::U8 elem[3];
- for (int i = 0;i < palSize;i++) {
- is->readBytes(elem, 3);
- serverpf.bufferFromRGB((rdr::U8*)&palette[i], elem, 1, NULL);
- }
+ rdr::U8 tightPalette[256 * 3];
+ is->readBytes(tightPalette, palSize * 3);
+ serverpf.bufferFromRGB((rdr::U8*)palette, tightPalette, palSize, NULL);
} else {
- for (int i = 0; i < palSize; i++)
- palette[i] = is->READ_PIXEL();
+ is->readBytes(palette, palSize * sizeof(PIXEL_T));
}
break;
case rfbTightFilterGradient:
@@ -141,15 +138,24 @@ void TIGHT_DECODE (const Rect& r)
int dataSize = r.height() * rowSize;
int streamId = -1;
rdr::InStream *input;
+ bool useZlib = false;
if (dataSize < TIGHT_MIN_TO_COMPRESS) {
input = is;
} else {
+ useZlib = true;
int length = is->readCompactLength();
streamId = comp_ctl & 0x03;
zis[streamId].setUnderlying(is, length);
input = &zis[streamId];
}
+ // Allocate netbuf and read in data
+ rdr::U8 *netbuf = new rdr::U8[dataSize];
+ if (!netbuf) {
+ throw Exception("rfb::TightDecoder::tightDecode unable to allocate buffer");
+ }
+ input->readBytes(netbuf, dataSize);
+
PIXEL_T *buf;
int stride = r.width();
if (directDecode) buf = (PIXEL_T *)handler->getRawPixelsRW(r, &stride);
@@ -160,32 +166,30 @@ void TIGHT_DECODE (const Rect& r)
if (useGradient) {
#if BPP == 32
if (cutZeros) {
- FilterGradient24(input, buf, stride, r, dataSize);
+ FilterGradient24(netbuf, buf, stride, r);
} else
#endif
{
- FILTER_GRADIENT(input, buf, stride, r, dataSize);
+ FILTER_GRADIENT(netbuf, buf, stride, r);
}
} else {
// Copy
int h = r.height();
PIXEL_T *ptr = buf;
+ rdr::U8 *srcPtr = netbuf;
+ int w = r.width();
if (cutZeros) {
- int w = r.width(), pad = stride - w;
- rdr::U8 elem[3];
while (h > 0) {
- PIXEL_T *endOfRow = ptr + w;
- while (ptr < endOfRow) {
- input->readBytes(elem, 3);
- serverpf.bufferFromRGB((rdr::U8*)ptr++, elem, 1, NULL);
- }
- ptr += pad;
+ serverpf.bufferFromRGB((rdr::U8*)ptr, srcPtr, w, NULL);
+ ptr += stride;
+ srcPtr += w * sizeof(PIXEL_T);
h--;
}
} else {
while (h > 0) {
- input->readBytes(ptr, rowSize);
+ memcpy(ptr, srcPtr, rowSize * sizeof(PIXEL_T));
ptr += stride;
+ srcPtr += w * sizeof(PIXEL_T);
h--;
}
}
@@ -194,18 +198,18 @@ void TIGHT_DECODE (const Rect& r)
// Indexed color
int x, h = r.height(), w = r.width(), b, pad = stride - w;
PIXEL_T *ptr = buf;
- rdr::U8 bits;
+ rdr::U8 bits, *srcPtr = netbuf;
if (palSize <= 2) {
// 2-color palette
while (h > 0) {
for (x = 0; x < w / 8; x++) {
- bits = input->readU8();
+ bits = *srcPtr++;
for (b = 7; b >= 0; b--) {
*ptr++ = palette[bits >> b & 1];
}
}
if (w % 8 != 0) {
- bits = input->readU8();
+ bits = *srcPtr++;
for (b = 7; b >= 8 - w % 8; b--) {
*ptr++ = palette[bits >> b & 1];
}
@@ -218,7 +222,7 @@ void TIGHT_DECODE (const Rect& r)
while (h > 0) {
PIXEL_T *endOfRow = ptr + w;
while (ptr < endOfRow) {
- *ptr++ = palette[input->readU8()];
+ *ptr++ = palette[*srcPtr++];
}
ptr += pad;
h--;
@@ -229,6 +233,8 @@ void TIGHT_DECODE (const Rect& r)
if (directDecode) handler->releaseRawPixels(r);
else IMAGE_RECT(r, buf);
+ delete [] netbuf;
+
if (streamId != -1) {
zis[streamId].reset();
}
@@ -246,7 +252,7 @@ DECOMPRESS_JPEG_RECT(const Rect& r)
// Allocate netbuf and read in data
rdr::U8* netbuf = new rdr::U8[compressedLen];
if (!netbuf) {
- throw Exception("rfb::tightDecode unable to allocate buffer");
+ throw Exception("rfb::TightDecoder::DecompressJpegRect unable to allocate buffer");
}
is->readBytes(netbuf, compressedLen);
@@ -263,8 +269,8 @@ DECOMPRESS_JPEG_RECT(const Rect& r)
#if BPP == 32
void
-TightDecoder::FilterGradient24(rdr::InStream* is, PIXEL_T* buf, int stride,
- const Rect& r, int dataSize)
+TightDecoder::FilterGradient24(rdr::U8 *netbuf, PIXEL_T* buf, int stride,
+ const Rect& r)
{
int x, y, c;
static rdr::U8 prevRow[TIGHT_MAX_WIDTH*3];
@@ -274,13 +280,6 @@ TightDecoder::FilterGradient24(rdr::InStream* is, PIXEL_T* buf, int stride,
memset(prevRow, 0, sizeof(prevRow));
- // Allocate netbuf and read in data
- rdr::U8 *netbuf = new rdr::U8[dataSize];
- if (!netbuf) {
- throw Exception("rfb::tightDecode unable to allocate buffer");
- }
- is->readBytes(netbuf, dataSize);
-
// Set up shortcut variables
int rectHeight = r.height();
int rectWidth = r.width();
@@ -310,15 +309,12 @@ TightDecoder::FilterGradient24(rdr::InStream* is, PIXEL_T* buf, int stride,
memcpy(prevRow, thisRow, sizeof(prevRow));
}
-
- delete [] netbuf;
}
#endif
void
-FILTER_GRADIENT(rdr::InStream* is, PIXEL_T* buf, int stride, const Rect& r,
- int dataSize)
+FILTER_GRADIENT(rdr::U8 *netbuf, PIXEL_T* buf, int stride, const Rect& r)
{
int x, y, c;
static rdr::U8 prevRow[TIGHT_MAX_WIDTH*sizeof(PIXEL_T)];
@@ -328,13 +324,6 @@ FILTER_GRADIENT(rdr::InStream* is, PIXEL_T* buf, int stride, const Rect& r,
memset(prevRow, 0, sizeof(prevRow));
- // Allocate netbuf and read in data
- PIXEL_T *netbuf = (PIXEL_T*)new rdr::U8[dataSize];
- if (!netbuf) {
- throw Exception("rfb::tightDecode unable to allocate buffer");
- }
- is->readBytes(netbuf, dataSize);
-
// Set up shortcut variables
int rectHeight = r.height();
int rectWidth = r.width();
@@ -371,8 +360,6 @@ FILTER_GRADIENT(rdr::InStream* is, PIXEL_T* buf, int stride, const Rect& r,
memcpy(prevRow, thisRow, sizeof(prevRow));
}
-
- delete [] netbuf;
}
#undef TIGHT_MIN_TO_COMPRESS