<table border="1" cellspacing="0" cellpadding="8">
    <tr>
        <th>Issue</th>
        <td>
            <a href=https://github.com/llvm/llvm-project/issues/69147>69147</a>
        </td>
    </tr>

    <tr>
        <th>Summary</th>
        <td>
            ArgumentPromotion creates an illegal type argument for AArch64 SVE VLS
        </td>
    </tr>

    <tr>
      <th>Labels</th>
      <td>
            backend:AArch64,
            SVE,
            llvm:ir
      </td>
    </tr>

    <tr>
      <th>Assignees</th>
      <td>
      </td>
    </tr>

    <tr>
      <th>Reporter</th>
      <td>
          kawashima-fj
      </td>
    </tr>
</table>

<pre>
    # ArgumentPromotion creates an illegal type argument for AArch64 SVE VLS

This issue is derived from #63025.

# Problem

Compiling the following ACLE program with `-O3 -march=armv8.2-a+sve -msve-vector-bits=256` for Linux/AArch64 crashes. This problem is specific to AArch64 SVE VLS (a.k.a. fixed-length).

```c
#include <arm_sve.h>

typedef svfloat32_t svfloat32_256_t __attribute__((arm_sve_vector_bits(256)));

__attribute__((noinline))
static void callee(svfloat32_256_t *src, svfloat32_256_t *dst) {
    *dst = *src;
}

void caller(svfloat32_256_t *src, svfloat32_256_t *dst) {
    callee(src, dst);
}
```

```console
$ clang -S --target=aarch64-unknwon-linux-gnu --sysroot=/opt/aarch64-none-linux-gnu/libc -O3 -march=armv8.2-a+sve -msve-vector-bits=256 -fno-crash-diagnostics test.c
clang: /src/llvm/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp:7014: void analyzeCallOperands(const llvm::AArch64TargetLowering&, const llvm::AArch64Subtarget*, const llvm::TargetLowering::CallLoweringInfo&, llvm::CCState&): Assertion `!Res && "Call operand has unhandled type"' failed.
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace, preprocessed source, and associated run script.
Stack dump:
0. Program arguments: clang -S --target=aarch64-unknwon-linux-gnu --sysroot=/opt/aarch64-none-linux-gnu/libc -O3 -march=armv8.2-a+sve -msve-vector-bits=256 -fno-crash-diagnostics test.c
1.      <eof> parser at end of file
2.      Code generation
3.      Running pass 'Function Pass Manager' on module 'test.c'.
4.      Running pass 'AArch64 Instruction Selection' on function '@caller'
 #0 0x00007f41724fa010 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/opt/llvm/bin/../lib/libLLVMSupport.so.18git+0x248010)
 #1 0x00007f41724f741f llvm::sys::RunSignalHandlers() (/opt/llvm/bin/../lib/libLLVMSupport.so.18git+0x24541f)
 #2 0x00007f41723fba68 CrashRecoverySignalHandler(int) CrashRecoveryContext.cpp:0:0
 #3 0x00007f4171e92520 (/lib/x86_64-linux-gnu/libc.so.6+0x42520)
 #4 0x00007f4171ee69fc __pthread_kill_implementation ./nptl/pthread_kill.c:44:76
 #5 0x00007f4171ee69fc __pthread_kill_internal ./nptl/pthread_kill.c:78:10
 #6 0x00007f4171ee69fc pthread_kill ./nptl/pthread_kill.c:89:10
 #7 0x00007f4171e92476 gsignal ./signal/../sysdeps/posix/raise.c:27:6
 #8 0x00007f4171e787f3 abort ./stdlib/abort.c:81:7
 #9 0x00007f4171e7871b _nl_load_domain ./intl/loadmsgcat.c:1177:9
#10 0x00007f4171e89e96 (/lib/x86_64-linux-gnu/libc.so.6+0x39e96)
#11 0x00007f417730dbbf analyzeCallOperands(llvm::AArch64TargetLowering const&, llvm::AArch64Subtarget const*, llvm::TargetLowering::CallLoweringInfo const&, llvm::CCState&) AArch64ISelLowering.cpp:0:0
#12 0x00007f417739f9aa llvm::AArch64TargetLowering::LowerCall(llvm::TargetLowering::CallLoweringInfo&, llvm::SmallVectorImpl<llvm::SDValue>&) const (/opt/llvm/bin/../lib/libLLVMAArch64CodeGen.so.18git+0x6a49aa)
#13 0x00007f41717eb86b llvm::TargetLowering::LowerCallTo(llvm::TargetLowering::CallLoweringInfo&) const (/opt/llvm/bin/../lib/../lib/libLLVMSelectionDAG.so.18git+0x35686b)
#14 0x00007f41717f8686 llvm::SelectionDAGBuilder::lowerInvokable(llvm::TargetLowering::CallLoweringInfo&, llvm::BasicBlock const*) (/opt/llvm/bin/../lib/../lib/libLLVMSelectionDAG.so.18git+0x363686)
#15 0x00007f4171818e5e llvm::SelectionDAGBuilder::LowerCallTo(llvm::CallBase const&, llvm::SDValue, bool, bool, llvm::BasicBlock const*) (/opt/llvm/bin/../lib/../lib/libLLVMSelectionDAG.so.18git+0x383e5e)
#16 0x00007f4171805ddd llvm::SelectionDAGBuilder::visitCall(llvm::CallInst const&) (/opt/llvm/bin/../lib/../lib/libLLVMSelectionDAG.so.18git+0x370ddd)
#17 0x00007f4171839a9e llvm::SelectionDAGBuilder::visit(llvm::Instruction const&) (/opt/llvm/bin/../lib/../lib/libLLVMSelectionDAG.so.18git+0x3a4a9e)
#18 0x00007f41718ca5b8 llvm::SelectionDAGISel::SelectBasicBlock(llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Instruction, true, false, void>, false, true>, llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Instruction, true, false, void>, false, true>, bool&) (/opt/llvm/bin/../lib/../lib/libLLVMSelectionDAG.so.18git+0x4355b8)
#19 0x00007f41718cb2a8 llvm::SelectionDAGISel::SelectAllBasicBlocks(llvm::Function const&) (/opt/llvm/bin/../lib/../lib/libLLVMSelectionDAG.so.18git+0x4362a8)
#20 0x00007f41718cd114 llvm::SelectionDAGISel::runOnMachineFunction(llvm::MachineFunction&) (.part.0) SelectionDAGISel.cpp:0:0
#21 0x00007f4175a9bf07 llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (.part.0) MachineFunctionPass.cpp:0:0
#22 0x00007f417312488e llvm::FPPassManager::runOnFunction(llvm::Function&) (/opt/llvm/bin/../lib/libLLVMCore.so.18git+0x49888e)
#23 0x00007f4173124ad9 llvm::FPPassManager::runOnModule(llvm::Module&) (/opt/llvm/bin/../lib/libLLVMCore.so.18git+0x498ad9)
#24 0x00007f4173125415 llvm::legacy::PassManagerImpl::run(llvm::Module&) (/opt/llvm/bin/../lib/libLLVMCore.so.18git+0x499415)
#25 0x00007f41761bb078 clang::EmitBackendOutput(clang::DiagnosticsEngine&, clang::HeaderSearchOptions const&, clang::CodeGenOptions const&, clang::TargetOptions const&, clang::LangOptions const&, llvm::StringRef, llvm::Module*, clang::BackendAction, llvm::IntrusiveRefCntPtr<llvm::vfs::FileSystem>, std::unique_ptr<llvm::raw_pwrite_stream, std::default_delete<llvm::raw_pwrite_stream>>) (/opt/llvm/bin/../lib/libclangCodeGen.so.18git+0x2d6078)
#26 0x00007f4176668c3a clang::BackendConsumer::HandleTranslationUnit(clang::ASTContext&) CodeGenAction.cpp:0:0
#27 0x00007f416f7515f9 clang::ParseAST(clang::Sema&, bool, bool) (/opt/llvm/bin/../lib/../lib/libclangParse.so.18git+0x685f9)
#28 0x00007f4174cbdca9 clang::FrontendAction::Execute() (/opt/llvm/bin/../lib/libclangFrontend.so.18git+0x199ca9)
#29 0x00007f4174c2eb15 clang::CompilerInstance::ExecuteAction(clang::FrontendAction&) (/opt/llvm/bin/../lib/libclangFrontend.so.18git+0x10ab15)
#30 0x00007f4176bb4e75 clang::ExecuteCompilerInvocation(clang::CompilerInstance*) (/opt/llvm/bin/../lib/libclangFrontendTool.so.18git+0x5e75)
#31 0x00005576f0c83e59 cc1_main(llvm::ArrayRef<char const*>, char const*, void*) (/opt/llvm/bin/clang-18+0x19e59)
#32 0x00005576f0c7b693 ExecuteCC1Tool(llvm::SmallVectorImpl<char const*>&, llvm::ToolContext const&) driver.cpp:0:0
#33 0x00007f417490c34d void llvm::function_ref<void ()>::callback_fn<clang::driver::CC1Command::Execute(llvm::ArrayRef<std::optional<llvm::StringRef>>, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char>>*, bool*) const::'lambda'()>(long) Job.cpp:0:0
#34 0x00007f41723fbf30 llvm::CrashRecoveryContext::RunSafely(llvm::function_ref<void ()>) (/opt/llvm/bin/../lib/libLLVMSupport.so.18git+0x149f30)
#35 0x00007f417490cbce clang::driver::CC1Command::Execute(llvm::ArrayRef<std::optional<llvm::StringRef>>, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char>>*, bool*) const (.part.0) Job.cpp:0:0
#36 0x00007f41748cd29a clang::driver::Compilation::ExecuteCommand(clang::driver::Command const&, clang::driver::Command const*&, bool) const (/opt/llvm/bin/../lib/libclangDriver.so.18git+0xff29a)
#37 0x00007f41748cdd6d clang::driver::Compilation::ExecuteJobs(clang::driver::JobList const&, llvm::SmallVectorImpl<std::pair<int, clang::driver::Command const*>>&, bool) const (/opt/llvm/bin/../lib/libclangDriver.so.18git+0xffd6d)
#38 0x00007f41748dcd34 clang::driver::Driver::ExecuteCompilation(clang::driver::Compilation&, llvm::SmallVectorImpl<std::pair<int, clang::driver::Command const*>>&) (/opt/llvm/bin/../lib/libclangDriver.so.18git+0x10ed34)
#39 0x00005576f0c80bd0 clang_main(int, char**, llvm::ToolContext const&) (/opt/llvm/bin/clang-18+0x16bd0)
#40 0x00005576f0c911a3 main (/opt/llvm/bin/clang-18+0x271a3)
#41 0x00007f4171e79d90 __libc_start_call_main ./csu/../sysdeps/nptl/libc_start_call_main.h:58:16
#42 0x00007f4171e79e40 call_init ./csu/../csu/libc-start.c:128:20
#43 0x00007f4171e79e40 __libc_start_main ./csu/../csu/libc-start.c:379:5
#44 0x00005576f0c7a2d5 _start (/opt/llvm/bin/clang-18+0x102d5)
clang: error: clang frontend command failed with exit code 134 (use -v to see invocation)
```

# Environment

The latest `main` branch (commit 97c9f9a20af4) and at least 13.0.1, 14.0.6, 15.0.7, 16.0.6, 17.0.1 have this problem.

# Cause

As described in #63025, the root cause is that ArgumentPromotion promotes an `<8 x float>` *pointer* argument to an `<8 x float>` *value* argument. There is no ABI for SVE VLS so we cannot legalize vector arguments which are larger then 128 bits.

Before ArgumentPromotionPass:

```llvm
; *** IR Dump Before ArgumentPromotionPass on (callee) ***
; ModuleID = 'test.c'
source_filename = "test.c"
target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
target triple = "aarch64-unknwon-linux-gnu"

; Function Attrs: nounwind uwtable vscale_range(2,2)
define dso_local void @caller(ptr noundef %src, ptr noundef %dst) local_unnamed_addr #0 {
entry:
  call fastcc void @callee(ptr noundef %src, ptr noundef %dst)
  ret void
}

; Function Attrs: noinline nounwind uwtable vscale_range(2,2)
define internal fastcc void @callee(ptr nocapture noundef readonly %src, ptr nocapture noundef writeonly %dst) unnamed_addr #1 {
entry:
  %0 = load <8 x float>, ptr %src, align 16, !tbaa !6
  store <8 x float> %0, ptr %dst, align 16, !tbaa !6
  ret void
}

attributes #0 = { nounwind uwtable vscale_range(2,2) "frame-pointer"="non-leaf" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="generic" "target-features"="+crc,+fp-armv8,+fullfp16,+lse,+neon,+outline-atomics,+ras,+rdm,+sve,+v8.1a,+v8.2a,+v8a,-fmv" }
attributes #1 = { noinline nounwind uwtable vscale_range(2,2) "frame-pointer"="non-leaf" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="generic" "target-features"="+crc,+fp-armv8,+fullfp16,+lse,+neon,+outline-atomics,+ras,+rdm,+sve,+v8.1a,+v8.2a,+v8a,-fmv" }

!llvm.module.flags = !{!0, !1, !2, !3, !4}
!llvm.ident = !{!5}

!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 8, !"PIC Level", i32 2}
!2 = !{i32 7, !"PIE Level", i32 2}
!3 = !{i32 7, !"uwtable", i32 2}
!4 = !{i32 7, !"frame-pointer", i32 1}
!5 = !{!"clang version 18.0.0"}
!6 = !{!7, !7, i64 0}
!7 = !{!"omnipotent char", !8, i64 0}
!8 = !{!"Simple C/C++ TBAA"}
```

After ArgumentPromotionPass:

```llvm
; *** IR Dump After ArgumentPromotionPass on (callee) ***
; ModuleID = 'test.c'
source_filename = "test.c"
target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
target triple = "aarch64-unknwon-linux-gnu"

; Function Attrs: nounwind uwtable vscale_range(2,2)
define dso_local void @caller(ptr noundef %src, ptr noundef %dst) local_unnamed_addr #0 {
entry:
  %src.val = load <8 x float>, ptr %src, align 16, !tbaa !6
  call fastcc void @callee(<8 x float> %src.val, ptr noundef %dst)
  ret void
}

; Function Attrs: noinline nounwind uwtable vscale_range(2,2)
define internal fastcc void @callee(<8 x float> %src.0.val, ptr nocapture noundef writeonly %dst) unnamed_addr #1 {
entry:
  store <8 x float> %src.0.val, ptr %dst, align 16, !tbaa !6
  ret void
}

attributes #0 = { nounwind uwtable vscale_range(2,2) "frame-pointer"="non-leaf" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="generic" "target-features"="+crc,+fp-armv8,+fullfp16,+lse,+neon,+outline-atomics,+ras,+rdm,+sve,+v8.1a,+v8.2a,+v8a,-fmv" }
attributes #1 = { noinline nounwind uwtable vscale_range(2,2) "frame-pointer"="non-leaf" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="generic" "target-features"="+crc,+fp-armv8,+fullfp16,+lse,+neon,+outline-atomics,+ras,+rdm,+sve,+v8.1a,+v8.2a,+v8a,-fmv" }

!llvm.module.flags = !{!0, !1, !2, !3, !4}
!llvm.ident = !{!5}

!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 8, !"PIC Level", i32 2}
!2 = !{i32 7, !"PIE Level", i32 2}
!3 = !{i32 7, !"uwtable", i32 2}
!4 = !{i32 7, !"frame-pointer", i32 1}
!5 = !{!"clang version 18.0.0"}
!6 = !{!7, !7, i64 0}
!7 = !{!"omnipotent char", !8, i64 0}
!8 = !{!"Simple C/C++ TBAA"}
```

Diff:

```diff
@@ -1,4 +1,4 @@
-; *** IR Dump Before ArgumentPromotionPass on (callee) ***
+; *** IR Dump After ArgumentPromotionPass on (callee) ***
 ; ModuleID = 'test.c'
 source_filename = "test.c"
 target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
@@ -7,15 +7,15 @@
 ; Function Attrs: nounwind uwtable vscale_range(2,2)
 define dso_local void @caller(ptr noundef %src, ptr noundef %dst) local_unnamed_addr #0 {
 entry:
-  call fastcc void @callee(ptr noundef %src, ptr noundef %dst)
+  %src.val = load <8 x float>, ptr %src, align 16, !tbaa !6
+ call fastcc void @callee(<8 x float> %src.val, ptr noundef %dst)
   ret void
 }
 
 ; Function Attrs: noinline nounwind uwtable vscale_range(2,2)
-define internal fastcc void @callee(ptr nocapture noundef readonly %src, ptr nocapture noundef writeonly %dst) unnamed_addr #1 {
+define internal fastcc void @callee(<8 x float> %src.0.val, ptr nocapture noundef writeonly %dst) unnamed_addr #1 {
 entry:
-  %0 = load <8 x float>, ptr %src, align 16, !tbaa !6
-  store <8 x float> %0, ptr %dst, align 16, !tbaa !6
+  store <8 x float> %src.0.val, ptr %dst, align 16, !tbaa !6
   ret void
 }
 
```

# Possible Fix

Given that the AArch64 backend won't support vector arguments which are VLS larger then 128 bits, we have two options.

1. Don't promote such arguments.
2. Promote such arguments to scalable vectors and "bitcast" appropriately (as @paulwalker-arm [said](https://github.com/llvm/llvm-project/issues/63025#issuecomment-1669920964)).

ArgumentPromotion has [a hook to check ABI using `TargetTransformInfo`](https://github.com/llvm/llvm-project/blob/llvmorg-17.0.2/llvm/lib/Transforms/IPO/ArgumentPromotion.cpp#L663-L676). [X86](https://github.com/llvm/llvm-project/blob/llvmorg-17.0.2/llvm/lib/Target/X86/X86TargetTransformInfo.cpp#L6080) and [PPC](https://github.com/llvm/llvm-project/blob/llvmorg-17.0.2/llvm/lib/Target/PowerPC/PPCTargetTransformInfo.cpp#L879) use this hook to prevent illegal argument promotions. So I'd like to take a similar approach for 1. above.

Are there any comments? If no objection, I'll post a PR.

</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzsfFtz46i2_6dRv1BySej-0A-2k8zOVKY61cm_6__mQhKymSDQAeQk8-lPAZItfMmldzI1e5_u6m4raLH4rQuLBawYSUnWDOOvXrLwkosvqFcbLr4-oEckN6RFfvPnl5LXz189GIG5WPctZupW8JYrwhmoBEYKS4AYIJTiNaJAPXcYoIESNFyA-VxUmzQGdz8uwY-bOy-48IK5_f9-QyQgUvYYEAlqLMgW16ARvAUejNIogMlsSq9R3ApeUtxOm5e87QglbA3UBoOGU8of9U_z5c0l6ARfC9SCR6I2wEsD_1sE_BaJauNFF0i023wGfeTBhdxi4Ldyi_0trhQXfkmU9KILmKReGhhRbgjrnzx4NYpUCSQ3WM6AEaSzyLQossMVaUgFFD-UH3gwR7OHGZqBhjzh2qeYrdXGg4UrahrYv9VOdMIq2tcYeNESiXYlt3i28aLLaS-t_Ro3QG4bypGK4EpNnmGSrhRYrZBSgpS9wquVB3ONx7JbWcFXRnCYa8FhMfyNFtNxTvBgnDBKGB7oDZlUSJEKbDmpQYUoxdiD-SEeD86lqDy4PELqwXktlQcL4GXD8ACAoRl40cXYdwcuu5ii3I8rPmLcvQS2m6U5MfhoutP25ExyikerxqCiiK2Bfwd8XyGxxkr7JTI-4_fsgT1y5lPteP6a9cD35bMUnGsqD17xTnnwaiRnnOE9rQevKCkr8DMeD_yGcd_4t18TtGZcKlJJoLBUs8ElDXAvmgMPXhmVXFG6bScfpPTg1b2VaTdp9k_Xd5je8EcsCFvPqq7zonkWhLHmaCyHGKLPf-ElovRbhwVitfZKrT8FzBDR3IvmAzM7zMjOg6m20Bnau74cNA3np8gOeJk2jWJsuWYNH0bYd1ou7xRS2LQXWoa5lFiYMKkND8PvWALzNgUehJof4FYssEES9GyDWE1xbUKoB6EHM9AgQnE9BIbbm8v53SWQfdkSBRAo-zUQuONC6TCzUaqTGgq88uDVmqhNX84q3rpm8TvB_8SVtoeJu9KDV0BDGIOLjqDG7KBE1YMSqMJazk7gTvAKS4lrIHkvbLPuiaTkFUEK10D0DMhKkE4NkO8Uqh5A3bfauLYpmOkQbkLyuExo2P-50yCcAfPHi5aYN150CTokJBYAKYBZDXgDGjJOeDgQL3mNwRozLJB2EfsyGl5-7xnT61eHpHaZ7KpnlXGkW93wB2JorSNaBjgDLa97ijXVgAlmg-7jM9zG9eiaSSV6y_gOU2yeBq7NOKIHMy8OxhiaDcHQg1EAgqcgCIKsicMMxg0KwmAyG-SztA-3gjBl3ODe-lK-JxLoccWlEhi1w3QizIZdvaIMRh2ctyTMg1ez2S6uUFLe3Pz4467v9AyYST4L8zVRHlwETzDOgzDYLUMab3iAN4vD5hTe7z27I2uG6L_MbBTSYPkISEkcNg4k6ECKmhKlOVhqX_uOK77F4tlB4sF8UI9Ds-RM4Sc1BNDA_NsNEU2HCHEBExgMoljIT3m6SuOjyaKxpwZ3rLs4sGOXJ06LpgKrVac2AqN69UAoXZG2o1hPbePdQKuIdYp68GpKNqu8aB7rgJ-le_7JW_gzhQVD9EXOWe5F83CijfQU52m3F9nlxQG77FC5cZaCtTQ2M5zs4-gj8lnWuNMBt-OS6DRSICKx4Q0zL5pPdJC7rLM8ayKASh3qDStVW_OZJosu1BLvORRHHMISrBhdUY7qVc1bRKxdCDPi6uZWritk2YVhpiEVu-QzDFyGeYGL9H2uFOkuO1fSPJ1JmUVBXZbNmWX_lQXfruFHi_Lhgj-SzV2ytyz4Z0Zwln1wPrOZTEwtOXQlL5oCoVeTGvPK_KTBOUr5qZTlrkWU_jBr3nXbUS9aTt5d_EC0x3p_YUWzSdI7wuAgg17pfsPMjYYpiguEHF9wQ1WGyzwtXzHRThX3_OeU8R6pTsT5cdG8mP_mihclaZ6Wjnhu1MyaPM3TqSkmvBY9oTUW9gXVmK_Zlj-gkuJ_3-YLJEm1oLx6mMyFty1v79JAGqW5O9nduJ6HOU7wWzRwzsq6aYEkPjMxRweGS1ByTqeff7828ggn2NGGuxblQVLX9Vu0sSWSqKPprxt0PjfRxSdIkQV1XTtSuEtgHhWoeJNNjRSOBNNs9FOFQDEqXFO4i21eoaTMzwihA_u0de8_jjCEEqlWROnsngsnrtpXNVaIDJwYr_GKd3oE6ZBOVKK9VgnrzQ2i0jzoTbKJz5M2Q2Tb_mFw7OT7FJvGUZKUuWPT4sCmJURvtenchJXBrG7qsduIfaaHxlEKkSMNDA6kqcMwflUa0bNv7A9UbQjDI3BHmqN3ozizDgk101k_OGR9MpuBTh6XoKJsggycHUjvYicQT2J7EdQJfqdxOVlWFMI4z6fh6epWdx330-9G9NZEaMkFPjBxkee5E4RgdAgV1cUboP5htv-uWYemD4GJ6sKBGR_ATOIwmcCkeI2q52Hnvwdss8sB9KeBLeIwccA6GUcalmWQ5WA8tfSi-WVL1AJVD5jV33rV9XpFmry-2B_4XLK1Odq2p4p7kn9hVGNxh5GoNt9szHTSkQnpkAe_QmVzuleIbhBbnyKZRASlE8DvuHGbR23PDxgOSpjvgvs06ivRS7LF33GzZOpWuevHthmm8hWh-O5ZKtwO8V6q2r7pGfmfHq-6g54CPa66R0EUXo1HQJNONW5QT_XKRLHCr3SMLs2Yb3YgI_nJfQms0yBzY6-TqKVpmlcROqG7JWeyb8e5aY9s7gVikpojkP_HyIF3ze_uh6ObwfsHQNYIp-PZNN1KmywJk6aYYrlFQuL53b070h1u0eAhbib8M2uX4WvGOdjR5UnjhgonrYqrsq6QA_ZKaPF3Xmdn5BOuer2bfs-Zm-E5cnNRhUVRIRdW4cKCuAwTd562HaF6zyUVYhV2gI0zJD8vx7tC2UvQA1S68cw9c03LMsaZA30AuZdgyyt0DPhIwrdveg4h33NOXdgJzlzQY26QJFnaBJXeCRWgqsJVi4i7FsyFQM86ZkXLaoPEfkdmA4rbNiacr2A3aP0wH7wBJ44z7I5gB3BZmRYRGNW4DO_NNMlfOjE5RnoQijWPYaI7aWMtyBaLk_PcPbaNi6CK4treie35jkf0K2E0Zt7aeWPioSapEKUlqh5WDdNI9x5gxx4PsMIlb1vE6sMpeNIyuwhttwjo4NRot-4MMXkS0ler6ukpDO0Ppc6wdfw2JxdGiw6xblgpgcxNjH19wA5Rqr3b7GfG95pkvo9v890Jj-3iwYyitqyRB7O9qmBOOVtr0t95edoe8eFJfRNNLztOncfvbxNQg-mzo86XTfcBlw1hXDRR4Hh6cuhSZYXB_2WXONhTnLW9s_7HeVXDAp1VnIms6Gg9G7XphOGDjprgXML3AuncWdnfeUxrhriwgchxoKaBhXM86152aDXUaf1eNfzOS3leB7_z8oY4R1gvn1XvzN4hoi1uLsferrbBNz5FeXXqHJO51zlxXld1FJ8DejF5dhb0Eyv5OaX_jcp7X95wSl1hgOsodvRVHOQMQVkHFtuYNYx4TZCYH1_onFl035gnpGXtRM84cAEVYYgiYK7Q3sYRZiGKHI7hwf1cURcBWK20olZSIaFWevVe7a7pKtkfXyQOV5WnOs02XjRPzA1ouh8VHo6K48DUNa0II-pwIPuoufuGu70ZhJop3EfIODrF1BHllBQnmUdZoWHveccHCRqCdQIs17caM4D1PiPd1SxhIfQ6MdadNENCC6rB1W3lja0axE9Eu1GNQRjFetheYuBvgeJAYgzIJM8uXioBgxG4ZFsiOGsxU24hJAYUKayjTxoYH08DUArEqg0wRU9tSxQosqpoCgQD1OgJY8tvFKAYSQXCaBbMQj0PwngWzEwICJNZMMvMU7pryzQd2KAtBmpSt3hUablEvcTTxrkENZaVICWugfF9W6NpTno3GAjOFah0L0AkUBukTtSMdubJFo1qBUXLHDwBU4CnY0oaAA_OO25u-D0439eSKv5il6297dl3mIH7DRYGCuNgvrg2JZxjFabk4BGDCjHGtQLXiJK_MLAFQPvCJPC4IdUGIKHNI9ZYaDkZCGEOSqKko7IFbrjAxxKPx52nigGN29qmaAHGSDYH19_BRd924CWewJTn5GNVYrHvvudoD3yuL4ZiyX2N0FCfaQq5Vg2hmKEWD1RwpIJDUam9Oq-RQhQ9834svYTY1-EW-0RHBP0vgj4JUxtz7E9p7EXzNPaJDRshzH0WQdt2p9sOBlGCdHQH5Gz9167bXtTd2fxcKWEqyhjv2SNhNegfFSopBltZIYpXArG1TmahB5dwN2Vr3BCGQS35SmeR1O63JsVPeaeE4VnjBngwGapAD1qHwlHDYtUzrdZ6hepa2KKpXUEpZko879zCFpeCBklVVe7I-H0jj_wEVnaDfKow9py-bAXvzyluV5LzshAV6lQv8A64wKjmjD4fyXVIaE78RspBy4f6Dc_r14NJYNyKclSDwxAyjLrHgChZMxCagOnBUJUI6c-xRAdIpeflARszyISXQfk6rxdNtauzloMD6ZmRLd5sIz2NGoFa7O9iKjQ1k5DpCYVR40EIzI--EqjrCFv7LVKbHZ296DM0UqHqwe8EV0OhZN80WPiS_IV35PlAaye0X3X97pWpdySVS9BgpO0sd1QeXFTGCB5cNJ1vKjWHn3pKm84o0oMLe8XowQXD5tDagwveK-3APlK8JZW0jQKND3VrH-R26LnNZyHaPcLdo37wm3ZrkI72cC0RTizxzmnzyyQfZZIxVwn1OjqzpbCzhqK1HFaQUMcDGAbD1AuHTzh8RsNnvOc48CK1TjkcJsnxsMGEgkQQjPw9CB_NccVoBrgE-r0zTnjQOd93vr1eghu8xXTSF077woO-2bTv5ct9o_N9B8c91zM-3_PIn4f-4bR_4irUg9Am31sspF6JwnwWzALde9IpdTuNY5pPksYgmBJnRyPwlpGOK21Nu1kcbZ-fZJAfMbgztaxg6cEr7YkeXID7xXzuoDyV7c8bhcXHZoMvsPyVDP43JYOW4WyL6AemLC9mmCcymQHBf2CmeUaYwBXngxPMsxnh0dC_MsP_sjTkV2b4jzPJr8zwV2b4T80ML0jTnEsBa_3ONsWBFwfA154TAw8uhgfTbEn8Tzg0hIsPzz3BG5JP8LbsE_wt6eeoeu1J2jXhYnyaKB98RJ4J_uZEE7hZi__R5456DnxG9qr5flb-epBl7dcQ8IqhfyqH9f-Zx6UeXPyjsutjR_3QA1z_I09wjdN_Rvr_mmeevWW85VIS7YpX5Gn67jeyxcxezKkN3n0zSWlLWMGj-f1vBaStKXrpNuzHzd3JGzEtyiMeLhcfORh-kcS5KAtn4GIYabgMBLI3fIdxBmpovingxHtz8VohamebASnNXagHYUlUhbR6IUBdJ3gnCFLYuF2OpHbkDvX0EdEHLHS6CrxkIRGpveTCg_nPf4nCcBEamYaKtxqoH6ZpUcCgSGP7rSiOGo6vRjcaYLJAYMP5gxay2uDqwVxd9pKwNfDSwBaIm8rihovW_I5fGvwk-pLycmjlYu2bm2F49AUe41hazOvbbx68OoJuSqdgdJOmkX-TZqmWVYvy__P0U6GN3y2ixzH_n1DPDluQB-OluZcsbm-Xfwu0W_6Ixa1OEm9vly_Ay7PCxEQ53MqPPtAJvNU56vgFS7v78G5UvpyBOw6uPZjVgJIHrHsp9IABApK0hCJhpwKqNuYKPJwBVPItPvBG890fAgPEnsHgwNKLrsB1AxgHvPwT7349QI9FKei4VACB2-8Dpy_116guogJ9wV_DtMjiKMmK9Mvma12XOSxhgTDGeRM1SYpgVGV5GqZlUZXhF_IVBjAKgzANkiSN0lle5TnCOa5rhBBsMi8OcIsInZk9GBfrL2aifU2LMM6-UFRiKs2XWEE4RLP9b1HbzF4n7D8ud89DrRAxeX9y8UV8NVYu-7X04oASqeR-LEUUxV8_5vuvvvSCfv034owW-H8DAAD__5zKdg0">