blob: db2e4b19697d8cc6aad0409c8bfa25a266986c8e [file] [log] [blame]
Chris Lattner3c8a3b12005-05-11 04:22:47 +00001; Make sure this testcase is supported by all code generators
Reid Spencer69ccadd2006-12-02 04:23:10 +00002; RUN: llvm-upgrade < %s | llvm-as | llc
Chris Lattner3c8a3b12005-05-11 04:22:47 +00003
Reid Spencera3c533a2007-04-01 07:36:28 +00004declare uint %llvm.ctpop.i64(ulong)
Reid Spencerd05b67d2006-12-02 20:38:10 +00005declare uint %llvm.ctpop.i32(uint)
Reid Spencera3c533a2007-04-01 07:36:28 +00006declare uint %llvm.ctpop.i16(ushort)
7declare uint %llvm.ctpop.i8(ubyte)
Chris Lattner3c8a3b12005-05-11 04:22:47 +00008
Reid Spencerd05b67d2006-12-02 20:38:10 +00009void %ctpoptest(ubyte %A, ushort %B, uint %C, ulong %D,
Reid Spencera3c533a2007-04-01 07:36:28 +000010 uint *%AP, uint* %BP, uint* %CP, uint* %DP) {
11 %a = call uint %llvm.ctpop.i8(ubyte %A)
12 %b = call uint %llvm.ctpop.i16(ushort %B)
Reid Spencerd05b67d2006-12-02 20:38:10 +000013 %c = call uint %llvm.ctpop.i32(uint %C)
Reid Spencera3c533a2007-04-01 07:36:28 +000014 %d = call uint %llvm.ctpop.i64(ulong %D)
Chris Lattner3c8a3b12005-05-11 04:22:47 +000015
Reid Spencera3c533a2007-04-01 07:36:28 +000016 store uint %a, uint* %AP
17 store uint %b, uint* %BP
18 store uint %c, uint* %CP
19 store uint %d, uint* %DP
Chris Lattner3c8a3b12005-05-11 04:22:47 +000020 ret void
21}
Chris Lattner07fc1732005-05-11 05:31:01 +000022
Reid Spencera3c533a2007-04-01 07:36:28 +000023declare uint %llvm.ctlz.i64(ulong)
Reid Spencerd05b67d2006-12-02 20:38:10 +000024declare uint %llvm.ctlz.i32(uint)
Reid Spencera3c533a2007-04-01 07:36:28 +000025declare uint %llvm.ctlz.i16(ushort)
26declare uint %llvm.ctlz.i8(ubyte)
Chris Lattner07fc1732005-05-11 05:31:01 +000027
Reid Spencerd05b67d2006-12-02 20:38:10 +000028void %ctlztest(ubyte %A, ushort %B, uint %C, ulong %D,
Reid Spencera3c533a2007-04-01 07:36:28 +000029 uint *%AP, uint* %BP, uint* %CP, uint* %DP) {
30 %a = call uint %llvm.ctlz.i8(ubyte %A)
31 %b = call uint %llvm.ctlz.i16(ushort %B)
Reid Spencerd05b67d2006-12-02 20:38:10 +000032 %c = call uint %llvm.ctlz.i32(uint %C)
Reid Spencera3c533a2007-04-01 07:36:28 +000033 %d = call uint %llvm.ctlz.i64(ulong %D)
Chris Lattner07fc1732005-05-11 05:31:01 +000034
Reid Spencera3c533a2007-04-01 07:36:28 +000035 store uint %a, uint* %AP
36 store uint %b, uint* %BP
37 store uint %c, uint* %CP
38 store uint %d, uint* %DP
Chris Lattner07fc1732005-05-11 05:31:01 +000039 ret void
40}
41
Reid Spencera3c533a2007-04-01 07:36:28 +000042declare uint %llvm.cttz.i64(ulong)
Reid Spencerd05b67d2006-12-02 20:38:10 +000043declare uint %llvm.cttz.i32(uint)
Reid Spencera3c533a2007-04-01 07:36:28 +000044declare uint %llvm.cttz.i16(ushort)
45declare uint %llvm.cttz.i8(ubyte)
Chris Lattner07fc1732005-05-11 05:31:01 +000046
Reid Spencerd05b67d2006-12-02 20:38:10 +000047void %cttztest(ubyte %A, ushort %B, uint %C, ulong %D,
Reid Spencera3c533a2007-04-01 07:36:28 +000048 uint *%AP, uint* %BP, uint* %CP, uint* %DP) {
49 %a = call uint %llvm.cttz.i8(ubyte %A)
50 %b = call uint %llvm.cttz.i16(ushort %B)
Reid Spencerd05b67d2006-12-02 20:38:10 +000051 %c = call uint %llvm.cttz.i32(uint %C)
Reid Spencera3c533a2007-04-01 07:36:28 +000052 %d = call uint %llvm.cttz.i64(ulong %D)
Chris Lattner07fc1732005-05-11 05:31:01 +000053
Reid Spencera3c533a2007-04-01 07:36:28 +000054 store uint %a, uint* %AP
55 store uint %b, uint* %BP
56 store uint %c, uint* %CP
57 store uint %d, uint* %DP
Chris Lattner07fc1732005-05-11 05:31:01 +000058 ret void
59}