[llvm] IR: introduce struct with CmpInst::Predicate and samesign (PR #116867)

Yingwei Zheng via llvm-commits llvm-commits at lists.llvm.org
Fri Nov 29 23:10:02 PST 2024


================
@@ -0,0 +1,46 @@
+//===- CmpPredicate.h - CmpInst Predicate with samesign information -------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+//
+// A CmpInst::Predicate with any samesign information (applicable to ICmpInst).
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef LLVM_IR_CMPPREDICATE_H
+#define LLVM_IR_CMPPREDICATE_H
+
+#include "llvm/IR/InstrTypes.h"
+
+namespace llvm {
+/// An abstraction over a floating-point predicate, and a pack of an integer
+/// predicate with samesign information. Some functions in ICmpInst construct
+/// and return this type in place of a Predicate. It is also implictly
+/// constructed with a Predicate, dropping samesign information.
+class CmpPredicate {
+  CmpInst::Predicate Pred;
+  bool HasSameSign;
+
+public:
+  CmpPredicate(CmpInst::Predicate Pred, bool HasSameSign = false)
+      : Pred(Pred), HasSameSign(HasSameSign) {
+    assert(!HasSameSign || CmpInst::isIntPredicate(Pred));
+  }
+
+  operator CmpInst::Predicate() const { return Pred; }
+
+  bool hasSameSign() const { return HasSameSign; }
+
+  static std::optional<CmpPredicate> getMatching(CmpPredicate A,
----------------
dtcxzyw wrote:

Please add some header comments to clarify the behavior.


https://github.com/llvm/llvm-project/pull/116867


More information about the llvm-commits mailing list