]> git.proxmox.com Git - mirror_zfs.git/blame - include/zfs_fletcher.h
Fletcher4 algorithm implemented in pure NEON for Aarch64 / ARMv8 64 bits
[mirror_zfs.git] / include / zfs_fletcher.h
CommitLineData
428870ff
BB
1/*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21/*
22 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
24 */
3c67d83a
TH
25/*
26 * Copyright 2013 Saso Kiselkov. All rights reserved.
27 */
428870ff
BB
28
29#ifndef _ZFS_FLETCHER_H
30#define _ZFS_FLETCHER_H
31
32#include <sys/types.h>
1eeb4562 33#include <sys/spa_checksum.h>
428870ff
BB
34
35#ifdef __cplusplus
36extern "C" {
37#endif
38
39/*
40 * fletcher checksum functions
fc897b24
GN
41 *
42 * Note: Fletcher checksum methods expect buffer size to be 4B aligned. This
43 * limitation stems from the algorithm design. Performing incremental checksum
44 * without said alignment would yield different results. Therefore, the code
45 * includes assertions for the size alignment.
46 * For compatibility, it is required that some code paths calculate checksum of
47 * non-aligned buffer sizes. For this purpose, `fletcher_4_native_varsize()`
48 * checksum method is added. This method will ignore last (size % 4) bytes of
49 * the data buffer.
428870ff 50 */
3c67d83a
TH
51void fletcher_2_native(const void *, uint64_t, const void *, zio_cksum_t *);
52void fletcher_2_byteswap(const void *, uint64_t, const void *, zio_cksum_t *);
53void fletcher_4_native(const void *, uint64_t, const void *, zio_cksum_t *);
fc897b24 54void fletcher_4_native_varsize(const void *, uint64_t, zio_cksum_t *);
3c67d83a 55void fletcher_4_byteswap(const void *, uint64_t, const void *, zio_cksum_t *);
428870ff
BB
56void fletcher_4_incremental_native(const void *, uint64_t,
57 zio_cksum_t *);
58void fletcher_4_incremental_byteswap(const void *, uint64_t,
59 zio_cksum_t *);
1eeb4562
JX
60int fletcher_4_impl_set(const char *selector);
61void fletcher_4_init(void);
62void fletcher_4_fini(void);
63
fc897b24 64
5bf703b8
GN
65
66/* Internal fletcher ctx */
67
68typedef struct zfs_fletcher_sse {
69 uint64_t v[2] __attribute__((aligned(16)));
70} zfs_fletcher_sse_t;
71
72typedef struct zfs_fletcher_avx {
73 uint64_t v[4] __attribute__((aligned(32)));
74} zfs_fletcher_avx_t;
75
76typedef struct zfs_fletcher_avx512 {
77 uint64_t v[8] __attribute__((aligned(64)));
78} zfs_fletcher_avx512_t;
79
24cdeaf1
RD
80typedef struct zfs_fletcher_aarch64_neon {
81 uint64_t v[2] __attribute__((aligned(16)));
82} zfs_fletcher_aarch64_neon_t;
83
5bf703b8
GN
84
85typedef union fletcher_4_ctx {
86 zio_cksum_t scalar;
87
88#if defined(HAVE_SSE2) || (defined(HAVE_SSE2) && defined(HAVE_SSSE3))
89 zfs_fletcher_sse_t sse[4];
90#endif
91#if defined(HAVE_AVX) && defined(HAVE_AVX2)
92 zfs_fletcher_avx_t avx[4];
93#endif
94#if defined(__x86_64) && defined(HAVE_AVX512F)
95 zfs_fletcher_avx512_t avx512[4];
96#endif
24cdeaf1
RD
97#if defined(__aarch64__)
98 zfs_fletcher_aarch64_neon_t aarch64_neon[4];
99#endif
5bf703b8
GN
100} fletcher_4_ctx_t;
101
1eeb4562
JX
102/*
103 * fletcher checksum struct
104 */
5bf703b8
GN
105typedef void (*fletcher_4_init_f)(fletcher_4_ctx_t *);
106typedef void (*fletcher_4_fini_f)(fletcher_4_ctx_t *, zio_cksum_t *);
107typedef void (*fletcher_4_compute_f)(fletcher_4_ctx_t *,
108 const void *, uint64_t);
fc897b24 109
1eeb4562 110typedef struct fletcher_4_func {
fc897b24
GN
111 fletcher_4_init_f init_native;
112 fletcher_4_fini_f fini_native;
113 fletcher_4_compute_f compute_native;
114 fletcher_4_init_f init_byteswap;
115 fletcher_4_fini_f fini_byteswap;
116 fletcher_4_compute_f compute_byteswap;
1eeb4562
JX
117 boolean_t (*valid)(void);
118 const char *name;
119} fletcher_4_ops_t;
120
5bf703b8 121
35a76a03
TS
122#if defined(HAVE_SSE2)
123extern const fletcher_4_ops_t fletcher_4_sse2_ops;
124#endif
125
126#if defined(HAVE_SSE2) && defined(HAVE_SSSE3)
127extern const fletcher_4_ops_t fletcher_4_ssse3_ops;
128#endif
129
1eeb4562
JX
130#if defined(HAVE_AVX) && defined(HAVE_AVX2)
131extern const fletcher_4_ops_t fletcher_4_avx2_ops;
132#endif
428870ff 133
70b258fc
GN
134#if defined(__x86_64) && defined(HAVE_AVX512F)
135extern const fletcher_4_ops_t fletcher_4_avx512f_ops;
136#endif
137
24cdeaf1
RD
138#if defined(__aarch64__)
139extern const fletcher_4_ops_t fletcher_4_aarch64_neon_ops;
140#endif
141
428870ff
BB
142#ifdef __cplusplus
143}
144#endif
145
146#endif /* _ZFS_FLETCHER_H */