File: ctpop.ll

package info (click to toggle)
llvm 2.2-12
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 38,648 kB
  • ctags: 28,258
  • sloc: cpp: 215,479; sh: 12,132; ansic: 10,002; yacc: 5,525; perl: 2,352; ml: 1,580; makefile: 956; pascal: 718; lex: 602; exp: 320; ada: 193; lisp: 160; csh: 116; objc: 59; python: 59; tcl: 20
file content (30 lines) | stat: -rw-r--r-- 816 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
; RUN: llvm-as -o - %s | llc -march=cellspu > %t1.s
; RUN: grep cntb    %t1.s | count 3 &&
; RUN: grep andi    %t1.s | count 3 &&
; RUN: grep rotmi   %t1.s | count 2 &&
; RUN: grep rothmi  %t1.s | count 1
target datalayout = "E-p:32:32:128-f64:64:128-f32:32:128-i64:32:128-i32:32:128-i16:16:128-i8:8:128-i1:8:128-a0:0:128-v128:128:128-s0:128:128"
target triple = "spu"

declare i32 @llvm.ctpop.i8(i8)
declare i32 @llvm.ctpop.i16(i16)
declare i32 @llvm.ctpop.i32(i32)

define i32 @test_i8(i8 %X) {
	call i32 @llvm.ctpop.i8(i8 %X)
	%Y = bitcast i32 %1 to i32
	ret i32 %Y
}

define i32 @test_i16(i16 %X) {
        call i32 @llvm.ctpop.i16(i16 %X)
	%Y = bitcast i32 %1 to i32
        ret i32 %Y
}

define i32 @test_i32(i32 %X) {
        call i32 @llvm.ctpop.i32(i32 %X)
	%Y = bitcast i32 %1 to i32
        ret i32 %Y
}