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