1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2025-01-03 05:35:58 +00:00

Implemented checksum and roll_checksum in C.

About 30% Performance boost. Yay!
This commit is contained in:
Jonas Borgström 2010-03-02 20:21:13 +01:00
parent 61cbaf8642
commit 3ce990ba19
2 changed files with 41 additions and 5 deletions

View file

@ -95,19 +95,24 @@ chunkify(PyObject *self, PyObject *args)
return (PyObject *)p; return (PyObject *)p;
} }
static PyObject * static PyObject *
checksum(PyObject *self, PyObject *args) checksum(PyObject *self, PyObject *args)
{ {
unsigned long int sum = 0, s1, s2; unsigned long int sum = 0, s1, s2;
PyObject *data; PyObject *data;
Py_ssize_t i, len; Py_ssize_t i, len;
const char *ptr; const char *ptr;
if (!PyArg_ParseTuple(args, "O|l", &data, &sum)) return NULL; if(!PyArg_ParseTuple(args, "O|l", &data, &sum)) return NULL;
if(!PyString_Check(data))
{
PyErr_SetNone(PyExc_TypeError);
Py_INCREF(data);
return NULL;
}
len = PyString_Size(data); len = PyString_Size(data);
ptr = PyString_AsString(data); ptr = PyString_AsString(data);
s1 = sum & 0xffff; s1 = sum & 0xffff;
s2 = sum >> 16; s2 = sum >> 16;
printf("Woot %lu\n", sizeof(s1));
for(i=0; i < len; i++) for(i=0; i < len; i++)
{ {
s1 += ptr[i] + 1; s1 += ptr[i] + 1;
@ -116,9 +121,33 @@ chunkify(PyObject *self, PyObject *args)
return PyInt_FromLong(((s2 & 0xffff) << 16) | (s1 & 0xffff)); return PyInt_FromLong(((s2 & 0xffff) << 16) | (s1 & 0xffff));
} }
static PyObject *
roll_checksum(PyObject *self, PyObject *args)
{
unsigned long int sum = 0, len, s1, s2, a, r;
PyObject *add, *remove;
if (!PyArg_ParseTuple(args, "lOOl", &sum, &remove, &add, &len)) return NULL;
if(!PyString_Check(remove) || !PyString_Check(add) ||
PyString_Size(remove) != 1 || PyString_Size(add) != 1)
{
PyErr_SetNone(PyExc_TypeError);
Py_INCREF(remove);
Py_INCREF(add);
return NULL;
}
a = *((const unsigned char *)PyString_AsString(add));
r = *((const unsigned char *)PyString_AsString(remove));
s1 = sum & 0xffff;
s2 = sum >> 16;
s1 -= r - a;
s2 -= len * (r + 1) - s1;
return PyInt_FromLong(((s2 & 0xffff) << 16) | (s1 & 0xffff));
}
static PyMethodDef ChunkifierMethods[] = { static PyMethodDef ChunkifierMethods[] = {
{"chunkify", chunkify, METH_VARARGS, ""}, {"chunkify", chunkify, METH_VARARGS, ""},
{"checksum", checksum, METH_VARARGS, ""}, {"checksum", checksum, METH_VARARGS, ""},
{"roll_checksum", roll_checksum, METH_VARARGS, ""},
{NULL, NULL, 0, NULL} /* Sentinel */ {NULL, NULL, 0, NULL} /* Sentinel */
}; };

View file

@ -111,6 +111,13 @@ def chunkify(fd, chunk_size, chunks):
""" """
return ChunkifyIter(fd, chunk_size, chunks) return ChunkifyIter(fd, chunk_size, chunks)
try:
import _speedups
checksum = _speedups.checksum
roll_checksum = _speedups.roll_checksum
except ImportError:
print 'Failed to load _speedups module, things will be slow'
if __name__ == '__main__': if __name__ == '__main__':
import StringIO import StringIO