@zigc/lib 0.17.0-dev.131 → 0.17.0-dev.215
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/c/stdlib.zig +32 -22
- package/compiler/aro/aro/Compilation.zig +0 -3
- package/compiler/translate-c/ast.zig +5 -2
- package/compiler_rt/arm.zig +3 -3
- package/compiler_rt/trunctfhf2.zig +3 -0
- package/compiler_rt.zig +1 -22
- package/docs/wasm/markdown/Parser.zig +5 -9
- package/include/__clang_spirv_builtins.h +12 -12
- package/include/__float_float.h +176 -0
- package/include/__float_header_macro.h +12 -0
- package/include/__float_infinity_nan.h +20 -0
- package/include/amo.h +131 -0
- package/include/amxavx512intrin.h +215 -1
- package/include/amxintrin.h +0 -2
- package/include/arm_acle.h +37 -27
- package/include/arm_neon.h +218 -82
- package/include/arm_sme.h +8 -8
- package/include/arm_sve.h +4162 -3782
- package/include/avx10_2_512bf16intrin.h +19 -12
- package/include/avx10_2_512convertintrin.h +1 -1
- package/include/avx10_2_512niintrin.h +31 -31
- package/include/avx10_2_512satcvtdsintrin.h +1 -1
- package/include/avx10_2bf16intrin.h +54 -45
- package/include/avx10_2convertintrin.h +2 -2
- package/include/avx10_2copyintrin.h +1 -1
- package/include/avx10_2niintrin.h +14 -14
- package/include/avx10_2satcvtdsintrin.h +2 -2
- package/include/avx2intrin.h +275 -377
- package/include/avx512bf16intrin.h +25 -16
- package/include/avx512bitalgintrin.h +19 -30
- package/include/avx512bwintrin.h +386 -505
- package/include/avx512cdintrin.h +42 -55
- package/include/avx512dqintrin.h +132 -161
- package/include/avx512fintrin.h +1015 -1424
- package/include/avx512fp16intrin.h +112 -110
- package/include/avx512ifmaintrin.h +32 -34
- package/include/avx512ifmavlintrin.h +73 -46
- package/include/avx512vbmi2intrin.h +43 -32
- package/include/avx512vbmiintrin.h +19 -27
- package/include/avx512vbmivlintrin.h +35 -49
- package/include/avx512vlbf16intrin.h +32 -22
- package/include/avx512vlbitalgintrin.h +37 -53
- package/include/avx512vlbwintrin.h +470 -573
- package/include/avx512vlcdintrin.h +74 -102
- package/include/avx512vldqintrin.h +110 -127
- package/include/avx512vlfp16intrin.h +130 -111
- package/include/avx512vlintrin.h +945 -1299
- package/include/avx512vlvbmi2intrin.h +78 -63
- package/include/avx512vlvnniintrin.h +21 -18
- package/include/avx512vlvp2intersectintrin.h +2 -2
- package/include/avx512vnniintrin.h +10 -10
- package/include/avx512vp2intersectintrin.h +1 -2
- package/include/avx512vpopcntdqintrin.h +8 -10
- package/include/avx512vpopcntdqvlintrin.h +17 -15
- package/include/avxifmaintrin.h +16 -0
- package/include/avxintrin.h +165 -241
- package/include/avxvnniint16intrin.h +118 -99
- package/include/avxvnniint8intrin.h +56 -32
- package/include/avxvnniintrin.h +16 -8
- package/include/cpuid.h +101 -4
- package/include/emmintrin.h +168 -168
- package/include/f16cintrin.h +23 -9
- package/include/float.h +16 -155
- package/include/fma4intrin.h +98 -96
- package/include/fmaintrin.h +96 -66
- package/include/gfniintrin.h +21 -16
- package/include/hexagon_types.h +23 -20
- package/include/hvx_hexagon_protos.h +649 -860
- package/include/immintrin.h +0 -12
- package/include/intrin.h +4 -0
- package/include/lasxintrin.h +113 -0
- package/include/llvm_libc_wrappers/assert.h +3 -5
- package/include/llvm_libc_wrappers/ctype.h +3 -115
- package/include/llvm_libc_wrappers/inttypes.h +3 -5
- package/include/llvm_libc_wrappers/stdio.h +10 -38
- package/include/llvm_libc_wrappers/stdlib.h +3 -24
- package/include/llvm_libc_wrappers/string.h +2 -70
- package/include/llvm_libc_wrappers/time.h +4 -10
- package/include/mmintrin.h +188 -257
- package/include/module.modulemap +23 -4
- package/include/movrs_avx10_2_512intrin.h +2 -2
- package/include/movrs_avx10_2intrin.h +4 -4
- package/include/pmmintrin.h +12 -24
- package/include/ptrauth.h +16 -2
- package/include/riscv_mips.h +34 -0
- package/include/riscv_nds.h +89 -0
- package/include/sifive_vector.h +58 -2
- package/include/sm4evexintrin.h +2 -2
- package/include/smmintrin.h +77 -59
- package/include/spirvintrin.h +194 -0
- package/include/stddefer.h +19 -0
- package/include/tmmintrin.h +116 -147
- package/include/vaesintrin.h +1 -2
- package/include/xmmintrin.h +44 -70
- package/include/xopintrin.h +20 -10
- package/libc/include/aarch64-linux-any/asm/hwcap.h +1 -0
- package/libc/include/aarch64-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/any-linux-any/asm-generic/errno.h +2 -0
- package/libc/include/any-linux-any/asm-generic/unistd.h +4 -1
- package/libc/include/any-linux-any/drm/amdgpu_drm.h +20 -6
- package/libc/include/any-linux-any/drm/amdxdna_accel.h +8 -0
- package/libc/include/any-linux-any/drm/drm_fourcc.h +6 -6
- package/libc/include/any-linux-any/drm/panfrost_drm.h +75 -1
- package/libc/include/any-linux-any/drm/panthor_drm.h +154 -3
- package/libc/include/any-linux-any/drm/rocket_accel.h +74 -24
- package/libc/include/any-linux-any/drm/xe_drm.h +89 -6
- package/libc/include/any-linux-any/linux/android/binder.h +1 -1
- package/libc/include/any-linux-any/linux/bpf.h +28 -0
- package/libc/include/any-linux-any/linux/btrfs.h +1 -0
- package/libc/include/any-linux-any/linux/btrfs_tree.h +32 -2
- package/libc/include/any-linux-any/linux/dma-buf.h +1 -0
- package/libc/include/any-linux-any/linux/dpll.h +1 -0
- package/libc/include/any-linux-any/linux/elf.h +2 -0
- package/libc/include/any-linux-any/linux/ethtool.h +21 -5
- package/libc/include/any-linux-any/linux/fs.h +1 -0
- package/libc/include/any-linux-any/linux/hyperv.h +1 -1
- package/libc/include/any-linux-any/linux/idxd.h +134 -134
- package/libc/include/any-linux-any/linux/if_alg.h +1 -1
- package/libc/include/any-linux-any/linux/if_link.h +1 -0
- package/libc/include/any-linux-any/linux/input-event-codes.h +4 -0
- package/libc/include/any-linux-any/linux/io_uring/bpf_filter.h +68 -0
- package/libc/include/any-linux-any/linux/io_uring/query.h +5 -1
- package/libc/include/any-linux-any/linux/io_uring.h +33 -2
- package/libc/include/any-linux-any/linux/iommufd.h +39 -0
- package/libc/include/any-linux-any/linux/kfd_ioctl.h +13 -3
- package/libc/include/any-linux-any/linux/kfd_sysfs.h +2 -1
- package/libc/include/any-linux-any/linux/kvm.h +30 -6
- package/libc/include/any-linux-any/linux/landlock.h +22 -8
- package/libc/include/any-linux-any/linux/magic.h +1 -0
- package/libc/include/any-linux-any/linux/mempolicy.h +3 -0
- package/libc/include/any-linux-any/linux/mount.h +11 -2
- package/libc/include/any-linux-any/linux/mptcp_pm.h +1 -1
- package/libc/include/any-linux-any/linux/mshv.h +2 -0
- package/libc/include/any-linux-any/linux/netfilter_bridge.h +5 -4
- package/libc/include/any-linux-any/linux/netfilter_ipv4.h +4 -5
- package/libc/include/any-linux-any/linux/netfilter_ipv6.h +3 -4
- package/libc/include/any-linux-any/linux/nfs.h +1 -1
- package/libc/include/any-linux-any/linux/nfsd_netlink.h +1 -0
- package/libc/include/any-linux-any/linux/nilfs2_api.h +2 -2
- package/libc/include/any-linux-any/linux/nilfs2_ondisk.h +97 -66
- package/libc/include/any-linux-any/linux/nl80211.h +104 -3
- package/libc/include/any-linux-any/linux/pci.h +7 -0
- package/libc/include/any-linux-any/linux/pci_regs.h +65 -6
- package/libc/include/any-linux-any/linux/pcitest.h +1 -0
- package/libc/include/any-linux-any/linux/perf_event.h +24 -3
- package/libc/include/any-linux-any/linux/pkt_sched.h +1 -0
- package/libc/include/any-linux-any/linux/prctl.h +30 -0
- package/libc/include/any-linux-any/linux/rseq.h +62 -5
- package/libc/include/any-linux-any/linux/shm.h +0 -1
- package/libc/include/any-linux-any/linux/stddef.h +4 -0
- package/libc/include/any-linux-any/linux/sysctl.h +1 -2
- package/libc/include/any-linux-any/linux/taskstats.h +12 -1
- package/libc/include/any-linux-any/linux/tcp.h +23 -3
- package/libc/include/any-linux-any/linux/typelimits.h +8 -0
- package/libc/include/any-linux-any/linux/ublk_cmd.h +120 -1
- package/libc/include/any-linux-any/linux/v4l2-controls.h +63 -0
- package/libc/include/any-linux-any/linux/vbox_vmmdev_types.h +2 -2
- package/libc/include/any-linux-any/linux/vduse.h +80 -5
- package/libc/include/any-linux-any/linux/version.h +3 -3
- package/libc/include/any-linux-any/linux/vfio.h +4 -0
- package/libc/include/any-linux-any/linux/videodev2.h +3 -0
- package/libc/include/any-linux-any/linux/virtio_ring.h +1 -2
- package/libc/include/any-linux-any/linux/vmclock-abi.h +20 -0
- package/libc/include/any-linux-any/rdma/bnxt_re-abi.h +16 -0
- package/libc/include/any-linux-any/rdma/ib_user_ioctl_cmds.h +16 -0
- package/libc/include/any-linux-any/rdma/mana-abi.h +3 -0
- package/libc/include/any-linux-any/scsi/scsi_bsg_ufs.h +8 -9
- package/libc/include/any-linux-any/sound/sof/tokens.h +6 -0
- package/libc/include/arc-linux-any/asm/swab.h +0 -63
- package/libc/include/arc-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/arm-linux-any/asm/ptrace.h +0 -9
- package/libc/include/arm-linux-any/asm/unistd-eabi.h +1 -0
- package/libc/include/arm-linux-any/asm/unistd-oabi.h +1 -0
- package/libc/include/csky-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/hexagon-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/loongarch-linux-any/asm/hwcap.h +1 -0
- package/libc/include/loongarch-linux-any/asm/kvm.h +1 -0
- package/libc/include/loongarch-linux-any/asm/kvm_para.h +1 -0
- package/libc/include/loongarch-linux-any/asm/unistd_32.h +2 -0
- package/libc/include/loongarch-linux-any/asm/unistd_64.h +2 -0
- package/libc/include/m68k-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/mips-linux-any/asm/errno.h +2 -0
- package/libc/include/mips-linux-any/asm/unistd_n32.h +1 -0
- package/libc/include/mips-linux-any/asm/unistd_n64.h +1 -0
- package/libc/include/mips-linux-any/asm/unistd_o32.h +1 -0
- package/libc/include/powerpc-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/powerpc-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/riscv-linux-any/asm/hwprobe.h +4 -0
- package/libc/include/riscv-linux-any/asm/kvm.h +3 -0
- package/libc/include/riscv-linux-any/asm/ptrace.h +37 -0
- package/libc/include/riscv-linux-any/asm/sigcontext.h +1 -0
- package/libc/include/riscv-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/riscv-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/s390x-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/sparc-linux-any/asm/errno.h +2 -0
- package/libc/include/sparc-linux-any/asm/ioctls.h +4 -4
- package/libc/include/sparc-linux-any/asm/unistd_32.h +2 -0
- package/libc/include/sparc-linux-any/asm/unistd_64.h +2 -0
- package/libc/include/x86-linux-any/asm/auxvec.h +0 -4
- package/libc/include/x86-linux-any/asm/kvm.h +13 -8
- package/libc/include/x86-linux-any/asm/svm.h +16 -16
- package/libc/include/x86-linux-any/asm/unistd_32.h +1 -0
- package/libc/include/x86-linux-any/asm/unistd_64.h +1 -0
- package/libc/include/x86-linux-any/asm/unistd_x32.h +1 -0
- package/libc/include/xtensa-linux-any/asm/unistd_32.h +1 -0
- package/libcxx/include/__algorithm/all_of.h +11 -5
- package/libcxx/include/__algorithm/comp.h +4 -0
- package/libcxx/include/__algorithm/copy.h +28 -147
- package/libcxx/include/__algorithm/copy_backward.h +9 -24
- package/libcxx/include/__algorithm/copy_n.h +50 -16
- package/libcxx/include/__algorithm/count.h +2 -2
- package/libcxx/include/__algorithm/equal.h +43 -55
- package/libcxx/include/__algorithm/fill.h +26 -8
- package/libcxx/include/__algorithm/fill_n.h +32 -46
- package/libcxx/include/__algorithm/find.h +96 -39
- package/libcxx/include/__algorithm/find_end.h +105 -0
- package/libcxx/include/__algorithm/for_each.h +18 -24
- package/libcxx/include/__algorithm/for_each_n.h +20 -47
- package/libcxx/include/__algorithm/for_each_n_segment.h +1 -1
- package/libcxx/include/__algorithm/for_each_segment.h +26 -0
- package/libcxx/include/__algorithm/generate.h +4 -2
- package/libcxx/include/__algorithm/generate_n.h +19 -6
- package/libcxx/include/__algorithm/is_permutation.h +4 -4
- package/libcxx/include/__algorithm/iterator_operations.h +3 -0
- package/libcxx/include/__algorithm/lexicographical_compare.h +2 -2
- package/libcxx/include/__algorithm/lexicographical_compare_three_way.h +6 -6
- package/libcxx/include/__algorithm/make_heap.h +16 -4
- package/libcxx/include/__algorithm/mismatch.h +2 -2
- package/libcxx/include/__algorithm/move.h +8 -19
- package/libcxx/include/__algorithm/move_backward.h +9 -24
- package/libcxx/include/__algorithm/none_of.h +4 -4
- package/libcxx/include/__algorithm/partial_sort.h +1 -1
- package/libcxx/include/__algorithm/partial_sort_copy.h +1 -1
- package/libcxx/include/__algorithm/pstl.h +9 -9
- package/libcxx/include/__algorithm/radix_sort.h +27 -25
- package/libcxx/include/__algorithm/ranges_copy_n.h +3 -26
- package/libcxx/include/__algorithm/ranges_equal.h +17 -26
- package/libcxx/include/__algorithm/ranges_fill.h +7 -6
- package/libcxx/include/__algorithm/ranges_for_each.h +9 -1
- package/libcxx/include/__algorithm/ranges_generate_n.h +2 -6
- package/libcxx/include/__algorithm/ranges_search_n.h +2 -2
- package/libcxx/include/__algorithm/rotate.h +27 -44
- package/libcxx/include/__algorithm/search_n.h +49 -37
- package/libcxx/include/__algorithm/sift_down.h +19 -18
- package/libcxx/include/__algorithm/simd_utils.h +33 -4
- package/libcxx/include/__algorithm/specialized_algorithms.h +54 -0
- package/libcxx/include/__algorithm/stable_sort.h +1 -1
- package/libcxx/include/__assertion_handler +31 -4
- package/libcxx/include/__atomic/atomic.h +36 -60
- package/libcxx/include/__atomic/atomic_flag.h +19 -37
- package/libcxx/include/__atomic/atomic_ref.h +29 -12
- package/libcxx/include/__atomic/atomic_sync.h +127 -55
- package/libcxx/include/__atomic/atomic_sync_timed.h +144 -0
- package/libcxx/include/__atomic/atomic_waitable_traits.h +103 -0
- package/libcxx/include/__atomic/contention_t.h +27 -3
- package/libcxx/include/__atomic/floating_point_helper.h +55 -0
- package/libcxx/include/__bit/countl.h +1 -2
- package/libcxx/include/__bit/countr.h +1 -2
- package/libcxx/include/__bit/has_single_bit.h +1 -1
- package/libcxx/include/__bit/popcount.h +0 -1
- package/libcxx/include/__bit/rotate.h +15 -26
- package/libcxx/include/__bit_reference +207 -18
- package/libcxx/include/__charconv/from_chars_integral.h +1 -1
- package/libcxx/include/__charconv/from_chars_result.h +1 -1
- package/libcxx/include/__charconv/to_chars_integral.h +1 -0
- package/libcxx/include/__charconv/to_chars_result.h +1 -1
- package/libcxx/include/__charconv/traits.h +3 -24
- package/libcxx/include/__chrono/day.h +11 -0
- package/libcxx/include/__chrono/duration.h +58 -33
- package/libcxx/include/__chrono/file_clock.h +4 -2
- package/libcxx/include/__chrono/is_clock.h +72 -0
- package/libcxx/include/__chrono/leap_second.h +13 -0
- package/libcxx/include/__chrono/month.h +13 -0
- package/libcxx/include/__chrono/month_weekday.h +22 -0
- package/libcxx/include/__chrono/monthday.h +20 -0
- package/libcxx/include/__chrono/steady_clock.h +1 -1
- package/libcxx/include/__chrono/system_clock.h +3 -3
- package/libcxx/include/__chrono/time_point.h +37 -13
- package/libcxx/include/__chrono/weekday.h +25 -0
- package/libcxx/include/__chrono/year.h +11 -0
- package/libcxx/include/__chrono/year_month.h +13 -0
- package/libcxx/include/__chrono/year_month_day.h +23 -0
- package/libcxx/include/__chrono/year_month_weekday.h +26 -0
- package/libcxx/include/__chrono/zoned_time.h +16 -0
- package/libcxx/include/__compare/is_eq.h +6 -6
- package/libcxx/include/__compare/strong_order.h +12 -30
- package/libcxx/include/__compare/three_way_comparable.h +2 -2
- package/libcxx/include/__concepts/comparison_common_type.h +40 -0
- package/libcxx/include/__concepts/equality_comparable.h +2 -1
- package/libcxx/include/__condition_variable/condition_variable.h +1 -1
- package/libcxx/include/__config +63 -280
- package/libcxx/include/__configuration/abi.h +14 -24
- package/libcxx/include/__configuration/availability.h +65 -118
- package/libcxx/include/__configuration/compiler.h +6 -6
- package/libcxx/include/__configuration/experimental.h +38 -0
- package/libcxx/include/__configuration/hardening.h +215 -0
- package/libcxx/include/__configuration/language.h +3 -0
- package/libcxx/include/__configuration/platform.h +9 -16
- package/libcxx/include/__coroutine/coroutine_handle.h +9 -9
- package/libcxx/include/__coroutine/noop_coroutine_handle.h +11 -13
- package/libcxx/include/__debug_utils/strict_weak_ordering_check.h +1 -1
- package/libcxx/include/__exception/exception.h +6 -4
- package/libcxx/include/__exception/exception_ptr.h +27 -5
- package/libcxx/include/__exception/nested_exception.h +2 -2
- package/libcxx/include/__exception/operations.h +5 -5
- package/libcxx/include/__expected/bad_expected_access.h +8 -6
- package/libcxx/include/__expected/expected.h +62 -64
- package/libcxx/include/__expected/unexpected.h +4 -4
- package/libcxx/include/__filesystem/copy_options.h +4 -4
- package/libcxx/include/__filesystem/directory_entry.h +37 -33
- package/libcxx/include/__filesystem/directory_iterator.h +9 -11
- package/libcxx/include/__filesystem/directory_options.h +7 -4
- package/libcxx/include/__filesystem/file_status.h +3 -3
- package/libcxx/include/__filesystem/filesystem_error.h +9 -10
- package/libcxx/include/__filesystem/operations.h +97 -66
- package/libcxx/include/__filesystem/path.h +68 -64
- package/libcxx/include/__filesystem/path_iterator.h +1 -3
- package/libcxx/include/__filesystem/perm_options.h +4 -4
- package/libcxx/include/__filesystem/perms.h +4 -4
- package/libcxx/include/__filesystem/recursive_directory_iterator.h +9 -14
- package/libcxx/include/__filesystem/space_info.h +1 -1
- package/libcxx/include/__filesystem/u8path.h +12 -14
- package/libcxx/include/__flat_map/flat_map.h +88 -71
- package/libcxx/include/__flat_map/flat_multimap.h +251 -172
- package/libcxx/include/__flat_map/key_value_iterator.h +0 -1
- package/libcxx/include/__flat_map/utils.h +1 -0
- package/libcxx/include/__flat_set/flat_multiset.h +211 -143
- package/libcxx/include/__flat_set/flat_set.h +86 -68
- package/libcxx/include/__format/concepts.h +0 -14
- package/libcxx/include/__format/extended_grapheme_cluster_table.h +3 -2
- package/libcxx/include/__format/fmt_pair_like.h +42 -0
- package/libcxx/include/__format/format_arg.h +7 -10
- package/libcxx/include/__format/format_args.h +1 -1
- package/libcxx/include/__format/format_context.h +5 -5
- package/libcxx/include/__format/format_parse_context.h +2 -2
- package/libcxx/include/__format/formatter_output.h +30 -34
- package/libcxx/include/__format/indic_conjunct_break_table.h +3 -2
- package/libcxx/include/__format/range_default_formatter.h +2 -41
- package/libcxx/include/__format/range_format.h +71 -0
- package/libcxx/include/__format/range_formatter.h +1 -0
- package/libcxx/include/__format/width_estimation_table.h +4 -2
- package/libcxx/include/__functional/bind.h +10 -15
- package/libcxx/include/__functional/bind_back.h +1 -1
- package/libcxx/include/__functional/bind_front.h +1 -1
- package/libcxx/include/__functional/function.h +57 -75
- package/libcxx/include/__functional/hash.h +1 -10
- package/libcxx/include/__functional/identity.h +1 -1
- package/libcxx/include/__functional/is_transparent.h +8 -0
- package/libcxx/include/__functional/mem_fn.h +2 -1
- package/libcxx/include/__functional/operations.h +18 -0
- package/libcxx/include/__functional/ranges_operations.h +7 -0
- package/libcxx/include/__functional/reference_wrapper.h +7 -5
- package/libcxx/include/__functional/weak_result_type.h +14 -28
- package/libcxx/include/__fwd/ios.h +1 -1
- package/libcxx/include/__fwd/tuple.h +14 -0
- package/libcxx/include/__hash_table +371 -357
- package/libcxx/include/__ios/fpos.h +4 -4
- package/libcxx/include/__iterator/back_insert_iterator.h +1 -7
- package/libcxx/include/__iterator/bounded_iter.h +7 -8
- package/libcxx/include/__iterator/concepts.h +6 -9
- package/libcxx/include/__iterator/cpp17_iterator_concepts.h +13 -12
- package/libcxx/include/__iterator/distance.h +40 -18
- package/libcxx/include/__iterator/front_insert_iterator.h +1 -7
- package/libcxx/include/__iterator/insert_iterator.h +1 -7
- package/libcxx/include/__iterator/istream_iterator.h +6 -7
- package/libcxx/include/__iterator/istreambuf_iterator.h +6 -7
- package/libcxx/include/__iterator/iter_move.h +1 -1
- package/libcxx/include/__iterator/iterator.h +13 -0
- package/libcxx/include/__iterator/iterator_traits.h +13 -14
- package/libcxx/include/__iterator/ostream_iterator.h +1 -7
- package/libcxx/include/__iterator/ostreambuf_iterator.h +1 -7
- package/libcxx/include/__iterator/reverse_iterator.h +8 -13
- package/libcxx/include/__iterator/segmented_iterator.h +3 -8
- package/libcxx/include/__iterator/static_bounded_iter.h +3 -3
- package/libcxx/include/__iterator/wrap_iter.h +8 -6
- package/libcxx/include/__locale +3 -10
- package/libcxx/include/__locale_dir/locale_base_api/bsd_locale_fallbacks.h +0 -10
- package/libcxx/include/__locale_dir/locale_base_api.h +5 -28
- package/libcxx/include/__locale_dir/messages.h +1 -1
- package/libcxx/include/__locale_dir/money.h +2 -2
- package/libcxx/include/__locale_dir/num.h +190 -243
- package/libcxx/include/__locale_dir/pad_and_output.h +5 -6
- package/libcxx/include/__locale_dir/support/bsd_like.h +0 -20
- package/libcxx/include/__locale_dir/support/fuchsia.h +0 -7
- package/libcxx/include/__locale_dir/support/linux.h +0 -37
- package/libcxx/include/__locale_dir/support/netbsd.h +0 -2
- package/libcxx/include/__locale_dir/support/newlib.h +243 -0
- package/libcxx/include/__locale_dir/support/no_locale/characters.h +0 -4
- package/libcxx/include/__locale_dir/support/no_locale/strtonum.h +0 -9
- package/libcxx/include/__locale_dir/support/windows.h +0 -29
- package/libcxx/include/__locale_dir/time.h +3 -7
- package/libcxx/include/__math/hypot.h +1 -1
- package/libcxx/include/__math/logarithms.h +1 -1
- package/libcxx/include/__math/traits.h +80 -11
- package/libcxx/include/__mdspan/extents.h +7 -4
- package/libcxx/include/__mdspan/layout_stride.h +4 -5
- package/libcxx/include/__mdspan/mdspan.h +29 -23
- package/libcxx/include/__memory/addressof.h +7 -5
- package/libcxx/include/__memory/align.h +18 -1
- package/libcxx/include/__memory/allocate_at_least.h +15 -10
- package/libcxx/include/__memory/allocator.h +14 -26
- package/libcxx/include/__memory/allocator_traits.h +6 -4
- package/libcxx/include/__memory/compressed_pair.h +15 -9
- package/libcxx/include/__memory/construct_at.h +12 -23
- package/libcxx/include/__memory/inout_ptr.h +1 -1
- package/libcxx/include/__memory/is_sufficiently_aligned.h +1 -1
- package/libcxx/include/__memory/out_ptr.h +1 -1
- package/libcxx/include/__memory/pointer_traits.h +1 -1
- package/libcxx/include/__memory/raw_storage_iterator.h +3 -9
- package/libcxx/include/__memory/shared_count.h +9 -30
- package/libcxx/include/__memory/shared_ptr.h +100 -145
- package/libcxx/include/__memory/temp_value.h +1 -2
- package/libcxx/include/__memory/uninitialized_algorithms.h +44 -115
- package/libcxx/include/__memory/unique_ptr.h +14 -16
- package/libcxx/include/__memory/uses_allocator_construction.h +1 -0
- package/libcxx/include/__memory_resource/memory_resource.h +4 -2
- package/libcxx/include/__memory_resource/monotonic_buffer_resource.h +1 -1
- package/libcxx/include/__memory_resource/polymorphic_allocator.h +13 -8
- package/libcxx/include/__memory_resource/pool_options.h +1 -1
- package/libcxx/include/__memory_resource/synchronized_pool_resource.h +4 -2
- package/libcxx/include/__memory_resource/unsynchronized_pool_resource.h +1 -1
- package/libcxx/include/__mutex/mutex.h +2 -2
- package/libcxx/include/__mutex/once_flag.h +14 -11
- package/libcxx/include/__mutex/tag_types.h +3 -3
- package/libcxx/include/__mutex/unique_lock.h +8 -7
- package/libcxx/include/__new/align_val_t.h +6 -0
- package/libcxx/include/__new/allocate.h +1 -2
- package/libcxx/include/__new/exceptions.h +8 -2
- package/libcxx/include/__new/global_new_delete.h +4 -11
- package/libcxx/include/__new/interference_size.h +0 -4
- package/libcxx/include/__new/launder.h +3 -5
- package/libcxx/include/__new/nothrow_t.h +1 -1
- package/libcxx/include/__numeric/gcd_lcm.h +24 -34
- package/libcxx/include/__numeric/midpoint.h +9 -14
- package/libcxx/include/__numeric/pstl.h +2 -2
- package/libcxx/include/__numeric/saturation_arithmetic.h +13 -5
- package/libcxx/include/__ostream/basic_ostream.h +8 -8
- package/libcxx/include/__pstl/backends/default.h +14 -14
- package/libcxx/include/__pstl/backends/libdispatch.h +2 -2
- package/libcxx/include/__pstl/cpu_algos/find_if.h +1 -1
- package/libcxx/include/__pstl/cpu_algos/transform.h +5 -6
- package/libcxx/include/__pstl/cpu_algos/transform_reduce.h +5 -4
- package/libcxx/include/__random/binomial_distribution.h +10 -4
- package/libcxx/include/__random/mersenne_twister_engine.h +50 -154
- package/libcxx/include/__random/piecewise_constant_distribution.h +3 -2
- package/libcxx/include/__random/piecewise_linear_distribution.h +3 -2
- package/libcxx/include/__ranges/adjacent_transform_view.h +406 -0
- package/libcxx/include/__ranges/adjacent_view.h +419 -0
- package/libcxx/include/__ranges/as_rvalue_view.h +9 -9
- package/libcxx/include/__ranges/chunk_by_view.h +6 -6
- package/libcxx/include/__ranges/common_view.h +7 -7
- package/libcxx/include/__ranges/drop_view.h +8 -8
- package/libcxx/include/__ranges/drop_while_view.h +5 -5
- package/libcxx/include/__ranges/elements_of.h +49 -0
- package/libcxx/include/__ranges/empty_view.h +5 -5
- package/libcxx/include/__ranges/filter_view.h +10 -10
- package/libcxx/include/__ranges/iota_view.h +41 -22
- package/libcxx/include/__ranges/owning_view.h +15 -15
- package/libcxx/include/__ranges/ref_view.h +6 -6
- package/libcxx/include/__ranges/repeat_view.h +17 -10
- package/libcxx/include/__ranges/single_view.h +8 -8
- package/libcxx/include/__ranges/take_view.h +9 -9
- package/libcxx/include/__ranges/transform_view.h +1 -2
- package/libcxx/include/__ranges/view_interface.h +10 -10
- package/libcxx/include/__ranges/zip_transform_view.h +357 -0
- package/libcxx/include/__ranges/zip_view.h +20 -20
- package/libcxx/include/__split_buffer +612 -240
- package/libcxx/include/__stop_token/atomic_unique_lock.h +1 -1
- package/libcxx/include/__stop_token/stop_callback.h +2 -2
- package/libcxx/include/__stop_token/stop_source.h +1 -1
- package/libcxx/include/__stop_token/stop_state.h +4 -4
- package/libcxx/include/__stop_token/stop_token.h +1 -1
- package/libcxx/include/__string/char_traits.h +51 -31
- package/libcxx/include/__string/constexpr_c_functions.h +5 -5
- package/libcxx/include/__support/xlocale/__strtonum_fallback.h +0 -8
- package/libcxx/include/__system_error/error_category.h +8 -8
- package/libcxx/include/__system_error/error_code.h +5 -5
- package/libcxx/include/__system_error/error_condition.h +4 -4
- package/libcxx/include/__system_error/system_error.h +1 -1
- package/libcxx/include/__thread/id.h +1 -1
- package/libcxx/include/__thread/jthread.h +1 -1
- package/libcxx/include/__thread/poll_with_backoff.h +27 -8
- package/libcxx/include/__thread/support/c11.h +8 -8
- package/libcxx/include/__thread/support/pthread.h +8 -8
- package/libcxx/include/__thread/support/windows.h +8 -8
- package/libcxx/include/__thread/thread.h +13 -8
- package/libcxx/include/__thread/timed_backoff_policy.h +3 -2
- package/libcxx/include/__tree +849 -701
- package/libcxx/include/__tuple/sfinae_helpers.h +1 -44
- package/libcxx/include/__tuple/tuple_element.h +0 -12
- package/libcxx/include/__tuple/tuple_size.h +0 -4
- package/libcxx/include/__tuple/tuple_transform.h +45 -0
- package/libcxx/include/__type_traits/aligned_storage.h +13 -40
- package/libcxx/include/__type_traits/desugars_to.h +4 -0
- package/libcxx/include/__type_traits/invoke.h +8 -0
- package/libcxx/include/__type_traits/is_allocator.h +6 -7
- package/libcxx/include/__type_traits/is_array.h +26 -0
- package/libcxx/include/__type_traits/is_equality_comparable.h +16 -21
- package/libcxx/include/__type_traits/is_final.h +1 -1
- package/libcxx/include/__type_traits/is_floating_point.h +7 -6
- package/libcxx/include/__type_traits/is_generic_transparent_comparator.h +30 -0
- package/libcxx/include/__type_traits/is_specialization.h +2 -6
- package/libcxx/include/__type_traits/is_within_lifetime.h +29 -0
- package/libcxx/include/__type_traits/make_transparent.h +52 -0
- package/libcxx/include/__type_traits/reference_constructs_from_temporary.h +1 -7
- package/libcxx/include/__type_traits/reference_converts_from_temporary.h +1 -1
- package/libcxx/include/__utility/cmp.h +19 -7
- package/libcxx/include/__utility/default_three_way_comparator.h +70 -0
- package/libcxx/include/__utility/in_place.h +1 -1
- package/libcxx/include/__utility/integer_sequence.h +56 -41
- package/libcxx/include/__utility/lazy_synth_three_way_comparator.h +120 -0
- package/libcxx/include/__utility/pair.h +22 -25
- package/libcxx/include/__utility/scope_guard.h +2 -0
- package/libcxx/include/__utility/try_key_extraction.h +114 -0
- package/libcxx/include/__vector/vector.h +187 -160
- package/libcxx/include/__vector/vector_bool.h +76 -83
- package/libcxx/include/any +118 -155
- package/libcxx/include/array +88 -56
- package/libcxx/include/atomic +2 -0
- package/libcxx/include/barrier +20 -24
- package/libcxx/include/bitset +49 -30
- package/libcxx/include/ccomplex +3 -11
- package/libcxx/include/chrono +47 -0
- package/libcxx/include/ciso646 +3 -6
- package/libcxx/include/complex +77 -65
- package/libcxx/include/complex.h +10 -10
- package/libcxx/include/condition_variable +3 -3
- package/libcxx/include/cstdalign +3 -10
- package/libcxx/include/cstdbool +3 -10
- package/libcxx/include/ctgmath +2 -11
- package/libcxx/include/ctype.h +24 -24
- package/libcxx/include/cwchar +2 -2
- package/libcxx/include/deque +109 -225
- package/libcxx/include/errno.h +269 -269
- package/libcxx/include/exception +4 -1
- package/libcxx/include/ext/hash_map +7 -48
- package/libcxx/include/ext/hash_set +2 -8
- package/libcxx/include/fenv.h +43 -43
- package/libcxx/include/flat_map +663 -11
- package/libcxx/include/flat_set +543 -8
- package/libcxx/include/float.h +16 -16
- package/libcxx/include/forward_list +33 -53
- package/libcxx/include/fstream +57 -42
- package/libcxx/include/future +41 -51
- package/libcxx/include/initializer_list +9 -3
- package/libcxx/include/inttypes.h +16 -16
- package/libcxx/include/ios +28 -28
- package/libcxx/include/istream +19 -13
- package/libcxx/include/iterator +10 -0
- package/libcxx/include/latch +7 -5
- package/libcxx/include/limits +4 -4
- package/libcxx/include/list +61 -79
- package/libcxx/include/map +386 -274
- package/libcxx/include/math.h +19 -0
- package/libcxx/include/mdspan +1 -5
- package/libcxx/include/mutex +29 -19
- package/libcxx/include/optional +644 -149
- package/libcxx/include/print +9 -5
- package/libcxx/include/queue +39 -37
- package/libcxx/include/ranges +48 -0
- package/libcxx/include/regex +33 -31
- package/libcxx/include/scoped_allocator +16 -11
- package/libcxx/include/semaphore +15 -18
- package/libcxx/include/set +220 -192
- package/libcxx/include/shared_mutex +3 -8
- package/libcxx/include/span +53 -37
- package/libcxx/include/sstream +34 -28
- package/libcxx/include/stack +13 -15
- package/libcxx/include/stddef.h +10 -10
- package/libcxx/include/stdexcept +2 -2
- package/libcxx/include/stdio.h +20 -21
- package/libcxx/include/streambuf +59 -19
- package/libcxx/include/string +574 -573
- package/libcxx/include/string_view +113 -89
- package/libcxx/include/strstream +10 -10
- package/libcxx/include/syncstream +4 -4
- package/libcxx/include/tgmath.h +12 -12
- package/libcxx/include/tuple +242 -212
- package/libcxx/include/type_traits +8 -2
- package/libcxx/include/typeindex +5 -3
- package/libcxx/include/typeinfo +92 -89
- package/libcxx/include/unordered_map +179 -304
- package/libcxx/include/unordered_set +168 -195
- package/libcxx/include/utility +12 -0
- package/libcxx/include/valarray +106 -161
- package/libcxx/include/variant +25 -33
- package/libcxx/include/version +41 -24
- package/libcxx/include/wctype.h +29 -29
- package/libcxx/src/any.cpp +4 -0
- package/libcxx/src/atomic.cpp +365 -80
- package/libcxx/src/barrier.cpp +4 -3
- package/libcxx/src/charconv.cpp +6 -3
- package/libcxx/src/condition_variable_destructor.cpp +1 -1
- package/libcxx/src/error_category.cpp +3 -1
- package/libcxx/src/exception.cpp +2 -10
- package/libcxx/src/experimental/time_zone.cpp +1 -1
- package/libcxx/src/experimental/tzdb.cpp +4 -1
- package/libcxx/src/filesystem/error.h +4 -22
- package/libcxx/src/filesystem/format_string.h +9 -18
- package/libcxx/src/filesystem/int128_builtins.cpp +2 -0
- package/libcxx/src/filesystem/operations.cpp +2 -9
- package/libcxx/src/filesystem/path.cpp +3 -1
- package/libcxx/src/include/aligned_alloc.h +65 -0
- package/libcxx/src/include/config_elast.h +1 -1
- package/libcxx/src/include/from_chars_floating_point.h +11 -7
- package/libcxx/src/include/overridable_function.h +8 -10
- package/libcxx/src/iostream.cpp +56 -37
- package/libcxx/src/locale.cpp +213 -196
- package/libcxx/src/memory.cpp +12 -14
- package/libcxx/src/mutex_destructor.cpp +1 -1
- package/libcxx/src/new.cpp +5 -5
- package/libcxx/src/optional.cpp +4 -0
- package/libcxx/src/print.cpp +9 -1
- package/libcxx/src/random.cpp +0 -26
- package/libcxx/src/string.cpp +10 -25
- package/libcxx/src/support/runtime/exception_fallback.ipp +2 -0
- package/libcxx/src/support/runtime/exception_glibcxx.ipp +3 -0
- package/libcxx/src/support/runtime/exception_libcxxabi.ipp +6 -2
- package/libcxx/src/support/runtime/exception_libcxxrt.ipp +2 -0
- package/libcxx/src/support/runtime/exception_msvc.ipp +2 -0
- package/libcxx/src/support/runtime/exception_pointer_cxxabi.ipp +9 -10
- package/libcxx/src/support/runtime/exception_pointer_glibcxx.ipp +2 -0
- package/libcxx/src/support/runtime/exception_pointer_msvc.ipp +1 -0
- package/libcxx/src/support/runtime/exception_pointer_unimplemented.ipp +1 -0
- package/libcxx/src/support/win32/locale_win32.cpp +1 -1
- package/libcxx/src/system_error.cpp +2 -0
- package/libcxx/src/thread.cpp +1 -3
- package/libcxx/src/valarray.cpp +1 -2
- package/libcxx/src/vector.cpp +2 -2
- package/libcxxabi/include/__cxxabi_config.h +42 -23
- package/libcxxabi/src/cxa_exception.cpp +4 -2
- package/libcxxabi/src/cxa_exception.h +16 -14
- package/libcxxabi/src/cxa_personality.cpp +126 -9
- package/libcxxabi/src/cxa_thread_atexit.cpp +2 -1
- package/libcxxabi/src/demangle/DemangleConfig.h +4 -0
- package/libcxxabi/src/demangle/ItaniumDemangle.h +9 -6
- package/libcxxabi/src/demangle/Utility.h +21 -7
- package/libcxxabi/src/fallback_malloc.cpp +1 -1
- package/libcxxabi/src/private_typeinfo.cpp +6 -0
- package/libcxxabi/src/stdlib_new_delete.cpp +5 -5
- package/libtsan/LICENSE.TXT +311 -0
- package/libtsan/builtins/assembly.h +41 -8
- package/libtsan/interception/interception_win.cpp +4 -0
- package/libtsan/sanitizer_common/sanitizer_allocator_primary32.h +1 -0
- package/libtsan/sanitizer_common/sanitizer_allocator_primary64.h +18 -0
- package/libtsan/sanitizer_common/sanitizer_common.h +15 -2
- package/libtsan/sanitizer_common/sanitizer_common_interceptors.inc +30 -4
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_ioctl.inc +4 -0
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_aarch64.inc.S +2 -1
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_i386.inc.S +2 -0
- package/libtsan/sanitizer_common/sanitizer_common_interceptors_vfork_x86_64.inc.S +2 -0
- package/libtsan/sanitizer_common/sanitizer_common_syscalls.inc +18 -0
- package/libtsan/sanitizer_common/sanitizer_file.cpp +40 -12
- package/libtsan/sanitizer_common/sanitizer_file.h +3 -0
- package/libtsan/sanitizer_common/sanitizer_flags.inc +7 -0
- package/libtsan/sanitizer_common/sanitizer_fuchsia.cpp +30 -3
- package/libtsan/sanitizer_common/sanitizer_haiku.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_internal_defs.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_libc.cpp +8 -0
- package/libtsan/sanitizer_common/sanitizer_libc.h +1 -0
- package/libtsan/sanitizer_common/sanitizer_linux.cpp +15 -7
- package/libtsan/sanitizer_common/sanitizer_linux.h +3 -3
- package/libtsan/sanitizer_common/sanitizer_linux_libcdep.cpp +1 -0
- package/libtsan/sanitizer_common/sanitizer_mac.cpp +255 -104
- package/libtsan/sanitizer_common/sanitizer_mac.h +5 -0
- package/libtsan/sanitizer_common/sanitizer_netbsd.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_platform.h +27 -1
- package/libtsan/sanitizer_common/sanitizer_platform_interceptors.h +5 -4
- package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.cpp +15 -17
- package/libtsan/sanitizer_common/sanitizer_platform_limits_posix.h +32 -6
- package/libtsan/sanitizer_common/sanitizer_posix.cpp +3 -12
- package/libtsan/sanitizer_common/sanitizer_posix.h +2 -1
- package/libtsan/sanitizer_common/sanitizer_posix_libcdep.cpp +19 -0
- package/libtsan/sanitizer_common/sanitizer_procmaps_mac.cpp +102 -37
- package/libtsan/sanitizer_common/sanitizer_redefine_builtins.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_signal_interceptors.inc +40 -2
- package/libtsan/sanitizer_common/sanitizer_stoptheworld.h +1 -1
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_linux_libcdep.cpp +83 -12
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_mac.cpp +3 -3
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_netbsd_libcdep.cpp +7 -7
- package/libtsan/sanitizer_common/sanitizer_stoptheworld_win.cpp +2 -2
- package/libtsan/sanitizer_common/sanitizer_symbolizer_internal.h +5 -1
- package/libtsan/sanitizer_common/sanitizer_symbolizer_libcdep.cpp +11 -1
- package/libtsan/sanitizer_common/sanitizer_symbolizer_mac.cpp +86 -29
- package/libtsan/sanitizer_common/sanitizer_symbolizer_posix_libcdep.cpp +27 -16
- package/libtsan/sanitizer_common/sanitizer_thread_registry.cpp +5 -4
- package/libtsan/sanitizer_common/sanitizer_thread_registry.h +4 -4
- package/libtsan/sanitizer_common/sanitizer_win.cpp +1 -3
- package/libtsan/tsan_debugging.cpp +2 -2
- package/libtsan/tsan_flags.cpp +37 -0
- package/libtsan/tsan_flags.h +8 -0
- package/libtsan/tsan_flags.inc +12 -0
- package/libtsan/tsan_interceptors.h +9 -1
- package/libtsan/tsan_interceptors_mac.cpp +19 -0
- package/libtsan/tsan_interceptors_posix.cpp +78 -32
- package/libtsan/tsan_interface.h +3 -3
- package/libtsan/tsan_interface_ann.cpp +23 -9
- package/libtsan/tsan_mman.cpp +18 -4
- package/libtsan/tsan_platform.h +44 -7
- package/libtsan/tsan_platform_linux.cpp +42 -14
- package/libtsan/tsan_platform_mac.cpp +16 -3
- package/libtsan/tsan_report.h +14 -1
- package/libtsan/tsan_rtl.cpp +14 -0
- package/libtsan/tsan_rtl.h +7 -2
- package/libtsan/tsan_rtl_aarch64.S +3 -5
- package/libtsan/tsan_rtl_access.cpp +8 -3
- package/libtsan/tsan_rtl_amd64.S +2 -0
- package/libtsan/tsan_rtl_mutex.cpp +94 -49
- package/libtsan/tsan_rtl_report.cpp +132 -65
- package/libtsan/tsan_rtl_thread.cpp +31 -9
- package/libtsan/tsan_symbolize.cpp +1 -1
- package/libtsan/tsan_symbolize.h +1 -1
- package/libtsan/tsan_trace.h +1 -1
- package/libunwind/include/__libunwind_config.h +11 -2
- package/libunwind/include/libunwind.h +117 -11
- package/libunwind/include/unwind_arm_ehabi.h +4 -1
- package/libunwind/src/AddressSpace.hpp +40 -19
- package/libunwind/src/CompactUnwinder.hpp +16 -5
- package/libunwind/src/DwarfInstructions.hpp +24 -13
- package/libunwind/src/DwarfParser.hpp +60 -22
- package/libunwind/src/EHHeaderParser.hpp +7 -4
- package/libunwind/src/Registers.hpp +226 -22
- package/libunwind/src/Unwind-seh.cpp +6 -7
- package/libunwind/src/Unwind-wasm.c +7 -7
- package/libunwind/src/UnwindCursor.hpp +167 -49
- package/libunwind/src/UnwindLevel1.c +46 -17
- package/libunwind/src/UnwindRegistersRestore.S +46 -5
- package/libunwind/src/UnwindRegistersSave.S +86 -2
- package/libunwind/src/assembly.h +5 -1
- package/libunwind/src/config.h +9 -0
- package/libunwind/src/gcc_personality_v0.c +79 -6
- package/libunwind/src/libunwind.cpp +104 -4
- package/libunwind/src/libunwind_ext.h +7 -1
- package/libunwind/src/shadow_stack_unwind.h +2 -2
- package/lldb/pretty_printers.py +948 -0
- package/package.json +1 -1
- package/std/Build/Step/Compile.zig +18 -19
- package/std/Build/Step/Run.zig +13 -6
- package/std/Build/Step.zig +0 -3
- package/std/Io/Threaded.zig +3 -0
- package/std/Target/aarch64.zig +620 -77
- package/std/Target/amdgcn.zig +421 -21
- package/std/Target/arm.zig +40 -6
- package/std/Target/bpf.zig +6 -0
- package/std/Target/hexagon.zig +41 -6
- package/std/Target/loongarch.zig +18 -0
- package/std/Target/mips.zig +6 -0
- package/std/Target/nvptx.zig +58 -35
- package/std/Target/powerpc.zig +27 -19
- package/std/Target/riscv.zig +415 -177
- package/std/Target/sparc.zig +17 -0
- package/std/Target/wasm.zig +7 -0
- package/std/Target/x86.zig +200 -31
- package/std/Target/xtensa.zig +65 -0
- package/std/Target.zig +11 -2
- package/std/c.zig +7 -0
- package/std/debug/Dwarf.zig +14 -11
- package/std/debug/Pdb.zig +24 -16
- package/std/hash/xxhash.zig +0 -6
- package/std/math/log10.zig +0 -2
- package/std/math/modf.zig +0 -1
- package/std/mem.zig +1 -2
- package/std/os/linux/syscalls.zig +26 -1
- package/std/os/linux/x86.zig +2 -2
- package/std/os/windows.zig +130 -1
- package/std/simd.zig +4 -21
- package/std/start.zig +4 -3
- package/std/zig/Ast.zig +5 -7
- package/std/zig/AstGen.zig +20 -14
- package/std/zig/ErrorBundle.zig +6 -2
- package/std/zig/ZonGen.zig +13 -21
- package/std/zig/llvm/Builder.zig +2 -2
- package/std/zig/system/arm.zig +56 -2
- package/std/zig/system/windows.zig +34 -1
- package/std/zig/system/x86.zig +60 -16
- package/std/zig/system.zig +0 -10
- package/include/amxbf16transposeintrin.h +0 -94
- package/include/amxcomplextransposeintrin.h +0 -303
- package/include/amxfp16transposeintrin.h +0 -94
- package/include/amxmovrstransposeintrin.h +0 -200
- package/include/amxtf32transposeintrin.h +0 -105
- package/include/amxtransposeintrin.h +0 -248
- package/libc/include/hexagon-linux-any/asm/signal.h +0 -29
- package/libc/include/s390x-linux-any/asm/tape390.h +0 -103
- package/libtsan/sanitizer_common/sanitizer_coverage_interface.inc +0 -43
- package/std/Build/Step/CheckObject.zig +0 -2764
package/std/simd.zig
CHANGED
|
@@ -157,13 +157,6 @@ pub fn join(a: anytype, b: anytype) @Vector(vectorLength(@TypeOf(a)) + vectorLen
|
|
|
157
157
|
/// Returns a vector whose elements alternates between those of each input vector.
|
|
158
158
|
/// For example, `interlace(.{[4]u32{11, 12, 13, 14}, [4]u32{21, 22, 23, 24}})` returns a vector containing `.{11, 21, 12, 22, 13, 23, 14, 24}`.
|
|
159
159
|
pub fn interlace(vecs: anytype) @Vector(vectorLength(@TypeOf(vecs[0])) * vecs.len, std.meta.Child(@TypeOf(vecs[0]))) {
|
|
160
|
-
// interlace doesn't work on MIPS, for some reason.
|
|
161
|
-
// Notes from earlier debug attempt:
|
|
162
|
-
// The indices are correct. The problem seems to be with the @shuffle builtin.
|
|
163
|
-
// On MIPS, the test that interlaces small_base gives { 0, 2, 0, 0, 64, 255, 248, 200, 0, 0 }.
|
|
164
|
-
// Calling this with two inputs seems to work fine, but I'll let the compile error trigger for all inputs, just to be safe.
|
|
165
|
-
if (builtin.cpu.arch.isMIPS()) @compileError("TODO: Find out why interlace() doesn't work on MIPS");
|
|
166
|
-
|
|
167
160
|
const VecType = @TypeOf(vecs[0]);
|
|
168
161
|
const vecs_arr = @as([vecs.len]VecType, vecs);
|
|
169
162
|
const Child = std.meta.Child(@TypeOf(vecs_arr[0]));
|
|
@@ -247,13 +240,11 @@ test "vector patterns" {
|
|
|
247
240
|
try std.testing.expectEqual([8]u32{ 10, 20, 30, 40, 55, 66, 77, 88 }, join(base, other_base));
|
|
248
241
|
try std.testing.expectEqual([2]u32{ 20, 30 }, extract(base, 1, 2));
|
|
249
242
|
|
|
250
|
-
|
|
251
|
-
try std.testing.expectEqual([8]u32{ 10, 55, 20, 66, 30, 77, 40, 88 }, interlace(.{ base, other_base }));
|
|
243
|
+
try std.testing.expectEqual([8]u32{ 10, 55, 20, 66, 30, 77, 40, 88 }, interlace(.{ base, other_base }));
|
|
252
244
|
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
}
|
|
245
|
+
const small_braid = interlace(small_bases);
|
|
246
|
+
try std.testing.expectEqual([10]u8{ 0, 2, 4, 6, 8, 1, 3, 5, 7, 9 }, small_braid);
|
|
247
|
+
try std.testing.expectEqual(small_bases, deinterlace(small_bases.len, small_braid));
|
|
257
248
|
}
|
|
258
249
|
|
|
259
250
|
/// Joins two vectors, shifts them leftwards (towards lower indices) and extracts the leftmost elements into a vector the length of a and b.
|
|
@@ -384,9 +375,6 @@ pub fn prefixScanWithFunc(
|
|
|
384
375
|
/// For example, this should be 0 for addition or 1 for multiplication.
|
|
385
376
|
comptime identity: std.meta.Child(@TypeOf(vec)),
|
|
386
377
|
) if (ErrorType == void) @TypeOf(vec) else ErrorType!@TypeOf(vec) {
|
|
387
|
-
// I haven't debugged this, but it might be a cousin of sorts to what's going on with interlace.
|
|
388
|
-
if (builtin.cpu.arch.isMIPS()) @compileError("TODO: Find out why prefixScan doesn't work on MIPS");
|
|
389
|
-
|
|
390
378
|
const len = vectorLength(@TypeOf(vec));
|
|
391
379
|
|
|
392
380
|
if (hop == 0) @compileError("hop can not be 0; you'd be going nowhere forever!");
|
|
@@ -456,11 +444,6 @@ pub fn prefixScan(comptime op: std.builtin.ReduceOp, comptime hop: isize, vec: a
|
|
|
456
444
|
}
|
|
457
445
|
|
|
458
446
|
test "vector prefix scan" {
|
|
459
|
-
if (builtin.cpu.arch == .aarch64_be and builtin.zig_backend == .stage2_llvm) return error.SkipZigTest; // https://github.com/ziglang/zig/issues/21893
|
|
460
|
-
if (builtin.zig_backend == .stage2_llvm and builtin.cpu.arch == .hexagon) return error.SkipZigTest;
|
|
461
|
-
|
|
462
|
-
if (builtin.cpu.arch.isMIPS()) return error.SkipZigTest;
|
|
463
|
-
|
|
464
447
|
const int_base = @Vector(4, i32){ 11, 23, 9, -21 };
|
|
465
448
|
const float_base = @Vector(4, f32){ 2, 0.5, -10, 6.54321 };
|
|
466
449
|
const bool_base = @Vector(4, bool){ true, false, true, false };
|
package/std/start.zig
CHANGED
|
@@ -20,8 +20,9 @@ comptime {
|
|
|
20
20
|
_ = root;
|
|
21
21
|
|
|
22
22
|
if (builtin.output_mode == .Lib and builtin.link_mode == .dynamic) {
|
|
23
|
-
if (
|
|
24
|
-
|
|
23
|
+
const dll_main_crt_startup = if (builtin.abi.isGnu()) "DllMainCRTStartup" else "_DllMainCRTStartup";
|
|
24
|
+
if (native_os == .windows and !builtin.link_libc and !@hasDecl(root, dll_main_crt_startup)) {
|
|
25
|
+
@export(&DllMainCRTStartup, .{ .name = dll_main_crt_startup });
|
|
25
26
|
}
|
|
26
27
|
} else if (builtin.output_mode == .Exe or @hasDecl(root, "main")) {
|
|
27
28
|
if (builtin.link_libc and @hasDecl(root, "main")) {
|
|
@@ -71,7 +72,7 @@ comptime {
|
|
|
71
72
|
}
|
|
72
73
|
}
|
|
73
74
|
|
|
74
|
-
fn
|
|
75
|
+
fn DllMainCRTStartup(
|
|
75
76
|
hinstDLL: std.os.windows.HINSTANCE,
|
|
76
77
|
fdwReason: std.os.windows.DWORD,
|
|
77
78
|
lpReserved: std.os.windows.LPVOID,
|
package/std/zig/Ast.zig
CHANGED
|
@@ -196,19 +196,17 @@ pub fn parseTokens(
|
|
|
196
196
|
.zon => try parser.parseZon(),
|
|
197
197
|
}
|
|
198
198
|
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
const errors = try parser.errors.toOwnedSlice(gpa);
|
|
202
|
-
errdefer gpa.free(errors);
|
|
199
|
+
try parser.extra_data.shrinkToLen(gpa);
|
|
200
|
+
try parser.errors.shrinkToLen(gpa);
|
|
203
201
|
|
|
204
202
|
// TODO experiment with compacting the MultiArrayList slices here
|
|
205
|
-
return
|
|
203
|
+
return .{
|
|
206
204
|
.source = source,
|
|
207
205
|
.mode = mode,
|
|
208
206
|
.tokens = tokens,
|
|
209
207
|
.nodes = parser.nodes.toOwnedSlice(),
|
|
210
|
-
.extra_data = extra_data,
|
|
211
|
-
.errors = errors,
|
|
208
|
+
.extra_data = parser.extra_data.toOwnedSliceAssert(),
|
|
209
|
+
.errors = parser.errors.toOwnedSliceAssert(),
|
|
212
210
|
};
|
|
213
211
|
}
|
|
214
212
|
|
package/std/zig/AstGen.zig
CHANGED
|
@@ -243,10 +243,13 @@ pub fn generate(gpa: Allocator, tree: Ast) Allocator.Error!Zir {
|
|
|
243
243
|
}
|
|
244
244
|
}
|
|
245
245
|
|
|
246
|
+
try astgen.extra.shrinkToLen(gpa);
|
|
247
|
+
try astgen.string_bytes.shrinkToLen(gpa);
|
|
248
|
+
|
|
246
249
|
return .{
|
|
247
250
|
.instructions = if (fatal) .empty else astgen.instructions.toOwnedSlice(),
|
|
248
|
-
.string_bytes =
|
|
249
|
-
.extra =
|
|
251
|
+
.string_bytes = astgen.string_bytes.toOwnedSliceAssert(),
|
|
252
|
+
.extra = astgen.extra.toOwnedSliceAssert(),
|
|
250
253
|
};
|
|
251
254
|
}
|
|
252
255
|
|
|
@@ -4998,6 +5001,10 @@ fn structDeclInner(
|
|
|
4998
5001
|
);
|
|
4999
5002
|
if (field_comptime_bits) |bits| @memset(bits.get(astgen), 0);
|
|
5000
5003
|
|
|
5004
|
+
const old_hasher = astgen.src_hasher;
|
|
5005
|
+
defer astgen.src_hasher = old_hasher;
|
|
5006
|
+
astgen.src_hasher = .init(.{});
|
|
5007
|
+
|
|
5001
5008
|
// Before any field bodies comes the backing int type, if specified.
|
|
5002
5009
|
const backing_int_type_body_len: ?u32 = if (maybe_backing_int_node.unwrap()) |backing_int_node| len: {
|
|
5003
5010
|
if (layout != .@"packed") return astgen.failNode(
|
|
@@ -5005,6 +5012,7 @@ fn structDeclInner(
|
|
|
5005
5012
|
"non-packed struct does not support backing integer type",
|
|
5006
5013
|
.{},
|
|
5007
5014
|
);
|
|
5015
|
+
astgen.src_hasher.update(astgen.tree.getNodeSource(backing_int_node));
|
|
5008
5016
|
const type_ref = try typeExpr(&block_scope, &namespace.base, backing_int_node);
|
|
5009
5017
|
if (!block_scope.endsWithNoReturn()) {
|
|
5010
5018
|
_ = try block_scope.addBreak(.break_inline, decl_inst, type_ref);
|
|
@@ -5014,10 +5022,6 @@ fn structDeclInner(
|
|
|
5014
5022
|
break :len body_len;
|
|
5015
5023
|
} else null;
|
|
5016
5024
|
|
|
5017
|
-
const old_hasher = astgen.src_hasher;
|
|
5018
|
-
defer astgen.src_hasher = old_hasher;
|
|
5019
|
-
astgen.src_hasher = .init(.{});
|
|
5020
|
-
|
|
5021
5025
|
var next_field_idx: u32 = 0;
|
|
5022
5026
|
for (container_decl.ast.members) |member_node| {
|
|
5023
5027
|
var member = switch (try containerMember(&block_scope, &namespace.base, &wip_decls, member_node)) {
|
|
@@ -5278,8 +5282,13 @@ fn unionDeclInner(
|
|
|
5278
5282
|
const field_align_body_lens = try scratch.addOptionalSlice(scan_result.any_field_aligns, scan_result.fields_len);
|
|
5279
5283
|
const field_value_body_lens = try scratch.addOptionalSlice(scan_result.any_field_values, scan_result.fields_len);
|
|
5280
5284
|
|
|
5285
|
+
const old_hasher = astgen.src_hasher;
|
|
5286
|
+
defer astgen.src_hasher = old_hasher;
|
|
5287
|
+
astgen.src_hasher = .init(.{});
|
|
5288
|
+
|
|
5281
5289
|
// Before any field bodies comes the tag/backing type, if specified.
|
|
5282
5290
|
const arg_type_body_len: ?u32 = if (opt_arg_node.unwrap()) |arg_node| len: {
|
|
5291
|
+
astgen.src_hasher.update(astgen.tree.getNodeSource(arg_node));
|
|
5283
5292
|
const type_ref = try typeExpr(&block_scope, &namespace.base, arg_node);
|
|
5284
5293
|
if (!block_scope.endsWithNoReturn()) {
|
|
5285
5294
|
_ = try block_scope.addBreak(.break_inline, decl_inst, type_ref);
|
|
@@ -5289,10 +5298,6 @@ fn unionDeclInner(
|
|
|
5289
5298
|
break :len body_len;
|
|
5290
5299
|
} else null;
|
|
5291
5300
|
|
|
5292
|
-
const old_hasher = astgen.src_hasher;
|
|
5293
|
-
defer astgen.src_hasher = old_hasher;
|
|
5294
|
-
astgen.src_hasher = .init(.{});
|
|
5295
|
-
|
|
5296
5301
|
var next_field_idx: u32 = 0;
|
|
5297
5302
|
for (members) |member_node| {
|
|
5298
5303
|
var member = switch (try containerMember(&block_scope, &namespace.base, &wip_decls, member_node)) {
|
|
@@ -5483,8 +5488,13 @@ fn containerDecl(
|
|
|
5483
5488
|
const field_names = try scratch.addSlice(fields_len);
|
|
5484
5489
|
const field_value_body_lens = try scratch.addOptionalSlice(scan_result.any_field_values, fields_len);
|
|
5485
5490
|
|
|
5491
|
+
const old_hasher = astgen.src_hasher;
|
|
5492
|
+
defer astgen.src_hasher = old_hasher;
|
|
5493
|
+
astgen.src_hasher = .init(.{});
|
|
5494
|
+
|
|
5486
5495
|
// Before any field bodies comes the tag type, if specified.
|
|
5487
5496
|
const tag_type_body_len: ?u32 = if (container_decl.ast.arg.unwrap()) |tag_type_node| len: {
|
|
5497
|
+
astgen.src_hasher.update(astgen.tree.getNodeSource(tag_type_node));
|
|
5488
5498
|
const type_ref = try typeExpr(&block_scope, &namespace.base, tag_type_node);
|
|
5489
5499
|
if (!block_scope.endsWithNoReturn()) {
|
|
5490
5500
|
_ = try block_scope.addBreak(.break_inline, decl_inst, type_ref);
|
|
@@ -5494,10 +5504,6 @@ fn containerDecl(
|
|
|
5494
5504
|
break :len body_len;
|
|
5495
5505
|
} else null;
|
|
5496
5506
|
|
|
5497
|
-
const old_hasher = astgen.src_hasher;
|
|
5498
|
-
defer astgen.src_hasher = old_hasher;
|
|
5499
|
-
astgen.src_hasher = .init(.{});
|
|
5500
|
-
|
|
5501
5507
|
var next_field_idx: u32 = 0;
|
|
5502
5508
|
var opt_nonexhaustive_node: Ast.Node.OptionalIndex = .none;
|
|
5503
5509
|
for (container_decl.ast.members) |member_node| {
|
package/std/zig/ErrorBundle.zig
CHANGED
|
@@ -397,9 +397,13 @@ pub const Wip = struct {
|
|
|
397
397
|
});
|
|
398
398
|
try wip.extra.appendSlice(gpa, @as([]const u32, @ptrCast(wip.root_list.items)));
|
|
399
399
|
wip.root_list.clearAndFree(gpa);
|
|
400
|
+
|
|
401
|
+
try wip.string_bytes.shrinkToLen(gpa);
|
|
402
|
+
try wip.extra.shrinkToLen(gpa);
|
|
403
|
+
|
|
400
404
|
return .{
|
|
401
|
-
.string_bytes =
|
|
402
|
-
.extra =
|
|
405
|
+
.string_bytes = wip.string_bytes.toOwnedSliceAssert(),
|
|
406
|
+
.extra = wip.extra.toOwnedSliceAssert(),
|
|
403
407
|
};
|
|
404
408
|
}
|
|
405
409
|
|
package/std/zig/ZonGen.zig
CHANGED
|
@@ -67,38 +67,30 @@ pub fn generate(gpa: Allocator, tree: Ast, options: Options) Allocator.Error!Zoi
|
|
|
67
67
|
}
|
|
68
68
|
|
|
69
69
|
if (zg.compile_errors.items.len > 0) {
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
errdefer gpa.free(compile_errors);
|
|
74
|
-
const error_notes = try zg.error_notes.toOwnedSlice(gpa);
|
|
75
|
-
errdefer gpa.free(error_notes);
|
|
70
|
+
try zg.string_bytes.shrinkToLen(gpa);
|
|
71
|
+
try zg.compile_errors.shrinkToLen(gpa);
|
|
72
|
+
try zg.error_notes.shrinkToLen(gpa);
|
|
76
73
|
|
|
77
74
|
return .{
|
|
78
75
|
.nodes = .empty,
|
|
79
76
|
.extra = &.{},
|
|
80
77
|
.limbs = &.{},
|
|
81
|
-
.string_bytes = string_bytes,
|
|
82
|
-
.compile_errors = compile_errors,
|
|
83
|
-
.error_notes = error_notes,
|
|
78
|
+
.string_bytes = zg.string_bytes.toOwnedSliceAssert(),
|
|
79
|
+
.compile_errors = zg.compile_errors.toOwnedSliceAssert(),
|
|
80
|
+
.error_notes = zg.error_notes.toOwnedSliceAssert(),
|
|
84
81
|
};
|
|
85
82
|
} else {
|
|
86
83
|
assert(zg.error_notes.items.len == 0);
|
|
87
84
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
errdefer gpa.free(extra);
|
|
92
|
-
const limbs = try zg.limbs.toOwnedSlice(gpa);
|
|
93
|
-
errdefer gpa.free(limbs);
|
|
94
|
-
const string_bytes = try zg.string_bytes.toOwnedSlice(gpa);
|
|
95
|
-
errdefer gpa.free(string_bytes);
|
|
85
|
+
try zg.extra.shrinkToLen(gpa);
|
|
86
|
+
try zg.limbs.shrinkToLen(gpa);
|
|
87
|
+
try zg.string_bytes.shrinkToLen(gpa);
|
|
96
88
|
|
|
97
89
|
return .{
|
|
98
|
-
.nodes = nodes,
|
|
99
|
-
.extra = extra,
|
|
100
|
-
.limbs = limbs,
|
|
101
|
-
.string_bytes = string_bytes,
|
|
90
|
+
.nodes = zg.nodes.toOwnedSlice(),
|
|
91
|
+
.extra = zg.extra.toOwnedSliceAssert(),
|
|
92
|
+
.limbs = zg.limbs.toOwnedSliceAssert(),
|
|
93
|
+
.string_bytes = zg.string_bytes.toOwnedSliceAssert(),
|
|
102
94
|
.compile_errors = &.{},
|
|
103
95
|
.error_notes = &.{},
|
|
104
96
|
};
|
package/std/zig/llvm/Builder.zig
CHANGED
|
@@ -13947,8 +13947,8 @@ pub fn toBitcode(self: *Builder, allocator: Allocator, producer: Producer) bitco
|
|
|
13947
13947
|
const bit_count = extra.type.scalarBits(self);
|
|
13948
13948
|
const val: i64 = if (bit_count <= 64)
|
|
13949
13949
|
bigint.toInt(i64) catch unreachable
|
|
13950
|
-
else if (bigint.toInt(
|
|
13951
|
-
@bitCast(val)
|
|
13950
|
+
else if (bigint.toInt(u63)) |val|
|
|
13951
|
+
@bitCast(@as(u64, val))
|
|
13952
13952
|
else |_| {
|
|
13953
13953
|
const limbs = try record.addManyAsSlice(
|
|
13954
13954
|
self.gpa,
|
package/std/zig/system/arm.zig
CHANGED
|
@@ -21,7 +21,7 @@ pub const cpu_models = struct {
|
|
|
21
21
|
};
|
|
22
22
|
|
|
23
23
|
// implementer = 0x41
|
|
24
|
-
const
|
|
24
|
+
const Arm = [_]E{
|
|
25
25
|
E{ .part = 0x926, .m32 = &A32.arm926ej_s },
|
|
26
26
|
E{ .part = 0xb02, .m32 = &A32.mpcore },
|
|
27
27
|
E{ .part = 0xb36, .m32 = &A32.arm1136j_s },
|
|
@@ -88,8 +88,12 @@ pub const cpu_models = struct {
|
|
|
88
88
|
E{ .part = 0xd87, .m64 = &A64.cortex_a725 },
|
|
89
89
|
E{ .part = 0xd88, .m64 = &A64.cortex_a520ae },
|
|
90
90
|
E{ .part = 0xd89, .m64 = &A64.cortex_a720ae },
|
|
91
|
+
E{ .part = 0xd8a, .m64 = &A64.c1_nano },
|
|
92
|
+
E{ .part = 0xd8b, .m64 = &A64.c1_pro },
|
|
93
|
+
E{ .part = 0xd8c, .m64 = &A64.c1_ultra },
|
|
91
94
|
E{ .part = 0xd8e, .m64 = &A64.neoverse_n3 },
|
|
92
95
|
E{ .part = 0xd8f, .m64 = &A64.cortex_a320 },
|
|
96
|
+
E{ .part = 0xd90, .m64 = &A64.c1_premium },
|
|
93
97
|
};
|
|
94
98
|
// implementer = 0x42
|
|
95
99
|
const Broadcom = [_]E{
|
|
@@ -102,10 +106,17 @@ pub const cpu_models = struct {
|
|
|
102
106
|
E{ .part = 0x0a3, .m64 = &A64.thunderxt83 },
|
|
103
107
|
E{ .part = 0x0a1, .m64 = &A64.thunderxt88 },
|
|
104
108
|
E{ .part = 0x0af, .m64 = &A64.thunderx2t99 },
|
|
109
|
+
E{ .part = 0x0b0, .m64 = &A64.cortex_a57 },
|
|
110
|
+
E{ .part = 0x0b1, .m64 = &A64.cortex_a57 },
|
|
111
|
+
E{ .part = 0x0b2, .m64 = &A64.cortex_a57 },
|
|
112
|
+
E{ .part = 0x0b3, .m64 = &A64.cortex_a57 },
|
|
113
|
+
E{ .part = 0x0b4, .m64 = &A64.cortex_a57 },
|
|
114
|
+
E{ .part = 0x0b5, .m64 = &A64.cortex_a57 },
|
|
105
115
|
};
|
|
106
116
|
// implementer = 0x46
|
|
107
117
|
const Fujitsu = [_]E{
|
|
108
118
|
E{ .part = 0x001, .m64 = &A64.a64fx },
|
|
119
|
+
E{ .part = 0x003, .m64 = &A64.fujitsu_monaka },
|
|
109
120
|
};
|
|
110
121
|
// implementer = 0x48
|
|
111
122
|
const HiSilicon = [_]E{
|
|
@@ -137,8 +148,14 @@ pub const cpu_models = struct {
|
|
|
137
148
|
E{ .part = 0xc00, .m64 = &A64.falkor },
|
|
138
149
|
E{ .part = 0xc01, .m64 = &A64.saphira },
|
|
139
150
|
};
|
|
151
|
+
// implementer = 0x53
|
|
152
|
+
const Samsung = [_]E{
|
|
153
|
+
E{ .part = 0x000, .m64 = &A64.exynos_m1 },
|
|
154
|
+
};
|
|
140
155
|
// implementer = 0x61
|
|
141
156
|
const Apple = [_]E{
|
|
157
|
+
E{ .part = 0x020, .m64 = &A64.apple_m1 },
|
|
158
|
+
E{ .part = 0x021, .m64 = &A64.apple_m1 },
|
|
142
159
|
E{ .part = 0x022, .m64 = &A64.apple_m1 },
|
|
143
160
|
E{ .part = 0x023, .m64 = &A64.apple_m1 },
|
|
144
161
|
E{ .part = 0x024, .m64 = &A64.apple_m1 },
|
|
@@ -151,11 +168,43 @@ pub const cpu_models = struct {
|
|
|
151
168
|
E{ .part = 0x035, .m64 = &A64.apple_m2 },
|
|
152
169
|
E{ .part = 0x038, .m64 = &A64.apple_m2 },
|
|
153
170
|
E{ .part = 0x039, .m64 = &A64.apple_m2 },
|
|
171
|
+
E{ .part = 0x042, .m64 = &A64.apple_m3 },
|
|
172
|
+
E{ .part = 0x043, .m64 = &A64.apple_m3 },
|
|
173
|
+
E{ .part = 0x044, .m64 = &A64.apple_m3 },
|
|
174
|
+
E{ .part = 0x045, .m64 = &A64.apple_m3 },
|
|
175
|
+
E{ .part = 0x048, .m64 = &A64.apple_m3 },
|
|
176
|
+
E{ .part = 0x049, .m64 = &A64.apple_m3 },
|
|
177
|
+
E{ .part = 0x052, .m64 = &A64.apple_m4 },
|
|
178
|
+
E{ .part = 0x053, .m64 = &A64.apple_m4 },
|
|
179
|
+
E{ .part = 0x054, .m64 = &A64.apple_m4 },
|
|
180
|
+
E{ .part = 0x055, .m64 = &A64.apple_m4 },
|
|
181
|
+
E{ .part = 0x058, .m64 = &A64.apple_m4 },
|
|
182
|
+
E{ .part = 0x059, .m64 = &A64.apple_m4 },
|
|
183
|
+
};
|
|
184
|
+
// implementer = 0x63
|
|
185
|
+
const ArmChina = [_]E{
|
|
186
|
+
E{ .part = 0x132, .m32 = &A32.star_mc1 },
|
|
187
|
+
E{ .part = 0xd25, .m32 = &A32.star_mc3 },
|
|
188
|
+
};
|
|
189
|
+
// implementer = 0x68
|
|
190
|
+
const Hxt = [_]E{
|
|
191
|
+
E{ .part = 0x000, .m64 = &A64.cortex_a57 },
|
|
192
|
+
};
|
|
193
|
+
// implementer = 0x6d
|
|
194
|
+
const Microsoft = [_]E{
|
|
195
|
+
E{ .part = 0xd49, .m64 = &A64.neoverse_n2 },
|
|
196
|
+
};
|
|
197
|
+
// implementer = 0xC0
|
|
198
|
+
const AmpereOne = [_]E{
|
|
199
|
+
E{ .part = 0xac3, .m64 = &A64.ampere1 },
|
|
200
|
+
E{ .part = 0xac4, .m64 = &A64.ampere1a },
|
|
201
|
+
E{ .part = 0xac5, .m64 = &A64.ampere1b },
|
|
202
|
+
E{ .part = 0xac7, .m64 = &A64.ampere1c },
|
|
154
203
|
};
|
|
155
204
|
|
|
156
205
|
pub fn isKnown(core: CoreInfo, is_64bit: bool) ?*const Target.Cpu.Model {
|
|
157
206
|
const models = switch (core.implementer) {
|
|
158
|
-
0x41 => &
|
|
207
|
+
0x41 => &Arm,
|
|
159
208
|
0x42 => &Broadcom,
|
|
160
209
|
0x43 => &Cavium,
|
|
161
210
|
0x46 => &Fujitsu,
|
|
@@ -163,7 +212,12 @@ pub const cpu_models = struct {
|
|
|
163
212
|
0x4e => &Nvidia,
|
|
164
213
|
0x50 => &Ampere,
|
|
165
214
|
0x51 => &Qualcomm,
|
|
215
|
+
0x53 => &Samsung,
|
|
166
216
|
0x61 => &Apple,
|
|
217
|
+
0x63 => &ArmChina,
|
|
218
|
+
0x68 => &Hxt,
|
|
219
|
+
0x6d => &Microsoft,
|
|
220
|
+
0xC0 => &AmpereOne,
|
|
167
221
|
else => return null,
|
|
168
222
|
};
|
|
169
223
|
|
|
@@ -215,10 +215,43 @@ fn genericCpuAndNativeFeatures(arch: Target.Cpu.Arch) Target.Cpu {
|
|
|
215
215
|
// Override any features that are either present or absent
|
|
216
216
|
setFeature(Feature, &cpu, .neon, IsProcessorFeaturePresent(PF.ARM_NEON_INSTRUCTIONS_AVAILABLE));
|
|
217
217
|
setFeature(Feature, &cpu, .crc, IsProcessorFeaturePresent(PF.ARM_V8_CRC32_INSTRUCTIONS_AVAILABLE));
|
|
218
|
-
setFeature(Feature, &cpu, .
|
|
218
|
+
setFeature(Feature, &cpu, .aes, IsProcessorFeaturePresent(PF.ARM_V8_CRYPTO_INSTRUCTIONS_AVAILABLE));
|
|
219
|
+
setFeature(Feature, &cpu, .sha2, IsProcessorFeaturePresent(PF.ARM_V8_CRYPTO_INSTRUCTIONS_AVAILABLE));
|
|
219
220
|
setFeature(Feature, &cpu, .lse, IsProcessorFeaturePresent(PF.ARM_V81_ATOMIC_INSTRUCTIONS_AVAILABLE));
|
|
220
221
|
setFeature(Feature, &cpu, .dotprod, IsProcessorFeaturePresent(PF.ARM_V82_DP_INSTRUCTIONS_AVAILABLE));
|
|
221
222
|
setFeature(Feature, &cpu, .jsconv, IsProcessorFeaturePresent(PF.ARM_V83_JSCVT_INSTRUCTIONS_AVAILABLE));
|
|
223
|
+
setFeature(Feature, &cpu, .rcpc, IsProcessorFeaturePresent(PF.ARM_V83_LRCPC_INSTRUCTIONS_AVAILABLE));
|
|
224
|
+
setFeature(Feature, &cpu, .sve, IsProcessorFeaturePresent(PF.ARM_SVE_INSTRUCTIONS_AVAILABLE));
|
|
225
|
+
setFeature(Feature, &cpu, .sve2, IsProcessorFeaturePresent(PF.ARM_SVE2_INSTRUCTIONS_AVAILABLE));
|
|
226
|
+
setFeature(Feature, &cpu, .sve2p1, IsProcessorFeaturePresent(PF.ARM_SVE2_1_INSTRUCTIONS_AVAILABLE));
|
|
227
|
+
setFeature(Feature, &cpu, .sve_aes, IsProcessorFeaturePresent(PF.ARM_SVE_AES_INSTRUCTIONS_AVAILABLE) or IsProcessorFeaturePresent(PF.ARM_SVE_PMULL128_INSTRUCTIONS_AVAILABLE));
|
|
228
|
+
setFeature(Feature, &cpu, .sve_bitperm, IsProcessorFeaturePresent(PF.ARM_SVE_BITPERM_INSTRUCTIONS_AVAILABLE));
|
|
229
|
+
setFeature(Feature, &cpu, .bf16, IsProcessorFeaturePresent(PF.ARM_V86_BF16_INSTRUCTIONS_AVAILABLE));
|
|
230
|
+
setFeature(Feature, &cpu, .sve_b16b16, IsProcessorFeaturePresent(PF.ARM_SVE_B16B16_INSTRUCTIONS_AVAILABLE));
|
|
231
|
+
setFeature(Feature, &cpu, .sve_sha3, IsProcessorFeaturePresent(PF.ARM_SVE_SHA3_INSTRUCTIONS_AVAILABLE));
|
|
232
|
+
setFeature(Feature, &cpu, .sve_sm4, IsProcessorFeaturePresent(PF.ARM_SVE_SM4_INSTRUCTIONS_AVAILABLE));
|
|
233
|
+
setFeature(Feature, &cpu, .i8mm, IsProcessorFeaturePresent(PF.ARM_V82_I8MM_INSTRUCTIONS_AVAILABLE));
|
|
234
|
+
setFeature(Feature, &cpu, .f32mm, IsProcessorFeaturePresent(PF.ARM_SVE_F32MM_INSTRUCTIONS_AVAILABLE));
|
|
235
|
+
setFeature(Feature, &cpu, .f64mm, IsProcessorFeaturePresent(PF.ARM_SVE_F64MM_INSTRUCTIONS_AVAILABLE));
|
|
236
|
+
setFeature(Feature, &cpu, .sme, IsProcessorFeaturePresent(PF.ARM_SME_INSTRUCTIONS_AVAILABLE));
|
|
237
|
+
setFeature(Feature, &cpu, .sme2, IsProcessorFeaturePresent(PF.ARM_SME2_INSTRUCTIONS_AVAILABLE));
|
|
238
|
+
setFeature(Feature, &cpu, .lse2, IsProcessorFeaturePresent(PF.ARM_LSE2_AVAILABLE));
|
|
239
|
+
setFeature(Feature, &cpu, .sha3, IsProcessorFeaturePresent(PF.ARM_SHA3_INSTRUCTIONS_AVAILABLE) and IsProcessorFeaturePresent(PF.ARM_SHA512_INSTRUCTIONS_AVAILABLE));
|
|
240
|
+
setFeature(Feature, &cpu, .fullfp16, IsProcessorFeaturePresent(PF.ARM_V82_FP16_INSTRUCTIONS_AVAILABLE));
|
|
241
|
+
setFeature(Feature, &cpu, .sme2p1, IsProcessorFeaturePresent(PF.ARM_SME2_1_INSTRUCTIONS_AVAILABLE));
|
|
242
|
+
setFeature(Feature, &cpu, .sme2p2, IsProcessorFeaturePresent(PF.ARM_SME2_2_INSTRUCTIONS_AVAILABLE));
|
|
243
|
+
setFeature(Feature, &cpu, .ssve_aes, IsProcessorFeaturePresent(PF.ARM_SME_AES_INSTRUCTIONS_AVAILABLE));
|
|
244
|
+
setFeature(Feature, &cpu, .ssve_bitperm, IsProcessorFeaturePresent(PF.ARM_SME_SBITPERM_INSTRUCTIONS_AVAILABLE));
|
|
245
|
+
setFeature(Feature, &cpu, .ssve_fp8dot2, IsProcessorFeaturePresent(PF.ARM_SME_SF8DP2_INSTRUCTIONS_AVAILABLE));
|
|
246
|
+
setFeature(Feature, &cpu, .ssve_fp8dot4, IsProcessorFeaturePresent(PF.ARM_SME_SF8DP4_INSTRUCTIONS_AVAILABLE));
|
|
247
|
+
setFeature(Feature, &cpu, .ssve_fp8fma, IsProcessorFeaturePresent(PF.ARM_SME_SF8FMA_INSTRUCTIONS_AVAILABLE));
|
|
248
|
+
setFeature(Feature, &cpu, .sme_f8f32, IsProcessorFeaturePresent(PF.ARM_SME_F8F32_INSTRUCTIONS_AVAILABLE));
|
|
249
|
+
setFeature(Feature, &cpu, .sme_f8f16, IsProcessorFeaturePresent(PF.ARM_SME_F8F16_INSTRUCTIONS_AVAILABLE));
|
|
250
|
+
setFeature(Feature, &cpu, .sme_b16b16, IsProcessorFeaturePresent(PF.ARM_SME_B16B16_INSTRUCTIONS_AVAILABLE));
|
|
251
|
+
setFeature(Feature, &cpu, .sme_f64f64, IsProcessorFeaturePresent(PF.ARM_SME_F64F64_INSTRUCTIONS_AVAILABLE));
|
|
252
|
+
setFeature(Feature, &cpu, .sme_i16i64, IsProcessorFeaturePresent(PF.ARM_SME_I16I64_INSTRUCTIONS_AVAILABLE));
|
|
253
|
+
setFeature(Feature, &cpu, .sme_lutv2, IsProcessorFeaturePresent(PF.ARM_SME_LUTv2_INSTRUCTIONS_AVAILABLE));
|
|
254
|
+
setFeature(Feature, &cpu, .sme_fa64, IsProcessorFeaturePresent(PF.ARM_SME_FA64_INSTRUCTIONS_AVAILABLE));
|
|
222
255
|
},
|
|
223
256
|
else => {},
|
|
224
257
|
}
|
package/std/zig/system/x86.zig
CHANGED
|
@@ -232,7 +232,7 @@ fn detectIntelProcessor(cpu: *Target.Cpu, family: u32, model: u32, brand_id: u32
|
|
|
232
232
|
cpu.model = &Target.x86.cpu.lunarlake;
|
|
233
233
|
return;
|
|
234
234
|
},
|
|
235
|
-
0xcc => {
|
|
235
|
+
0xcc, 0xd5 => {
|
|
236
236
|
cpu.model = &Target.x86.cpu.pantherlake;
|
|
237
237
|
return;
|
|
238
238
|
},
|
|
@@ -307,6 +307,20 @@ fn detectIntelProcessor(cpu: *Target.Cpu, family: u32, model: u32, brand_id: u32
|
|
|
307
307
|
cpu.model = &Target.x86.cpu.pentium4;
|
|
308
308
|
return;
|
|
309
309
|
},
|
|
310
|
+
18 => switch (model) {
|
|
311
|
+
0x01, 0x03 => {
|
|
312
|
+
cpu.model = &Target.x86.cpu.novalake;
|
|
313
|
+
return;
|
|
314
|
+
},
|
|
315
|
+
else => return, // Unknown CPU Model
|
|
316
|
+
},
|
|
317
|
+
19 => switch (model) {
|
|
318
|
+
0x01 => {
|
|
319
|
+
cpu.model = &Target.x86.cpu.diamondrapids;
|
|
320
|
+
return;
|
|
321
|
+
},
|
|
322
|
+
else => return, // Unknown CPU Model
|
|
323
|
+
},
|
|
310
324
|
else => return, // Unknown CPU Model
|
|
311
325
|
}
|
|
312
326
|
}
|
|
@@ -412,6 +426,8 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
412
426
|
// AMX requires additional context to be saved by the OS.
|
|
413
427
|
const has_amx_save = xcr0.xtilecfg and xcr0.xtiledata;
|
|
414
428
|
|
|
429
|
+
const has_apx_save = xcr0.apx;
|
|
430
|
+
|
|
415
431
|
setFeature(cpu, .avx, has_avx_save);
|
|
416
432
|
setFeature(cpu, .fma, bit(leaf.ecx, 12) and has_avx_save);
|
|
417
433
|
// Only enable XSAVE if OS has enabled support for saving YMM state.
|
|
@@ -470,7 +486,20 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
470
486
|
}
|
|
471
487
|
}
|
|
472
488
|
|
|
473
|
-
if (
|
|
489
|
+
if (max_ext_level >= 0x80000021) {
|
|
490
|
+
leaf = cpuid(0x80000021, 0);
|
|
491
|
+
|
|
492
|
+
// AMD uses a different bit for prefetchi.
|
|
493
|
+
setFeature(cpu, .prefetchi, bit(leaf.eax, 20));
|
|
494
|
+
} else {
|
|
495
|
+
for ([_]Target.x86.Feature{
|
|
496
|
+
.prefetchi,
|
|
497
|
+
}) |feat| {
|
|
498
|
+
setFeature(cpu, feat, false);
|
|
499
|
+
}
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
const has_avx10 = if (max_level >= 0x7) has_avx10: {
|
|
474
503
|
leaf = cpuid(0x7, 0);
|
|
475
504
|
|
|
476
505
|
setFeature(cpu, .fsgsbase, bit(leaf.ebx, 0));
|
|
@@ -484,7 +513,6 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
484
513
|
setFeature(cpu, .rtm, bit(leaf.ebx, 11));
|
|
485
514
|
// AVX512 is only supported if the OS supports the context save for it.
|
|
486
515
|
setFeature(cpu, .avx512f, bit(leaf.ebx, 16) and has_avx512_save);
|
|
487
|
-
setFeature(cpu, .evex512, bit(leaf.ebx, 16) and has_avx512_save);
|
|
488
516
|
setFeature(cpu, .avx512dq, bit(leaf.ebx, 17) and has_avx512_save);
|
|
489
517
|
setFeature(cpu, .rdseed, bit(leaf.ebx, 18));
|
|
490
518
|
setFeature(cpu, .adx, bit(leaf.ebx, 19));
|
|
@@ -556,15 +584,20 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
556
584
|
setFeature(cpu, .avxneconvert, bit(leaf.edx, 5) and has_avx_save);
|
|
557
585
|
setFeature(cpu, .amx_complex, bit(leaf.edx, 8) and has_amx_save);
|
|
558
586
|
setFeature(cpu, .avxvnniint16, bit(leaf.edx, 10) and has_avx_save);
|
|
559
|
-
|
|
587
|
+
// This needs to account for prefetchi already being detected above on AMD.
|
|
588
|
+
setFeature(cpu, .prefetchi, cpu.has(.x86, .prefetchi) or bit(leaf.edx, 14));
|
|
560
589
|
setFeature(cpu, .usermsr, bit(leaf.edx, 15));
|
|
561
590
|
// APX
|
|
562
|
-
setFeature(cpu, .egpr, bit(leaf.edx, 21));
|
|
563
|
-
setFeature(cpu, .push2pop2, bit(leaf.edx, 21));
|
|
564
|
-
setFeature(cpu, .ppx, bit(leaf.edx, 21));
|
|
565
|
-
setFeature(cpu, .ndd, bit(leaf.edx, 21));
|
|
566
|
-
setFeature(cpu, .ccmp, bit(leaf.edx, 21));
|
|
567
|
-
setFeature(cpu, .
|
|
591
|
+
setFeature(cpu, .egpr, bit(leaf.edx, 21) and has_apx_save);
|
|
592
|
+
setFeature(cpu, .push2pop2, bit(leaf.edx, 21) and has_apx_save);
|
|
593
|
+
setFeature(cpu, .ppx, bit(leaf.edx, 21) and has_apx_save);
|
|
594
|
+
setFeature(cpu, .ndd, bit(leaf.edx, 21) and has_apx_save);
|
|
595
|
+
setFeature(cpu, .ccmp, bit(leaf.edx, 21) and has_apx_save);
|
|
596
|
+
setFeature(cpu, .nf, bit(leaf.edx, 21) and has_apx_save);
|
|
597
|
+
setFeature(cpu, .cf, bit(leaf.edx, 21) and has_apx_save);
|
|
598
|
+
setFeature(cpu, .zu, bit(leaf.edx, 21) and has_apx_save);
|
|
599
|
+
|
|
600
|
+
break :has_avx10 bit(leaf.edx, 19);
|
|
568
601
|
} else {
|
|
569
602
|
for ([_]Target.x86.Feature{
|
|
570
603
|
.sha512,
|
|
@@ -582,19 +615,23 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
582
615
|
.avxneconvert,
|
|
583
616
|
.amx_complex,
|
|
584
617
|
.avxvnniint16,
|
|
585
|
-
.
|
|
618
|
+
// prefetchi already handled earlier.
|
|
586
619
|
.usermsr,
|
|
587
620
|
.egpr,
|
|
588
621
|
.push2pop2,
|
|
589
622
|
.ppx,
|
|
590
623
|
.ndd,
|
|
591
624
|
.ccmp,
|
|
625
|
+
.nf,
|
|
592
626
|
.cf,
|
|
627
|
+
.zu,
|
|
593
628
|
}) |feat| {
|
|
594
629
|
setFeature(cpu, feat, false);
|
|
595
630
|
}
|
|
596
631
|
}
|
|
597
|
-
|
|
632
|
+
|
|
633
|
+
break :has_avx10 false;
|
|
634
|
+
} else has_avx10: {
|
|
598
635
|
for ([_]Target.x86.Feature{
|
|
599
636
|
.fsgsbase,
|
|
600
637
|
.sgx,
|
|
@@ -605,7 +642,6 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
605
642
|
.invpcid,
|
|
606
643
|
.rtm,
|
|
607
644
|
.avx512f,
|
|
608
|
-
.evex512,
|
|
609
645
|
.avx512dq,
|
|
610
646
|
.rdseed,
|
|
611
647
|
.adx,
|
|
@@ -664,18 +700,22 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
664
700
|
.avxneconvert,
|
|
665
701
|
.amx_complex,
|
|
666
702
|
.avxvnniint16,
|
|
667
|
-
.
|
|
703
|
+
// prefetchi already handled earlier.
|
|
668
704
|
.usermsr,
|
|
669
705
|
.egpr,
|
|
670
706
|
.push2pop2,
|
|
671
707
|
.ppx,
|
|
672
708
|
.ndd,
|
|
673
709
|
.ccmp,
|
|
710
|
+
.nf,
|
|
674
711
|
.cf,
|
|
712
|
+
.zu,
|
|
675
713
|
}) |feat| {
|
|
676
714
|
setFeature(cpu, feat, false);
|
|
677
715
|
}
|
|
678
|
-
|
|
716
|
+
|
|
717
|
+
break :has_avx10 false;
|
|
718
|
+
};
|
|
679
719
|
|
|
680
720
|
if (max_level >= 0xD and has_avx_save) {
|
|
681
721
|
leaf = cpuid(0xD, 0x1);
|
|
@@ -721,10 +761,14 @@ fn detectNativeFeatures(cpu: *Target.Cpu, os_tag: Target.Os.Tag) void {
|
|
|
721
761
|
if (max_level >= 0x24) {
|
|
722
762
|
leaf = cpuid(0x24, 0);
|
|
723
763
|
|
|
724
|
-
|
|
764
|
+
const avx_ver = leaf.ebx & 0xff;
|
|
765
|
+
|
|
766
|
+
setFeature(cpu, .avx10_1, has_avx10 and avx_ver >= 1);
|
|
767
|
+
setFeature(cpu, .avx10_2, has_avx10 and avx_ver >= 2);
|
|
725
768
|
} else {
|
|
726
769
|
for ([_]Target.x86.Feature{
|
|
727
770
|
.avx10_1,
|
|
771
|
+
.avx10_2,
|
|
728
772
|
}) |feat| {
|
|
729
773
|
setFeature(cpu, feat, false);
|
|
730
774
|
}
|
package/std/zig/system.zig
CHANGED
|
@@ -460,16 +460,6 @@ pub fn resolveTargetQuery(io: Io, query: Target.Query) DetectError!Target {
|
|
|
460
460
|
if (result.cpu.arch.isArm() and result.abi.float() == .soft) {
|
|
461
461
|
result.cpu.features.removeFeature(@intFromEnum(Target.arm.Feature.vfp2));
|
|
462
462
|
}
|
|
463
|
-
|
|
464
|
-
// https://github.com/llvm/llvm-project/issues/135283
|
|
465
|
-
if (result.cpu.arch.isMIPS() and result.abi.float() == .soft) {
|
|
466
|
-
result.cpu.features.addFeature(@intFromEnum(Target.mips.Feature.soft_float));
|
|
467
|
-
}
|
|
468
|
-
|
|
469
|
-
// https://github.com/llvm/llvm-project/issues/168992
|
|
470
|
-
if (result.cpu.arch == .s390x) {
|
|
471
|
-
result.cpu.features.removeFeature(@intFromEnum(Target.s390x.Feature.vector));
|
|
472
|
-
}
|
|
473
463
|
}
|
|
474
464
|
|
|
475
465
|
// It's possible that we detect the native ABI, but fail to detect the OS version or were told
|