1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=thumbv7-windows -o - %s \ 2*9880d681SAndroid Build Coastguard Worker; RUN: | FileCheck %s -check-prefix CHECK-WINDOWS 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=thumbv7-eabi -o - %s \ 5*9880d681SAndroid Build Coastguard Worker; RUN: | FileCheck %s -check-prefix CHECK-EABI 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker@i = common global i32 0, align 4 8*9880d681SAndroid Build Coastguard Worker@j = common global i32 0, align 4 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind optsize readonly 11*9880d681SAndroid Build Coastguard Workerdefine i32 @relocation(i32 %j, i32 %k) { 12*9880d681SAndroid Build Coastguard Workerentry: 13*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* @i, align 4 14*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* @j, align 4 15*9880d681SAndroid Build Coastguard Worker %add = add nsw i32 %1, %0 16*9880d681SAndroid Build Coastguard Worker ret i32 %add 17*9880d681SAndroid Build Coastguard Worker} 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker; CHECK-WINDOWS: movw r[[i:[0-4]]], :lower16:i 20*9880d681SAndroid Build Coastguard Worker; CHECK-WINDOWS-NEXT: movt r[[i]], :upper16:i 21*9880d681SAndroid Build Coastguard Worker; CHECK-WINDOWS: movw r[[j:[0-4]]], :lower16:j 22*9880d681SAndroid Build Coastguard Worker; CHECK-WINDOWS-NEXT: movt r[[j]], :upper16:j 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Worker; CHECK-EABI: movw r[[i:[0-4]]], :lower16:i 25*9880d681SAndroid Build Coastguard Worker; CHECK-EABI: movw r[[j:[0-4]]], :lower16:j 26*9880d681SAndroid Build Coastguard Worker; CHECK-EABI-NEXT: movt r[[i]], :upper16:i 27*9880d681SAndroid Build Coastguard Worker; CHECK-EABI-NEXT: movt r[[j]], :upper16:j 28