summaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/AArch64/extract-vector-elt.ll
diff options
context:
space:
mode:
authorMingming Liu <mingmingl@google.com>2025-09-10 15:25:31 -0700
committerGitHub <noreply@github.com>2025-09-10 15:25:31 -0700
commit1417dafa1db9cb1b2b09438aa9f53ea5ab6e36e2 (patch)
tree57f4b1f313c8cf74eed8819870f39c36ea263c68 /llvm/test/CodeGen/AArch64/extract-vector-elt.ll
parent898b813bc8a6d0276bf0f4769f5f2f64b34e632d (diff)
parentb8cefcb601ddaa18482555c4ff363c01a270c2fe (diff)
Merge branch 'main' into users/mingmingl-llvm/samplefdo-profile-formatusers/mingmingl-llvm/samplefdo-profile-format
Diffstat (limited to 'llvm/test/CodeGen/AArch64/extract-vector-elt.ll')
-rw-r--r--llvm/test/CodeGen/AArch64/extract-vector-elt.ll35
1 files changed, 35 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/AArch64/extract-vector-elt.ll b/llvm/test/CodeGen/AArch64/extract-vector-elt.ll
index 18b028c9898e..6ab703c08b83 100644
--- a/llvm/test/CodeGen/AArch64/extract-vector-elt.ll
+++ b/llvm/test/CodeGen/AArch64/extract-vector-elt.ll
@@ -1093,3 +1093,38 @@ loop:
ret:
ret i32 %3
}
+
+define <3 x ptr> @v3move(<3 x ptr> %a, <3 x ptr> %b, <3 x ptr> %x) {
+; CHECK-SD-LABEL: v3move:
+; CHECK-SD: // %bb.0: // %entry
+; CHECK-SD-NEXT: fmov d1, d7
+; CHECK-SD-NEXT: fmov d0, d6
+; CHECK-SD-NEXT: ldr d2, [sp]
+; CHECK-SD-NEXT: ret
+;
+; CHECK-GI-LABEL: v3move:
+; CHECK-GI: // %bb.0: // %entry
+; CHECK-GI-NEXT: ldr x8, [sp]
+; CHECK-GI-NEXT: fmov d0, d6
+; CHECK-GI-NEXT: fmov d1, d7
+; CHECK-GI-NEXT: fmov d2, x8
+; CHECK-GI-NEXT: ret
+entry:
+ ret <3 x ptr> %x
+}
+
+define ptr @v3ext(<3 x ptr> %a, <3 x ptr> %b, <3 x ptr> %x) {
+; CHECK-SD-LABEL: v3ext:
+; CHECK-SD: // %bb.0: // %entry
+; CHECK-SD-NEXT: ldr d0, [sp]
+; CHECK-SD-NEXT: fmov x0, d0
+; CHECK-SD-NEXT: ret
+;
+; CHECK-GI-LABEL: v3ext:
+; CHECK-GI: // %bb.0: // %entry
+; CHECK-GI-NEXT: ldr x0, [sp]
+; CHECK-GI-NEXT: ret
+entry:
+ %c = extractelement <3 x ptr> %x, i32 2
+ ret ptr %c
+}