Browse Source

Micro-optimize copy instructions in DeltaEncoder

The copy instruction formatter should not to compute the shifts and
masks twice.  Instead compute them once and assume there is a register
available to store the temporary "b" for compare with 0.

Change-Id: Ic7826f29dca67b16903d8f790bdf785eb478c10d
stable-3.0
Shawn Pearce 12 years ago
parent
commit
0f32901ab7
  1. 37
      org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/DeltaEncoder.java

37
org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/DeltaEncoder.java

@ -134,7 +134,7 @@ public class DeltaEncoder {
} }
buf[p++] = (byte) (((int) sz) & 0x7f); buf[p++] = (byte) (((int) sz) & 0x7f);
size += p; size += p;
if (limit <= 0 || size < limit) if (limit == 0 || size < limit)
out.write(buf, 0, p); out.write(buf, 0, p);
} }
@ -189,7 +189,7 @@ public class DeltaEncoder {
throws IOException { throws IOException {
if (cnt <= 0) if (cnt <= 0)
return true; return true;
if (0 < limit) { if (limit != 0) {
int hdrs = cnt / MAX_INSERT_DATA_SIZE; int hdrs = cnt / MAX_INSERT_DATA_SIZE;
if (cnt % MAX_INSERT_DATA_SIZE != 0) if (cnt % MAX_INSERT_DATA_SIZE != 0)
hdrs++; hdrs++;
@ -236,7 +236,7 @@ public class DeltaEncoder {
cnt -= MAX_V2_COPY; cnt -= MAX_V2_COPY;
if (buf.length < p + MAX_COPY_CMD_SIZE) { if (buf.length < p + MAX_COPY_CMD_SIZE) {
if (0 < limit && limit < size + p) if (limit != 0 && limit < size + p)
return false; return false;
out.write(buf, 0, p); out.write(buf, 0, p);
size += p; size += p;
@ -245,7 +245,7 @@ public class DeltaEncoder {
} }
p = encodeCopy(p, offset, cnt); p = encodeCopy(p, offset, cnt);
if (0 < limit && limit < size + p) if (limit != 0 && limit < size + p)
return false; return false;
out.write(buf, 0, p); out.write(buf, 0, p);
size += p; size += p;
@ -255,36 +255,37 @@ public class DeltaEncoder {
private int encodeCopy(int p, long offset, int cnt) { private int encodeCopy(int p, long offset, int cnt) {
int cmd = 0x80; int cmd = 0x80;
final int cmdPtr = p++; // save room for the command final int cmdPtr = p++; // save room for the command
byte b;
if ((offset & 0xff) != 0) { if ((b = (byte) (offset & 0xff)) != 0) {
cmd |= 0x01; cmd |= 0x01;
buf[p++] = (byte) (offset & 0xff); buf[p++] = b;
} }
if ((offset & (0xff << 8)) != 0) { if ((b = (byte) ((offset >>> 8) & 0xff)) != 0) {
cmd |= 0x02; cmd |= 0x02;
buf[p++] = (byte) ((offset >>> 8) & 0xff); buf[p++] = b;
} }
if ((offset & (0xff << 16)) != 0) { if ((b = (byte) ((offset >>> 16) & 0xff)) != 0) {
cmd |= 0x04; cmd |= 0x04;
buf[p++] = (byte) ((offset >>> 16) & 0xff); buf[p++] = b;
} }
if ((offset & (0xff << 24)) != 0) { if ((b = (byte) ((offset >>> 24) & 0xff)) != 0) {
cmd |= 0x08; cmd |= 0x08;
buf[p++] = (byte) ((offset >>> 24) & 0xff); buf[p++] = b;
} }
if (cnt != MAX_V2_COPY) { if (cnt != MAX_V2_COPY) {
if ((cnt & 0xff) != 0) { if ((b = (byte) (cnt & 0xff)) != 0) {
cmd |= 0x10; cmd |= 0x10;
buf[p++] = (byte) (cnt & 0xff); buf[p++] = b;
} }
if ((cnt & (0xff << 8)) != 0) { if ((b = (byte) ((cnt >>> 8) & 0xff)) != 0) {
cmd |= 0x20; cmd |= 0x20;
buf[p++] = (byte) ((cnt >>> 8) & 0xff); buf[p++] = b;
} }
if ((cnt & (0xff << 16)) != 0) { if ((b = (byte) ((cnt >>> 16) & 0xff)) != 0) {
cmd |= 0x40; cmd |= 0x40;
buf[p++] = (byte) ((cnt >>> 16) & 0xff); buf[p++] = b;
} }
} }

Loading…
Cancel
Save