1*9880d681SAndroid Build Coastguard Worker// RUN: llvm-mc -triple aarch64-none-linux-gnu -mattr=+neon,+fullfp16 -show-encoding < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker//------------------------------------------------------------------------------ 4*9880d681SAndroid Build Coastguard Worker// Floating Point fused multiply-add (scalar, by element) 5*9880d681SAndroid Build Coastguard Worker//------------------------------------------------------------------------------ 6*9880d681SAndroid Build Coastguard Worker fmla h0, h1, v1.h[5] 7*9880d681SAndroid Build Coastguard Worker fmla s0, s1, v1.s[0] 8*9880d681SAndroid Build Coastguard Worker fmla s30, s11, v1.s[1] 9*9880d681SAndroid Build Coastguard Worker fmla s4, s5, v7.s[2] 10*9880d681SAndroid Build Coastguard Worker fmla s16, s22, v16.s[3] 11*9880d681SAndroid Build Coastguard Worker fmla d0, d1, v1.d[0] 12*9880d681SAndroid Build Coastguard Worker fmla d30, d11, v1.d[1] 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker// CHECK: fmla h0, h1, v1.h[5] // encoding: [0x20,0x18,0x11,0x5f] 15*9880d681SAndroid Build Coastguard Worker// CHECK: fmla s0, s1, v1.s[0] // encoding: [0x20,0x10,0x81,0x5f] 16*9880d681SAndroid Build Coastguard Worker// CHECK: fmla s30, s11, v1.s[1] // encoding: [0x7e,0x11,0xa1,0x5f] 17*9880d681SAndroid Build Coastguard Worker// CHECK: fmla s4, s5, v7.s[2] // encoding: [0xa4,0x18,0x87,0x5f] 18*9880d681SAndroid Build Coastguard Worker// CHECK: fmla s16, s22, v16.s[3] // encoding: [0xd0,0x1a,0xb0,0x5f] 19*9880d681SAndroid Build Coastguard Worker// CHECK: fmla d0, d1, v1.d[0] // encoding: [0x20,0x10,0xc1,0x5f] 20*9880d681SAndroid Build Coastguard Worker// CHECK: fmla d30, d11, v1.d[1] // encoding: [0x7e,0x19,0xc1,0x5f] 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Worker//------------------------------------------------------------------------------ 23*9880d681SAndroid Build Coastguard Worker// Floating Point fused multiply-subtract (scalar, by element) 24*9880d681SAndroid Build Coastguard Worker//------------------------------------------------------------------------------ 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Worker fmls h2, h3, v4.h[5] 27*9880d681SAndroid Build Coastguard Worker fmls s2, s3, v4.s[0] 28*9880d681SAndroid Build Coastguard Worker fmls s29, s10, v28.s[1] 29*9880d681SAndroid Build Coastguard Worker fmls s5, s12, v23.s[2] 30*9880d681SAndroid Build Coastguard Worker fmls s7, s17, v26.s[3] 31*9880d681SAndroid Build Coastguard Worker fmls d0, d1, v1.d[0] 32*9880d681SAndroid Build Coastguard Worker fmls d30, d11, v1.d[1] 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Worker// CHECK: fmls h2, h3, v4.h[5] // encoding: [0x62,0x58,0x14,0x5f] 35*9880d681SAndroid Build Coastguard Worker// CHECK: fmls s2, s3, v4.s[0] // encoding: [0x62,0x50,0x84,0x5f] 36*9880d681SAndroid Build Coastguard Worker// CHECK: fmls s29, s10, v28.s[1] // encoding: [0x5d,0x51,0xbc,0x5f] 37*9880d681SAndroid Build Coastguard Worker// CHECK: fmls s5, s12, v23.s[2] // encoding: [0x85,0x59,0x97,0x5f] 38*9880d681SAndroid Build Coastguard Worker// CHECK: fmls s7, s17, v26.s[3] // encoding: [0x27,0x5a,0xba,0x5f] 39*9880d681SAndroid Build Coastguard Worker// CHECK: fmls d0, d1, v1.d[0] // encoding: [0x20,0x50,0xc1,0x5f] 40*9880d681SAndroid Build Coastguard Worker// CHECK: fmls d30, d11, v1.d[1] // encoding: [0x7e,0x59,0xc1,0x5f] 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Worker 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker 46*9880d681SAndroid Build Coastguard Worker 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Worker 49