| ; Ensure that shifts are lowered to loops when the barrel shifter unit is | 
 | ; not available in the hardware and that loops are not used when the | 
 | ; barrel shifter unit is available in the hardware. | 
 | ; | 
 | ; RUN: llc < %s -march=mblaze | FileCheck -check-prefix=FUN %s | 
 | ; RUN: llc < %s -march=mblaze -mattr=+barrel | FileCheck -check-prefix=SHT %s | 
 |  | 
 | define i8 @test_i8(i8 %a, i8 %b) { | 
 |     ; FUN:        test_i8: | 
 |     ; SHT:        test_i8: | 
 |  | 
 |     %tmp.1 = shl i8 %a, %b | 
 |     ; FUN:        andi | 
 |     ; FUN:        add | 
 |     ; FUN:        bnei | 
 |     ; SHT-NOT:    bnei | 
 |  | 
 |     ret i8 %tmp.1 | 
 |     ; FUN:        rtsd | 
 |     ; SHT:        rtsd | 
 |     ; FUN-NOT:    bsll | 
 |     ; SHT-NEXT:   bsll | 
 | } | 
 |  | 
 | define i8 @testc_i8(i8 %a, i8 %b) { | 
 |     ; FUN:        testc_i8: | 
 |     ; SHT:        testc_i8: | 
 |  | 
 |     %tmp.1 = shl i8 %a, 5 | 
 |     ; FUN:        andi | 
 |     ; FUN:        add | 
 |     ; FUN:        bnei | 
 |     ; SHT-NOT:    andi | 
 |     ; SHT-NOT:    add | 
 |     ; SHT-NOT:    bnei | 
 |  | 
 |     ret i8 %tmp.1 | 
 |     ; FUN:        rtsd | 
 |     ; SHT:        rtsd | 
 |     ; FUN-NOT:    bsll | 
 |     ; SHT-NEXT:   bslli | 
 | } | 
 |  | 
 | define i16 @test_i16(i16 %a, i16 %b) { | 
 |     ; FUN:        test_i16: | 
 |     ; SHT:        test_i16: | 
 |  | 
 |     %tmp.1 = shl i16 %a, %b | 
 |     ; FUN:        andi | 
 |     ; FUN:        add | 
 |     ; FUN:        bnei | 
 |     ; SHT-NOT:    bnei | 
 |  | 
 |     ret i16 %tmp.1 | 
 |     ; FUN:        rtsd | 
 |     ; SHT:        rtsd | 
 |     ; FUN-NOT:    bsll | 
 |     ; SHT-NEXT:   bsll | 
 | } | 
 |  | 
 | define i16 @testc_i16(i16 %a, i16 %b) { | 
 |     ; FUN:        testc_i16: | 
 |     ; SHT:        testc_i16: | 
 |  | 
 |     %tmp.1 = shl i16 %a, 5 | 
 |     ; FUN:        andi | 
 |     ; FUN:        add | 
 |     ; FUN:        bnei | 
 |     ; SHT-NOT:    andi | 
 |     ; SHT-NOT:    add | 
 |     ; SHT-NOT:    bnei | 
 |  | 
 |     ret i16 %tmp.1 | 
 |     ; FUN:        rtsd | 
 |     ; SHT:        rtsd | 
 |     ; FUN-NOT:    bsll | 
 |     ; SHT-NEXT:   bslli | 
 | } | 
 |  | 
 | define i32 @test_i32(i32 %a, i32 %b) { | 
 |     ; FUN:        test_i32: | 
 |     ; SHT:        test_i32: | 
 |  | 
 |     %tmp.1 = shl i32 %a, %b | 
 |     ; FUN:        andi | 
 |     ; FUN:        add | 
 |     ; FUN:        bnei | 
 |     ; SHT-NOT:    andi | 
 |     ; SHT-NOT:    bnei | 
 |  | 
 |     ret i32 %tmp.1 | 
 |     ; FUN:        rtsd | 
 |     ; SHT:        rtsd | 
 |     ; FUN-NOT:    bsll | 
 |     ; SHT-NEXT:   bsll | 
 | } | 
 |  | 
 | define i32 @testc_i32(i32 %a, i32 %b) { | 
 |     ; FUN:        testc_i32: | 
 |     ; SHT:        testc_i32: | 
 |  | 
 |     %tmp.1 = shl i32 %a, 5 | 
 |     ; FUN:        andi | 
 |     ; FUN:        add | 
 |     ; FUN:        bnei | 
 |     ; SHT-NOT:    andi | 
 |     ; SHT-NOT:    add | 
 |     ; SHT-NOT:    bnei | 
 |  | 
 |     ret i32 %tmp.1 | 
 |     ; FUN:        rtsd | 
 |     ; SHT:        rtsd | 
 |     ; FUN-NOT:    bsll | 
 |     ; SHT-NEXT:   bslli | 
 | } |