Package evaluation to test SIMD on Julia 1.14.0-DEV.2043 (b936235316*) started at 2026-04-16T16:22:13.638 ################################################################################ # Set-up # Installing PkgEval dependencies (TestEnv)... Activating project at `~/.julia/environments/v1.14` Set-up completed after 14.13s ################################################################################ # Installation # Installing SIMD... Resolving package versions... Updating `~/.julia/environments/v1.14/Project.toml` [fdea26ae] + SIMD v3.7.2 Updating `~/.julia/environments/v1.14/Manifest.toml` [aea7be01] + PrecompileTools v1.3.3 [21216c6a] + Preferences v1.5.2 [fdea26ae] + SIMD v3.7.2 [ade2ca70] + Dates v1.11.0 [de0858da] + Printf v1.11.0 [fa267f1f] + TOML v1.0.3 [4ec0a83e] + Unicode v1.11.0 Installation completed after 1.25s ################################################################################ # Precompilation # Precompiling PkgEval dependencies... Precompiling package dependencies... Precompiling project... 2.4 s ✓ OpenCL_Headers_jll 2.3 s ✓ SPIRV_LLVM_Translator_jll 2.5 s ✓ SPIRV_Tools_jll 2.6 s ✓ LLD_unified_jll 2.5 s ✓ SPIRV_LLVM_Backend_jll 2.3 s ✓ OpenCL_jll 2.5 s ✓ Clang_unified_jll 13.0 s ✓ SPIRVIntrinsics 2.7 s ✓ pocl_jll 11.0 s ✓ SPIRVIntrinsics → SPIRVIntrinsicsSIMDExt 17.7 s ✓ OpenCL 10.6 s ✓ Atomix → AtomixOpenCLExt 12 dependencies successfully precompiled in 74 seconds. 80 already precompiled. Precompilation completed after 103.13s ################################################################################ # Testing # Testing SIMD Status `/tmp/jl_bK80gY/Project.toml` [63c18a36] KernelAbstractions v0.9.41 [08131aa3] OpenCL v0.10.9 [fdea26ae] SIMD v3.7.2 [627d6b7a] pocl_jll v7.1.0+1 [b77e0a4c] InteractiveUtils v1.11.0 [8dfed614] Test v1.11.0 Status `/tmp/jl_bK80gY/Manifest.toml` [79e6a3ab] Adapt v4.5.2 [a9b6321e] Atomix v1.1.3 [fa961155] CEnum v0.5.0 [ffbed154] DocStringExtensions v0.9.5 [e2ba6199] ExprTools v0.1.10 [0c68f7d7] GPUArrays v11.5.1 [46192b85] GPUArraysCore v0.2.0 [61eb1bfa] GPUCompiler v1.9.1 [096a3bc2] GPUToolbox v1.1.1 [076d061b] HashArrayMappedTries v0.2.0 [92d709cd] IrrationalConstants v0.2.6 [692b3bcd] JLLWrappers v1.7.1 [63c18a36] KernelAbstractions v0.9.41 [929cbde3] LLVM v9.4.6 [2ab3a3ac] LogExpFunctions v0.3.29 [1914dd2f] MacroTools v0.5.16 [08131aa3] OpenCL v0.10.9 [aea7be01] PrecompileTools v1.3.3 [21216c6a] Preferences v1.5.2 [74087812] Random123 v1.7.1 [e6cf234a] RandomNumbers v1.6.0 [189a3867] Reexport v1.2.2 [ae029012] Requires v1.3.1 [fdea26ae] SIMD v3.7.2 [71d1d633] SPIRVIntrinsics v0.5.9 [7e506255] ScopedValues v1.6.0 [6c6a2e73] Scratch v1.3.0 [276daf66] SpecialFunctions v2.7.2 [90137ffa] StaticArrays v1.9.18 [1e83bf80] StaticArraysCore v1.4.4 [10745b16] Statistics v1.11.1 [e689c965] Tracy v0.1.6 [013be700] UnsafeAtomics v0.3.1 [ffc816e1] Clang_unified_jll v0.1.4+0 [e33a78d0] Hwloc_jll v2.13.0+1 [fbc507ec] LLD_unified_jll v0.1.2+0 [dad2f222] LLVMExtra_jll v0.0.38+0 [ad6e5548] LibTracyClient_jll v0.13.1+0 [94ce4f54] Libiconv_jll v1.18.0+0 [a7aa756b] OpenCL_Headers_jll v2025.6.13+0 [6cb37087] OpenCL_jll v2024.10.24+1 [efe28fd5] OpenSpecFun_jll v0.5.6+0 ⌅ [4376b9bf] SPIRV_LLVM_Backend_jll v20.1.5+3 ⌅ [4a5d46fc] SPIRV_LLVM_Translator_jll v20.1.0+6 [6ac6d60f] SPIRV_Tools_jll v2025.4.0+0 ⌅ [02c8fc9c] XML2_jll v2.13.9+0 [a65dc6b1] Xorg_libpciaccess_jll v0.18.1+0 [627d6b7a] pocl_jll v7.1.0+1 [0dad84c5] ArgTools v1.1.2 [56f22d72] Artifacts v1.11.0 [2a0f44e3] Base64 v1.11.0 [ade2ca70] Dates v1.11.0 [f43a241f] Downloads v1.7.0 [7b1f6079] FileWatching v1.11.0 [b77e0a4c] InteractiveUtils v1.11.0 [ac6e5ff7] JuliaSyntaxHighlighting v1.13.0 [4af54fe1] LazyArtifacts v1.11.0 [b27032c2] LibCURL v1.0.0 [76f85450] LibGit2 v1.11.0 [8f399da3] Libdl v1.11.0 [37e2e46d] LinearAlgebra v1.13.0 [56ddb016] Logging v1.11.0 [d6f4376e] Markdown v1.11.0 [ca575930] NetworkOptions v1.3.0 [44cfe95a] Pkg v1.14.0 [de0858da] Printf v1.11.0 [9a3f8284] Random v1.11.0 [ea8e919c] SHA v1.0.0 [9e88b42a] Serialization v1.11.0 [2f01184e] SparseArrays v1.13.0 [f489334b] StyledStrings v1.13.0 [fa267f1f] TOML v1.0.3 [a4e569a6] Tar v1.10.0 [8dfed614] Test v1.11.0 [cf7118a7] UUIDs v1.11.0 [4ec0a83e] Unicode v1.11.0 [e66e0078] CompilerSupportLibraries_jll v1.3.0+1 [deac9b47] LibCURL_jll v8.19.0+0 [e37daf67] LibGit2_jll v1.9.2+0 [29816b5a] LibSSH2_jll v1.11.3+1 [14a3606d] MozillaCACerts_jll v2026.3.19 [4536629a] OpenBLAS_jll v0.3.30+0 [05823500] OpenLibm_jll v0.8.7+0 [458c3c95] OpenSSL_jll v3.5.6+0 [efcefdf7] PCRE2_jll v10.47.0+0 [bea87d4a] SuiteSparse_jll v7.10.1+0 [83775a58] Zlib_jll v1.3.2+0 [3161d3a3] Zstd_jll v1.5.7+1 [8f36deef] libLLVM_jll v20.1.8+0 [8e850b90] libblastrampoline_jll v5.15.0+0 [8e850ede] nghttp2_jll v1.68.1+0 [3f19e933] p7zip_jll v17.8.0+0 Info Packages marked with ⌅ have new versions available but compatibility constraints restrict them from upgrading. Testing Running tests... Test Summary: | Pass Total Time Type properties | 10 10 0.8s Test Summary: | Pass Total Time Errors | 2 2 1.4s Test Summary: | Pass Total Time Type conversion | 8 8 0.8s Test Summary: | Pass Total Time Conversion and reinterpretation | 4 4 0.9s Test Summary: | Pass Total Time convert(target_type, source) | 144 144 10.9s Test Summary: | Pass Total Time Element-wise access | 22 22 0.4s Test Summary: | Pass Total Time Integer arithmetic functions | 116 116 3.6s Test Summary: | Pass Total Time bswap | 6 6 0.4s Test Summary: | Pass Total Time saturation | 4 4 0.2s Test Summary: | Pass Total Time overflow arithmetic | 24 24 4.0s Test Summary: | Pass Total Time Floating point arithmetic functions | 106 106 47.3s Test Summary: | Pass Total Time Type promotion | 88 88 1.1s Test Summary: | Pass Total Time Reduction operations | 21 21 1.5s Test Summary: | Pass Total Time Load and store functions | 66 66 1.7s Test Summary: | Pass Total Time Load and store with pointers | 168 168 3.9s Test Summary: | Pass Total Time fastmath | 6 6 0.3s Test Summary: | Pass Total Time Gather and scatter function | 174 174 9.1s Test Summary: | Pass Total Time expandload | 10 10 0.3s Test Summary: | Pass Total Time compressstore | 10 10 0.6s Test Summary: | Pass Total Time Index-based load/store | 104 104 5.2s ; Function Signature: vsum(Base.SubArray{Float64, 1, Array{Float64, 1}, Tuple{Base.UnitRange{Int64}}, true}, Type{SIMD.Vec{4, Float64}}) ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:866 within `vsum` define double @julia_vsum_0(ptr nocapture noundef nonnull readonly align 8 dereferenceable(40) %"xs::SubArray", ptr nocapture noundef nonnull readonly align 8 dereferenceable(8) %.roots.xs) local_unnamed_addr #0 { top: %gcframe1 = alloca [3 x ptr], align 16 call void @llvm.memset.p0.i64(ptr align 16 %gcframe1, i8 0, i64 24, i1 true) %"new::VecRange" = alloca [1 x i64], align 8 %thread_ptr = call ptr asm "movq %fs:0, $0", "=r"() #13 %tls_ppgcstack = getelementptr inbounds i8, ptr %thread_ptr, i64 -8 %tls_pgcstack = load ptr, ptr %tls_ppgcstack, align 8 store i64 4, ptr %gcframe1, align 8 %frame.prev = getelementptr inbounds nuw i8, ptr %gcframe1, i64 8 %task.gcstack = load ptr, ptr %tls_pgcstack, align 8 store ptr %task.gcstack, ptr %frame.prev, align 8 store ptr %gcframe1, ptr %tls_pgcstack, align 8 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:867 within `vsum` ; ┌ @ essentials.jl:13 within `length` ; │┌ @ subarray.jl:65 within `size` ; ││┌ @ subarray.jl:512 within `axes` ; │││┌ @ Base_compiler.jl:58 within `getproperty` %0 = getelementptr inbounds nuw i8, ptr %"xs::SubArray", i64 8 ; │││└ ; │││┌ @ subarray.jl:517 within `_indices_sub` ; ││││┌ @ abstractarray.jl:102 within `axes` ; │││││┌ @ range.jl:692 within `size` ; ││││││┌ @ range.jl:782 within `length` ; │││││││┌ @ range.jl:863 within `last` ; ││││││││┌ @ Base_compiler.jl:58 within `getproperty` %.stop_ptr = getelementptr inbounds nuw i8, ptr %"xs::SubArray", i64 16 ; │││││││└└ ; │││││││ @ range.jl:785 within `length` ; │││││││┌ @ essentials.jl:1227 within `-` %.stop_ptr.unbox = load i64, ptr %.stop_ptr, align 8 %.unbox = load i64, ptr %0, align 8 %1 = sub i64 %.stop_ptr.unbox, %.unbox ; │││││││└ ; │││││││┌ @ essentials.jl:1226 within `+` %2 = add i64 %1, 1 ; └└└└└└└└ ; ┌ @ promotion.jl:637 within `==` %3 = and i64 %2, 3 %.not = icmp eq i64 %3, 0 ; └ br i1 %.not, label %L10, label %L127 L10: ; preds = %top ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:870 within `vsum` ; ┌ @ range.jl:22 within `Colon` ; │┌ @ range.jl:24 within `_colon` ; ││┌ @ range.jl:393 within `StepRange` @ range.jl:338 ; │││┌ @ range.jl:353 within `steprange_last` ; ││││┌ @ promotion.jl:637 within `==` %.not29 = icmp eq i64 %.stop_ptr.unbox, %.unbox ; ││││└ br i1 %.not29, label %L69.preheader, label %L22 L22: ; preds = %L10 ; ││││ @ range.jl:356 within `steprange_last` ; ││││┌ @ operators.jl:424 within `>` ; │││││┌ @ int.jl:83 within `<` %4 = icmp sgt i64 %2, 1 ; ││││└└ br i1 %4, label %L55, label %L123 L55: ; preds = %L22 ; ││││ @ range.jl:369 within `steprange_last` ; ││││┌ @ int.jl:342 within `rem` %5 = and i64 %1, 3 ; ││││└ ; ││││ @ range.jl:372 within `steprange_last` %6 = sub nsw i64 %2, %5 ; └└└└ ; ┌ @ range.jl:921 within `iterate` ; │┌ @ range.jl:694 within `isempty` ; ││┌ @ bool.jl:14 within `&` %7 = icmp slt i64 %6, 1 ; └└└ br i1 %7, label %L123, label %L69.preheader L69.preheader: ; preds = %L55, %L10 %value_phi42 = phi i64 [ %6, %L55 ], [ 1, %L10 ] %8 = load ptr, ptr %.roots.xs, align 8 %9 = getelementptr inbounds nuw i8, ptr %"xs::SubArray", i64 24 %.unbox12 = load i64, ptr %9, align 8 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:871 within `vsum` ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; ││┌ @ essentials.jl:391 within `checkbounds` br label %L69 L69: ; preds = %L97, %L69.preheader %value_phi6 = phi i64 [ %13, %L97 ], [ 1, %L69.preheader ] %value_phi8 = phi <4 x double> [ %19, %L97 ], [ zeroinitializer, %L69.preheader ] ; │││ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; ││││┌ @ int.jl:560 within `<=` %10 = icmp sgt i64 %value_phi6, 0 ; ││││└ %11 = add nuw i64 %value_phi6, 3 %12 = icmp sle i64 %11, %2 ; │││└ ; │││ @ essentials.jl:391 within `checkbounds` %narrow.not.not38 = and i1 %10, %12 br i1 %narrow.not.not38, label %L97, label %L93 L93: ; preds = %L69 ; └└└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:226 within `+` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:219 within `VecRange` store i64 %value_phi6, ptr %"new::VecRange", align 8 ; └└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; ││┌ @ essentials.jl:391 within `checkbounds` call void @j__throw_boundserror_indices_0(ptr nocapture nonnull readonly %"xs::SubArray", ptr nocapture nonnull readonly %.roots.xs, ptr nocapture nonnull readonly %"new::VecRange") #4 unreachable L97: ; preds = %L69 ; │││ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` %13 = add nuw i64 %value_phi6, 4 ; │└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:295 within `_pointer` ; ││┌ @ subarray.jl:498 within `pointer` ; │││┌ @ essentials.jl:1226 within `+` %14 = add i64 %.unbox12, %value_phi6 ; │││└ ; │││ @ subarray.jl:498 within `pointer` @ abstractarray.jl:1273 @ abstractarray.jl:1270 ; │││┌ @ pointer.jl:63 within `cconvert` %15 = load ptr, ptr %8, align 8 ; │││└ ; │││ @ subarray.jl:498 within `pointer` @ abstractarray.jl:1273 ; │││┌ @ abstractarray.jl:1277 within `_memory_offset` ; ││││┌ @ int.jl:88 within `*` %16 = shl i64 %14, 3 ; │││└└ ; │││┌ @ pointer.jl:314 within `+` %17 = getelementptr i8, ptr %15, i64 %16 %18 = getelementptr i8, ptr %17, i64 -8 ; │└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 within `vload` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:51 ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:477 within `load` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:486 within `macro expansion` %res.i = load <4 x double>, ptr %18, align 8 ; └└└└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:264 within `+` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:227 within `fadd` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:227 ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:236 within `macro expansion` %19 = fadd <4 x double> %value_phi8, %res.i ; └└└ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:872 within `vsum` ; ┌ @ range.jl:925 within `iterate` ; │┌ @ promotion.jl:637 within `==` %.not32 = icmp eq i64 %value_phi6, %value_phi42 ; └└ br i1 %.not32, label %L123, label %L69 L123: ; preds = %L97, %L55, %L22 %value_phi16 = phi <4 x double> [ zeroinitializer, %L55 ], [ zeroinitializer, %L22 ], [ %19, %L97 ] ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:873 within `vsum` ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:498 within `sum` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1077 within `reduce_fadd` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1093 within `macro expansion` %res.i33 = call reassoc double @llvm.vector.reduce.fadd.v4f64(double 0.000000e+00, <4 x double> %value_phi16) %frame.prev51 = load ptr, ptr %frame.prev, align 8 store ptr %frame.prev51, ptr %tls_pgcstack, align 8 ret double %res.i33 L127: ; preds = %top ; └└└ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:867 within `vsum` %"jl_global#0" = load ptr, ptr @"jl_global#0", align 8 %20 = call [1 x ptr] @j_AssertionError_0(ptr nonnull %"jl_global#0") %"+Core.AssertionError#0" = load ptr, ptr @"+Core.AssertionError#0", align 8 %gc_slot_addr_0 = getelementptr inbounds nuw i8, ptr %gcframe1, i64 16 %21 = extractvalue [1 x ptr] %20, 0 store ptr %21, ptr %gc_slot_addr_0, align 8 %ptls_field = getelementptr inbounds nuw i8, ptr %tls_pgcstack, i64 16 %ptls_load = load ptr, ptr %ptls_field, align 8 %22 = ptrtoint ptr %"+Core.AssertionError#0" to i64 %"box::AssertionError" = call noalias nonnull align 8 dereferenceable(16) ptr @ijl_gc_small_alloc(ptr %ptls_load, i32 360, i32 16, i64 %22) #9 %"box::AssertionError.tag_addr" = getelementptr inbounds i8, ptr %"box::AssertionError", i64 -8 store atomic ptr %"+Core.AssertionError#0", ptr %"box::AssertionError.tag_addr" unordered, align 8 store ptr %21, ptr %"box::AssertionError", align 8 store ptr null, ptr %gc_slot_addr_0, align 8 call void @ijl_throw(ptr nonnull %"box::AssertionError") unreachable } .file "vsum" .section .ltext,"axl",@progbits .globl julia_vsum_0 # -- Begin function julia_vsum_0 .p2align 4 .type julia_vsum_0,@function julia_vsum_0: # @julia_vsum_0 ; Function Signature: vsum(Base.SubArray{Float64, 1, Array{Float64, 1}, Tuple{Base.UnitRange{Int64}}, true}, Type{SIMD.Vec{4, Float64}}) ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:866 within `vsum` # %bb.0: # %top #DEBUG_VALUE: vsum:xs <- [$rdi+0] push rbp mov rbp, rsp push r15 push r14 push rbx sub rsp, 40 vxorpd xmm0, xmm0, xmm0 #APP mov rax, qword ptr fs:[0] #NO_APP lea rcx, [rbp - 48] vmovapd xmmword ptr [rbp - 48], xmm0 mov qword ptr [rbp - 32], 0 mov r15, qword ptr [rax - 8] mov qword ptr [rbp - 48], 4 mov rax, qword ptr [r15] mov qword ptr [rbp - 40], rax mov qword ptr [r15], rcx ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:867 within `vsum` ; │┌ @ essentials.jl:13 within `length` ; ││┌ @ subarray.jl:65 within `size` ; │││┌ @ subarray.jl:512 within `axes` ; ││││┌ @ subarray.jl:517 within `_indices_sub` ; │││││┌ @ abstractarray.jl:102 within `axes` ; ││││││┌ @ range.jl:692 within `size` ; │││││││┌ @ range.jl:785 within `length` ; ││││││││┌ @ essentials.jl:1227 within `-` mov r8, qword ptr [rdi + 16] mov rdx, qword ptr [rdi + 8] mov rcx, r8 sub rcx, rdx ; ││││││││└ ; ││││││││┌ @ essentials.jl:1226 within `+` lea rax, [rcx + 1] ; │└└└└└└└└ ; │┌ @ promotion.jl:637 within `==` test al, 3 ; │└ jne .LBB0_9 # %bb.1: # %L10 mov r9d, 1 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:870 within `vsum` ; │┌ @ range.jl:22 within `Colon` ; ││┌ @ range.jl:24 within `_colon` ; │││┌ @ range.jl:393 within `StepRange` @ range.jl:338 ; ││││┌ @ range.jl:353 within `steprange_last` ; │││││┌ @ promotion.jl:637 within `==` cmp r8, rdx ; │││││└ je .LBB0_4 # %bb.2: # %L22 vxorpd xmm0, xmm0, xmm0 ; │││││ @ range.jl:356 within `steprange_last` ; │││││┌ @ operators.jl:424 within `>` ; ││││││┌ @ int.jl:83 within `<` cmp rax, 2 ; │││││└└ jl .LBB0_8 # %bb.3: # %L55 ; │││││ @ range.jl:369 within `steprange_last` ; │││││┌ @ int.jl:342 within `rem` and ecx, 3 ; │└└└└└ ; │┌ @ range.jl:921 within `iterate` ; ││┌ @ range.jl:694 within `isempty` ; │││┌ @ bool.jl:14 within `&` mov r9, rax sub r9, rcx ; │└└└ jle .LBB0_8 .LBB0_4: # %L69.preheader mov rdx, qword ptr [rdi + 24] mov rcx, qword ptr [rsi] mov r8, -3 vxorpd xmm0, xmm0, xmm0 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:871 within `vsum` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; │││┌ @ essentials.jl:391 within `checkbounds` sub r8, r9 mov r9d, 4 shl rdx, 3 .p2align 4 .LBB0_5: # %L69 # =>This Inner Loop Header: Depth=1 ; ││││ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; │││││┌ @ int.jl:560 within `<=` lea r10, [r9 - 3] test r10, r10 ; ││││└└ ; ││││ @ essentials.jl:391 within `checkbounds` jle .LBB0_10 # %bb.6: # %L69 # in Loop: Header=BB0_5 Depth=1 cmp r9, rax jg .LBB0_10 # %bb.7: # %L97 # in Loop: Header=BB0_5 Depth=1 mov r10, qword ptr [rcx] ; ││└└ ; ││ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 within `vload` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:51 ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:477 within `load` ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:486 within `macro expansion` add r10, rdx ; │└└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:264 within `+` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:227 within `fadd` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:227 ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:236 within `macro expansion` vaddpd ymm0, ymm0, ymmword ptr [r10 + 8*r9 - 32] ; │└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:872 within `vsum` ; │┌ @ range.jl:925 within `iterate` ; ││┌ @ promotion.jl:637 within `==` lea r10, [r8 + r9 + 4] add r9, 4 cmp r10, 4 ; │└└ jne .LBB0_5 .LBB0_8: # %L123 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:873 within `vsum` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:498 within `sum` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1077 within `reduce_fadd` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1093 within `macro expansion` vextractf128 xmm1, ymm0, 1 mov rax, qword ptr [rbp - 40] vaddpd xmm0, xmm0, xmm1 vshufpd xmm1, xmm0, xmm0, 1 # xmm1 = xmm0[1,0] mov qword ptr [r15], rax vaddsd xmm0, xmm0, xmm1 vxorpd xmm1, xmm1, xmm1 vaddsd xmm0, xmm0, xmm1 add rsp, 40 pop rbx pop r14 pop r15 pop rbp vzeroupper ret .LBB0_10: # %L93 ; │└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:871 within `vsum` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; │││┌ @ essentials.jl:391 within `checkbounds` movabs rax, offset j__throw_boundserror_indices_0 lea rdx, [rbp - 56] ; │└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:226 within `+` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:219 within `VecRange` mov qword ptr [rbp - 56], r10 ; │└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; │││┌ @ essentials.jl:391 within `checkbounds` vzeroupper call rax .LBB0_9: # %L127 ; │└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:867 within `vsum` movabs rax, offset "jl_global#0" mov rdi, qword ptr [rax] movabs rax, offset j_AssertionError_0 call rax mov rbx, rax movabs rax, offset "+Core.AssertionError#0" mov esi, 360 mov edx, 16 mov r14, qword ptr [rax] mov qword ptr [rbp - 32], rbx movabs rax, offset ijl_gc_small_alloc mov rdi, qword ptr [r15 + 16] mov rcx, r14 call rax movabs rcx, offset ijl_throw mov rdi, rax mov qword ptr [rax - 8], r14 mov qword ptr [rax], rbx mov qword ptr [rbp - 32], 0 call rcx .Lfunc_end0: .size julia_vsum_0, .Lfunc_end0-julia_vsum_0 ; └ # -- End function .section ".note.GNU-stack","",@progbits ; Function Signature: vcompress!(Array{Float64, 1}, Array{Bool, 1}, Array{Float64, 1}) ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:939 within `vcompress!` define nonnull ptr @"japi1_vcompress!_0"(ptr %"function::Core.Function", ptr noalias nocapture noundef readonly %"args::Any[]", i32 %"nargs::UInt32") local_unnamed_addr #0 { top: %gcframe2 = alloca [3 x ptr], align 16 call void @llvm.memset.p0.i64(ptr align 16 %gcframe2, i8 0, i64 24, i1 true) %stackargs = alloca ptr, align 8 store volatile ptr %"args::Any[]", ptr %stackargs, align 8 %"new::VecRange" = alloca [1 x i64], align 8 %"new::LinearIndices" = alloca [1 x [1 x [1 x i64]]], align 8 %"new::VecRange17" = alloca [1 x i64], align 8 %"new::LinearIndices24" = alloca [1 x [1 x [1 x i64]]], align 8 %"new::UnitRange" = alloca [2 x i64], align 8 %thread_ptr = call ptr asm "movq %fs:0, $0", "=r"() #18 %tls_ppgcstack = getelementptr inbounds i8, ptr %thread_ptr, i64 -8 %tls_pgcstack = load ptr, ptr %tls_ppgcstack, align 8 store i64 4, ptr %gcframe2, align 8 %frame.prev = getelementptr inbounds nuw i8, ptr %gcframe2, i64 8 %task.gcstack = load ptr, ptr %tls_pgcstack, align 8 store ptr %task.gcstack, ptr %frame.prev, align 8 store ptr %gcframe2, ptr %tls_pgcstack, align 8 %0 = load ptr, ptr %"args::Any[]", align 8 %1 = getelementptr inbounds nuw i8, ptr %"args::Any[]", i64 8 %2 = load ptr, ptr %1, align 8 %3 = getelementptr inbounds nuw i8, ptr %"args::Any[]", i64 16 %4 = load ptr, ptr %3, align 8 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 ; ┌ @ abstractarray.jl:102 within `axes` ; │┌ @ essentials.jl:12 within `size` %.size_ptr = getelementptr inbounds nuw i8, ptr %4, i64 16 %.size.0.copyload = load i64, ptr %.size_ptr, align 8 %.size_ptr1 = getelementptr inbounds nuw i8, ptr %0, i64 16 %.size2.0.copyload = load i64, ptr %.size_ptr1, align 8 ; └└ ; ┌ @ tuple.jl:543 within `==` ; │┌ @ tuple.jl:547 within `_eq` ; ││┌ @ range.jl:1142 within `==` @ promotion.jl:637 %.not.not = icmp eq i64 %.size2.0.copyload, %.size.0.copyload ; └└└ br i1 %.not.not, label %L27, label %L248 L27: ; preds = %top ; ┌ @ abstractarray.jl:102 within `axes` ; │┌ @ essentials.jl:12 within `size` %.size_ptr3 = getelementptr inbounds nuw i8, ptr %2, i64 16 %.size4.0.copyload = load i64, ptr %.size_ptr3, align 8 ; └└ ; ┌ @ tuple.jl:543 within `==` ; │┌ @ tuple.jl:547 within `_eq` ; ││┌ @ range.jl:1142 within `==` @ promotion.jl:637 %.not.not239 = icmp eq i64 %.size.0.copyload, %.size4.0.copyload ; └└└ br i1 %.not.not239, label %L29, label %L248 L29: ; preds = %L27 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:941 ; ┌ @ essentials.jl:1226 within `+` %5 = add i64 %.size.0.copyload, -3 ; └ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:945 ; ┌ @ int.jl:560 within `<=` %.not131218 = icmp slt i64 %5, 1 ; └ br i1 %.not131218, label %L184.preheader, label %L37 L184.preheader.loopexit: ; preds = %L166 %.size47.0.copyload.pre = load i64, ptr %.size_ptr, align 8 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:947 ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:113 within `vstorec` br label %L184.preheader L184.preheader: ; preds = %L184.preheader.loopexit, %L29 %.size47.0.copyload = phi i64 [ %.size.0.copyload, %L29 ], [ %.size47.0.copyload.pre, %L184.preheader.loopexit ] %value_phi10.lcssa = phi i64 [ 1, %L29 ], [ %27, %L184.preheader.loopexit ] %value_phi11.lcssa = phi i64 [ 1, %L29 ], [ %28, %L184.preheader.loopexit ] ; └ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:951 ; ┌ @ int.jl:560 within `<=` %.not141236 = icmp sgt i64 %value_phi11.lcssa, %.size47.0.copyload ; └ br i1 %.not141236, label %L251, label %L192.lr.ph L192.lr.ph: ; preds = %L184.preheader %.size49.0.copyload = load i64, ptr %.size_ptr3, align 8 %memoryref_data = load ptr, ptr %2, align 8 %6 = getelementptr inbounds nuw i8, ptr %2, i64 8 %memoryref_mem = load ptr, ptr %6, align 8 %memory_data_ptr = getelementptr inbounds nuw i8, ptr %memoryref_mem, i64 8 %memoryref_data60 = load ptr, ptr %4, align 8 %7 = getelementptr inbounds nuw i8, ptr %4, i64 8 %memoryref_mem80 = load ptr, ptr %7, align 8 %memory_data_ptr68 = getelementptr inbounds nuw i8, ptr %memoryref_mem80, i64 8 %.size86.0.copyload = load i64, ptr %.size_ptr1, align 8 %memoryref_data89 = load ptr, ptr %0, align 8 %8 = getelementptr inbounds nuw i8, ptr %0, i64 8 %memoryref_mem110 = load ptr, ptr %8, align 8 %memory_data_ptr97 = getelementptr inbounds nuw i8, ptr %memoryref_mem110, i64 8 br label %L192 L37: ; preds = %L166, %L29 %value_phi11224 = phi i64 [ %28, %L166 ], [ 1, %L29 ] %value_phi10223 = phi i64 [ %27, %L166 ], [ 1, %L29 ] ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:946 ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; ││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; ││││┌ @ int.jl:560 within `<=` %9 = icmp sgt i64 %value_phi11224, 0 ; ││││└ br i1 %9, label %L52, label %L54 L52: ; preds = %L37 ; │││└ ; │││┌ @ abstractarray.jl:394 within `eachindex` ; ││││┌ @ essentials.jl:1255 within `length` %.size13.0.copyload = load i64, ptr %.size_ptr3, align 8 ; │││└└ ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:224 within `last` ; │││││┌ @ essentials.jl:1227 within `-` %10 = add nuw i64 %value_phi11224, 3 ; ││││└└ ; ││││┌ @ int.jl:560 within `<=` %.not.not334 = icmp sgt i64 %10, %.size13.0.copyload ; │││└└ ; │││ @ essentials.jl:391 within `checkbounds` br i1 %.not.not334, label %L54, label %L58 L54: ; preds = %L52, %L37 %value_phi11224.lcssa = phi i64 [ -9223372036854775807, %L37 ], [ %value_phi11224, %L52 ] ; └└└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:226 within `+` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:219 within `VecRange` store i64 %value_phi11224.lcssa, ptr %"new::VecRange", align 1 ; └└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; ││┌ @ essentials.jl:391 within `checkbounds` call void @j__throw_boundserror_indices_3(ptr nonnull %2, ptr nocapture nonnull readonly %"new::VecRange") #6 unreachable L58: ; preds = %L52 ; │└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; ││┌ @ indices.jl:557 within `getindex` ; │││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; ││││┌ @ abstractarray.jl:753 within `checkindex` ; │││││┌ @ essentials.jl:1227 within `-` %11 = add nsw i64 %value_phi11224, -1 ; │││││└ ; │││││┌ @ int.jl:559 within `<` %.not132 = icmp ult i64 %11, %.size13.0.copyload ; ││││└└ ; ││││ @ essentials.jl:391 within `checkbounds` br i1 %.not132, label %L101, label %L72 L72: ; preds = %L58 ; ││└└ ; ││┌ @ indices.jl:533 within `LinearIndices` ; │││┌ @ abstractarray.jl:102 within `axes` ; ││││┌ @ tuple.jl:357 within `map` ; │││││┌ @ range.jl:488 within `unchecked_oneto` store i64 %.size13.0.copyload, ptr %"new::LinearIndices", align 1 ; ││└└└└ ; ││┌ @ indices.jl:557 within `getindex` ; │││┌ @ essentials.jl:391 within `checkbounds` call void @j__throw_boundserror_indices_1(ptr nocapture nonnull readonly %"new::LinearIndices", i64 signext %value_phi11224) #6 unreachable L101: ; preds = %L58 ; ││└└ ; ││┌ @ abstractarray.jl:1273 within `pointer` @ abstractarray.jl:1270 ; │││┌ @ pointer.jl:63 within `cconvert` %12 = load ptr, ptr %2, align 8 ; │││└ ; │││ @ abstractarray.jl:1273 within `pointer` ; │││┌ @ pointer.jl:314 within `+` %13 = getelementptr i8, ptr %12, i64 %11 ; │└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 within `vload` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:51 ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:477 within `load` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:486 within `macro expansion` %res.i = load <4 x i8>, ptr %13, align 1 ; └└└└ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:947 ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; ││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││┌ @ abstractarray.jl:394 within `eachindex` ; ││││┌ @ essentials.jl:1255 within `length` %.size20.0.copyload = load i64, ptr %.size_ptr, align 8 ; │││└└ ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; ││││┌ @ int.jl:560 within `<=` %.not240.not = icmp sgt i64 %10, %.size20.0.copyload ; │││└└ ; │││ @ essentials.jl:391 within `checkbounds` br i1 %.not240.not, label %L103, label %L107 L103: ; preds = %L101 ; └└└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:226 within `+` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:219 within `VecRange` store i64 %value_phi11224, ptr %"new::VecRange17", align 1 ; └└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; ││┌ @ essentials.jl:391 within `checkbounds` call void @j__throw_boundserror_indices_2(ptr nonnull %4, ptr nocapture nonnull readonly %"new::VecRange17") #6 unreachable L107: ; preds = %L101 ; │└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; ││┌ @ indices.jl:557 within `getindex` ; │││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; ││││┌ @ abstractarray.jl:753 within `checkindex` ; │││││┌ @ int.jl:559 within `<` %.not133 = icmp ult i64 %11, %.size20.0.copyload ; ││││└└ ; ││││ @ essentials.jl:391 within `checkbounds` br i1 %.not133, label %L125, label %L121 L121: ; preds = %L107 ; ││└└ ; ││┌ @ indices.jl:533 within `LinearIndices` ; │││┌ @ abstractarray.jl:102 within `axes` ; ││││┌ @ tuple.jl:357 within `map` ; │││││┌ @ range.jl:488 within `unchecked_oneto` store i64 %.size20.0.copyload, ptr %"new::LinearIndices24", align 1 ; ││└└└└ ; ││┌ @ indices.jl:557 within `getindex` ; │││┌ @ essentials.jl:391 within `checkbounds` call void @j__throw_boundserror_indices_1(ptr nocapture nonnull readonly %"new::LinearIndices24", i64 signext %value_phi11224) #6 unreachable L125: ; preds = %L107 ; └└└└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:110 within `vstorec` ; │┌ @ essentials.jl:1227 within `-` %14 = add i64 %value_phi10223, 3 ; │└ ; │┌ @ range.jl:5 within `Colon` ; ││┌ @ range.jl:417 within `UnitRange` ; │││┌ @ range.jl:428 within `unitrange_last` ; ││││┌ @ operators.jl:479 within `>=` ; │││││┌ @ int.jl:560 within `<=` %.not134 = icmp sgt i64 %value_phi10223, 9223372036854775804 ; ││││└└ %15 = add i64 %value_phi10223, -1 %value_phi27 = select i1 %.not134, i64 %15, i64 %14 ; │└└└ ; │┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; ││┌ @ abstractarray.jl:394 within `eachindex` ; │││┌ @ essentials.jl:1255 within `length` %.size31.0.copyload = load i64, ptr %.size_ptr1, align 8 ; ││└└ ; ││┌ @ abstractarray.jl:756 within `checkindex` ; │││┌ @ range.jl:697 within `isempty` ; ││││┌ @ operators.jl:424 within `>` ; │││││┌ @ int.jl:83 within `<` %16 = icmp slt i64 %value_phi27, %value_phi10223 ; │││└└└ ; │││ @ abstractarray.jl:756 within `checkindex` @ abstractarray.jl:753 ; │││┌ @ int.jl:559 within `<` %17 = icmp ult i64 %15, %.size31.0.copyload ; │││└ ; │││┌ @ essentials.jl:1227 within `-` %18 = add i64 %value_phi27, -1 ; │││└ ; │││┌ @ int.jl:559 within `<` %19 = icmp ult i64 %18, %.size31.0.copyload ; ││└└ ; ││ @ essentials.jl:391 within `checkbounds` %.not140.not245 = and i1 %17, %19 %.not137.not242 = or i1 %16, %.not140.not245 br i1 %.not137.not242, label %L166, label %L163 L163: ; preds = %L125 %20 = getelementptr inbounds nuw i8, ptr %"new::UnitRange", i64 8 ; │└ ; │┌ @ range.jl:5 within `Colon` ; ││┌ @ range.jl:417 within `UnitRange` store i64 %value_phi27, ptr %20, align 1 store i64 %value_phi10223, ptr %"new::UnitRange", align 1 ; │└└ ; │┌ @ essentials.jl:391 within `checkbounds` call void @j__throw_boundserror_indices_0(ptr nonnull %0, ptr nocapture nonnull readonly %"new::UnitRange") #6 unreachable L166: ; preds = %L125 ; └└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; ││┌ @ abstractarray.jl:1273 within `pointer` @ abstractarray.jl:1270 ; │││┌ @ pointer.jl:63 within `cconvert` %21 = load ptr, ptr %4, align 8 ; │││└ ; │││ @ abstractarray.jl:1273 within `pointer` ; │││┌ @ abstractarray.jl:1277 within `_memory_offset` ; ││││┌ @ int.jl:88 within `*` %22 = shl i64 %11, 3 ; │││└└ ; │││┌ @ pointer.jl:314 within `+` %23 = getelementptr i8, ptr %21, i64 %22 ; │└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 within `vload` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:51 ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:477 within `load` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:486 within `macro expansion` %res.i151 = load <4 x double>, ptr %23, align 8 ; └└└└ ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:112 within `vstorec` ; │┌ @ abstractarray.jl:1273 within `pointer` @ abstractarray.jl:1270 ; ││┌ @ pointer.jl:63 within `cconvert` %24 = load ptr, ptr %0, align 8 ; ││└ ; ││ @ abstractarray.jl:1273 within `pointer` ; ││┌ @ abstractarray.jl:1277 within `_memory_offset` ; │││┌ @ int.jl:88 within `*` %25 = shl i64 %15, 3 ; ││└└ ; ││┌ @ pointer.jl:314 within `+` %26 = getelementptr i8, ptr %24, i64 %25 ; │└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:113 within `vstorec` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:105 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:663 within `maskedcompressstore` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:680 within `macro expansion` %mask.i = trunc <4 x i8> %res.i to <4 x i1> call void @llvm.masked.compressstore.v4f64(<4 x double> %res.i151, ptr %26, <4 x i1> %mask.i) ; └└└ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:948 ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:496 within `sum` ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:486 within `reduce` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1099 within `reduce_add` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1129 within `macro expansion` %maski.i = bitcast <4 x i1> %mask.i to i4 %maskipopcnt.i = call range(i4 0, 5) i4 @llvm.ctpop.i4(i4 %maski.i) %res.i153 = zext nneg i4 %maskipopcnt.i to i64 ; └└└└ ; ┌ @ essentials.jl:1226 within `+` %27 = add i64 %value_phi10223, %res.i153 ; └ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:949 ; ┌ @ essentials.jl:1226 within `+` %28 = add nuw i64 %value_phi11224, 4 ; └ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:945 ; ┌ @ int.jl:560 within `<=` %.not131 = icmp sgt i64 %28, %5 ; └ br i1 %.not131, label %L184.preheader.loopexit, label %L37 L192: ; preds = %L244, %L192.lr.ph %value_phi45238 = phi i64 [ %value_phi11.lcssa, %L192.lr.ph ], [ %45, %L244 ] %value_phi44237 = phi i64 [ %value_phi10.lcssa, %L192.lr.ph ], [ %value_phi115, %L244 ] ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:952 ; ┌ @ essentials.jl:1039 within `getindex` ; │┌ @ essentials.jl:391 within `checkbounds` @ essentials.jl:387 %29 = add i64 %value_phi45238, -1 %.not142 = icmp ult i64 %29, %.size49.0.copyload ; ││ @ essentials.jl:391 within `checkbounds` br i1 %.not142, label %L203, label %L200 L200: ; preds = %L192 call void @j__throw_boundserror_indices_5(ptr nonnull %2, i64 signext %value_phi45238) #6 unreachable L203: ; preds = %L192 ; │└ ; │ @ essentials.jl:1040 within `getindex` %memory_len = load i64, ptr %memoryref_mem, align 8 %30 = shl nuw i64 %memory_len, 1 %31 = add i64 %memory_len, %29 %memoryref_ovflw.not = icmp ult i64 %31, %30 %memoryref_data_byteoffset = getelementptr i8, ptr %memoryref_data, i64 %29 %memory_data = load ptr, ptr %memory_data_ptr, align 8 %32 = ptrtoint ptr %memory_data to i64 %33 = ptrtoint ptr %memoryref_data_byteoffset to i64 %34 = sub i64 %33, %32 %memoryref_isinbounds = icmp ult i64 %34, %memory_len %or.cond = select i1 %memoryref_ovflw.not, i1 %memoryref_isinbounds, i1 false br i1 %or.cond, label %load, label %oob L210: ; preds = %load ; └ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:953 ; ┌ @ essentials.jl:1039 within `getindex` ; │┌ @ essentials.jl:391 within `checkbounds` @ essentials.jl:387 %.not145 = icmp ult i64 %29, %.size47.0.copyload ; ││ @ essentials.jl:391 within `checkbounds` br i1 %.not145, label %L221, label %L218 L218: ; preds = %L210 call void @j__throw_boundserror_indices_4(ptr nonnull %4, i64 signext %value_phi45238) #6 unreachable L221: ; preds = %L210 ; │└ ; │ @ essentials.jl:1040 within `getindex` %memory_len63 = load i64, ptr %memoryref_mem80, align 8 %35 = shl nuw nsw i64 %memory_len63, 1 %36 = add i64 %memory_len63, %29 %memoryref_ovflw64.not = icmp ult i64 %36, %35 %memoryref_byteoffset65 = shl i64 %29, 3 %memoryref_data_byteoffset66 = getelementptr i8, ptr %memoryref_data60, i64 %memoryref_byteoffset65 %memory_data69 = load ptr, ptr %memory_data_ptr68, align 8 %37 = ptrtoint ptr %memory_data69 to i64 %38 = ptrtoint ptr %memoryref_data_byteoffset66 to i64 %39 = sub i64 %38, %37 %memoryref_bytelen70 = shl nuw nsw i64 %memory_len63, 3 %memoryref_isinbounds73 = icmp ult i64 %39, %memoryref_bytelen70 %or.cond125 = select i1 %memoryref_ovflw64.not, i1 %memoryref_isinbounds73, i1 false br i1 %or.cond125, label %idxend78, label %oob74 L235: ; preds = %idxend78 ; └ ; ┌ @ array.jl:1043 within `setindex!` ; │┌ @ array.jl:1047 within `_setindex!` ; ││┌ @ essentials.jl:391 within `checkbounds` call void @j__throw_boundserror_indices_4(ptr nonnull %0, i64 signext %value_phi44237) #6 unreachable L238: ; preds = %idxend78 ; ││└ ; ││ @ array.jl:1048 within `_setindex!` %memory_len92 = load i64, ptr %memoryref_mem110, align 8 %40 = shl nuw nsw i64 %memory_len92, 1 %41 = add i64 %memory_len92, %54 %memoryref_ovflw93.not = icmp ult i64 %41, %40 %memoryref_byteoffset94 = shl i64 %54, 3 %memoryref_data_byteoffset95 = getelementptr i8, ptr %memoryref_data89, i64 %memoryref_byteoffset94 %memory_data98 = load ptr, ptr %memory_data_ptr97, align 8 %42 = ptrtoint ptr %memory_data98 to i64 %43 = ptrtoint ptr %memoryref_data_byteoffset95 to i64 %44 = sub i64 %43, %42 %memoryref_bytelen99 = shl nuw nsw i64 %memory_len92, 3 %memoryref_isinbounds102 = icmp ult i64 %44, %memoryref_bytelen99 %or.cond126 = select i1 %memoryref_ovflw93.not, i1 %memoryref_isinbounds102, i1 false br i1 %or.cond126, label %idxend108, label %oob103 L244: ; preds = %idxend108, %load %value_phi115 = phi i64 [ %56, %idxend108 ], [ %value_phi44237, %load ] ; └└ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:956 ; ┌ @ essentials.jl:1226 within `+` %45 = add i64 %value_phi45238, 1 ; └ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:951 ; ┌ @ int.jl:560 within `<=` %.not141 = icmp sgt i64 %45, %.size47.0.copyload ; └ br i1 %.not141, label %L251, label %L192 L248: ; preds = %L27, %top ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 %"jl_global#3" = load ptr, ptr @"jl_global#3", align 8 %46 = call [1 x ptr] @j_AssertionError_0(ptr nonnull %"jl_global#3") %"+Core.AssertionError#0" = load ptr, ptr @"+Core.AssertionError#0", align 8 %gc_slot_addr_0 = getelementptr inbounds nuw i8, ptr %gcframe2, i64 16 %47 = extractvalue [1 x ptr] %46, 0 store ptr %47, ptr %gc_slot_addr_0, align 8 %ptls_field = getelementptr inbounds nuw i8, ptr %tls_pgcstack, i64 16 %ptls_load = load ptr, ptr %ptls_field, align 8 %48 = ptrtoint ptr %"+Core.AssertionError#0" to i64 %"box::AssertionError" = call noalias nonnull align 8 dereferenceable(16) ptr @ijl_gc_small_alloc(ptr %ptls_load, i32 360, i32 16, i64 %48) #14 %"box::AssertionError.tag_addr" = getelementptr inbounds i8, ptr %"box::AssertionError", i64 -8 store atomic ptr %"+Core.AssertionError#0", ptr %"box::AssertionError.tag_addr" unordered, align 8 store ptr %47, ptr %"box::AssertionError", align 8 store ptr null, ptr %gc_slot_addr_0, align 8 call void @ijl_throw(ptr nonnull %"box::AssertionError") unreachable L251: ; preds = %L244, %L184.preheader %frame.prev424 = load ptr, ptr %frame.prev, align 8 store ptr %frame.prev424, ptr %tls_pgcstack, align 8 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:958 ret ptr %0 oob: ; preds = %L203 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:952 ; ┌ @ essentials.jl:1040 within `getindex` %"+Core.GenericMemoryRef#0" = load ptr, ptr @"+Core.GenericMemoryRef#0", align 8 %gc_slot_addr_0401 = getelementptr inbounds nuw i8, ptr %gcframe2, i64 16 store ptr %memoryref_mem, ptr %gc_slot_addr_0401, align 8 %ptls_field413 = getelementptr inbounds nuw i8, ptr %tls_pgcstack, i64 16 %ptls_load414 = load ptr, ptr %ptls_field413, align 8 %49 = ptrtoint ptr %"+Core.GenericMemoryRef#0" to i64 %"box::GenericMemoryRef" = call noalias nonnull align 8 dereferenceable(32) ptr @ijl_gc_small_alloc(ptr %ptls_load414, i32 408, i32 32, i64 %49) #14 %"box::GenericMemoryRef.tag_addr" = getelementptr inbounds i8, ptr %"box::GenericMemoryRef", i64 -8 store atomic ptr %"+Core.GenericMemoryRef#0", ptr %"box::GenericMemoryRef.tag_addr" unordered, align 8 store ptr %memoryref_data, ptr %"box::GenericMemoryRef", align 8 %.repack143 = getelementptr inbounds nuw i8, ptr %"box::GenericMemoryRef", i64 8 store ptr %memoryref_mem, ptr %.repack143, align 8 store ptr null, ptr %gc_slot_addr_0401, align 8 call void @ijl_bounds_error_int(ptr nonnull %"box::GenericMemoryRef", i64 %value_phi45238) unreachable load: ; preds = %L203 %50 = load i8, ptr %memoryref_data_byteoffset, align 1 %51 = trunc i8 %50 to i1 ; └ br i1 %51, label %L210, label %L244 oob74: ; preds = %L221 ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:953 ; ┌ @ essentials.jl:1040 within `getindex` %"+Core.GenericMemoryRef#1" = load ptr, ptr @"+Core.GenericMemoryRef#1", align 8 %gc_slot_addr_0403 = getelementptr inbounds nuw i8, ptr %gcframe2, i64 16 store ptr %memoryref_mem80, ptr %gc_slot_addr_0403, align 8 %ptls_field417 = getelementptr inbounds nuw i8, ptr %tls_pgcstack, i64 16 %ptls_load418 = load ptr, ptr %ptls_field417, align 8 %52 = ptrtoint ptr %"+Core.GenericMemoryRef#1" to i64 %"box::GenericMemoryRef77" = call noalias nonnull align 8 dereferenceable(32) ptr @ijl_gc_small_alloc(ptr %ptls_load418, i32 408, i32 32, i64 %52) #14 %"box::GenericMemoryRef77.tag_addr" = getelementptr inbounds i8, ptr %"box::GenericMemoryRef77", i64 -8 store atomic ptr %"+Core.GenericMemoryRef#1", ptr %"box::GenericMemoryRef77.tag_addr" unordered, align 8 store ptr %memoryref_data60, ptr %"box::GenericMemoryRef77", align 8 %.repack146 = getelementptr inbounds nuw i8, ptr %"box::GenericMemoryRef77", i64 8 store ptr %memoryref_mem80, ptr %.repack146, align 8 store ptr null, ptr %gc_slot_addr_0403, align 8 call void @ijl_bounds_error_int(ptr nonnull %"box::GenericMemoryRef77", i64 %value_phi45238) unreachable idxend78: ; preds = %L221 %53 = load double, ptr %memoryref_data_byteoffset66, align 8 ; └ ; ┌ @ array.jl:1043 within `setindex!` ; │┌ @ array.jl:1047 within `_setindex!` ; ││┌ @ essentials.jl:391 within `checkbounds` @ essentials.jl:387 %54 = add i64 %value_phi44237, -1 %.not148 = icmp ult i64 %54, %.size86.0.copyload ; │││ @ essentials.jl:391 within `checkbounds` br i1 %.not148, label %L238, label %L235 oob103: ; preds = %L238 ; ││└ ; ││ @ array.jl:1048 within `_setindex!` %"+Core.GenericMemoryRef#1104" = load ptr, ptr @"+Core.GenericMemoryRef#1", align 8 %gc_slot_addr_0405 = getelementptr inbounds nuw i8, ptr %gcframe2, i64 16 store ptr %memoryref_mem110, ptr %gc_slot_addr_0405, align 8 %ptls_field421 = getelementptr inbounds nuw i8, ptr %tls_pgcstack, i64 16 %ptls_load422 = load ptr, ptr %ptls_field421, align 8 %55 = ptrtoint ptr %"+Core.GenericMemoryRef#1104" to i64 %"box::GenericMemoryRef107" = call noalias nonnull align 8 dereferenceable(32) ptr @ijl_gc_small_alloc(ptr %ptls_load422, i32 408, i32 32, i64 %55) #14 %"box::GenericMemoryRef107.tag_addr" = getelementptr inbounds i8, ptr %"box::GenericMemoryRef107", i64 -8 store atomic ptr %"+Core.GenericMemoryRef#1104", ptr %"box::GenericMemoryRef107.tag_addr" unordered, align 8 store ptr %memoryref_data89, ptr %"box::GenericMemoryRef107", align 8 %.repack149 = getelementptr inbounds nuw i8, ptr %"box::GenericMemoryRef107", i64 8 store ptr %memoryref_mem110, ptr %.repack149, align 8 store ptr null, ptr %gc_slot_addr_0405, align 8 call void @ijl_bounds_error_int(ptr nonnull %"box::GenericMemoryRef107", i64 %value_phi44237) unreachable idxend108: ; preds = %L238 store double %53, ptr %memoryref_data_byteoffset95, align 8 ; └└ ; @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:954 ; ┌ @ essentials.jl:1226 within `+` %56 = add i64 %value_phi44237, 1 br label %L244 ; └ } .file "vcompress!" .section .ltext,"axl",@progbits .globl "japi1_vcompress!_0" # -- Begin function japi1_vcompress!_0 .p2align 4 .type "japi1_vcompress!_0",@function "japi1_vcompress!_0": # @"japi1_vcompress!_0" ; Function Signature: vcompress!(Array{Float64, 1}, Array{Bool, 1}, Array{Float64, 1}) ; ┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:939 within `vcompress!` # %bb.0: # %top #DEBUG_VALUE: vcompress!:dest <- undef #DEBUG_VALUE: vcompress!:pred <- undef #DEBUG_VALUE: vcompress!:src <- undef push rbp mov rbp, rsp push r15 push r14 push r13 push r12 push rbx sub rsp, 152 vxorps xmm0, xmm0, xmm0 #APP mov rax, qword ptr fs:[0] #NO_APP lea rcx, [rbp - 80] vmovaps xmmword ptr [rbp - 80], xmm0 mov qword ptr [rbp - 64], 0 mov qword ptr [rbp - 184], rsi mov r15, qword ptr [rax - 8] mov qword ptr [rbp - 80], 4 mov rax, qword ptr [r15] mov qword ptr [rbp - 72], rax mov qword ptr [r15], rcx mov rcx, qword ptr [rsi + 16] mov rax, qword ptr [rsi] ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 ; │┌ @ abstractarray.jl:102 within `axes` ; ││┌ @ essentials.jl:12 within `size` mov rdx, qword ptr [rcx + 16] ; │└└ ; │┌ @ tuple.jl:543 within `==` ; ││┌ @ tuple.jl:547 within `_eq` ; │││┌ @ range.jl:1142 within `==` @ promotion.jl:637 cmp qword ptr [rax + 16], rdx ; │└└└ jne .LBB0_36 # %bb.1: # %L27 mov rdi, qword ptr [rsi + 8] ; │┌ @ tuple.jl:543 within `==` ; ││┌ @ tuple.jl:547 within `_eq` ; │││┌ @ range.jl:1142 within `==` @ promotion.jl:637 cmp rdx, qword ptr [rdi + 16] ; │└└└ jne .LBB0_36 # %bb.2: # %L29 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:941 ; │┌ @ essentials.jl:1226 within `+` lea r8, [rdx - 3] mov r14d, 1 mov qword ptr [rbp - 48], r15 # 8-byte Spill ; │└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:945 ; │┌ @ int.jl:560 within `<=` test r8, r8 ; │└ jle .LBB0_3 # %bb.9: # %L37.preheader movabs rdx, 9223372036854775804 xor r9d, r9d jmp .LBB0_10 .p2align 4 .LBB0_25: # %else23 # in Loop: Header=BB0_10 Depth=1 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:948 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:496 within `sum` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/simdvec.jl:486 within `reduce` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1099 within `reduce_add` ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:1129 within `macro expansion` popcnt esi, r10d ; │└└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:945 ; │┌ @ int.jl:560 within `<=` add r9, 5 ; │└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:948 ; │┌ @ essentials.jl:1226 within `+` add r14, rsi ; │└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:945 ; │┌ @ int.jl:560 within `<=` cmp r9, r8 mov r9, rbx ; │└ jg .LBB0_4 .LBB0_10: # %L37 # =>This Inner Loop Header: Depth=1 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:946 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; │││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; │││││┌ @ int.jl:560 within `<=` lea rsi, [r9 + 1] test rsi, rsi ; │││││└ jle .LBB0_44 # %bb.11: # %L52 # in Loop: Header=BB0_10 Depth=1 ; ││││└ ; ││││┌ @ abstractarray.jl:394 within `eachindex` ; │││││┌ @ essentials.jl:1255 within `length` mov r10, qword ptr [rdi + 16] ; ││││└└ ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; │││││┌ @ int.jl:560 within `<=` lea rbx, [r9 + 4] cmp rbx, r10 ; ││││└└ ; ││││ @ essentials.jl:391 within `checkbounds` jg .LBB0_45 # %bb.12: # %L58 # in Loop: Header=BB0_10 Depth=1 ; ││└└ ; ││ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; │││┌ @ indices.jl:557 within `getindex` ; ││││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││││┌ @ abstractarray.jl:753 within `checkindex` ; ││││││┌ @ int.jl:559 within `<` cmp r9, r10 ; │││││└└ ; │││││ @ essentials.jl:391 within `checkbounds` jae .LBB0_46 # %bb.13: # %L101 # in Loop: Header=BB0_10 Depth=1 ; │└└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:947 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; │││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; ││││┌ @ abstractarray.jl:394 within `eachindex` ; │││││┌ @ essentials.jl:1255 within `length` mov r10, qword ptr [rcx + 16] ; ││││└└ ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:230 within `checkindex` ; │││││┌ @ int.jl:560 within `<=` cmp rbx, r10 ; ││││└└ ; ││││ @ essentials.jl:391 within `checkbounds` jg .LBB0_47 # %bb.14: # %L107 # in Loop: Header=BB0_10 Depth=1 ; ││└└ ; ││ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; │││┌ @ indices.jl:557 within `getindex` ; ││││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││││┌ @ abstractarray.jl:753 within `checkindex` ; ││││││┌ @ int.jl:559 within `<` cmp r9, r10 ; │││││└└ ; │││││ @ essentials.jl:391 within `checkbounds` jae .LBB0_48 # %bb.15: # %L125 # in Loop: Header=BB0_10 Depth=1 ; │└└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:0 mov rsi, qword ptr [rdi] ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:947 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:110 within `vstorec` ; ││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││┌ @ abstractarray.jl:394 within `eachindex` ; ││││┌ @ essentials.jl:1255 within `length` mov r15, qword ptr [rax + 16] ; ││└└└ ; ││┌ @ essentials.jl:1227 within `-` lea r10, [r14 + 3] ; ││└ ; ││┌ @ range.jl:5 within `Colon` ; │││┌ @ range.jl:417 within `UnitRange` ; ││││┌ @ range.jl:428 within `unitrange_last` ; │││││┌ @ operators.jl:479 within `>=` ; ││││││┌ @ int.jl:560 within `<=` cmp r14, rdx ; │└└└└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:0 vmovd xmm1, dword ptr [rsi + r9] # xmm1 = mem[0],zero,zero,zero ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:947 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:110 within `vstorec` ; ││┌ @ range.jl:5 within `Colon` ; │││┌ @ range.jl:417 within `UnitRange` ; ││││┌ @ range.jl:428 within `unitrange_last` lea rsi, [r14 - 1] cmovg r10, rsi ; ││└└└ ; ││┌ @ essentials.jl:391 within `checkbounds` @ abstractarray.jl:692 ; │││┌ @ abstractarray.jl:756 within `checkindex` @ abstractarray.jl:753 ; ││││┌ @ int.jl:559 within `<` cmp rsi, r15 ; ││││└ ; ││││┌ @ essentials.jl:1227 within `-` lea r12, [r10 - 1] ; ││││└ ; ││││┌ @ int.jl:559 within `<` setb r11b cmp r12, r15 setb r15b ; ││││└ ; ││││ @ abstractarray.jl:756 within `checkindex` ; ││││┌ @ range.jl:697 within `isempty` ; │││││┌ @ operators.jl:424 within `>` ; ││││││┌ @ int.jl:83 within `<` cmp r10, r14 ; │││└└└└ ; │││ @ essentials.jl:391 within `checkbounds` jl .LBB0_17 # %bb.16: # %L125 # in Loop: Header=BB0_10 Depth=1 and r11b, r15b je .LBB0_49 .LBB0_17: # %L166 # in Loop: Header=BB0_10 Depth=1 ; │└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; │││┌ @ abstractarray.jl:1273 within `pointer` @ abstractarray.jl:1270 ; ││││┌ @ pointer.jl:63 within `cconvert` mov r10, qword ptr [rcx] ; │└└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:112 within `vstorec` ; ││┌ @ abstractarray.jl:1273 within `pointer` ; │││┌ @ abstractarray.jl:1277 within `_memory_offset` ; ││││┌ @ int.jl:88 within `*` shl rsi, 3 ; │││└└ ; │││┌ @ pointer.jl:314 within `+` add rsi, qword ptr [rax] ; ││└└ ; ││ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:113 within `vstorec` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:105 ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:663 within `maskedcompressstore` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:680 within `macro expansion` vpmovzxbd xmm1, xmm1 # xmm1 = xmm1[0],zero,zero,zero,xmm1[1],zero,zero,zero,xmm1[2],zero,zero,zero,xmm1[3],zero,zero,zero vpslld xmm1, xmm1, 31 ; │└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 within `vload` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:50 @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:51 ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:477 within `load` ; ││││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:486 within `macro expansion` vmovups ymm0, ymmword ptr [r10 + 8*r9] ; │└└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:113 within `vstorec` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:105 ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:663 within `maskedcompressstore` ; │││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/LLVM_intrinsics.jl:680 within `macro expansion` vmovmskps r10d, xmm1 test r10b, 1 jne .LBB0_18 # %bb.19: # %else # in Loop: Header=BB0_10 Depth=1 test r10b, 2 jne .LBB0_20 .LBB0_21: # %else17 # in Loop: Header=BB0_10 Depth=1 test r10b, 4 jne .LBB0_22 .LBB0_23: # %else20 # in Loop: Header=BB0_10 Depth=1 test r10b, 8 je .LBB0_25 jmp .LBB0_24 .p2align 4 .LBB0_18: # %cond.store # in Loop: Header=BB0_10 Depth=1 vmovlps qword ptr [rsi], xmm0 add rsi, 8 test r10b, 2 je .LBB0_21 .LBB0_20: # %cond.store16 # in Loop: Header=BB0_10 Depth=1 vmovhps qword ptr [rsi], xmm0 add rsi, 8 test r10b, 4 je .LBB0_23 .LBB0_22: # %cond.store19 # in Loop: Header=BB0_10 Depth=1 vextractf128 xmm1, ymm0, 1 vmovlps qword ptr [rsi], xmm1 add rsi, 8 test r10b, 8 je .LBB0_25 .LBB0_24: # %cond.store22 # in Loop: Header=BB0_10 Depth=1 vextractf128 xmm0, ymm0, 1 vmovhps qword ptr [rsi], xmm0 jmp .LBB0_25 .LBB0_4: # %L184.preheader.loopexit mov rdx, qword ptr [rcx + 16] ; ││└└ ; ││ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:113 within `vstorec` inc rbx ; │└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:951 ; │┌ @ int.jl:560 within `<=` cmp rbx, rdx ; │└ jg .LBB0_43 jmp .LBB0_6 .LBB0_3: mov ebx, 1 ; │┌ @ int.jl:560 within `<=` cmp rbx, rdx ; │└ jle .LBB0_6 .LBB0_43: # %L251 mov rcx, qword ptr [rbp - 72] mov rdx, qword ptr [rbp - 48] # 8-byte Reload mov qword ptr [rdx], rcx ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:958 add rsp, 152 pop rbx pop r12 pop r13 pop r14 pop r15 pop rbp vzeroupper ret .LBB0_6: # %L192.lr.ph mov r10, qword ptr [rcx + 8] mov r8, qword ptr [rdi] mov r9, qword ptr [rcx] mov rsi, qword ptr [rdi + 16] mov r13, qword ptr [rdi + 8] mov r12, qword ptr [rax + 8] mov qword ptr [rbp - 120], r10 # 8-byte Spill mov r10, qword ptr [rax + 16] mov qword ptr [rbp - 104], r8 # 8-byte Spill dec r8 mov qword ptr [rbp - 128], rsi # 8-byte Spill mov qword ptr [rbp - 88], r9 # 8-byte Spill mov qword ptr [rbp - 112], r10 # 8-byte Spill mov r10, qword ptr [rax] mov qword ptr [rbp - 96], r10 # 8-byte Spill ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:951 lea r10, [r9 + 8*rbx - 8] jmp .LBB0_7 .p2align 4 .LBB0_38: # in Loop: Header=BB0_7 Depth=1 mov r12, rsi .LBB0_42: # %L244 # in Loop: Header=BB0_7 Depth=1 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:956 ; │┌ @ essentials.jl:1226 within `+` inc rbx ; │└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:951 ; │┌ @ int.jl:560 within `<=` add r10, 8 cmp rbx, rdx ; │└ jg .LBB0_43 .LBB0_7: # %L192 # =>This Inner Loop Header: Depth=1 ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:952 ; │┌ @ essentials.jl:1039 within `getindex` ; ││┌ @ essentials.jl:391 within `checkbounds` @ essentials.jl:387 lea r11, [rbx - 1] cmp r11, qword ptr [rbp - 128] # 8-byte Folded Reload ; │││ @ essentials.jl:391 within `checkbounds` jae .LBB0_8 # %bb.26: # %L203 # in Loop: Header=BB0_7 Depth=1 ; ││└ ; ││ @ essentials.jl:1040 within `getindex` mov r9, qword ptr [r13] mov rsi, r12 lea r12, [r9 + r9] lea r15, [rbx + r9 - 1] cmp r15, r12 jae .LBB0_28 # %bb.27: # %L203 # in Loop: Header=BB0_7 Depth=1 lea r15, [r8 + rbx] sub r15, qword ptr [r13 + 8] cmp r15, r9 jae .LBB0_28 # %bb.37: # %load # in Loop: Header=BB0_7 Depth=1 mov r9, qword ptr [rbp - 104] # 8-byte Reload ; │└ test byte ptr [r9 + rbx - 1], 1 je .LBB0_38 # %bb.29: # %L210 # in Loop: Header=BB0_7 Depth=1 mov r12, qword ptr [rbp - 120] # 8-byte Reload ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:953 ; │┌ @ essentials.jl:1039 within `getindex` ; ││┌ @ essentials.jl:391 within `checkbounds` @ essentials.jl:387 cmp r11, rdx ; │││ @ essentials.jl:391 within `checkbounds` jae .LBB0_50 # %bb.30: # %L221 # in Loop: Header=BB0_7 Depth=1 ; ││└ ; ││ @ essentials.jl:1040 within `getindex` mov r9, qword ptr [r12] lea r11, [r9 + r9] lea r15, [rbx + r9 - 1] cmp r15, r11 jae .LBB0_32 # %bb.31: # %L221 # in Loop: Header=BB0_7 Depth=1 mov r11, r10 sub r11, qword ptr [r12 + 8] shl r9, 3 cmp r11, r9 jae .LBB0_32 # %bb.39: # %idxend78 # in Loop: Header=BB0_7 Depth=1 ; │└ ; │┌ @ array.jl:1043 within `setindex!` ; ││┌ @ array.jl:1047 within `_setindex!` ; │││┌ @ essentials.jl:391 within `checkbounds` @ essentials.jl:387 lea r11, [r14 - 1] cmp r11, qword ptr [rbp - 112] # 8-byte Folded Reload ; ││││ @ essentials.jl:391 within `checkbounds` jae .LBB0_40 # %bb.33: # %L238 # in Loop: Header=BB0_7 Depth=1 ; │││└ ; │││ @ array.jl:1048 within `_setindex!` mov r9, qword ptr [rsi] lea r15, [r9 + r9] lea r12, [r9 + r11] cmp r12, r15 mov r12, rsi jae .LBB0_35 # %bb.34: # %L238 # in Loop: Header=BB0_7 Depth=1 mov r15, qword ptr [rbp - 96] # 8-byte Reload shl r9, 3 lea r11, [r15 + 8*r11] mov r15, r11 sub r15, qword ptr [r12 + 8] cmp r15, r9 jae .LBB0_35 # %bb.41: # %idxend108 # in Loop: Header=BB0_7 Depth=1 mov r9, qword ptr [rbp - 88] # 8-byte Reload ; │└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:954 ; │┌ @ essentials.jl:1226 within `+` inc r14 ; │└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:953 vmovsd xmm0, qword ptr [r9 + 8*rbx - 8] # xmm0 = mem[0],zero ; │┌ @ array.jl:1043 within `setindex!` ; ││┌ @ array.jl:1048 within `_setindex!` vmovsd qword ptr [r11], xmm0 jmp .LBB0_42 .LBB0_28: # %oob mov rcx, qword ptr [rbp - 48] # 8-byte Reload ; │└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:952 ; │┌ @ essentials.jl:1040 within `getindex` movabs rax, offset "+Core.GenericMemoryRef#0" mov qword ptr [rbp - 64], r13 mov esi, 408 mov edx, 32 mov r14, qword ptr [rax] movabs rax, offset ijl_gc_small_alloc mov rdi, qword ptr [rcx + 16] mov rcx, r14 vzeroupper call rax mov rcx, qword ptr [rbp - 104] # 8-byte Reload mov qword ptr [rax - 8], r14 mov rdi, rax mov rsi, rbx mov qword ptr [rbp - 64], 0 mov qword ptr [rax], rcx movabs rcx, offset ijl_bounds_error_int mov qword ptr [rax + 8], r13 call rcx .LBB0_32: # %oob74 mov rcx, qword ptr [rbp - 48] # 8-byte Reload ; │└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:953 ; │┌ @ essentials.jl:1040 within `getindex` movabs rax, offset "+Core.GenericMemoryRef#1" mov qword ptr [rbp - 64], r12 mov esi, 408 mov edx, 32 mov r14, qword ptr [rax] movabs rax, offset ijl_gc_small_alloc mov rdi, qword ptr [rcx + 16] mov rcx, r14 vzeroupper call rax mov rcx, qword ptr [rbp - 88] # 8-byte Reload mov qword ptr [rax - 8], r14 mov rdi, rax mov rsi, rbx mov qword ptr [rbp - 64], 0 mov qword ptr [rax], rcx movabs rcx, offset ijl_bounds_error_int mov qword ptr [rax + 8], r12 call rcx .LBB0_35: # %oob103 mov rcx, qword ptr [rbp - 48] # 8-byte Reload ; │└ ; │┌ @ array.jl:1043 within `setindex!` ; ││┌ @ array.jl:1048 within `_setindex!` movabs rax, offset "+Core.GenericMemoryRef#1" mov qword ptr [rbp - 64], r12 mov esi, 408 mov edx, 32 mov rbx, qword ptr [rax] movabs rax, offset ijl_gc_small_alloc mov rdi, qword ptr [rcx + 16] mov rcx, rbx vzeroupper call rax mov rcx, qword ptr [rbp - 96] # 8-byte Reload mov qword ptr [rax - 8], rbx mov rdi, rax mov rsi, r14 mov qword ptr [rbp - 64], 0 mov qword ptr [rax], rcx movabs rcx, offset ijl_bounds_error_int mov qword ptr [rax + 8], r12 call rcx .LBB0_47: # %L103 ; │└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:947 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:226 within `+` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:219 within `VecRange` mov qword ptr [rbp - 144], rsi ; │└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; │││┌ @ essentials.jl:391 within `checkbounds` movabs rax, offset j__throw_boundserror_indices_2 lea rsi, [rbp - 144] mov rdi, rcx vzeroupper call rax .LBB0_49: # %L163 ; │└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:110 within `vstorec` ; ││┌ @ essentials.jl:391 within `checkbounds` movabs rcx, offset j__throw_boundserror_indices_0 lea rsi, [rbp - 176] mov rdi, rax ; ││└ ; ││┌ @ range.jl:5 within `Colon` ; │││┌ @ range.jl:417 within `UnitRange` mov qword ptr [rbp - 168], r10 mov qword ptr [rbp - 176], r14 ; ││└└ ; ││┌ @ essentials.jl:391 within `checkbounds` vzeroupper call rcx .LBB0_48: # %L121 ; │└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; │││┌ @ indices.jl:557 within `getindex` ; ││││┌ @ essentials.jl:391 within `checkbounds` movabs rax, offset j__throw_boundserror_indices_1 lea rdi, [rbp - 136] ; │││└└ ; │││┌ @ indices.jl:533 within `LinearIndices` ; ││││┌ @ abstractarray.jl:102 within `axes` ; │││││┌ @ tuple.jl:357 within `map` ; ││││││┌ @ range.jl:488 within `unchecked_oneto` mov qword ptr [rbp - 136], r10 ; │││└└└└ ; │││┌ @ indices.jl:557 within `getindex` ; ││││┌ @ essentials.jl:391 within `checkbounds` vzeroupper call rax .LBB0_46: # %L72 ; │└└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:946 ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:307 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:291 within `_pointer` ; │││┌ @ indices.jl:557 within `getindex` ; ││││┌ @ essentials.jl:391 within `checkbounds` movabs rax, offset j__throw_boundserror_indices_1 lea rdi, [rbp - 152] ; │││└└ ; │││┌ @ indices.jl:533 within `LinearIndices` ; ││││┌ @ abstractarray.jl:102 within `axes` ; │││││┌ @ tuple.jl:357 within `map` ; ││││││┌ @ range.jl:488 within `unchecked_oneto` mov qword ptr [rbp - 152], r10 ; │││└└└└ ; │││┌ @ indices.jl:557 within `getindex` ; ││││┌ @ essentials.jl:391 within `checkbounds` vzeroupper call rax .LBB0_44: # %L54split add rdx, 5 mov rsi, rdx .LBB0_45: # %L54 ; │└└└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:226 within `+` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:219 within `VecRange` mov qword ptr [rbp - 160], rsi ; │└└ ; │┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:306 within `getindex` ; ││┌ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/src/arrayops.jl:281 within `_preprocessindices` ; │││┌ @ essentials.jl:391 within `checkbounds` movabs rax, offset j__throw_boundserror_indices_3 lea rsi, [rbp - 160] vzeroupper call rax .LBB0_8: # %L200 ; │└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:952 ; │┌ @ essentials.jl:1039 within `getindex` ; ││┌ @ essentials.jl:391 within `checkbounds` movabs rax, offset j__throw_boundserror_indices_5 mov rsi, rbx vzeroupper call rax .LBB0_50: # %L218 ; │└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:953 ; │┌ @ essentials.jl:1039 within `getindex` ; ││┌ @ essentials.jl:391 within `checkbounds` movabs rax, offset j__throw_boundserror_indices_4 mov rdi, rcx mov rsi, rbx vzeroupper call rax .LBB0_40: # %L235 ; │└└ ; │┌ @ array.jl:1043 within `setindex!` ; ││┌ @ array.jl:1047 within `_setindex!` ; │││┌ @ essentials.jl:391 within `checkbounds` movabs rcx, offset j__throw_boundserror_indices_4 mov rdi, rax mov rsi, r14 vzeroupper call rcx .LBB0_36: # %L248 ; │└└└ ; │ @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 within `vcompress!` @ /home/pkgeval/.julia/packages/SIMD/UiGbs/test/runtests.jl:940 movabs rax, offset "jl_global#3" mov rdi, qword ptr [rax] movabs rax, offset j_AssertionError_0 call rax mov rbx, rax movabs rax, offset "+Core.AssertionError#0" mov esi, 360 mov edx, 16 mov r14, qword ptr [rax] mov qword ptr [rbp - 64], rbx movabs rax, offset ijl_gc_small_alloc mov rdi, qword ptr [r15 + 16] mov rcx, r14 call rax movabs rcx, offset ijl_throw mov rdi, rax mov qword ptr [rax - 8], r14 mov qword ptr [rax], rbx mov qword ptr [rbp - 64], 0 call rcx .Lfunc_end0: .size "japi1_vcompress!_0", .Lfunc_end0-"japi1_vcompress!_0" ; └ # -- End function .section ".note.GNU-stack","",@progbits Test Summary: | Pass Total Time Real-world examples | 17 17 2.8s Test Summary: | Pass Total Time Vector shuffles | 222 222 1.9s Test Summary: | Pass Total Time Contiguous ReinterpretArrays load/store | 6 6 1.1s Test Summary: | Pass Total Time funnel shift | 6 6 0.1s Test Summary: | Pass Total Time fastmath min | 2 2 0.0s Test Summary: | Pass Total Time bitmask | 10 10 0.9s Test Summary: | Pass Total Time OpenCL SIMD Load/Store Tests | 197 197 3m12.6s Testing SIMD tests passed Testing completed after 342.87s PkgEval succeeded after 482.23s