summaryrefslogtreecommitdiffstats
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
commit742d1704e1cc1870c44a17181df694a66f1dc2f9 (patch)
treeba50d6ab1c722110eeb8cab2b71e6ccb5653deb7
parentaf8be4458fd0dc046703c1ce0012579c10563a36 (diff)
downloadbcm5719-llvm-742d1704e1cc1870c44a17181df694a66f1dc2f9.tar.gz
bcm5719-llvm-742d1704e1cc1870c44a17181df694a66f1dc2f9.zip
Add methods for bit width modification: sextOrTrunc, zextOrTrunc.
llvm-svn: 34789
-rw-r--r--llvm/include/llvm/ADT/APInt.h10
-rw-r--r--llvm/lib/Support/APInt.cpp16
2 files changed, 26 insertions, 0 deletions
diff --git a/llvm/include/llvm/ADT/APInt.h b/llvm/include/llvm/ADT/APInt.h
index 0e127b8c44d..9043227f0b7 100644
--- a/llvm/include/llvm/ADT/APInt.h
+++ b/llvm/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/llvm/lib/Support/APInt.cpp b/llvm/lib/Support/APInt.cpp
index 93442f344c1..50b0dc34fea 100644
--- a/llvm/lib/Support/APInt.cpp
+++ b/llvm/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 {
OpenPOWER on IntegriCloud