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