[llvm] [GlobalISel] Add G_ABDS and G_ABDU instructions (PR #118122)
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Tue Dec 3 10:32:05 PST 2024
Thorsten =?utf-8?q?Schütt?= <schuett at gmail.com>,
Thorsten =?utf-8?q?Schütt?= <schuett at gmail.com>,
Thorsten =?utf-8?q?Schütt?= <schuett at gmail.com>
Message-ID:
In-Reply-To: <llvm.org/llvm/llvm-project/pull/118122 at github.com>
================
@@ -0,0 +1,35 @@
+# RUN: not --crash llc -verify-machineinstrs -mtriple=arm64 -run-pass none -o /dev/null %s 2>&1 | FileCheck %s
+# REQUIRES: aarch64-registered-target
+
+---
+name: g_abd_su
+body: |
+ bb.0:
+
+ %2:_(p0) = G_IMPLICIT_DEF
+ %3:_(p0) = G_IMPLICIT_DEF
+ ; CHECK: Generic abds/abdu does not support pointers as operands
+ %4:_(s1) = G_ABDS %2, %3
+
+ %12:_(s64) = G_IMPLICIT_DEF
+ %13:_(s64) = G_IMPLICIT_DEF
+ ; CHECK: Generic abds/abdu does not support pointers as a result
+ %14:_(p0) = G_ABDS %12, %13
+
+ %23:_(<2 x s32>) = G_IMPLICIT_DEF
+ %24:_(<2 x s32>) = G_IMPLICIT_DEF
+ ; CHECK: Generic vector abds/abdu must preserve number of lanes
+ %5:_(s1) = G_ABDU %23, %24
+
+ %15:_(s32) = G_CONSTANT i32 0
+ %16:_(s64) = G_CONSTANT i64 2
+ ; CHECK: Generic abds/abdu must have same input types
+ %17:_(s1) = G_ABDU %15, %16
+
+ %18:_(s64) = G_CONSTANT i64 0
+ %19:_(s64) = G_CONSTANT i64 2
+ ; CHECK: Generic abds/abdu must have same input and output types
+ %20:_(s1) = G_ABDU %18, %19
+
----------------
arsenm wrote:
Maybe check vector of pointer since that manages to always break
https://github.com/llvm/llvm-project/pull/118122
More information about the llvm-commits
mailing list