blob: a528d728be066500467a97d7c9b0333ce95ba1d0 [file] [log] [blame]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00001; Make sure this testcase codegens to the ctpop instruction
Tanya Lattnerf28e0ce2008-02-19 01:41:04 +00002; RUN: llvm-as < %s | llc -march=alpha -mcpu=ev67 | grep -i ctpop
3; RUN: llvm-as < %s | llc -march=alpha -mattr=+CIX | \
Dan Gohmanf17a25c2007-07-18 16:29:46 +00004; RUN: grep -i ctpop
Tanya Lattnerf28e0ce2008-02-19 01:41:04 +00005; RUN: llvm-as < %s | llc -march=alpha -mcpu=ev6 | \
Dan Gohmanf17a25c2007-07-18 16:29:46 +00006; RUN: not grep -i ctpop
Tanya Lattnerf28e0ce2008-02-19 01:41:04 +00007; RUN: llvm-as < %s | llc -march=alpha -mattr=-CIX | \
Dan Gohmanf17a25c2007-07-18 16:29:46 +00008; RUN: not grep -i ctpop
9
Tanya Lattnerf28e0ce2008-02-19 01:41:04 +000010declare i64 @llvm.ctpop.i64(i64)
Dan Gohmanf17a25c2007-07-18 16:29:46 +000011
Tanya Lattnerf28e0ce2008-02-19 01:41:04 +000012define i64 @bar(i64 %x) {
Dan Gohmanf17a25c2007-07-18 16:29:46 +000013entry:
Tanya Lattnerf28e0ce2008-02-19 01:41:04 +000014 %tmp.1 = call i64 @llvm.ctpop.i64( i64 %x ) ; <i64> [#uses=1]
15 ret i64 %tmp.1
Dan Gohmanf17a25c2007-07-18 16:29:46 +000016}
Tanya Lattnerf28e0ce2008-02-19 01:41:04 +000017