File: combine.ll

package info (click to toggle)
llvm-3.1 3.1-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 80,224 kB
  • sloc: cpp: 491,014; asm: 110,971; ansic: 14,579; sh: 13,120; python: 6,152; ml: 4,719; makefile: 1,830; pascal: 1,553; perl: 874; xml: 283; lisp: 187; csh: 117; exp: 4
file content (18 lines) | stat: -rw-r--r-- 473 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
; RUN: true
; DISABLED: llc -march=hexagon -mcpu=hexagonv4 < %s | FileCheck %s
; CHECK: combine(r{{[0-9]+}}, r{{[0-9]+}})

@j = external global i32
@k = external global i64

define void @foo() nounwind {
entry:
  %0 = load i32* @j, align 4
  %1 = load i64* @k, align 8
  %conv = trunc i64 %1 to i32
  %2 = call i64 @llvm.hexagon.A2.combinew(i32 %0, i32 %conv)
  store i64 %2, i64* @k, align 8
  ret void
}

declare i64 @llvm.hexagon.A2.combinew(i32, i32) nounwind readnone