1*9880d681SAndroid Build Coastguard Worker# RUN: not llvm-mc %s -arch=mips -mcpu=mips32r2 2>%t1 2*9880d681SAndroid Build Coastguard Worker# RUN: FileCheck %s < %t1 --check-prefix=32-BIT 3*9880d681SAndroid Build Coastguard Worker# RUN: not llvm-mc %s -arch=mips64 -mcpu=mips64 -target-abi n32 2>&1 | \ 4*9880d681SAndroid Build Coastguard Worker# RUN: FileCheck %s --check-prefixes=64-BIT,N32-ONLY 5*9880d681SAndroid Build Coastguard Worker# RUN: not llvm-mc %s -arch=mips64 -mcpu=mips64 -target-abi n64 2>&1 | \ 6*9880d681SAndroid Build Coastguard Worker# RUN: FileCheck %s --check-prefixes=64-BIT,N64-ONLY 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker .text 9*9880d681SAndroid Build Coastguard Worker dli $5, 1 10*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction requires a 64-bit architecture 11*9880d681SAndroid Build Coastguard Worker bne $2, 0x100010001, 1332 12*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction requires a 32-bit immediate 13*9880d681SAndroid Build Coastguard Worker beq $2, 0x100010001, 1332 14*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction requires a 32-bit immediate 15*9880d681SAndroid Build Coastguard Worker .set mips32r6 16*9880d681SAndroid Build Coastguard Worker ulh $5, 0 17*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 18*9880d681SAndroid Build Coastguard Worker # 64-BIT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 19*9880d681SAndroid Build Coastguard Worker ulhu $5, 0 20*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 21*9880d681SAndroid Build Coastguard Worker # 64-BIT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 22*9880d681SAndroid Build Coastguard Worker .set mips32 23*9880d681SAndroid Build Coastguard Worker ulh $5, 1 24*9880d681SAndroid Build Coastguard Worker # 32-BIT-NOT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 25*9880d681SAndroid Build Coastguard Worker # 64-BIT-NOT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 26*9880d681SAndroid Build Coastguard Worker ulhu $5, 1 27*9880d681SAndroid Build Coastguard Worker # 32-BIT-NOT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 28*9880d681SAndroid Build Coastguard Worker # 64-BIT-NOT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 29*9880d681SAndroid Build Coastguard Worker .set mips64r6 30*9880d681SAndroid Build Coastguard Worker ulh $5, 2 31*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 32*9880d681SAndroid Build Coastguard Worker # 64-BIT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 33*9880d681SAndroid Build Coastguard Worker ulhu $5, 2 34*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 35*9880d681SAndroid Build Coastguard Worker # 64-BIT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Worker .set mips32r6 38*9880d681SAndroid Build Coastguard Worker ulw $5, 0 39*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 40*9880d681SAndroid Build Coastguard Worker # 64-BIT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 41*9880d681SAndroid Build Coastguard Worker .set mips32 42*9880d681SAndroid Build Coastguard Worker ulw $5, 1 43*9880d681SAndroid Build Coastguard Worker # 32-BIT-NOT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 44*9880d681SAndroid Build Coastguard Worker # 64-BIT-NOT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 45*9880d681SAndroid Build Coastguard Worker .set mips64r6 46*9880d681SAndroid Build Coastguard Worker ulw $5, 2 47*9880d681SAndroid Build Coastguard Worker # 32-BIT: :[[@LINE-1]]:3: error: instruction not supported on mips32r6 or mips64r6 48*9880d681SAndroid Build Coastguard Worker # 64-BIT: :[[@LINE-2]]:3: error: instruction not supported on mips32r6 or mips64r6 49