1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=arm64-apple-ios < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workerdefine i64 @sbfiz64(i64 %v) { 4*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: sbfiz64: 5*9880d681SAndroid Build Coastguard Worker; CHECK: sbfiz x0, x0, #1, #16 6*9880d681SAndroid Build Coastguard Worker %shl = shl i64 %v, 48 7*9880d681SAndroid Build Coastguard Worker %shr = ashr i64 %shl, 47 8*9880d681SAndroid Build Coastguard Worker ret i64 %shr 9*9880d681SAndroid Build Coastguard Worker} 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Workerdefine i32 @sbfiz32(i32 %v) { 12*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: sbfiz32: 13*9880d681SAndroid Build Coastguard Worker; CHECK: sbfiz w0, w0, #1, #14 14*9880d681SAndroid Build Coastguard Worker %shl = shl i32 %v, 18 15*9880d681SAndroid Build Coastguard Worker %shr = ashr i32 %shl, 17 16*9880d681SAndroid Build Coastguard Worker ret i32 %shr 17*9880d681SAndroid Build Coastguard Worker} 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Workerdefine i64 @ubfiz64(i64 %v) { 20*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: ubfiz64: 21*9880d681SAndroid Build Coastguard Worker; CHECK: ubfiz x0, x0, #36, #11 22*9880d681SAndroid Build Coastguard Worker %shl = shl i64 %v, 53 23*9880d681SAndroid Build Coastguard Worker %shr = lshr i64 %shl, 17 24*9880d681SAndroid Build Coastguard Worker ret i64 %shr 25*9880d681SAndroid Build Coastguard Worker} 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerdefine i32 @ubfiz32(i32 %v) { 28*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: ubfiz32: 29*9880d681SAndroid Build Coastguard Worker; CHECK: ubfiz w0, w0, #6, #24 30*9880d681SAndroid Build Coastguard Worker %shl = shl i32 %v, 8 31*9880d681SAndroid Build Coastguard Worker %shr = lshr i32 %shl, 2 32*9880d681SAndroid Build Coastguard Worker ret i32 %shr 33*9880d681SAndroid Build Coastguard Worker} 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Workerdefine i64 @ubfiz64and(i64 %v) { 36*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: ubfiz64and: 37*9880d681SAndroid Build Coastguard Worker; CHECK: ubfiz x0, x0, #36, #11 38*9880d681SAndroid Build Coastguard Worker %shl = shl i64 %v, 36 39*9880d681SAndroid Build Coastguard Worker %and = and i64 %shl, 140668768878592 40*9880d681SAndroid Build Coastguard Worker ret i64 %and 41*9880d681SAndroid Build Coastguard Worker} 42*9880d681SAndroid Build Coastguard Worker 43*9880d681SAndroid Build Coastguard Workerdefine i32 @ubfiz32and(i32 %v) { 44*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: ubfiz32and: 45*9880d681SAndroid Build Coastguard Worker; CHECK: ubfiz w0, w0, #6, #24 46*9880d681SAndroid Build Coastguard Worker %shl = shl i32 %v, 6 47*9880d681SAndroid Build Coastguard Worker %and = and i32 %shl, 1073741760 48*9880d681SAndroid Build Coastguard Worker ret i32 %and 49*9880d681SAndroid Build Coastguard Worker} 50*9880d681SAndroid Build Coastguard Worker 51*9880d681SAndroid Build Coastguard Worker; Check that we don't generate a ubfiz if the lsl has more than one 52*9880d681SAndroid Build Coastguard Worker; use, since we'd just be replacing an and with a ubfiz. 53*9880d681SAndroid Build Coastguard Workerdefine i32 @noubfiz32(i32 %v) { 54*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: noubfiz32: 55*9880d681SAndroid Build Coastguard Worker; CHECK: lsl w[[REG1:[0-9]+]], w0, #6 56*9880d681SAndroid Build Coastguard Worker; CHECK: and w[[REG2:[0-9]+]], w[[REG1]], #0x3fffffc0 57*9880d681SAndroid Build Coastguard Worker; CHECK: add w0, w[[REG1]], w[[REG2]] 58*9880d681SAndroid Build Coastguard Worker; CHECK: ret 59*9880d681SAndroid Build Coastguard Worker %shl = shl i32 %v, 6 60*9880d681SAndroid Build Coastguard Worker %and = and i32 %shl, 1073741760 61*9880d681SAndroid Build Coastguard Worker %add = add i32 %shl, %and 62*9880d681SAndroid Build Coastguard Worker ret i32 %add 63*9880d681SAndroid Build Coastguard Worker} 64