summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorThiago Macieira <thiago.macieira@intel.com>2013-09-11 16:25:37 -0700
committerThe Qt Project <gerrit-noreply@qt-project.org>2013-09-13 19:11:48 +0200
commitc1c715f800d3c79eed8305f4b4be9bff8a81fda3 (patch)
treeb7fb9e385d861d5d1c94b918d4165179ca95a376 /src
parentd7e424ee6686f663f5134666e09c2875bb3e42b6 (diff)
downloadqtbase-c1c715f800d3c79eed8305f4b4be9bff8a81fda3.tar.gz
Optimize QBitArray::count(bool)
Ever since 76e0223619da02911d02813961ef631a5e02d826, qPopulationCount was extracted from QBitArray and moved elsewhere. That unfortunately meant that the 24-bit loads are completely useless, since qPopulationCount always operates on 32 bits. Instead, do a full loop on 32-bit and then do 16-bit and finally 8-bit (for which there are qPopulationCount overloads). Change-Id: If945609f075095257d12877c39434909ac190e54 Reviewed-by: Olivier Goffart <ogoffart@woboq.com> Reviewed-by: Marc Mutz <marc.mutz@kdab.com>
Diffstat (limited to 'src')
-rw-r--r--src/corelib/tools/qbitarray.cpp29
1 files changed, 12 insertions, 17 deletions
diff --git a/src/corelib/tools/qbitarray.cpp b/src/corelib/tools/qbitarray.cpp
index fb60534495..42e29f641c 100644
--- a/src/corelib/tools/qbitarray.cpp
+++ b/src/corelib/tools/qbitarray.cpp
@@ -169,30 +169,25 @@ QBitArray::QBitArray(int size, bool value)
int QBitArray::count(bool on) const
{
int numBits = 0;
- int len = size();
-#if 0
- for (int i = 0; i < len; ++i)
- numBits += testBit(i);
-#else
const quint8 *bits = reinterpret_cast<const quint8 *>(d.data()) + 1;
- while (len >= 32) {
+
+ // the loops below will try to read from *end
+ // it's the QByteArray implicit NUL, so it will not change the bit count
+ const quint8 *const end = reinterpret_cast<const quint8 *>(d.end());
+
+ while (bits + 3 <= end) {
quint32 v = quint32(bits[0]) | (quint32(bits[1]) << 8) | (quint32(bits[2]) << 16) | (quint32(bits[3]) << 24);
- len -= 32;
bits += 4;
numBits += int(qPopulationCount(v));
}
- while (len >= 24) {
- quint32 v = quint32(bits[0]) | (quint32(bits[1]) << 8) | (quint32(bits[2]) << 16);
- len -= 24;
- bits += 3;
+ if (bits + 1 < end) {
+ quint16 v = quint16(bits[0]) | (quint16(bits[1]) << 8);
+ bits += 2;
numBits += int(qPopulationCount(v));
}
- while (len > 0) {
- --len;
- if (bits[len / 8] & (1 << (len & 7)))
- ++numBits;
- }
-#endif
+ if (bits < end)
+ numBits += int(qPopulationCount(bits[0]));
+
return on ? numBits : size() - numBits;
}