xref: /freebsd/sys/modules/zfs/Makefile (revision 94ca18c18bb0d231c66f146704d9233da48bc84e)
1SRCDIR=${SRCTOP}/sys/contrib/openzfs/module
2INCDIR=${SRCTOP}/sys/contrib/openzfs/include
3
4KMOD=	zfs
5
6.PATH:	${SRCDIR}/avl \
7	${SRCDIR}/lua \
8	${SRCDIR}/nvpair \
9	${SRCDIR}/icp/algs/blake3 \
10	${SRCDIR}/icp/algs/edonr \
11	${SRCDIR}/icp/algs/sha2 \
12	${SRCDIR}/icp/asm-aarch64/blake3 \
13	${SRCDIR}/icp/asm-aarch64/sha2 \
14	${SRCDIR}/icp/asm-arm/sha2 \
15	${SRCDIR}/icp/asm-ppc64/sha2 \
16	${SRCDIR}/icp/asm-ppc64/blake3 \
17	${SRCDIR}/icp/asm-x86_64/blake3 \
18	${SRCDIR}/icp/asm-x86_64/modes \
19	${SRCDIR}/icp/asm-x86_64/sha2 \
20	${SRCDIR}/os/freebsd/spl \
21	${SRCDIR}/os/freebsd/zfs \
22	${SRCDIR}/unicode \
23	${SRCDIR}/zcommon \
24	${SRCDIR}/zfs \
25	${SRCDIR}/zstd \
26	${SRCDIR}/zstd/lib/common \
27	${SRCDIR}/zstd/lib/compress \
28	${SRCDIR}/zstd/lib/decompress
29
30CFLAGS+= -I${INCDIR}
31CFLAGS+= -I${SRCDIR}/icp/include
32CFLAGS+= -I${INCDIR}/os/freebsd
33CFLAGS+= -I${INCDIR}/os/freebsd/spl
34CFLAGS+= -I${INCDIR}/os/freebsd/zfs
35CFLAGS+= -I${SRCDIR}/zstd/include
36CFLAGS+= -I${.CURDIR}
37
38CFLAGS+= -D__KERNEL__ -DFREEBSD_NAMECACHE -DBUILDING_ZFS \
39	-DHAVE_UIO_ZEROCOPY -DWITHOUT_NETDUMP -D__KERNEL -D_SYS_CONDVAR_H_ \
40	-D_SYS_VMEM_H_
41
42.if ${MACHINE_ARCH} == "amd64"
43CFLAGS+= -D__x86_64 -DHAVE_SSE2 -DHAVE_SSSE3 -DHAVE_SSE4_1 -DHAVE_SSE4_2 \
44	-DHAVE_AVX -DHAVE_AVX2 -DHAVE_AVX512F -DHAVE_AVX512VL -DHAVE_AVX512BW \
45	-DHAVE_VAES -DHAVE_VPCLMULQDQ
46.endif
47
48.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "powerpc" || \
49	${MACHINE_ARCH} == "powerpcspe" || ${MACHINE_ARCH} == "arm"
50CFLAGS+= -DBITS_PER_LONG=32
51.else
52CFLAGS+= -DBITS_PER_LONG=64
53.endif
54
55SRCS=	vnode_if.h device_if.h bus_if.h
56
57# avl
58SRCS+=	avl.c
59
60# icp
61SRCS+=	edonr.c
62
63#icp/algs/blake3
64SRCS+=	blake3.c \
65	blake3_generic.c \
66	blake3_impl.c
67
68
69.if ${MACHINE_ARCH} == "aarch64"
70#icp/asm-aarch64/blake3
71SRCS+=	b3_aarch64_sse2.S \
72	b3_aarch64_sse41.S
73.endif
74
75.if ${MACHINE_ARCH} == "powerpc64le"
76#icp/asm-ppc64/blake3
77SRCS+=	b3_ppc64le_sse2.S \
78	b3_ppc64le_sse41.S
79.endif
80
81.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
82#icp/asm-x86_64/blake3
83SRCS+=	blake3_avx2.S \
84	blake3_avx512.S \
85	blake3_sse2.S \
86	blake3_sse41.S
87
88#icp/asm-x86_64/modes
89SRCS+=	aesni-gcm-avx2-vaes.S
90.endif
91
92#icp/algs/sha2
93SRCS+=	sha2_generic.c \
94	sha256_impl.c \
95	sha512_impl.c
96
97.if ${MACHINE_ARCH} == "armv7"
98#icp/asm-arm/sha2
99SRCS+=	sha256-armv7.S \
100	sha512-armv7.S
101.endif
102
103.if ${MACHINE_ARCH} == "aarch64"
104#icp/asm-aarch64/sha2
105OBJS+=	zfs-sha256-armv8.o \
106	zfs-sha512-armv8.o
107.endif
108
109.if ${MACHINE_ARCH} == "powerpc64" || ${MACHINE_ARCH} == "powerpc64le"
110#icp/asm-ppc64/sha2
111SRCS+=	sha256-p8.S \
112	sha512-p8.S \
113	sha256-ppc.S \
114	sha512-ppc.S
115.endif
116
117.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
118#icp/asm-x86_64/sha2
119OBJS+=	zfs-sha256-x86_64.o \
120	zfs-sha512-x86_64.o
121.endif
122
123#lua
124SRCS+=	lapi.c \
125	lauxlib.c \
126	lbaselib.c \
127	lcode.c \
128	lcompat.c \
129	lcorolib.c \
130	lctype.c \
131	ldebug.c \
132	ldo.c \
133	lfunc.c \
134	lgc.c \
135	llex.c \
136	lmem.c \
137	lobject.c \
138	lopcodes.c \
139	lparser.c \
140	lstate.c \
141	lstring.c \
142	lstrlib.c \
143	ltable.c \
144	ltablib.c \
145	ltm.c \
146	lvm.c \
147	lzio.c
148
149#nvpair
150SRCS+=	nvpair.c \
151	fnvpair.c \
152	nvpair_alloc_spl.c \
153	nvpair_alloc_fixed.c
154
155#os/freebsd/spl
156SRCS+=	acl_common.c \
157	callb.c \
158	list.c \
159	spl_acl.c \
160	spl_cmn_err.c \
161	spl_dtrace.c \
162	spl_kmem.c \
163	spl_kstat.c \
164	spl_misc.c \
165	spl_policy.c \
166	spl_procfs_list.c \
167	spl_string.c \
168	spl_sunddi.c \
169	spl_sysevent.c \
170	spl_taskq.c \
171	spl_uio.c \
172	spl_vfs.c \
173	spl_vm.c \
174	spl_zlib.c \
175	spl_zone.c
176
177
178.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "powerpc" || \
179	${MACHINE_ARCH} == "powerpcspe" || ${MACHINE_ARCH} == "arm"
180SRCS+= spl_atomic.c
181.endif
182
183#os/freebsd/zfs
184SRCS+=	abd_os.c \
185	arc_os.c \
186	crypto_os.c \
187	dmu_os.c \
188	event_os.c \
189	hkdf.c \
190	kmod_core.c \
191	spa_os.c \
192	sysctl_os.c \
193	vdev_geom.c \
194	vdev_label_os.c \
195	zfs_acl.c \
196	zfs_ctldir.c \
197	zfs_crrd.c \
198	zfs_debug.c \
199	zfs_dir.c \
200	zfs_ioctl_compat.c \
201	zfs_ioctl_os.c \
202	zfs_racct.c \
203	zfs_vfsops.c \
204	zfs_vnops_os.c \
205	zfs_znode_os.c \
206	zio_crypt.c \
207	zvol_os.c
208
209#unicode
210SRCS+=	u8_textprep.c
211
212#zcommon
213SRCS+=	zfeature_common.c \
214	zfs_comutil.c \
215	zfs_deleg.c \
216	zfs_fletcher.c \
217	zfs_fletcher_avx512.c \
218	zfs_fletcher_intel.c \
219	zfs_fletcher_sse.c \
220	zfs_fletcher_superscalar.c \
221	zfs_fletcher_superscalar4.c \
222	zfs_namecheck.c \
223	zfs_prop.c \
224	zfs_valstr.c \
225	zpool_prop.c \
226	zprop_common.c
227
228#zfs
229SRCS+=	abd.c \
230	aggsum.c \
231	arc.c \
232	blake3_zfs.c \
233	blkptr.c \
234	bplist.c \
235	bpobj.c \
236	brt.c \
237	btree.c \
238	cityhash.c \
239	dbuf.c \
240	dbuf_stats.c \
241	bptree.c \
242	bqueue.c \
243	dataset_kstats.c \
244	ddt.c \
245	ddt_log.c \
246	ddt_stats.c \
247	ddt_zap.c \
248	dmu.c \
249	dmu_direct.c \
250	dmu_diff.c \
251	dmu_object.c \
252	dmu_objset.c \
253	dmu_recv.c \
254	dmu_redact.c \
255	dmu_send.c \
256	dmu_traverse.c \
257	dmu_tx.c \
258	dmu_zfetch.c \
259	dnode.c \
260	dnode_sync.c \
261	dsl_dataset.c \
262	dsl_deadlist.c \
263	dsl_deleg.c \
264	dsl_bookmark.c \
265	dsl_dir.c \
266	dsl_crypt.c \
267	dsl_destroy.c \
268	dsl_pool.c \
269	dsl_prop.c \
270	dsl_scan.c \
271	dsl_synctask.c \
272	dsl_userhold.c \
273	edonr_zfs.c \
274	fm.c \
275	gzip.c \
276	lzjb.c \
277	lz4.c \
278	lz4_zfs.c \
279	metaslab.c \
280	mmp.c \
281	multilist.c \
282	objlist.c \
283	pathname.c \
284	range_tree.c \
285	refcount.c \
286	rrwlock.c \
287	sa.c \
288	sha2_zfs.c \
289	skein_zfs.c \
290	spa.c \
291	spa_checkpoint.c \
292	spa_config.c \
293	spa_errlog.c \
294	spa_history.c \
295	spa_log_spacemap.c \
296	spa_misc.c \
297	spa_stats.c \
298	space_map.c \
299	space_reftree.c \
300	txg.c \
301	uberblock.c \
302	unique.c \
303	vdev.c \
304	vdev_draid.c \
305	vdev_draid_rand.c \
306	vdev_file.c \
307	vdev_indirect.c \
308	vdev_indirect_births.c \
309	vdev_indirect_mapping.c \
310	vdev_initialize.c \
311	vdev_label.c \
312	vdev_mirror.c \
313	vdev_missing.c \
314	vdev_queue.c \
315	vdev_raidz.c \
316	vdev_raidz_math.c \
317	vdev_raidz_math_scalar.c \
318	vdev_raidz_math_avx2.c \
319	vdev_raidz_math_avx512bw.c \
320	vdev_raidz_math_avx512f.c \
321	vdev_raidz_math_sse2.c \
322	vdev_raidz_math_ssse3.c \
323	vdev_rebuild.c \
324	vdev_removal.c \
325	vdev_root.c \
326	vdev_trim.c \
327	zap.c \
328	zap_leaf.c \
329	zap_micro.c \
330	zcp.c \
331	zcp_get.c \
332	zcp_global.c \
333	zcp_iter.c \
334	zcp_set.c \
335	zcp_synctask.c \
336	zfeature.c \
337	zfs_byteswap.c \
338	zfs_chksum.c \
339	zfs_file_os.c \
340	zfs_fm.c \
341	zfs_fuid.c \
342	zfs_impl.c \
343	zfs_ioctl.c \
344	zfs_log.c \
345	zfs_onexit.c \
346	zfs_quota.c \
347	zfs_ratelimit.c \
348	zfs_replay.c \
349	zfs_rlock.c \
350	zfs_sa.c \
351	zfs_vnops.c \
352	zfs_znode.c \
353	zil.c \
354	zio.c \
355	zio_checksum.c \
356	zio_compress.c \
357	zio_inject.c \
358	zle.c \
359	zrlock.c \
360	zthr.c \
361	zvol.c
362
363#zstd
364SRCS+=	zfs_zstd.c \
365	entropy_common.c \
366	error_private.c \
367	fse_compress.c \
368	fse_decompress.c \
369	hist.c \
370	huf_compress.c \
371	huf_decompress.c \
372	pool.c \
373	xxhash.c \
374	zstd_common.c \
375	zstd_compress.c \
376	zstd_compress_literals.c \
377	zstd_compress_sequences.c \
378	zstd_compress_superblock.c \
379	zstd_ddict.c \
380	zstd_decompress.c \
381	zstd_decompress_block.c \
382	zstd_double_fast.c \
383	zstd_fast.c \
384	zstd_lazy.c \
385	zstd_ldm.c \
386	zstd_opt.c
387
388.include <bsd.kmod.mk>
389
390CFLAGS+= -include ${SRCTOP}/sys/cddl/compat/opensolaris/sys/debug_compat.h
391CFLAGS+= -include ${INCDIR}/os/freebsd/spl/sys/ccompile.h
392CFLAGS+= -include ${SRCTOP}/sys/modules/zfs/static_ccompile.h
393
394CFLAGS.sysctl_os.c= -include ${SRCTOP}/sys/modules/zfs/zfs_config.h
395CFLAGS.xxhash.c+= -include ${SRCTOP}/sys/sys/_null.h
396
397CFLAGS.gcc+= -Wno-pointer-to-int-cast
398
399CFLAGS.abd.c= -Wno-cast-qual
400CFLAGS.ddt.c= -Wno-cast-qual
401CFLAGS.ddt_log.c= -Wno-cast-qual -Wno-pointer-arith
402CFLAGS.ddt_zap.c= -Wno-cast-qual
403CFLAGS.dmu.c= -Wno-cast-qual
404CFLAGS.dmu_traverse.c= -Wno-cast-qual
405CFLAGS.dnode.c= ${NO_WUNUSED_BUT_SET_VARIABLE}
406CFLAGS.dsl_deadlist.c= -Wno-cast-qual
407CFLAGS.dsl_dir.c= -Wno-cast-qual
408CFLAGS.dsl_prop.c= -Wno-cast-qual
409CFLAGS.edonr.c= -Wno-cast-qual
410CFLAGS.fm.c= -Wno-cast-qual
411CFLAGS.hist.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
412CFLAGS.lapi.c= -Wno-cast-qual
413CFLAGS.lcompat.c= -Wno-cast-qual
414CFLAGS.ldo.c= ${NO_WINFINITE_RECURSION}
415CFLAGS.lobject.c= -Wno-cast-qual
416CFLAGS.ltable.c= -Wno-cast-qual
417CFLAGS.lvm.c= -Wno-cast-qual
418CFLAGS.lz4.c= -Wno-cast-qual
419CFLAGS.lz4_zfs.c= -Wno-cast-qual
420CFLAGS.nvpair.c= -Wno-cast-qual -DHAVE_RPC_TYPES ${NO_WSTRINGOP_OVERREAD}
421CFLAGS.pool.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
422CFLAGS.pool.c= -U__BMI__ -fno-tree-vectorize
423CFLAGS.spa.c= -Wno-cast-qual
424CFLAGS.spa_misc.c= -Wno-cast-qual
425CFLAGS.spl_string.c= -Wno-cast-qual
426CFLAGS.spl_vm.c= -Wno-cast-qual
427CFLAGS.spl_zlib.c= -Wno-cast-qual
428CFLAGS.u8_textprep.c= -Wno-cast-qual
429CFLAGS.vdev_draid.c= -Wno-cast-qual
430CFLAGS.vdev_raidz.c= -Wno-cast-qual
431CFLAGS.vdev_raidz_math.c= -Wno-cast-qual
432CFLAGS.vdev_raidz_math_avx2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
433CFLAGS.vdev_raidz_math_avx512f.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
434CFLAGS.vdev_raidz_math_scalar.c= -Wno-cast-qual
435CFLAGS.vdev_raidz_math_sse2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
436CFLAGS.zap_leaf.c= -Wno-cast-qual
437CFLAGS.zap_micro.c= -Wno-cast-qual
438CFLAGS.zcp.c= -Wno-cast-qual
439CFLAGS.zfs_fletcher.c= -Wno-cast-qual -Wno-pointer-arith
440CFLAGS.zfs_fletcher_avx512.c= -Wno-cast-qual -Wno-pointer-arith
441CFLAGS.zfs_fletcher_intel.c= -Wno-cast-qual -Wno-pointer-arith
442CFLAGS.zfs_fletcher_sse.c= -Wno-cast-qual -Wno-pointer-arith
443CFLAGS.zfs_fm.c= -Wno-cast-qual ${NO_WUNUSED_BUT_SET_VARIABLE}
444CFLAGS.zfs_ioctl.c= -Wno-cast-qual
445CFLAGS.zfs_log.c= -Wno-cast-qual
446CFLAGS.zfs_vnops_os.c= -Wno-pointer-arith
447CFLAGS.zfs_zstd.c= -Wno-cast-qual -Wno-pointer-arith
448CFLAGS.zil.c= -Wno-cast-qual
449CFLAGS.zio.c= -Wno-cast-qual
450CFLAGS.zprop_common.c= -Wno-cast-qual
451CFLAGS.zrlock.c= -Wno-cast-qual
452
453#zstd
454CFLAGS.entropy_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
455CFLAGS.error_private.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
456CFLAGS.fse_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
457CFLAGS.fse_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
458CFLAGS.huf_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
459CFLAGS.huf_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
460CFLAGS.xxhash.c+= -U__BMI__ -fno-tree-vectorize
461CFLAGS.xxhash.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
462CFLAGS.zstd.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
463CFLAGS.zstd_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
464CFLAGS.zstd_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
465CFLAGS.zstd_compress_literals.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
466CFLAGS.zstd_compress_sequences.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
467CFLAGS.zstd_compress_superblock.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
468CFLAGS.zstd_ddict.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
469CFLAGS.zstd_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
470CFLAGS.zstd_decompress_block.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
471CFLAGS.zstd_double_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
472CFLAGS.zstd_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
473CFLAGS.zstd_lazy.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
474CFLAGS.zstd_ldm.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
475CFLAGS.zstd_opt.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
476
477.if ${MACHINE_ARCH} == "aarch64"
478__ZFS_ZSTD_AARCH64_FLAGS= -include ${SRCDIR}/zstd/include/aarch64_compat.h
479CFLAGS.zstd.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
480CFLAGS.entropy_common.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
481CFLAGS.error_private.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
482CFLAGS.fse_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
483CFLAGS.fse_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
484CFLAGS.hist.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
485CFLAGS.huf_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
486CFLAGS.huf_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
487CFLAGS.pool.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
488CFLAGS.xxhash.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
489CFLAGS.zstd_common.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
490CFLAGS.zstd_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
491CFLAGS.zstd_compress_literals.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
492CFLAGS.zstd_compress_sequences.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
493CFLAGS.zstd_compress_superblock.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
494CFLAGS.zstd_ddict.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
495CFLAGS.zstd_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
496CFLAGS.zstd_decompress_block.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
497CFLAGS.zstd_double_fast.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
498CFLAGS.zstd_fast.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
499CFLAGS.zstd_lazy.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
500CFLAGS.zstd_ldm.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
501CFLAGS.zstd_opt.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
502
503b3_aarch64_sse2.o: b3_aarch64_sse2.S
504	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
505	     -o ${.TARGET}
506	${CTFCONVERT_CMD}
507
508b3_aarch64_sse41.o: b3_aarch64_sse41.S
509	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
510	     -o ${.TARGET}
511	${CTFCONVERT_CMD}
512
513zfs-sha256-armv8.o: sha256-armv8.S
514	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} \
515	    ${SRCDIR}/icp/asm-aarch64/sha2/sha256-armv8.S \
516	    -o ${.TARGET}
517	${CTFCONVERT_CMD}
518
519zfs-sha512-armv8.o: sha512-armv8.S
520	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} \
521	    ${SRCDIR}/icp/asm-aarch64/sha2/sha512-armv8.S \
522	    -o ${.TARGET}
523	${CTFCONVERT_CMD}
524.endif
525
526.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
527zfs-sha256-x86_64.o: sha256-x86_64.S
528	${CC} -c ${CFLAGS} ${WERROR} \
529	    ${SRCDIR}/icp/asm-x86_64/sha2/sha256-x86_64.S \
530	    -o ${.TARGET}
531	${CTFCONVERT_CMD}
532
533zfs-sha512-x86_64.o: sha512-x86_64.S
534	${CC} -c ${CFLAGS} ${WERROR} \
535	    ${SRCDIR}/icp/asm-x86_64/sha2/sha512-x86_64.S \
536	    -o ${.TARGET}
537	${CTFCONVERT_CMD}
538.endif
539