Пример #1
0
/*
 * GENz (triple parity with powers of 2^-1) 64bit C implementation
 */
void raid_genz_int64(int nd, size_t size, void **vv)
{
	uint8_t **v = (uint8_t **)vv;
	uint8_t *p;
	uint8_t *q;
	uint8_t *r;
	int d, l;
	size_t i;

	uint64_t d0, r0, q0, p0;
	uint64_t d1, r1, q1, p1;

	l = nd - 1;
	p = v[nd];
	q = v[nd+1];
	r = v[nd+2];

	for (i = 0; i < size; i += 16) {
		r0 = q0 = p0 = v_64(v[l][i]);
		r1 = q1 = p1 = v_64(v[l][i+8]);
		for (d = l-1; d >= 0; --d) {
			d0 = v_64(v[d][i]);
			d1 = v_64(v[d][i+8]);

			p0 ^= d0;
			p1 ^= d1;

			q0 = x2_64(q0);
			q1 = x2_64(q1);

			q0 ^= d0;
			q1 ^= d1;

			r0 = d2_64(r0);
			r1 = d2_64(r1);

			r0 ^= d0;
			r1 ^= d1;
		}
		v_64(p[i]) = p0;
		v_64(p[i+8]) = p1;
		v_64(q[i]) = q0;
		v_64(q[i+8]) = q1;
		v_64(r[i]) = r0;
		v_64(r[i+8]) = r1;
	}
}
Пример #2
0
/*
 * GEN1 (RAID5 with xor) 64bit C implementation
 */
void raid_gen1_int64(int nd, size_t size, void **vv)
{
    uint8_t **v = (uint8_t **)vv;
    uint8_t *p;
    int d, l;
    size_t i;

    uint64_t p0;
    uint64_t p1;

    l = nd - 1;
    p = v[nd];

    for (i = 0; i < size; i += 16) {
        p0 = v_64(v[l][i]);
        p1 = v_64(v[l][i + 8]);
        for (d = l - 1; d >= 0; --d) {
            p0 ^= v_64(v[d][i]);
            p1 ^= v_64(v[d][i + 8]);
        }
        v_64(p[i]) = p0;
        v_64(p[i + 8]) = p1;
    }
}