@zigc/lib 0.17.0-dev.76 → 0.17.0-dev.813
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/c/fcntl.zig +5 -0
- package/c/math.zig +41 -2
- package/c/pthread.zig +57 -0
- package/c/stdlib.zig +32 -22
- package/c/string.zig +20 -0
- package/c/unistd.zig +1 -0
- package/c/wchar.zig +10 -0
- package/c.zig +1 -0
- package/{std/Build → compiler/Maker}/Fuzz.zig +177 -89
- package/compiler/Maker/Graph.zig +85 -0
- package/compiler/Maker/PkgConfig.zig +122 -0
- package/compiler/Maker/ScannedConfig.zig +372 -0
- package/compiler/Maker/Step/CheckFile.zig +63 -0
- package/compiler/Maker/Step/Compile.zig +1388 -0
- package/compiler/Maker/Step/ConfigHeader.zig +610 -0
- package/compiler/Maker/Step/FindProgram.zig +120 -0
- package/compiler/Maker/Step/Fmt.zig +65 -0
- package/compiler/Maker/Step/InstallArtifact.zig +141 -0
- package/compiler/Maker/Step/InstallDir.zig +99 -0
- package/compiler/Maker/Step/InstallFile.zig +26 -0
- package/compiler/Maker/Step/ObjCopy.zig +173 -0
- package/compiler/Maker/Step/Options.zig +104 -0
- package/compiler/Maker/Step/Run.zig +2390 -0
- package/compiler/Maker/Step/TranslateC.zig +157 -0
- package/compiler/Maker/Step/UpdateSourceFiles.zig +89 -0
- package/compiler/Maker/Step/WriteFile.zig +294 -0
- package/compiler/Maker/Step.zig +894 -0
- package/{std/Build → compiler/Maker}/Watch/FsEvents.zig +36 -26
- package/{std/Build → compiler/Maker}/Watch.zig +89 -68
- package/{std/Build → compiler/Maker}/WebServer.zig +145 -118
- package/compiler/Maker.zig +2061 -0
- package/compiler/aro/aro/Attribute.zig +52 -51
- package/compiler/aro/aro/CodeGen.zig +7 -8
- package/compiler/aro/aro/Compilation.zig +22 -22
- package/compiler/aro/aro/Diagnostics.zig +7 -7
- package/compiler/aro/aro/Driver.zig +18 -16
- package/compiler/aro/aro/Parser.zig +22 -17
- package/compiler/aro/aro/Pragma.zig +3 -2
- package/compiler/aro/aro/Preprocessor.zig +11 -8
- package/compiler/aro/aro/Tree.zig +11 -11
- package/compiler/aro/aro/features.zig +4 -4
- package/compiler/aro/aro/pragmas/message.zig +3 -2
- package/compiler/aro/aro/text_literal.zig +5 -4
- package/compiler/aro/assembly_backend/x86_64.zig +4 -4
- package/compiler/aro/backend/Interner.zig +14 -13
- package/compiler/aro/backend/Ir/x86/Renderer.zig +3 -3
- package/compiler/configurer.zig +1402 -0
- package/compiler/reduce/Walk.zig +8 -13
- package/compiler/resinator/bmp.zig +3 -2
- package/compiler/resinator/code_pages.zig +14 -12
- package/compiler/resinator/compile.zig +1 -1
- package/compiler/resinator/cvtres.zig +15 -14
- package/compiler/resinator/errors.zig +25 -29
- package/compiler/resinator/ico.zig +4 -4
- package/compiler/resinator/lang.zig +7 -7
- package/compiler/resinator/parse.zig +3 -3
- package/compiler/resinator/res.zig +1 -1
- package/compiler/std-docs.zig +17 -38
- package/compiler/test_runner.zig +25 -15
- package/compiler/translate-c/MacroTranslator.zig +1 -1
- package/compiler/translate-c/Translator.zig +2 -2
- package/compiler/translate-c/ast.zig +22 -29
- package/compiler/translate-c/main.zig +1 -1
- package/compiler_rt/addf3.zig +1 -1
- package/compiler_rt/arm.zig +3 -3
- package/compiler_rt/atomics.zig +1 -1
- package/compiler_rt/comparef.zig +3 -3
- package/compiler_rt/cos.zig +1 -1
- package/compiler_rt/count0bits.zig +1 -1
- package/compiler_rt/divdf3.zig +2 -2
- package/compiler_rt/divsf3.zig +1 -1
- package/compiler_rt/divtf3.zig +1 -1
- package/compiler_rt/divxf3.zig +1 -1
- package/compiler_rt/extendf.zig +5 -5
- package/compiler_rt/fabs.zig +1 -1
- package/compiler_rt/float_from_int.zig +4 -5
- package/compiler_rt/fmax.zig +1 -1
- package/compiler_rt/fmin.zig +1 -1
- package/compiler_rt/fmod.zig +2 -2
- package/compiler_rt/int_from_float.zig +1 -1
- package/compiler_rt/limb64.zig +3 -34
- package/compiler_rt/log.zig +230 -3
- package/compiler_rt/log10.zig +228 -3
- package/compiler_rt/log2.zig +221 -3
- package/compiler_rt/log_f128.zig +173 -0
- package/compiler_rt/mulf3.zig +2 -2
- package/compiler_rt/rem_pio2l.zig +1 -1
- package/compiler_rt/sin.zig +1 -1
- package/compiler_rt/sincos.zig +1 -1
- package/compiler_rt/ssp.zig +2 -2
- package/compiler_rt/tan.zig +1 -1
- package/compiler_rt/truncf.zig +3 -3
- package/compiler_rt/trunctfhf2.zig +3 -0
- package/compiler_rt.zig +5 -26
- package/docs/main.js +8 -8
- package/docs/wasm/Walk.zig +1 -3
- package/docs/wasm/html_render.zig +1 -2
- package/docs/wasm/markdown/Document.zig +3 -3
- package/docs/wasm/markdown/Parser.zig +19 -23
- package/fuzzer.zig +5 -3
- package/include/__clang_spirv_builtins.h +12 -12
- package/include/__float_float.h +176 -0
- package/include/__float_header_macro.h +12 -0
- package/include/__float_infinity_nan.h +20 -0
- package/include/amo.h +131 -0
- package/include/amxavx512intrin.h +215 -1
- package/include/amxintrin.h +0 -2
- package/include/arm_acle.h +37 -27
- package/include/arm_neon.h +218 -82
- package/include/arm_sme.h +8 -8
- package/include/arm_sve.h +4162 -3782
- package/include/avx10_2_512bf16intrin.h +19 -12
- package/include/avx10_2_512convertintrin.h +1 -1
- package/include/avx10_2_512niintrin.h +31 -31
- package/include/avx10_2_512satcvtdsintrin.h +1 -1
- package/include/avx10_2bf16intrin.h +54 -45
- package/include/avx10_2convertintrin.h +2 -2
- package/include/avx10_2copyintrin.h +1 -1
- package/include/avx10_2niintrin.h +14 -14
- package/include/avx10_2satcvtdsintrin.h +2 -2
- package/include/avx2intrin.h +275 -377
- package/include/avx512bf16intrin.h +25 -16
- package/include/avx512bitalgintrin.h +19 -30
- package/include/avx512bwintrin.h +386 -505
- package/include/avx512cdintrin.h +42 -55
- package/include/avx512dqintrin.h +132 -161
- package/include/avx512fintrin.h +1015 -1424
- package/include/avx512fp16intrin.h +112 -110
- package/include/avx512ifmaintrin.h +32 -34
- package/include/avx512ifmavlintrin.h +73 -46
- package/include/avx512vbmi2intrin.h +43 -32
- package/include/avx512vbmiintrin.h +19 -27
- package/include/avx512vbmivlintrin.h +35 -49
- package/include/avx512vlbf16intrin.h +32 -22
- package/include/avx512vlbitalgintrin.h +37 -53
- package/include/avx512vlbwintrin.h +470 -573
- package/include/avx512vlcdintrin.h +74 -102
- package/include/avx512vldqintrin.h +110 -127
- package/include/avx512vlfp16intrin.h +130 -111
- package/include/avx512vlintrin.h +945 -1299
- package/include/avx512vlvbmi2intrin.h +78 -63
- package/include/avx512vlvnniintrin.h +21 -18
- package/include/avx512vlvp2intersectintrin.h +2 -2
- package/include/avx512vnniintrin.h +10 -10
- package/include/avx512vp2intersectintrin.h +1 -2
- package/include/avx512vpopcntdqintrin.h +8 -10
- package/include/avx512vpopcntdqvlintrin.h +17 -15
- package/include/avxifmaintrin.h +16 -0
- package/include/avxintrin.h +165 -241
- package/include/avxvnniint16intrin.h +118 -99
- package/include/avxvnniint8intrin.h +56 -32
- package/include/avxvnniintrin.h +16 -8
- package/include/cpuid.h +101 -4
- package/include/emmintrin.h +168 -168
- package/include/f16cintrin.h +23 -9
- package/include/float.h +16 -155
- package/include/fma4intrin.h +98 -96
- package/include/fmaintrin.h +96 -66
- package/include/gfniintrin.h +21 -16
- package/include/hexagon_types.h +23 -20
- package/include/hvx_hexagon_protos.h +649 -860
- package/include/immintrin.h +0 -12
- package/include/intrin.h +4 -0
- package/include/lasxintrin.h +113 -0
- package/include/llvm_libc_wrappers/assert.h +3 -5
- package/include/llvm_libc_wrappers/ctype.h +3 -115
- package/include/llvm_libc_wrappers/inttypes.h +3 -5
- package/include/llvm_libc_wrappers/stdio.h +10 -38
- package/include/llvm_libc_wrappers/stdlib.h +3 -24
- package/include/llvm_libc_wrappers/string.h +2 -70
- package/include/llvm_libc_wrappers/time.h +4 -10
- package/include/mmintrin.h +188 -257
- package/include/module.modulemap +23 -4
- package/include/movrs_avx10_2_512intrin.h +2 -2
- package/include/movrs_avx10_2intrin.h +4 -4
- package/include/pmmintrin.h +12 -24
- package/include/ptrauth.h +16 -2
- package/include/riscv_mips.h +34 -0
- package/include/riscv_nds.h +89 -0
- package/include/sifive_vector.h +58 -2
- package/include/sm4evexintrin.h +2 -2
- package/include/smmintrin.h +77 -59
- package/include/spirvintrin.h +194 -0
- package/include/stddefer.h +19 -0
- package/include/tmmintrin.h +116 -147
- package/include/vaesintrin.h +1 -2
- package/include/xmmintrin.h +44 -70
- package/include/xopintrin.h +20 -10
- package/init/build.zig +1 -3
- package/libc/darwin/SDKSettings.json +1 -1
- package/libc/darwin/libSystem.tbd +88 -87
- package/libc/include/aarch64-linux-any/asm/hwcap.h +1 -0
- package/libc/include/aarch64-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/aarch64-netbsd-none/aarch64/armreg.h +259 -22
- package/libc/include/aarch64-netbsd-none/aarch64/byte_swap.h +3 -2
- package/libc/include/aarch64-netbsd-none/aarch64/cpu.h +26 -1
- package/libc/include/aarch64-netbsd-none/aarch64/lwp_private.h +3 -0
- package/libc/include/aarch64-netbsd-none/aarch64/pmap.h +7 -33
- package/libc/include/aarch64-netbsd-none/aarch64/sljit_machdep.h +1 -1
- package/libc/include/aarch64-netbsd-none/aarch64/vmparam.h +4 -4
- package/libc/include/aarch64-netbsd-none/machine/armreg.h +259 -22
- package/libc/include/aarch64-netbsd-none/machine/byte_swap.h +3 -2
- package/libc/include/aarch64-netbsd-none/machine/cpu.h +26 -1
- package/libc/include/aarch64-netbsd-none/machine/lwp_private.h +3 -0
- package/libc/include/aarch64-netbsd-none/machine/pmap.h +7 -33
- package/libc/include/aarch64-netbsd-none/machine/sljit_machdep.h +1 -1
- package/libc/include/aarch64-netbsd-none/machine/vmparam.h +4 -4
- package/libc/include/aarch64-openbsd-none/arm64/cpu.h +7 -1
- package/libc/include/aarch64-openbsd-none/arm64/intr.h +9 -1
- package/libc/include/aarch64-openbsd-none/machine/cpu.h +7 -1
- package/libc/include/aarch64-openbsd-none/machine/intr.h +9 -1
- package/libc/include/any-darwin-any/AvailabilityInternal.h +10 -10
- package/libc/include/any-darwin-any/AvailabilityVersions.h +8 -0
- package/libc/include/any-darwin-any/mach/host_info.h +3 -1
- package/libc/include/any-darwin-any/mach/mach_voucher_types.h +2 -0
- package/libc/include/any-darwin-any/mach/vm_statistics.h +33 -2
- package/libc/include/any-darwin-any/spawn.h +3 -1
- package/libc/include/any-darwin-any/sys/_symbol_aliasing.h +12 -0
- package/libc/include/any-linux-any/asm-generic/errno.h +2 -0
- package/libc/include/any-linux-any/asm-generic/unistd.h +4 -1
- package/libc/include/any-linux-any/drm/amdgpu_drm.h +20 -6
- package/libc/include/any-linux-any/drm/amdxdna_accel.h +8 -0
- package/libc/include/any-linux-any/drm/drm_fourcc.h +6 -6
- package/libc/include/any-linux-any/drm/panfrost_drm.h +75 -1
- package/libc/include/any-linux-any/drm/panthor_drm.h +154 -3
- package/libc/include/any-linux-any/drm/rocket_accel.h +74 -24
- package/libc/include/any-linux-any/drm/xe_drm.h +89 -6
- package/libc/include/any-linux-any/linux/android/binder.h +1 -1
- package/libc/include/any-linux-any/linux/bpf.h +28 -0
- package/libc/include/any-linux-any/linux/btrfs.h +1 -0
- package/libc/include/any-linux-any/linux/btrfs_tree.h +32 -2
- package/libc/include/any-linux-any/linux/dma-buf.h +1 -0
- package/libc/include/any-linux-any/linux/dpll.h +1 -0
- package/libc/include/any-linux-any/linux/elf.h +2 -0
- package/libc/include/any-linux-any/linux/ethtool.h +21 -5
- package/libc/include/any-linux-any/linux/fs.h +1 -0
- package/libc/include/any-linux-any/linux/hyperv.h +1 -1
- package/libc/include/any-linux-any/linux/idxd.h +134 -134
- package/libc/include/any-linux-any/linux/if_alg.h +1 -1
- package/libc/include/any-linux-any/linux/if_link.h +1 -0
- package/libc/include/any-linux-any/linux/input-event-codes.h +4 -0
- package/libc/include/any-linux-any/linux/io_uring/bpf_filter.h +68 -0
- package/libc/include/any-linux-any/linux/io_uring/query.h +5 -1
- package/libc/include/any-linux-any/linux/io_uring.h +33 -2
- package/libc/include/any-linux-any/linux/iommufd.h +39 -0
- package/libc/include/any-linux-any/linux/kfd_ioctl.h +13 -3
- package/libc/include/any-linux-any/linux/kfd_sysfs.h +2 -1
- package/libc/include/any-linux-any/linux/kvm.h +30 -6
- package/libc/include/any-linux-any/linux/landlock.h +22 -8
- package/libc/include/any-linux-any/linux/magic.h +1 -0
- package/libc/include/any-linux-any/linux/mempolicy.h +3 -0
- package/libc/include/any-linux-any/linux/mount.h +11 -2
- package/libc/include/any-linux-any/linux/mptcp_pm.h +1 -1
- package/libc/include/any-linux-any/linux/mshv.h +2 -0
- package/libc/include/any-linux-any/linux/netfilter_bridge.h +5 -4
- package/libc/include/any-linux-any/linux/netfilter_ipv4.h +4 -5
- package/libc/include/any-linux-any/linux/netfilter_ipv6.h +3 -4
- package/libc/include/any-linux-any/linux/nfs.h +1 -1
- package/libc/include/any-linux-any/linux/nfsd_netlink.h +1 -0
- package/libc/include/any-linux-any/linux/nilfs2_api.h +2 -2
- package/libc/include/any-linux-any/linux/nilfs2_ondisk.h +97 -66
- package/libc/include/any-linux-any/linux/nl80211.h +104 -3
- package/libc/include/any-linux-any/linux/pci.h +7 -0
- package/libc/include/any-linux-any/linux/pci_regs.h +65 -6
- package/libc/include/any-linux-any/linux/pcitest.h +1 -0
- package/libc/include/any-linux-any/linux/perf_event.h +24 -3
- package/libc/include/any-linux-any/linux/pkt_sched.h +1 -0
- package/libc/include/any-linux-any/linux/prctl.h +30 -0
- package/libc/include/any-linux-any/linux/rseq.h +62 -5
- package/libc/include/any-linux-any/linux/shm.h +0 -1
- package/libc/include/any-linux-any/linux/stddef.h +4 -0
- package/libc/include/any-linux-any/linux/sysctl.h +1 -2
- package/libc/include/any-linux-any/linux/taskstats.h +12 -1
- package/libc/include/any-linux-any/linux/tcp.h +23 -3
- package/libc/include/any-linux-any/linux/typelimits.h +8 -0
- package/libc/include/any-linux-any/linux/ublk_cmd.h +120 -1
- package/libc/include/any-linux-any/linux/v4l2-controls.h +63 -0
- package/libc/include/any-linux-any/linux/vbox_vmmdev_types.h +2 -2
- package/libc/include/any-linux-any/linux/vduse.h +80 -5
- package/libc/include/any-linux-any/linux/version.h +3 -3
- package/libc/include/any-linux-any/linux/vfio.h +4 -0
- package/libc/include/any-linux-any/linux/videodev2.h +3 -0
- package/libc/include/any-linux-any/linux/virtio_ring.h +1 -2
- package/libc/include/any-linux-any/linux/vmclock-abi.h +20 -0
- package/libc/include/any-linux-any/rdma/bnxt_re-abi.h +16 -0
- package/libc/include/any-linux-any/rdma/ib_user_ioctl_cmds.h +16 -0
- package/libc/include/any-linux-any/rdma/mana-abi.h +3 -0
- package/libc/include/any-linux-any/scsi/scsi_bsg_ufs.h +8 -9
- package/libc/include/any-linux-any/sound/sof/tokens.h +6 -0
- package/libc/include/arc-linux-any/asm/swab.h +0 -63
- package/libc/include/arc-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/arm-linux-any/asm/ptrace.h +0 -9
- package/libc/include/arm-linux-any/asm/unistd-eabi.h +1 -0
- package/libc/include/arm-linux-any/asm/unistd-oabi.h +1 -0
- package/libc/include/arm-netbsd-eabi/float.h +2 -1
- package/libc/include/arm-netbsd-eabi/machine/asm.h +48 -19
- package/libc/include/arm-netbsd-eabi/machine/byte_swap.h +121 -0
- package/libc/include/arm-netbsd-eabi/machine/cpu.h +1 -3
- package/libc/include/arm-netbsd-eabi/machine/float.h +2 -1
- package/libc/include/arm-netbsd-eabi/machine/lwp_private.h +81 -0
- package/libc/include/arm-netbsd-eabi/machine/mcontext.h +5 -51
- package/libc/include/arm-netbsd-eabi/machine/mutex.h +1 -1
- package/libc/include/arm-netbsd-eabi/machine/proc.h +2 -2
- package/libc/include/arm-netbsd-eabi/machine/profile.h +28 -96
- package/libc/include/arm-netbsd-eabi/machine/setjmp.h +7 -6
- package/libc/include/arm-netbsd-eabi/machine/sysarch.h +85 -0
- package/libc/include/csky-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/generic-netbsd/altq/altq.h +2 -2
- package/libc/include/generic-netbsd/altq/altq_afmap.h +2 -1
- package/libc/include/generic-netbsd/altq/altq_classq.h +8 -6
- package/libc/include/generic-netbsd/altq/altq_jobs.h +37 -37
- package/libc/include/generic-netbsd/altq/altq_rmclass.h +8 -8
- package/libc/include/generic-netbsd/altq/altq_var.h +2 -2
- package/libc/include/generic-netbsd/arm/arm32/pmap.h +8 -32
- package/libc/include/generic-netbsd/arm/arm32/vmparam.h +5 -5
- package/libc/include/generic-netbsd/arm/asm.h +48 -19
- package/libc/include/generic-netbsd/arm/byte_swap.h +2 -2
- package/libc/include/generic-netbsd/arm/cpu.h +1 -3
- package/libc/include/generic-netbsd/arm/cputypes.h +12 -1
- package/libc/include/generic-netbsd/arm/float.h +2 -1
- package/libc/include/generic-netbsd/arm/lwp_private.h +81 -0
- package/libc/include/generic-netbsd/arm/mcontext.h +5 -51
- package/libc/include/generic-netbsd/arm/mutex.h +1 -1
- package/libc/include/generic-netbsd/arm/proc.h +2 -2
- package/libc/include/generic-netbsd/arm/profile.h +28 -96
- package/libc/include/generic-netbsd/arm/setjmp.h +7 -6
- package/libc/include/generic-netbsd/arpa/nameser.h +3 -3
- package/libc/include/generic-netbsd/arpa/nameser_compat.h +3 -3
- package/libc/include/generic-netbsd/assert.h +12 -22
- package/libc/include/generic-netbsd/bitstring.h +5 -5
- package/libc/include/generic-netbsd/cdbw.h +2 -2
- package/libc/include/generic-netbsd/crypto/cryptodev.h +99 -92
- package/libc/include/generic-netbsd/dev/i2c/emcfaninfo.h +234 -0
- package/libc/include/generic-netbsd/dev/i2c/emcfanreg.h +127 -0
- package/libc/include/generic-netbsd/dev/i2o/i2o.h +3 -366
- package/libc/include/generic-netbsd/dev/ic/hd44780var.h +3 -1
- package/libc/include/generic-netbsd/dev/ic/scmdreg.h +2 -2
- package/libc/include/generic-netbsd/dev/ic/stireg.h +777 -0
- package/libc/include/generic-netbsd/dev/ic/summitreg.h +214 -0
- package/libc/include/generic-netbsd/dev/iscsi/iscsi.h +1 -1
- package/libc/include/generic-netbsd/dev/pci/amrreg.h +2 -2
- package/libc/include/generic-netbsd/dev/pci/mlyreg.h +2 -2
- package/libc/include/generic-netbsd/dev/pci/pcidevs.h +177 -22
- package/libc/include/generic-netbsd/dev/pci/pcidevs_data.h +14971 -14588
- package/libc/include/generic-netbsd/dev/pci/pcireg.h +14 -14
- package/libc/include/generic-netbsd/dev/pckbc/pckbdreg.h +2 -1
- package/libc/include/generic-netbsd/dev/pcmcia/if_rayreg.h +2 -2
- package/libc/include/generic-netbsd/dev/raidframe/raidframeio.h +1 -1
- package/libc/include/generic-netbsd/dev/scsipi/scsi_disk.h +42 -7
- package/libc/include/generic-netbsd/dev/scsipi/scsi_spc.h +2 -2
- package/libc/include/generic-netbsd/dev/scsipi/scsipi_all.h +83 -2
- package/libc/include/generic-netbsd/dev/scsipi/scsipiconf.h +3 -1
- package/libc/include/generic-netbsd/dev/tc/sfbreg.h +3 -3
- package/libc/include/generic-netbsd/dev/tc/sticio.h +2 -2
- package/libc/include/generic-netbsd/dev/usb/umcpmio_hid_reports.h +499 -0
- package/libc/include/generic-netbsd/dev/usb/umcpmio_io.h +45 -0
- package/libc/include/generic-netbsd/dev/usb/usb.h +44 -6
- package/libc/include/generic-netbsd/dev/vndvar.h +2 -2
- package/libc/include/generic-netbsd/dev/wscons/wsconsio.h +19 -1
- package/libc/include/generic-netbsd/dev/wscons/wsksymdef.h +2 -2
- package/libc/include/generic-netbsd/dirent.h +1 -1
- package/libc/include/generic-netbsd/dlfcn.h +4 -2
- package/libc/include/generic-netbsd/elf.h +32 -20
- package/libc/include/generic-netbsd/elfdefinitions.h +1 -1
- package/libc/include/generic-netbsd/evbarm/intr.h +1 -1
- package/libc/include/generic-netbsd/evbmips/lwp_private.h +3 -0
- package/libc/include/generic-netbsd/execinfo.h +4 -2
- package/libc/include/generic-netbsd/fcntl.h +26 -2
- package/libc/include/generic-netbsd/float.h +58 -2
- package/libc/include/generic-netbsd/fmtmsg.h +2 -2
- package/libc/include/generic-netbsd/fs/hfs/libhfs.h +1 -1
- package/libc/include/generic-netbsd/fs/nilfs/nilfs_fs.h +2 -2
- package/libc/include/generic-netbsd/gelf.h +2 -2
- package/libc/include/generic-netbsd/i386/asm.h +12 -4
- package/libc/include/generic-netbsd/i386/byte_swap.h +2 -2
- package/libc/include/generic-netbsd/i386/cpu.h +15 -4
- package/libc/include/generic-netbsd/i386/elf_machdep.h +2 -1
- package/libc/include/generic-netbsd/i386/lwp_private.h +3 -0
- package/libc/include/generic-netbsd/i386/mcontext.h +6 -24
- package/libc/include/generic-netbsd/i386/param.h +9 -1
- package/libc/include/generic-netbsd/i386/pcb.h +6 -2
- package/libc/include/generic-netbsd/i386/ptrace.h +2 -2
- package/libc/include/generic-netbsd/i386/types.h +2 -1
- package/libc/include/generic-netbsd/i386/wchar_limits.h +1 -1
- package/libc/include/generic-netbsd/isofs/cd9660/cd9660_extern.h +6 -1
- package/libc/include/generic-netbsd/isofs/cd9660/cd9660_mount.h +7 -1
- package/libc/include/generic-netbsd/langinfo.h +2 -1
- package/libc/include/generic-netbsd/lauxlib.h +1 -1
- package/libc/include/generic-netbsd/libelf.h +6 -15
- package/libc/include/generic-netbsd/limits.h +1 -1
- package/libc/include/generic-netbsd/lua.h +1 -1
- package/libc/include/generic-netbsd/luaconf.h +1 -1
- package/libc/include/generic-netbsd/lualib.h +1 -1
- package/libc/include/generic-netbsd/lwp.h +1 -1
- package/libc/include/generic-netbsd/machine/ansi.h +2 -2
- package/libc/include/generic-netbsd/machine/aout_machdep.h +39 -2
- package/libc/include/generic-netbsd/machine/arm32/pmap.h +8 -32
- package/libc/include/generic-netbsd/machine/arm32/vmparam.h +5 -5
- package/libc/include/generic-netbsd/machine/asm.h +271 -2
- package/libc/include/generic-netbsd/machine/bswap.h +9 -1
- package/libc/include/generic-netbsd/machine/byte_swap.h +42 -64
- package/libc/include/generic-netbsd/machine/cdefs.h +7 -2
- package/libc/include/generic-netbsd/machine/cpu.h +207 -30
- package/libc/include/generic-netbsd/machine/cputypes.h +12 -1
- package/libc/include/generic-netbsd/machine/disklabel.h +41 -42
- package/libc/include/generic-netbsd/machine/elf_machdep.h +143 -2
- package/libc/include/generic-netbsd/machine/endian.h +1 -1
- package/libc/include/generic-netbsd/machine/fenv.h +35 -2
- package/libc/include/generic-netbsd/machine/float.h +58 -2
- package/libc/include/generic-netbsd/machine/frame.h +129 -2
- package/libc/include/generic-netbsd/machine/ieee.h +3 -2
- package/libc/include/generic-netbsd/machine/ieeefp.h +43 -2
- package/libc/include/generic-netbsd/machine/int_const.h +32 -2
- package/libc/include/generic-netbsd/machine/int_fmtio.h +380 -2
- package/libc/include/generic-netbsd/machine/int_limits.h +2 -2
- package/libc/include/generic-netbsd/machine/int_mwgwtypes.h +2 -2
- package/libc/include/generic-netbsd/machine/int_types.h +2 -2
- package/libc/include/generic-netbsd/machine/kcore.h +39 -2
- package/libc/include/generic-netbsd/machine/limits.h +2 -2
- package/libc/include/generic-netbsd/machine/lock.h +2 -2
- package/libc/include/generic-netbsd/machine/lwp_private.h +83 -0
- package/libc/include/generic-netbsd/machine/math.h +3 -2
- package/libc/include/generic-netbsd/machine/mcontext.h +149 -2
- package/libc/include/generic-netbsd/machine/mutex.h +127 -2
- package/libc/include/generic-netbsd/machine/param.h +90 -23
- package/libc/include/generic-netbsd/machine/pcb.h +54 -2
- package/libc/include/generic-netbsd/machine/pmap.h +262 -2
- package/libc/include/generic-netbsd/machine/proc.h +75 -2
- package/libc/include/generic-netbsd/machine/profile.h +116 -2
- package/libc/include/generic-netbsd/machine/psl.h +2 -2
- package/libc/include/generic-netbsd/machine/pte.h +346 -2
- package/libc/include/generic-netbsd/machine/ptrace.h +62 -2
- package/libc/include/generic-netbsd/machine/reg.h +124 -2
- package/libc/include/generic-netbsd/machine/reloc.h +2 -2
- package/libc/include/generic-netbsd/machine/setjmp.h +69 -2
- package/libc/include/generic-netbsd/machine/signal.h +39 -2
- package/libc/include/generic-netbsd/machine/sljit_machdep.h +1 -1
- package/libc/include/generic-netbsd/machine/sysarch.h +2 -84
- package/libc/include/generic-netbsd/machine/sysreg.h +354 -0
- package/libc/include/generic-netbsd/machine/trap.h +2 -2
- package/libc/include/generic-netbsd/machine/types.h +118 -6
- package/libc/include/generic-netbsd/machine/vmparam.h +235 -2
- package/libc/include/generic-netbsd/machine/wchar_limits.h +2 -2
- package/libc/include/generic-netbsd/math.h +19 -6
- package/libc/include/generic-netbsd/md2.h +6 -3
- package/libc/include/generic-netbsd/mips/asm.h +69 -17
- package/libc/include/generic-netbsd/mips/bswap.h +3 -1
- package/libc/include/generic-netbsd/mips/cpu.h +7 -7
- package/libc/include/generic-netbsd/mips/elf_machdep.h +2 -1
- package/libc/include/generic-netbsd/mips/fenv.h +2 -1
- package/libc/include/generic-netbsd/mips/float.h +3 -2
- package/libc/include/generic-netbsd/mips/frame.h +3 -2
- package/libc/include/generic-netbsd/mips/limits.h +4 -13
- package/libc/include/generic-netbsd/mips/lwp_private.h +87 -0
- package/libc/include/generic-netbsd/mips/mcontext.h +2 -53
- package/libc/include/generic-netbsd/mips/mips3_pte.h +2 -2
- package/libc/include/generic-netbsd/mips/mips_param.h +16 -2
- package/libc/include/generic-netbsd/mips/mutex.h +1 -1
- package/libc/include/generic-netbsd/mips/types.h +1 -1
- package/libc/include/generic-netbsd/mips/vmparam.h +1 -1
- package/libc/include/generic-netbsd/miscfs/kernfs/kernfs.h +2 -2
- package/libc/include/generic-netbsd/miscfs/procfs/procfs.h +33 -2
- package/libc/include/generic-netbsd/miscfs/specfs/specdev.h +1 -2
- package/libc/include/generic-netbsd/monetary.h +2 -1
- package/libc/include/generic-netbsd/net/agr/if_agrioctl.h +2 -2
- package/libc/include/generic-netbsd/net/bpf.h +11 -4
- package/libc/include/generic-netbsd/net/bpfdesc.h +1 -1
- package/libc/include/generic-netbsd/net/dlt.h +222 -48
- package/libc/include/generic-netbsd/net/if.h +20 -5
- package/libc/include/generic-netbsd/net/if_bridgevar.h +2 -3
- package/libc/include/generic-netbsd/net/if_ether.h +4 -3
- package/libc/include/generic-netbsd/net/if_lagg.h +2 -2
- package/libc/include/generic-netbsd/net/if_media.h +2 -2
- package/libc/include/generic-netbsd/net/if_ppp.h +1 -3
- package/libc/include/generic-netbsd/net/if_stats.h +19 -5
- package/libc/include/generic-netbsd/net/net_stats.h +13 -6
- package/libc/include/generic-netbsd/net/npf.h +33 -5
- package/libc/include/generic-netbsd/net/pfkeyv2.h +1 -1
- package/libc/include/generic-netbsd/net/route.h +4 -4
- package/libc/include/generic-netbsd/net80211/ieee80211_node.h +3 -2
- package/libc/include/generic-netbsd/net80211/ieee80211_var.h +2 -2
- package/libc/include/generic-netbsd/netbt/hci.h +3 -3
- package/libc/include/generic-netbsd/netdb.h +2 -2
- package/libc/include/generic-netbsd/netinet/icmp6.h +6 -2
- package/libc/include/generic-netbsd/netinet/in.h +17 -17
- package/libc/include/generic-netbsd/netinet/in_var.h +5 -9
- package/libc/include/generic-netbsd/netinet/ip_mroute.h +24 -28
- package/libc/include/generic-netbsd/netinet/ip_var.h +2 -2
- package/libc/include/generic-netbsd/netinet/sctp.h +4 -4
- package/libc/include/generic-netbsd/netinet/tcp_var.h +2 -2
- package/libc/include/generic-netbsd/netinet/tcp_vtw.h +2 -2
- package/libc/include/generic-netbsd/netinet6/in6_var.h +7 -33
- package/libc/include/generic-netbsd/netinet6/ip6_var.h +2 -2
- package/libc/include/generic-netbsd/nfs/krpc.h +9 -4
- package/libc/include/generic-netbsd/nfs/nfs.h +5 -3
- package/libc/include/generic-netbsd/nfs/nfsdiskless.h +37 -20
- package/libc/include/generic-netbsd/nfs/nfsm_subs.h +4 -7
- package/libc/include/generic-netbsd/nfs/nfsmount.h +3 -4
- package/libc/include/generic-netbsd/nfs/nfsnode.h +9 -6
- package/libc/include/generic-netbsd/nfs/nfsproto.h +5 -2
- package/libc/include/generic-netbsd/nfs/nfsrtt.h +8 -4
- package/libc/include/generic-netbsd/nfs/nfsrvcache.h +9 -3
- package/libc/include/generic-netbsd/nfs/rpcv2.h +5 -3
- package/libc/include/generic-netbsd/nfs/xdr_subs.h +6 -5
- package/libc/include/generic-netbsd/nl_types.h +3 -1
- package/libc/include/generic-netbsd/ntfs/ntfs_inode.h +2 -2
- package/libc/include/generic-netbsd/poll.h +8 -2
- package/libc/include/generic-netbsd/prop/prop_object.h +48 -3
- package/libc/include/generic-netbsd/protocols/talkd.h +2 -2
- package/libc/include/generic-netbsd/pthread.h +51 -12
- package/libc/include/generic-netbsd/regex.h +2 -1
- package/libc/include/generic-netbsd/riscv/ansi.h +3 -0
- package/libc/include/generic-netbsd/riscv/aout_machdep.h +40 -0
- package/libc/include/generic-netbsd/riscv/asm.h +272 -0
- package/libc/include/generic-netbsd/riscv/bswap.h +11 -0
- package/libc/include/generic-netbsd/riscv/byte_swap.h +99 -0
- package/libc/include/generic-netbsd/riscv/cdefs.h +8 -0
- package/libc/include/generic-netbsd/riscv/cpu.h +242 -0
- package/libc/include/generic-netbsd/riscv/disklabel.h +68 -0
- package/libc/include/generic-netbsd/riscv/elf_machdep.h +144 -0
- package/libc/include/generic-netbsd/riscv/endian.h +3 -0
- package/libc/include/generic-netbsd/riscv/endian_machdep.h +3 -0
- package/libc/include/generic-netbsd/riscv/fenv.h +36 -0
- package/libc/include/generic-netbsd/riscv/float.h +59 -0
- package/libc/include/generic-netbsd/riscv/ieee.h +4 -0
- package/libc/include/generic-netbsd/riscv/ieeefp.h +44 -0
- package/libc/include/generic-netbsd/riscv/int_const.h +33 -0
- package/libc/include/generic-netbsd/riscv/int_fmtio.h +381 -0
- package/libc/include/generic-netbsd/riscv/int_limits.h +3 -0
- package/libc/include/generic-netbsd/riscv/int_mwgwtypes.h +3 -0
- package/libc/include/generic-netbsd/riscv/int_types.h +3 -0
- package/libc/include/generic-netbsd/riscv/kcore.h +40 -0
- package/libc/include/generic-netbsd/riscv/limits.h +3 -0
- package/libc/include/generic-netbsd/riscv/lock.h +3 -0
- package/libc/include/generic-netbsd/riscv/lwp_private.h +83 -0
- package/libc/include/generic-netbsd/riscv/math.h +4 -0
- package/libc/include/generic-netbsd/riscv/mcontext.h +150 -0
- package/libc/include/generic-netbsd/riscv/mutex.h +128 -0
- package/libc/include/generic-netbsd/riscv/param.h +110 -0
- package/libc/include/generic-netbsd/riscv/pcb.h +55 -0
- package/libc/include/generic-netbsd/riscv/pmap.h +263 -0
- package/libc/include/generic-netbsd/riscv/proc.h +76 -0
- package/libc/include/generic-netbsd/riscv/profile.h +117 -0
- package/libc/include/generic-netbsd/riscv/pte.h +347 -0
- package/libc/include/generic-netbsd/riscv/ptrace.h +63 -0
- package/libc/include/generic-netbsd/riscv/reg.h +125 -0
- package/libc/include/generic-netbsd/riscv/rwlock.h +1 -0
- package/libc/include/generic-netbsd/riscv/setjmp.h +70 -0
- package/libc/include/generic-netbsd/riscv/signal.h +40 -0
- package/libc/include/generic-netbsd/riscv/sysarch.h +3 -0
- package/libc/include/generic-netbsd/riscv/sysreg.h +354 -0
- package/libc/include/generic-netbsd/riscv/types.h +123 -0
- package/libc/include/generic-netbsd/riscv/vmparam.h +236 -0
- package/libc/include/generic-netbsd/riscv/wchar_limits.h +13 -0
- package/libc/include/generic-netbsd/rmd160.h +3 -3
- package/libc/include/generic-netbsd/rpc/xdr.h +3 -3
- package/libc/include/generic-netbsd/rpcsvc/yp_prot.h +3 -2
- package/libc/include/generic-netbsd/rump/rump_namei.h +2 -2
- package/libc/include/generic-netbsd/rump/rump_syscalls.h +4 -4
- package/libc/include/generic-netbsd/rump/rumpuser.h +6 -1
- package/libc/include/generic-netbsd/rump/rumpvnode_if.h +2 -2
- package/libc/include/generic-netbsd/sha1.h +3 -3
- package/libc/include/generic-netbsd/sha2.h +8 -1
- package/libc/include/generic-netbsd/signal.h +4 -4
- package/libc/include/generic-netbsd/sparc/asm.h +10 -1
- package/libc/include/generic-netbsd/sparc/bswap.h +9 -1
- package/libc/include/generic-netbsd/sparc/cgtworeg.h +2 -2
- package/libc/include/generic-netbsd/sparc/cpu.h +1 -1
- package/libc/include/generic-netbsd/sparc/float.h +3 -1
- package/libc/include/generic-netbsd/sparc/limits.h +4 -6
- package/libc/include/generic-netbsd/sparc/lwp_private.h +51 -0
- package/libc/include/generic-netbsd/sparc/mcontext.h +4 -22
- package/libc/include/generic-netbsd/sparc/mutex.h +1 -1
- package/libc/include/generic-netbsd/sparc/param.h +4 -2
- package/libc/include/generic-netbsd/sparc/pmap.h +2 -2
- package/libc/include/generic-netbsd/sparc/psl.h +6 -3
- package/libc/include/generic-netbsd/sparc/types.h +2 -2
- package/libc/include/generic-netbsd/sparc64/bswap.h +9 -1
- package/libc/include/generic-netbsd/sparc64/cpu.h +2 -2
- package/libc/include/generic-netbsd/sparc64/ctlreg.h +8 -7
- package/libc/include/generic-netbsd/sparc64/intr.h +1 -1
- package/libc/include/generic-netbsd/sparc64/lwp_private.h +3 -0
- package/libc/include/generic-netbsd/sparc64/mcontext.h +4 -4
- package/libc/include/generic-netbsd/sparc64/mutex.h +1 -1
- package/libc/include/generic-netbsd/sparc64/param.h +8 -2
- package/libc/include/generic-netbsd/sparc64/psl.h +7 -2
- package/libc/include/generic-netbsd/sparc64/pte.h +2 -2
- package/libc/include/generic-netbsd/sparc64/vmparam.h +1 -1
- package/libc/include/generic-netbsd/ssp/ssp.h +16 -6
- package/libc/include/generic-netbsd/stdalign.h +3 -3
- package/libc/include/generic-netbsd/stdarg.h +2 -2
- package/libc/include/generic-netbsd/stddef.h +90 -12
- package/libc/include/generic-netbsd/stdlib.h +11 -2
- package/libc/include/generic-netbsd/stdnoreturn.h +2 -2
- package/libc/include/generic-netbsd/string.h +66 -39
- package/libc/include/generic-netbsd/strings.h +17 -3
- package/libc/include/generic-netbsd/sys/atomic.h +10 -5
- package/libc/include/generic-netbsd/sys/bitops.h +2 -2
- package/libc/include/generic-netbsd/sys/bootblock.h +13 -2
- package/libc/include/generic-netbsd/sys/bswap.h +46 -20
- package/libc/include/generic-netbsd/sys/buf.h +3 -3
- package/libc/include/generic-netbsd/sys/cdefs.h +44 -6
- package/libc/include/generic-netbsd/sys/cdefs_aout.h +8 -1
- package/libc/include/generic-netbsd/sys/cdefs_elf.h +9 -2
- package/libc/include/generic-netbsd/sys/chio.h +2 -2
- package/libc/include/generic-netbsd/sys/clock.h +5 -1
- package/libc/include/generic-netbsd/sys/common_limits.h +3 -1
- package/libc/include/generic-netbsd/sys/condvar.h +1 -1
- package/libc/include/generic-netbsd/sys/conf.h +4 -3
- package/libc/include/generic-netbsd/sys/container_of.h +75 -0
- package/libc/include/generic-netbsd/sys/device.h +20 -13
- package/libc/include/generic-netbsd/sys/disk.h +8 -1
- package/libc/include/generic-netbsd/sys/disklabel.h +2 -2
- package/libc/include/generic-netbsd/sys/disklabel_gpt.h +7 -1
- package/libc/include/generic-netbsd/sys/efiio.h +1 -1
- package/libc/include/generic-netbsd/sys/elfdefinitions.h +2368 -1591
- package/libc/include/generic-netbsd/sys/endian.h +17 -17
- package/libc/include/generic-netbsd/sys/evcnt.h +15 -2
- package/libc/include/generic-netbsd/sys/event.h +3 -2
- package/libc/include/generic-netbsd/sys/exec.h +2 -2
- package/libc/include/generic-netbsd/sys/exec_elf.h +32 -20
- package/libc/include/generic-netbsd/sys/fcntl.h +26 -2
- package/libc/include/generic-netbsd/sys/fd_set.h +3 -3
- package/libc/include/generic-netbsd/sys/featuretest.h +24 -6
- package/libc/include/generic-netbsd/sys/file.h +18 -6
- package/libc/include/generic-netbsd/sys/filedesc.h +8 -4
- package/libc/include/generic-netbsd/sys/futex.h +11 -11
- package/libc/include/generic-netbsd/sys/ieee754.h +2 -2
- package/libc/include/generic-netbsd/sys/ipc.h +2 -2
- package/libc/include/generic-netbsd/sys/ipmi.h +4 -2
- package/libc/include/generic-netbsd/sys/ksem.h +1 -1
- package/libc/include/generic-netbsd/sys/ktrace.h +6 -4
- package/libc/include/generic-netbsd/sys/lock.h +2 -2
- package/libc/include/generic-netbsd/sys/lua.h +1 -1
- package/libc/include/generic-netbsd/sys/lwp.h +25 -92
- package/libc/include/generic-netbsd/sys/mbuf.h +15 -13
- package/libc/include/generic-netbsd/sys/mman.h +11 -3
- package/libc/include/generic-netbsd/sys/mount.h +1 -2
- package/libc/include/generic-netbsd/sys/msg.h +3 -3
- package/libc/include/generic-netbsd/sys/mutex.h +1 -3
- package/libc/include/generic-netbsd/sys/namei.h +32 -17
- package/libc/include/generic-netbsd/sys/param.h +11 -8
- package/libc/include/generic-netbsd/sys/pipe.h +10 -11
- package/libc/include/generic-netbsd/sys/poll.h +8 -2
- package/libc/include/generic-netbsd/sys/proc.h +15 -15
- package/libc/include/generic-netbsd/sys/ptrace.h +24 -7
- package/libc/include/generic-netbsd/sys/ptree.h +2 -1
- package/libc/include/generic-netbsd/sys/queue.h +37 -37
- package/libc/include/generic-netbsd/sys/rbtree.h +23 -9
- package/libc/include/generic-netbsd/sys/resourcevar.h +2 -2
- package/libc/include/generic-netbsd/sys/rmd160.h +3 -3
- package/libc/include/generic-netbsd/sys/rndio.h +1 -1
- package/libc/include/generic-netbsd/sys/rwlock.h +1 -2
- package/libc/include/generic-netbsd/sys/sched.h +1 -1
- package/libc/include/generic-netbsd/sys/sdt.h +181 -111
- package/libc/include/generic-netbsd/sys/sem.h +7 -2
- package/libc/include/generic-netbsd/sys/sha1.h +3 -3
- package/libc/include/generic-netbsd/sys/sha2.h +8 -1
- package/libc/include/generic-netbsd/sys/shm.h +2 -2
- package/libc/include/generic-netbsd/sys/siginfo.h +5 -5
- package/libc/include/generic-netbsd/sys/signal.h +1 -1
- package/libc/include/generic-netbsd/sys/sigtypes.h +4 -4
- package/libc/include/generic-netbsd/sys/sleepq.h +14 -27
- package/libc/include/generic-netbsd/sys/socket.h +3 -1
- package/libc/include/generic-netbsd/sys/socketvar.h +4 -4
- package/libc/include/generic-netbsd/sys/stat.h +5 -5
- package/libc/include/generic-netbsd/sys/stdalign.h +55 -0
- package/libc/include/generic-netbsd/sys/stdarg.h +2 -2
- package/libc/include/generic-netbsd/sys/stddef.h +156 -0
- package/libc/include/generic-netbsd/sys/swap.h +2 -2
- package/libc/include/generic-netbsd/sys/syncobj.h +9 -6
- package/libc/include/generic-netbsd/sys/syscall.h +29 -8
- package/libc/include/generic-netbsd/sys/syscallargs.h +89 -12
- package/libc/include/generic-netbsd/sys/sysctl.h +94 -86
- package/libc/include/generic-netbsd/sys/syslimits.h +8 -1
- package/libc/include/generic-netbsd/sys/syslog.h +6 -7
- package/libc/include/generic-netbsd/sys/time.h +10 -8
- package/libc/include/generic-netbsd/sys/tree.h +13 -13
- package/libc/include/generic-netbsd/sys/tty.h +2 -2
- package/libc/include/generic-netbsd/sys/ttycom.h +7 -1
- package/libc/include/generic-netbsd/sys/types.h +1 -1
- package/libc/include/generic-netbsd/sys/ucontext.h +46 -49
- package/libc/include/generic-netbsd/sys/un.h +12 -4
- package/libc/include/generic-netbsd/sys/unistd.h +103 -102
- package/libc/include/generic-netbsd/sys/unpcb.h +2 -2
- package/libc/include/generic-netbsd/sys/vmmeter.h +1 -39
- package/libc/include/generic-netbsd/sys/vnode_if.h +2 -2
- package/libc/include/generic-netbsd/sys/vnode_impl.h +6 -3
- package/libc/include/generic-netbsd/sys/wapbl_replay.h +2 -2
- package/libc/include/generic-netbsd/sys/wchan.h +37 -0
- package/libc/include/generic-netbsd/syslog.h +6 -7
- package/libc/include/generic-netbsd/time.h +44 -8
- package/libc/include/generic-netbsd/tzfile.h +11 -6
- package/libc/include/generic-netbsd/uchar.h +1 -1
- package/libc/include/generic-netbsd/ucontext.h +2 -1
- package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs.h +31 -16
- package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs_dir.h +1 -1
- package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs_extents.h +5 -5
- package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs_extern.h +4 -4
- package/libc/include/generic-netbsd/ufs/ffs/ffs_extern.h +1 -1
- package/libc/include/generic-netbsd/ufs/ffs/fs.h +3 -3
- package/libc/include/generic-netbsd/ufs/ufs/quota2.h +2 -2
- package/libc/include/generic-netbsd/unistd.h +11 -5
- package/libc/include/generic-netbsd/unwind.h +1 -1
- package/libc/include/generic-netbsd/util.h +15 -1
- package/libc/include/generic-netbsd/uvm/uvm.h +1 -5
- package/libc/include/generic-netbsd/uvm/uvm_extern.h +3 -4
- package/libc/include/generic-netbsd/uvm/uvm_object.h +2 -2
- package/libc/include/generic-netbsd/uvm/uvm_param.h +1 -1
- package/libc/include/generic-netbsd/uvm/uvm_swap.h +14 -3
- package/libc/include/generic-netbsd/wchar.h +7 -2
- package/libc/include/generic-netbsd/x86/bootinfo.h +4 -1
- package/libc/include/generic-netbsd/x86/cpu.h +18 -1
- package/libc/include/generic-netbsd/x86/cpu_extended_state.h +3 -1
- package/libc/include/generic-netbsd/x86/cpuvar.h +4 -1
- package/libc/include/generic-netbsd/x86/float.h +24 -1
- package/libc/include/generic-netbsd/x86/ieee.h +11 -7
- package/libc/include/generic-netbsd/x86/lwp_private.h +56 -0
- package/libc/include/generic-netbsd/x86/mutex.h +1 -1
- package/libc/include/generic-netbsd/x86/specialreg.h +111 -23
- package/libc/include/generic-openbsd/db.h +1 -7
- package/libc/include/generic-openbsd/ddb/db_interface.h +2 -1
- package/libc/include/generic-openbsd/fnmatch.h +6 -2
- package/libc/include/generic-openbsd/login_cap.h +3 -1
- package/libc/include/generic-openbsd/miscfs/fuse/fusefs_node.h +2 -1
- package/libc/include/generic-openbsd/net/bpf.h +3 -1
- package/libc/include/generic-openbsd/net/hfsc.h +4 -4
- package/libc/include/generic-openbsd/net/if.h +5 -1
- package/libc/include/generic-openbsd/net/if_bridge.h +48 -1
- package/libc/include/generic-openbsd/net/if_etherbridge.h +20 -7
- package/libc/include/generic-openbsd/net/if_media.h +26 -1
- package/libc/include/generic-openbsd/net/if_pflow.h +71 -20
- package/libc/include/generic-openbsd/net/if_pfsync.h +2 -2
- package/libc/include/generic-openbsd/net/if_sppp.h +2 -1
- package/libc/include/generic-openbsd/net/if_trunk.h +3 -2
- package/libc/include/generic-openbsd/net/if_types.h +2 -2
- package/libc/include/generic-openbsd/net/if_var.h +34 -12
- package/libc/include/generic-openbsd/net/netisr.h +1 -3
- package/libc/include/generic-openbsd/net/pfvar.h +154 -1
- package/libc/include/generic-openbsd/net/pfvar_priv.h +256 -1
- package/libc/include/generic-openbsd/net80211/ieee80211.h +76 -4
- package/libc/include/generic-openbsd/net80211/ieee80211_ioctl.h +3 -2
- package/libc/include/generic-openbsd/net80211/ieee80211_node.h +48 -2
- package/libc/include/generic-openbsd/net80211/ieee80211_proto.h +4 -1
- package/libc/include/generic-openbsd/net80211/ieee80211_var.h +18 -2
- package/libc/include/generic-openbsd/netinet/if_ether.h +12 -11
- package/libc/include/generic-openbsd/netinet/igmp_var.h +17 -3
- package/libc/include/generic-openbsd/netinet/in_pcb.h +2 -1
- package/libc/include/generic-openbsd/netinet/in_var.h +17 -59
- package/libc/include/generic-openbsd/netinet/ip.h +3 -2
- package/libc/include/generic-openbsd/netinet/tcp_timer.h +1 -2
- package/libc/include/generic-openbsd/netinet6/in6_var.h +15 -29
- package/libc/include/generic-openbsd/netinet6/ip6_var.h +1 -2
- package/libc/include/generic-openbsd/netinet6/mld6_var.h +17 -4
- package/libc/include/generic-openbsd/netinet6/nd6.h +2 -2
- package/libc/include/generic-openbsd/pthread.h +2 -2
- package/libc/include/generic-openbsd/signal.h +2 -2
- package/libc/include/generic-openbsd/sndio.h +6 -12
- package/libc/include/generic-openbsd/strings.h +5 -1
- package/libc/include/generic-openbsd/sys/device.h +4 -3
- package/libc/include/generic-openbsd/sys/disklabel.h +17 -5
- package/libc/include/generic-openbsd/sys/dkio.h +3 -5
- package/libc/include/generic-openbsd/sys/filedesc.h +3 -2
- package/libc/include/generic-openbsd/sys/mbuf.h +1 -1
- package/libc/include/generic-openbsd/sys/mman.h +7 -2
- package/libc/include/generic-openbsd/sys/mutex.h +10 -7
- package/libc/include/generic-openbsd/sys/namei.h +8 -7
- package/libc/include/generic-openbsd/sys/param.h +1 -1
- package/libc/include/generic-openbsd/sys/pledge.h +1 -3
- package/libc/include/generic-openbsd/sys/protosw.h +8 -1
- package/libc/include/generic-openbsd/sys/ptrace.h +4 -1
- package/libc/include/generic-openbsd/sys/sched.h +8 -1
- package/libc/include/generic-openbsd/sys/signal.h +4 -2
- package/libc/include/generic-openbsd/sys/socketvar.h +2 -1
- package/libc/include/generic-openbsd/sys/sockio.h +11 -1
- package/libc/include/generic-openbsd/sys/syscall.h +5 -3
- package/libc/include/generic-openbsd/sys/syscallargs.h +9 -2
- package/libc/include/generic-openbsd/sys/sysctl.h +7 -4
- package/libc/include/generic-openbsd/sys/types.h +6 -2
- package/libc/include/generic-openbsd/sys/videoio.h +143 -68
- package/libc/include/generic-openbsd/sys/xcall.h +2 -2
- package/libc/include/generic-openbsd/time.h +2 -2
- package/libc/include/generic-openbsd/unistd.h +2 -2
- package/libc/include/generic-openbsd/uvm/uvm_anon.h +2 -3
- package/libc/include/generic-openbsd/uvm/uvm_extern.h +1 -19
- package/libc/include/generic-openbsd/uvm/uvm_pager.h +3 -4
- package/libc/include/generic-openbsd/uvm/uvm_pmemrange.h +1 -2
- package/libc/include/generic-openbsd/uvm/uvm_swap.h +4 -1
- package/libc/include/generic-openbsd/uvm/uvm_vnode.h +3 -4
- package/libc/include/generic-openbsd/uvm/uvmexp.h +41 -35
- package/libc/include/hexagon-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/loongarch-linux-any/asm/hwcap.h +1 -0
- package/libc/include/loongarch-linux-any/asm/kvm.h +1 -0
- package/libc/include/loongarch-linux-any/asm/kvm_para.h +1 -0
- package/libc/include/loongarch-linux-any/asm/unistd_32.h +2 -0
- package/libc/include/loongarch-linux-any/asm/unistd_64.h +2 -0
- package/libc/include/m68k-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/m68k-netbsd-none/m68k/asm.h +11 -2
- package/libc/include/m68k-netbsd-none/m68k/bus_dma.h +2 -2
- package/libc/include/m68k-netbsd-none/m68k/byte_swap.h +2 -2
- package/libc/include/m68k-netbsd-none/m68k/cacheops_30.h +2 -2
- package/libc/include/m68k-netbsd-none/m68k/cacheops_40.h +3 -1
- package/libc/include/m68k-netbsd-none/m68k/cacheops_60.h +5 -3
- package/libc/include/m68k-netbsd-none/m68k/cpu.h +86 -59
- package/libc/include/m68k-netbsd-none/m68k/cpuframe.h +5 -5
- package/libc/include/m68k-netbsd-none/m68k/fenv.h +6 -4
- package/libc/include/m68k-netbsd-none/m68k/float.h +26 -1
- package/libc/include/m68k-netbsd-none/m68k/frame.h +31 -19
- package/libc/include/m68k-netbsd-none/m68k/ieee.h +13 -8
- package/libc/include/m68k-netbsd-none/m68k/ieeefp.h +3 -3
- package/libc/include/m68k-netbsd-none/m68k/int_limits.h +2 -2
- package/libc/include/m68k-netbsd-none/m68k/intr.h +211 -0
- package/libc/include/m68k-netbsd-none/m68k/kcore.h +31 -31
- package/libc/include/m68k-netbsd-none/m68k/lwp_private.h +64 -0
- package/libc/include/m68k-netbsd-none/m68k/m68k.h +3 -7
- package/libc/include/m68k-netbsd-none/m68k/mcontext.h +5 -36
- package/libc/include/m68k-netbsd-none/m68k/mmu_30.h +105 -0
- package/libc/include/m68k-netbsd-none/m68k/mmu_40.h +232 -0
- package/libc/include/m68k-netbsd-none/m68k/mmu_51.h +273 -0
- package/libc/include/m68k-netbsd-none/m68k/mutex.h +1 -1
- package/libc/include/m68k-netbsd-none/m68k/pcb.h +2 -2
- package/libc/include/m68k-netbsd-none/m68k/pmap_motorola.h +32 -23
- package/libc/include/m68k-netbsd-none/m68k/psl.h +26 -7
- package/libc/include/m68k-netbsd-none/m68k/pte_motorola.h +37 -26
- package/libc/include/m68k-netbsd-none/m68k/trap.h +7 -7
- package/libc/include/m68k-netbsd-none/mac68k/cpu.h +1 -57
- package/libc/include/m68k-netbsd-none/mac68k/intr.h +3 -2
- package/libc/include/m68k-netbsd-none/mac68k/lwp_private.h +3 -0
- package/libc/include/m68k-netbsd-none/mac68k/pmap.h +20 -2
- package/libc/include/m68k-netbsd-none/mac68k/z8530var.h +2 -2
- package/libc/include/m68k-netbsd-none/machine/cpu.h +1 -57
- package/libc/include/m68k-netbsd-none/machine/intr.h +3 -2
- package/libc/include/m68k-netbsd-none/machine/lwp_private.h +3 -0
- package/libc/include/m68k-netbsd-none/machine/pmap.h +20 -2
- package/libc/include/m68k-netbsd-none/machine/z8530var.h +2 -2
- package/libc/include/mips-linux-any/asm/errno.h +2 -0
- package/libc/include/mips-linux-any/asm/unistd_n32.h +1 -0
- package/libc/include/mips-linux-any/asm/unistd_n64.h +1 -0
- package/libc/include/mips-linux-any/asm/unistd_o32.h +1 -0
- package/libc/include/mips-netbsd-eabi/machine/lwp_private.h +3 -0
- package/libc/include/mips64-openbsd-none/machine/octeonvar.h +1 -27
- package/libc/include/mips64-openbsd-none/octeon/octeonvar.h +1 -27
- package/libc/include/mips64el-openbsd-none/loongson/apmvar.h +1 -1
- package/libc/include/mips64el-openbsd-none/loongson/param.h +1 -5
- package/libc/include/mips64el-openbsd-none/machine/apmvar.h +1 -1
- package/libc/include/mips64el-openbsd-none/machine/param.h +1 -5
- package/libc/include/powerpc-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/powerpc-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/powerpc-linux-gnu/bits/struct_mutex.h +2 -2
- package/libc/include/powerpc-netbsd-eabi/evbppc/lwp_private.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/float.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/ansi.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/aout_machdep.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/asm.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/cdefs.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/cpu.h +65 -0
- package/libc/include/powerpc-netbsd-eabi/machine/disklabel.h +69 -0
- package/libc/include/powerpc-netbsd-eabi/machine/elf_machdep.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/endian.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/fenv.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/float.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/frame.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/ieee.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/ieeefp.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/int_const.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/int_fmtio.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/int_limits.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/int_mwgwtypes.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/int_types.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/kcore.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/limits.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/lock.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/lwp_private.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/math.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/mcontext.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/mutex.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/param.h +43 -0
- package/libc/include/powerpc-netbsd-eabi/machine/pcb.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/pmap.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/proc.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/profile.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/psl.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/pte.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/ptrace.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/reg.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/reloc.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/setjmp.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/signal.h +3 -0
- package/libc/include/{mips-netbsd-eabi → powerpc-netbsd-eabi}/machine/sljit_machdep.h +1 -1
- package/libc/include/powerpc-netbsd-eabi/machine/trap.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/types.h +11 -0
- package/libc/include/powerpc-netbsd-eabi/machine/vmparam.h +3 -0
- package/libc/include/powerpc-netbsd-eabi/machine/wchar_limits.h +3 -0
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/asm.h +12 -2
- package/libc/include/powerpc-netbsd-eabi/powerpc/bswap.h +14 -0
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/cpu.h +3 -3
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/fenv.h +2 -1
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/pmap.h +3 -3
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ieee.h +7 -2
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/limits.h +4 -13
- package/libc/include/powerpc-netbsd-eabi/powerpc/lwp_private.h +79 -0
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/mcontext.h +6 -50
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/mutex.h +1 -1
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/hid.h +2 -2
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/pmap.h +2 -2
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/pmap.h +1 -1
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/psl.h +2 -2
- package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/vmparam.h +1 -1
- package/libc/include/powerpc-openbsd-eabihf/powerpc/intr.h +1 -4
- package/libc/include/powerpc64-openbsd-none/machine/atomic.h +3 -3
- package/libc/include/powerpc64-openbsd-none/powerpc64/atomic.h +3 -3
- package/libc/include/riscv-linux-any/asm/hwprobe.h +4 -0
- package/libc/include/riscv-linux-any/asm/kvm.h +3 -0
- package/libc/include/riscv-linux-any/asm/ptrace.h +37 -0
- package/libc/include/riscv-linux-any/asm/sigcontext.h +1 -0
- package/libc/include/riscv-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/riscv-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/riscv32-netbsd-none/machine/bswap.h +11 -0
- package/libc/include/riscv32-netbsd-none/machine/endian_machdep.h +3 -0
- package/libc/include/riscv32-netbsd-none/machine/rwlock.h +1 -0
- package/libc/include/riscv32-netbsd-none/machine/wchar_limits.h +4 -0
- package/libc/include/riscv64-netbsd-none/machine/bswap.h +11 -0
- package/libc/include/riscv64-netbsd-none/machine/endian_machdep.h +3 -0
- package/libc/include/riscv64-netbsd-none/machine/rwlock.h +1 -0
- package/libc/include/riscv64-netbsd-none/machine/wchar_limits.h +4 -0
- package/libc/include/riscv64-openbsd-none/machine/cpu.h +4 -8
- package/libc/include/riscv64-openbsd-none/machine/cpufunc.h +4 -4
- package/libc/include/riscv64-openbsd-none/machine/pmap.h +5 -1
- package/libc/include/riscv64-openbsd-none/machine/pte.h +9 -1
- package/libc/include/riscv64-openbsd-none/riscv64/cpu.h +4 -8
- package/libc/include/riscv64-openbsd-none/riscv64/cpufunc.h +4 -4
- package/libc/include/riscv64-openbsd-none/riscv64/pmap.h +5 -1
- package/libc/include/riscv64-openbsd-none/riscv64/pte.h +9 -1
- package/libc/include/s390x-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/s390x-linux-gnu/bits/fenv.h +2 -2
- package/libc/include/s390x-linux-gnu/bits/struct_mutex.h +2 -2
- package/libc/include/sparc-linux-any/asm/errno.h +2 -0
- package/libc/include/sparc-linux-any/asm/ioctls.h +4 -4
- package/libc/include/sparc-linux-any/asm/unistd_32.h +2 -0
- package/libc/include/sparc-linux-any/asm/unistd_64.h +2 -0
- package/libc/include/sparc-netbsd-none/float.h +3 -1
- package/libc/include/sparc-netbsd-none/machine/asm.h +10 -1
- package/libc/include/sparc-netbsd-none/machine/cgtworeg.h +2 -2
- package/libc/include/sparc-netbsd-none/machine/cpu.h +1 -1
- package/libc/include/sparc-netbsd-none/machine/float.h +3 -1
- package/libc/include/sparc-netbsd-none/machine/limits.h +4 -6
- package/libc/include/sparc-netbsd-none/machine/lwp_private.h +51 -0
- package/libc/include/sparc-netbsd-none/machine/mcontext.h +4 -22
- package/libc/include/sparc-netbsd-none/machine/mutex.h +1 -1
- package/libc/include/sparc-netbsd-none/machine/param.h +4 -2
- package/libc/include/sparc-netbsd-none/machine/pmap.h +2 -2
- package/libc/include/sparc-netbsd-none/machine/psl.h +6 -3
- package/libc/include/sparc-netbsd-none/machine/sxreg.h +5 -1
- package/libc/include/sparc-netbsd-none/machine/types.h +2 -2
- package/libc/include/sparc-netbsd-none/sparc/sxreg.h +5 -1
- package/libc/include/sparc64-netbsd-none/machine/cpu.h +2 -2
- package/libc/include/sparc64-netbsd-none/machine/ctlreg.h +8 -7
- package/libc/include/sparc64-netbsd-none/machine/intr.h +1 -1
- package/libc/include/sparc64-netbsd-none/machine/lwp_private.h +3 -0
- package/libc/include/sparc64-netbsd-none/machine/mcontext.h +4 -4
- package/libc/include/sparc64-netbsd-none/machine/mutex.h +1 -1
- package/libc/include/sparc64-netbsd-none/machine/param.h +8 -2
- package/libc/include/sparc64-netbsd-none/machine/psl.h +7 -2
- package/libc/include/sparc64-netbsd-none/machine/pte.h +2 -2
- package/libc/include/sparc64-netbsd-none/machine/vmparam.h +1 -1
- package/libc/include/x86-linux-any/asm/auxvec.h +0 -4
- package/libc/include/x86-linux-any/asm/kvm.h +13 -8
- package/libc/include/x86-linux-any/asm/svm.h +16 -16
- package/libc/include/x86-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/x86-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/x86-linux-any/asm/unistd_x32.h +1 -0
- package/libc/include/x86-linux-gnu/bits/struct_mutex.h +2 -2
- package/libc/include/x86-netbsd-none/machine/asm.h +12 -4
- package/libc/include/x86-netbsd-none/machine/byte_swap.h +2 -2
- package/libc/include/x86-netbsd-none/machine/cpu.h +15 -4
- package/libc/include/x86-netbsd-none/machine/elf_machdep.h +2 -1
- package/libc/include/x86-netbsd-none/machine/lwp_private.h +3 -0
- package/libc/include/x86-netbsd-none/machine/mcontext.h +6 -24
- package/libc/include/x86-netbsd-none/machine/param.h +9 -1
- package/libc/include/x86-netbsd-none/machine/pcb.h +6 -2
- package/libc/include/x86-netbsd-none/machine/ptrace.h +2 -2
- package/libc/include/x86-netbsd-none/machine/types.h +2 -1
- package/libc/include/x86-openbsd-none/i386/specialreg.h +3 -1
- package/libc/include/x86-openbsd-none/machine/specialreg.h +3 -1
- package/libc/include/x86_64-netbsd-none/amd64/asm.h +11 -3
- package/libc/include/x86_64-netbsd-none/amd64/byte_swap.h +2 -2
- package/libc/include/x86_64-netbsd-none/amd64/cpu.h +13 -3
- package/libc/include/x86_64-netbsd-none/amd64/frame.h +2 -2
- package/libc/include/x86_64-netbsd-none/amd64/lwp_private.h +3 -0
- package/libc/include/x86_64-netbsd-none/amd64/mcontext.h +5 -23
- package/libc/include/x86_64-netbsd-none/amd64/param.h +23 -4
- package/libc/include/x86_64-netbsd-none/amd64/pcb.h +14 -3
- package/libc/include/x86_64-netbsd-none/amd64/ptrace.h +2 -2
- package/libc/include/x86_64-netbsd-none/amd64/types.h +2 -1
- package/libc/include/x86_64-netbsd-none/machine/asm.h +11 -3
- package/libc/include/x86_64-netbsd-none/machine/byte_swap.h +2 -2
- package/libc/include/x86_64-netbsd-none/machine/cpu.h +13 -3
- package/libc/include/x86_64-netbsd-none/machine/frame.h +2 -2
- package/libc/include/x86_64-netbsd-none/machine/lwp_private.h +3 -0
- package/libc/include/x86_64-netbsd-none/machine/mcontext.h +5 -23
- package/libc/include/x86_64-netbsd-none/machine/param.h +23 -4
- package/libc/include/x86_64-netbsd-none/machine/pcb.h +14 -3
- package/libc/include/x86_64-netbsd-none/machine/ptrace.h +2 -2
- package/libc/include/x86_64-netbsd-none/machine/types.h +2 -1
- package/libc/include/x86_64-openbsd-none/amd64/conf.h +11 -2
- package/libc/include/x86_64-openbsd-none/amd64/cpu.h +14 -4
- package/libc/include/x86_64-openbsd-none/amd64/cpufunc.h +2 -3
- package/libc/include/x86_64-openbsd-none/amd64/ghcb.h +2 -1
- package/libc/include/x86_64-openbsd-none/amd64/i82489var.h +2 -4
- package/libc/include/x86_64-openbsd-none/amd64/i8259.h +1 -53
- package/libc/include/x86_64-openbsd-none/amd64/intr.h +5 -2
- package/libc/include/x86_64-openbsd-none/amd64/intrdefs.h +9 -7
- package/libc/include/x86_64-openbsd-none/amd64/kexec.h +48 -0
- package/libc/include/x86_64-openbsd-none/amd64/specialreg.h +4 -1
- package/libc/include/x86_64-openbsd-none/machine/conf.h +11 -2
- package/libc/include/x86_64-openbsd-none/machine/cpu.h +14 -4
- package/libc/include/x86_64-openbsd-none/machine/cpufunc.h +2 -3
- package/libc/include/x86_64-openbsd-none/machine/ghcb.h +2 -1
- package/libc/include/x86_64-openbsd-none/machine/i82489var.h +2 -4
- package/libc/include/x86_64-openbsd-none/machine/i8259.h +1 -53
- package/libc/include/x86_64-openbsd-none/machine/intr.h +5 -2
- package/libc/include/x86_64-openbsd-none/machine/intrdefs.h +9 -7
- package/libc/include/x86_64-openbsd-none/machine/kexec.h +48 -0
- package/libc/include/x86_64-openbsd-none/machine/specialreg.h +4 -1
- package/libc/include/xtensa-linux-any/asm/unistd_32.h +1 -0
- package/libc/netbsd/abilists +0 -0
- package/libc/netbsd/lib/csu/arch/riscv/crt0.S +62 -0
- package/libc/netbsd/lib/csu/common/crt0-common.c +32 -7
- package/libc/netbsd/lib/csu/common/csu-common.h +2 -0
- package/libc/openbsd/abilists +0 -0
- package/libcxx/include/__algorithm/all_of.h +11 -5
- package/libcxx/include/__algorithm/comp.h +4 -0
- package/libcxx/include/__algorithm/copy.h +28 -147
- package/libcxx/include/__algorithm/copy_backward.h +9 -24
- package/libcxx/include/__algorithm/copy_n.h +50 -16
- package/libcxx/include/__algorithm/count.h +2 -2
- package/libcxx/include/__algorithm/equal.h +43 -55
- package/libcxx/include/__algorithm/fill.h +26 -8
- package/libcxx/include/__algorithm/fill_n.h +32 -46
- package/libcxx/include/__algorithm/find.h +96 -39
- package/libcxx/include/__algorithm/find_end.h +105 -0
- package/libcxx/include/__algorithm/for_each.h +18 -24
- package/libcxx/include/__algorithm/for_each_n.h +20 -47
- package/libcxx/include/__algorithm/for_each_n_segment.h +1 -1
- package/libcxx/include/__algorithm/for_each_segment.h +26 -0
- package/libcxx/include/__algorithm/generate.h +4 -2
- package/libcxx/include/__algorithm/generate_n.h +19 -6
- package/libcxx/include/__algorithm/is_permutation.h +4 -4
- package/libcxx/include/__algorithm/iterator_operations.h +3 -0
- package/libcxx/include/__algorithm/lexicographical_compare.h +2 -2
- package/libcxx/include/__algorithm/lexicographical_compare_three_way.h +6 -6
- package/libcxx/include/__algorithm/make_heap.h +16 -4
- package/libcxx/include/__algorithm/mismatch.h +2 -2
- package/libcxx/include/__algorithm/move.h +8 -19
- package/libcxx/include/__algorithm/move_backward.h +9 -24
- package/libcxx/include/__algorithm/none_of.h +4 -4
- package/libcxx/include/__algorithm/partial_sort.h +1 -1
- package/libcxx/include/__algorithm/partial_sort_copy.h +1 -1
- package/libcxx/include/__algorithm/pstl.h +9 -9
- package/libcxx/include/__algorithm/radix_sort.h +27 -25
- package/libcxx/include/__algorithm/ranges_copy_n.h +3 -26
- package/libcxx/include/__algorithm/ranges_equal.h +17 -26
- package/libcxx/include/__algorithm/ranges_fill.h +7 -6
- package/libcxx/include/__algorithm/ranges_for_each.h +9 -1
- package/libcxx/include/__algorithm/ranges_generate_n.h +2 -6
- package/libcxx/include/__algorithm/ranges_search_n.h +2 -2
- package/libcxx/include/__algorithm/rotate.h +27 -44
- package/libcxx/include/__algorithm/search_n.h +49 -37
- package/libcxx/include/__algorithm/sift_down.h +19 -18
- package/libcxx/include/__algorithm/simd_utils.h +33 -4
- package/libcxx/include/__algorithm/specialized_algorithms.h +54 -0
- package/libcxx/include/__algorithm/stable_sort.h +1 -1
- package/libcxx/include/__assertion_handler +31 -4
- package/libcxx/include/__atomic/atomic.h +36 -60
- package/libcxx/include/__atomic/atomic_flag.h +19 -37
- package/libcxx/include/__atomic/atomic_ref.h +29 -12
- package/libcxx/include/__atomic/atomic_sync.h +127 -55
- package/libcxx/include/__atomic/atomic_sync_timed.h +144 -0
- package/libcxx/include/__atomic/atomic_waitable_traits.h +103 -0
- package/libcxx/include/__atomic/contention_t.h +27 -3
- package/libcxx/include/__atomic/floating_point_helper.h +55 -0
- package/libcxx/include/__bit/countl.h +1 -2
- package/libcxx/include/__bit/countr.h +1 -2
- package/libcxx/include/__bit/has_single_bit.h +1 -1
- package/libcxx/include/__bit/popcount.h +0 -1
- package/libcxx/include/__bit/rotate.h +15 -26
- package/libcxx/include/__bit_reference +207 -18
- package/libcxx/include/__charconv/from_chars_integral.h +1 -1
- package/libcxx/include/__charconv/from_chars_result.h +1 -1
- package/libcxx/include/__charconv/to_chars_integral.h +1 -0
- package/libcxx/include/__charconv/to_chars_result.h +1 -1
- package/libcxx/include/__charconv/traits.h +3 -24
- package/libcxx/include/__chrono/day.h +11 -0
- package/libcxx/include/__chrono/duration.h +58 -33
- package/libcxx/include/__chrono/file_clock.h +4 -2
- package/libcxx/include/__chrono/is_clock.h +72 -0
- package/libcxx/include/__chrono/leap_second.h +13 -0
- package/libcxx/include/__chrono/month.h +13 -0
- package/libcxx/include/__chrono/month_weekday.h +22 -0
- package/libcxx/include/__chrono/monthday.h +20 -0
- package/libcxx/include/__chrono/steady_clock.h +1 -1
- package/libcxx/include/__chrono/system_clock.h +3 -3
- package/libcxx/include/__chrono/time_point.h +37 -13
- package/libcxx/include/__chrono/weekday.h +25 -0
- package/libcxx/include/__chrono/year.h +11 -0
- package/libcxx/include/__chrono/year_month.h +13 -0
- package/libcxx/include/__chrono/year_month_day.h +23 -0
- package/libcxx/include/__chrono/year_month_weekday.h +26 -0
- package/libcxx/include/__chrono/zoned_time.h +16 -0
- package/libcxx/include/__compare/is_eq.h +6 -6
- package/libcxx/include/__compare/strong_order.h +12 -30
- package/libcxx/include/__compare/three_way_comparable.h +2 -2
- package/libcxx/include/__concepts/comparison_common_type.h +40 -0
- package/libcxx/include/__concepts/equality_comparable.h +2 -1
- package/libcxx/include/__condition_variable/condition_variable.h +1 -1
- package/libcxx/include/__config +63 -280
- package/libcxx/include/__configuration/abi.h +14 -24
- package/libcxx/include/__configuration/availability.h +65 -118
- package/libcxx/include/__configuration/compiler.h +6 -6
- package/libcxx/include/__configuration/experimental.h +38 -0
- package/libcxx/include/__configuration/hardening.h +215 -0
- package/libcxx/include/__configuration/language.h +3 -0
- package/libcxx/include/__configuration/platform.h +9 -16
- package/libcxx/include/__coroutine/coroutine_handle.h +9 -9
- package/libcxx/include/__coroutine/noop_coroutine_handle.h +11 -13
- package/libcxx/include/__debug_utils/strict_weak_ordering_check.h +1 -1
- package/libcxx/include/__exception/exception.h +6 -4
- package/libcxx/include/__exception/exception_ptr.h +27 -5
- package/libcxx/include/__exception/nested_exception.h +2 -2
- package/libcxx/include/__exception/operations.h +5 -5
- package/libcxx/include/__expected/bad_expected_access.h +8 -6
- package/libcxx/include/__expected/expected.h +62 -64
- package/libcxx/include/__expected/unexpected.h +4 -4
- package/libcxx/include/__filesystem/copy_options.h +4 -4
- package/libcxx/include/__filesystem/directory_entry.h +37 -33
- package/libcxx/include/__filesystem/directory_iterator.h +9 -11
- package/libcxx/include/__filesystem/directory_options.h +7 -4
- package/libcxx/include/__filesystem/file_status.h +3 -3
- package/libcxx/include/__filesystem/filesystem_error.h +9 -10
- package/libcxx/include/__filesystem/operations.h +97 -66
- package/libcxx/include/__filesystem/path.h +68 -64
- package/libcxx/include/__filesystem/path_iterator.h +1 -3
- package/libcxx/include/__filesystem/perm_options.h +4 -4
- package/libcxx/include/__filesystem/perms.h +4 -4
- package/libcxx/include/__filesystem/recursive_directory_iterator.h +9 -14
- package/libcxx/include/__filesystem/space_info.h +1 -1
- package/libcxx/include/__filesystem/u8path.h +12 -14
- package/libcxx/include/__flat_map/flat_map.h +88 -71
- package/libcxx/include/__flat_map/flat_multimap.h +251 -172
- package/libcxx/include/__flat_map/key_value_iterator.h +0 -1
- package/libcxx/include/__flat_map/utils.h +1 -0
- package/libcxx/include/__flat_set/flat_multiset.h +211 -143
- package/libcxx/include/__flat_set/flat_set.h +86 -68
- package/libcxx/include/__format/concepts.h +0 -14
- package/libcxx/include/__format/extended_grapheme_cluster_table.h +3 -2
- package/libcxx/include/__format/fmt_pair_like.h +42 -0
- package/libcxx/include/__format/format_arg.h +7 -10
- package/libcxx/include/__format/format_args.h +1 -1
- package/libcxx/include/__format/format_context.h +5 -5
- package/libcxx/include/__format/format_parse_context.h +2 -2
- package/libcxx/include/__format/formatter_output.h +30 -34
- package/libcxx/include/__format/indic_conjunct_break_table.h +3 -2
- package/libcxx/include/__format/range_default_formatter.h +2 -41
- package/libcxx/include/__format/range_format.h +71 -0
- package/libcxx/include/__format/range_formatter.h +1 -0
- package/libcxx/include/__format/width_estimation_table.h +4 -2
- package/libcxx/include/__functional/bind.h +10 -15
- package/libcxx/include/__functional/bind_back.h +1 -1
- package/libcxx/include/__functional/bind_front.h +1 -1
- package/libcxx/include/__functional/function.h +57 -75
- package/libcxx/include/__functional/hash.h +1 -10
- package/libcxx/include/__functional/identity.h +1 -1
- package/libcxx/include/__functional/is_transparent.h +8 -0
- package/libcxx/include/__functional/mem_fn.h +2 -1
- package/libcxx/include/__functional/operations.h +18 -0
- package/libcxx/include/__functional/ranges_operations.h +7 -0
- package/libcxx/include/__functional/reference_wrapper.h +7 -5
- package/libcxx/include/__functional/weak_result_type.h +14 -28
- package/libcxx/include/__fwd/ios.h +1 -1
- package/libcxx/include/__fwd/tuple.h +14 -0
- package/libcxx/include/__hash_table +371 -357
- package/libcxx/include/__ios/fpos.h +4 -4
- package/libcxx/include/__iterator/back_insert_iterator.h +1 -7
- package/libcxx/include/__iterator/bounded_iter.h +7 -8
- package/libcxx/include/__iterator/concepts.h +6 -9
- package/libcxx/include/__iterator/cpp17_iterator_concepts.h +13 -12
- package/libcxx/include/__iterator/distance.h +40 -18
- package/libcxx/include/__iterator/front_insert_iterator.h +1 -7
- package/libcxx/include/__iterator/insert_iterator.h +1 -7
- package/libcxx/include/__iterator/istream_iterator.h +6 -7
- package/libcxx/include/__iterator/istreambuf_iterator.h +6 -7
- package/libcxx/include/__iterator/iter_move.h +1 -1
- package/libcxx/include/__iterator/iterator.h +13 -0
- package/libcxx/include/__iterator/iterator_traits.h +13 -14
- package/libcxx/include/__iterator/ostream_iterator.h +1 -7
- package/libcxx/include/__iterator/ostreambuf_iterator.h +1 -7
- package/libcxx/include/__iterator/reverse_iterator.h +8 -13
- package/libcxx/include/__iterator/segmented_iterator.h +3 -8
- package/libcxx/include/__iterator/static_bounded_iter.h +3 -3
- package/libcxx/include/__iterator/wrap_iter.h +8 -6
- package/libcxx/include/__locale +3 -10
- package/libcxx/include/__locale_dir/locale_base_api/bsd_locale_fallbacks.h +0 -10
- package/libcxx/include/__locale_dir/locale_base_api.h +5 -28
- package/libcxx/include/__locale_dir/messages.h +1 -1
- package/libcxx/include/__locale_dir/money.h +2 -2
- package/libcxx/include/__locale_dir/num.h +190 -243
- package/libcxx/include/__locale_dir/pad_and_output.h +5 -6
- package/libcxx/include/__locale_dir/support/bsd_like.h +0 -20
- package/libcxx/include/__locale_dir/support/fuchsia.h +0 -7
- package/libcxx/include/__locale_dir/support/linux.h +0 -37
- package/libcxx/include/__locale_dir/support/netbsd.h +0 -2
- package/libcxx/include/__locale_dir/support/newlib.h +243 -0
- package/libcxx/include/__locale_dir/support/no_locale/characters.h +0 -4
- package/libcxx/include/__locale_dir/support/no_locale/strtonum.h +0 -9
- package/libcxx/include/__locale_dir/support/windows.h +0 -29
- package/libcxx/include/__locale_dir/time.h +3 -7
- package/libcxx/include/__math/hypot.h +1 -1
- package/libcxx/include/__math/logarithms.h +1 -1
- package/libcxx/include/__math/traits.h +80 -11
- package/libcxx/include/__mdspan/extents.h +7 -4
- package/libcxx/include/__mdspan/layout_stride.h +4 -5
- package/libcxx/include/__mdspan/mdspan.h +29 -23
- package/libcxx/include/__memory/addressof.h +7 -5
- package/libcxx/include/__memory/align.h +18 -1
- package/libcxx/include/__memory/allocate_at_least.h +15 -10
- package/libcxx/include/__memory/allocator.h +14 -26
- package/libcxx/include/__memory/allocator_traits.h +6 -4
- package/libcxx/include/__memory/compressed_pair.h +15 -9
- package/libcxx/include/__memory/construct_at.h +12 -23
- package/libcxx/include/__memory/inout_ptr.h +1 -1
- package/libcxx/include/__memory/is_sufficiently_aligned.h +1 -1
- package/libcxx/include/__memory/out_ptr.h +1 -1
- package/libcxx/include/__memory/pointer_traits.h +1 -1
- package/libcxx/include/__memory/raw_storage_iterator.h +3 -9
- package/libcxx/include/__memory/shared_count.h +9 -30
- package/libcxx/include/__memory/shared_ptr.h +100 -145
- package/libcxx/include/__memory/temp_value.h +1 -2
- package/libcxx/include/__memory/uninitialized_algorithms.h +44 -115
- package/libcxx/include/__memory/unique_ptr.h +14 -16
- package/libcxx/include/__memory/uses_allocator_construction.h +1 -0
- package/libcxx/include/__memory_resource/memory_resource.h +4 -2
- package/libcxx/include/__memory_resource/monotonic_buffer_resource.h +1 -1
- package/libcxx/include/__memory_resource/polymorphic_allocator.h +13 -8
- package/libcxx/include/__memory_resource/pool_options.h +1 -1
- package/libcxx/include/__memory_resource/synchronized_pool_resource.h +4 -2
- package/libcxx/include/__memory_resource/unsynchronized_pool_resource.h +1 -1
- package/libcxx/include/__mutex/mutex.h +2 -2
- package/libcxx/include/__mutex/once_flag.h +14 -11
- package/libcxx/include/__mutex/tag_types.h +3 -3
- package/libcxx/include/__mutex/unique_lock.h +8 -7
- package/libcxx/include/__new/align_val_t.h +6 -0
- package/libcxx/include/__new/allocate.h +1 -2
- package/libcxx/include/__new/exceptions.h +8 -2
- package/libcxx/include/__new/global_new_delete.h +4 -11
- package/libcxx/include/__new/interference_size.h +0 -4
- package/libcxx/include/__new/launder.h +3 -5
- package/libcxx/include/__new/nothrow_t.h +1 -1
- package/libcxx/include/__numeric/gcd_lcm.h +24 -34
- package/libcxx/include/__numeric/midpoint.h +9 -14
- package/libcxx/include/__numeric/pstl.h +2 -2
- package/libcxx/include/__numeric/saturation_arithmetic.h +13 -5
- package/libcxx/include/__ostream/basic_ostream.h +8 -8
- package/libcxx/include/__pstl/backends/default.h +14 -14
- package/libcxx/include/__pstl/backends/libdispatch.h +2 -2
- package/libcxx/include/__pstl/cpu_algos/find_if.h +1 -1
- package/libcxx/include/__pstl/cpu_algos/transform.h +5 -6
- package/libcxx/include/__pstl/cpu_algos/transform_reduce.h +5 -4
- package/libcxx/include/__random/binomial_distribution.h +10 -4
- package/libcxx/include/__random/mersenne_twister_engine.h +50 -154
- package/libcxx/include/__random/piecewise_constant_distribution.h +3 -2
- package/libcxx/include/__random/piecewise_linear_distribution.h +3 -2
- package/libcxx/include/__ranges/adjacent_transform_view.h +406 -0
- package/libcxx/include/__ranges/adjacent_view.h +419 -0
- package/libcxx/include/__ranges/as_rvalue_view.h +9 -9
- package/libcxx/include/__ranges/chunk_by_view.h +6 -6
- package/libcxx/include/__ranges/common_view.h +7 -7
- package/libcxx/include/__ranges/drop_view.h +8 -8
- package/libcxx/include/__ranges/drop_while_view.h +5 -5
- package/libcxx/include/__ranges/elements_of.h +49 -0
- package/libcxx/include/__ranges/empty_view.h +5 -5
- package/libcxx/include/__ranges/filter_view.h +10 -10
- package/libcxx/include/__ranges/iota_view.h +41 -22
- package/libcxx/include/__ranges/owning_view.h +15 -15
- package/libcxx/include/__ranges/ref_view.h +6 -6
- package/libcxx/include/__ranges/repeat_view.h +17 -10
- package/libcxx/include/__ranges/single_view.h +8 -8
- package/libcxx/include/__ranges/take_view.h +9 -9
- package/libcxx/include/__ranges/transform_view.h +1 -2
- package/libcxx/include/__ranges/view_interface.h +10 -10
- package/libcxx/include/__ranges/zip_transform_view.h +357 -0
- package/libcxx/include/__ranges/zip_view.h +20 -20
- package/libcxx/include/__split_buffer +612 -240
- package/libcxx/include/__stop_token/atomic_unique_lock.h +1 -1
- package/libcxx/include/__stop_token/stop_callback.h +2 -2
- package/libcxx/include/__stop_token/stop_source.h +1 -1
- package/libcxx/include/__stop_token/stop_state.h +4 -4
- package/libcxx/include/__stop_token/stop_token.h +1 -1
- package/libcxx/include/__string/char_traits.h +51 -31
- package/libcxx/include/__string/constexpr_c_functions.h +5 -5
- package/libcxx/include/__support/xlocale/__strtonum_fallback.h +0 -8
- package/libcxx/include/__system_error/error_category.h +8 -8
- package/libcxx/include/__system_error/error_code.h +5 -5
- package/libcxx/include/__system_error/error_condition.h +4 -4
- package/libcxx/include/__system_error/system_error.h +1 -1
- package/libcxx/include/__thread/id.h +1 -1
- package/libcxx/include/__thread/jthread.h +1 -1
- package/libcxx/include/__thread/poll_with_backoff.h +27 -8
- package/libcxx/include/__thread/support/c11.h +8 -8
- package/libcxx/include/__thread/support/pthread.h +8 -8
- package/libcxx/include/__thread/support/windows.h +8 -8
- package/libcxx/include/__thread/thread.h +13 -8
- package/libcxx/include/__thread/timed_backoff_policy.h +3 -2
- package/libcxx/include/__tree +849 -701
- package/libcxx/include/__tuple/sfinae_helpers.h +1 -44
- package/libcxx/include/__tuple/tuple_element.h +0 -12
- package/libcxx/include/__tuple/tuple_size.h +0 -4
- package/libcxx/include/__tuple/tuple_transform.h +45 -0
- package/libcxx/include/__type_traits/aligned_storage.h +13 -40
- package/libcxx/include/__type_traits/desugars_to.h +4 -0
- package/libcxx/include/__type_traits/invoke.h +8 -0
- package/libcxx/include/__type_traits/is_allocator.h +6 -7
- package/libcxx/include/__type_traits/is_array.h +26 -0
- package/libcxx/include/__type_traits/is_equality_comparable.h +16 -21
- package/libcxx/include/__type_traits/is_final.h +1 -1
- package/libcxx/include/__type_traits/is_floating_point.h +7 -6
- package/libcxx/include/__type_traits/is_generic_transparent_comparator.h +30 -0
- package/libcxx/include/__type_traits/is_specialization.h +2 -6
- package/libcxx/include/__type_traits/is_within_lifetime.h +29 -0
- package/libcxx/include/__type_traits/make_transparent.h +52 -0
- package/libcxx/include/__type_traits/reference_constructs_from_temporary.h +1 -7
- package/libcxx/include/__type_traits/reference_converts_from_temporary.h +1 -1
- package/libcxx/include/__utility/cmp.h +19 -7
- package/libcxx/include/__utility/default_three_way_comparator.h +70 -0
- package/libcxx/include/__utility/in_place.h +1 -1
- package/libcxx/include/__utility/integer_sequence.h +56 -41
- package/libcxx/include/__utility/lazy_synth_three_way_comparator.h +120 -0
- package/libcxx/include/__utility/pair.h +22 -25
- package/libcxx/include/__utility/scope_guard.h +2 -0
- package/libcxx/include/__utility/try_key_extraction.h +114 -0
- package/libcxx/include/__vector/vector.h +187 -160
- package/libcxx/include/__vector/vector_bool.h +76 -83
- package/libcxx/include/any +118 -155
- package/libcxx/include/array +88 -56
- package/libcxx/include/atomic +2 -0
- package/libcxx/include/barrier +20 -24
- package/libcxx/include/bitset +49 -30
- package/libcxx/include/ccomplex +3 -11
- package/libcxx/include/chrono +47 -0
- package/libcxx/include/ciso646 +3 -6
- package/libcxx/include/complex +77 -65
- package/libcxx/include/complex.h +10 -10
- package/libcxx/include/condition_variable +3 -3
- package/libcxx/include/cstdalign +3 -10
- package/libcxx/include/cstdbool +3 -10
- package/libcxx/include/ctgmath +2 -11
- package/libcxx/include/ctype.h +24 -24
- package/libcxx/include/cwchar +2 -2
- package/libcxx/include/deque +109 -225
- package/libcxx/include/errno.h +269 -269
- package/libcxx/include/exception +4 -1
- package/libcxx/include/ext/hash_map +7 -48
- package/libcxx/include/ext/hash_set +2 -8
- package/libcxx/include/fenv.h +43 -43
- package/libcxx/include/flat_map +663 -11
- package/libcxx/include/flat_set +543 -8
- package/libcxx/include/float.h +16 -16
- package/libcxx/include/forward_list +33 -53
- package/libcxx/include/fstream +57 -42
- package/libcxx/include/future +41 -51
- package/libcxx/include/initializer_list +9 -3
- package/libcxx/include/inttypes.h +16 -16
- package/libcxx/include/ios +28 -28
- package/libcxx/include/istream +19 -13
- package/libcxx/include/iterator +10 -0
- package/libcxx/include/latch +7 -5
- package/libcxx/include/limits +4 -4
- package/libcxx/include/list +61 -79
- package/libcxx/include/map +386 -274
- package/libcxx/include/math.h +19 -0
- package/libcxx/include/mdspan +1 -5
- package/libcxx/include/mutex +29 -19
- package/libcxx/include/optional +644 -149
- package/libcxx/include/print +9 -5
- package/libcxx/include/queue +39 -37
- package/libcxx/include/ranges +48 -0
- package/libcxx/include/regex +33 -31
- package/libcxx/include/scoped_allocator +16 -11
- package/libcxx/include/semaphore +15 -18
- package/libcxx/include/set +220 -192
- package/libcxx/include/shared_mutex +3 -8
- package/libcxx/include/span +53 -37
- package/libcxx/include/sstream +34 -28
- package/libcxx/include/stack +13 -15
- package/libcxx/include/stddef.h +10 -10
- package/libcxx/include/stdexcept +2 -2
- package/libcxx/include/stdio.h +20 -21
- package/libcxx/include/streambuf +59 -19
- package/libcxx/include/string +574 -573
- package/libcxx/include/string_view +113 -89
- package/libcxx/include/strstream +10 -10
- package/libcxx/include/syncstream +4 -4
- package/libcxx/include/tgmath.h +12 -12
- package/libcxx/include/tuple +242 -212
- package/libcxx/include/type_traits +8 -2
- package/libcxx/include/typeindex +5 -3
- package/libcxx/include/typeinfo +92 -89
- package/libcxx/include/unordered_map +179 -304
- package/libcxx/include/unordered_set +168 -195
- package/libcxx/include/utility +12 -0
- package/libcxx/include/valarray +106 -161
- package/libcxx/include/variant +25 -33
- package/libcxx/include/version +41 -24
- package/libcxx/include/wctype.h +29 -29
- package/libcxx/libc/hdr/errno_macros.h +3 -1
- package/libcxx/libc/hdr/stdint_proxy.h +18 -0
- package/libcxx/libc/hdr/types/wchar_t.h +23 -0
- package/libcxx/libc/hdr/wchar_overlay.h +69 -0
- package/libcxx/libc/include/llvm-libc-macros/cfloat128-macros.h +41 -0
- package/libcxx/libc/include/llvm-libc-macros/cfloat16-macros.h +20 -0
- package/libcxx/libc/include/llvm-libc-macros/wchar-macros.h +18 -0
- package/libcxx/libc/include/llvm-libc-types/cfloat128.h +11 -28
- package/libcxx/libc/include/llvm-libc-types/cfloat16.h +4 -7
- package/libcxx/libc/include/llvm-libc-types/wint_t.h +14 -0
- package/libcxx/libc/shared/libc_common.h +5 -0
- package/libcxx/libc/src/__support/CPP/bit.h +50 -12
- package/libcxx/libc/src/__support/CPP/type_traits/is_complex.h +7 -0
- package/libcxx/libc/src/__support/CPP/type_traits/is_destructible.h +2 -1
- package/libcxx/libc/src/__support/CPP/type_traits/is_unsigned.h +6 -0
- package/libcxx/libc/src/__support/CPP/utility/integer_sequence.h +10 -0
- package/libcxx/libc/src/__support/FPUtil/FPBits.h +6 -7
- package/libcxx/libc/src/__support/FPUtil/rounding_mode.h +50 -4
- package/libcxx/libc/src/__support/big_int.h +14 -14
- package/libcxx/libc/src/__support/common.h +3 -2
- package/libcxx/libc/src/__support/ctype_utils.h +19 -12
- package/libcxx/libc/src/__support/detailed_powers_of_ten.h +1 -2
- package/libcxx/libc/src/__support/high_precision_decimal.h +33 -14
- package/libcxx/libc/src/__support/libc_assert.h +2 -0
- package/libcxx/libc/src/__support/macros/attributes.h +44 -1
- package/libcxx/libc/src/__support/macros/config.h +23 -0
- package/libcxx/libc/src/__support/macros/null_check.h +1 -2
- package/libcxx/libc/src/__support/macros/optimization.h +3 -0
- package/libcxx/libc/src/__support/macros/properties/architectures.h +5 -1
- package/libcxx/libc/src/__support/macros/properties/compiler.h +8 -3
- package/libcxx/libc/src/__support/macros/properties/cpu_features.h +17 -1
- package/libcxx/libc/src/__support/macros/properties/types.h +2 -3
- package/libcxx/libc/src/__support/macros/sanitizer.h +0 -10
- package/libcxx/libc/src/__support/math_extras.h +20 -4
- package/libcxx/libc/src/__support/str_to_float.h +98 -125
- package/libcxx/libc/src/__support/str_to_integer.h +39 -27
- package/libcxx/libc/src/__support/wctype_utils.h +588 -0
- package/libcxx/src/any.cpp +4 -0
- package/libcxx/src/atomic.cpp +365 -80
- package/libcxx/src/barrier.cpp +4 -3
- package/libcxx/src/charconv.cpp +6 -3
- package/libcxx/src/condition_variable_destructor.cpp +1 -1
- package/libcxx/src/error_category.cpp +3 -1
- package/libcxx/src/exception.cpp +2 -10
- package/libcxx/src/experimental/time_zone.cpp +1 -1
- package/libcxx/src/experimental/tzdb.cpp +4 -1
- package/libcxx/src/filesystem/error.h +4 -22
- package/libcxx/src/filesystem/format_string.h +9 -18
- package/libcxx/src/filesystem/int128_builtins.cpp +2 -0
- package/libcxx/src/filesystem/operations.cpp +2 -9
- package/libcxx/src/filesystem/path.cpp +3 -1
- package/libcxx/src/include/aligned_alloc.h +65 -0
- package/libcxx/src/include/config_elast.h +1 -1
- package/libcxx/src/include/from_chars_floating_point.h +11 -7
- package/libcxx/src/include/overridable_function.h +8 -10
- package/libcxx/src/iostream.cpp +56 -37
- package/libcxx/src/locale.cpp +213 -196
- package/libcxx/src/memory.cpp +12 -14
- package/libcxx/src/mutex_destructor.cpp +1 -1
- package/libcxx/src/new.cpp +5 -5
- package/libcxx/src/optional.cpp +4 -0
- package/libcxx/src/print.cpp +9 -1
- package/libcxx/src/random.cpp +0 -26
- package/libcxx/src/string.cpp +10 -25
- package/libcxx/src/support/runtime/exception_fallback.ipp +2 -0
- package/libcxx/src/support/runtime/exception_glibcxx.ipp +3 -0
- package/libcxx/src/support/runtime/exception_libcxxabi.ipp +6 -2
- package/libcxx/src/support/runtime/exception_libcxxrt.ipp +2 -0
- package/libcxx/src/support/runtime/exception_msvc.ipp +2 -0
- package/libcxx/src/support/runtime/exception_pointer_cxxabi.ipp +9 -10
- package/libcxx/src/support/runtime/exception_pointer_glibcxx.ipp +2 -0
- package/libcxx/src/support/runtime/exception_pointer_msvc.ipp +1 -0
- package/libcxx/src/support/runtime/exception_pointer_unimplemented.ipp +1 -0
- package/libcxx/src/support/win32/locale_win32.cpp +1 -1
- package/libcxx/src/system_error.cpp +2 -0
- package/libcxx/src/thread.cpp +1 -3
- package/libcxx/src/valarray.cpp +1 -2
- package/libcxx/src/vector.cpp +2 -2
- package/libcxxabi/include/__cxxabi_config.h +42 -23
- package/libcxxabi/src/cxa_exception.cpp +4 -2
- package/libcxxabi/src/cxa_exception.h +16 -14
- package/libcxxabi/src/cxa_personality.cpp +126 -9
- package/libcxxabi/src/cxa_thread_atexit.cpp +2 -1
- package/libcxxabi/src/demangle/DemangleConfig.h +4 -0
- package/libcxxabi/src/demangle/ItaniumDemangle.h +9 -6
- package/libcxxabi/src/demangle/Utility.h +21 -7
- package/libcxxabi/src/fallback_malloc.cpp +1 -1
- package/libcxxabi/src/private_typeinfo.cpp +6 -0
- package/libcxxabi/src/stdlib_new_delete.cpp +5 -5
- package/libtsan/LICENSE.TXT +311 -0
- package/libtsan/builtins/assembly.h +41 -8
- package/libtsan/interception/interception_win.cpp +4 -0
- package/libtsan/sanitizer_common/sanitizer_allocator_primary32.h +1 -0
- package/libtsan/sanitizer_common/sanitizer_allocator_primary64.h +18 -0
- package/libtsan/sanitizer_common/sanitizer_common.h +15 -2
- package/libtsan/sanitizer_common/sanitizer_common_interceptors.inc +30 -4
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_ioctl.inc +4 -0
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_aarch64.inc.S +2 -1
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_i386.inc.S +2 -0
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_x86_64.inc.S +2 -0
- package/libtsan/sanitizer_common/sanitizer_common_syscalls.inc +18 -0
- package/libtsan/sanitizer_common/sanitizer_file.cpp +40 -12
- package/libtsan/sanitizer_common/sanitizer_file.h +3 -0
- package/libtsan/sanitizer_common/sanitizer_flags.inc +7 -0
- package/libtsan/sanitizer_common/sanitizer_fuchsia.cpp +30 -3
- package/libtsan/sanitizer_common/sanitizer_haiku.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_internal_defs.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_libc.cpp +8 -0
- package/libtsan/sanitizer_common/sanitizer_libc.h +1 -0
- package/libtsan/sanitizer_common/sanitizer_linux.cpp +15 -7
- package/libtsan/sanitizer_common/sanitizer_linux.h +3 -3
- package/libtsan/sanitizer_common/sanitizer_linux_libcdep.cpp +1 -0
- package/libtsan/sanitizer_common/sanitizer_mac.cpp +255 -104
- package/libtsan/sanitizer_common/sanitizer_mac.h +5 -0
- package/libtsan/sanitizer_common/sanitizer_netbsd.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_platform.h +27 -1
- package/libtsan/sanitizer_common/sanitizer_platform_interceptors.h +5 -4
- package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.cpp +15 -17
- package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.h +32 -6
- package/libtsan/sanitizer_common/sanitizer_posix.cpp +3 -12
- package/libtsan/sanitizer_common/sanitizer_posix.h +2 -1
- package/libtsan/sanitizer_common/sanitizer_posix_libcdep.cpp +19 -0
- package/libtsan/sanitizer_common/sanitizer_procmaps_mac.cpp +102 -37
- package/libtsan/sanitizer_common/sanitizer_redefine_builtins.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_signal_interceptors.inc +40 -2
- package/libtsan/sanitizer_common/sanitizer_stoptheworld.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_linux_libcdep.cpp +83 -12
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_mac.cpp +3 -3
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_netbsd_libcdep.cpp +7 -7
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_win.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_symbolizer_internal.h +5 -1
- package/libtsan/sanitizer_common/sanitizer_symbolizer_libcdep.cpp +11 -1
- package/libtsan/sanitizer_common/sanitizer_symbolizer_mac.cpp +86 -29
- package/libtsan/sanitizer_common/sanitizer_symbolizer_posix_libcdep.cpp +27 -16
- package/libtsan/sanitizer_common/sanitizer_thread_registry.cpp +5 -4
- package/libtsan/sanitizer_common/sanitizer_thread_registry.h +4 -4
- package/libtsan/sanitizer_common/sanitizer_win.cpp +1 -3
- package/libtsan/tsan_debugging.cpp +2 -2
- package/libtsan/tsan_flags.cpp +37 -0
- package/libtsan/tsan_flags.h +8 -0
- package/libtsan/tsan_flags.inc +12 -0
- package/libtsan/tsan_interceptors.h +9 -1
- package/libtsan/tsan_interceptors_mac.cpp +19 -0
- package/libtsan/tsan_interceptors_posix.cpp +78 -32
- package/libtsan/tsan_interface.h +3 -3
- package/libtsan/tsan_interface_ann.cpp +23 -9
- package/libtsan/tsan_mman.cpp +18 -4
- package/libtsan/tsan_platform.h +44 -7
- package/libtsan/tsan_platform_linux.cpp +42 -14
- package/libtsan/tsan_platform_mac.cpp +16 -3
- package/libtsan/tsan_report.h +14 -1
- package/libtsan/tsan_rtl.cpp +14 -0
- package/libtsan/tsan_rtl.h +7 -2
- package/libtsan/tsan_rtl_aarch64.S +3 -5
- package/libtsan/tsan_rtl_access.cpp +8 -3
- package/libtsan/tsan_rtl_amd64.S +2 -0
- package/libtsan/tsan_rtl_mutex.cpp +94 -49
- package/libtsan/tsan_rtl_report.cpp +132 -65
- package/libtsan/tsan_rtl_thread.cpp +31 -9
- package/libtsan/tsan_symbolize.cpp +1 -1
- package/libtsan/tsan_symbolize.h +1 -1
- package/libtsan/tsan_trace.h +1 -1
- package/libunwind/include/__libunwind_config.h +11 -2
- package/libunwind/include/libunwind.h +117 -11
- package/libunwind/include/unwind_arm_ehabi.h +4 -1
- package/libunwind/src/AddressSpace.hpp +42 -20
- package/libunwind/src/CompactUnwinder.hpp +16 -5
- package/libunwind/src/DwarfInstructions.hpp +24 -13
- package/libunwind/src/DwarfParser.hpp +62 -23
- package/libunwind/src/EHHeaderParser.hpp +7 -4
- package/libunwind/src/Registers.hpp +226 -22
- package/libunwind/src/Unwind-seh.cpp +6 -7
- package/libunwind/src/Unwind-wasm.c +7 -7
- package/libunwind/src/UnwindCursor.hpp +167 -49
- package/libunwind/src/UnwindLevel1.c +46 -17
- package/libunwind/src/UnwindRegistersRestore.S +46 -5
- package/libunwind/src/UnwindRegistersSave.S +86 -2
- package/libunwind/src/assembly.h +5 -1
- package/libunwind/src/config.h +9 -0
- package/libunwind/src/gcc_personality_v0.c +79 -6
- package/libunwind/src/libunwind.cpp +104 -4
- package/libunwind/src/libunwind_ext.h +7 -1
- package/libunwind/src/shadow_stack_unwind.h +2 -2
- package/lldb/pretty_printers.py +948 -0
- package/package.json +1 -1
- package/std/Build/Cache/Path.zig +42 -43
- package/std/Build/Cache.zig +19 -9
- package/std/Build/Configuration.zig +3479 -0
- package/std/Build/Module.zig +99 -225
- package/std/Build/Step/CheckFile.zig +17 -63
- package/std/Build/Step/Compile.zig +97 -1426
- package/std/Build/Step/ConfigHeader.zig +56 -944
- package/std/Build/Step/Fail.zig +10 -20
- package/std/Build/Step/FindProgram.zig +31 -0
- package/std/Build/Step/Fmt.zig +22 -57
- package/std/Build/Step/InstallArtifact.zig +26 -141
- package/std/Build/Step/InstallDir.zig +14 -67
- package/std/Build/Step/InstallFile.zig +12 -21
- package/std/Build/Step/ObjCopy.zig +82 -199
- package/std/Build/Step/Options.zig +55 -284
- package/std/Build/Step/Run.zig +138 -2246
- package/std/Build/Step/TranslateC.zig +55 -164
- package/std/Build/Step/UpdateSourceFiles.zig +38 -91
- package/std/Build/Step/WriteFile.zig +113 -328
- package/std/Build/Step.zig +45 -916
- package/std/Build/abi.zig +1 -1
- package/std/Build.zig +725 -770
- package/std/Io/Dir.zig +12 -7
- package/std/Io/Dispatch.zig +5 -5
- package/std/Io/File/Writer.zig +8 -6
- package/std/Io/File.zig +6 -9
- package/std/Io/Kqueue.zig +5 -5
- package/std/Io/Reader.zig +66 -23
- package/std/Io/RwLock.zig +2 -0
- package/std/Io/Terminal.zig +1 -1
- package/std/Io/Threaded.zig +36 -30
- package/std/Io/Uring.zig +11 -9
- package/std/Io/Writer.zig +125 -37
- package/std/Io/net/HostName.zig +11 -6
- package/std/Io/net.zig +3 -1
- package/std/Io.zig +29 -19
- package/std/Progress.zig +2 -2
- package/std/Random/ChaCha.zig +2 -2
- package/std/Random/benchmark.zig +2 -2
- package/std/Random.zig +6 -6
- package/std/SemanticVersion.zig +1 -1
- package/std/Target/Query.zig +4 -5
- package/std/Target/aarch64.zig +622 -79
- package/std/Target/alpha.zig +2 -2
- package/std/Target/amdgcn.zig +423 -23
- package/std/Target/arc.zig +2 -2
- package/std/Target/arm.zig +42 -8
- package/std/Target/avr.zig +2 -2
- package/std/Target/bpf.zig +8 -2
- package/std/Target/csky.zig +2 -2
- package/std/Target/hexagon.zig +43 -8
- package/std/Target/hppa.zig +2 -2
- package/std/Target/kvx.zig +2 -2
- package/std/Target/lanai.zig +2 -2
- package/std/Target/loongarch.zig +20 -2
- package/std/Target/m68k.zig +2 -2
- package/std/Target/mips.zig +8 -2
- package/std/Target/msp430.zig +2 -2
- package/std/Target/nvptx.zig +60 -37
- package/std/Target/powerpc.zig +29 -21
- package/std/Target/propeller.zig +2 -2
- package/std/Target/riscv.zig +514 -179
- package/std/Target/s390x.zig +2 -2
- package/std/Target/sparc.zig +19 -2
- package/std/Target/spirv.zig +3 -3
- package/std/Target/ve.zig +2 -2
- package/std/Target/wasm.zig +9 -2
- package/std/Target/x86.zig +202 -33
- package/std/Target/xcore.zig +2 -2
- package/std/Target/xtensa.zig +67 -2
- package/std/Target.zig +101 -62
- package/std/Thread.zig +39 -6
- package/std/array_hash_map.zig +104 -59
- package/std/array_list.zig +20 -35
- package/std/ascii.zig +0 -9
- package/std/atomic.zig +2 -0
- package/std/base64.zig +5 -5
- package/std/bit_set.zig +85 -93
- package/std/c/darwin.zig +7 -1
- package/std/c.zig +88 -29
- package/std/coff.zig +1 -1
- package/std/compress/flate/Compress.zig +4 -2
- package/std/compress/flate/Decompress.zig +3 -4
- package/std/compress/zstd/Decompress.zig +7 -9
- package/std/crypto/25519/curve25519.zig +2 -2
- package/std/crypto/25519/edwards25519.zig +3 -3
- package/std/crypto/25519/ristretto255.zig +2 -2
- package/std/crypto/25519/scalar.zig +6 -6
- package/std/crypto/25519/x25519.zig +1 -1
- package/std/crypto/Certificate.zig +14 -2
- package/std/crypto/Sha1.zig +1 -1
- package/std/crypto/aegis.zig +45 -39
- package/std/crypto/aes/aesni.zig +1 -1
- package/std/crypto/aes/armcrypto.zig +4 -4
- package/std/crypto/aes/soft.zig +4 -4
- package/std/crypto/aes.zig +12 -0
- package/std/crypto/aes_ccm.zig +22 -22
- package/std/crypto/aes_gcm.zig +10 -12
- package/std/crypto/aes_ocb.zig +9 -9
- package/std/crypto/aes_siv.zig +4 -2
- package/std/crypto/argon2.zig +15 -15
- package/std/crypto/ascon.zig +75 -35
- package/std/crypto/bcrypt.zig +20 -10
- package/std/crypto/benchmark.zig +7 -7
- package/std/crypto/blake2.zig +100 -64
- package/std/crypto/cbc_mac.zig +1 -1
- package/std/crypto/chacha20.zig +10 -10
- package/std/crypto/cmac.zig +3 -3
- package/std/crypto/codecs/asn1/Oid.zig +22 -11
- package/std/crypto/codecs/asn1/der/Decoder.zig +51 -20
- package/std/crypto/codecs/asn1/der/Encoder.zig +111 -46
- package/std/crypto/codecs/asn1/der.zig +42 -0
- package/std/crypto/codecs/asn1.zig +97 -38
- package/std/crypto/codecs/base64_hex_ct.zig +3 -5
- package/std/crypto/codecs.zig +6 -0
- package/std/crypto/ecdsa.zig +9 -9
- package/std/crypto/ff.zig +7 -6
- package/std/crypto/ghash_polyval.zig +4 -4
- package/std/crypto/hkdf.zig +1 -1
- package/std/crypto/isap.zig +3 -3
- package/std/crypto/kangarootwelve.zig +1 -1
- package/std/crypto/keccak_p.zig +8 -8
- package/std/crypto/md5.zig +1 -1
- package/std/crypto/ml_dsa.zig +39 -39
- package/std/crypto/ml_kem.zig +12 -34
- package/std/crypto/modes.zig +2 -2
- package/std/crypto/pbkdf2.zig +1 -1
- package/std/crypto/pcurves/common.zig +4 -5
- package/std/crypto/pcurves/p256/scalar.zig +3 -3
- package/std/crypto/pcurves/p384/scalar.zig +2 -2
- package/std/crypto/pcurves/secp256k1/scalar.zig +3 -3
- package/std/crypto/pcurves/tests/p256.zig +5 -5
- package/std/crypto/pcurves/tests/p384.zig +5 -5
- package/std/crypto/pcurves/tests/secp256k1.zig +3 -3
- package/std/crypto/phc_encoding.zig +23 -20
- package/std/crypto/salsa20.zig +8 -14
- package/std/crypto/sha2.zig +2 -2
- package/std/crypto/sha3.zig +2 -4
- package/std/crypto/siphash.zig +1 -1
- package/std/crypto/timing_safe.zig +11 -10
- package/std/crypto/tls/Client.zig +107 -16
- package/std/crypto/tls.zig +2 -2
- package/std/crypto.zig +4 -3
- package/std/debug/Dwarf/Unwind/VirtualMachine.zig +11 -5
- package/std/debug/Dwarf.zig +21 -12
- package/std/debug/ElfFile.zig +12 -8
- package/std/debug/MachOFile.zig +2 -2
- package/std/debug/Pdb.zig +86 -51
- package/std/debug/SelfInfo/Elf.zig +13 -9
- package/std/debug/SelfInfo/MachO.zig +44 -17
- package/std/debug/SelfInfo/Windows.zig +5 -7
- package/std/debug/cpu_context.zig +231 -39
- package/std/debug.zig +16 -8
- package/std/deque.zig +1 -1
- package/std/elf.zig +29 -12
- package/std/enums.zig +74 -87
- package/std/fmt/float.zig +2 -0
- package/std/fmt/parse_float/decimal.zig +1 -1
- package/std/fmt/parse_float.zig +1 -1
- package/std/fmt.zig +7 -8
- package/std/fs/path.zig +7 -5
- package/std/gpu.zig +1 -1
- package/std/hash/Adler32.zig +3 -3
- package/std/hash/auto_hash.zig +8 -8
- package/std/hash/benchmark.zig +2 -2
- package/std/hash/verify.zig +3 -3
- package/std/hash/wyhash.zig +2 -2
- package/std/hash/xxhash.zig +0 -6
- package/std/hash_map.zig +22 -2
- package/std/heap/ArenaAllocator.zig +3 -5
- package/std/heap/BrkAllocator.zig +1 -1
- package/std/heap/BufferFirstAllocator.zig +165 -0
- package/std/heap/SafeAllocator.zig +2180 -0
- package/std/heap/debug_allocator.zig +2 -2
- package/std/heap/memory_pool.zig +34 -197
- package/std/heap.zig +20 -133
- package/std/http/Client.zig +2 -2
- package/std/http.zig +4 -5
- package/std/json/Scanner.zig +2 -2
- package/std/json/Stringify.zig +14 -14
- package/std/json/static.zig +49 -32
- package/std/json.zig +1 -1
- package/std/{builtin → lang}/assembly.zig +71 -0
- package/std/{builtin.zig → lang.zig} +70 -100
- package/std/leb128.zig +2 -2
- package/std/math/acos.zig +6 -0
- package/std/math/asin.zig +6 -0
- package/std/math/atan.zig +5 -0
- package/std/math/big/int.zig +5 -5
- package/std/math/big.zig +4 -4
- package/std/math/copysign.zig +1 -1
- package/std/math/float.zig +62 -0
- package/std/math/frexp.zig +4 -4
- package/std/math/hypot.zig +4 -0
- package/std/math/ilogb.zig +1 -1
- package/std/math/isfinite.zig +1 -1
- package/std/math/isinf.zig +1 -1
- package/std/math/isnan.zig +6 -2
- package/std/math/isnormal.zig +2 -2
- package/std/math/iszero.zig +2 -2
- package/std/math/ldexp.zig +2 -2
- package/std/math/log10.zig +0 -2
- package/std/math/log1p.zig +13 -19
- package/std/math/modf.zig +1 -2
- package/std/math/nextafter.zig +3 -4
- package/std/math/pow.zig +1 -1
- package/std/math/powi.zig +2 -3
- package/std/math/signbit.zig +0 -1
- package/std/math.zig +28 -28
- package/std/mem/Allocator.zig +14 -18
- package/std/mem.zig +137 -176
- package/std/meta/trailer_flags.zig +27 -20
- package/std/meta.zig +134 -215
- package/std/multi_array_list.zig +70 -54
- package/std/os/emscripten.zig +7 -6
- package/std/os/linux/IoUring.zig +2 -0
- package/std/os/linux/alpha.zig +358 -0
- package/std/os/linux/arm.zig +0 -26
- package/std/os/linux/bpf.zig +6 -0
- package/std/os/linux/csky.zig +165 -0
- package/std/os/linux/ioctl.zig +3 -2
- package/std/os/linux/microblaze.zig +170 -0
- package/std/os/linux/sh.zig +239 -0
- package/std/os/linux/sparc.zig +277 -0
- package/std/os/linux/sparc64.zig +44 -30
- package/std/os/linux/syscalls.zig +2246 -13
- package/std/os/linux/tls.zig +12 -1
- package/std/os/linux/x86.zig +2 -2
- package/std/os/linux/xtensa.zig +193 -0
- package/std/os/linux.zig +829 -58
- package/std/os/plan9.zig +1 -1
- package/std/os/uefi/hii.zig +1 -1
- package/std/os/uefi/protocol/device_path.zig +8 -7
- package/std/os/uefi/protocol/file.zig +16 -0
- package/std/os/uefi/tables/boot_services.zig +9 -8
- package/std/os/uefi/tables/runtime_services.zig +1 -1
- package/std/os/windows.zig +139 -16
- package/std/os.zig +0 -15
- package/std/pie.zig +19 -0
- package/std/posix.zig +2 -2
- package/std/process/Child.zig +20 -0
- package/std/process/Environ.zig +28 -4
- package/std/process.zig +13 -5
- package/std/simd.zig +4 -21
- package/std/sort/pdq.zig +91 -13
- package/std/start.zig +63 -22
- package/std/static_string_map.zig +59 -1
- package/std/std.zig +8 -1
- package/std/tar/Writer.zig +39 -33
- package/std/tar.zig +8 -4
- package/std/testing/Smith.zig +35 -21
- package/std/testing.zig +83 -30
- package/std/unicode.zig +13 -8
- package/std/zig/Ast/Render.zig +6 -30
- package/std/zig/Ast.zig +16 -41
- package/std/zig/AstGen.zig +216 -300
- package/std/zig/AstRlAnnotate.zig +1 -11
- package/std/zig/AstSmith.zig +5 -11
- package/std/zig/ErrorBundle.zig +22 -15
- package/std/zig/LibCDirs.zig +14 -7
- package/std/zig/LibCInstallation.zig +61 -26
- package/std/zig/Parse.zig +18 -83
- package/std/zig/PkgConfig.zig +151 -0
- package/std/zig/TokenSmith.zig +0 -6
- package/std/zig/WindowsSdk.zig +18 -18
- package/std/zig/Zir.zig +22 -76
- package/std/zig/ZonGen.zig +19 -27
- package/std/zig/c_translation/helpers.zig +2 -2
- package/std/zig/llvm/BitcodeReader.zig +3 -3
- package/std/zig/llvm/Builder.zig +163 -126
- package/std/zig/llvm/bitcode_writer.zig +7 -7
- package/std/zig/llvm/ir.zig +8 -8
- package/std/zig/system/arm.zig +56 -2
- package/std/zig/system/darwin/macos.zig +11 -7
- package/std/zig/system/linux.zig +4 -0
- package/std/zig/system/loongarch.zig +25 -9
- package/std/zig/system/windows.zig +45 -12
- package/std/zig/system/x86.zig +60 -16
- package/std/zig/system.zig +23 -30
- package/std/zig/target.zig +3 -5
- package/std/zig/tokenizer.zig +4 -43
- package/std/zig.zig +114 -26
- package/std/zip.zig +5 -5
- package/std/zon/Serializer.zig +34 -25
- package/std/zon/parse.zig +84 -62
- package/ubsan_rt.zig +3 -3
- package/zig.h +61 -11
- package/compiler/build_runner.zig +0 -1857
- package/compiler_rt/long_double.zig +0 -37
- package/include/amxbf16transposeintrin.h +0 -94
- package/include/amxcomplextransposeintrin.h +0 -303
- package/include/amxfp16transposeintrin.h +0 -94
- package/include/amxmovrstransposeintrin.h +0 -200
- package/include/amxtf32transposeintrin.h +0 -105
- package/include/amxtransposeintrin.h +0 -248
- package/libc/include/arm-netbsd-eabi/machine/frame.h +0 -130
- package/libc/include/generic-netbsd/powerpc/bswap.h +0 -8
- package/libc/include/hexagon-linux-any/asm/signal.h +0 -29
- package/libc/include/mips-netbsd-eabi/machine/psl.h +0 -3
- package/libc/include/mips-netbsd-eabi/machine/reloc.h +0 -3
- package/libc/include/mips-netbsd-eabi/machine/trap.h +0 -3
- package/libc/include/mips64el-openbsd-none/loongson/hibernate.h +0 -33
- package/libc/include/mips64el-openbsd-none/loongson/hibernate_var.h +0 -39
- package/libc/include/mips64el-openbsd-none/machine/hibernate.h +0 -33
- package/libc/include/mips64el-openbsd-none/machine/hibernate_var.h +0 -39
- package/libc/include/s390x-linux-any/asm/tape390.h +0 -103
- package/libc/mingw/math/lrintl.c +0 -18
- package/libc/mingw/math/rintl.c +0 -16
- package/libc/mingw/winpthreads/spinlock.c +0 -82
- package/libc/musl/src/linux/tee.c +0 -8
- package/libc/musl/src/math/i386/log1p.s +0 -25
- package/libc/musl/src/math/i386/log1pf.s +0 -26
- package/libc/musl/src/math/i386/lrintl.c +0 -8
- package/libc/musl/src/math/i386/rintl.c +0 -7
- package/libc/musl/src/math/log1p.c +0 -122
- package/libc/musl/src/math/log1pf.c +0 -77
- package/libc/musl/src/math/lrintl.c +0 -36
- package/libc/musl/src/math/rintl.c +0 -29
- package/libc/musl/src/math/s390x/rintl.c +0 -15
- package/libc/musl/src/math/x32/lrintl.s +0 -7
- package/libc/musl/src/math/x32/rintl.s +0 -6
- package/libc/musl/src/math/x86_64/lrintl.c +0 -8
- package/libc/musl/src/math/x86_64/rintl.c +0 -7
- package/libc/musl/src/string/strdup.c +0 -10
- package/libc/musl/src/string/strndup.c +0 -12
- package/libc/musl/src/string/wcsdup.c +0 -10
- package/libc/musl/src/thread/pthread_spin_destroy.c +0 -6
- package/libc/musl/src/thread/pthread_spin_init.c +0 -6
- package/libc/musl/src/thread/pthread_spin_lock.c +0 -8
- package/libc/musl/src/thread/pthread_spin_trylock.c +0 -7
- package/libc/musl/src/thread/pthread_spin_unlock.c +0 -7
- package/libc/wasi/thread-stub/pthread_spin_lock.c +0 -8
- package/libc/wasi/thread-stub/pthread_spin_trylock.c +0 -8
- package/libc/wasi/thread-stub/pthread_spin_unlock.c +0 -7
- package/libtsan/sanitizer_common/sanitizer_coverage_interface.inc +0 -43
- package/std/Build/Step/CheckObject.zig +0 -2764
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ansi.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/aout_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/asm.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/bswap.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/cdefs.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/cpu.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/disklabel.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/elf_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/endian.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/endian_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/fenv.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/float.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/fpu.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/frame.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ieee.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ieeefp.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_const.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_fmtio.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_limits.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_mwgwtypes.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_types.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/intr.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/kcore.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/limits.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/lock.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/math.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/mcontext.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/mutex.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/param.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/pcb.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/pmap.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/proc.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/profile.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/psl.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/pte.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ptrace.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/reg.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/reloc.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/rwlock.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/setjmp.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/signal.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/sljit_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/trap.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/types.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/vmparam.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/wchar_limits.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/machine/fpu.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/machine/intr.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ansi.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/aout_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/cdefs.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/elf_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/endian.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/endian_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/float.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/fpu.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/frame.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/cpu.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/spr.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/tlb.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ieeefp.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_const.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_fmtio.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_limits.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_mwgwtypes.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_types.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/kcore.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/lock.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/math.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/bat.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/hid_601.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/pte.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/spr.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/sr_601.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/vmparam.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/param.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/pcb.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/proc.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/profile.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/pte.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ptrace.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/reg.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/reloc.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/rwlock.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/setjmp.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/signal.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/sljit_machdep.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/spr.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/trap.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/types.h +0 -0
- /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/wchar_limits.h +0 -0
|
@@ -0,0 +1,2180 @@
|
|
|
1
|
+
//! Provides the following guarantees:
|
|
2
|
+
//! * `deinit` reports all leaks and frees all backing memory.
|
|
3
|
+
//! * All allocation mismatches result in either a panic or segmentation fault.
|
|
4
|
+
//! * Allocations from other `SafeAllocator` instances cause a panic (if `Options.canary` differ).
|
|
5
|
+
//! * Double frees and operation (resize, remap, and free) races panic or segmentation fault.
|
|
6
|
+
//!
|
|
7
|
+
//! Given the backing allocator does not reuse memory, this does not reuse memory either and
|
|
8
|
+
//! * Most writes after free will segmentation fault or are eventually detected and panic.
|
|
9
|
+
//!
|
|
10
|
+
//! Thread-safe
|
|
11
|
+
|
|
12
|
+
// General Design:
|
|
13
|
+
//
|
|
14
|
+
// Every allocation is trailed by an `AllocFooter` which contains metadata for the allocation and
|
|
15
|
+
// stack traces. It is protected by a checksum to catch corruption from allocation overwrites and
|
|
16
|
+
// report canary mismatches. An allocation's memory has a minimum alignment of `AllocFooter` so
|
|
17
|
+
// that the footer is at a fixed offset determined from the allocation size. An allocation's memory
|
|
18
|
+
// is stored either:
|
|
19
|
+
// * Inside linearly-filled buckets for small allocations.
|
|
20
|
+
// * Inside an allocation directly from the backing allocator.
|
|
21
|
+
//
|
|
22
|
+
// To track allocations, each thread maintains a table of backing allocations. The table may be
|
|
23
|
+
// modified by other threads in the case of a producer-consumer operation, so the table is a linked
|
|
24
|
+
// list only expanded by creating new segments. Each thread maintains a linked list of free
|
|
25
|
+
// entries, which may contain entries from other threads' tables.
|
|
26
|
+
//
|
|
27
|
+
// In the case of producer-consumer operations, acquire/release ordering is assumed to be provided
|
|
28
|
+
// externally. This is also assumed by all other thread-safe allocators that reuse memory as
|
|
29
|
+
// otherwise there would be data races on reuse of allocated memory.
|
|
30
|
+
|
|
31
|
+
const std = @import("../std.zig");
|
|
32
|
+
const math = std.math;
|
|
33
|
+
const mem = std.mem;
|
|
34
|
+
const Alignment = mem.Alignment;
|
|
35
|
+
const assert = std.debug.assert;
|
|
36
|
+
const panic = std.debug.panic;
|
|
37
|
+
|
|
38
|
+
const SafeAllocator = @This();
|
|
39
|
+
const scoped_log = std.log.scoped(.SafeAllocator);
|
|
40
|
+
|
|
41
|
+
pub const Options = struct {
|
|
42
|
+
const is_debug = @import("builtin").mode == .Debug;
|
|
43
|
+
const page_size_log2 = @max(math.log2_int(usize, std.heap.page_size_max), 8);
|
|
44
|
+
|
|
45
|
+
stack_trace_frames: usize = if (is_debug and std.debug.sys_can_stack_trace) 7 else 0,
|
|
46
|
+
check_write_after_free: bool = is_debug,
|
|
47
|
+
/// A unique value used to check that allocations created by other
|
|
48
|
+
/// `SafeAllocator` instances are not passed to this one.
|
|
49
|
+
canary: u32 = 0x85dff10f,
|
|
50
|
+
|
|
51
|
+
/// Controls the block size and alignment of allocation buckets.
|
|
52
|
+
///
|
|
53
|
+
/// Changing this is useful to save memory if the backing allocator offers better granuality,
|
|
54
|
+
/// or if the backing allocator has a limit on active allocations, however decreasing this
|
|
55
|
+
/// can harm performance.
|
|
56
|
+
///
|
|
57
|
+
/// Asserted to be >= 8
|
|
58
|
+
bucket_size_log2: u5 = @max(page_size_log2, 13),
|
|
59
|
+
/// Controls the block size of internal metadata.
|
|
60
|
+
///
|
|
61
|
+
/// Changing this is useful to save memory if the backing allocator offers better granuality,
|
|
62
|
+
/// or if the backing allocator has a limit on active allocations, however decreasing this
|
|
63
|
+
/// can harm performance.
|
|
64
|
+
///
|
|
65
|
+
/// Asserted to be >= 8
|
|
66
|
+
block_size_log2: u5 = page_size_log2,
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
var n_threads: usize = 0;
|
|
70
|
+
threadlocal var thread_index: usize = 0;
|
|
71
|
+
|
|
72
|
+
backing: mem.Allocator,
|
|
73
|
+
// Needs to be a fixed size so the max `n_threads` value is agreed upon by all instances.
|
|
74
|
+
threads: [128]Thread,
|
|
75
|
+
|
|
76
|
+
bucket_size_log2: u5,
|
|
77
|
+
block_size_log2: u5,
|
|
78
|
+
/// In `usize`s
|
|
79
|
+
stack_trace_size: usize,
|
|
80
|
+
/// In `usize`s
|
|
81
|
+
allocs_entry_count: usize,
|
|
82
|
+
large_alloc_threshold: usize,
|
|
83
|
+
|
|
84
|
+
canary: u32,
|
|
85
|
+
check_write_after_free: bool,
|
|
86
|
+
|
|
87
|
+
fn bucketSize(s: *SafeAllocator) u32 {
|
|
88
|
+
return @as(u32, 1) << s.bucket_size_log2;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
fn bucketMask(s: *SafeAllocator) u32 {
|
|
92
|
+
return s.bucketSize() - 1;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
const Thread = struct {
|
|
96
|
+
/// Avoid false sharing.
|
|
97
|
+
_: void align(std.atomic.cache_line) = {},
|
|
98
|
+
|
|
99
|
+
mutex: std.atomic.Mutex,
|
|
100
|
+
fill_bucket: ?*Bucket,
|
|
101
|
+
free_entry: ?*Allocs.Entry,
|
|
102
|
+
allocs_next: usize,
|
|
103
|
+
allocs_first: ?*Allocs,
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
/// Trailed by `[allocs_entry_count]Entry`
|
|
107
|
+
const Allocs = extern struct {
|
|
108
|
+
next: ?*Allocs,
|
|
109
|
+
|
|
110
|
+
comptime {
|
|
111
|
+
assert(@alignOf(@This()) == @alignOf(usize));
|
|
112
|
+
assert(@sizeOf(@This()) == @sizeOf(usize));
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
fn usizes(a: *Allocs, s: *SafeAllocator) []usize {
|
|
116
|
+
return @as([*]usize, @ptrCast(a))[0 .. 1 + s.allocs_entry_count];
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
fn entries(a: *Allocs, s: *SafeAllocator) []Entry {
|
|
120
|
+
return @as([*]Entry, @ptrCast(a))[1..][0..s.allocs_entry_count];
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
const Entry = packed struct(usize) {
|
|
124
|
+
kind: Kind,
|
|
125
|
+
ptr_high: @Int(.unsigned, @bitSizeOf(usize) - 2),
|
|
126
|
+
|
|
127
|
+
const Kind = enum(u2) { free, bucket, large_alloc };
|
|
128
|
+
|
|
129
|
+
comptime {
|
|
130
|
+
assert(@alignOf(Entry) >= 4);
|
|
131
|
+
assert(@alignOf(Bucket) >= 4);
|
|
132
|
+
assert(@alignOf(AllocFooter) >= 4);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
fn fromFree(ptr: ?*Entry) Entry {
|
|
136
|
+
return .{
|
|
137
|
+
.ptr_high = @intCast(@intFromPtr(ptr) >> 2),
|
|
138
|
+
.kind = .free,
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
fn fromBucket(ptr: *Bucket) Entry {
|
|
143
|
+
return .{
|
|
144
|
+
.ptr_high = @intCast(@intFromPtr(ptr) >> 2),
|
|
145
|
+
.kind = .bucket,
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
fn fromLargeAlloc(ptr: *AllocFooter) Entry {
|
|
150
|
+
return .{
|
|
151
|
+
.ptr_high = @intCast(@intFromPtr(ptr) >> 2),
|
|
152
|
+
.kind = .large_alloc,
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
fn toFree(ent: Entry) ?*Entry {
|
|
157
|
+
assert(ent.kind == .free);
|
|
158
|
+
return @ptrFromInt(@as(usize, ent.ptr_high) << 2);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
fn toBucket(ent: Entry) *Bucket {
|
|
162
|
+
assert(ent.kind == .bucket);
|
|
163
|
+
return @ptrFromInt(@as(usize, ent.ptr_high) << 2);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
fn toLargeAlloc(ent: Entry) *AllocFooter {
|
|
167
|
+
assert(ent.kind == .large_alloc);
|
|
168
|
+
return @ptrFromInt(@as(usize, ent.ptr_high) << 2);
|
|
169
|
+
}
|
|
170
|
+
};
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
/// This struct contains the header for a bucket. It is always part of a larger
|
|
174
|
+
/// allocations of length and alignment `bucketSize()`.
|
|
175
|
+
///
|
|
176
|
+
/// All allocations inside buckets have a minimum of 8-byte alignment (including length)
|
|
177
|
+
/// so that allocations with 8-byte alignment or less do not need to store the location
|
|
178
|
+
/// of the previous footer since it is directly before it. This property is used by non-
|
|
179
|
+
/// extended footers to omit the offset of the previous footer.
|
|
180
|
+
const Bucket = struct {
|
|
181
|
+
entry: *Allocs.Entry,
|
|
182
|
+
/// Accesed atomically with `.acquire` / `.release` ordering to
|
|
183
|
+
/// provide memory ordering for allocation footers, **expect for
|
|
184
|
+
/// the `modify` field**. This needs `.acquire` fenced every time
|
|
185
|
+
/// footer data is updated (`AllocCount.fenceAcqRel`).
|
|
186
|
+
alloc_count: AllocCount,
|
|
187
|
+
/// Accesed atomically with `.monotonic` ordering. Alternatively,
|
|
188
|
+
/// this is also synchronized by `alloc_count`.
|
|
189
|
+
fill: Fill,
|
|
190
|
+
|
|
191
|
+
/// So that `@sizeOf(Bucket)` is the start of first allocation if it is 8-byte aligned or less.
|
|
192
|
+
_: void align(8) = {},
|
|
193
|
+
comptime {
|
|
194
|
+
assert(@alignOf(@This()) >= 8);
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
const AllocCount = packed struct(u32) {
|
|
198
|
+
n: u31,
|
|
199
|
+
/// If `true`, this bucket cannot be freed yet.
|
|
200
|
+
filling: bool,
|
|
201
|
+
|
|
202
|
+
fn fenceAcqRel(a: *AllocCount) void {
|
|
203
|
+
_ = @atomicRmw(AllocCount, a, .Or, .{ .n = 0, .filling = false }, .acq_rel);
|
|
204
|
+
}
|
|
205
|
+
};
|
|
206
|
+
|
|
207
|
+
const Fill = packed struct(u32) {
|
|
208
|
+
at: u31,
|
|
209
|
+
last_is_extended: bool,
|
|
210
|
+
};
|
|
211
|
+
|
|
212
|
+
fn of(s: *SafeAllocator, ptr: [*]u8) *Bucket {
|
|
213
|
+
const size_log2 = s.bucket_size_log2;
|
|
214
|
+
return @ptrFromInt(@intFromPtr(ptr) >> @intCast(size_log2) << @intCast(size_log2));
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
fn fillAt(s: *SafeAllocator, ptr: [*]const u8) u32 {
|
|
218
|
+
return @intCast(@intFromPtr(ptr) & s.bucketMask());
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
fn bytes(b: *Bucket, s: *SafeAllocator) []u8 {
|
|
222
|
+
assert(@intFromPtr(b) & s.bucketMask() == 0);
|
|
223
|
+
return @as([*]u8, @ptrCast(b))[0..s.bucketSize()];
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
fn lastAlloc(b: *Bucket, s: *SafeAllocator, fill: Fill) ?*AllocFooter {
|
|
227
|
+
return b.allocFooterBefore(s, fill.at, fill.last_is_extended);
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
fn allocFooterBefore(b: *Bucket, s: *SafeAllocator, at: u32, is_extended: bool) ?*AllocFooter {
|
|
231
|
+
if (at - @sizeOf(Bucket) == 0) return null;
|
|
232
|
+
const off = at - AllocFooter.lenBucket(s, is_extended);
|
|
233
|
+
assert(off >= @sizeOf(Bucket));
|
|
234
|
+
return @ptrCast(@alignCast(b.bytes(s)[off..]));
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
/// Checks that no writes after frees were performed.
|
|
238
|
+
///
|
|
239
|
+
/// Assumes `b.alloc_count` has been loaded with `.acquire` ordering.
|
|
240
|
+
fn check(b: *Bucket, s: *SafeAllocator) void {
|
|
241
|
+
var footer = b.lastAlloc(s, b.fill).?;
|
|
242
|
+
while (true) {
|
|
243
|
+
const modify = @atomicLoad(
|
|
244
|
+
AllocFooter.Modify,
|
|
245
|
+
&footer.modify,
|
|
246
|
+
// The only possible value should be `.freed` since `b.alloc_count`
|
|
247
|
+
// has been loaded with `.acquire`. However, another thread may be trying to
|
|
248
|
+
// modify the allocation after it is freed and so the other thread is going
|
|
249
|
+
// to panic even if this thread still sees `.freed`.
|
|
250
|
+
.unordered,
|
|
251
|
+
).storedXor(&footer.modify);
|
|
252
|
+
if (modify != .freed or footer.actualChecksum(s) != footer.checksum ^ s.canary) {
|
|
253
|
+
panic("corrupted footer metadata in bucket at *{x}", .{@intFromPtr(&footer)});
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
s.checkFreed(footer);
|
|
257
|
+
footer = footer.bucketPrev(b, s) orelse break;
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
};
|
|
261
|
+
|
|
262
|
+
/// Trails the allocation, which has the following advantages:
|
|
263
|
+
/// * For buckets, the footer of the last allocation is always at the current fill.
|
|
264
|
+
/// * Aligning the allocation is simpler and wastes less space.
|
|
265
|
+
/// * Allocation overwrites are more likely to be caught by the footer getting corrupted.
|
|
266
|
+
/// For bucket allocs, this is trailed by `[2][stack_trace_size]usize`.
|
|
267
|
+
/// For large allocs, this is trailed by `[1][stack_trace_size]usize`.
|
|
268
|
+
const AllocFooter = struct {
|
|
269
|
+
/// Hash of `data` with the seed as the hash of its address so that memcpys of allocation
|
|
270
|
+
/// metadata are detected or are at least caught across runs.
|
|
271
|
+
///
|
|
272
|
+
/// This stored value is xored with the canary value so that canary mismatches are detected.
|
|
273
|
+
checksum: u32,
|
|
274
|
+
/// Accesed atomically with `.monotonic` ordering to catch operation races.
|
|
275
|
+
///
|
|
276
|
+
/// This stored value is xored with the hash of its address so that memcpys of allocation
|
|
277
|
+
/// metadata are detected or are at least caught across runs.
|
|
278
|
+
modify: Modify,
|
|
279
|
+
data: Data,
|
|
280
|
+
|
|
281
|
+
/// `8`: minimum alignment for `Bucket` allocations
|
|
282
|
+
/// `@alignOf(usize)`: so that the offset of trailing data is at `@sizeOf(@This())`
|
|
283
|
+
_: void align(@max(8, @alignOf(usize))) = {},
|
|
284
|
+
|
|
285
|
+
comptime {
|
|
286
|
+
assert(@alignOf(@This()) >= @max(8, @alignOf(usize)));
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
const Data = packed struct(u16) {
|
|
290
|
+
len: Len,
|
|
291
|
+
/// Low bits of the alignment.
|
|
292
|
+
///
|
|
293
|
+
/// For non-extended headers, this is the entire alignment. The location of the previous
|
|
294
|
+
/// header is directly before this allocation since footers in `Bucket` are gauraunteed to
|
|
295
|
+
/// have at least 8-byte alignment.
|
|
296
|
+
alignment: u2,
|
|
297
|
+
/// Used only for bucket allocations.
|
|
298
|
+
prev_extended: bool,
|
|
299
|
+
|
|
300
|
+
const Len = enum(u13) {
|
|
301
|
+
_,
|
|
302
|
+
|
|
303
|
+
/// This footer is trailed (before the traces) by `Extended`.
|
|
304
|
+
/// The high bits of the alignment are encoded as the offset from `extended_start`.
|
|
305
|
+
///
|
|
306
|
+
/// This may be set even if `Extended` is not strictly necesary
|
|
307
|
+
/// as a result of resizes and remaps.
|
|
308
|
+
const extended_start: u13 = math.maxInt(u13) - ((@bitSizeOf(usize) - 1) >> 2);
|
|
309
|
+
};
|
|
310
|
+
};
|
|
311
|
+
|
|
312
|
+
const Extended = struct {
|
|
313
|
+
len: usize,
|
|
314
|
+
container: Container,
|
|
315
|
+
|
|
316
|
+
const Container = union {
|
|
317
|
+
bucket_prev: ?*AllocFooter,
|
|
318
|
+
large_entry: *Allocs.Entry,
|
|
319
|
+
};
|
|
320
|
+
|
|
321
|
+
comptime {
|
|
322
|
+
// Exactly `usize` so this is directly after the regular footer
|
|
323
|
+
// and so that traces start directly after `@sizeOf(@This())`.
|
|
324
|
+
assert(@alignOf(@This()) == @alignOf(usize));
|
|
325
|
+
}
|
|
326
|
+
};
|
|
327
|
+
|
|
328
|
+
const Modify = enum(u16) {
|
|
329
|
+
// Random non-linear enum values to decrease the chance of undetected corruption.
|
|
330
|
+
none = 0x2962,
|
|
331
|
+
resized = 0x0030,
|
|
332
|
+
remaped = 0x9068,
|
|
333
|
+
freeing = 0x7f3d,
|
|
334
|
+
freed = 0xb98b,
|
|
335
|
+
_,
|
|
336
|
+
|
|
337
|
+
fn setNone(m: *Modify) void {
|
|
338
|
+
_ = @atomicRmw(Modify, m, .Xchg, .storedXor(.none, m), .monotonic);
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
fn opName(m: Modify) []const u8 {
|
|
342
|
+
return switch (m) {
|
|
343
|
+
.resized => "resize",
|
|
344
|
+
.remaped => "remap",
|
|
345
|
+
.freeing => "free",
|
|
346
|
+
_, .none, .freed => unreachable,
|
|
347
|
+
};
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
fn stateName(m: Modify) []const u8 {
|
|
351
|
+
return switch (m) {
|
|
352
|
+
.resized => "after resize",
|
|
353
|
+
.remaped => "after remap",
|
|
354
|
+
.freeing => "during free",
|
|
355
|
+
.freed => "after free",
|
|
356
|
+
_, .none => unreachable,
|
|
357
|
+
};
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
fn storedXor(m: Modify, ptr: *Modify) Modify {
|
|
361
|
+
const addr_hash: u16 = @truncate(std.hash.int(@intFromPtr(ptr)));
|
|
362
|
+
return @enumFromInt(@intFromEnum(m) ^ addr_hash);
|
|
363
|
+
}
|
|
364
|
+
};
|
|
365
|
+
|
|
366
|
+
fn isExtended(f: *AllocFooter) bool {
|
|
367
|
+
return @intFromEnum(f.data.len) >= Data.Len.extended_start;
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
fn extended(f: *AllocFooter) *Extended {
|
|
371
|
+
assert(f.isExtended());
|
|
372
|
+
return @ptrFromInt(@intFromPtr(f) + @sizeOf(AllocFooter));
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
fn userMemory(f: *AllocFooter) []u8 {
|
|
376
|
+
const memory_addr = @intFromPtr(f) - allocOffset(f.userLen());
|
|
377
|
+
assert(f.userAlign().check(memory_addr));
|
|
378
|
+
const memory_ptr: [*]u8 = @ptrFromInt(memory_addr);
|
|
379
|
+
return memory_ptr[0..f.userLen()];
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
fn userLen(f: *AllocFooter) usize {
|
|
383
|
+
const len_int = @intFromEnum(f.data.len);
|
|
384
|
+
return if (len_int < Data.Len.extended_start) len_int else f.extended().len;
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
fn userAlign(f: *AllocFooter) Alignment {
|
|
388
|
+
const high = (@intFromEnum(f.data.len) -| Data.Len.extended_start) << 2;
|
|
389
|
+
return @enumFromInt(high | f.data.alignment);
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
fn bucketPrev(f: *AllocFooter, b: *Bucket, s: *SafeAllocator) ?*AllocFooter {
|
|
393
|
+
if (f.isExtended()) return f.extended().container.bucket_prev;
|
|
394
|
+
return b.allocFooterBefore(s, Bucket.fillAt(s, f.userMemory().ptr), f.data.prev_extended);
|
|
395
|
+
}
|
|
396
|
+
|
|
397
|
+
fn tracesPtr(f: *AllocFooter) [*]usize {
|
|
398
|
+
const off_footer = @divExact(@sizeOf(AllocFooter), @sizeOf(usize));
|
|
399
|
+
const off_extended = @as(usize, @divExact(@sizeOf(Extended), @sizeOf(usize))) *
|
|
400
|
+
@intFromBool(f.isExtended());
|
|
401
|
+
return @as([*]usize, @ptrCast(f))[off_footer + off_extended ..];
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
fn allocTrace(f: *AllocFooter, s: *SafeAllocator) []usize {
|
|
405
|
+
return f.tracesPtr()[0..s.stack_trace_size];
|
|
406
|
+
}
|
|
407
|
+
|
|
408
|
+
fn freeTrace(f: *AllocFooter, s: *SafeAllocator) []usize {
|
|
409
|
+
const trace_size = s.stack_trace_size;
|
|
410
|
+
return f.tracesPtr()[trace_size..][0..trace_size];
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
fn actualChecksum(f: *AllocFooter, s: *SafeAllocator) u32 {
|
|
414
|
+
if (f.isExtended()) {
|
|
415
|
+
const len = f.extended().len;
|
|
416
|
+
const addr: usize = if (s.isLarge(len, f.userAlign()))
|
|
417
|
+
@intFromPtr(f.extended().container.large_entry)
|
|
418
|
+
else
|
|
419
|
+
@intFromPtr(f.extended().container.bucket_prev);
|
|
420
|
+
|
|
421
|
+
const len_bytes: [@sizeOf(usize)]u8 = @bitCast(len);
|
|
422
|
+
const container: [@sizeOf(usize)]u8 = @bitCast(addr);
|
|
423
|
+
const regular_bytes: [2]u8 = @bitCast(f.data);
|
|
424
|
+
const data_bytes = len_bytes ++ container ++ regular_bytes;
|
|
425
|
+
|
|
426
|
+
return @truncate(std.hash.Wyhash.hash(@truncate(@intFromPtr(f)), &data_bytes));
|
|
427
|
+
}
|
|
428
|
+
return @truncate(std.hash.int(@as(u16, @bitCast(f.data)) ^ @intFromPtr(f)));
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
fn allocOffset(len: usize) usize {
|
|
432
|
+
return Alignment.of(AllocFooter).forward(len);
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
fn allocAlign(a: Alignment) Alignment {
|
|
436
|
+
return a.max(.of(AllocFooter));
|
|
437
|
+
}
|
|
438
|
+
|
|
439
|
+
/// Assumes the footer is in a bucket allocation; all
|
|
440
|
+
/// large allocations require an extended header.
|
|
441
|
+
fn requiresExtended(len: usize, alignment: Alignment) bool {
|
|
442
|
+
return len >= Data.Len.extended_start or @intFromEnum(alignment) > math.maxInt(u2);
|
|
443
|
+
}
|
|
444
|
+
|
|
445
|
+
fn lenBucket(s: *SafeAllocator, is_extended: bool) usize {
|
|
446
|
+
return Alignment.forward(.@"8", @sizeOf(AllocFooter) +
|
|
447
|
+
@as(usize, @sizeOf(Extended)) * @intFromBool(is_extended) +
|
|
448
|
+
s.stack_trace_size * @sizeOf(usize) * 2);
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
fn lenLarge(s: *SafeAllocator) usize {
|
|
452
|
+
return @sizeOf(AllocFooter) + @sizeOf(Extended) + s.stack_trace_size * @sizeOf(usize);
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
fn allocLenBucket(s: *SafeAllocator, len: usize, is_extended: bool) usize {
|
|
456
|
+
return allocOffset(len) + lenBucket(s, is_extended);
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
fn allocLenLarge(s: *SafeAllocator, len: usize) usize {
|
|
460
|
+
return allocOffset(len) + lenLarge(s);
|
|
461
|
+
}
|
|
462
|
+
|
|
463
|
+
fn allocOffsetOrOom(len: usize) error{OutOfMemory}!usize {
|
|
464
|
+
return alignForwardOrOom(.of(AllocFooter), len);
|
|
465
|
+
}
|
|
466
|
+
|
|
467
|
+
fn allocLenBucketOrOom(
|
|
468
|
+
s: *SafeAllocator,
|
|
469
|
+
len: usize,
|
|
470
|
+
is_extended: bool,
|
|
471
|
+
) error{OutOfMemory}!usize {
|
|
472
|
+
return addOrOom(try allocOffsetOrOom(len), lenBucket(s, is_extended));
|
|
473
|
+
}
|
|
474
|
+
|
|
475
|
+
fn of(user_memory: []u8) *AllocFooter {
|
|
476
|
+
// Avoid panicing now if `memory.ptr` is not correctly aligned since a more
|
|
477
|
+
// useful panic will be provided later by a mismatch or invalid footer.
|
|
478
|
+
const aligned_start = Alignment.backward(.of(AllocFooter), @intFromPtr(user_memory.ptr));
|
|
479
|
+
return @ptrFromInt(aligned_start + allocOffset(user_memory.len));
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
fn startModify(f: *AllocFooter, m: Modify, s: *SafeAllocator, mem_fmt: FormatMemory) void {
|
|
483
|
+
const prev = @atomicRmw(
|
|
484
|
+
Modify,
|
|
485
|
+
&f.modify,
|
|
486
|
+
.Xchg,
|
|
487
|
+
.storedXor(m, &f.modify),
|
|
488
|
+
.monotonic,
|
|
489
|
+
).storedXor(&f.modify);
|
|
490
|
+
|
|
491
|
+
if (prev != .none) {
|
|
492
|
+
@branchHint(.cold);
|
|
493
|
+
const op_name = m.opName();
|
|
494
|
+
switch (prev) {
|
|
495
|
+
.none => unreachable,
|
|
496
|
+
.resized, .remaped => panic(
|
|
497
|
+
\\{s} {s} of {f}
|
|
498
|
+
\\alloc: {f}
|
|
499
|
+
\\{s}:
|
|
500
|
+
// (panic stack trace)
|
|
501
|
+
, .{
|
|
502
|
+
op_name,
|
|
503
|
+
prev.stateName(),
|
|
504
|
+
mem_fmt,
|
|
505
|
+
// The stack trace may have been overwritten, but at least give it a try
|
|
506
|
+
formatStackTrace(f.allocTrace(s)),
|
|
507
|
+
op_name,
|
|
508
|
+
}),
|
|
509
|
+
.freeing, .freed => {
|
|
510
|
+
if (prev == .freeing) {
|
|
511
|
+
// Wait for trace to become available
|
|
512
|
+
const complete: Modify = .storedXor(.freed, &f.modify);
|
|
513
|
+
while (@atomicLoad(Modify, &f.modify, .monotonic) != complete) {}
|
|
514
|
+
const b: *Bucket = .of(s, @ptrCast(f));
|
|
515
|
+
b.alloc_count.fenceAcqRel();
|
|
516
|
+
}
|
|
517
|
+
if (m == .freeing) {
|
|
518
|
+
panic(
|
|
519
|
+
\\double free of {f}
|
|
520
|
+
\\alloc: {f}
|
|
521
|
+
\\first free: {f}
|
|
522
|
+
\\second free:
|
|
523
|
+
// (panic stack trace)
|
|
524
|
+
, .{
|
|
525
|
+
mem_fmt,
|
|
526
|
+
formatStackTrace(f.allocTrace(s)),
|
|
527
|
+
formatStackTrace(f.freeTrace(s)),
|
|
528
|
+
});
|
|
529
|
+
} else {
|
|
530
|
+
panic(
|
|
531
|
+
\\{s} {s} of {f}
|
|
532
|
+
\\alloc: {f}
|
|
533
|
+
\\free: {f}
|
|
534
|
+
\\{s}:
|
|
535
|
+
// (panic stack trace)
|
|
536
|
+
, .{
|
|
537
|
+
op_name,
|
|
538
|
+
prev.stateName(),
|
|
539
|
+
mem_fmt,
|
|
540
|
+
formatStackTrace(f.allocTrace(s)),
|
|
541
|
+
formatStackTrace(f.freeTrace(s)),
|
|
542
|
+
op_name,
|
|
543
|
+
});
|
|
544
|
+
}
|
|
545
|
+
},
|
|
546
|
+
_ => panic(
|
|
547
|
+
"{s} of invalid memory {f} or corrupted metadata",
|
|
548
|
+
.{ m.opName(), mem_fmt },
|
|
549
|
+
),
|
|
550
|
+
}
|
|
551
|
+
comptime unreachable;
|
|
552
|
+
}
|
|
553
|
+
|
|
554
|
+
const expected_checksum = f.actualChecksum(s);
|
|
555
|
+
if (f.checksum ^ s.canary != expected_checksum) {
|
|
556
|
+
@branchHint(.cold);
|
|
557
|
+
const other_canary = f.checksum ^ expected_checksum;
|
|
558
|
+
panic(
|
|
559
|
+
"{s} of invalid memory {f}, corrupted metadata, or foreign allocation from canary 0x{x}",
|
|
560
|
+
.{ m.opName(), mem_fmt, other_canary },
|
|
561
|
+
);
|
|
562
|
+
}
|
|
563
|
+
|
|
564
|
+
if (f.userLen() != mem_fmt.memory.len or f.userAlign() != mem_fmt.alignment) {
|
|
565
|
+
const op_name = m.opName();
|
|
566
|
+
panic(
|
|
567
|
+
\\{s} of {f} mismatches allocation of {f}
|
|
568
|
+
\\alloc: {f}
|
|
569
|
+
\\{s}:
|
|
570
|
+
// (panic stack trace)
|
|
571
|
+
, .{ op_name, mem_fmt, FormatMemory{
|
|
572
|
+
.memory = f.userMemory(),
|
|
573
|
+
.alignment = f.userAlign(),
|
|
574
|
+
}, formatStackTrace(f.allocTrace(s)), op_name });
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
|
|
578
|
+
/// It is the caller's responsibility to `.acquire` fence the respective `Bucket.alloc_count`.
|
|
579
|
+
fn populate(
|
|
580
|
+
memory: []align(@alignOf(AllocFooter)) u8,
|
|
581
|
+
len: usize,
|
|
582
|
+
alignment: Alignment,
|
|
583
|
+
ra: usize,
|
|
584
|
+
/// `true` for large allocations
|
|
585
|
+
is_extended: bool,
|
|
586
|
+
/// `false` for large allocations
|
|
587
|
+
prev_extended: bool,
|
|
588
|
+
container: Extended.Container,
|
|
589
|
+
s: *SafeAllocator,
|
|
590
|
+
) *AllocFooter {
|
|
591
|
+
const footer: *AllocFooter = @ptrCast(@alignCast(memory[allocOffset(len)..].ptr));
|
|
592
|
+
|
|
593
|
+
if (!is_extended) {
|
|
594
|
+
footer.data = .{
|
|
595
|
+
.len = @enumFromInt(len),
|
|
596
|
+
.alignment = @intCast(@intFromEnum(alignment)),
|
|
597
|
+
.prev_extended = prev_extended,
|
|
598
|
+
};
|
|
599
|
+
assert(!footer.isExtended());
|
|
600
|
+
} else {
|
|
601
|
+
footer.data = .{
|
|
602
|
+
.len = @enumFromInt(Data.Len.extended_start + (@intFromEnum(alignment) >> 2)),
|
|
603
|
+
.alignment = @truncate(@intFromEnum(alignment)),
|
|
604
|
+
.prev_extended = prev_extended,
|
|
605
|
+
};
|
|
606
|
+
assert(footer.isExtended());
|
|
607
|
+
footer.extended().* = .{
|
|
608
|
+
.len = len,
|
|
609
|
+
.container = container,
|
|
610
|
+
};
|
|
611
|
+
}
|
|
612
|
+
|
|
613
|
+
captureStackTrace(footer.allocTrace(s), ra);
|
|
614
|
+
footer.checksum = footer.actualChecksum(s) ^ s.canary;
|
|
615
|
+
footer.modify.setNone();
|
|
616
|
+
|
|
617
|
+
return footer;
|
|
618
|
+
}
|
|
619
|
+
};
|
|
620
|
+
|
|
621
|
+
pub fn init(
|
|
622
|
+
/// Must be thread-safe for this allocator to be thread-safe
|
|
623
|
+
backing: mem.Allocator,
|
|
624
|
+
options: Options,
|
|
625
|
+
) SafeAllocator {
|
|
626
|
+
assert(options.block_size_log2 >= 8);
|
|
627
|
+
assert(options.bucket_size_log2 >= 8);
|
|
628
|
+
|
|
629
|
+
const allocs_entry_count = (@as(usize, 1) << options.block_size_log2) / @sizeOf(usize);
|
|
630
|
+
return .{
|
|
631
|
+
.backing = backing,
|
|
632
|
+
.threads = @splat(.{
|
|
633
|
+
.mutex = .unlocked,
|
|
634
|
+
.fill_bucket = null,
|
|
635
|
+
.free_entry = null,
|
|
636
|
+
.allocs_next = allocs_entry_count,
|
|
637
|
+
.allocs_first = null,
|
|
638
|
+
}),
|
|
639
|
+
|
|
640
|
+
.bucket_size_log2 = options.bucket_size_log2,
|
|
641
|
+
.block_size_log2 = options.block_size_log2,
|
|
642
|
+
.stack_trace_size = options.stack_trace_frames +
|
|
643
|
+
@intFromBool(options.stack_trace_frames != 0),
|
|
644
|
+
.allocs_entry_count = allocs_entry_count,
|
|
645
|
+
.large_alloc_threshold = (@as(usize, 1) << options.bucket_size_log2) * 3 / 4,
|
|
646
|
+
|
|
647
|
+
.canary = options.canary,
|
|
648
|
+
.check_write_after_free = options.check_write_after_free,
|
|
649
|
+
};
|
|
650
|
+
}
|
|
651
|
+
|
|
652
|
+
/// Returns the number of leaks
|
|
653
|
+
pub fn deinit(s: *SafeAllocator) usize {
|
|
654
|
+
return s.deinitLog(true);
|
|
655
|
+
}
|
|
656
|
+
|
|
657
|
+
/// Same as `deinit`, expect if `log` is `false`, it will not log leaks.
|
|
658
|
+
pub fn deinitLog(s: *SafeAllocator, log: bool) usize {
|
|
659
|
+
var leaks: usize = 0;
|
|
660
|
+
const thread_count = @atomicRmw(usize, &n_threads, .Or, 0, .monotonic);
|
|
661
|
+
for (s.threads[0..@max(1, thread_count)]) |*t| {
|
|
662
|
+
assert(t.mutex == .unlocked); // use of allocator during `deinit`
|
|
663
|
+
|
|
664
|
+
var maybe_allocs = t.allocs_first;
|
|
665
|
+
var n_entries = t.allocs_next;
|
|
666
|
+
while (maybe_allocs) |allocs| {
|
|
667
|
+
for (allocs.entries(s)[0..n_entries]) |*ent| {
|
|
668
|
+
switch (ent.kind) {
|
|
669
|
+
.free => {
|
|
670
|
+
@branchHint(.likely);
|
|
671
|
+
},
|
|
672
|
+
.bucket => leaks += s.deinitLeakedBucket(ent.toBucket(), log),
|
|
673
|
+
.large_alloc => {
|
|
674
|
+
leaks += 1;
|
|
675
|
+
s.deinitLargeAlloc(ent.toLargeAlloc(), log);
|
|
676
|
+
},
|
|
677
|
+
}
|
|
678
|
+
}
|
|
679
|
+
maybe_allocs = allocs.next;
|
|
680
|
+
n_entries = s.allocs_entry_count;
|
|
681
|
+
s.backing.rawFree(@ptrCast(allocs.usizes(s)), .of(usize), 0);
|
|
682
|
+
}
|
|
683
|
+
}
|
|
684
|
+
return leaks;
|
|
685
|
+
}
|
|
686
|
+
|
|
687
|
+
/// Returns the true count of leaks
|
|
688
|
+
fn deinitLeakedBucket(s: *SafeAllocator, b: *Bucket, log: bool) usize {
|
|
689
|
+
var leaks: usize = 0;
|
|
690
|
+
|
|
691
|
+
const expected = @atomicLoad(Bucket.AllocCount, &b.alloc_count, .acquire);
|
|
692
|
+
if (expected.n == 0) assert(expected.filling);
|
|
693
|
+
|
|
694
|
+
var footer = b.lastAlloc(s, b.fill).?;
|
|
695
|
+
while (true) {
|
|
696
|
+
const modify = @atomicRmw(
|
|
697
|
+
AllocFooter.Modify,
|
|
698
|
+
&footer.modify,
|
|
699
|
+
.Xchg,
|
|
700
|
+
undefined,
|
|
701
|
+
.monotonic,
|
|
702
|
+
).storedXor(&footer.modify);
|
|
703
|
+
|
|
704
|
+
const bad_modify = modify != .none and modify != .freed;
|
|
705
|
+
if (bad_modify or footer.actualChecksum(s) != footer.checksum ^ s.canary) {
|
|
706
|
+
panic("corrupted footer metadata in bucket at *{x}", .{@intFromPtr(&footer)});
|
|
707
|
+
}
|
|
708
|
+
|
|
709
|
+
switch (modify) {
|
|
710
|
+
.none => {
|
|
711
|
+
leaks += 1;
|
|
712
|
+
if (log) scoped_log.err("leaked {f} allocated at: {f}", .{ FormatMemory{
|
|
713
|
+
.memory = footer.userMemory(),
|
|
714
|
+
.alignment = footer.userAlign(),
|
|
715
|
+
}, formatStackTrace(footer.allocTrace(s)) });
|
|
716
|
+
},
|
|
717
|
+
.freed => s.checkFreed(footer),
|
|
718
|
+
else => unreachable,
|
|
719
|
+
}
|
|
720
|
+
|
|
721
|
+
footer = footer.bucketPrev(b, s) orelse break;
|
|
722
|
+
}
|
|
723
|
+
s.backing.rawFree(b.bytes(s), @enumFromInt(s.bucket_size_log2), 0);
|
|
724
|
+
|
|
725
|
+
assert(leaks == expected.n);
|
|
726
|
+
return leaks;
|
|
727
|
+
}
|
|
728
|
+
|
|
729
|
+
fn deinitLargeAlloc(s: *SafeAllocator, footer: *AllocFooter, log: bool) void {
|
|
730
|
+
const modify = footer.modify.storedXor(&footer.modify);
|
|
731
|
+
if (modify != .none or footer.checksum ^ s.canary != footer.actualChecksum(s)) {
|
|
732
|
+
panic("corrupted footer metadata at *{x}", .{@intFromPtr(&footer)});
|
|
733
|
+
}
|
|
734
|
+
|
|
735
|
+
const memory = footer.userMemory();
|
|
736
|
+
if (log) scoped_log.err("leaked {f} allocated at {f}", .{ FormatMemory{
|
|
737
|
+
.memory = memory,
|
|
738
|
+
.alignment = footer.userAlign(),
|
|
739
|
+
}, formatStackTrace(footer.allocTrace(s)) });
|
|
740
|
+
|
|
741
|
+
s.backing.rawFree(
|
|
742
|
+
memory.ptr[0..AllocFooter.allocLenLarge(s, memory.len)],
|
|
743
|
+
AllocFooter.allocAlign(footer.userAlign()),
|
|
744
|
+
0,
|
|
745
|
+
);
|
|
746
|
+
}
|
|
747
|
+
|
|
748
|
+
/// Returned allocator is thread-safe
|
|
749
|
+
pub fn allocator(s: *SafeAllocator) mem.Allocator {
|
|
750
|
+
return .{ .ptr = s, .vtable = &vtable };
|
|
751
|
+
}
|
|
752
|
+
|
|
753
|
+
fn acquireThread(s: *SafeAllocator) *Thread {
|
|
754
|
+
while (true) {
|
|
755
|
+
const t = &s.threads[thread_index];
|
|
756
|
+
if (t.mutex.tryLock()) {
|
|
757
|
+
@branchHint(.likely);
|
|
758
|
+
return t;
|
|
759
|
+
}
|
|
760
|
+
|
|
761
|
+
var max = @atomicLoad(usize, &n_threads, .unordered);
|
|
762
|
+
if (max == 0) {
|
|
763
|
+
@branchHint(.unlikely);
|
|
764
|
+
max = @min(std.Thread.getCpuCount() catch s.threads.len, s.threads.len);
|
|
765
|
+
max = @cmpxchgStrong(usize, &n_threads, 0, max, .monotonic, .monotonic) orelse max;
|
|
766
|
+
}
|
|
767
|
+
|
|
768
|
+
thread_index += 1;
|
|
769
|
+
// thread_index may be greater than max if the zero is returned by getCpuCount
|
|
770
|
+
thread_index *= @intFromBool(thread_index < max);
|
|
771
|
+
}
|
|
772
|
+
}
|
|
773
|
+
|
|
774
|
+
fn alignForwardOrOom(a: Alignment, addr: usize) error{OutOfMemory}!usize {
|
|
775
|
+
const x = a.toByteUnits() - 1;
|
|
776
|
+
return try addOrOom(addr, x) & ~x;
|
|
777
|
+
}
|
|
778
|
+
|
|
779
|
+
fn addOrOom(a: usize, b: usize) error{OutOfMemory}!usize {
|
|
780
|
+
return math.add(usize, a, b) catch error.OutOfMemory;
|
|
781
|
+
}
|
|
782
|
+
|
|
783
|
+
fn isLarge(s: *SafeAllocator, len: usize, alignment: Alignment) bool {
|
|
784
|
+
const max_align_waste = alignment.toByteUnits() - 1;
|
|
785
|
+
const max_use = max_align_waste + AllocFooter.allocLenBucket(s, len, true);
|
|
786
|
+
return max_use >= s.large_alloc_threshold;
|
|
787
|
+
}
|
|
788
|
+
|
|
789
|
+
fn isLargeOrOom(s: *SafeAllocator, len: usize, alignment: Alignment) error{OutOfMemory}!bool {
|
|
790
|
+
const max_align_waste = alignment.toByteUnits() - 1;
|
|
791
|
+
const max_use = try addOrOom(max_align_waste, try AllocFooter.allocLenBucketOrOom(s, len, true));
|
|
792
|
+
return max_use >= s.large_alloc_threshold;
|
|
793
|
+
}
|
|
794
|
+
|
|
795
|
+
fn newAllocEntry(s: *SafeAllocator, t: *Thread, ra: usize) error{OutOfMemory}!*Allocs.Entry {
|
|
796
|
+
if (t.free_entry) |ent| {
|
|
797
|
+
@branchHint(.likely);
|
|
798
|
+
t.free_entry = ent.toFree();
|
|
799
|
+
return ent;
|
|
800
|
+
}
|
|
801
|
+
|
|
802
|
+
if (s.allocs_entry_count - t.allocs_next != 0) {
|
|
803
|
+
@branchHint(.likely);
|
|
804
|
+
const ent = &t.allocs_first.?.entries(s)[t.allocs_next];
|
|
805
|
+
t.allocs_next += 1;
|
|
806
|
+
return ent;
|
|
807
|
+
}
|
|
808
|
+
|
|
809
|
+
const new_segment: *Allocs = @ptrCast(@alignCast(s.backing.rawAlloc(
|
|
810
|
+
(1 + s.allocs_entry_count) * @sizeOf(usize),
|
|
811
|
+
.of(usize),
|
|
812
|
+
ra,
|
|
813
|
+
) orelse return error.OutOfMemory));
|
|
814
|
+
new_segment.next = t.allocs_first;
|
|
815
|
+
t.allocs_first = new_segment;
|
|
816
|
+
t.allocs_next = 1;
|
|
817
|
+
return &new_segment.entries(s)[0];
|
|
818
|
+
}
|
|
819
|
+
|
|
820
|
+
fn freeAllocEntry(t: *Thread, ent: *Allocs.Entry) void {
|
|
821
|
+
ent.* = .fromFree(t.free_entry);
|
|
822
|
+
t.free_entry = ent;
|
|
823
|
+
}
|
|
824
|
+
|
|
825
|
+
fn overwriteFreed(s: *SafeAllocator, bytes: []u8) void {
|
|
826
|
+
if (!s.check_write_after_free) return;
|
|
827
|
+
// 0x55 is used so that undefined writes of 0xaa are still caught. Another option would be a
|
|
828
|
+
// stream of random bytes seeded by the address, however that makes debugging reads after frees
|
|
829
|
+
// more difficult and has a performance penalty and so is not worth catching slightly more
|
|
830
|
+
// writes after frees.
|
|
831
|
+
@memset(bytes, 0x55);
|
|
832
|
+
}
|
|
833
|
+
|
|
834
|
+
/// Returns the first address of a write after free
|
|
835
|
+
fn checkFreed(s: *SafeAllocator, footer: *AllocFooter) void {
|
|
836
|
+
if (!s.check_write_after_free) return;
|
|
837
|
+
const memory = footer.userMemory();
|
|
838
|
+
for (memory) |*b| if (b.* != 0x55) {
|
|
839
|
+
panic(
|
|
840
|
+
\\write after free at *{x}
|
|
841
|
+
\\original alloc of {f}: {f}
|
|
842
|
+
\\free: {f}
|
|
843
|
+
\\stack trace:
|
|
844
|
+
// (panic stack trace)
|
|
845
|
+
, .{
|
|
846
|
+
@intFromPtr(b),
|
|
847
|
+
FormatMemory{ .memory = memory, .alignment = footer.userAlign() },
|
|
848
|
+
formatStackTrace(footer.allocTrace(s)),
|
|
849
|
+
formatStackTrace(footer.freeTrace(s)),
|
|
850
|
+
});
|
|
851
|
+
};
|
|
852
|
+
}
|
|
853
|
+
|
|
854
|
+
const FormatMemory = struct {
|
|
855
|
+
memory: []const u8,
|
|
856
|
+
alignment: Alignment,
|
|
857
|
+
|
|
858
|
+
pub fn format(m: FormatMemory, w: *std.Io.Writer) std.Io.Writer.Error!void {
|
|
859
|
+
return w.print(
|
|
860
|
+
"[addr: {x}, len: {} (0x{x}) align: {}]",
|
|
861
|
+
.{ @intFromPtr(m.memory.ptr), m.memory.len, m.memory.len, m.alignment.toByteUnits() },
|
|
862
|
+
);
|
|
863
|
+
}
|
|
864
|
+
};
|
|
865
|
+
|
|
866
|
+
/// The first element stores the length of the stack trace including skipped frames.
|
|
867
|
+
/// The remaining elements store the return addresses.
|
|
868
|
+
fn captureStackTrace(trace_buf: []usize, ra: usize) void {
|
|
869
|
+
if (trace_buf.len == 0) return;
|
|
870
|
+
|
|
871
|
+
if (ra == 0) { // No return address provided
|
|
872
|
+
@branchHint(.unlikely);
|
|
873
|
+
trace_buf[0] = 0;
|
|
874
|
+
return;
|
|
875
|
+
}
|
|
876
|
+
|
|
877
|
+
const t = std.debug.captureCurrentStackTrace(.{ .first_address = ra }, trace_buf[1..]);
|
|
878
|
+
const skipped = @intFromEnum(t.skipped) *
|
|
879
|
+
@intFromBool(t.return_addresses.len == trace_buf[1..].len);
|
|
880
|
+
trace_buf[0] = t.return_addresses.len +| skipped;
|
|
881
|
+
}
|
|
882
|
+
|
|
883
|
+
fn formatStackTrace(trace_buf: []usize) std.debug.FormatStackTrace {
|
|
884
|
+
return .{
|
|
885
|
+
.stack_trace = if (trace_buf.len != 0) trace: {
|
|
886
|
+
const frames = trace_buf[0];
|
|
887
|
+
const addrs = trace_buf[1..];
|
|
888
|
+
break :trace .{
|
|
889
|
+
.return_addresses = addrs[0..@min(frames, addrs.len)],
|
|
890
|
+
.skipped = switch (frames) {
|
|
891
|
+
else => @enumFromInt(frames -| addrs.len),
|
|
892
|
+
0, math.maxInt(usize) => .unknown,
|
|
893
|
+
},
|
|
894
|
+
};
|
|
895
|
+
} else .{
|
|
896
|
+
.return_addresses = &.{},
|
|
897
|
+
.skipped = .unknown,
|
|
898
|
+
},
|
|
899
|
+
.terminal_mode = std.log.terminalMode(),
|
|
900
|
+
};
|
|
901
|
+
}
|
|
902
|
+
|
|
903
|
+
/// If this fails, future allocations to the bucket are illegal
|
|
904
|
+
fn allocBucket(
|
|
905
|
+
s: *SafeAllocator,
|
|
906
|
+
t: *Thread,
|
|
907
|
+
b: *Bucket,
|
|
908
|
+
len: usize,
|
|
909
|
+
alignment: Alignment,
|
|
910
|
+
ra: usize,
|
|
911
|
+
) ?[*]u8 {
|
|
912
|
+
const fill = &b.fill;
|
|
913
|
+
const is_extended = AllocFooter.requiresExtended(len, alignment);
|
|
914
|
+
const alloc_len: u32 = @intCast(AllocFooter.allocLenBucket(s, len, is_extended));
|
|
915
|
+
const alloc_align = AllocFooter.allocAlign(alignment);
|
|
916
|
+
|
|
917
|
+
var prev_fill = @atomicLoad(Bucket.Fill, fill, .monotonic);
|
|
918
|
+
var start: u32 = undefined;
|
|
919
|
+
var end: u32 = undefined;
|
|
920
|
+
while (true) {
|
|
921
|
+
start = @intCast(alloc_align.forward(prev_fill.at));
|
|
922
|
+
end = start + alloc_len;
|
|
923
|
+
|
|
924
|
+
if (end > s.bucketSize()) {
|
|
925
|
+
@branchHint(.unlikely);
|
|
926
|
+
|
|
927
|
+
const prev_count = @atomicRmw(
|
|
928
|
+
Bucket.AllocCount,
|
|
929
|
+
&b.alloc_count,
|
|
930
|
+
.Sub,
|
|
931
|
+
.{ .filling = true, .n = 0 },
|
|
932
|
+
.acq_rel,
|
|
933
|
+
);
|
|
934
|
+
assert(prev_count.filling);
|
|
935
|
+
|
|
936
|
+
if (prev_count.n == 0) {
|
|
937
|
+
@branchHint(.unlikely);
|
|
938
|
+
freeAllocEntry(t, b.entry);
|
|
939
|
+
b.check(s);
|
|
940
|
+
s.backing.rawFree(b.bytes(s), @enumFromInt(s.bucket_size_log2), ra);
|
|
941
|
+
}
|
|
942
|
+
|
|
943
|
+
return null;
|
|
944
|
+
}
|
|
945
|
+
|
|
946
|
+
prev_fill = @cmpxchgWeak(
|
|
947
|
+
Bucket.Fill,
|
|
948
|
+
fill,
|
|
949
|
+
prev_fill,
|
|
950
|
+
.{ .at = @intCast(end), .last_is_extended = is_extended },
|
|
951
|
+
.monotonic,
|
|
952
|
+
.monotonic,
|
|
953
|
+
) orelse {
|
|
954
|
+
@branchHint(.likely);
|
|
955
|
+
break;
|
|
956
|
+
};
|
|
957
|
+
// b.fill was changed during a resize (or a sporadic cmpxchgWeak failure)
|
|
958
|
+
}
|
|
959
|
+
|
|
960
|
+
const memory = b.bytes(s)[start..end];
|
|
961
|
+
_ = AllocFooter.populate(
|
|
962
|
+
@alignCast(memory),
|
|
963
|
+
len,
|
|
964
|
+
alignment,
|
|
965
|
+
ra,
|
|
966
|
+
is_extended,
|
|
967
|
+
prev_fill.last_is_extended,
|
|
968
|
+
.{ .bucket_prev = b.lastAlloc(s, prev_fill) },
|
|
969
|
+
s,
|
|
970
|
+
);
|
|
971
|
+
|
|
972
|
+
assert(@atomicRmw(
|
|
973
|
+
Bucket.AllocCount,
|
|
974
|
+
&b.alloc_count,
|
|
975
|
+
.Add,
|
|
976
|
+
.{ .filling = false, .n = 1 },
|
|
977
|
+
.acq_rel,
|
|
978
|
+
).filling);
|
|
979
|
+
|
|
980
|
+
return memory.ptr;
|
|
981
|
+
}
|
|
982
|
+
|
|
983
|
+
fn growingResizeBucket(
|
|
984
|
+
s: *SafeAllocator,
|
|
985
|
+
f: *AllocFooter,
|
|
986
|
+
memory: []const u8,
|
|
987
|
+
alignment: Alignment,
|
|
988
|
+
new_len: usize,
|
|
989
|
+
ra: usize,
|
|
990
|
+
) bool {
|
|
991
|
+
assert(new_len >= memory.len);
|
|
992
|
+
return s.advanceBucketAlloc(f, Bucket.fillAt(s, memory.ptr), false, alignment, new_len, ra);
|
|
993
|
+
}
|
|
994
|
+
|
|
995
|
+
fn advanceBucketAlloc(
|
|
996
|
+
s: *SafeAllocator,
|
|
997
|
+
old: *AllocFooter,
|
|
998
|
+
new_start: u32,
|
|
999
|
+
start_moved: bool,
|
|
1000
|
+
alignment: Alignment,
|
|
1001
|
+
new_len: usize,
|
|
1002
|
+
ra: usize,
|
|
1003
|
+
) bool {
|
|
1004
|
+
assert(AllocFooter.allocAlign(alignment).check(new_start));
|
|
1005
|
+
const b: *Bucket = .of(s, @ptrCast(old));
|
|
1006
|
+
|
|
1007
|
+
const old_is_extended = old.isExtended();
|
|
1008
|
+
const old_footer_len = AllocFooter.lenBucket(s, old_is_extended);
|
|
1009
|
+
const old_fill: u32 = @intCast(Bucket.fillAt(s, @ptrCast(old)) + old_footer_len);
|
|
1010
|
+
|
|
1011
|
+
const new_is_extended = old_is_extended or start_moved or
|
|
1012
|
+
AllocFooter.requiresExtended(new_len, alignment);
|
|
1013
|
+
const new_footer_len = AllocFooter.lenBucket(s, new_is_extended);
|
|
1014
|
+
const new_fill: u32 = @intCast(new_start + AllocFooter.allocOffset(new_len) + new_footer_len);
|
|
1015
|
+
|
|
1016
|
+
assert(old_fill <= new_fill);
|
|
1017
|
+
if (new_fill > s.bucketSize()) {
|
|
1018
|
+
return false;
|
|
1019
|
+
}
|
|
1020
|
+
|
|
1021
|
+
if (old_fill == new_fill or @cmpxchgStrong(
|
|
1022
|
+
Bucket.Fill,
|
|
1023
|
+
&b.fill,
|
|
1024
|
+
.{ .last_is_extended = old_is_extended, .at = @intCast(old_fill) },
|
|
1025
|
+
.{ .last_is_extended = new_is_extended, .at = @intCast(new_fill) },
|
|
1026
|
+
.monotonic,
|
|
1027
|
+
.monotonic,
|
|
1028
|
+
) != null) {
|
|
1029
|
+
return false;
|
|
1030
|
+
}
|
|
1031
|
+
|
|
1032
|
+
_ = AllocFooter.populate(
|
|
1033
|
+
@alignCast(b.bytes(s)[new_start..new_fill]),
|
|
1034
|
+
new_len,
|
|
1035
|
+
alignment,
|
|
1036
|
+
ra,
|
|
1037
|
+
new_is_extended,
|
|
1038
|
+
old.data.prev_extended,
|
|
1039
|
+
.{ .bucket_prev = old.bucketPrev(b, s) },
|
|
1040
|
+
s,
|
|
1041
|
+
);
|
|
1042
|
+
b.alloc_count.fenceAcqRel();
|
|
1043
|
+
return true;
|
|
1044
|
+
}
|
|
1045
|
+
|
|
1046
|
+
const vtable: mem.Allocator.VTable = .{
|
|
1047
|
+
.alloc = alloc,
|
|
1048
|
+
.free = free,
|
|
1049
|
+
.resize = resize,
|
|
1050
|
+
.remap = remap,
|
|
1051
|
+
};
|
|
1052
|
+
|
|
1053
|
+
fn alloc(ctx: *anyopaque, len: usize, alignment: Alignment, ra: usize) ?[*]u8 {
|
|
1054
|
+
assert(len != 0);
|
|
1055
|
+
|
|
1056
|
+
const s: *SafeAllocator = @ptrCast(@alignCast(ctx));
|
|
1057
|
+
const t = s.acquireThread();
|
|
1058
|
+
defer t.mutex.unlock();
|
|
1059
|
+
|
|
1060
|
+
if (s.isLargeOrOom(len, alignment) catch return null) {
|
|
1061
|
+
@branchHint(.unlikely);
|
|
1062
|
+
|
|
1063
|
+
const entry = s.newAllocEntry(t, ra) catch return null;
|
|
1064
|
+
const alloc_len = AllocFooter.allocLenLarge(s, len);
|
|
1065
|
+
const alloc_align = AllocFooter.allocAlign(alignment);
|
|
1066
|
+
const alloc_ptr = s.backing.rawAlloc(alloc_len, alloc_align, ra) orelse {
|
|
1067
|
+
freeAllocEntry(t, entry);
|
|
1068
|
+
return null;
|
|
1069
|
+
};
|
|
1070
|
+
|
|
1071
|
+
const footer = AllocFooter.populate(
|
|
1072
|
+
@alignCast(alloc_ptr[0..alloc_len]),
|
|
1073
|
+
len,
|
|
1074
|
+
alignment,
|
|
1075
|
+
ra,
|
|
1076
|
+
true,
|
|
1077
|
+
false,
|
|
1078
|
+
.{ .large_entry = entry },
|
|
1079
|
+
s,
|
|
1080
|
+
);
|
|
1081
|
+
entry.* = .fromLargeAlloc(footer);
|
|
1082
|
+
|
|
1083
|
+
return alloc_ptr;
|
|
1084
|
+
}
|
|
1085
|
+
|
|
1086
|
+
if (t.fill_bucket) |bucket| {
|
|
1087
|
+
@branchHint(.likely);
|
|
1088
|
+
if (s.allocBucket(t, bucket, len, alignment, ra)) |ptr| {
|
|
1089
|
+
@branchHint(.likely);
|
|
1090
|
+
return ptr;
|
|
1091
|
+
}
|
|
1092
|
+
}
|
|
1093
|
+
t.fill_bucket = null; // In case of OOM below, this bucket will still be unusable for future
|
|
1094
|
+
// allocations.
|
|
1095
|
+
|
|
1096
|
+
const entry = s.newAllocEntry(t, ra) catch return null;
|
|
1097
|
+
const bucket: *Bucket = @ptrCast(@alignCast(s.backing.rawAlloc(
|
|
1098
|
+
s.bucketSize(),
|
|
1099
|
+
@enumFromInt(s.bucket_size_log2),
|
|
1100
|
+
ra,
|
|
1101
|
+
) orelse {
|
|
1102
|
+
freeAllocEntry(t, entry);
|
|
1103
|
+
return null;
|
|
1104
|
+
}));
|
|
1105
|
+
bucket.* = .{
|
|
1106
|
+
.entry = entry,
|
|
1107
|
+
// No atomic stores necessary because this thread is the
|
|
1108
|
+
// first to atomically update these below in allocBucket.
|
|
1109
|
+
.alloc_count = .{ .filling = true, .n = 0 },
|
|
1110
|
+
.fill = .{ .at = @sizeOf(Bucket), .last_is_extended = false },
|
|
1111
|
+
};
|
|
1112
|
+
entry.* = .fromBucket(bucket);
|
|
1113
|
+
|
|
1114
|
+
t.fill_bucket = bucket;
|
|
1115
|
+
return s.allocBucket(t, bucket, len, alignment, ra);
|
|
1116
|
+
}
|
|
1117
|
+
|
|
1118
|
+
fn free(ctx: *anyopaque, memory: []u8, alignment: Alignment, ra: usize) void {
|
|
1119
|
+
const s: *SafeAllocator = @ptrCast(@alignCast(ctx));
|
|
1120
|
+
const f: *AllocFooter = .of(memory);
|
|
1121
|
+
f.startModify(.freeing, s, .{ .memory = memory, .alignment = alignment });
|
|
1122
|
+
|
|
1123
|
+
if (s.isLarge(memory.len, alignment)) {
|
|
1124
|
+
@branchHint(.unlikely);
|
|
1125
|
+
|
|
1126
|
+
const t = s.acquireThread();
|
|
1127
|
+
freeAllocEntry(t, f.extended().container.large_entry);
|
|
1128
|
+
t.mutex.unlock();
|
|
1129
|
+
s.backing.rawFree(
|
|
1130
|
+
memory.ptr[0..AllocFooter.allocLenLarge(s, memory.len)],
|
|
1131
|
+
AllocFooter.allocAlign(alignment),
|
|
1132
|
+
ra,
|
|
1133
|
+
);
|
|
1134
|
+
return;
|
|
1135
|
+
}
|
|
1136
|
+
|
|
1137
|
+
const b: *Bucket = .of(s, memory.ptr);
|
|
1138
|
+
s.overwriteFreed(memory);
|
|
1139
|
+
captureStackTrace(f.freeTrace(s), ra);
|
|
1140
|
+
|
|
1141
|
+
// Fence the alloc count before setting `f.modify` to `.freed`.
|
|
1142
|
+
// This way, if another thread is waiting for the trace to become
|
|
1143
|
+
// available, it will not be racing with us to see this `.release`.
|
|
1144
|
+
//
|
|
1145
|
+
// The below alloc count update can not be moved up here instead
|
|
1146
|
+
// since that would allow another thread to see the `.freeing` state.
|
|
1147
|
+
b.alloc_count.fenceAcqRel();
|
|
1148
|
+
|
|
1149
|
+
// If this result is different than .freeing, then some other thread
|
|
1150
|
+
// is in the process of panicing. So, just ignore it. (This is also
|
|
1151
|
+
// the reasoning for several other places.)
|
|
1152
|
+
_ = @atomicRmw(
|
|
1153
|
+
AllocFooter.Modify,
|
|
1154
|
+
&f.modify,
|
|
1155
|
+
.Xchg,
|
|
1156
|
+
.storedXor(.freed, &f.modify),
|
|
1157
|
+
.monotonic,
|
|
1158
|
+
);
|
|
1159
|
+
|
|
1160
|
+
const prev_count = @atomicRmw(
|
|
1161
|
+
Bucket.AllocCount,
|
|
1162
|
+
&b.alloc_count,
|
|
1163
|
+
.Sub,
|
|
1164
|
+
.{ .filling = false, .n = 1 },
|
|
1165
|
+
.acq_rel,
|
|
1166
|
+
);
|
|
1167
|
+
|
|
1168
|
+
if (prev_count.n - 1 == 0 and !prev_count.filling) {
|
|
1169
|
+
@branchHint(.unlikely);
|
|
1170
|
+
const t = s.acquireThread();
|
|
1171
|
+
freeAllocEntry(t, b.entry);
|
|
1172
|
+
t.mutex.unlock();
|
|
1173
|
+
b.check(s);
|
|
1174
|
+
s.backing.rawFree(b.bytes(s), @enumFromInt(s.bucket_size_log2), ra);
|
|
1175
|
+
}
|
|
1176
|
+
}
|
|
1177
|
+
|
|
1178
|
+
fn resize(ctx: *anyopaque, memory: []u8, alignment: Alignment, new_len: usize, ra: usize) bool {
|
|
1179
|
+
assert(new_len != 0);
|
|
1180
|
+
|
|
1181
|
+
const s: *SafeAllocator = @ptrCast(@alignCast(ctx));
|
|
1182
|
+
const f: *AllocFooter = .of(memory);
|
|
1183
|
+
f.startModify(.resized, s, .{ .memory = memory, .alignment = alignment });
|
|
1184
|
+
|
|
1185
|
+
// Check that the allocation is not moving between a bucket and large allocation. This is
|
|
1186
|
+
// done after the above so that it is still checked that valid memory is passed and there
|
|
1187
|
+
// is no double modify.
|
|
1188
|
+
const from_large_alloc = s.isLarge(memory.len, alignment);
|
|
1189
|
+
const to_large_alloc = s.isLargeOrOom(new_len, alignment) catch {
|
|
1190
|
+
f.modify.setNone();
|
|
1191
|
+
return false;
|
|
1192
|
+
};
|
|
1193
|
+
if (from_large_alloc != to_large_alloc) {
|
|
1194
|
+
@branchHint(.unlikely);
|
|
1195
|
+
f.modify.setNone();
|
|
1196
|
+
return false;
|
|
1197
|
+
}
|
|
1198
|
+
|
|
1199
|
+
if (from_large_alloc) {
|
|
1200
|
+
@branchHint(.unlikely);
|
|
1201
|
+
|
|
1202
|
+
const entry = f.extended().container.large_entry;
|
|
1203
|
+
const new_alloc_len = AllocFooter.allocLenLarge(s, new_len);
|
|
1204
|
+
if (!s.backing.rawResize(
|
|
1205
|
+
memory.ptr[0..AllocFooter.allocLenLarge(s, memory.len)],
|
|
1206
|
+
AllocFooter.allocAlign(alignment),
|
|
1207
|
+
new_alloc_len,
|
|
1208
|
+
ra,
|
|
1209
|
+
)) {
|
|
1210
|
+
f.modify.setNone();
|
|
1211
|
+
return false;
|
|
1212
|
+
}
|
|
1213
|
+
|
|
1214
|
+
const new_footer = AllocFooter.populate(
|
|
1215
|
+
@alignCast(memory.ptr[0..new_alloc_len]),
|
|
1216
|
+
new_len,
|
|
1217
|
+
alignment,
|
|
1218
|
+
ra,
|
|
1219
|
+
true,
|
|
1220
|
+
false,
|
|
1221
|
+
.{ .large_entry = entry },
|
|
1222
|
+
s,
|
|
1223
|
+
);
|
|
1224
|
+
assert(entry.kind == .large_alloc);
|
|
1225
|
+
entry.* = .fromLargeAlloc(new_footer);
|
|
1226
|
+
return true;
|
|
1227
|
+
}
|
|
1228
|
+
|
|
1229
|
+
if (new_len < memory.len) {
|
|
1230
|
+
// Resize shrinks are disallowed in all cases since the linked list would be broken. Even
|
|
1231
|
+
// if this footer is the final one, the fill value would need decreased which would allow
|
|
1232
|
+
// memory to be reused.
|
|
1233
|
+
f.modify.setNone();
|
|
1234
|
+
return false;
|
|
1235
|
+
}
|
|
1236
|
+
|
|
1237
|
+
if (s.growingResizeBucket(f, memory, alignment, new_len, ra)) {
|
|
1238
|
+
@branchHint(.likely);
|
|
1239
|
+
return true;
|
|
1240
|
+
} else {
|
|
1241
|
+
f.modify.setNone();
|
|
1242
|
+
return false;
|
|
1243
|
+
}
|
|
1244
|
+
}
|
|
1245
|
+
|
|
1246
|
+
fn remap(ctx: *anyopaque, memory: []u8, alignment: Alignment, new_len: usize, ra: usize) ?[*]u8 {
|
|
1247
|
+
assert(new_len != 0);
|
|
1248
|
+
|
|
1249
|
+
const s: *SafeAllocator = @ptrCast(@alignCast(ctx));
|
|
1250
|
+
const f: *AllocFooter = .of(memory);
|
|
1251
|
+
f.startModify(.remaped, s, .{ .memory = memory, .alignment = alignment });
|
|
1252
|
+
|
|
1253
|
+
// Check that the allocation is not moving between a bucket and large allocation. This is
|
|
1254
|
+
// done after the above so that it is still checked that valid memory is passed and there
|
|
1255
|
+
// is no double modify.
|
|
1256
|
+
const from_large_alloc = s.isLarge(memory.len, alignment);
|
|
1257
|
+
const to_large_alloc = s.isLargeOrOom(new_len, alignment) catch {
|
|
1258
|
+
f.modify.setNone();
|
|
1259
|
+
return null;
|
|
1260
|
+
};
|
|
1261
|
+
if (from_large_alloc != to_large_alloc) {
|
|
1262
|
+
@branchHint(.unlikely);
|
|
1263
|
+
f.modify.setNone();
|
|
1264
|
+
return null;
|
|
1265
|
+
}
|
|
1266
|
+
|
|
1267
|
+
if (from_large_alloc) {
|
|
1268
|
+
@branchHint(.unlikely);
|
|
1269
|
+
|
|
1270
|
+
const entry = f.extended().container.large_entry;
|
|
1271
|
+
const new_alloc_len = AllocFooter.allocLenLarge(s, new_len);
|
|
1272
|
+
const new_memory = s.backing.rawRemap(
|
|
1273
|
+
memory.ptr[0..AllocFooter.allocLenLarge(s, memory.len)],
|
|
1274
|
+
AllocFooter.allocAlign(alignment),
|
|
1275
|
+
new_alloc_len,
|
|
1276
|
+
ra,
|
|
1277
|
+
) orelse {
|
|
1278
|
+
f.modify.setNone();
|
|
1279
|
+
return null;
|
|
1280
|
+
};
|
|
1281
|
+
|
|
1282
|
+
const new_footer = AllocFooter.populate(
|
|
1283
|
+
@alignCast(new_memory[0..new_alloc_len]),
|
|
1284
|
+
new_len,
|
|
1285
|
+
alignment,
|
|
1286
|
+
ra,
|
|
1287
|
+
true,
|
|
1288
|
+
false,
|
|
1289
|
+
.{ .large_entry = entry },
|
|
1290
|
+
s,
|
|
1291
|
+
);
|
|
1292
|
+
assert(entry.kind == .large_alloc);
|
|
1293
|
+
entry.* = .fromLargeAlloc(new_footer);
|
|
1294
|
+
return new_memory;
|
|
1295
|
+
}
|
|
1296
|
+
|
|
1297
|
+
if (new_len < memory.len) {
|
|
1298
|
+
// Move the allocation forward to avoid bucket reuse
|
|
1299
|
+
|
|
1300
|
+
const fixed_start = Bucket.fillAt(s, @ptrCast(f)) - AllocFooter.allocOffset(new_len);
|
|
1301
|
+
const moved_start = alignment.forward(fixed_start);
|
|
1302
|
+
if (moved_start != fixed_start or !f.isExtended()) {
|
|
1303
|
+
@branchHint(.unlikely);
|
|
1304
|
+
// For `moved_start != fixed_start`: the footer needs moved forward as well to
|
|
1305
|
+
// maintain the correct allocOffset.
|
|
1306
|
+
//
|
|
1307
|
+
// For `!f.isExtended()`: since the memory will no longer be directly after the
|
|
1308
|
+
// previous footer, the footer needs promoted to an extended one to encode the
|
|
1309
|
+
// location of the previous footer.
|
|
1310
|
+
if (!s.advanceBucketAlloc(f, @intCast(moved_start), true, alignment, new_len, ra)) {
|
|
1311
|
+
@branchHint(.unlikely);
|
|
1312
|
+
f.modify.setNone();
|
|
1313
|
+
return null;
|
|
1314
|
+
}
|
|
1315
|
+
const new_memory = Bucket.bytes(.of(s, @ptrCast(f)), s)[moved_start..][0..new_len];
|
|
1316
|
+
@memmove(new_memory, memory[0..new_memory.len]);
|
|
1317
|
+
return new_memory.ptr;
|
|
1318
|
+
}
|
|
1319
|
+
|
|
1320
|
+
// The footer can be modified in place
|
|
1321
|
+
const b: *Bucket = .of(s, @ptrCast(f));
|
|
1322
|
+
f.extended().len = new_len;
|
|
1323
|
+
f.checksum = f.actualChecksum(s) ^ s.canary;
|
|
1324
|
+
captureStackTrace(f.allocTrace(s), ra);
|
|
1325
|
+
|
|
1326
|
+
f.modify.setNone();
|
|
1327
|
+
b.alloc_count.fenceAcqRel();
|
|
1328
|
+
|
|
1329
|
+
const new_memory = f.userMemory();
|
|
1330
|
+
@memmove(new_memory, memory[0..new_memory.len]);
|
|
1331
|
+
return new_memory.ptr;
|
|
1332
|
+
}
|
|
1333
|
+
|
|
1334
|
+
if (s.growingResizeBucket(f, memory, alignment, new_len, ra)) {
|
|
1335
|
+
@branchHint(.likely);
|
|
1336
|
+
return memory.ptr;
|
|
1337
|
+
} else {
|
|
1338
|
+
f.modify.setNone();
|
|
1339
|
+
return null;
|
|
1340
|
+
}
|
|
1341
|
+
}
|
|
1342
|
+
|
|
1343
|
+
const Smith = std.testing.Smith;
|
|
1344
|
+
|
|
1345
|
+
/// Shared between single-threaded and multi-threaded fuzzing.
|
|
1346
|
+
const fuzz_probs = struct {
|
|
1347
|
+
const alignment: []const Smith.Weight = &.{
|
|
1348
|
+
.rangeAtMost(Alignment, .@"1", .@"16", 32), // ~75%
|
|
1349
|
+
.rangeAtMost(Alignment, .@"16", @enumFromInt(@bitSizeOf(usize) - 1), 1),
|
|
1350
|
+
.value(Alignment, @enumFromInt(@bitSizeOf(usize) - 1), 32), // More likely overflow cases
|
|
1351
|
+
};
|
|
1352
|
+
|
|
1353
|
+
const eos: []const Smith.Weight = &.{
|
|
1354
|
+
// Very high false weight so that expanding allocation tables, OOM cases,
|
|
1355
|
+
// and multi-threaded consumer-producer cases get tested thoroughly.
|
|
1356
|
+
.value(bool, false, 255),
|
|
1357
|
+
.value(bool, true, 1),
|
|
1358
|
+
};
|
|
1359
|
+
|
|
1360
|
+
fn generateOptions(smith: *Smith) Options {
|
|
1361
|
+
@disableInstrumentation();
|
|
1362
|
+
|
|
1363
|
+
const size_log2_weights: []const Smith.Weight = &.{
|
|
1364
|
+
.value(u5, 8, 1024), // 8x odds of below
|
|
1365
|
+
.rangeAtMost(u5, 8, 16, 16),
|
|
1366
|
+
.rangeAtMost(u5, 17, 31, 1), // 1/32 odds of above since these just OOM with the fixed buffer
|
|
1367
|
+
};
|
|
1368
|
+
return .{
|
|
1369
|
+
.stack_trace_frames = smith.valueWeighted(u16, &.{
|
|
1370
|
+
.value(u16, 0, 1 << 18), // 4x - stack traces have no tested properties except I.B.
|
|
1371
|
+
.rangeAtMost(u16, 0, math.maxInt(u16), 1),
|
|
1372
|
+
}),
|
|
1373
|
+
// If set, it is aimed to allocate much fewer bytes since freeing becomes O(n).
|
|
1374
|
+
// Without this, it is O(1) since mem.Allocator is bypassed so there is no memsets
|
|
1375
|
+
// of the data.
|
|
1376
|
+
.check_write_after_free = smith.valueWeighted(bool, &.{
|
|
1377
|
+
.value(bool, false, 31),
|
|
1378
|
+
.value(bool, false, 1),
|
|
1379
|
+
}),
|
|
1380
|
+
.canary = smith.value(u32),
|
|
1381
|
+
|
|
1382
|
+
.block_size_log2 = smith.valueWeighted(u5, size_log2_weights),
|
|
1383
|
+
.bucket_size_log2 = smith.valueWeighted(u5, size_log2_weights),
|
|
1384
|
+
};
|
|
1385
|
+
}
|
|
1386
|
+
|
|
1387
|
+
const Op = enum(u8) { alloc, free, resize, remap };
|
|
1388
|
+
fn generateOp(smith: *Smith, any_allocs: bool) Op {
|
|
1389
|
+
@disableInstrumentation();
|
|
1390
|
+
return if (any_allocs) smith.valueWeighted(Op, &.{
|
|
1391
|
+
.rangeAtMost(Op, .alloc, .free, 4),
|
|
1392
|
+
.rangeAtMost(Op, .resize, .remap, 1),
|
|
1393
|
+
}) else .alloc;
|
|
1394
|
+
}
|
|
1395
|
+
|
|
1396
|
+
fn generateSplat(smith: *Smith) ?u8 {
|
|
1397
|
+
@disableInstrumentation();
|
|
1398
|
+
|
|
1399
|
+
// Same rationale for `check_write_after_free`
|
|
1400
|
+
const n = smith.valueWeighted(u16, &.{
|
|
1401
|
+
.value(u16, 256, 256 * 31),
|
|
1402
|
+
.rangeAtMost(u16, 0, 255, 1),
|
|
1403
|
+
});
|
|
1404
|
+
return if (n == 256) null else @intCast(n);
|
|
1405
|
+
}
|
|
1406
|
+
|
|
1407
|
+
fn generateLen(smith: *Smith, will_memset: bool) usize {
|
|
1408
|
+
@disableInstrumentation();
|
|
1409
|
+
|
|
1410
|
+
// 1 << 24 indicates to generate an unweighted usize.
|
|
1411
|
+
// 1 << 25 indicates to provide a value relative to the maximum usize.
|
|
1412
|
+
const len = smith.valueWeightedWithHash(
|
|
1413
|
+
u32,
|
|
1414
|
+
if (!will_memset) comptime &.{
|
|
1415
|
+
// zig fmt: off
|
|
1416
|
+
.rangeLessThan(u32, 1 , 1 << 6 , 1 << 15), // 2^21 - 2^4 times below so 16x odds
|
|
1417
|
+
.rangeLessThan(u32, 1 << 6, 1 << 17, 1 ), // 2^17 - 2^4 times below so 16x odds
|
|
1418
|
+
.value (u32, 1 << 24, 1 << 12), // 2^12
|
|
1419
|
+
.value (u32, 1 << 25, 1 << 12), // 2^12
|
|
1420
|
+
// zig fmt: on
|
|
1421
|
+
} else comptime &.{
|
|
1422
|
+
// zig fmt: off
|
|
1423
|
+
.rangeLessThan(u32, 1 , 1 << 6, 1 << 17), // 2^23 - 2^6 times below so 64x odds
|
|
1424
|
+
.rangeLessThan(u32, 1 << 6, 1 << 17, 1 ), // 2^17 - 2^6 times below so 64x odds
|
|
1425
|
+
.value (u32, 1 << 24, 1 << 10), // 2^10
|
|
1426
|
+
.value (u32, 1 << 25, 1 << 10), // 2^10
|
|
1427
|
+
// zig fmt: on
|
|
1428
|
+
},
|
|
1429
|
+
// Give the fuzzer different hashes when the weights used differ
|
|
1430
|
+
// so that it does not reuse values from other probabilities.
|
|
1431
|
+
if (!will_memset) 0x38a74424 else 0xec581ff0,
|
|
1432
|
+
);
|
|
1433
|
+
|
|
1434
|
+
if (len == 1 << 24) return @max(1, smith.value(usize));
|
|
1435
|
+
if (len == 1 << 25) return @as(usize, math.maxInt(usize)) - smith.value(u16);
|
|
1436
|
+
return len;
|
|
1437
|
+
}
|
|
1438
|
+
|
|
1439
|
+
fn checkSplat(splat: ?u8, bytes: []const u8) void {
|
|
1440
|
+
@disableInstrumentation();
|
|
1441
|
+
|
|
1442
|
+
const byte = splat orelse return;
|
|
1443
|
+
for (bytes) |*b| if (b.* != byte) {
|
|
1444
|
+
panic("SafeAllocator corrupted allocation data at *{x}", .{@intFromPtr(b)});
|
|
1445
|
+
};
|
|
1446
|
+
}
|
|
1447
|
+
};
|
|
1448
|
+
|
|
1449
|
+
test "fuzz single threaded" {
|
|
1450
|
+
// This single threaded fuzz test has the following advantages:
|
|
1451
|
+
// * Higher throughput and deterministic, which helps the fuzzer.
|
|
1452
|
+
// * Easier debugging of single-threaded reproducable bugs.
|
|
1453
|
+
const testing_buf = try std.testing.allocator.alloc(u8, 65536);
|
|
1454
|
+
defer std.testing.allocator.free(testing_buf);
|
|
1455
|
+
const backing_buf = try std.testing.allocator.alloc(u8, 1 << 17);
|
|
1456
|
+
defer std.testing.allocator.free(backing_buf);
|
|
1457
|
+
try std.testing.fuzz(FuzzSingleThreadedContext{
|
|
1458
|
+
.testing_buf = testing_buf,
|
|
1459
|
+
.backing_buf = backing_buf,
|
|
1460
|
+
}, fuzzSingleThreaded, .{});
|
|
1461
|
+
}
|
|
1462
|
+
|
|
1463
|
+
const FuzzSingleThreadedContext = struct {
|
|
1464
|
+
testing_buf: []u8,
|
|
1465
|
+
backing_buf: []u8,
|
|
1466
|
+
};
|
|
1467
|
+
|
|
1468
|
+
/// Guarantees memory will not be reused.
|
|
1469
|
+
const FuzzSingleThreadedAllocator = struct {
|
|
1470
|
+
gpa: mem.Allocator,
|
|
1471
|
+
smith: *std.testing.Smith,
|
|
1472
|
+
|
|
1473
|
+
buf: []u8,
|
|
1474
|
+
fill: usize,
|
|
1475
|
+
allocs: std.MultiArrayList(AllocInfo),
|
|
1476
|
+
|
|
1477
|
+
const AllocInfo = struct {
|
|
1478
|
+
ptr: [*]u8,
|
|
1479
|
+
len: usize,
|
|
1480
|
+
alignment: Alignment,
|
|
1481
|
+
};
|
|
1482
|
+
|
|
1483
|
+
fn allocator(f: *FuzzSingleThreadedAllocator) mem.Allocator {
|
|
1484
|
+
@disableInstrumentation();
|
|
1485
|
+
return .{ .ptr = f, .vtable = &.{
|
|
1486
|
+
.alloc = FuzzSingleThreadedAllocator.alloc,
|
|
1487
|
+
.free = FuzzSingleThreadedAllocator.free,
|
|
1488
|
+
.resize = FuzzSingleThreadedAllocator.resize,
|
|
1489
|
+
.remap = FuzzSingleThreadedAllocator.remap,
|
|
1490
|
+
} };
|
|
1491
|
+
}
|
|
1492
|
+
|
|
1493
|
+
fn alloc(ctx: *anyopaque, len: usize, alignment: Alignment, _: usize) ?[*]u8 {
|
|
1494
|
+
@disableInstrumentation();
|
|
1495
|
+
|
|
1496
|
+
const f: *FuzzSingleThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1497
|
+
f.allocs.ensureUnusedCapacity(f.gpa, 1) catch return null;
|
|
1498
|
+
|
|
1499
|
+
const ptr = f.allocInner(len, alignment) orelse return null;
|
|
1500
|
+
f.allocs.appendAssumeCapacity(.{
|
|
1501
|
+
.ptr = ptr,
|
|
1502
|
+
.len = len,
|
|
1503
|
+
.alignment = alignment,
|
|
1504
|
+
});
|
|
1505
|
+
return ptr;
|
|
1506
|
+
}
|
|
1507
|
+
|
|
1508
|
+
fn allocInner(f: *FuzzSingleThreadedAllocator, len: usize, alignment: Alignment) ?[*]u8 {
|
|
1509
|
+
@disableInstrumentation();
|
|
1510
|
+
|
|
1511
|
+
const start_addr = alignment.forward(@intFromPtr(f.buf[f.fill..].ptr));
|
|
1512
|
+
const start = @as([*]u8, @ptrFromInt(start_addr)) - f.buf.ptr;
|
|
1513
|
+
if (start +| len > f.buf.len or f.smith.boolWeighted(31, 1)) return null;
|
|
1514
|
+
f.fill = start + len;
|
|
1515
|
+
return f.buf[start..][0..len].ptr;
|
|
1516
|
+
}
|
|
1517
|
+
|
|
1518
|
+
fn allocIndex(f: *FuzzSingleThreadedAllocator, memory: []u8, alignment: Alignment) usize {
|
|
1519
|
+
@disableInstrumentation();
|
|
1520
|
+
|
|
1521
|
+
const allocs_slice = f.allocs.slice();
|
|
1522
|
+
const i = mem.indexOfScalar([*]u8, allocs_slice.items(.ptr), memory.ptr) orelse panic(
|
|
1523
|
+
"invalid SafeAllocator free of {f}",
|
|
1524
|
+
.{FormatMemory{ .memory = memory, .alignment = alignment }},
|
|
1525
|
+
);
|
|
1526
|
+
const expected_len = allocs_slice.items(.len)[i];
|
|
1527
|
+
const expected_align = allocs_slice.items(.alignment)[i];
|
|
1528
|
+
if (memory.len != expected_len or allocs_slice.items(.alignment)[i] != expected_align) {
|
|
1529
|
+
panic("SafeAllocator free {f} mismatches alloc {f}", .{
|
|
1530
|
+
FormatMemory{ .memory = memory, .alignment = alignment },
|
|
1531
|
+
FormatMemory{ .memory = memory.ptr[0..expected_len], .alignment = expected_align },
|
|
1532
|
+
});
|
|
1533
|
+
}
|
|
1534
|
+
return i;
|
|
1535
|
+
}
|
|
1536
|
+
|
|
1537
|
+
fn free(ctx: *anyopaque, memory: []u8, alignment: Alignment, _: usize) void {
|
|
1538
|
+
@disableInstrumentation();
|
|
1539
|
+
|
|
1540
|
+
const f: *FuzzSingleThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1541
|
+
f.allocs.swapRemove(f.allocIndex(memory, alignment));
|
|
1542
|
+
}
|
|
1543
|
+
|
|
1544
|
+
fn resize(ctx: *anyopaque, memory: []u8, alignment: Alignment, new_len: usize, _: usize) bool {
|
|
1545
|
+
@disableInstrumentation();
|
|
1546
|
+
|
|
1547
|
+
const f: *FuzzSingleThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1548
|
+
const i = f.allocIndex(memory, alignment);
|
|
1549
|
+
|
|
1550
|
+
const start = memory.ptr - f.buf.ptr;
|
|
1551
|
+
const old_end = start + memory.len;
|
|
1552
|
+
const new_end = start +| new_len;
|
|
1553
|
+
if (new_end > f.buf.len or f.smith.value(bool)) {
|
|
1554
|
+
return false;
|
|
1555
|
+
}
|
|
1556
|
+
|
|
1557
|
+
if (new_len <= memory.len) {
|
|
1558
|
+
// The fill is not decreased so memory is not reused.
|
|
1559
|
+
} else if (f.fill == old_end) {
|
|
1560
|
+
f.fill = new_end;
|
|
1561
|
+
} else {
|
|
1562
|
+
return false;
|
|
1563
|
+
}
|
|
1564
|
+
f.allocs.items(.len)[i] = new_len;
|
|
1565
|
+
return true;
|
|
1566
|
+
}
|
|
1567
|
+
|
|
1568
|
+
fn remap(ctx: *anyopaque, memory: []u8, alignment: Alignment, new_len: usize, _: usize) ?[*]u8 {
|
|
1569
|
+
@disableInstrumentation();
|
|
1570
|
+
|
|
1571
|
+
const f: *FuzzSingleThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1572
|
+
if (f.smith.value(bool)) {
|
|
1573
|
+
const resized = FuzzSingleThreadedAllocator.resize(
|
|
1574
|
+
ctx,
|
|
1575
|
+
memory,
|
|
1576
|
+
alignment,
|
|
1577
|
+
new_len,
|
|
1578
|
+
undefined,
|
|
1579
|
+
);
|
|
1580
|
+
return if (resized) memory.ptr else null;
|
|
1581
|
+
}
|
|
1582
|
+
|
|
1583
|
+
const i = f.allocIndex(memory, alignment);
|
|
1584
|
+
if (f.smith.value(bool)) return null;
|
|
1585
|
+
|
|
1586
|
+
const new_ptr = f.allocInner(new_len, alignment) orelse return null;
|
|
1587
|
+
const copy_len = @min(memory.len, new_len);
|
|
1588
|
+
@memcpy(new_ptr[0..copy_len], memory[0..copy_len]);
|
|
1589
|
+
|
|
1590
|
+
f.allocs.set(i, .{
|
|
1591
|
+
.ptr = new_ptr,
|
|
1592
|
+
.len = new_len,
|
|
1593
|
+
.alignment = alignment,
|
|
1594
|
+
});
|
|
1595
|
+
return new_ptr;
|
|
1596
|
+
}
|
|
1597
|
+
};
|
|
1598
|
+
|
|
1599
|
+
fn fuzzSingleThreaded(ctx: FuzzSingleThreadedContext, smith: *Smith) !void {
|
|
1600
|
+
@disableInstrumentation();
|
|
1601
|
+
|
|
1602
|
+
var gpa_instance: std.heap.FixedBufferAllocator = .init(ctx.testing_buf);
|
|
1603
|
+
const gpa = gpa_instance.allocator();
|
|
1604
|
+
var backing_gpa_instance: FuzzSingleThreadedAllocator = .{
|
|
1605
|
+
.gpa = gpa,
|
|
1606
|
+
.smith = smith,
|
|
1607
|
+
|
|
1608
|
+
.buf = ctx.backing_buf,
|
|
1609
|
+
.fill = 0,
|
|
1610
|
+
.allocs = .empty,
|
|
1611
|
+
};
|
|
1612
|
+
const backing_gpa = backing_gpa_instance.allocator();
|
|
1613
|
+
|
|
1614
|
+
const options = fuzz_probs.generateOptions(smith);
|
|
1615
|
+
var s: SafeAllocator = .init(backing_gpa, options);
|
|
1616
|
+
const no_ra: usize = 0;
|
|
1617
|
+
|
|
1618
|
+
var allocs: std.MultiArrayList(struct {
|
|
1619
|
+
memory: []u8,
|
|
1620
|
+
alignment: Alignment,
|
|
1621
|
+
splat: ?u8,
|
|
1622
|
+
}) = .empty;
|
|
1623
|
+
var used_memory: std.ArrayList(struct {
|
|
1624
|
+
start: usize,
|
|
1625
|
+
end: usize,
|
|
1626
|
+
}) = .empty;
|
|
1627
|
+
|
|
1628
|
+
while (!smith.eosWeighted(fuzz_probs.eos)) {
|
|
1629
|
+
const op = fuzz_probs.generateOp(smith, allocs.len != 0);
|
|
1630
|
+
const new_mem: []const u8, const old_mem: ?[]const u8 = new_alloc: switch (op) {
|
|
1631
|
+
.alloc => {
|
|
1632
|
+
used_memory.ensureUnusedCapacity(gpa, 1) catch break;
|
|
1633
|
+
allocs.ensureUnusedCapacity(gpa, 1) catch break;
|
|
1634
|
+
|
|
1635
|
+
const splat = fuzz_probs.generateSplat(smith);
|
|
1636
|
+
const will_memset = options.check_write_after_free or splat != null;
|
|
1637
|
+
const len = fuzz_probs.generateLen(smith, will_memset);
|
|
1638
|
+
const alignment = smith.valueWeighted(Alignment, fuzz_probs.alignment);
|
|
1639
|
+
|
|
1640
|
+
const ptr = alloc(&s, len, alignment, no_ra) orelse continue;
|
|
1641
|
+
if (!alignment.check(@intFromPtr(ptr))) @panic("bad returned alignment");
|
|
1642
|
+
const memory = ptr[0..len];
|
|
1643
|
+
if (splat) |b| @memset(memory, b);
|
|
1644
|
+
|
|
1645
|
+
allocs.appendAssumeCapacity(.{
|
|
1646
|
+
.memory = memory,
|
|
1647
|
+
.alignment = alignment,
|
|
1648
|
+
.splat = splat,
|
|
1649
|
+
});
|
|
1650
|
+
break :new_alloc .{ memory, null };
|
|
1651
|
+
},
|
|
1652
|
+
.free => {
|
|
1653
|
+
const i = smith.valueRangeLessThan(u32, 0, @intCast(allocs.len));
|
|
1654
|
+
const alloc_info = allocs.get(i);
|
|
1655
|
+
allocs.swapRemove(i);
|
|
1656
|
+
|
|
1657
|
+
fuzz_probs.checkSplat(alloc_info.splat, alloc_info.memory);
|
|
1658
|
+
free(&s, alloc_info.memory, alloc_info.alignment, no_ra);
|
|
1659
|
+
continue;
|
|
1660
|
+
},
|
|
1661
|
+
.resize => {
|
|
1662
|
+
used_memory.ensureUnusedCapacity(gpa, 1) catch break;
|
|
1663
|
+
const i = smith.valueRangeLessThan(u32, 0, @intCast(allocs.len));
|
|
1664
|
+
const allocs_slice = allocs.slice();
|
|
1665
|
+
|
|
1666
|
+
const prev_alloc = allocs_slice.get(i);
|
|
1667
|
+
const old_len = prev_alloc.memory.len;
|
|
1668
|
+
|
|
1669
|
+
const alloc_memory = &allocs_slice.items(.memory)[i];
|
|
1670
|
+
const splat = prev_alloc.splat;
|
|
1671
|
+
const will_memset = options.check_write_after_free or splat != null;
|
|
1672
|
+
|
|
1673
|
+
const new_len = fuzz_probs.generateLen(smith, will_memset);
|
|
1674
|
+
if (!resize(&s, prev_alloc.memory, prev_alloc.alignment, new_len, no_ra)) {
|
|
1675
|
+
fuzz_probs.checkSplat(prev_alloc.splat, prev_alloc.memory);
|
|
1676
|
+
continue;
|
|
1677
|
+
}
|
|
1678
|
+
alloc_memory.len = new_len;
|
|
1679
|
+
|
|
1680
|
+
fuzz_probs.checkSplat(prev_alloc.splat, alloc_memory.*[0..@min(old_len, new_len)]);
|
|
1681
|
+
if (splat) |b| @memset(alloc_memory.*[@min(old_len, new_len)..], b);
|
|
1682
|
+
|
|
1683
|
+
break :new_alloc .{ alloc_memory.*, prev_alloc.memory };
|
|
1684
|
+
},
|
|
1685
|
+
.remap => {
|
|
1686
|
+
used_memory.ensureUnusedCapacity(gpa, 1) catch break;
|
|
1687
|
+
const i = smith.valueRangeLessThan(u32, 0, @intCast(allocs.len));
|
|
1688
|
+
const allocs_slice = allocs.slice();
|
|
1689
|
+
|
|
1690
|
+
const prev_alloc = allocs_slice.get(i);
|
|
1691
|
+
const old_len = prev_alloc.memory.len;
|
|
1692
|
+
|
|
1693
|
+
const alloc_memory = &allocs_slice.items(.memory)[i];
|
|
1694
|
+
const alignment = prev_alloc.alignment;
|
|
1695
|
+
const splat = prev_alloc.splat;
|
|
1696
|
+
const will_memset = options.check_write_after_free or splat != null;
|
|
1697
|
+
|
|
1698
|
+
const new_len = fuzz_probs.generateLen(smith, will_memset);
|
|
1699
|
+
const new_ptr = remap(
|
|
1700
|
+
&s,
|
|
1701
|
+
prev_alloc.memory,
|
|
1702
|
+
prev_alloc.alignment,
|
|
1703
|
+
new_len,
|
|
1704
|
+
no_ra,
|
|
1705
|
+
) orelse {
|
|
1706
|
+
fuzz_probs.checkSplat(prev_alloc.splat, prev_alloc.memory);
|
|
1707
|
+
continue;
|
|
1708
|
+
};
|
|
1709
|
+
alloc_memory.* = new_ptr[0..new_len];
|
|
1710
|
+
|
|
1711
|
+
if (!alignment.check(@intFromPtr(new_ptr))) @panic("bad returned alignment");
|
|
1712
|
+
fuzz_probs.checkSplat(prev_alloc.splat, alloc_memory.*[0..@min(old_len, new_len)]);
|
|
1713
|
+
if (splat) |b| @memset(alloc_memory.*[@min(old_len, new_len)..], b);
|
|
1714
|
+
|
|
1715
|
+
break :new_alloc .{ alloc_memory.*, prev_alloc.memory };
|
|
1716
|
+
},
|
|
1717
|
+
};
|
|
1718
|
+
|
|
1719
|
+
const new_start = @intFromPtr(new_mem.ptr);
|
|
1720
|
+
const new_end = new_start + new_mem.len;
|
|
1721
|
+
const old_start = if (old_mem) |old| @intFromPtr(old.ptr) else 0;
|
|
1722
|
+
const old_end = new_start + if (old_mem) |old| old.len else 0;
|
|
1723
|
+
for (used_memory.items) |used| {
|
|
1724
|
+
if (old_start <= used.end and used.start <= old_end) {
|
|
1725
|
+
continue;
|
|
1726
|
+
}
|
|
1727
|
+
if (new_start <= used.end and used.start <= new_end) {
|
|
1728
|
+
panic(
|
|
1729
|
+
"memory reuse between [addr: {x}, len: {}] and new [addr: {x}, len: {}]",
|
|
1730
|
+
.{ used.start, used.end, new_start, new_end },
|
|
1731
|
+
);
|
|
1732
|
+
}
|
|
1733
|
+
}
|
|
1734
|
+
used_memory.appendAssumeCapacity(.{ .start = new_start, .end = new_end });
|
|
1735
|
+
}
|
|
1736
|
+
|
|
1737
|
+
try std.testing.expectEqual(allocs.len, s.deinitLog(false));
|
|
1738
|
+
const leaks_slice = backing_gpa_instance.allocs.slice();
|
|
1739
|
+
for (0..leaks_slice.len) |i| {
|
|
1740
|
+
const leak = leaks_slice.get(i);
|
|
1741
|
+
std.log.err("SafeAllocator leaked {f}", .{FormatMemory{
|
|
1742
|
+
.memory = leak.ptr[0..leak.len],
|
|
1743
|
+
.alignment = leak.alignment,
|
|
1744
|
+
}});
|
|
1745
|
+
}
|
|
1746
|
+
try std.testing.expectEqual(0, leaks_slice.len); // no leaks
|
|
1747
|
+
}
|
|
1748
|
+
|
|
1749
|
+
test "fuzz multi threaded" {
|
|
1750
|
+
if (@import("builtin").single_threaded) return error.SkipZigTest;
|
|
1751
|
+
|
|
1752
|
+
const testing_buf = try std.testing.allocator.alloc(u8, 65536);
|
|
1753
|
+
defer std.testing.allocator.free(testing_buf);
|
|
1754
|
+
const backing_buf = try std.testing.allocator.alloc(u8, 1 << 17);
|
|
1755
|
+
defer std.testing.allocator.free(backing_buf);
|
|
1756
|
+
|
|
1757
|
+
// `std.testing` instances are overwritten during `std.testing.fuzz` so
|
|
1758
|
+
// it is necessary to use our own io and gpa instances.
|
|
1759
|
+
var threaded_io: std.Io.Threaded = .init(std.heap.smp_allocator, .{});
|
|
1760
|
+
defer threaded_io.deinit();
|
|
1761
|
+
const io = threaded_io.io();
|
|
1762
|
+
|
|
1763
|
+
var ops: FuzzMultiThreadedContext.ThreadOps = undefined;
|
|
1764
|
+
ops.run = .{ .n = false };
|
|
1765
|
+
var group: std.Io.Group = .init;
|
|
1766
|
+
defer group.cancel(io);
|
|
1767
|
+
for (0..FuzzMultiThreadedContext.n_threads) |_| {
|
|
1768
|
+
try group.concurrent(io, fuzzMultiThreadedWorker, .{ io, &ops });
|
|
1769
|
+
}
|
|
1770
|
+
|
|
1771
|
+
try std.testing.fuzz(FuzzMultiThreadedContext{
|
|
1772
|
+
.testing_buf = testing_buf,
|
|
1773
|
+
.backing_buf = backing_buf,
|
|
1774
|
+
|
|
1775
|
+
.io = io,
|
|
1776
|
+
.ops = &ops,
|
|
1777
|
+
}, fuzzMultiThreaded, .{});
|
|
1778
|
+
}
|
|
1779
|
+
|
|
1780
|
+
const FuzzMultiThreadedContext = struct {
|
|
1781
|
+
testing_buf: []u8,
|
|
1782
|
+
backing_buf: []u8,
|
|
1783
|
+
|
|
1784
|
+
io: std.Io,
|
|
1785
|
+
ops: *ThreadOps,
|
|
1786
|
+
|
|
1787
|
+
const n_threads = 4;
|
|
1788
|
+
|
|
1789
|
+
const ThreadOps = struct {
|
|
1790
|
+
/// Switches between two values for each time a run starts.
|
|
1791
|
+
run: Run,
|
|
1792
|
+
/// While this can be calculated as `n_threads - (i -| ops.items.len)`,
|
|
1793
|
+
/// this also serves as `.release` synchronization for each thread.
|
|
1794
|
+
running: u32,
|
|
1795
|
+
|
|
1796
|
+
instance: SafeAllocator,
|
|
1797
|
+
i: usize,
|
|
1798
|
+
items: []Op,
|
|
1799
|
+
|
|
1800
|
+
const Run = packed struct(u32) {
|
|
1801
|
+
n: bool,
|
|
1802
|
+
pad: u31 = 0,
|
|
1803
|
+
|
|
1804
|
+
fn wait(ptr: *Run, val: Run, io: std.Io) error{Canceled}!void {
|
|
1805
|
+
assert(val.pad == 0);
|
|
1806
|
+
while (true) {
|
|
1807
|
+
// This cannot load a previous value since this thread previously loaded the
|
|
1808
|
+
// latest value.
|
|
1809
|
+
const prev = @atomicLoad(Run, ptr, .acquire);
|
|
1810
|
+
assert(prev.pad == 0);
|
|
1811
|
+
if (prev == val) break;
|
|
1812
|
+
|
|
1813
|
+
try io.futexWait(Run, ptr, prev);
|
|
1814
|
+
}
|
|
1815
|
+
}
|
|
1816
|
+
|
|
1817
|
+
fn next(r: Run) Run {
|
|
1818
|
+
assert(r.pad == 0);
|
|
1819
|
+
return .{ .n = !r.n };
|
|
1820
|
+
}
|
|
1821
|
+
};
|
|
1822
|
+
|
|
1823
|
+
const Op = union(fuzz_probs.Op) {
|
|
1824
|
+
alloc: struct {
|
|
1825
|
+
len: usize,
|
|
1826
|
+
alignment: Alignment,
|
|
1827
|
+
|
|
1828
|
+
splat: ?u8,
|
|
1829
|
+
/// Not embeded directly in the struct as a workaround for tsan since a
|
|
1830
|
+
/// switch directly on `Op` loads the entire value non-atomically.
|
|
1831
|
+
result: *MemoryDependency,
|
|
1832
|
+
},
|
|
1833
|
+
free: struct {
|
|
1834
|
+
memory: *MemoryDependency,
|
|
1835
|
+
alignment: Alignment,
|
|
1836
|
+
|
|
1837
|
+
splat: ?u8,
|
|
1838
|
+
},
|
|
1839
|
+
resize: Realloc,
|
|
1840
|
+
remap: Realloc,
|
|
1841
|
+
|
|
1842
|
+
const Realloc = struct {
|
|
1843
|
+
memory: *MemoryDependency,
|
|
1844
|
+
alignment: Alignment,
|
|
1845
|
+
new_len: usize,
|
|
1846
|
+
|
|
1847
|
+
splat: ?u8,
|
|
1848
|
+
/// Not embeded directly in the struct as a workaround for tsan since a
|
|
1849
|
+
/// switch directly on `Op` loads the entire value non-atomically.
|
|
1850
|
+
result: *MemoryDependency,
|
|
1851
|
+
};
|
|
1852
|
+
|
|
1853
|
+
const MemoryDependency = struct {
|
|
1854
|
+
ready: std.Io.Event,
|
|
1855
|
+
/// Null if the memory failed to be allocated
|
|
1856
|
+
memory: ?[]u8,
|
|
1857
|
+
|
|
1858
|
+
const init: MemoryDependency = .{
|
|
1859
|
+
.ready = .unset,
|
|
1860
|
+
.memory = undefined,
|
|
1861
|
+
};
|
|
1862
|
+
|
|
1863
|
+
fn get(dep: *MemoryDependency, io: std.Io) ?[]u8 {
|
|
1864
|
+
dep.ready.waitUncancelable(io);
|
|
1865
|
+
return dep.memory;
|
|
1866
|
+
}
|
|
1867
|
+
};
|
|
1868
|
+
};
|
|
1869
|
+
};
|
|
1870
|
+
};
|
|
1871
|
+
|
|
1872
|
+
/// Guarantees memory will not be reused.
|
|
1873
|
+
const FuzzMultiThreadedAllocator = struct {
|
|
1874
|
+
gpa: mem.Allocator,
|
|
1875
|
+
|
|
1876
|
+
fill: usize,
|
|
1877
|
+
active_allocs: usize,
|
|
1878
|
+
fail_i: usize,
|
|
1879
|
+
fixed_remap_i: usize,
|
|
1880
|
+
|
|
1881
|
+
// The below are assumed to be externally synchronized
|
|
1882
|
+
// i.e. each thread has an acquire fence before **first** using the allocator
|
|
1883
|
+
buf: []u8,
|
|
1884
|
+
fails: []const bool,
|
|
1885
|
+
fixed_remaps: []const bool,
|
|
1886
|
+
|
|
1887
|
+
fn allocator(f: *FuzzMultiThreadedAllocator) mem.Allocator {
|
|
1888
|
+
@disableInstrumentation();
|
|
1889
|
+
return .{ .ptr = f, .vtable = &.{
|
|
1890
|
+
.alloc = FuzzMultiThreadedAllocator.alloc,
|
|
1891
|
+
.free = FuzzMultiThreadedAllocator.free,
|
|
1892
|
+
.resize = FuzzMultiThreadedAllocator.resize,
|
|
1893
|
+
.remap = FuzzMultiThreadedAllocator.remap,
|
|
1894
|
+
} };
|
|
1895
|
+
}
|
|
1896
|
+
|
|
1897
|
+
fn maybeFail(f: *FuzzMultiThreadedAllocator) bool {
|
|
1898
|
+
@disableInstrumentation();
|
|
1899
|
+
const i = @atomicRmw(usize, &f.fail_i, .Add, 1, .monotonic);
|
|
1900
|
+
return i < f.fails.len and f.fails[i];
|
|
1901
|
+
}
|
|
1902
|
+
|
|
1903
|
+
fn maybeFixedRemap(f: *FuzzMultiThreadedAllocator) bool {
|
|
1904
|
+
@disableInstrumentation();
|
|
1905
|
+
const i = @atomicRmw(usize, &f.fixed_remap_i, .Add, 1, .monotonic);
|
|
1906
|
+
return i < f.fixed_remaps.len and f.fixed_remaps[i];
|
|
1907
|
+
}
|
|
1908
|
+
|
|
1909
|
+
fn alloc(ctx: *anyopaque, len: usize, alignment: Alignment, _: usize) ?[*]u8 {
|
|
1910
|
+
@disableInstrumentation();
|
|
1911
|
+
|
|
1912
|
+
const f: *FuzzMultiThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1913
|
+
const memory = f.allocInner(len, alignment) orelse return null;
|
|
1914
|
+
_ = @atomicRmw(usize, &f.active_allocs, .Add, 1, .monotonic);
|
|
1915
|
+
return memory;
|
|
1916
|
+
}
|
|
1917
|
+
|
|
1918
|
+
fn allocInner(f: *FuzzMultiThreadedAllocator, len: usize, alignment: Alignment) ?[*]u8 {
|
|
1919
|
+
var prev_fill = @atomicLoad(usize, &f.fill, .monotonic);
|
|
1920
|
+
var start: usize = undefined;
|
|
1921
|
+
while (true) {
|
|
1922
|
+
const start_addr = alignment.forward(@intFromPtr(f.buf[prev_fill..].ptr));
|
|
1923
|
+
start = @as([*]u8, @ptrFromInt(start_addr)) - f.buf.ptr;
|
|
1924
|
+
if (start +| len > f.buf.len or f.maybeFail()) return null;
|
|
1925
|
+
prev_fill = @cmpxchgStrong(
|
|
1926
|
+
usize,
|
|
1927
|
+
&f.fill,
|
|
1928
|
+
prev_fill,
|
|
1929
|
+
start + len,
|
|
1930
|
+
.monotonic,
|
|
1931
|
+
.monotonic,
|
|
1932
|
+
) orelse {
|
|
1933
|
+
@branchHint(.likely);
|
|
1934
|
+
break;
|
|
1935
|
+
};
|
|
1936
|
+
}
|
|
1937
|
+
return f.buf[start..][0..len].ptr;
|
|
1938
|
+
}
|
|
1939
|
+
|
|
1940
|
+
fn free(ctx: *anyopaque, _: []u8, _: Alignment, _: usize) void {
|
|
1941
|
+
@disableInstrumentation();
|
|
1942
|
+
|
|
1943
|
+
const f: *FuzzMultiThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1944
|
+
assert(@atomicRmw(usize, &f.active_allocs, .Sub, 1, .monotonic) != 0);
|
|
1945
|
+
}
|
|
1946
|
+
|
|
1947
|
+
fn resize(ctx: *anyopaque, memory: []u8, _: Alignment, new_len: usize, _: usize) bool {
|
|
1948
|
+
@disableInstrumentation();
|
|
1949
|
+
|
|
1950
|
+
const f: *FuzzMultiThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1951
|
+
const start = memory.ptr - f.buf.ptr;
|
|
1952
|
+
const old_end = start + memory.len;
|
|
1953
|
+
const new_end = start +| new_len;
|
|
1954
|
+
if (new_end > f.buf.len or f.maybeFail()) {
|
|
1955
|
+
return false;
|
|
1956
|
+
}
|
|
1957
|
+
|
|
1958
|
+
if (new_len <= memory.len) {
|
|
1959
|
+
// The fill is not decreased so memory is not reused.
|
|
1960
|
+
return true;
|
|
1961
|
+
}
|
|
1962
|
+
|
|
1963
|
+
return @cmpxchgStrong(usize, &f.fill, old_end, new_end, .monotonic, .monotonic) == null;
|
|
1964
|
+
}
|
|
1965
|
+
|
|
1966
|
+
fn remap(ctx: *anyopaque, memory: []u8, alignment: Alignment, new_len: usize, _: usize) ?[*]u8 {
|
|
1967
|
+
@disableInstrumentation();
|
|
1968
|
+
|
|
1969
|
+
if (maybeFixedRemap(@ptrCast(@alignCast(ctx)))) {
|
|
1970
|
+
const resized = FuzzMultiThreadedAllocator.resize(
|
|
1971
|
+
ctx,
|
|
1972
|
+
memory,
|
|
1973
|
+
alignment,
|
|
1974
|
+
new_len,
|
|
1975
|
+
undefined,
|
|
1976
|
+
);
|
|
1977
|
+
return if (resized) memory.ptr else null;
|
|
1978
|
+
}
|
|
1979
|
+
|
|
1980
|
+
const f: *FuzzMultiThreadedAllocator = @ptrCast(@alignCast(ctx));
|
|
1981
|
+
const new_ptr = f.allocInner(new_len, alignment) orelse return null;
|
|
1982
|
+
const copy_len = @min(memory.len, new_len);
|
|
1983
|
+
@memcpy(new_ptr[0..copy_len], memory[0..copy_len]);
|
|
1984
|
+
return new_ptr;
|
|
1985
|
+
}
|
|
1986
|
+
};
|
|
1987
|
+
|
|
1988
|
+
fn fuzzMultiThreaded(ctx: FuzzMultiThreadedContext, smith: *Smith) !void {
|
|
1989
|
+
@disableInstrumentation();
|
|
1990
|
+
|
|
1991
|
+
var gpa_instance: std.heap.FixedBufferAllocator = .init(ctx.testing_buf);
|
|
1992
|
+
const gpa = gpa_instance.allocator();
|
|
1993
|
+
|
|
1994
|
+
var op_count: u32 = 0;
|
|
1995
|
+
while (!smith.eosWeighted(fuzz_probs.eos)) op_count += 1;
|
|
1996
|
+
const Op = FuzzMultiThreadedContext.ThreadOps.Op;
|
|
1997
|
+
const ops = gpa.alloc(Op, op_count) catch return error.SkipZigTest;
|
|
1998
|
+
const op_results = gpa.alloc(Op.MemoryDependency, op_count) catch return error.SkipZigTest;
|
|
1999
|
+
@memset(op_results, .init);
|
|
2000
|
+
|
|
2001
|
+
const allocs = gpa.alloc(struct {
|
|
2002
|
+
memory: *FuzzMultiThreadedContext.ThreadOps.Op.MemoryDependency,
|
|
2003
|
+
alignment: Alignment,
|
|
2004
|
+
splat: ?u8,
|
|
2005
|
+
}, op_count) catch return error.SkipZigTest;
|
|
2006
|
+
var allocs_n: u32 = 0;
|
|
2007
|
+
var expected_remaps: usize = 0;
|
|
2008
|
+
|
|
2009
|
+
const options = fuzz_probs.generateOptions(smith);
|
|
2010
|
+
for (ops, op_results) |*op, *result| switch (fuzz_probs.generateOp(smith, allocs_n != 0)) {
|
|
2011
|
+
.alloc => {
|
|
2012
|
+
const splat = fuzz_probs.generateSplat(smith);
|
|
2013
|
+
const will_memset = options.check_write_after_free or splat != null;
|
|
2014
|
+
op.* = .{ .alloc = .{
|
|
2015
|
+
.len = fuzz_probs.generateLen(smith, will_memset),
|
|
2016
|
+
.alignment = smith.valueWeighted(Alignment, fuzz_probs.alignment),
|
|
2017
|
+
|
|
2018
|
+
.splat = splat,
|
|
2019
|
+
.result = result,
|
|
2020
|
+
} };
|
|
2021
|
+
allocs[allocs_n] = .{
|
|
2022
|
+
.memory = result,
|
|
2023
|
+
.alignment = op.alloc.alignment,
|
|
2024
|
+
.splat = splat,
|
|
2025
|
+
};
|
|
2026
|
+
allocs_n += 1;
|
|
2027
|
+
},
|
|
2028
|
+
.free => {
|
|
2029
|
+
const i = smith.valueRangeLessThan(u32, 0, allocs_n);
|
|
2030
|
+
op.* = .{ .free = .{
|
|
2031
|
+
.memory = allocs[i].memory,
|
|
2032
|
+
.alignment = allocs[i].alignment,
|
|
2033
|
+
|
|
2034
|
+
.splat = allocs[i].splat,
|
|
2035
|
+
} };
|
|
2036
|
+
|
|
2037
|
+
allocs_n -= 1;
|
|
2038
|
+
allocs[i] = allocs[allocs_n];
|
|
2039
|
+
},
|
|
2040
|
+
.resize, .remap => |kind| {
|
|
2041
|
+
op.* = switch (kind) {
|
|
2042
|
+
.remap => .{ .remap = undefined },
|
|
2043
|
+
.resize => .{ .resize = undefined },
|
|
2044
|
+
else => unreachable,
|
|
2045
|
+
};
|
|
2046
|
+
const realloc = switch (kind) {
|
|
2047
|
+
.remap => &op.remap,
|
|
2048
|
+
.resize => &op.resize,
|
|
2049
|
+
else => unreachable,
|
|
2050
|
+
};
|
|
2051
|
+
expected_remaps += @intFromBool(kind == .remap);
|
|
2052
|
+
|
|
2053
|
+
const i = smith.valueRangeLessThan(u32, 0, allocs_n);
|
|
2054
|
+
realloc.* = .{
|
|
2055
|
+
.memory = allocs[i].memory,
|
|
2056
|
+
.alignment = allocs[i].alignment,
|
|
2057
|
+
.new_len = fuzz_probs.generateLen(smith, options.check_write_after_free),
|
|
2058
|
+
|
|
2059
|
+
.splat = allocs[i].splat,
|
|
2060
|
+
.result = result,
|
|
2061
|
+
};
|
|
2062
|
+
allocs[i].memory = result;
|
|
2063
|
+
},
|
|
2064
|
+
};
|
|
2065
|
+
|
|
2066
|
+
const fails: []bool = gpa.alloc(bool, ops.len * 2 + smith.value(u8)) catch &.{};
|
|
2067
|
+
const fixed_remaps: []bool = gpa.alloc(bool, expected_remaps + smith.value(u8)) catch &.{};
|
|
2068
|
+
for (fails) |*f| f.* = smith.boolWeighted(31, 1);
|
|
2069
|
+
for (fixed_remaps) |*f| f.* = smith.value(bool);
|
|
2070
|
+
var backing_gpa_instance: FuzzMultiThreadedAllocator = .{
|
|
2071
|
+
.gpa = gpa,
|
|
2072
|
+
|
|
2073
|
+
.fill = 0,
|
|
2074
|
+
.active_allocs = 0,
|
|
2075
|
+
.fail_i = 0,
|
|
2076
|
+
.fixed_remap_i = 0,
|
|
2077
|
+
|
|
2078
|
+
.buf = ctx.backing_buf,
|
|
2079
|
+
.fails = fails,
|
|
2080
|
+
.fixed_remaps = fixed_remaps,
|
|
2081
|
+
};
|
|
2082
|
+
const backing_gpa = backing_gpa_instance.allocator();
|
|
2083
|
+
|
|
2084
|
+
ctx.ops.instance = .init(backing_gpa, options);
|
|
2085
|
+
ctx.ops.i = 0;
|
|
2086
|
+
ctx.ops.items = ops;
|
|
2087
|
+
|
|
2088
|
+
ctx.ops.running = FuzzMultiThreadedContext.n_threads;
|
|
2089
|
+
// Loading `ctx.ops.run` non-atomically is fine since this is the only thread that writes to it.
|
|
2090
|
+
@atomicStore(FuzzMultiThreadedContext.ThreadOps.Run, &ctx.ops.run, ctx.ops.run.next(), .release);
|
|
2091
|
+
ctx.io.futexWake(FuzzMultiThreadedContext.ThreadOps.Run, &ctx.ops.run, math.maxInt(u32));
|
|
2092
|
+
while (true) {
|
|
2093
|
+
const prev_running = @atomicLoad(u32, &ctx.ops.running, .acquire);
|
|
2094
|
+
if (prev_running == 0) break;
|
|
2095
|
+
ctx.io.futexWaitUncancelable(u32, &ctx.ops.running, prev_running);
|
|
2096
|
+
}
|
|
2097
|
+
|
|
2098
|
+
var expected_allocs = allocs_n;
|
|
2099
|
+
for (allocs[0..allocs_n]) |a| {
|
|
2100
|
+
expected_allocs -= @intFromBool(a.memory.memory == null);
|
|
2101
|
+
}
|
|
2102
|
+
try std.testing.expectEqual(expected_allocs, ctx.ops.instance.deinitLog(false));
|
|
2103
|
+
try std.testing.expectEqual(0, backing_gpa_instance.active_allocs); // no leaks
|
|
2104
|
+
}
|
|
2105
|
+
|
|
2106
|
+
fn fuzzMultiThreadedWorker(
|
|
2107
|
+
io: std.Io,
|
|
2108
|
+
ops: *FuzzMultiThreadedContext.ThreadOps,
|
|
2109
|
+
) error{Canceled}!void {
|
|
2110
|
+
const no_ra: usize = 0;
|
|
2111
|
+
var next_run: FuzzMultiThreadedContext.ThreadOps.Run = .{ .n = true };
|
|
2112
|
+
while (true) {
|
|
2113
|
+
try ops.run.wait(next_run, io);
|
|
2114
|
+
next_run = .next(next_run);
|
|
2115
|
+
|
|
2116
|
+
while (true) {
|
|
2117
|
+
const i = @atomicRmw(usize, &ops.i, .Add, 1, .monotonic);
|
|
2118
|
+
if (i >= ops.items.len) {
|
|
2119
|
+
// `.acq_rel` is necessary since acquire loads only synchronize with the thread
|
|
2120
|
+
// which the read value was written from, not all previous writer threads.
|
|
2121
|
+
const prev_rem = @atomicRmw(u32, &ops.running, .Sub, 1, .acq_rel);
|
|
2122
|
+
if (prev_rem - 1 == 0) {
|
|
2123
|
+
io.futexWake(u32, &ops.running, 1);
|
|
2124
|
+
}
|
|
2125
|
+
break;
|
|
2126
|
+
}
|
|
2127
|
+
|
|
2128
|
+
switch (ops.items[i]) {
|
|
2129
|
+
.alloc => |call| {
|
|
2130
|
+
const alloc_ptr = alloc(&ops.instance, call.len, call.alignment, no_ra);
|
|
2131
|
+
if (alloc_ptr) |memory_ptr| {
|
|
2132
|
+
const memory = memory_ptr[0..call.len];
|
|
2133
|
+
if (call.splat) |b| @memset(memory, b);
|
|
2134
|
+
call.result.memory = memory;
|
|
2135
|
+
} else {
|
|
2136
|
+
call.result.memory = null;
|
|
2137
|
+
}
|
|
2138
|
+
call.result.ready.set(io);
|
|
2139
|
+
},
|
|
2140
|
+
.free => |call| {
|
|
2141
|
+
const memory = call.memory.get(io) orelse continue;
|
|
2142
|
+
fuzz_probs.checkSplat(call.splat, memory);
|
|
2143
|
+
free(&ops.instance, memory, call.alignment, no_ra);
|
|
2144
|
+
},
|
|
2145
|
+
.resize, .remap => |call, kind| {
|
|
2146
|
+
const memory = call.memory.get(io) orelse {
|
|
2147
|
+
call.result.memory = null;
|
|
2148
|
+
call.result.ready.set(io);
|
|
2149
|
+
continue;
|
|
2150
|
+
};
|
|
2151
|
+
const new_memory: []u8 = switch (kind) {
|
|
2152
|
+
.remap => if (remap(
|
|
2153
|
+
&ops.instance,
|
|
2154
|
+
memory,
|
|
2155
|
+
call.alignment,
|
|
2156
|
+
call.new_len,
|
|
2157
|
+
no_ra,
|
|
2158
|
+
)) |new_ptr| new_ptr[0..call.new_len] else memory,
|
|
2159
|
+
.resize => if (resize(
|
|
2160
|
+
&ops.instance,
|
|
2161
|
+
memory,
|
|
2162
|
+
call.alignment,
|
|
2163
|
+
call.new_len,
|
|
2164
|
+
no_ra,
|
|
2165
|
+
)) memory.ptr[0..call.new_len] else memory,
|
|
2166
|
+
else => unreachable,
|
|
2167
|
+
};
|
|
2168
|
+
|
|
2169
|
+
const old_len = memory.len;
|
|
2170
|
+
const new_len = new_memory.len;
|
|
2171
|
+
fuzz_probs.checkSplat(call.splat, new_memory[0..@min(old_len, new_len)]);
|
|
2172
|
+
if (call.splat) |b| @memset(new_memory[@min(old_len, new_len)..], b);
|
|
2173
|
+
|
|
2174
|
+
call.result.memory = new_memory;
|
|
2175
|
+
call.result.ready.set(io);
|
|
2176
|
+
},
|
|
2177
|
+
}
|
|
2178
|
+
}
|
|
2179
|
+
}
|
|
2180
|
+
}
|