1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon < %s 2*9880d681SAndroid Build Coastguard Worker; REQUIRES: asserts 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; This test used to crash in register scavenger due to incorrectly set 5*9880d681SAndroid Build Coastguard Worker; kill flags. 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Workertarget triple = "hexagon" 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Workerdefine void @foo(i64 %a) #0 { 10*9880d681SAndroid Build Coastguard Workerentry: 11*9880d681SAndroid Build Coastguard Worker %conv.i = and i64 %a, 9218868437227405312 12*9880d681SAndroid Build Coastguard Worker %cmp = icmp ne i64 %conv.i, 9218868437227405312 13*9880d681SAndroid Build Coastguard Worker %and.i37 = and i64 %a, 4503599627370495 14*9880d681SAndroid Build Coastguard Worker %tobool = icmp eq i64 %and.i37, 0 15*9880d681SAndroid Build Coastguard Worker %or.cond = or i1 %cmp, %tobool 16*9880d681SAndroid Build Coastguard Worker br i1 %or.cond, label %lor.lhs.false, label %if.then 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Workerlor.lhs.false: ; preds = %entry 19*9880d681SAndroid Build Coastguard Worker br i1 undef, label %return, label %if.then 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Workerif.then: ; preds = %lor.lhs.false, %entry 22*9880d681SAndroid Build Coastguard Worker br label %return 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Workerreturn: ; preds = %if.then, %lor.lhs.false 25*9880d681SAndroid Build Coastguard Worker ret void 26*9880d681SAndroid Build Coastguard Worker} 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Workerattributes #0 = { norecurse nounwind } 29