[llvm-commits] CVS: llvm/test/Feature/intrinsics.ll

Reid Spencer reid at x10sys.com
Wed Jan 18 17:17:18 PST 2006



Changes in directory llvm/test/Feature:

intrinsics.ll updated: 1.10 -> 1.11
---
Log message:

Expand test to cover the non-overloaded variants of the arithmetic and
floating point intrinsics.


---
Diffs of the changes:  (+45 -1)

 intrinsics.ll |   46 +++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 45 insertions(+), 1 deletion(-)


Index: llvm/test/Feature/intrinsics.ll
diff -u llvm/test/Feature/intrinsics.ll:1.10 llvm/test/Feature/intrinsics.ll:1.11
--- llvm/test/Feature/intrinsics.ll:1.10	Sun May  8 23:47:32 2005
+++ llvm/test/Feature/intrinsics.ll	Wed Jan 18 19:17:06 2006
@@ -5,12 +5,33 @@
 
 declare bool %llvm.isunordered(float, float)
 declare bool %llvm.isunordered(double, double)
+declare bool %llvm.isunordered.f32(float,float)
+declare bool %llvm.isunordered.f64(double,double)
 
 declare void %llvm.prefetch(sbyte*, uint, uint)
 
 declare uint %llvm.ctpop(uint)
+declare ubyte %llvm.ctpop.i8(ubyte)
+declare ushort %llvm.ctpop.i16(ushort)
+declare uint %llvm.ctpop.i32(uint)
+declare ulong %llvm.ctpop.i64(ulong)
+
 declare ushort %llvm.cttz(ushort)
+declare ubyte %llvm.cttz.i8(ubyte)
+declare ushort %llvm.cttz.i16(ushort)
+declare uint %llvm.cttz.i32(uint)
+declare ulong %llvm.cttz.i64(ulong)
+
 declare ulong %llvm.ctlz(ulong)
+declare ubyte %llvm.ctlz.i8(ubyte)
+declare ushort %llvm.ctlz.i16(ushort)
+declare uint %llvm.ctlz.i32(uint)
+declare ulong %llvm.ctlz.i64(ulong)
+
+declare float %llvm.sqrt(float)
+declare double %llvm.sqrt(double)
+declare float %llvm.sqrt.f32(float)
+declare double %llvm.sqrt.f64(double)
 
 implementation
 
@@ -19,10 +40,33 @@
 void %libm() {
         call bool %llvm.isunordered(float 0.0, float 1.0)
         call bool %llvm.isunordered(double 0.0, double 0x7FF8000000000000)
+        call bool %llvm.isunordered.f32(float 1.0, float 2.0)
+        call bool %llvm.isunordered.f64(double 3.0, double 4.0)
+
 	call void %llvm.prefetch(sbyte* null, uint 1, uint 3)
+
+        call float %llvm.sqrt(float 4.0)
+        call double %llvm.sqrt(double 4.0)
+        call float %llvm.sqrt.f32(float 5.0)
+        call double %llvm.sqrt.f64(double 6.0)
+
         call uint %llvm.ctpop(uint 3)
-        call ushort %llvm.cttz(ushort 7)
+        call ubyte %llvm.ctpop.i8(ubyte 10)
+        call ushort %llvm.ctpop.i16(ushort 11)
+        call uint %llvm.ctpop.i32(uint 12)
+        call ulong %llvm.ctpop.i64(ulong 13)
+
         call ulong %llvm.ctlz(ulong 65000)
+        call ubyte %llvm.ctlz.i8(ubyte 14)
+        call ushort %llvm.ctlz.i16(ushort 15)
+        call uint %llvm.ctlz.i32(uint 16)
+        call ulong %llvm.ctlz.i64(ulong 17)
+
+        call ushort %llvm.cttz(ushort 7)
+        call ubyte %llvm.cttz.i8(ubyte 18)
+        call ushort %llvm.cttz.i16(ushort 19)
+        call uint %llvm.cttz.i32(uint 20)
+        call ulong %llvm.cttz.i64(ulong 21)
 	ret void
 }
 






More information about the llvm-commits mailing list