doc: Fix section of functions age(xid) and mxid_age(xid)
[pgsql.git] / src / port / pg_crc32c_loongarch.c
blob2004b840c8ddfb0d063a6a20c28918e170e95263
1 /*-------------------------------------------------------------------------
3 * pg_crc32c_loongarch.c
4 * Compute CRC-32C checksum using LoongArch CRCC instructions
6 * Portions Copyright (c) 1996-2024, PostgreSQL Global Development Group
7 * Portions Copyright (c) 1994, Regents of the University of California
10 * IDENTIFICATION
11 * src/port/pg_crc32c_loongarch.c
13 *-------------------------------------------------------------------------
15 #include "c.h"
17 #include "port/pg_crc32c.h"
19 pg_crc32c
20 pg_comp_crc32c_loongarch(pg_crc32c crc, const void *data, size_t len)
22 const unsigned char *p = data;
23 const unsigned char *pend = p + len;
26 * LoongArch doesn't require alignment, but aligned memory access is
27 * significantly faster. Process leading bytes so that the loop below
28 * starts with a pointer aligned to eight bytes.
30 if (!PointerIsAligned(p, uint16) &&
31 p + 1 <= pend)
33 crc = __builtin_loongarch_crcc_w_b_w(*p, crc);
34 p += 1;
36 if (!PointerIsAligned(p, uint32) &&
37 p + 2 <= pend)
39 crc = __builtin_loongarch_crcc_w_h_w(*(uint16 *) p, crc);
40 p += 2;
42 if (!PointerIsAligned(p, uint64) &&
43 p + 4 <= pend)
45 crc = __builtin_loongarch_crcc_w_w_w(*(uint32 *) p, crc);
46 p += 4;
49 /* Process eight bytes at a time, as far as we can. */
50 while (p + 8 <= pend)
52 crc = __builtin_loongarch_crcc_w_d_w(*(uint64 *) p, crc);
53 p += 8;
56 /* Process remaining 0-7 bytes. */
57 if (p + 4 <= pend)
59 crc = __builtin_loongarch_crcc_w_w_w(*(uint32 *) p, crc);
60 p += 4;
62 if (p + 2 <= pend)
64 crc = __builtin_loongarch_crcc_w_h_w(*(uint16 *) p, crc);
65 p += 2;
67 if (p < pend)
69 crc = __builtin_loongarch_crcc_w_b_w(*p, crc);
72 return crc;