@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.
Files changed (2025) hide show
  1. package/c/fcntl.zig +5 -0
  2. package/c/math.zig +41 -2
  3. package/c/pthread.zig +57 -0
  4. package/c/stdlib.zig +32 -22
  5. package/c/string.zig +20 -0
  6. package/c/unistd.zig +1 -0
  7. package/c/wchar.zig +10 -0
  8. package/c.zig +1 -0
  9. package/{std/Build → compiler/Maker}/Fuzz.zig +177 -89
  10. package/compiler/Maker/Graph.zig +85 -0
  11. package/compiler/Maker/PkgConfig.zig +122 -0
  12. package/compiler/Maker/ScannedConfig.zig +372 -0
  13. package/compiler/Maker/Step/CheckFile.zig +63 -0
  14. package/compiler/Maker/Step/Compile.zig +1388 -0
  15. package/compiler/Maker/Step/ConfigHeader.zig +610 -0
  16. package/compiler/Maker/Step/FindProgram.zig +120 -0
  17. package/compiler/Maker/Step/Fmt.zig +65 -0
  18. package/compiler/Maker/Step/InstallArtifact.zig +141 -0
  19. package/compiler/Maker/Step/InstallDir.zig +99 -0
  20. package/compiler/Maker/Step/InstallFile.zig +26 -0
  21. package/compiler/Maker/Step/ObjCopy.zig +173 -0
  22. package/compiler/Maker/Step/Options.zig +104 -0
  23. package/compiler/Maker/Step/Run.zig +2390 -0
  24. package/compiler/Maker/Step/TranslateC.zig +157 -0
  25. package/compiler/Maker/Step/UpdateSourceFiles.zig +89 -0
  26. package/compiler/Maker/Step/WriteFile.zig +294 -0
  27. package/compiler/Maker/Step.zig +894 -0
  28. package/{std/Build → compiler/Maker}/Watch/FsEvents.zig +36 -26
  29. package/{std/Build → compiler/Maker}/Watch.zig +89 -68
  30. package/{std/Build → compiler/Maker}/WebServer.zig +145 -118
  31. package/compiler/Maker.zig +2061 -0
  32. package/compiler/aro/aro/Attribute.zig +52 -51
  33. package/compiler/aro/aro/CodeGen.zig +7 -8
  34. package/compiler/aro/aro/Compilation.zig +22 -22
  35. package/compiler/aro/aro/Diagnostics.zig +7 -7
  36. package/compiler/aro/aro/Driver.zig +18 -16
  37. package/compiler/aro/aro/Parser.zig +22 -17
  38. package/compiler/aro/aro/Pragma.zig +3 -2
  39. package/compiler/aro/aro/Preprocessor.zig +11 -8
  40. package/compiler/aro/aro/Tree.zig +11 -11
  41. package/compiler/aro/aro/features.zig +4 -4
  42. package/compiler/aro/aro/pragmas/message.zig +3 -2
  43. package/compiler/aro/aro/text_literal.zig +5 -4
  44. package/compiler/aro/assembly_backend/x86_64.zig +4 -4
  45. package/compiler/aro/backend/Interner.zig +14 -13
  46. package/compiler/aro/backend/Ir/x86/Renderer.zig +3 -3
  47. package/compiler/configurer.zig +1402 -0
  48. package/compiler/reduce/Walk.zig +8 -13
  49. package/compiler/resinator/bmp.zig +3 -2
  50. package/compiler/resinator/code_pages.zig +14 -12
  51. package/compiler/resinator/compile.zig +1 -1
  52. package/compiler/resinator/cvtres.zig +15 -14
  53. package/compiler/resinator/errors.zig +25 -29
  54. package/compiler/resinator/ico.zig +4 -4
  55. package/compiler/resinator/lang.zig +7 -7
  56. package/compiler/resinator/parse.zig +3 -3
  57. package/compiler/resinator/res.zig +1 -1
  58. package/compiler/std-docs.zig +17 -38
  59. package/compiler/test_runner.zig +25 -15
  60. package/compiler/translate-c/MacroTranslator.zig +1 -1
  61. package/compiler/translate-c/Translator.zig +2 -2
  62. package/compiler/translate-c/ast.zig +22 -29
  63. package/compiler/translate-c/main.zig +1 -1
  64. package/compiler_rt/addf3.zig +1 -1
  65. package/compiler_rt/arm.zig +3 -3
  66. package/compiler_rt/atomics.zig +1 -1
  67. package/compiler_rt/comparef.zig +3 -3
  68. package/compiler_rt/cos.zig +1 -1
  69. package/compiler_rt/count0bits.zig +1 -1
  70. package/compiler_rt/divdf3.zig +2 -2
  71. package/compiler_rt/divsf3.zig +1 -1
  72. package/compiler_rt/divtf3.zig +1 -1
  73. package/compiler_rt/divxf3.zig +1 -1
  74. package/compiler_rt/extendf.zig +5 -5
  75. package/compiler_rt/fabs.zig +1 -1
  76. package/compiler_rt/float_from_int.zig +4 -5
  77. package/compiler_rt/fmax.zig +1 -1
  78. package/compiler_rt/fmin.zig +1 -1
  79. package/compiler_rt/fmod.zig +2 -2
  80. package/compiler_rt/int_from_float.zig +1 -1
  81. package/compiler_rt/limb64.zig +3 -34
  82. package/compiler_rt/log.zig +230 -3
  83. package/compiler_rt/log10.zig +228 -3
  84. package/compiler_rt/log2.zig +221 -3
  85. package/compiler_rt/log_f128.zig +173 -0
  86. package/compiler_rt/mulf3.zig +2 -2
  87. package/compiler_rt/rem_pio2l.zig +1 -1
  88. package/compiler_rt/sin.zig +1 -1
  89. package/compiler_rt/sincos.zig +1 -1
  90. package/compiler_rt/ssp.zig +2 -2
  91. package/compiler_rt/tan.zig +1 -1
  92. package/compiler_rt/truncf.zig +3 -3
  93. package/compiler_rt/trunctfhf2.zig +3 -0
  94. package/compiler_rt.zig +5 -26
  95. package/docs/main.js +8 -8
  96. package/docs/wasm/Walk.zig +1 -3
  97. package/docs/wasm/html_render.zig +1 -2
  98. package/docs/wasm/markdown/Document.zig +3 -3
  99. package/docs/wasm/markdown/Parser.zig +19 -23
  100. package/fuzzer.zig +5 -3
  101. package/include/__clang_spirv_builtins.h +12 -12
  102. package/include/__float_float.h +176 -0
  103. package/include/__float_header_macro.h +12 -0
  104. package/include/__float_infinity_nan.h +20 -0
  105. package/include/amo.h +131 -0
  106. package/include/amxavx512intrin.h +215 -1
  107. package/include/amxintrin.h +0 -2
  108. package/include/arm_acle.h +37 -27
  109. package/include/arm_neon.h +218 -82
  110. package/include/arm_sme.h +8 -8
  111. package/include/arm_sve.h +4162 -3782
  112. package/include/avx10_2_512bf16intrin.h +19 -12
  113. package/include/avx10_2_512convertintrin.h +1 -1
  114. package/include/avx10_2_512niintrin.h +31 -31
  115. package/include/avx10_2_512satcvtdsintrin.h +1 -1
  116. package/include/avx10_2bf16intrin.h +54 -45
  117. package/include/avx10_2convertintrin.h +2 -2
  118. package/include/avx10_2copyintrin.h +1 -1
  119. package/include/avx10_2niintrin.h +14 -14
  120. package/include/avx10_2satcvtdsintrin.h +2 -2
  121. package/include/avx2intrin.h +275 -377
  122. package/include/avx512bf16intrin.h +25 -16
  123. package/include/avx512bitalgintrin.h +19 -30
  124. package/include/avx512bwintrin.h +386 -505
  125. package/include/avx512cdintrin.h +42 -55
  126. package/include/avx512dqintrin.h +132 -161
  127. package/include/avx512fintrin.h +1015 -1424
  128. package/include/avx512fp16intrin.h +112 -110
  129. package/include/avx512ifmaintrin.h +32 -34
  130. package/include/avx512ifmavlintrin.h +73 -46
  131. package/include/avx512vbmi2intrin.h +43 -32
  132. package/include/avx512vbmiintrin.h +19 -27
  133. package/include/avx512vbmivlintrin.h +35 -49
  134. package/include/avx512vlbf16intrin.h +32 -22
  135. package/include/avx512vlbitalgintrin.h +37 -53
  136. package/include/avx512vlbwintrin.h +470 -573
  137. package/include/avx512vlcdintrin.h +74 -102
  138. package/include/avx512vldqintrin.h +110 -127
  139. package/include/avx512vlfp16intrin.h +130 -111
  140. package/include/avx512vlintrin.h +945 -1299
  141. package/include/avx512vlvbmi2intrin.h +78 -63
  142. package/include/avx512vlvnniintrin.h +21 -18
  143. package/include/avx512vlvp2intersectintrin.h +2 -2
  144. package/include/avx512vnniintrin.h +10 -10
  145. package/include/avx512vp2intersectintrin.h +1 -2
  146. package/include/avx512vpopcntdqintrin.h +8 -10
  147. package/include/avx512vpopcntdqvlintrin.h +17 -15
  148. package/include/avxifmaintrin.h +16 -0
  149. package/include/avxintrin.h +165 -241
  150. package/include/avxvnniint16intrin.h +118 -99
  151. package/include/avxvnniint8intrin.h +56 -32
  152. package/include/avxvnniintrin.h +16 -8
  153. package/include/cpuid.h +101 -4
  154. package/include/emmintrin.h +168 -168
  155. package/include/f16cintrin.h +23 -9
  156. package/include/float.h +16 -155
  157. package/include/fma4intrin.h +98 -96
  158. package/include/fmaintrin.h +96 -66
  159. package/include/gfniintrin.h +21 -16
  160. package/include/hexagon_types.h +23 -20
  161. package/include/hvx_hexagon_protos.h +649 -860
  162. package/include/immintrin.h +0 -12
  163. package/include/intrin.h +4 -0
  164. package/include/lasxintrin.h +113 -0
  165. package/include/llvm_libc_wrappers/assert.h +3 -5
  166. package/include/llvm_libc_wrappers/ctype.h +3 -115
  167. package/include/llvm_libc_wrappers/inttypes.h +3 -5
  168. package/include/llvm_libc_wrappers/stdio.h +10 -38
  169. package/include/llvm_libc_wrappers/stdlib.h +3 -24
  170. package/include/llvm_libc_wrappers/string.h +2 -70
  171. package/include/llvm_libc_wrappers/time.h +4 -10
  172. package/include/mmintrin.h +188 -257
  173. package/include/module.modulemap +23 -4
  174. package/include/movrs_avx10_2_512intrin.h +2 -2
  175. package/include/movrs_avx10_2intrin.h +4 -4
  176. package/include/pmmintrin.h +12 -24
  177. package/include/ptrauth.h +16 -2
  178. package/include/riscv_mips.h +34 -0
  179. package/include/riscv_nds.h +89 -0
  180. package/include/sifive_vector.h +58 -2
  181. package/include/sm4evexintrin.h +2 -2
  182. package/include/smmintrin.h +77 -59
  183. package/include/spirvintrin.h +194 -0
  184. package/include/stddefer.h +19 -0
  185. package/include/tmmintrin.h +116 -147
  186. package/include/vaesintrin.h +1 -2
  187. package/include/xmmintrin.h +44 -70
  188. package/include/xopintrin.h +20 -10
  189. package/init/build.zig +1 -3
  190. package/libc/darwin/SDKSettings.json +1 -1
  191. package/libc/darwin/libSystem.tbd +88 -87
  192. package/libc/include/aarch64-linux-any/asm/hwcap.h +1 -0
  193. package/libc/include/aarch64-linux-any/asm/unistd_64.h +1 -0
  194. package/libc/include/aarch64-netbsd-none/aarch64/armreg.h +259 -22
  195. package/libc/include/aarch64-netbsd-none/aarch64/byte_swap.h +3 -2
  196. package/libc/include/aarch64-netbsd-none/aarch64/cpu.h +26 -1
  197. package/libc/include/aarch64-netbsd-none/aarch64/lwp_private.h +3 -0
  198. package/libc/include/aarch64-netbsd-none/aarch64/pmap.h +7 -33
  199. package/libc/include/aarch64-netbsd-none/aarch64/sljit_machdep.h +1 -1
  200. package/libc/include/aarch64-netbsd-none/aarch64/vmparam.h +4 -4
  201. package/libc/include/aarch64-netbsd-none/machine/armreg.h +259 -22
  202. package/libc/include/aarch64-netbsd-none/machine/byte_swap.h +3 -2
  203. package/libc/include/aarch64-netbsd-none/machine/cpu.h +26 -1
  204. package/libc/include/aarch64-netbsd-none/machine/lwp_private.h +3 -0
  205. package/libc/include/aarch64-netbsd-none/machine/pmap.h +7 -33
  206. package/libc/include/aarch64-netbsd-none/machine/sljit_machdep.h +1 -1
  207. package/libc/include/aarch64-netbsd-none/machine/vmparam.h +4 -4
  208. package/libc/include/aarch64-openbsd-none/arm64/cpu.h +7 -1
  209. package/libc/include/aarch64-openbsd-none/arm64/intr.h +9 -1
  210. package/libc/include/aarch64-openbsd-none/machine/cpu.h +7 -1
  211. package/libc/include/aarch64-openbsd-none/machine/intr.h +9 -1
  212. package/libc/include/any-darwin-any/AvailabilityInternal.h +10 -10
  213. package/libc/include/any-darwin-any/AvailabilityVersions.h +8 -0
  214. package/libc/include/any-darwin-any/mach/host_info.h +3 -1
  215. package/libc/include/any-darwin-any/mach/mach_voucher_types.h +2 -0
  216. package/libc/include/any-darwin-any/mach/vm_statistics.h +33 -2
  217. package/libc/include/any-darwin-any/spawn.h +3 -1
  218. package/libc/include/any-darwin-any/sys/_symbol_aliasing.h +12 -0
  219. package/libc/include/any-linux-any/asm-generic/errno.h +2 -0
  220. package/libc/include/any-linux-any/asm-generic/unistd.h +4 -1
  221. package/libc/include/any-linux-any/drm/amdgpu_drm.h +20 -6
  222. package/libc/include/any-linux-any/drm/amdxdna_accel.h +8 -0
  223. package/libc/include/any-linux-any/drm/drm_fourcc.h +6 -6
  224. package/libc/include/any-linux-any/drm/panfrost_drm.h +75 -1
  225. package/libc/include/any-linux-any/drm/panthor_drm.h +154 -3
  226. package/libc/include/any-linux-any/drm/rocket_accel.h +74 -24
  227. package/libc/include/any-linux-any/drm/xe_drm.h +89 -6
  228. package/libc/include/any-linux-any/linux/android/binder.h +1 -1
  229. package/libc/include/any-linux-any/linux/bpf.h +28 -0
  230. package/libc/include/any-linux-any/linux/btrfs.h +1 -0
  231. package/libc/include/any-linux-any/linux/btrfs_tree.h +32 -2
  232. package/libc/include/any-linux-any/linux/dma-buf.h +1 -0
  233. package/libc/include/any-linux-any/linux/dpll.h +1 -0
  234. package/libc/include/any-linux-any/linux/elf.h +2 -0
  235. package/libc/include/any-linux-any/linux/ethtool.h +21 -5
  236. package/libc/include/any-linux-any/linux/fs.h +1 -0
  237. package/libc/include/any-linux-any/linux/hyperv.h +1 -1
  238. package/libc/include/any-linux-any/linux/idxd.h +134 -134
  239. package/libc/include/any-linux-any/linux/if_alg.h +1 -1
  240. package/libc/include/any-linux-any/linux/if_link.h +1 -0
  241. package/libc/include/any-linux-any/linux/input-event-codes.h +4 -0
  242. package/libc/include/any-linux-any/linux/io_uring/bpf_filter.h +68 -0
  243. package/libc/include/any-linux-any/linux/io_uring/query.h +5 -1
  244. package/libc/include/any-linux-any/linux/io_uring.h +33 -2
  245. package/libc/include/any-linux-any/linux/iommufd.h +39 -0
  246. package/libc/include/any-linux-any/linux/kfd_ioctl.h +13 -3
  247. package/libc/include/any-linux-any/linux/kfd_sysfs.h +2 -1
  248. package/libc/include/any-linux-any/linux/kvm.h +30 -6
  249. package/libc/include/any-linux-any/linux/landlock.h +22 -8
  250. package/libc/include/any-linux-any/linux/magic.h +1 -0
  251. package/libc/include/any-linux-any/linux/mempolicy.h +3 -0
  252. package/libc/include/any-linux-any/linux/mount.h +11 -2
  253. package/libc/include/any-linux-any/linux/mptcp_pm.h +1 -1
  254. package/libc/include/any-linux-any/linux/mshv.h +2 -0
  255. package/libc/include/any-linux-any/linux/netfilter_bridge.h +5 -4
  256. package/libc/include/any-linux-any/linux/netfilter_ipv4.h +4 -5
  257. package/libc/include/any-linux-any/linux/netfilter_ipv6.h +3 -4
  258. package/libc/include/any-linux-any/linux/nfs.h +1 -1
  259. package/libc/include/any-linux-any/linux/nfsd_netlink.h +1 -0
  260. package/libc/include/any-linux-any/linux/nilfs2_api.h +2 -2
  261. package/libc/include/any-linux-any/linux/nilfs2_ondisk.h +97 -66
  262. package/libc/include/any-linux-any/linux/nl80211.h +104 -3
  263. package/libc/include/any-linux-any/linux/pci.h +7 -0
  264. package/libc/include/any-linux-any/linux/pci_regs.h +65 -6
  265. package/libc/include/any-linux-any/linux/pcitest.h +1 -0
  266. package/libc/include/any-linux-any/linux/perf_event.h +24 -3
  267. package/libc/include/any-linux-any/linux/pkt_sched.h +1 -0
  268. package/libc/include/any-linux-any/linux/prctl.h +30 -0
  269. package/libc/include/any-linux-any/linux/rseq.h +62 -5
  270. package/libc/include/any-linux-any/linux/shm.h +0 -1
  271. package/libc/include/any-linux-any/linux/stddef.h +4 -0
  272. package/libc/include/any-linux-any/linux/sysctl.h +1 -2
  273. package/libc/include/any-linux-any/linux/taskstats.h +12 -1
  274. package/libc/include/any-linux-any/linux/tcp.h +23 -3
  275. package/libc/include/any-linux-any/linux/typelimits.h +8 -0
  276. package/libc/include/any-linux-any/linux/ublk_cmd.h +120 -1
  277. package/libc/include/any-linux-any/linux/v4l2-controls.h +63 -0
  278. package/libc/include/any-linux-any/linux/vbox_vmmdev_types.h +2 -2
  279. package/libc/include/any-linux-any/linux/vduse.h +80 -5
  280. package/libc/include/any-linux-any/linux/version.h +3 -3
  281. package/libc/include/any-linux-any/linux/vfio.h +4 -0
  282. package/libc/include/any-linux-any/linux/videodev2.h +3 -0
  283. package/libc/include/any-linux-any/linux/virtio_ring.h +1 -2
  284. package/libc/include/any-linux-any/linux/vmclock-abi.h +20 -0
  285. package/libc/include/any-linux-any/rdma/bnxt_re-abi.h +16 -0
  286. package/libc/include/any-linux-any/rdma/ib_user_ioctl_cmds.h +16 -0
  287. package/libc/include/any-linux-any/rdma/mana-abi.h +3 -0
  288. package/libc/include/any-linux-any/scsi/scsi_bsg_ufs.h +8 -9
  289. package/libc/include/any-linux-any/sound/sof/tokens.h +6 -0
  290. package/libc/include/arc-linux-any/asm/swab.h +0 -63
  291. package/libc/include/arc-linux-any/asm/unistd_32.h +1 -0
  292. package/libc/include/arm-linux-any/asm/ptrace.h +0 -9
  293. package/libc/include/arm-linux-any/asm/unistd-eabi.h +1 -0
  294. package/libc/include/arm-linux-any/asm/unistd-oabi.h +1 -0
  295. package/libc/include/arm-netbsd-eabi/float.h +2 -1
  296. package/libc/include/arm-netbsd-eabi/machine/asm.h +48 -19
  297. package/libc/include/arm-netbsd-eabi/machine/byte_swap.h +121 -0
  298. package/libc/include/arm-netbsd-eabi/machine/cpu.h +1 -3
  299. package/libc/include/arm-netbsd-eabi/machine/float.h +2 -1
  300. package/libc/include/arm-netbsd-eabi/machine/lwp_private.h +81 -0
  301. package/libc/include/arm-netbsd-eabi/machine/mcontext.h +5 -51
  302. package/libc/include/arm-netbsd-eabi/machine/mutex.h +1 -1
  303. package/libc/include/arm-netbsd-eabi/machine/proc.h +2 -2
  304. package/libc/include/arm-netbsd-eabi/machine/profile.h +28 -96
  305. package/libc/include/arm-netbsd-eabi/machine/setjmp.h +7 -6
  306. package/libc/include/arm-netbsd-eabi/machine/sysarch.h +85 -0
  307. package/libc/include/csky-linux-any/asm/unistd_32.h +1 -0
  308. package/libc/include/generic-netbsd/altq/altq.h +2 -2
  309. package/libc/include/generic-netbsd/altq/altq_afmap.h +2 -1
  310. package/libc/include/generic-netbsd/altq/altq_classq.h +8 -6
  311. package/libc/include/generic-netbsd/altq/altq_jobs.h +37 -37
  312. package/libc/include/generic-netbsd/altq/altq_rmclass.h +8 -8
  313. package/libc/include/generic-netbsd/altq/altq_var.h +2 -2
  314. package/libc/include/generic-netbsd/arm/arm32/pmap.h +8 -32
  315. package/libc/include/generic-netbsd/arm/arm32/vmparam.h +5 -5
  316. package/libc/include/generic-netbsd/arm/asm.h +48 -19
  317. package/libc/include/generic-netbsd/arm/byte_swap.h +2 -2
  318. package/libc/include/generic-netbsd/arm/cpu.h +1 -3
  319. package/libc/include/generic-netbsd/arm/cputypes.h +12 -1
  320. package/libc/include/generic-netbsd/arm/float.h +2 -1
  321. package/libc/include/generic-netbsd/arm/lwp_private.h +81 -0
  322. package/libc/include/generic-netbsd/arm/mcontext.h +5 -51
  323. package/libc/include/generic-netbsd/arm/mutex.h +1 -1
  324. package/libc/include/generic-netbsd/arm/proc.h +2 -2
  325. package/libc/include/generic-netbsd/arm/profile.h +28 -96
  326. package/libc/include/generic-netbsd/arm/setjmp.h +7 -6
  327. package/libc/include/generic-netbsd/arpa/nameser.h +3 -3
  328. package/libc/include/generic-netbsd/arpa/nameser_compat.h +3 -3
  329. package/libc/include/generic-netbsd/assert.h +12 -22
  330. package/libc/include/generic-netbsd/bitstring.h +5 -5
  331. package/libc/include/generic-netbsd/cdbw.h +2 -2
  332. package/libc/include/generic-netbsd/crypto/cryptodev.h +99 -92
  333. package/libc/include/generic-netbsd/dev/i2c/emcfaninfo.h +234 -0
  334. package/libc/include/generic-netbsd/dev/i2c/emcfanreg.h +127 -0
  335. package/libc/include/generic-netbsd/dev/i2o/i2o.h +3 -366
  336. package/libc/include/generic-netbsd/dev/ic/hd44780var.h +3 -1
  337. package/libc/include/generic-netbsd/dev/ic/scmdreg.h +2 -2
  338. package/libc/include/generic-netbsd/dev/ic/stireg.h +777 -0
  339. package/libc/include/generic-netbsd/dev/ic/summitreg.h +214 -0
  340. package/libc/include/generic-netbsd/dev/iscsi/iscsi.h +1 -1
  341. package/libc/include/generic-netbsd/dev/pci/amrreg.h +2 -2
  342. package/libc/include/generic-netbsd/dev/pci/mlyreg.h +2 -2
  343. package/libc/include/generic-netbsd/dev/pci/pcidevs.h +177 -22
  344. package/libc/include/generic-netbsd/dev/pci/pcidevs_data.h +14971 -14588
  345. package/libc/include/generic-netbsd/dev/pci/pcireg.h +14 -14
  346. package/libc/include/generic-netbsd/dev/pckbc/pckbdreg.h +2 -1
  347. package/libc/include/generic-netbsd/dev/pcmcia/if_rayreg.h +2 -2
  348. package/libc/include/generic-netbsd/dev/raidframe/raidframeio.h +1 -1
  349. package/libc/include/generic-netbsd/dev/scsipi/scsi_disk.h +42 -7
  350. package/libc/include/generic-netbsd/dev/scsipi/scsi_spc.h +2 -2
  351. package/libc/include/generic-netbsd/dev/scsipi/scsipi_all.h +83 -2
  352. package/libc/include/generic-netbsd/dev/scsipi/scsipiconf.h +3 -1
  353. package/libc/include/generic-netbsd/dev/tc/sfbreg.h +3 -3
  354. package/libc/include/generic-netbsd/dev/tc/sticio.h +2 -2
  355. package/libc/include/generic-netbsd/dev/usb/umcpmio_hid_reports.h +499 -0
  356. package/libc/include/generic-netbsd/dev/usb/umcpmio_io.h +45 -0
  357. package/libc/include/generic-netbsd/dev/usb/usb.h +44 -6
  358. package/libc/include/generic-netbsd/dev/vndvar.h +2 -2
  359. package/libc/include/generic-netbsd/dev/wscons/wsconsio.h +19 -1
  360. package/libc/include/generic-netbsd/dev/wscons/wsksymdef.h +2 -2
  361. package/libc/include/generic-netbsd/dirent.h +1 -1
  362. package/libc/include/generic-netbsd/dlfcn.h +4 -2
  363. package/libc/include/generic-netbsd/elf.h +32 -20
  364. package/libc/include/generic-netbsd/elfdefinitions.h +1 -1
  365. package/libc/include/generic-netbsd/evbarm/intr.h +1 -1
  366. package/libc/include/generic-netbsd/evbmips/lwp_private.h +3 -0
  367. package/libc/include/generic-netbsd/execinfo.h +4 -2
  368. package/libc/include/generic-netbsd/fcntl.h +26 -2
  369. package/libc/include/generic-netbsd/float.h +58 -2
  370. package/libc/include/generic-netbsd/fmtmsg.h +2 -2
  371. package/libc/include/generic-netbsd/fs/hfs/libhfs.h +1 -1
  372. package/libc/include/generic-netbsd/fs/nilfs/nilfs_fs.h +2 -2
  373. package/libc/include/generic-netbsd/gelf.h +2 -2
  374. package/libc/include/generic-netbsd/i386/asm.h +12 -4
  375. package/libc/include/generic-netbsd/i386/byte_swap.h +2 -2
  376. package/libc/include/generic-netbsd/i386/cpu.h +15 -4
  377. package/libc/include/generic-netbsd/i386/elf_machdep.h +2 -1
  378. package/libc/include/generic-netbsd/i386/lwp_private.h +3 -0
  379. package/libc/include/generic-netbsd/i386/mcontext.h +6 -24
  380. package/libc/include/generic-netbsd/i386/param.h +9 -1
  381. package/libc/include/generic-netbsd/i386/pcb.h +6 -2
  382. package/libc/include/generic-netbsd/i386/ptrace.h +2 -2
  383. package/libc/include/generic-netbsd/i386/types.h +2 -1
  384. package/libc/include/generic-netbsd/i386/wchar_limits.h +1 -1
  385. package/libc/include/generic-netbsd/isofs/cd9660/cd9660_extern.h +6 -1
  386. package/libc/include/generic-netbsd/isofs/cd9660/cd9660_mount.h +7 -1
  387. package/libc/include/generic-netbsd/langinfo.h +2 -1
  388. package/libc/include/generic-netbsd/lauxlib.h +1 -1
  389. package/libc/include/generic-netbsd/libelf.h +6 -15
  390. package/libc/include/generic-netbsd/limits.h +1 -1
  391. package/libc/include/generic-netbsd/lua.h +1 -1
  392. package/libc/include/generic-netbsd/luaconf.h +1 -1
  393. package/libc/include/generic-netbsd/lualib.h +1 -1
  394. package/libc/include/generic-netbsd/lwp.h +1 -1
  395. package/libc/include/generic-netbsd/machine/ansi.h +2 -2
  396. package/libc/include/generic-netbsd/machine/aout_machdep.h +39 -2
  397. package/libc/include/generic-netbsd/machine/arm32/pmap.h +8 -32
  398. package/libc/include/generic-netbsd/machine/arm32/vmparam.h +5 -5
  399. package/libc/include/generic-netbsd/machine/asm.h +271 -2
  400. package/libc/include/generic-netbsd/machine/bswap.h +9 -1
  401. package/libc/include/generic-netbsd/machine/byte_swap.h +42 -64
  402. package/libc/include/generic-netbsd/machine/cdefs.h +7 -2
  403. package/libc/include/generic-netbsd/machine/cpu.h +207 -30
  404. package/libc/include/generic-netbsd/machine/cputypes.h +12 -1
  405. package/libc/include/generic-netbsd/machine/disklabel.h +41 -42
  406. package/libc/include/generic-netbsd/machine/elf_machdep.h +143 -2
  407. package/libc/include/generic-netbsd/machine/endian.h +1 -1
  408. package/libc/include/generic-netbsd/machine/fenv.h +35 -2
  409. package/libc/include/generic-netbsd/machine/float.h +58 -2
  410. package/libc/include/generic-netbsd/machine/frame.h +129 -2
  411. package/libc/include/generic-netbsd/machine/ieee.h +3 -2
  412. package/libc/include/generic-netbsd/machine/ieeefp.h +43 -2
  413. package/libc/include/generic-netbsd/machine/int_const.h +32 -2
  414. package/libc/include/generic-netbsd/machine/int_fmtio.h +380 -2
  415. package/libc/include/generic-netbsd/machine/int_limits.h +2 -2
  416. package/libc/include/generic-netbsd/machine/int_mwgwtypes.h +2 -2
  417. package/libc/include/generic-netbsd/machine/int_types.h +2 -2
  418. package/libc/include/generic-netbsd/machine/kcore.h +39 -2
  419. package/libc/include/generic-netbsd/machine/limits.h +2 -2
  420. package/libc/include/generic-netbsd/machine/lock.h +2 -2
  421. package/libc/include/generic-netbsd/machine/lwp_private.h +83 -0
  422. package/libc/include/generic-netbsd/machine/math.h +3 -2
  423. package/libc/include/generic-netbsd/machine/mcontext.h +149 -2
  424. package/libc/include/generic-netbsd/machine/mutex.h +127 -2
  425. package/libc/include/generic-netbsd/machine/param.h +90 -23
  426. package/libc/include/generic-netbsd/machine/pcb.h +54 -2
  427. package/libc/include/generic-netbsd/machine/pmap.h +262 -2
  428. package/libc/include/generic-netbsd/machine/proc.h +75 -2
  429. package/libc/include/generic-netbsd/machine/profile.h +116 -2
  430. package/libc/include/generic-netbsd/machine/psl.h +2 -2
  431. package/libc/include/generic-netbsd/machine/pte.h +346 -2
  432. package/libc/include/generic-netbsd/machine/ptrace.h +62 -2
  433. package/libc/include/generic-netbsd/machine/reg.h +124 -2
  434. package/libc/include/generic-netbsd/machine/reloc.h +2 -2
  435. package/libc/include/generic-netbsd/machine/setjmp.h +69 -2
  436. package/libc/include/generic-netbsd/machine/signal.h +39 -2
  437. package/libc/include/generic-netbsd/machine/sljit_machdep.h +1 -1
  438. package/libc/include/generic-netbsd/machine/sysarch.h +2 -84
  439. package/libc/include/generic-netbsd/machine/sysreg.h +354 -0
  440. package/libc/include/generic-netbsd/machine/trap.h +2 -2
  441. package/libc/include/generic-netbsd/machine/types.h +118 -6
  442. package/libc/include/generic-netbsd/machine/vmparam.h +235 -2
  443. package/libc/include/generic-netbsd/machine/wchar_limits.h +2 -2
  444. package/libc/include/generic-netbsd/math.h +19 -6
  445. package/libc/include/generic-netbsd/md2.h +6 -3
  446. package/libc/include/generic-netbsd/mips/asm.h +69 -17
  447. package/libc/include/generic-netbsd/mips/bswap.h +3 -1
  448. package/libc/include/generic-netbsd/mips/cpu.h +7 -7
  449. package/libc/include/generic-netbsd/mips/elf_machdep.h +2 -1
  450. package/libc/include/generic-netbsd/mips/fenv.h +2 -1
  451. package/libc/include/generic-netbsd/mips/float.h +3 -2
  452. package/libc/include/generic-netbsd/mips/frame.h +3 -2
  453. package/libc/include/generic-netbsd/mips/limits.h +4 -13
  454. package/libc/include/generic-netbsd/mips/lwp_private.h +87 -0
  455. package/libc/include/generic-netbsd/mips/mcontext.h +2 -53
  456. package/libc/include/generic-netbsd/mips/mips3_pte.h +2 -2
  457. package/libc/include/generic-netbsd/mips/mips_param.h +16 -2
  458. package/libc/include/generic-netbsd/mips/mutex.h +1 -1
  459. package/libc/include/generic-netbsd/mips/types.h +1 -1
  460. package/libc/include/generic-netbsd/mips/vmparam.h +1 -1
  461. package/libc/include/generic-netbsd/miscfs/kernfs/kernfs.h +2 -2
  462. package/libc/include/generic-netbsd/miscfs/procfs/procfs.h +33 -2
  463. package/libc/include/generic-netbsd/miscfs/specfs/specdev.h +1 -2
  464. package/libc/include/generic-netbsd/monetary.h +2 -1
  465. package/libc/include/generic-netbsd/net/agr/if_agrioctl.h +2 -2
  466. package/libc/include/generic-netbsd/net/bpf.h +11 -4
  467. package/libc/include/generic-netbsd/net/bpfdesc.h +1 -1
  468. package/libc/include/generic-netbsd/net/dlt.h +222 -48
  469. package/libc/include/generic-netbsd/net/if.h +20 -5
  470. package/libc/include/generic-netbsd/net/if_bridgevar.h +2 -3
  471. package/libc/include/generic-netbsd/net/if_ether.h +4 -3
  472. package/libc/include/generic-netbsd/net/if_lagg.h +2 -2
  473. package/libc/include/generic-netbsd/net/if_media.h +2 -2
  474. package/libc/include/generic-netbsd/net/if_ppp.h +1 -3
  475. package/libc/include/generic-netbsd/net/if_stats.h +19 -5
  476. package/libc/include/generic-netbsd/net/net_stats.h +13 -6
  477. package/libc/include/generic-netbsd/net/npf.h +33 -5
  478. package/libc/include/generic-netbsd/net/pfkeyv2.h +1 -1
  479. package/libc/include/generic-netbsd/net/route.h +4 -4
  480. package/libc/include/generic-netbsd/net80211/ieee80211_node.h +3 -2
  481. package/libc/include/generic-netbsd/net80211/ieee80211_var.h +2 -2
  482. package/libc/include/generic-netbsd/netbt/hci.h +3 -3
  483. package/libc/include/generic-netbsd/netdb.h +2 -2
  484. package/libc/include/generic-netbsd/netinet/icmp6.h +6 -2
  485. package/libc/include/generic-netbsd/netinet/in.h +17 -17
  486. package/libc/include/generic-netbsd/netinet/in_var.h +5 -9
  487. package/libc/include/generic-netbsd/netinet/ip_mroute.h +24 -28
  488. package/libc/include/generic-netbsd/netinet/ip_var.h +2 -2
  489. package/libc/include/generic-netbsd/netinet/sctp.h +4 -4
  490. package/libc/include/generic-netbsd/netinet/tcp_var.h +2 -2
  491. package/libc/include/generic-netbsd/netinet/tcp_vtw.h +2 -2
  492. package/libc/include/generic-netbsd/netinet6/in6_var.h +7 -33
  493. package/libc/include/generic-netbsd/netinet6/ip6_var.h +2 -2
  494. package/libc/include/generic-netbsd/nfs/krpc.h +9 -4
  495. package/libc/include/generic-netbsd/nfs/nfs.h +5 -3
  496. package/libc/include/generic-netbsd/nfs/nfsdiskless.h +37 -20
  497. package/libc/include/generic-netbsd/nfs/nfsm_subs.h +4 -7
  498. package/libc/include/generic-netbsd/nfs/nfsmount.h +3 -4
  499. package/libc/include/generic-netbsd/nfs/nfsnode.h +9 -6
  500. package/libc/include/generic-netbsd/nfs/nfsproto.h +5 -2
  501. package/libc/include/generic-netbsd/nfs/nfsrtt.h +8 -4
  502. package/libc/include/generic-netbsd/nfs/nfsrvcache.h +9 -3
  503. package/libc/include/generic-netbsd/nfs/rpcv2.h +5 -3
  504. package/libc/include/generic-netbsd/nfs/xdr_subs.h +6 -5
  505. package/libc/include/generic-netbsd/nl_types.h +3 -1
  506. package/libc/include/generic-netbsd/ntfs/ntfs_inode.h +2 -2
  507. package/libc/include/generic-netbsd/poll.h +8 -2
  508. package/libc/include/generic-netbsd/prop/prop_object.h +48 -3
  509. package/libc/include/generic-netbsd/protocols/talkd.h +2 -2
  510. package/libc/include/generic-netbsd/pthread.h +51 -12
  511. package/libc/include/generic-netbsd/regex.h +2 -1
  512. package/libc/include/generic-netbsd/riscv/ansi.h +3 -0
  513. package/libc/include/generic-netbsd/riscv/aout_machdep.h +40 -0
  514. package/libc/include/generic-netbsd/riscv/asm.h +272 -0
  515. package/libc/include/generic-netbsd/riscv/bswap.h +11 -0
  516. package/libc/include/generic-netbsd/riscv/byte_swap.h +99 -0
  517. package/libc/include/generic-netbsd/riscv/cdefs.h +8 -0
  518. package/libc/include/generic-netbsd/riscv/cpu.h +242 -0
  519. package/libc/include/generic-netbsd/riscv/disklabel.h +68 -0
  520. package/libc/include/generic-netbsd/riscv/elf_machdep.h +144 -0
  521. package/libc/include/generic-netbsd/riscv/endian.h +3 -0
  522. package/libc/include/generic-netbsd/riscv/endian_machdep.h +3 -0
  523. package/libc/include/generic-netbsd/riscv/fenv.h +36 -0
  524. package/libc/include/generic-netbsd/riscv/float.h +59 -0
  525. package/libc/include/generic-netbsd/riscv/ieee.h +4 -0
  526. package/libc/include/generic-netbsd/riscv/ieeefp.h +44 -0
  527. package/libc/include/generic-netbsd/riscv/int_const.h +33 -0
  528. package/libc/include/generic-netbsd/riscv/int_fmtio.h +381 -0
  529. package/libc/include/generic-netbsd/riscv/int_limits.h +3 -0
  530. package/libc/include/generic-netbsd/riscv/int_mwgwtypes.h +3 -0
  531. package/libc/include/generic-netbsd/riscv/int_types.h +3 -0
  532. package/libc/include/generic-netbsd/riscv/kcore.h +40 -0
  533. package/libc/include/generic-netbsd/riscv/limits.h +3 -0
  534. package/libc/include/generic-netbsd/riscv/lock.h +3 -0
  535. package/libc/include/generic-netbsd/riscv/lwp_private.h +83 -0
  536. package/libc/include/generic-netbsd/riscv/math.h +4 -0
  537. package/libc/include/generic-netbsd/riscv/mcontext.h +150 -0
  538. package/libc/include/generic-netbsd/riscv/mutex.h +128 -0
  539. package/libc/include/generic-netbsd/riscv/param.h +110 -0
  540. package/libc/include/generic-netbsd/riscv/pcb.h +55 -0
  541. package/libc/include/generic-netbsd/riscv/pmap.h +263 -0
  542. package/libc/include/generic-netbsd/riscv/proc.h +76 -0
  543. package/libc/include/generic-netbsd/riscv/profile.h +117 -0
  544. package/libc/include/generic-netbsd/riscv/pte.h +347 -0
  545. package/libc/include/generic-netbsd/riscv/ptrace.h +63 -0
  546. package/libc/include/generic-netbsd/riscv/reg.h +125 -0
  547. package/libc/include/generic-netbsd/riscv/rwlock.h +1 -0
  548. package/libc/include/generic-netbsd/riscv/setjmp.h +70 -0
  549. package/libc/include/generic-netbsd/riscv/signal.h +40 -0
  550. package/libc/include/generic-netbsd/riscv/sysarch.h +3 -0
  551. package/libc/include/generic-netbsd/riscv/sysreg.h +354 -0
  552. package/libc/include/generic-netbsd/riscv/types.h +123 -0
  553. package/libc/include/generic-netbsd/riscv/vmparam.h +236 -0
  554. package/libc/include/generic-netbsd/riscv/wchar_limits.h +13 -0
  555. package/libc/include/generic-netbsd/rmd160.h +3 -3
  556. package/libc/include/generic-netbsd/rpc/xdr.h +3 -3
  557. package/libc/include/generic-netbsd/rpcsvc/yp_prot.h +3 -2
  558. package/libc/include/generic-netbsd/rump/rump_namei.h +2 -2
  559. package/libc/include/generic-netbsd/rump/rump_syscalls.h +4 -4
  560. package/libc/include/generic-netbsd/rump/rumpuser.h +6 -1
  561. package/libc/include/generic-netbsd/rump/rumpvnode_if.h +2 -2
  562. package/libc/include/generic-netbsd/sha1.h +3 -3
  563. package/libc/include/generic-netbsd/sha2.h +8 -1
  564. package/libc/include/generic-netbsd/signal.h +4 -4
  565. package/libc/include/generic-netbsd/sparc/asm.h +10 -1
  566. package/libc/include/generic-netbsd/sparc/bswap.h +9 -1
  567. package/libc/include/generic-netbsd/sparc/cgtworeg.h +2 -2
  568. package/libc/include/generic-netbsd/sparc/cpu.h +1 -1
  569. package/libc/include/generic-netbsd/sparc/float.h +3 -1
  570. package/libc/include/generic-netbsd/sparc/limits.h +4 -6
  571. package/libc/include/generic-netbsd/sparc/lwp_private.h +51 -0
  572. package/libc/include/generic-netbsd/sparc/mcontext.h +4 -22
  573. package/libc/include/generic-netbsd/sparc/mutex.h +1 -1
  574. package/libc/include/generic-netbsd/sparc/param.h +4 -2
  575. package/libc/include/generic-netbsd/sparc/pmap.h +2 -2
  576. package/libc/include/generic-netbsd/sparc/psl.h +6 -3
  577. package/libc/include/generic-netbsd/sparc/types.h +2 -2
  578. package/libc/include/generic-netbsd/sparc64/bswap.h +9 -1
  579. package/libc/include/generic-netbsd/sparc64/cpu.h +2 -2
  580. package/libc/include/generic-netbsd/sparc64/ctlreg.h +8 -7
  581. package/libc/include/generic-netbsd/sparc64/intr.h +1 -1
  582. package/libc/include/generic-netbsd/sparc64/lwp_private.h +3 -0
  583. package/libc/include/generic-netbsd/sparc64/mcontext.h +4 -4
  584. package/libc/include/generic-netbsd/sparc64/mutex.h +1 -1
  585. package/libc/include/generic-netbsd/sparc64/param.h +8 -2
  586. package/libc/include/generic-netbsd/sparc64/psl.h +7 -2
  587. package/libc/include/generic-netbsd/sparc64/pte.h +2 -2
  588. package/libc/include/generic-netbsd/sparc64/vmparam.h +1 -1
  589. package/libc/include/generic-netbsd/ssp/ssp.h +16 -6
  590. package/libc/include/generic-netbsd/stdalign.h +3 -3
  591. package/libc/include/generic-netbsd/stdarg.h +2 -2
  592. package/libc/include/generic-netbsd/stddef.h +90 -12
  593. package/libc/include/generic-netbsd/stdlib.h +11 -2
  594. package/libc/include/generic-netbsd/stdnoreturn.h +2 -2
  595. package/libc/include/generic-netbsd/string.h +66 -39
  596. package/libc/include/generic-netbsd/strings.h +17 -3
  597. package/libc/include/generic-netbsd/sys/atomic.h +10 -5
  598. package/libc/include/generic-netbsd/sys/bitops.h +2 -2
  599. package/libc/include/generic-netbsd/sys/bootblock.h +13 -2
  600. package/libc/include/generic-netbsd/sys/bswap.h +46 -20
  601. package/libc/include/generic-netbsd/sys/buf.h +3 -3
  602. package/libc/include/generic-netbsd/sys/cdefs.h +44 -6
  603. package/libc/include/generic-netbsd/sys/cdefs_aout.h +8 -1
  604. package/libc/include/generic-netbsd/sys/cdefs_elf.h +9 -2
  605. package/libc/include/generic-netbsd/sys/chio.h +2 -2
  606. package/libc/include/generic-netbsd/sys/clock.h +5 -1
  607. package/libc/include/generic-netbsd/sys/common_limits.h +3 -1
  608. package/libc/include/generic-netbsd/sys/condvar.h +1 -1
  609. package/libc/include/generic-netbsd/sys/conf.h +4 -3
  610. package/libc/include/generic-netbsd/sys/container_of.h +75 -0
  611. package/libc/include/generic-netbsd/sys/device.h +20 -13
  612. package/libc/include/generic-netbsd/sys/disk.h +8 -1
  613. package/libc/include/generic-netbsd/sys/disklabel.h +2 -2
  614. package/libc/include/generic-netbsd/sys/disklabel_gpt.h +7 -1
  615. package/libc/include/generic-netbsd/sys/efiio.h +1 -1
  616. package/libc/include/generic-netbsd/sys/elfdefinitions.h +2368 -1591
  617. package/libc/include/generic-netbsd/sys/endian.h +17 -17
  618. package/libc/include/generic-netbsd/sys/evcnt.h +15 -2
  619. package/libc/include/generic-netbsd/sys/event.h +3 -2
  620. package/libc/include/generic-netbsd/sys/exec.h +2 -2
  621. package/libc/include/generic-netbsd/sys/exec_elf.h +32 -20
  622. package/libc/include/generic-netbsd/sys/fcntl.h +26 -2
  623. package/libc/include/generic-netbsd/sys/fd_set.h +3 -3
  624. package/libc/include/generic-netbsd/sys/featuretest.h +24 -6
  625. package/libc/include/generic-netbsd/sys/file.h +18 -6
  626. package/libc/include/generic-netbsd/sys/filedesc.h +8 -4
  627. package/libc/include/generic-netbsd/sys/futex.h +11 -11
  628. package/libc/include/generic-netbsd/sys/ieee754.h +2 -2
  629. package/libc/include/generic-netbsd/sys/ipc.h +2 -2
  630. package/libc/include/generic-netbsd/sys/ipmi.h +4 -2
  631. package/libc/include/generic-netbsd/sys/ksem.h +1 -1
  632. package/libc/include/generic-netbsd/sys/ktrace.h +6 -4
  633. package/libc/include/generic-netbsd/sys/lock.h +2 -2
  634. package/libc/include/generic-netbsd/sys/lua.h +1 -1
  635. package/libc/include/generic-netbsd/sys/lwp.h +25 -92
  636. package/libc/include/generic-netbsd/sys/mbuf.h +15 -13
  637. package/libc/include/generic-netbsd/sys/mman.h +11 -3
  638. package/libc/include/generic-netbsd/sys/mount.h +1 -2
  639. package/libc/include/generic-netbsd/sys/msg.h +3 -3
  640. package/libc/include/generic-netbsd/sys/mutex.h +1 -3
  641. package/libc/include/generic-netbsd/sys/namei.h +32 -17
  642. package/libc/include/generic-netbsd/sys/param.h +11 -8
  643. package/libc/include/generic-netbsd/sys/pipe.h +10 -11
  644. package/libc/include/generic-netbsd/sys/poll.h +8 -2
  645. package/libc/include/generic-netbsd/sys/proc.h +15 -15
  646. package/libc/include/generic-netbsd/sys/ptrace.h +24 -7
  647. package/libc/include/generic-netbsd/sys/ptree.h +2 -1
  648. package/libc/include/generic-netbsd/sys/queue.h +37 -37
  649. package/libc/include/generic-netbsd/sys/rbtree.h +23 -9
  650. package/libc/include/generic-netbsd/sys/resourcevar.h +2 -2
  651. package/libc/include/generic-netbsd/sys/rmd160.h +3 -3
  652. package/libc/include/generic-netbsd/sys/rndio.h +1 -1
  653. package/libc/include/generic-netbsd/sys/rwlock.h +1 -2
  654. package/libc/include/generic-netbsd/sys/sched.h +1 -1
  655. package/libc/include/generic-netbsd/sys/sdt.h +181 -111
  656. package/libc/include/generic-netbsd/sys/sem.h +7 -2
  657. package/libc/include/generic-netbsd/sys/sha1.h +3 -3
  658. package/libc/include/generic-netbsd/sys/sha2.h +8 -1
  659. package/libc/include/generic-netbsd/sys/shm.h +2 -2
  660. package/libc/include/generic-netbsd/sys/siginfo.h +5 -5
  661. package/libc/include/generic-netbsd/sys/signal.h +1 -1
  662. package/libc/include/generic-netbsd/sys/sigtypes.h +4 -4
  663. package/libc/include/generic-netbsd/sys/sleepq.h +14 -27
  664. package/libc/include/generic-netbsd/sys/socket.h +3 -1
  665. package/libc/include/generic-netbsd/sys/socketvar.h +4 -4
  666. package/libc/include/generic-netbsd/sys/stat.h +5 -5
  667. package/libc/include/generic-netbsd/sys/stdalign.h +55 -0
  668. package/libc/include/generic-netbsd/sys/stdarg.h +2 -2
  669. package/libc/include/generic-netbsd/sys/stddef.h +156 -0
  670. package/libc/include/generic-netbsd/sys/swap.h +2 -2
  671. package/libc/include/generic-netbsd/sys/syncobj.h +9 -6
  672. package/libc/include/generic-netbsd/sys/syscall.h +29 -8
  673. package/libc/include/generic-netbsd/sys/syscallargs.h +89 -12
  674. package/libc/include/generic-netbsd/sys/sysctl.h +94 -86
  675. package/libc/include/generic-netbsd/sys/syslimits.h +8 -1
  676. package/libc/include/generic-netbsd/sys/syslog.h +6 -7
  677. package/libc/include/generic-netbsd/sys/time.h +10 -8
  678. package/libc/include/generic-netbsd/sys/tree.h +13 -13
  679. package/libc/include/generic-netbsd/sys/tty.h +2 -2
  680. package/libc/include/generic-netbsd/sys/ttycom.h +7 -1
  681. package/libc/include/generic-netbsd/sys/types.h +1 -1
  682. package/libc/include/generic-netbsd/sys/ucontext.h +46 -49
  683. package/libc/include/generic-netbsd/sys/un.h +12 -4
  684. package/libc/include/generic-netbsd/sys/unistd.h +103 -102
  685. package/libc/include/generic-netbsd/sys/unpcb.h +2 -2
  686. package/libc/include/generic-netbsd/sys/vmmeter.h +1 -39
  687. package/libc/include/generic-netbsd/sys/vnode_if.h +2 -2
  688. package/libc/include/generic-netbsd/sys/vnode_impl.h +6 -3
  689. package/libc/include/generic-netbsd/sys/wapbl_replay.h +2 -2
  690. package/libc/include/generic-netbsd/sys/wchan.h +37 -0
  691. package/libc/include/generic-netbsd/syslog.h +6 -7
  692. package/libc/include/generic-netbsd/time.h +44 -8
  693. package/libc/include/generic-netbsd/tzfile.h +11 -6
  694. package/libc/include/generic-netbsd/uchar.h +1 -1
  695. package/libc/include/generic-netbsd/ucontext.h +2 -1
  696. package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs.h +31 -16
  697. package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs_dir.h +1 -1
  698. package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs_extents.h +5 -5
  699. package/libc/include/generic-netbsd/ufs/ext2fs/ext2fs_extern.h +4 -4
  700. package/libc/include/generic-netbsd/ufs/ffs/ffs_extern.h +1 -1
  701. package/libc/include/generic-netbsd/ufs/ffs/fs.h +3 -3
  702. package/libc/include/generic-netbsd/ufs/ufs/quota2.h +2 -2
  703. package/libc/include/generic-netbsd/unistd.h +11 -5
  704. package/libc/include/generic-netbsd/unwind.h +1 -1
  705. package/libc/include/generic-netbsd/util.h +15 -1
  706. package/libc/include/generic-netbsd/uvm/uvm.h +1 -5
  707. package/libc/include/generic-netbsd/uvm/uvm_extern.h +3 -4
  708. package/libc/include/generic-netbsd/uvm/uvm_object.h +2 -2
  709. package/libc/include/generic-netbsd/uvm/uvm_param.h +1 -1
  710. package/libc/include/generic-netbsd/uvm/uvm_swap.h +14 -3
  711. package/libc/include/generic-netbsd/wchar.h +7 -2
  712. package/libc/include/generic-netbsd/x86/bootinfo.h +4 -1
  713. package/libc/include/generic-netbsd/x86/cpu.h +18 -1
  714. package/libc/include/generic-netbsd/x86/cpu_extended_state.h +3 -1
  715. package/libc/include/generic-netbsd/x86/cpuvar.h +4 -1
  716. package/libc/include/generic-netbsd/x86/float.h +24 -1
  717. package/libc/include/generic-netbsd/x86/ieee.h +11 -7
  718. package/libc/include/generic-netbsd/x86/lwp_private.h +56 -0
  719. package/libc/include/generic-netbsd/x86/mutex.h +1 -1
  720. package/libc/include/generic-netbsd/x86/specialreg.h +111 -23
  721. package/libc/include/generic-openbsd/db.h +1 -7
  722. package/libc/include/generic-openbsd/ddb/db_interface.h +2 -1
  723. package/libc/include/generic-openbsd/fnmatch.h +6 -2
  724. package/libc/include/generic-openbsd/login_cap.h +3 -1
  725. package/libc/include/generic-openbsd/miscfs/fuse/fusefs_node.h +2 -1
  726. package/libc/include/generic-openbsd/net/bpf.h +3 -1
  727. package/libc/include/generic-openbsd/net/hfsc.h +4 -4
  728. package/libc/include/generic-openbsd/net/if.h +5 -1
  729. package/libc/include/generic-openbsd/net/if_bridge.h +48 -1
  730. package/libc/include/generic-openbsd/net/if_etherbridge.h +20 -7
  731. package/libc/include/generic-openbsd/net/if_media.h +26 -1
  732. package/libc/include/generic-openbsd/net/if_pflow.h +71 -20
  733. package/libc/include/generic-openbsd/net/if_pfsync.h +2 -2
  734. package/libc/include/generic-openbsd/net/if_sppp.h +2 -1
  735. package/libc/include/generic-openbsd/net/if_trunk.h +3 -2
  736. package/libc/include/generic-openbsd/net/if_types.h +2 -2
  737. package/libc/include/generic-openbsd/net/if_var.h +34 -12
  738. package/libc/include/generic-openbsd/net/netisr.h +1 -3
  739. package/libc/include/generic-openbsd/net/pfvar.h +154 -1
  740. package/libc/include/generic-openbsd/net/pfvar_priv.h +256 -1
  741. package/libc/include/generic-openbsd/net80211/ieee80211.h +76 -4
  742. package/libc/include/generic-openbsd/net80211/ieee80211_ioctl.h +3 -2
  743. package/libc/include/generic-openbsd/net80211/ieee80211_node.h +48 -2
  744. package/libc/include/generic-openbsd/net80211/ieee80211_proto.h +4 -1
  745. package/libc/include/generic-openbsd/net80211/ieee80211_var.h +18 -2
  746. package/libc/include/generic-openbsd/netinet/if_ether.h +12 -11
  747. package/libc/include/generic-openbsd/netinet/igmp_var.h +17 -3
  748. package/libc/include/generic-openbsd/netinet/in_pcb.h +2 -1
  749. package/libc/include/generic-openbsd/netinet/in_var.h +17 -59
  750. package/libc/include/generic-openbsd/netinet/ip.h +3 -2
  751. package/libc/include/generic-openbsd/netinet/tcp_timer.h +1 -2
  752. package/libc/include/generic-openbsd/netinet6/in6_var.h +15 -29
  753. package/libc/include/generic-openbsd/netinet6/ip6_var.h +1 -2
  754. package/libc/include/generic-openbsd/netinet6/mld6_var.h +17 -4
  755. package/libc/include/generic-openbsd/netinet6/nd6.h +2 -2
  756. package/libc/include/generic-openbsd/pthread.h +2 -2
  757. package/libc/include/generic-openbsd/signal.h +2 -2
  758. package/libc/include/generic-openbsd/sndio.h +6 -12
  759. package/libc/include/generic-openbsd/strings.h +5 -1
  760. package/libc/include/generic-openbsd/sys/device.h +4 -3
  761. package/libc/include/generic-openbsd/sys/disklabel.h +17 -5
  762. package/libc/include/generic-openbsd/sys/dkio.h +3 -5
  763. package/libc/include/generic-openbsd/sys/filedesc.h +3 -2
  764. package/libc/include/generic-openbsd/sys/mbuf.h +1 -1
  765. package/libc/include/generic-openbsd/sys/mman.h +7 -2
  766. package/libc/include/generic-openbsd/sys/mutex.h +10 -7
  767. package/libc/include/generic-openbsd/sys/namei.h +8 -7
  768. package/libc/include/generic-openbsd/sys/param.h +1 -1
  769. package/libc/include/generic-openbsd/sys/pledge.h +1 -3
  770. package/libc/include/generic-openbsd/sys/protosw.h +8 -1
  771. package/libc/include/generic-openbsd/sys/ptrace.h +4 -1
  772. package/libc/include/generic-openbsd/sys/sched.h +8 -1
  773. package/libc/include/generic-openbsd/sys/signal.h +4 -2
  774. package/libc/include/generic-openbsd/sys/socketvar.h +2 -1
  775. package/libc/include/generic-openbsd/sys/sockio.h +11 -1
  776. package/libc/include/generic-openbsd/sys/syscall.h +5 -3
  777. package/libc/include/generic-openbsd/sys/syscallargs.h +9 -2
  778. package/libc/include/generic-openbsd/sys/sysctl.h +7 -4
  779. package/libc/include/generic-openbsd/sys/types.h +6 -2
  780. package/libc/include/generic-openbsd/sys/videoio.h +143 -68
  781. package/libc/include/generic-openbsd/sys/xcall.h +2 -2
  782. package/libc/include/generic-openbsd/time.h +2 -2
  783. package/libc/include/generic-openbsd/unistd.h +2 -2
  784. package/libc/include/generic-openbsd/uvm/uvm_anon.h +2 -3
  785. package/libc/include/generic-openbsd/uvm/uvm_extern.h +1 -19
  786. package/libc/include/generic-openbsd/uvm/uvm_pager.h +3 -4
  787. package/libc/include/generic-openbsd/uvm/uvm_pmemrange.h +1 -2
  788. package/libc/include/generic-openbsd/uvm/uvm_swap.h +4 -1
  789. package/libc/include/generic-openbsd/uvm/uvm_vnode.h +3 -4
  790. package/libc/include/generic-openbsd/uvm/uvmexp.h +41 -35
  791. package/libc/include/hexagon-linux-any/asm/unistd_32.h +1 -0
  792. package/libc/include/loongarch-linux-any/asm/hwcap.h +1 -0
  793. package/libc/include/loongarch-linux-any/asm/kvm.h +1 -0
  794. package/libc/include/loongarch-linux-any/asm/kvm_para.h +1 -0
  795. package/libc/include/loongarch-linux-any/asm/unistd_32.h +2 -0
  796. package/libc/include/loongarch-linux-any/asm/unistd_64.h +2 -0
  797. package/libc/include/m68k-linux-any/asm/unistd_32.h +1 -0
  798. package/libc/include/m68k-netbsd-none/m68k/asm.h +11 -2
  799. package/libc/include/m68k-netbsd-none/m68k/bus_dma.h +2 -2
  800. package/libc/include/m68k-netbsd-none/m68k/byte_swap.h +2 -2
  801. package/libc/include/m68k-netbsd-none/m68k/cacheops_30.h +2 -2
  802. package/libc/include/m68k-netbsd-none/m68k/cacheops_40.h +3 -1
  803. package/libc/include/m68k-netbsd-none/m68k/cacheops_60.h +5 -3
  804. package/libc/include/m68k-netbsd-none/m68k/cpu.h +86 -59
  805. package/libc/include/m68k-netbsd-none/m68k/cpuframe.h +5 -5
  806. package/libc/include/m68k-netbsd-none/m68k/fenv.h +6 -4
  807. package/libc/include/m68k-netbsd-none/m68k/float.h +26 -1
  808. package/libc/include/m68k-netbsd-none/m68k/frame.h +31 -19
  809. package/libc/include/m68k-netbsd-none/m68k/ieee.h +13 -8
  810. package/libc/include/m68k-netbsd-none/m68k/ieeefp.h +3 -3
  811. package/libc/include/m68k-netbsd-none/m68k/int_limits.h +2 -2
  812. package/libc/include/m68k-netbsd-none/m68k/intr.h +211 -0
  813. package/libc/include/m68k-netbsd-none/m68k/kcore.h +31 -31
  814. package/libc/include/m68k-netbsd-none/m68k/lwp_private.h +64 -0
  815. package/libc/include/m68k-netbsd-none/m68k/m68k.h +3 -7
  816. package/libc/include/m68k-netbsd-none/m68k/mcontext.h +5 -36
  817. package/libc/include/m68k-netbsd-none/m68k/mmu_30.h +105 -0
  818. package/libc/include/m68k-netbsd-none/m68k/mmu_40.h +232 -0
  819. package/libc/include/m68k-netbsd-none/m68k/mmu_51.h +273 -0
  820. package/libc/include/m68k-netbsd-none/m68k/mutex.h +1 -1
  821. package/libc/include/m68k-netbsd-none/m68k/pcb.h +2 -2
  822. package/libc/include/m68k-netbsd-none/m68k/pmap_motorola.h +32 -23
  823. package/libc/include/m68k-netbsd-none/m68k/psl.h +26 -7
  824. package/libc/include/m68k-netbsd-none/m68k/pte_motorola.h +37 -26
  825. package/libc/include/m68k-netbsd-none/m68k/trap.h +7 -7
  826. package/libc/include/m68k-netbsd-none/mac68k/cpu.h +1 -57
  827. package/libc/include/m68k-netbsd-none/mac68k/intr.h +3 -2
  828. package/libc/include/m68k-netbsd-none/mac68k/lwp_private.h +3 -0
  829. package/libc/include/m68k-netbsd-none/mac68k/pmap.h +20 -2
  830. package/libc/include/m68k-netbsd-none/mac68k/z8530var.h +2 -2
  831. package/libc/include/m68k-netbsd-none/machine/cpu.h +1 -57
  832. package/libc/include/m68k-netbsd-none/machine/intr.h +3 -2
  833. package/libc/include/m68k-netbsd-none/machine/lwp_private.h +3 -0
  834. package/libc/include/m68k-netbsd-none/machine/pmap.h +20 -2
  835. package/libc/include/m68k-netbsd-none/machine/z8530var.h +2 -2
  836. package/libc/include/mips-linux-any/asm/errno.h +2 -0
  837. package/libc/include/mips-linux-any/asm/unistd_n32.h +1 -0
  838. package/libc/include/mips-linux-any/asm/unistd_n64.h +1 -0
  839. package/libc/include/mips-linux-any/asm/unistd_o32.h +1 -0
  840. package/libc/include/mips-netbsd-eabi/machine/lwp_private.h +3 -0
  841. package/libc/include/mips64-openbsd-none/machine/octeonvar.h +1 -27
  842. package/libc/include/mips64-openbsd-none/octeon/octeonvar.h +1 -27
  843. package/libc/include/mips64el-openbsd-none/loongson/apmvar.h +1 -1
  844. package/libc/include/mips64el-openbsd-none/loongson/param.h +1 -5
  845. package/libc/include/mips64el-openbsd-none/machine/apmvar.h +1 -1
  846. package/libc/include/mips64el-openbsd-none/machine/param.h +1 -5
  847. package/libc/include/powerpc-linux-any/asm/unistd_32.h +1 -0
  848. package/libc/include/powerpc-linux-any/asm/unistd_64.h +1 -0
  849. package/libc/include/powerpc-linux-gnu/bits/struct_mutex.h +2 -2
  850. package/libc/include/powerpc-netbsd-eabi/evbppc/lwp_private.h +3 -0
  851. package/libc/include/powerpc-netbsd-eabi/float.h +3 -0
  852. package/libc/include/powerpc-netbsd-eabi/machine/ansi.h +3 -0
  853. package/libc/include/powerpc-netbsd-eabi/machine/aout_machdep.h +3 -0
  854. package/libc/include/powerpc-netbsd-eabi/machine/asm.h +3 -0
  855. package/libc/include/powerpc-netbsd-eabi/machine/cdefs.h +3 -0
  856. package/libc/include/powerpc-netbsd-eabi/machine/cpu.h +65 -0
  857. package/libc/include/powerpc-netbsd-eabi/machine/disklabel.h +69 -0
  858. package/libc/include/powerpc-netbsd-eabi/machine/elf_machdep.h +3 -0
  859. package/libc/include/powerpc-netbsd-eabi/machine/endian.h +3 -0
  860. package/libc/include/powerpc-netbsd-eabi/machine/fenv.h +3 -0
  861. package/libc/include/powerpc-netbsd-eabi/machine/float.h +3 -0
  862. package/libc/include/powerpc-netbsd-eabi/machine/frame.h +3 -0
  863. package/libc/include/powerpc-netbsd-eabi/machine/ieee.h +3 -0
  864. package/libc/include/powerpc-netbsd-eabi/machine/ieeefp.h +3 -0
  865. package/libc/include/powerpc-netbsd-eabi/machine/int_const.h +3 -0
  866. package/libc/include/powerpc-netbsd-eabi/machine/int_fmtio.h +3 -0
  867. package/libc/include/powerpc-netbsd-eabi/machine/int_limits.h +3 -0
  868. package/libc/include/powerpc-netbsd-eabi/machine/int_mwgwtypes.h +3 -0
  869. package/libc/include/powerpc-netbsd-eabi/machine/int_types.h +3 -0
  870. package/libc/include/powerpc-netbsd-eabi/machine/kcore.h +3 -0
  871. package/libc/include/powerpc-netbsd-eabi/machine/limits.h +3 -0
  872. package/libc/include/powerpc-netbsd-eabi/machine/lock.h +3 -0
  873. package/libc/include/powerpc-netbsd-eabi/machine/lwp_private.h +3 -0
  874. package/libc/include/powerpc-netbsd-eabi/machine/math.h +3 -0
  875. package/libc/include/powerpc-netbsd-eabi/machine/mcontext.h +3 -0
  876. package/libc/include/powerpc-netbsd-eabi/machine/mutex.h +3 -0
  877. package/libc/include/powerpc-netbsd-eabi/machine/param.h +43 -0
  878. package/libc/include/powerpc-netbsd-eabi/machine/pcb.h +3 -0
  879. package/libc/include/powerpc-netbsd-eabi/machine/pmap.h +3 -0
  880. package/libc/include/powerpc-netbsd-eabi/machine/proc.h +3 -0
  881. package/libc/include/powerpc-netbsd-eabi/machine/profile.h +3 -0
  882. package/libc/include/powerpc-netbsd-eabi/machine/psl.h +3 -0
  883. package/libc/include/powerpc-netbsd-eabi/machine/pte.h +3 -0
  884. package/libc/include/powerpc-netbsd-eabi/machine/ptrace.h +3 -0
  885. package/libc/include/powerpc-netbsd-eabi/machine/reg.h +3 -0
  886. package/libc/include/powerpc-netbsd-eabi/machine/reloc.h +3 -0
  887. package/libc/include/powerpc-netbsd-eabi/machine/setjmp.h +3 -0
  888. package/libc/include/powerpc-netbsd-eabi/machine/signal.h +3 -0
  889. package/libc/include/{mips-netbsd-eabi → powerpc-netbsd-eabi}/machine/sljit_machdep.h +1 -1
  890. package/libc/include/powerpc-netbsd-eabi/machine/trap.h +3 -0
  891. package/libc/include/powerpc-netbsd-eabi/machine/types.h +11 -0
  892. package/libc/include/powerpc-netbsd-eabi/machine/vmparam.h +3 -0
  893. package/libc/include/powerpc-netbsd-eabi/machine/wchar_limits.h +3 -0
  894. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/asm.h +12 -2
  895. package/libc/include/powerpc-netbsd-eabi/powerpc/bswap.h +14 -0
  896. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/cpu.h +3 -3
  897. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/fenv.h +2 -1
  898. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/pmap.h +3 -3
  899. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ieee.h +7 -2
  900. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/limits.h +4 -13
  901. package/libc/include/powerpc-netbsd-eabi/powerpc/lwp_private.h +79 -0
  902. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/mcontext.h +6 -50
  903. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/mutex.h +1 -1
  904. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/hid.h +2 -2
  905. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/pmap.h +2 -2
  906. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/pmap.h +1 -1
  907. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/psl.h +2 -2
  908. package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/vmparam.h +1 -1
  909. package/libc/include/powerpc-openbsd-eabihf/powerpc/intr.h +1 -4
  910. package/libc/include/powerpc64-openbsd-none/machine/atomic.h +3 -3
  911. package/libc/include/powerpc64-openbsd-none/powerpc64/atomic.h +3 -3
  912. package/libc/include/riscv-linux-any/asm/hwprobe.h +4 -0
  913. package/libc/include/riscv-linux-any/asm/kvm.h +3 -0
  914. package/libc/include/riscv-linux-any/asm/ptrace.h +37 -0
  915. package/libc/include/riscv-linux-any/asm/sigcontext.h +1 -0
  916. package/libc/include/riscv-linux-any/asm/unistd_32.h +1 -0
  917. package/libc/include/riscv-linux-any/asm/unistd_64.h +1 -0
  918. package/libc/include/riscv32-netbsd-none/machine/bswap.h +11 -0
  919. package/libc/include/riscv32-netbsd-none/machine/endian_machdep.h +3 -0
  920. package/libc/include/riscv32-netbsd-none/machine/rwlock.h +1 -0
  921. package/libc/include/riscv32-netbsd-none/machine/wchar_limits.h +4 -0
  922. package/libc/include/riscv64-netbsd-none/machine/bswap.h +11 -0
  923. package/libc/include/riscv64-netbsd-none/machine/endian_machdep.h +3 -0
  924. package/libc/include/riscv64-netbsd-none/machine/rwlock.h +1 -0
  925. package/libc/include/riscv64-netbsd-none/machine/wchar_limits.h +4 -0
  926. package/libc/include/riscv64-openbsd-none/machine/cpu.h +4 -8
  927. package/libc/include/riscv64-openbsd-none/machine/cpufunc.h +4 -4
  928. package/libc/include/riscv64-openbsd-none/machine/pmap.h +5 -1
  929. package/libc/include/riscv64-openbsd-none/machine/pte.h +9 -1
  930. package/libc/include/riscv64-openbsd-none/riscv64/cpu.h +4 -8
  931. package/libc/include/riscv64-openbsd-none/riscv64/cpufunc.h +4 -4
  932. package/libc/include/riscv64-openbsd-none/riscv64/pmap.h +5 -1
  933. package/libc/include/riscv64-openbsd-none/riscv64/pte.h +9 -1
  934. package/libc/include/s390x-linux-any/asm/unistd_64.h +1 -0
  935. package/libc/include/s390x-linux-gnu/bits/fenv.h +2 -2
  936. package/libc/include/s390x-linux-gnu/bits/struct_mutex.h +2 -2
  937. package/libc/include/sparc-linux-any/asm/errno.h +2 -0
  938. package/libc/include/sparc-linux-any/asm/ioctls.h +4 -4
  939. package/libc/include/sparc-linux-any/asm/unistd_32.h +2 -0
  940. package/libc/include/sparc-linux-any/asm/unistd_64.h +2 -0
  941. package/libc/include/sparc-netbsd-none/float.h +3 -1
  942. package/libc/include/sparc-netbsd-none/machine/asm.h +10 -1
  943. package/libc/include/sparc-netbsd-none/machine/cgtworeg.h +2 -2
  944. package/libc/include/sparc-netbsd-none/machine/cpu.h +1 -1
  945. package/libc/include/sparc-netbsd-none/machine/float.h +3 -1
  946. package/libc/include/sparc-netbsd-none/machine/limits.h +4 -6
  947. package/libc/include/sparc-netbsd-none/machine/lwp_private.h +51 -0
  948. package/libc/include/sparc-netbsd-none/machine/mcontext.h +4 -22
  949. package/libc/include/sparc-netbsd-none/machine/mutex.h +1 -1
  950. package/libc/include/sparc-netbsd-none/machine/param.h +4 -2
  951. package/libc/include/sparc-netbsd-none/machine/pmap.h +2 -2
  952. package/libc/include/sparc-netbsd-none/machine/psl.h +6 -3
  953. package/libc/include/sparc-netbsd-none/machine/sxreg.h +5 -1
  954. package/libc/include/sparc-netbsd-none/machine/types.h +2 -2
  955. package/libc/include/sparc-netbsd-none/sparc/sxreg.h +5 -1
  956. package/libc/include/sparc64-netbsd-none/machine/cpu.h +2 -2
  957. package/libc/include/sparc64-netbsd-none/machine/ctlreg.h +8 -7
  958. package/libc/include/sparc64-netbsd-none/machine/intr.h +1 -1
  959. package/libc/include/sparc64-netbsd-none/machine/lwp_private.h +3 -0
  960. package/libc/include/sparc64-netbsd-none/machine/mcontext.h +4 -4
  961. package/libc/include/sparc64-netbsd-none/machine/mutex.h +1 -1
  962. package/libc/include/sparc64-netbsd-none/machine/param.h +8 -2
  963. package/libc/include/sparc64-netbsd-none/machine/psl.h +7 -2
  964. package/libc/include/sparc64-netbsd-none/machine/pte.h +2 -2
  965. package/libc/include/sparc64-netbsd-none/machine/vmparam.h +1 -1
  966. package/libc/include/x86-linux-any/asm/auxvec.h +0 -4
  967. package/libc/include/x86-linux-any/asm/kvm.h +13 -8
  968. package/libc/include/x86-linux-any/asm/svm.h +16 -16
  969. package/libc/include/x86-linux-any/asm/unistd_32.h +1 -0
  970. package/libc/include/x86-linux-any/asm/unistd_64.h +1 -0
  971. package/libc/include/x86-linux-any/asm/unistd_x32.h +1 -0
  972. package/libc/include/x86-linux-gnu/bits/struct_mutex.h +2 -2
  973. package/libc/include/x86-netbsd-none/machine/asm.h +12 -4
  974. package/libc/include/x86-netbsd-none/machine/byte_swap.h +2 -2
  975. package/libc/include/x86-netbsd-none/machine/cpu.h +15 -4
  976. package/libc/include/x86-netbsd-none/machine/elf_machdep.h +2 -1
  977. package/libc/include/x86-netbsd-none/machine/lwp_private.h +3 -0
  978. package/libc/include/x86-netbsd-none/machine/mcontext.h +6 -24
  979. package/libc/include/x86-netbsd-none/machine/param.h +9 -1
  980. package/libc/include/x86-netbsd-none/machine/pcb.h +6 -2
  981. package/libc/include/x86-netbsd-none/machine/ptrace.h +2 -2
  982. package/libc/include/x86-netbsd-none/machine/types.h +2 -1
  983. package/libc/include/x86-openbsd-none/i386/specialreg.h +3 -1
  984. package/libc/include/x86-openbsd-none/machine/specialreg.h +3 -1
  985. package/libc/include/x86_64-netbsd-none/amd64/asm.h +11 -3
  986. package/libc/include/x86_64-netbsd-none/amd64/byte_swap.h +2 -2
  987. package/libc/include/x86_64-netbsd-none/amd64/cpu.h +13 -3
  988. package/libc/include/x86_64-netbsd-none/amd64/frame.h +2 -2
  989. package/libc/include/x86_64-netbsd-none/amd64/lwp_private.h +3 -0
  990. package/libc/include/x86_64-netbsd-none/amd64/mcontext.h +5 -23
  991. package/libc/include/x86_64-netbsd-none/amd64/param.h +23 -4
  992. package/libc/include/x86_64-netbsd-none/amd64/pcb.h +14 -3
  993. package/libc/include/x86_64-netbsd-none/amd64/ptrace.h +2 -2
  994. package/libc/include/x86_64-netbsd-none/amd64/types.h +2 -1
  995. package/libc/include/x86_64-netbsd-none/machine/asm.h +11 -3
  996. package/libc/include/x86_64-netbsd-none/machine/byte_swap.h +2 -2
  997. package/libc/include/x86_64-netbsd-none/machine/cpu.h +13 -3
  998. package/libc/include/x86_64-netbsd-none/machine/frame.h +2 -2
  999. package/libc/include/x86_64-netbsd-none/machine/lwp_private.h +3 -0
  1000. package/libc/include/x86_64-netbsd-none/machine/mcontext.h +5 -23
  1001. package/libc/include/x86_64-netbsd-none/machine/param.h +23 -4
  1002. package/libc/include/x86_64-netbsd-none/machine/pcb.h +14 -3
  1003. package/libc/include/x86_64-netbsd-none/machine/ptrace.h +2 -2
  1004. package/libc/include/x86_64-netbsd-none/machine/types.h +2 -1
  1005. package/libc/include/x86_64-openbsd-none/amd64/conf.h +11 -2
  1006. package/libc/include/x86_64-openbsd-none/amd64/cpu.h +14 -4
  1007. package/libc/include/x86_64-openbsd-none/amd64/cpufunc.h +2 -3
  1008. package/libc/include/x86_64-openbsd-none/amd64/ghcb.h +2 -1
  1009. package/libc/include/x86_64-openbsd-none/amd64/i82489var.h +2 -4
  1010. package/libc/include/x86_64-openbsd-none/amd64/i8259.h +1 -53
  1011. package/libc/include/x86_64-openbsd-none/amd64/intr.h +5 -2
  1012. package/libc/include/x86_64-openbsd-none/amd64/intrdefs.h +9 -7
  1013. package/libc/include/x86_64-openbsd-none/amd64/kexec.h +48 -0
  1014. package/libc/include/x86_64-openbsd-none/amd64/specialreg.h +4 -1
  1015. package/libc/include/x86_64-openbsd-none/machine/conf.h +11 -2
  1016. package/libc/include/x86_64-openbsd-none/machine/cpu.h +14 -4
  1017. package/libc/include/x86_64-openbsd-none/machine/cpufunc.h +2 -3
  1018. package/libc/include/x86_64-openbsd-none/machine/ghcb.h +2 -1
  1019. package/libc/include/x86_64-openbsd-none/machine/i82489var.h +2 -4
  1020. package/libc/include/x86_64-openbsd-none/machine/i8259.h +1 -53
  1021. package/libc/include/x86_64-openbsd-none/machine/intr.h +5 -2
  1022. package/libc/include/x86_64-openbsd-none/machine/intrdefs.h +9 -7
  1023. package/libc/include/x86_64-openbsd-none/machine/kexec.h +48 -0
  1024. package/libc/include/x86_64-openbsd-none/machine/specialreg.h +4 -1
  1025. package/libc/include/xtensa-linux-any/asm/unistd_32.h +1 -0
  1026. package/libc/netbsd/abilists +0 -0
  1027. package/libc/netbsd/lib/csu/arch/riscv/crt0.S +62 -0
  1028. package/libc/netbsd/lib/csu/common/crt0-common.c +32 -7
  1029. package/libc/netbsd/lib/csu/common/csu-common.h +2 -0
  1030. package/libc/openbsd/abilists +0 -0
  1031. package/libcxx/include/__algorithm/all_of.h +11 -5
  1032. package/libcxx/include/__algorithm/comp.h +4 -0
  1033. package/libcxx/include/__algorithm/copy.h +28 -147
  1034. package/libcxx/include/__algorithm/copy_backward.h +9 -24
  1035. package/libcxx/include/__algorithm/copy_n.h +50 -16
  1036. package/libcxx/include/__algorithm/count.h +2 -2
  1037. package/libcxx/include/__algorithm/equal.h +43 -55
  1038. package/libcxx/include/__algorithm/fill.h +26 -8
  1039. package/libcxx/include/__algorithm/fill_n.h +32 -46
  1040. package/libcxx/include/__algorithm/find.h +96 -39
  1041. package/libcxx/include/__algorithm/find_end.h +105 -0
  1042. package/libcxx/include/__algorithm/for_each.h +18 -24
  1043. package/libcxx/include/__algorithm/for_each_n.h +20 -47
  1044. package/libcxx/include/__algorithm/for_each_n_segment.h +1 -1
  1045. package/libcxx/include/__algorithm/for_each_segment.h +26 -0
  1046. package/libcxx/include/__algorithm/generate.h +4 -2
  1047. package/libcxx/include/__algorithm/generate_n.h +19 -6
  1048. package/libcxx/include/__algorithm/is_permutation.h +4 -4
  1049. package/libcxx/include/__algorithm/iterator_operations.h +3 -0
  1050. package/libcxx/include/__algorithm/lexicographical_compare.h +2 -2
  1051. package/libcxx/include/__algorithm/lexicographical_compare_three_way.h +6 -6
  1052. package/libcxx/include/__algorithm/make_heap.h +16 -4
  1053. package/libcxx/include/__algorithm/mismatch.h +2 -2
  1054. package/libcxx/include/__algorithm/move.h +8 -19
  1055. package/libcxx/include/__algorithm/move_backward.h +9 -24
  1056. package/libcxx/include/__algorithm/none_of.h +4 -4
  1057. package/libcxx/include/__algorithm/partial_sort.h +1 -1
  1058. package/libcxx/include/__algorithm/partial_sort_copy.h +1 -1
  1059. package/libcxx/include/__algorithm/pstl.h +9 -9
  1060. package/libcxx/include/__algorithm/radix_sort.h +27 -25
  1061. package/libcxx/include/__algorithm/ranges_copy_n.h +3 -26
  1062. package/libcxx/include/__algorithm/ranges_equal.h +17 -26
  1063. package/libcxx/include/__algorithm/ranges_fill.h +7 -6
  1064. package/libcxx/include/__algorithm/ranges_for_each.h +9 -1
  1065. package/libcxx/include/__algorithm/ranges_generate_n.h +2 -6
  1066. package/libcxx/include/__algorithm/ranges_search_n.h +2 -2
  1067. package/libcxx/include/__algorithm/rotate.h +27 -44
  1068. package/libcxx/include/__algorithm/search_n.h +49 -37
  1069. package/libcxx/include/__algorithm/sift_down.h +19 -18
  1070. package/libcxx/include/__algorithm/simd_utils.h +33 -4
  1071. package/libcxx/include/__algorithm/specialized_algorithms.h +54 -0
  1072. package/libcxx/include/__algorithm/stable_sort.h +1 -1
  1073. package/libcxx/include/__assertion_handler +31 -4
  1074. package/libcxx/include/__atomic/atomic.h +36 -60
  1075. package/libcxx/include/__atomic/atomic_flag.h +19 -37
  1076. package/libcxx/include/__atomic/atomic_ref.h +29 -12
  1077. package/libcxx/include/__atomic/atomic_sync.h +127 -55
  1078. package/libcxx/include/__atomic/atomic_sync_timed.h +144 -0
  1079. package/libcxx/include/__atomic/atomic_waitable_traits.h +103 -0
  1080. package/libcxx/include/__atomic/contention_t.h +27 -3
  1081. package/libcxx/include/__atomic/floating_point_helper.h +55 -0
  1082. package/libcxx/include/__bit/countl.h +1 -2
  1083. package/libcxx/include/__bit/countr.h +1 -2
  1084. package/libcxx/include/__bit/has_single_bit.h +1 -1
  1085. package/libcxx/include/__bit/popcount.h +0 -1
  1086. package/libcxx/include/__bit/rotate.h +15 -26
  1087. package/libcxx/include/__bit_reference +207 -18
  1088. package/libcxx/include/__charconv/from_chars_integral.h +1 -1
  1089. package/libcxx/include/__charconv/from_chars_result.h +1 -1
  1090. package/libcxx/include/__charconv/to_chars_integral.h +1 -0
  1091. package/libcxx/include/__charconv/to_chars_result.h +1 -1
  1092. package/libcxx/include/__charconv/traits.h +3 -24
  1093. package/libcxx/include/__chrono/day.h +11 -0
  1094. package/libcxx/include/__chrono/duration.h +58 -33
  1095. package/libcxx/include/__chrono/file_clock.h +4 -2
  1096. package/libcxx/include/__chrono/is_clock.h +72 -0
  1097. package/libcxx/include/__chrono/leap_second.h +13 -0
  1098. package/libcxx/include/__chrono/month.h +13 -0
  1099. package/libcxx/include/__chrono/month_weekday.h +22 -0
  1100. package/libcxx/include/__chrono/monthday.h +20 -0
  1101. package/libcxx/include/__chrono/steady_clock.h +1 -1
  1102. package/libcxx/include/__chrono/system_clock.h +3 -3
  1103. package/libcxx/include/__chrono/time_point.h +37 -13
  1104. package/libcxx/include/__chrono/weekday.h +25 -0
  1105. package/libcxx/include/__chrono/year.h +11 -0
  1106. package/libcxx/include/__chrono/year_month.h +13 -0
  1107. package/libcxx/include/__chrono/year_month_day.h +23 -0
  1108. package/libcxx/include/__chrono/year_month_weekday.h +26 -0
  1109. package/libcxx/include/__chrono/zoned_time.h +16 -0
  1110. package/libcxx/include/__compare/is_eq.h +6 -6
  1111. package/libcxx/include/__compare/strong_order.h +12 -30
  1112. package/libcxx/include/__compare/three_way_comparable.h +2 -2
  1113. package/libcxx/include/__concepts/comparison_common_type.h +40 -0
  1114. package/libcxx/include/__concepts/equality_comparable.h +2 -1
  1115. package/libcxx/include/__condition_variable/condition_variable.h +1 -1
  1116. package/libcxx/include/__config +63 -280
  1117. package/libcxx/include/__configuration/abi.h +14 -24
  1118. package/libcxx/include/__configuration/availability.h +65 -118
  1119. package/libcxx/include/__configuration/compiler.h +6 -6
  1120. package/libcxx/include/__configuration/experimental.h +38 -0
  1121. package/libcxx/include/__configuration/hardening.h +215 -0
  1122. package/libcxx/include/__configuration/language.h +3 -0
  1123. package/libcxx/include/__configuration/platform.h +9 -16
  1124. package/libcxx/include/__coroutine/coroutine_handle.h +9 -9
  1125. package/libcxx/include/__coroutine/noop_coroutine_handle.h +11 -13
  1126. package/libcxx/include/__debug_utils/strict_weak_ordering_check.h +1 -1
  1127. package/libcxx/include/__exception/exception.h +6 -4
  1128. package/libcxx/include/__exception/exception_ptr.h +27 -5
  1129. package/libcxx/include/__exception/nested_exception.h +2 -2
  1130. package/libcxx/include/__exception/operations.h +5 -5
  1131. package/libcxx/include/__expected/bad_expected_access.h +8 -6
  1132. package/libcxx/include/__expected/expected.h +62 -64
  1133. package/libcxx/include/__expected/unexpected.h +4 -4
  1134. package/libcxx/include/__filesystem/copy_options.h +4 -4
  1135. package/libcxx/include/__filesystem/directory_entry.h +37 -33
  1136. package/libcxx/include/__filesystem/directory_iterator.h +9 -11
  1137. package/libcxx/include/__filesystem/directory_options.h +7 -4
  1138. package/libcxx/include/__filesystem/file_status.h +3 -3
  1139. package/libcxx/include/__filesystem/filesystem_error.h +9 -10
  1140. package/libcxx/include/__filesystem/operations.h +97 -66
  1141. package/libcxx/include/__filesystem/path.h +68 -64
  1142. package/libcxx/include/__filesystem/path_iterator.h +1 -3
  1143. package/libcxx/include/__filesystem/perm_options.h +4 -4
  1144. package/libcxx/include/__filesystem/perms.h +4 -4
  1145. package/libcxx/include/__filesystem/recursive_directory_iterator.h +9 -14
  1146. package/libcxx/include/__filesystem/space_info.h +1 -1
  1147. package/libcxx/include/__filesystem/u8path.h +12 -14
  1148. package/libcxx/include/__flat_map/flat_map.h +88 -71
  1149. package/libcxx/include/__flat_map/flat_multimap.h +251 -172
  1150. package/libcxx/include/__flat_map/key_value_iterator.h +0 -1
  1151. package/libcxx/include/__flat_map/utils.h +1 -0
  1152. package/libcxx/include/__flat_set/flat_multiset.h +211 -143
  1153. package/libcxx/include/__flat_set/flat_set.h +86 -68
  1154. package/libcxx/include/__format/concepts.h +0 -14
  1155. package/libcxx/include/__format/extended_grapheme_cluster_table.h +3 -2
  1156. package/libcxx/include/__format/fmt_pair_like.h +42 -0
  1157. package/libcxx/include/__format/format_arg.h +7 -10
  1158. package/libcxx/include/__format/format_args.h +1 -1
  1159. package/libcxx/include/__format/format_context.h +5 -5
  1160. package/libcxx/include/__format/format_parse_context.h +2 -2
  1161. package/libcxx/include/__format/formatter_output.h +30 -34
  1162. package/libcxx/include/__format/indic_conjunct_break_table.h +3 -2
  1163. package/libcxx/include/__format/range_default_formatter.h +2 -41
  1164. package/libcxx/include/__format/range_format.h +71 -0
  1165. package/libcxx/include/__format/range_formatter.h +1 -0
  1166. package/libcxx/include/__format/width_estimation_table.h +4 -2
  1167. package/libcxx/include/__functional/bind.h +10 -15
  1168. package/libcxx/include/__functional/bind_back.h +1 -1
  1169. package/libcxx/include/__functional/bind_front.h +1 -1
  1170. package/libcxx/include/__functional/function.h +57 -75
  1171. package/libcxx/include/__functional/hash.h +1 -10
  1172. package/libcxx/include/__functional/identity.h +1 -1
  1173. package/libcxx/include/__functional/is_transparent.h +8 -0
  1174. package/libcxx/include/__functional/mem_fn.h +2 -1
  1175. package/libcxx/include/__functional/operations.h +18 -0
  1176. package/libcxx/include/__functional/ranges_operations.h +7 -0
  1177. package/libcxx/include/__functional/reference_wrapper.h +7 -5
  1178. package/libcxx/include/__functional/weak_result_type.h +14 -28
  1179. package/libcxx/include/__fwd/ios.h +1 -1
  1180. package/libcxx/include/__fwd/tuple.h +14 -0
  1181. package/libcxx/include/__hash_table +371 -357
  1182. package/libcxx/include/__ios/fpos.h +4 -4
  1183. package/libcxx/include/__iterator/back_insert_iterator.h +1 -7
  1184. package/libcxx/include/__iterator/bounded_iter.h +7 -8
  1185. package/libcxx/include/__iterator/concepts.h +6 -9
  1186. package/libcxx/include/__iterator/cpp17_iterator_concepts.h +13 -12
  1187. package/libcxx/include/__iterator/distance.h +40 -18
  1188. package/libcxx/include/__iterator/front_insert_iterator.h +1 -7
  1189. package/libcxx/include/__iterator/insert_iterator.h +1 -7
  1190. package/libcxx/include/__iterator/istream_iterator.h +6 -7
  1191. package/libcxx/include/__iterator/istreambuf_iterator.h +6 -7
  1192. package/libcxx/include/__iterator/iter_move.h +1 -1
  1193. package/libcxx/include/__iterator/iterator.h +13 -0
  1194. package/libcxx/include/__iterator/iterator_traits.h +13 -14
  1195. package/libcxx/include/__iterator/ostream_iterator.h +1 -7
  1196. package/libcxx/include/__iterator/ostreambuf_iterator.h +1 -7
  1197. package/libcxx/include/__iterator/reverse_iterator.h +8 -13
  1198. package/libcxx/include/__iterator/segmented_iterator.h +3 -8
  1199. package/libcxx/include/__iterator/static_bounded_iter.h +3 -3
  1200. package/libcxx/include/__iterator/wrap_iter.h +8 -6
  1201. package/libcxx/include/__locale +3 -10
  1202. package/libcxx/include/__locale_dir/locale_base_api/bsd_locale_fallbacks.h +0 -10
  1203. package/libcxx/include/__locale_dir/locale_base_api.h +5 -28
  1204. package/libcxx/include/__locale_dir/messages.h +1 -1
  1205. package/libcxx/include/__locale_dir/money.h +2 -2
  1206. package/libcxx/include/__locale_dir/num.h +190 -243
  1207. package/libcxx/include/__locale_dir/pad_and_output.h +5 -6
  1208. package/libcxx/include/__locale_dir/support/bsd_like.h +0 -20
  1209. package/libcxx/include/__locale_dir/support/fuchsia.h +0 -7
  1210. package/libcxx/include/__locale_dir/support/linux.h +0 -37
  1211. package/libcxx/include/__locale_dir/support/netbsd.h +0 -2
  1212. package/libcxx/include/__locale_dir/support/newlib.h +243 -0
  1213. package/libcxx/include/__locale_dir/support/no_locale/characters.h +0 -4
  1214. package/libcxx/include/__locale_dir/support/no_locale/strtonum.h +0 -9
  1215. package/libcxx/include/__locale_dir/support/windows.h +0 -29
  1216. package/libcxx/include/__locale_dir/time.h +3 -7
  1217. package/libcxx/include/__math/hypot.h +1 -1
  1218. package/libcxx/include/__math/logarithms.h +1 -1
  1219. package/libcxx/include/__math/traits.h +80 -11
  1220. package/libcxx/include/__mdspan/extents.h +7 -4
  1221. package/libcxx/include/__mdspan/layout_stride.h +4 -5
  1222. package/libcxx/include/__mdspan/mdspan.h +29 -23
  1223. package/libcxx/include/__memory/addressof.h +7 -5
  1224. package/libcxx/include/__memory/align.h +18 -1
  1225. package/libcxx/include/__memory/allocate_at_least.h +15 -10
  1226. package/libcxx/include/__memory/allocator.h +14 -26
  1227. package/libcxx/include/__memory/allocator_traits.h +6 -4
  1228. package/libcxx/include/__memory/compressed_pair.h +15 -9
  1229. package/libcxx/include/__memory/construct_at.h +12 -23
  1230. package/libcxx/include/__memory/inout_ptr.h +1 -1
  1231. package/libcxx/include/__memory/is_sufficiently_aligned.h +1 -1
  1232. package/libcxx/include/__memory/out_ptr.h +1 -1
  1233. package/libcxx/include/__memory/pointer_traits.h +1 -1
  1234. package/libcxx/include/__memory/raw_storage_iterator.h +3 -9
  1235. package/libcxx/include/__memory/shared_count.h +9 -30
  1236. package/libcxx/include/__memory/shared_ptr.h +100 -145
  1237. package/libcxx/include/__memory/temp_value.h +1 -2
  1238. package/libcxx/include/__memory/uninitialized_algorithms.h +44 -115
  1239. package/libcxx/include/__memory/unique_ptr.h +14 -16
  1240. package/libcxx/include/__memory/uses_allocator_construction.h +1 -0
  1241. package/libcxx/include/__memory_resource/memory_resource.h +4 -2
  1242. package/libcxx/include/__memory_resource/monotonic_buffer_resource.h +1 -1
  1243. package/libcxx/include/__memory_resource/polymorphic_allocator.h +13 -8
  1244. package/libcxx/include/__memory_resource/pool_options.h +1 -1
  1245. package/libcxx/include/__memory_resource/synchronized_pool_resource.h +4 -2
  1246. package/libcxx/include/__memory_resource/unsynchronized_pool_resource.h +1 -1
  1247. package/libcxx/include/__mutex/mutex.h +2 -2
  1248. package/libcxx/include/__mutex/once_flag.h +14 -11
  1249. package/libcxx/include/__mutex/tag_types.h +3 -3
  1250. package/libcxx/include/__mutex/unique_lock.h +8 -7
  1251. package/libcxx/include/__new/align_val_t.h +6 -0
  1252. package/libcxx/include/__new/allocate.h +1 -2
  1253. package/libcxx/include/__new/exceptions.h +8 -2
  1254. package/libcxx/include/__new/global_new_delete.h +4 -11
  1255. package/libcxx/include/__new/interference_size.h +0 -4
  1256. package/libcxx/include/__new/launder.h +3 -5
  1257. package/libcxx/include/__new/nothrow_t.h +1 -1
  1258. package/libcxx/include/__numeric/gcd_lcm.h +24 -34
  1259. package/libcxx/include/__numeric/midpoint.h +9 -14
  1260. package/libcxx/include/__numeric/pstl.h +2 -2
  1261. package/libcxx/include/__numeric/saturation_arithmetic.h +13 -5
  1262. package/libcxx/include/__ostream/basic_ostream.h +8 -8
  1263. package/libcxx/include/__pstl/backends/default.h +14 -14
  1264. package/libcxx/include/__pstl/backends/libdispatch.h +2 -2
  1265. package/libcxx/include/__pstl/cpu_algos/find_if.h +1 -1
  1266. package/libcxx/include/__pstl/cpu_algos/transform.h +5 -6
  1267. package/libcxx/include/__pstl/cpu_algos/transform_reduce.h +5 -4
  1268. package/libcxx/include/__random/binomial_distribution.h +10 -4
  1269. package/libcxx/include/__random/mersenne_twister_engine.h +50 -154
  1270. package/libcxx/include/__random/piecewise_constant_distribution.h +3 -2
  1271. package/libcxx/include/__random/piecewise_linear_distribution.h +3 -2
  1272. package/libcxx/include/__ranges/adjacent_transform_view.h +406 -0
  1273. package/libcxx/include/__ranges/adjacent_view.h +419 -0
  1274. package/libcxx/include/__ranges/as_rvalue_view.h +9 -9
  1275. package/libcxx/include/__ranges/chunk_by_view.h +6 -6
  1276. package/libcxx/include/__ranges/common_view.h +7 -7
  1277. package/libcxx/include/__ranges/drop_view.h +8 -8
  1278. package/libcxx/include/__ranges/drop_while_view.h +5 -5
  1279. package/libcxx/include/__ranges/elements_of.h +49 -0
  1280. package/libcxx/include/__ranges/empty_view.h +5 -5
  1281. package/libcxx/include/__ranges/filter_view.h +10 -10
  1282. package/libcxx/include/__ranges/iota_view.h +41 -22
  1283. package/libcxx/include/__ranges/owning_view.h +15 -15
  1284. package/libcxx/include/__ranges/ref_view.h +6 -6
  1285. package/libcxx/include/__ranges/repeat_view.h +17 -10
  1286. package/libcxx/include/__ranges/single_view.h +8 -8
  1287. package/libcxx/include/__ranges/take_view.h +9 -9
  1288. package/libcxx/include/__ranges/transform_view.h +1 -2
  1289. package/libcxx/include/__ranges/view_interface.h +10 -10
  1290. package/libcxx/include/__ranges/zip_transform_view.h +357 -0
  1291. package/libcxx/include/__ranges/zip_view.h +20 -20
  1292. package/libcxx/include/__split_buffer +612 -240
  1293. package/libcxx/include/__stop_token/atomic_unique_lock.h +1 -1
  1294. package/libcxx/include/__stop_token/stop_callback.h +2 -2
  1295. package/libcxx/include/__stop_token/stop_source.h +1 -1
  1296. package/libcxx/include/__stop_token/stop_state.h +4 -4
  1297. package/libcxx/include/__stop_token/stop_token.h +1 -1
  1298. package/libcxx/include/__string/char_traits.h +51 -31
  1299. package/libcxx/include/__string/constexpr_c_functions.h +5 -5
  1300. package/libcxx/include/__support/xlocale/__strtonum_fallback.h +0 -8
  1301. package/libcxx/include/__system_error/error_category.h +8 -8
  1302. package/libcxx/include/__system_error/error_code.h +5 -5
  1303. package/libcxx/include/__system_error/error_condition.h +4 -4
  1304. package/libcxx/include/__system_error/system_error.h +1 -1
  1305. package/libcxx/include/__thread/id.h +1 -1
  1306. package/libcxx/include/__thread/jthread.h +1 -1
  1307. package/libcxx/include/__thread/poll_with_backoff.h +27 -8
  1308. package/libcxx/include/__thread/support/c11.h +8 -8
  1309. package/libcxx/include/__thread/support/pthread.h +8 -8
  1310. package/libcxx/include/__thread/support/windows.h +8 -8
  1311. package/libcxx/include/__thread/thread.h +13 -8
  1312. package/libcxx/include/__thread/timed_backoff_policy.h +3 -2
  1313. package/libcxx/include/__tree +849 -701
  1314. package/libcxx/include/__tuple/sfinae_helpers.h +1 -44
  1315. package/libcxx/include/__tuple/tuple_element.h +0 -12
  1316. package/libcxx/include/__tuple/tuple_size.h +0 -4
  1317. package/libcxx/include/__tuple/tuple_transform.h +45 -0
  1318. package/libcxx/include/__type_traits/aligned_storage.h +13 -40
  1319. package/libcxx/include/__type_traits/desugars_to.h +4 -0
  1320. package/libcxx/include/__type_traits/invoke.h +8 -0
  1321. package/libcxx/include/__type_traits/is_allocator.h +6 -7
  1322. package/libcxx/include/__type_traits/is_array.h +26 -0
  1323. package/libcxx/include/__type_traits/is_equality_comparable.h +16 -21
  1324. package/libcxx/include/__type_traits/is_final.h +1 -1
  1325. package/libcxx/include/__type_traits/is_floating_point.h +7 -6
  1326. package/libcxx/include/__type_traits/is_generic_transparent_comparator.h +30 -0
  1327. package/libcxx/include/__type_traits/is_specialization.h +2 -6
  1328. package/libcxx/include/__type_traits/is_within_lifetime.h +29 -0
  1329. package/libcxx/include/__type_traits/make_transparent.h +52 -0
  1330. package/libcxx/include/__type_traits/reference_constructs_from_temporary.h +1 -7
  1331. package/libcxx/include/__type_traits/reference_converts_from_temporary.h +1 -1
  1332. package/libcxx/include/__utility/cmp.h +19 -7
  1333. package/libcxx/include/__utility/default_three_way_comparator.h +70 -0
  1334. package/libcxx/include/__utility/in_place.h +1 -1
  1335. package/libcxx/include/__utility/integer_sequence.h +56 -41
  1336. package/libcxx/include/__utility/lazy_synth_three_way_comparator.h +120 -0
  1337. package/libcxx/include/__utility/pair.h +22 -25
  1338. package/libcxx/include/__utility/scope_guard.h +2 -0
  1339. package/libcxx/include/__utility/try_key_extraction.h +114 -0
  1340. package/libcxx/include/__vector/vector.h +187 -160
  1341. package/libcxx/include/__vector/vector_bool.h +76 -83
  1342. package/libcxx/include/any +118 -155
  1343. package/libcxx/include/array +88 -56
  1344. package/libcxx/include/atomic +2 -0
  1345. package/libcxx/include/barrier +20 -24
  1346. package/libcxx/include/bitset +49 -30
  1347. package/libcxx/include/ccomplex +3 -11
  1348. package/libcxx/include/chrono +47 -0
  1349. package/libcxx/include/ciso646 +3 -6
  1350. package/libcxx/include/complex +77 -65
  1351. package/libcxx/include/complex.h +10 -10
  1352. package/libcxx/include/condition_variable +3 -3
  1353. package/libcxx/include/cstdalign +3 -10
  1354. package/libcxx/include/cstdbool +3 -10
  1355. package/libcxx/include/ctgmath +2 -11
  1356. package/libcxx/include/ctype.h +24 -24
  1357. package/libcxx/include/cwchar +2 -2
  1358. package/libcxx/include/deque +109 -225
  1359. package/libcxx/include/errno.h +269 -269
  1360. package/libcxx/include/exception +4 -1
  1361. package/libcxx/include/ext/hash_map +7 -48
  1362. package/libcxx/include/ext/hash_set +2 -8
  1363. package/libcxx/include/fenv.h +43 -43
  1364. package/libcxx/include/flat_map +663 -11
  1365. package/libcxx/include/flat_set +543 -8
  1366. package/libcxx/include/float.h +16 -16
  1367. package/libcxx/include/forward_list +33 -53
  1368. package/libcxx/include/fstream +57 -42
  1369. package/libcxx/include/future +41 -51
  1370. package/libcxx/include/initializer_list +9 -3
  1371. package/libcxx/include/inttypes.h +16 -16
  1372. package/libcxx/include/ios +28 -28
  1373. package/libcxx/include/istream +19 -13
  1374. package/libcxx/include/iterator +10 -0
  1375. package/libcxx/include/latch +7 -5
  1376. package/libcxx/include/limits +4 -4
  1377. package/libcxx/include/list +61 -79
  1378. package/libcxx/include/map +386 -274
  1379. package/libcxx/include/math.h +19 -0
  1380. package/libcxx/include/mdspan +1 -5
  1381. package/libcxx/include/mutex +29 -19
  1382. package/libcxx/include/optional +644 -149
  1383. package/libcxx/include/print +9 -5
  1384. package/libcxx/include/queue +39 -37
  1385. package/libcxx/include/ranges +48 -0
  1386. package/libcxx/include/regex +33 -31
  1387. package/libcxx/include/scoped_allocator +16 -11
  1388. package/libcxx/include/semaphore +15 -18
  1389. package/libcxx/include/set +220 -192
  1390. package/libcxx/include/shared_mutex +3 -8
  1391. package/libcxx/include/span +53 -37
  1392. package/libcxx/include/sstream +34 -28
  1393. package/libcxx/include/stack +13 -15
  1394. package/libcxx/include/stddef.h +10 -10
  1395. package/libcxx/include/stdexcept +2 -2
  1396. package/libcxx/include/stdio.h +20 -21
  1397. package/libcxx/include/streambuf +59 -19
  1398. package/libcxx/include/string +574 -573
  1399. package/libcxx/include/string_view +113 -89
  1400. package/libcxx/include/strstream +10 -10
  1401. package/libcxx/include/syncstream +4 -4
  1402. package/libcxx/include/tgmath.h +12 -12
  1403. package/libcxx/include/tuple +242 -212
  1404. package/libcxx/include/type_traits +8 -2
  1405. package/libcxx/include/typeindex +5 -3
  1406. package/libcxx/include/typeinfo +92 -89
  1407. package/libcxx/include/unordered_map +179 -304
  1408. package/libcxx/include/unordered_set +168 -195
  1409. package/libcxx/include/utility +12 -0
  1410. package/libcxx/include/valarray +106 -161
  1411. package/libcxx/include/variant +25 -33
  1412. package/libcxx/include/version +41 -24
  1413. package/libcxx/include/wctype.h +29 -29
  1414. package/libcxx/libc/hdr/errno_macros.h +3 -1
  1415. package/libcxx/libc/hdr/stdint_proxy.h +18 -0
  1416. package/libcxx/libc/hdr/types/wchar_t.h +23 -0
  1417. package/libcxx/libc/hdr/wchar_overlay.h +69 -0
  1418. package/libcxx/libc/include/llvm-libc-macros/cfloat128-macros.h +41 -0
  1419. package/libcxx/libc/include/llvm-libc-macros/cfloat16-macros.h +20 -0
  1420. package/libcxx/libc/include/llvm-libc-macros/wchar-macros.h +18 -0
  1421. package/libcxx/libc/include/llvm-libc-types/cfloat128.h +11 -28
  1422. package/libcxx/libc/include/llvm-libc-types/cfloat16.h +4 -7
  1423. package/libcxx/libc/include/llvm-libc-types/wint_t.h +14 -0
  1424. package/libcxx/libc/shared/libc_common.h +5 -0
  1425. package/libcxx/libc/src/__support/CPP/bit.h +50 -12
  1426. package/libcxx/libc/src/__support/CPP/type_traits/is_complex.h +7 -0
  1427. package/libcxx/libc/src/__support/CPP/type_traits/is_destructible.h +2 -1
  1428. package/libcxx/libc/src/__support/CPP/type_traits/is_unsigned.h +6 -0
  1429. package/libcxx/libc/src/__support/CPP/utility/integer_sequence.h +10 -0
  1430. package/libcxx/libc/src/__support/FPUtil/FPBits.h +6 -7
  1431. package/libcxx/libc/src/__support/FPUtil/rounding_mode.h +50 -4
  1432. package/libcxx/libc/src/__support/big_int.h +14 -14
  1433. package/libcxx/libc/src/__support/common.h +3 -2
  1434. package/libcxx/libc/src/__support/ctype_utils.h +19 -12
  1435. package/libcxx/libc/src/__support/detailed_powers_of_ten.h +1 -2
  1436. package/libcxx/libc/src/__support/high_precision_decimal.h +33 -14
  1437. package/libcxx/libc/src/__support/libc_assert.h +2 -0
  1438. package/libcxx/libc/src/__support/macros/attributes.h +44 -1
  1439. package/libcxx/libc/src/__support/macros/config.h +23 -0
  1440. package/libcxx/libc/src/__support/macros/null_check.h +1 -2
  1441. package/libcxx/libc/src/__support/macros/optimization.h +3 -0
  1442. package/libcxx/libc/src/__support/macros/properties/architectures.h +5 -1
  1443. package/libcxx/libc/src/__support/macros/properties/compiler.h +8 -3
  1444. package/libcxx/libc/src/__support/macros/properties/cpu_features.h +17 -1
  1445. package/libcxx/libc/src/__support/macros/properties/types.h +2 -3
  1446. package/libcxx/libc/src/__support/macros/sanitizer.h +0 -10
  1447. package/libcxx/libc/src/__support/math_extras.h +20 -4
  1448. package/libcxx/libc/src/__support/str_to_float.h +98 -125
  1449. package/libcxx/libc/src/__support/str_to_integer.h +39 -27
  1450. package/libcxx/libc/src/__support/wctype_utils.h +588 -0
  1451. package/libcxx/src/any.cpp +4 -0
  1452. package/libcxx/src/atomic.cpp +365 -80
  1453. package/libcxx/src/barrier.cpp +4 -3
  1454. package/libcxx/src/charconv.cpp +6 -3
  1455. package/libcxx/src/condition_variable_destructor.cpp +1 -1
  1456. package/libcxx/src/error_category.cpp +3 -1
  1457. package/libcxx/src/exception.cpp +2 -10
  1458. package/libcxx/src/experimental/time_zone.cpp +1 -1
  1459. package/libcxx/src/experimental/tzdb.cpp +4 -1
  1460. package/libcxx/src/filesystem/error.h +4 -22
  1461. package/libcxx/src/filesystem/format_string.h +9 -18
  1462. package/libcxx/src/filesystem/int128_builtins.cpp +2 -0
  1463. package/libcxx/src/filesystem/operations.cpp +2 -9
  1464. package/libcxx/src/filesystem/path.cpp +3 -1
  1465. package/libcxx/src/include/aligned_alloc.h +65 -0
  1466. package/libcxx/src/include/config_elast.h +1 -1
  1467. package/libcxx/src/include/from_chars_floating_point.h +11 -7
  1468. package/libcxx/src/include/overridable_function.h +8 -10
  1469. package/libcxx/src/iostream.cpp +56 -37
  1470. package/libcxx/src/locale.cpp +213 -196
  1471. package/libcxx/src/memory.cpp +12 -14
  1472. package/libcxx/src/mutex_destructor.cpp +1 -1
  1473. package/libcxx/src/new.cpp +5 -5
  1474. package/libcxx/src/optional.cpp +4 -0
  1475. package/libcxx/src/print.cpp +9 -1
  1476. package/libcxx/src/random.cpp +0 -26
  1477. package/libcxx/src/string.cpp +10 -25
  1478. package/libcxx/src/support/runtime/exception_fallback.ipp +2 -0
  1479. package/libcxx/src/support/runtime/exception_glibcxx.ipp +3 -0
  1480. package/libcxx/src/support/runtime/exception_libcxxabi.ipp +6 -2
  1481. package/libcxx/src/support/runtime/exception_libcxxrt.ipp +2 -0
  1482. package/libcxx/src/support/runtime/exception_msvc.ipp +2 -0
  1483. package/libcxx/src/support/runtime/exception_pointer_cxxabi.ipp +9 -10
  1484. package/libcxx/src/support/runtime/exception_pointer_glibcxx.ipp +2 -0
  1485. package/libcxx/src/support/runtime/exception_pointer_msvc.ipp +1 -0
  1486. package/libcxx/src/support/runtime/exception_pointer_unimplemented.ipp +1 -0
  1487. package/libcxx/src/support/win32/locale_win32.cpp +1 -1
  1488. package/libcxx/src/system_error.cpp +2 -0
  1489. package/libcxx/src/thread.cpp +1 -3
  1490. package/libcxx/src/valarray.cpp +1 -2
  1491. package/libcxx/src/vector.cpp +2 -2
  1492. package/libcxxabi/include/__cxxabi_config.h +42 -23
  1493. package/libcxxabi/src/cxa_exception.cpp +4 -2
  1494. package/libcxxabi/src/cxa_exception.h +16 -14
  1495. package/libcxxabi/src/cxa_personality.cpp +126 -9
  1496. package/libcxxabi/src/cxa_thread_atexit.cpp +2 -1
  1497. package/libcxxabi/src/demangle/DemangleConfig.h +4 -0
  1498. package/libcxxabi/src/demangle/ItaniumDemangle.h +9 -6
  1499. package/libcxxabi/src/demangle/Utility.h +21 -7
  1500. package/libcxxabi/src/fallback_malloc.cpp +1 -1
  1501. package/libcxxabi/src/private_typeinfo.cpp +6 -0
  1502. package/libcxxabi/src/stdlib_new_delete.cpp +5 -5
  1503. package/libtsan/LICENSE.TXT +311 -0
  1504. package/libtsan/builtins/assembly.h +41 -8
  1505. package/libtsan/interception/interception_win.cpp +4 -0
  1506. package/libtsan/sanitizer_common/sanitizer_allocator_primary32.h +1 -0
  1507. package/libtsan/sanitizer_common/sanitizer_allocator_primary64.h +18 -0
  1508. package/libtsan/sanitizer_common/sanitizer_common.h +15 -2
  1509. package/libtsan/sanitizer_common/sanitizer_common_interceptors.inc +30 -4
  1510. package/libtsan/sanitizer_common/sanitizer_common_interceptors_ioctl.inc +4 -0
  1511. package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_aarch64.inc.S +2 -1
  1512. package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_i386.inc.S +2 -0
  1513. package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_x86_64.inc.S +2 -0
  1514. package/libtsan/sanitizer_common/sanitizer_common_syscalls.inc +18 -0
  1515. package/libtsan/sanitizer_common/sanitizer_file.cpp +40 -12
  1516. package/libtsan/sanitizer_common/sanitizer_file.h +3 -0
  1517. package/libtsan/sanitizer_common/sanitizer_flags.inc +7 -0
  1518. package/libtsan/sanitizer_common/sanitizer_fuchsia.cpp +30 -3
  1519. package/libtsan/sanitizer_common/sanitizer_haiku.cpp +2 -2
  1520. package/libtsan/sanitizer_common/sanitizer_internal_defs.h +1 -1
  1521. package/libtsan/sanitizer_common/sanitizer_libc.cpp +8 -0
  1522. package/libtsan/sanitizer_common/sanitizer_libc.h +1 -0
  1523. package/libtsan/sanitizer_common/sanitizer_linux.cpp +15 -7
  1524. package/libtsan/sanitizer_common/sanitizer_linux.h +3 -3
  1525. package/libtsan/sanitizer_common/sanitizer_linux_libcdep.cpp +1 -0
  1526. package/libtsan/sanitizer_common/sanitizer_mac.cpp +255 -104
  1527. package/libtsan/sanitizer_common/sanitizer_mac.h +5 -0
  1528. package/libtsan/sanitizer_common/sanitizer_netbsd.cpp +2 -2
  1529. package/libtsan/sanitizer_common/sanitizer_platform.h +27 -1
  1530. package/libtsan/sanitizer_common/sanitizer_platform_interceptors.h +5 -4
  1531. package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.cpp +15 -17
  1532. package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.h +32 -6
  1533. package/libtsan/sanitizer_common/sanitizer_posix.cpp +3 -12
  1534. package/libtsan/sanitizer_common/sanitizer_posix.h +2 -1
  1535. package/libtsan/sanitizer_common/sanitizer_posix_libcdep.cpp +19 -0
  1536. package/libtsan/sanitizer_common/sanitizer_procmaps_mac.cpp +102 -37
  1537. package/libtsan/sanitizer_common/sanitizer_redefine_builtins.h +1 -1
  1538. package/libtsan/sanitizer_common/sanitizer_signal_interceptors.inc +40 -2
  1539. package/libtsan/sanitizer_common/sanitizer_stoptheworld.h +1 -1
  1540. package/libtsan/sanitizer_common/sanitizer_stoptheworld_linux_libcdep.cpp +83 -12
  1541. package/libtsan/sanitizer_common/sanitizer_stoptheworld_mac.cpp +3 -3
  1542. package/libtsan/sanitizer_common/sanitizer_stoptheworld_netbsd_libcdep.cpp +7 -7
  1543. package/libtsan/sanitizer_common/sanitizer_stoptheworld_win.cpp +2 -2
  1544. package/libtsan/sanitizer_common/sanitizer_symbolizer_internal.h +5 -1
  1545. package/libtsan/sanitizer_common/sanitizer_symbolizer_libcdep.cpp +11 -1
  1546. package/libtsan/sanitizer_common/sanitizer_symbolizer_mac.cpp +86 -29
  1547. package/libtsan/sanitizer_common/sanitizer_symbolizer_posix_libcdep.cpp +27 -16
  1548. package/libtsan/sanitizer_common/sanitizer_thread_registry.cpp +5 -4
  1549. package/libtsan/sanitizer_common/sanitizer_thread_registry.h +4 -4
  1550. package/libtsan/sanitizer_common/sanitizer_win.cpp +1 -3
  1551. package/libtsan/tsan_debugging.cpp +2 -2
  1552. package/libtsan/tsan_flags.cpp +37 -0
  1553. package/libtsan/tsan_flags.h +8 -0
  1554. package/libtsan/tsan_flags.inc +12 -0
  1555. package/libtsan/tsan_interceptors.h +9 -1
  1556. package/libtsan/tsan_interceptors_mac.cpp +19 -0
  1557. package/libtsan/tsan_interceptors_posix.cpp +78 -32
  1558. package/libtsan/tsan_interface.h +3 -3
  1559. package/libtsan/tsan_interface_ann.cpp +23 -9
  1560. package/libtsan/tsan_mman.cpp +18 -4
  1561. package/libtsan/tsan_platform.h +44 -7
  1562. package/libtsan/tsan_platform_linux.cpp +42 -14
  1563. package/libtsan/tsan_platform_mac.cpp +16 -3
  1564. package/libtsan/tsan_report.h +14 -1
  1565. package/libtsan/tsan_rtl.cpp +14 -0
  1566. package/libtsan/tsan_rtl.h +7 -2
  1567. package/libtsan/tsan_rtl_aarch64.S +3 -5
  1568. package/libtsan/tsan_rtl_access.cpp +8 -3
  1569. package/libtsan/tsan_rtl_amd64.S +2 -0
  1570. package/libtsan/tsan_rtl_mutex.cpp +94 -49
  1571. package/libtsan/tsan_rtl_report.cpp +132 -65
  1572. package/libtsan/tsan_rtl_thread.cpp +31 -9
  1573. package/libtsan/tsan_symbolize.cpp +1 -1
  1574. package/libtsan/tsan_symbolize.h +1 -1
  1575. package/libtsan/tsan_trace.h +1 -1
  1576. package/libunwind/include/__libunwind_config.h +11 -2
  1577. package/libunwind/include/libunwind.h +117 -11
  1578. package/libunwind/include/unwind_arm_ehabi.h +4 -1
  1579. package/libunwind/src/AddressSpace.hpp +42 -20
  1580. package/libunwind/src/CompactUnwinder.hpp +16 -5
  1581. package/libunwind/src/DwarfInstructions.hpp +24 -13
  1582. package/libunwind/src/DwarfParser.hpp +62 -23
  1583. package/libunwind/src/EHHeaderParser.hpp +7 -4
  1584. package/libunwind/src/Registers.hpp +226 -22
  1585. package/libunwind/src/Unwind-seh.cpp +6 -7
  1586. package/libunwind/src/Unwind-wasm.c +7 -7
  1587. package/libunwind/src/UnwindCursor.hpp +167 -49
  1588. package/libunwind/src/UnwindLevel1.c +46 -17
  1589. package/libunwind/src/UnwindRegistersRestore.S +46 -5
  1590. package/libunwind/src/UnwindRegistersSave.S +86 -2
  1591. package/libunwind/src/assembly.h +5 -1
  1592. package/libunwind/src/config.h +9 -0
  1593. package/libunwind/src/gcc_personality_v0.c +79 -6
  1594. package/libunwind/src/libunwind.cpp +104 -4
  1595. package/libunwind/src/libunwind_ext.h +7 -1
  1596. package/libunwind/src/shadow_stack_unwind.h +2 -2
  1597. package/lldb/pretty_printers.py +948 -0
  1598. package/package.json +1 -1
  1599. package/std/Build/Cache/Path.zig +42 -43
  1600. package/std/Build/Cache.zig +19 -9
  1601. package/std/Build/Configuration.zig +3479 -0
  1602. package/std/Build/Module.zig +99 -225
  1603. package/std/Build/Step/CheckFile.zig +17 -63
  1604. package/std/Build/Step/Compile.zig +97 -1426
  1605. package/std/Build/Step/ConfigHeader.zig +56 -944
  1606. package/std/Build/Step/Fail.zig +10 -20
  1607. package/std/Build/Step/FindProgram.zig +31 -0
  1608. package/std/Build/Step/Fmt.zig +22 -57
  1609. package/std/Build/Step/InstallArtifact.zig +26 -141
  1610. package/std/Build/Step/InstallDir.zig +14 -67
  1611. package/std/Build/Step/InstallFile.zig +12 -21
  1612. package/std/Build/Step/ObjCopy.zig +82 -199
  1613. package/std/Build/Step/Options.zig +55 -284
  1614. package/std/Build/Step/Run.zig +138 -2246
  1615. package/std/Build/Step/TranslateC.zig +55 -164
  1616. package/std/Build/Step/UpdateSourceFiles.zig +38 -91
  1617. package/std/Build/Step/WriteFile.zig +113 -328
  1618. package/std/Build/Step.zig +45 -916
  1619. package/std/Build/abi.zig +1 -1
  1620. package/std/Build.zig +725 -770
  1621. package/std/Io/Dir.zig +12 -7
  1622. package/std/Io/Dispatch.zig +5 -5
  1623. package/std/Io/File/Writer.zig +8 -6
  1624. package/std/Io/File.zig +6 -9
  1625. package/std/Io/Kqueue.zig +5 -5
  1626. package/std/Io/Reader.zig +66 -23
  1627. package/std/Io/RwLock.zig +2 -0
  1628. package/std/Io/Terminal.zig +1 -1
  1629. package/std/Io/Threaded.zig +36 -30
  1630. package/std/Io/Uring.zig +11 -9
  1631. package/std/Io/Writer.zig +125 -37
  1632. package/std/Io/net/HostName.zig +11 -6
  1633. package/std/Io/net.zig +3 -1
  1634. package/std/Io.zig +29 -19
  1635. package/std/Progress.zig +2 -2
  1636. package/std/Random/ChaCha.zig +2 -2
  1637. package/std/Random/benchmark.zig +2 -2
  1638. package/std/Random.zig +6 -6
  1639. package/std/SemanticVersion.zig +1 -1
  1640. package/std/Target/Query.zig +4 -5
  1641. package/std/Target/aarch64.zig +622 -79
  1642. package/std/Target/alpha.zig +2 -2
  1643. package/std/Target/amdgcn.zig +423 -23
  1644. package/std/Target/arc.zig +2 -2
  1645. package/std/Target/arm.zig +42 -8
  1646. package/std/Target/avr.zig +2 -2
  1647. package/std/Target/bpf.zig +8 -2
  1648. package/std/Target/csky.zig +2 -2
  1649. package/std/Target/hexagon.zig +43 -8
  1650. package/std/Target/hppa.zig +2 -2
  1651. package/std/Target/kvx.zig +2 -2
  1652. package/std/Target/lanai.zig +2 -2
  1653. package/std/Target/loongarch.zig +20 -2
  1654. package/std/Target/m68k.zig +2 -2
  1655. package/std/Target/mips.zig +8 -2
  1656. package/std/Target/msp430.zig +2 -2
  1657. package/std/Target/nvptx.zig +60 -37
  1658. package/std/Target/powerpc.zig +29 -21
  1659. package/std/Target/propeller.zig +2 -2
  1660. package/std/Target/riscv.zig +514 -179
  1661. package/std/Target/s390x.zig +2 -2
  1662. package/std/Target/sparc.zig +19 -2
  1663. package/std/Target/spirv.zig +3 -3
  1664. package/std/Target/ve.zig +2 -2
  1665. package/std/Target/wasm.zig +9 -2
  1666. package/std/Target/x86.zig +202 -33
  1667. package/std/Target/xcore.zig +2 -2
  1668. package/std/Target/xtensa.zig +67 -2
  1669. package/std/Target.zig +101 -62
  1670. package/std/Thread.zig +39 -6
  1671. package/std/array_hash_map.zig +104 -59
  1672. package/std/array_list.zig +20 -35
  1673. package/std/ascii.zig +0 -9
  1674. package/std/atomic.zig +2 -0
  1675. package/std/base64.zig +5 -5
  1676. package/std/bit_set.zig +85 -93
  1677. package/std/c/darwin.zig +7 -1
  1678. package/std/c.zig +88 -29
  1679. package/std/coff.zig +1 -1
  1680. package/std/compress/flate/Compress.zig +4 -2
  1681. package/std/compress/flate/Decompress.zig +3 -4
  1682. package/std/compress/zstd/Decompress.zig +7 -9
  1683. package/std/crypto/25519/curve25519.zig +2 -2
  1684. package/std/crypto/25519/edwards25519.zig +3 -3
  1685. package/std/crypto/25519/ristretto255.zig +2 -2
  1686. package/std/crypto/25519/scalar.zig +6 -6
  1687. package/std/crypto/25519/x25519.zig +1 -1
  1688. package/std/crypto/Certificate.zig +14 -2
  1689. package/std/crypto/Sha1.zig +1 -1
  1690. package/std/crypto/aegis.zig +45 -39
  1691. package/std/crypto/aes/aesni.zig +1 -1
  1692. package/std/crypto/aes/armcrypto.zig +4 -4
  1693. package/std/crypto/aes/soft.zig +4 -4
  1694. package/std/crypto/aes.zig +12 -0
  1695. package/std/crypto/aes_ccm.zig +22 -22
  1696. package/std/crypto/aes_gcm.zig +10 -12
  1697. package/std/crypto/aes_ocb.zig +9 -9
  1698. package/std/crypto/aes_siv.zig +4 -2
  1699. package/std/crypto/argon2.zig +15 -15
  1700. package/std/crypto/ascon.zig +75 -35
  1701. package/std/crypto/bcrypt.zig +20 -10
  1702. package/std/crypto/benchmark.zig +7 -7
  1703. package/std/crypto/blake2.zig +100 -64
  1704. package/std/crypto/cbc_mac.zig +1 -1
  1705. package/std/crypto/chacha20.zig +10 -10
  1706. package/std/crypto/cmac.zig +3 -3
  1707. package/std/crypto/codecs/asn1/Oid.zig +22 -11
  1708. package/std/crypto/codecs/asn1/der/Decoder.zig +51 -20
  1709. package/std/crypto/codecs/asn1/der/Encoder.zig +111 -46
  1710. package/std/crypto/codecs/asn1/der.zig +42 -0
  1711. package/std/crypto/codecs/asn1.zig +97 -38
  1712. package/std/crypto/codecs/base64_hex_ct.zig +3 -5
  1713. package/std/crypto/codecs.zig +6 -0
  1714. package/std/crypto/ecdsa.zig +9 -9
  1715. package/std/crypto/ff.zig +7 -6
  1716. package/std/crypto/ghash_polyval.zig +4 -4
  1717. package/std/crypto/hkdf.zig +1 -1
  1718. package/std/crypto/isap.zig +3 -3
  1719. package/std/crypto/kangarootwelve.zig +1 -1
  1720. package/std/crypto/keccak_p.zig +8 -8
  1721. package/std/crypto/md5.zig +1 -1
  1722. package/std/crypto/ml_dsa.zig +39 -39
  1723. package/std/crypto/ml_kem.zig +12 -34
  1724. package/std/crypto/modes.zig +2 -2
  1725. package/std/crypto/pbkdf2.zig +1 -1
  1726. package/std/crypto/pcurves/common.zig +4 -5
  1727. package/std/crypto/pcurves/p256/scalar.zig +3 -3
  1728. package/std/crypto/pcurves/p384/scalar.zig +2 -2
  1729. package/std/crypto/pcurves/secp256k1/scalar.zig +3 -3
  1730. package/std/crypto/pcurves/tests/p256.zig +5 -5
  1731. package/std/crypto/pcurves/tests/p384.zig +5 -5
  1732. package/std/crypto/pcurves/tests/secp256k1.zig +3 -3
  1733. package/std/crypto/phc_encoding.zig +23 -20
  1734. package/std/crypto/salsa20.zig +8 -14
  1735. package/std/crypto/sha2.zig +2 -2
  1736. package/std/crypto/sha3.zig +2 -4
  1737. package/std/crypto/siphash.zig +1 -1
  1738. package/std/crypto/timing_safe.zig +11 -10
  1739. package/std/crypto/tls/Client.zig +107 -16
  1740. package/std/crypto/tls.zig +2 -2
  1741. package/std/crypto.zig +4 -3
  1742. package/std/debug/Dwarf/Unwind/VirtualMachine.zig +11 -5
  1743. package/std/debug/Dwarf.zig +21 -12
  1744. package/std/debug/ElfFile.zig +12 -8
  1745. package/std/debug/MachOFile.zig +2 -2
  1746. package/std/debug/Pdb.zig +86 -51
  1747. package/std/debug/SelfInfo/Elf.zig +13 -9
  1748. package/std/debug/SelfInfo/MachO.zig +44 -17
  1749. package/std/debug/SelfInfo/Windows.zig +5 -7
  1750. package/std/debug/cpu_context.zig +231 -39
  1751. package/std/debug.zig +16 -8
  1752. package/std/deque.zig +1 -1
  1753. package/std/elf.zig +29 -12
  1754. package/std/enums.zig +74 -87
  1755. package/std/fmt/float.zig +2 -0
  1756. package/std/fmt/parse_float/decimal.zig +1 -1
  1757. package/std/fmt/parse_float.zig +1 -1
  1758. package/std/fmt.zig +7 -8
  1759. package/std/fs/path.zig +7 -5
  1760. package/std/gpu.zig +1 -1
  1761. package/std/hash/Adler32.zig +3 -3
  1762. package/std/hash/auto_hash.zig +8 -8
  1763. package/std/hash/benchmark.zig +2 -2
  1764. package/std/hash/verify.zig +3 -3
  1765. package/std/hash/wyhash.zig +2 -2
  1766. package/std/hash/xxhash.zig +0 -6
  1767. package/std/hash_map.zig +22 -2
  1768. package/std/heap/ArenaAllocator.zig +3 -5
  1769. package/std/heap/BrkAllocator.zig +1 -1
  1770. package/std/heap/BufferFirstAllocator.zig +165 -0
  1771. package/std/heap/SafeAllocator.zig +2180 -0
  1772. package/std/heap/debug_allocator.zig +2 -2
  1773. package/std/heap/memory_pool.zig +34 -197
  1774. package/std/heap.zig +20 -133
  1775. package/std/http/Client.zig +2 -2
  1776. package/std/http.zig +4 -5
  1777. package/std/json/Scanner.zig +2 -2
  1778. package/std/json/Stringify.zig +14 -14
  1779. package/std/json/static.zig +49 -32
  1780. package/std/json.zig +1 -1
  1781. package/std/{builtin → lang}/assembly.zig +71 -0
  1782. package/std/{builtin.zig → lang.zig} +70 -100
  1783. package/std/leb128.zig +2 -2
  1784. package/std/math/acos.zig +6 -0
  1785. package/std/math/asin.zig +6 -0
  1786. package/std/math/atan.zig +5 -0
  1787. package/std/math/big/int.zig +5 -5
  1788. package/std/math/big.zig +4 -4
  1789. package/std/math/copysign.zig +1 -1
  1790. package/std/math/float.zig +62 -0
  1791. package/std/math/frexp.zig +4 -4
  1792. package/std/math/hypot.zig +4 -0
  1793. package/std/math/ilogb.zig +1 -1
  1794. package/std/math/isfinite.zig +1 -1
  1795. package/std/math/isinf.zig +1 -1
  1796. package/std/math/isnan.zig +6 -2
  1797. package/std/math/isnormal.zig +2 -2
  1798. package/std/math/iszero.zig +2 -2
  1799. package/std/math/ldexp.zig +2 -2
  1800. package/std/math/log10.zig +0 -2
  1801. package/std/math/log1p.zig +13 -19
  1802. package/std/math/modf.zig +1 -2
  1803. package/std/math/nextafter.zig +3 -4
  1804. package/std/math/pow.zig +1 -1
  1805. package/std/math/powi.zig +2 -3
  1806. package/std/math/signbit.zig +0 -1
  1807. package/std/math.zig +28 -28
  1808. package/std/mem/Allocator.zig +14 -18
  1809. package/std/mem.zig +137 -176
  1810. package/std/meta/trailer_flags.zig +27 -20
  1811. package/std/meta.zig +134 -215
  1812. package/std/multi_array_list.zig +70 -54
  1813. package/std/os/emscripten.zig +7 -6
  1814. package/std/os/linux/IoUring.zig +2 -0
  1815. package/std/os/linux/alpha.zig +358 -0
  1816. package/std/os/linux/arm.zig +0 -26
  1817. package/std/os/linux/bpf.zig +6 -0
  1818. package/std/os/linux/csky.zig +165 -0
  1819. package/std/os/linux/ioctl.zig +3 -2
  1820. package/std/os/linux/microblaze.zig +170 -0
  1821. package/std/os/linux/sh.zig +239 -0
  1822. package/std/os/linux/sparc.zig +277 -0
  1823. package/std/os/linux/sparc64.zig +44 -30
  1824. package/std/os/linux/syscalls.zig +2246 -13
  1825. package/std/os/linux/tls.zig +12 -1
  1826. package/std/os/linux/x86.zig +2 -2
  1827. package/std/os/linux/xtensa.zig +193 -0
  1828. package/std/os/linux.zig +829 -58
  1829. package/std/os/plan9.zig +1 -1
  1830. package/std/os/uefi/hii.zig +1 -1
  1831. package/std/os/uefi/protocol/device_path.zig +8 -7
  1832. package/std/os/uefi/protocol/file.zig +16 -0
  1833. package/std/os/uefi/tables/boot_services.zig +9 -8
  1834. package/std/os/uefi/tables/runtime_services.zig +1 -1
  1835. package/std/os/windows.zig +139 -16
  1836. package/std/os.zig +0 -15
  1837. package/std/pie.zig +19 -0
  1838. package/std/posix.zig +2 -2
  1839. package/std/process/Child.zig +20 -0
  1840. package/std/process/Environ.zig +28 -4
  1841. package/std/process.zig +13 -5
  1842. package/std/simd.zig +4 -21
  1843. package/std/sort/pdq.zig +91 -13
  1844. package/std/start.zig +63 -22
  1845. package/std/static_string_map.zig +59 -1
  1846. package/std/std.zig +8 -1
  1847. package/std/tar/Writer.zig +39 -33
  1848. package/std/tar.zig +8 -4
  1849. package/std/testing/Smith.zig +35 -21
  1850. package/std/testing.zig +83 -30
  1851. package/std/unicode.zig +13 -8
  1852. package/std/zig/Ast/Render.zig +6 -30
  1853. package/std/zig/Ast.zig +16 -41
  1854. package/std/zig/AstGen.zig +216 -300
  1855. package/std/zig/AstRlAnnotate.zig +1 -11
  1856. package/std/zig/AstSmith.zig +5 -11
  1857. package/std/zig/ErrorBundle.zig +22 -15
  1858. package/std/zig/LibCDirs.zig +14 -7
  1859. package/std/zig/LibCInstallation.zig +61 -26
  1860. package/std/zig/Parse.zig +18 -83
  1861. package/std/zig/PkgConfig.zig +151 -0
  1862. package/std/zig/TokenSmith.zig +0 -6
  1863. package/std/zig/WindowsSdk.zig +18 -18
  1864. package/std/zig/Zir.zig +22 -76
  1865. package/std/zig/ZonGen.zig +19 -27
  1866. package/std/zig/c_translation/helpers.zig +2 -2
  1867. package/std/zig/llvm/BitcodeReader.zig +3 -3
  1868. package/std/zig/llvm/Builder.zig +163 -126
  1869. package/std/zig/llvm/bitcode_writer.zig +7 -7
  1870. package/std/zig/llvm/ir.zig +8 -8
  1871. package/std/zig/system/arm.zig +56 -2
  1872. package/std/zig/system/darwin/macos.zig +11 -7
  1873. package/std/zig/system/linux.zig +4 -0
  1874. package/std/zig/system/loongarch.zig +25 -9
  1875. package/std/zig/system/windows.zig +45 -12
  1876. package/std/zig/system/x86.zig +60 -16
  1877. package/std/zig/system.zig +23 -30
  1878. package/std/zig/target.zig +3 -5
  1879. package/std/zig/tokenizer.zig +4 -43
  1880. package/std/zig.zig +114 -26
  1881. package/std/zip.zig +5 -5
  1882. package/std/zon/Serializer.zig +34 -25
  1883. package/std/zon/parse.zig +84 -62
  1884. package/ubsan_rt.zig +3 -3
  1885. package/zig.h +61 -11
  1886. package/compiler/build_runner.zig +0 -1857
  1887. package/compiler_rt/long_double.zig +0 -37
  1888. package/include/amxbf16transposeintrin.h +0 -94
  1889. package/include/amxcomplextransposeintrin.h +0 -303
  1890. package/include/amxfp16transposeintrin.h +0 -94
  1891. package/include/amxmovrstransposeintrin.h +0 -200
  1892. package/include/amxtf32transposeintrin.h +0 -105
  1893. package/include/amxtransposeintrin.h +0 -248
  1894. package/libc/include/arm-netbsd-eabi/machine/frame.h +0 -130
  1895. package/libc/include/generic-netbsd/powerpc/bswap.h +0 -8
  1896. package/libc/include/hexagon-linux-any/asm/signal.h +0 -29
  1897. package/libc/include/mips-netbsd-eabi/machine/psl.h +0 -3
  1898. package/libc/include/mips-netbsd-eabi/machine/reloc.h +0 -3
  1899. package/libc/include/mips-netbsd-eabi/machine/trap.h +0 -3
  1900. package/libc/include/mips64el-openbsd-none/loongson/hibernate.h +0 -33
  1901. package/libc/include/mips64el-openbsd-none/loongson/hibernate_var.h +0 -39
  1902. package/libc/include/mips64el-openbsd-none/machine/hibernate.h +0 -33
  1903. package/libc/include/mips64el-openbsd-none/machine/hibernate_var.h +0 -39
  1904. package/libc/include/s390x-linux-any/asm/tape390.h +0 -103
  1905. package/libc/mingw/math/lrintl.c +0 -18
  1906. package/libc/mingw/math/rintl.c +0 -16
  1907. package/libc/mingw/winpthreads/spinlock.c +0 -82
  1908. package/libc/musl/src/linux/tee.c +0 -8
  1909. package/libc/musl/src/math/i386/log1p.s +0 -25
  1910. package/libc/musl/src/math/i386/log1pf.s +0 -26
  1911. package/libc/musl/src/math/i386/lrintl.c +0 -8
  1912. package/libc/musl/src/math/i386/rintl.c +0 -7
  1913. package/libc/musl/src/math/log1p.c +0 -122
  1914. package/libc/musl/src/math/log1pf.c +0 -77
  1915. package/libc/musl/src/math/lrintl.c +0 -36
  1916. package/libc/musl/src/math/rintl.c +0 -29
  1917. package/libc/musl/src/math/s390x/rintl.c +0 -15
  1918. package/libc/musl/src/math/x32/lrintl.s +0 -7
  1919. package/libc/musl/src/math/x32/rintl.s +0 -6
  1920. package/libc/musl/src/math/x86_64/lrintl.c +0 -8
  1921. package/libc/musl/src/math/x86_64/rintl.c +0 -7
  1922. package/libc/musl/src/string/strdup.c +0 -10
  1923. package/libc/musl/src/string/strndup.c +0 -12
  1924. package/libc/musl/src/string/wcsdup.c +0 -10
  1925. package/libc/musl/src/thread/pthread_spin_destroy.c +0 -6
  1926. package/libc/musl/src/thread/pthread_spin_init.c +0 -6
  1927. package/libc/musl/src/thread/pthread_spin_lock.c +0 -8
  1928. package/libc/musl/src/thread/pthread_spin_trylock.c +0 -7
  1929. package/libc/musl/src/thread/pthread_spin_unlock.c +0 -7
  1930. package/libc/wasi/thread-stub/pthread_spin_lock.c +0 -8
  1931. package/libc/wasi/thread-stub/pthread_spin_trylock.c +0 -8
  1932. package/libc/wasi/thread-stub/pthread_spin_unlock.c +0 -7
  1933. package/libtsan/sanitizer_common/sanitizer_coverage_interface.inc +0 -43
  1934. package/std/Build/Step/CheckObject.zig +0 -2764
  1935. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ansi.h +0 -0
  1936. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/aout_machdep.h +0 -0
  1937. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/asm.h +0 -0
  1938. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/bswap.h +0 -0
  1939. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/cdefs.h +0 -0
  1940. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/cpu.h +0 -0
  1941. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/disklabel.h +0 -0
  1942. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/elf_machdep.h +0 -0
  1943. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/endian.h +0 -0
  1944. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/endian_machdep.h +0 -0
  1945. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/fenv.h +0 -0
  1946. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/float.h +0 -0
  1947. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/fpu.h +0 -0
  1948. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/frame.h +0 -0
  1949. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ieee.h +0 -0
  1950. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ieeefp.h +0 -0
  1951. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_const.h +0 -0
  1952. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_fmtio.h +0 -0
  1953. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_limits.h +0 -0
  1954. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_mwgwtypes.h +0 -0
  1955. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/int_types.h +0 -0
  1956. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/intr.h +0 -0
  1957. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/kcore.h +0 -0
  1958. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/limits.h +0 -0
  1959. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/lock.h +0 -0
  1960. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/math.h +0 -0
  1961. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/mcontext.h +0 -0
  1962. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/mutex.h +0 -0
  1963. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/param.h +0 -0
  1964. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/pcb.h +0 -0
  1965. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/pmap.h +0 -0
  1966. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/proc.h +0 -0
  1967. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/profile.h +0 -0
  1968. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/psl.h +0 -0
  1969. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/pte.h +0 -0
  1970. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/ptrace.h +0 -0
  1971. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/reg.h +0 -0
  1972. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/reloc.h +0 -0
  1973. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/rwlock.h +0 -0
  1974. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/setjmp.h +0 -0
  1975. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/signal.h +0 -0
  1976. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/sljit_machdep.h +0 -0
  1977. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/trap.h +0 -0
  1978. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/types.h +0 -0
  1979. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/vmparam.h +0 -0
  1980. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/evbppc/wchar_limits.h +0 -0
  1981. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/machine/fpu.h +0 -0
  1982. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/machine/intr.h +0 -0
  1983. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ansi.h +0 -0
  1984. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/aout_machdep.h +0 -0
  1985. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/cdefs.h +0 -0
  1986. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/elf_machdep.h +0 -0
  1987. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/endian.h +0 -0
  1988. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/endian_machdep.h +0 -0
  1989. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/float.h +0 -0
  1990. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/fpu.h +0 -0
  1991. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/frame.h +0 -0
  1992. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/cpu.h +0 -0
  1993. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/spr.h +0 -0
  1994. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ibm4xx/tlb.h +0 -0
  1995. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ieeefp.h +0 -0
  1996. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_const.h +0 -0
  1997. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_fmtio.h +0 -0
  1998. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_limits.h +0 -0
  1999. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_mwgwtypes.h +0 -0
  2000. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/int_types.h +0 -0
  2001. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/kcore.h +0 -0
  2002. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/lock.h +0 -0
  2003. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/math.h +0 -0
  2004. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/bat.h +0 -0
  2005. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/hid_601.h +0 -0
  2006. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/pte.h +0 -0
  2007. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/spr.h +0 -0
  2008. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/sr_601.h +0 -0
  2009. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/oea/vmparam.h +0 -0
  2010. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/param.h +0 -0
  2011. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/pcb.h +0 -0
  2012. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/proc.h +0 -0
  2013. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/profile.h +0 -0
  2014. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/pte.h +0 -0
  2015. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/ptrace.h +0 -0
  2016. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/reg.h +0 -0
  2017. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/reloc.h +0 -0
  2018. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/rwlock.h +0 -0
  2019. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/setjmp.h +0 -0
  2020. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/signal.h +0 -0
  2021. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/sljit_machdep.h +0 -0
  2022. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/spr.h +0 -0
  2023. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/trap.h +0 -0
  2024. /package/libc/include/{generic-netbsd → powerpc-netbsd-eabi}/powerpc/types.h +0 -0
  2025. /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
+ }