aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2007-03-01 17:15:32 +0000
committerReid Spencer <rspencer@reidspencer.com>2007-03-01 17:15:32 +0000
commit68e2300ad965bf08af11ae363bb85e3badf964dc (patch)
tree3d9a08599949ad01020884d9a6770616a3afd85b
parent9dd9abd87f77da4e523db02a396721e34631ef32 (diff)
Add methods for bit width modification: sextOrTrunc, zextOrTrunc.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34789 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/llvm/ADT/APInt.h10
-rw-r--r--lib/Support/APInt.cpp16
2 files changed, 26 insertions, 0 deletions
diff --git a/include/llvm/ADT/APInt.h b/include/llvm/ADT/APInt.h
index 0e127b8c44..9043227f0b 100644
--- a/include/llvm/ADT/APInt.h
+++ b/include/llvm/ADT/APInt.h
@@ -423,6 +423,16 @@ public:
/// @brief Zero extend to a new width.
APInt &zext(uint32_t width);
+ /// Make this APInt have the bit width given by \p width. The value is sign
+ /// extended, truncated, or left alone to make it that width.
+ /// @brief Sign extend or truncate to width
+ APInt &sextOrTrunc(uint32_t width);
+
+ /// Make this APInt have the bit width given by \p width. The value is zero
+ /// extended, truncated, or left alone to make it that width.
+ /// @brief Zero extend or truncate to width
+ APInt &zextOrTrunc(uint32_t width);
+
/// @brief Set every bit to 1.
APInt& set();
diff --git a/lib/Support/APInt.cpp b/lib/Support/APInt.cpp
index 93442f344c..50b0dc34fe 100644
--- a/lib/Support/APInt.cpp
+++ b/lib/Support/APInt.cpp
@@ -985,6 +985,22 @@ APInt &APInt::zext(uint32_t width) {
return *this;
}
+APInt &APInt::zextOrTrunc(uint32_t width) {
+ if (BitWidth < width)
+ return zext(width);
+ if (BitWidth > width)
+ return trunc(width);
+ return *this;
+}
+
+APInt &APInt::sextOrTrunc(uint32_t width) {
+ if (BitWidth < width)
+ return sext(width);
+ if (BitWidth > width)
+ return trunc(width);
+ return *this;
+}
+
/// Arithmetic right-shift this APInt by shiftAmt.
/// @brief Arithmetic right-shift function.
APInt APInt::ashr(uint32_t shiftAmt) const {