[llvm-commits] CVS: llvm/lib/Transforms/Utils/Local.cpp

Reid Spencer reid at x10sys.com
Mon Jan 16 13:12:53 PST 2006



Changes in directory llvm/lib/Transforms/Utils:

Local.cpp updated: 1.49 -> 1.50
---
Log message:

For PR411: http://llvm.cs.uiuc.edu/PR411 :
This patch is an incremental step towards supporting a flat symbol table.
It de-overloads the intrinsic functions by providing type-specific intrinsics
and arranging for automatically upgrading from the old overloaded name to
the new non-overloaded name. Specifically:
  llvm.isunordered -> llvm.isunordered.f32, llvm.isunordered.f64
  llvm.sqrt -> llvm.sqrt.f32, llvm.sqrt.f64
  llvm.ctpop -> llvm.ctpop.i8, llvm.ctpop.i16, llvm.ctpop.i32, llvm.ctpop.i64
  llvm.ctlz -> llvm.ctlz.i8, llvm.ctlz.i16, llvm.ctlz.i32, llvm.ctlz.i64
  llvm.cttz -> llvm.cttz.i8, llvm.cttz.i16, llvm.cttz.i32, llvm.cttz.i64
New code should not use the overloaded intrinsic names. Warnings will be 
emitted if they are used.


---
Diffs of the changes:  (+16 -5)

 Local.cpp |   21 ++++++++++++++++-----
 1 files changed, 16 insertions(+), 5 deletions(-)


Index: llvm/lib/Transforms/Utils/Local.cpp
diff -u llvm/lib/Transforms/Utils/Local.cpp:1.49 llvm/lib/Transforms/Utils/Local.cpp:1.50
--- llvm/lib/Transforms/Utils/Local.cpp:1.49	Fri Jan 13 19:25:24 2006
+++ llvm/lib/Transforms/Utils/Local.cpp	Mon Jan 16 15:12:35 2006
@@ -297,14 +297,25 @@
       case Intrinsic::returnaddress:
       case Intrinsic::frameaddress:
       case Intrinsic::stacksave:
-      case Intrinsic::isunordered:
+      case Intrinsic::isunordered_f32:
+      case Intrinsic::isunordered_f64:
       case Intrinsic::bswap_i16:
       case Intrinsic::bswap_i32:
       case Intrinsic::bswap_i64:
-      case Intrinsic::ctpop:
-      case Intrinsic::ctlz:
-      case Intrinsic::cttz:
-      case Intrinsic::sqrt:
+      case Intrinsic::ctpop_i8:
+      case Intrinsic::ctpop_i16:
+      case Intrinsic::ctpop_i32:
+      case Intrinsic::ctpop_i64:
+      case Intrinsic::ctlz_i8:
+      case Intrinsic::ctlz_i16:
+      case Intrinsic::ctlz_i32:
+      case Intrinsic::ctlz_i64:
+      case Intrinsic::cttz_i8:
+      case Intrinsic::cttz_i16:
+      case Intrinsic::cttz_i32:
+      case Intrinsic::cttz_i64:
+      case Intrinsic::sqrt_f32:
+      case Intrinsic::sqrt_f64:
         return true;             // These intrinsics have no side effects.
       }
   return false;






More information about the llvm-commits mailing list