File: 2006-11-10-ashr-miscompile.ll

package info (click to toggle)
llvm-toolchain-11 1%3A11.0.1-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 995,808 kB
  • sloc: cpp: 4,767,656; ansic: 760,916; asm: 477,436; python: 170,940; objc: 69,804; lisp: 29,914; sh: 23,855; f90: 18,173; pascal: 7,551; perl: 7,471; ml: 5,603; awk: 3,489; makefile: 2,573; xml: 915; cs: 573; fortran: 503; javascript: 452
file content (9 lines) | stat: -rw-r--r-- 280 bytes parent folder | download | duplicates (28)
1
2
3
4
5
6
7
8
9
; RUN: opt < %s -instcombine -S | grep lshr
; Verify this is not turned into -1.

define i32 @test(i8 %amt) {
        %shift.upgrd.1 = zext i8 %amt to i32            ; <i32> [#uses=1]
        %B = lshr i32 -1, %shift.upgrd.1                ; <i32> [#uses=1]
        ret i32 %B
}