1; RUN: llc < %s -march=x86 -mattr=+sse2 2; ModuleID = 'mult-alt-x86.c' 3target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f80:128:128-v64:64:64-v128:128:128-a0:0:64-f80:32:32-n8:16:32" 4target triple = "i686-pc-win32" 5 6@mout0 = common global i32 0, align 4 7@min1 = common global i32 0, align 4 8@dout0 = common global double 0.000000e+000, align 8 9@din1 = common global double 0.000000e+000, align 8 10@marray = common global [2 x i32] zeroinitializer, align 4 11 12define void @single_R() nounwind { 13entry: 14 %tmp = load i32* @min1, align 4 15 %0 = call i32 asm "foo $1,$0", "=R,R,~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 16 store i32 %0, i32* @mout0, align 4 17 ret void 18} 19 20define void @single_q() nounwind { 21entry: 22 %tmp = load i32* @min1, align 4 23 %0 = call i32 asm "foo $1,$0", "=q,q,~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 24 store i32 %0, i32* @mout0, align 4 25 ret void 26} 27 28define void @single_Q() nounwind { 29entry: 30 %tmp = load i32* @min1, align 4 31 %0 = call i32 asm "foo $1,$0", "=Q,Q,~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 32 store i32 %0, i32* @mout0, align 4 33 ret void 34} 35 36define void @single_a() nounwind { 37entry: 38 %tmp = load i32* @min1, align 4 39 %0 = call i32 asm "foo $1,$0", "={ax},{ax},~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 40 store i32 %0, i32* @mout0, align 4 41 ret void 42} 43 44define void @single_b() nounwind { 45entry: 46 %tmp = load i32* @min1, align 4 47 %0 = call i32 asm "foo $1,$0", "={bx},{bx},~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 48 store i32 %0, i32* @mout0, align 4 49 ret void 50} 51 52define void @single_c() nounwind { 53entry: 54 %tmp = load i32* @min1, align 4 55 %0 = call i32 asm "foo $1,$0", "={cx},{cx},~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 56 store i32 %0, i32* @mout0, align 4 57 ret void 58} 59 60define void @single_d() nounwind { 61entry: 62 %tmp = load i32* @min1, align 4 63 %0 = call i32 asm "foo $1,$0", "={dx},{dx},~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 64 store i32 %0, i32* @mout0, align 4 65 ret void 66} 67 68define void @single_S() nounwind { 69entry: 70 %tmp = load i32* @min1, align 4 71 %0 = call i32 asm "foo $1,$0", "={si},{si},~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 72 store i32 %0, i32* @mout0, align 4 73 ret void 74} 75 76define void @single_D() nounwind { 77entry: 78 %tmp = load i32* @min1, align 4 79 %0 = call i32 asm "foo $1,$0", "={di},{di},~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 80 store i32 %0, i32* @mout0, align 4 81 ret void 82} 83 84define void @single_A() nounwind { 85entry: 86 %tmp = load i32* @min1, align 4 87 %0 = call i32 asm "foo $1,$0", "=A,A,~{dirflag},~{fpsr},~{flags}"(i32 %tmp) nounwind 88 store i32 %0, i32* @mout0, align 4 89 ret void 90} 91 92define void @single_f() nounwind { 93entry: 94 ret void 95} 96 97define void @single_t() nounwind { 98entry: 99 ret void 100} 101 102define void @single_u() nounwind { 103entry: 104 ret void 105} 106 107define void @single_y() nounwind { 108entry: 109 %tmp = load double* @din1, align 8 110 %0 = call double asm "foo $1,$0", "=y,y,~{dirflag},~{fpsr},~{flags}"(double %tmp) nounwind 111 store double %0, double* @dout0, align 8 112 ret void 113} 114 115define void @single_x() nounwind { 116entry: 117 %tmp = load double* @din1, align 8 118 %0 = call double asm "foo $1,$0", "=x,x,~{dirflag},~{fpsr},~{flags}"(double %tmp) nounwind 119 store double %0, double* @dout0, align 8 120 ret void 121} 122 123define void @single_Y0() nounwind { 124entry: 125 ret void 126} 127 128define void @single_I() nounwind { 129entry: 130 call void asm "foo $1,$0", "=*m,I,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 131 ret void 132} 133 134define void @single_J() nounwind { 135entry: 136 call void asm "foo $1,$0", "=*m,J,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 137 ret void 138} 139 140define void @single_K() nounwind { 141entry: 142 call void asm "foo $1,$0", "=*m,K,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 143 ret void 144} 145 146define void @single_L() nounwind { 147entry: 148; Missing lowering support for 'L'. 149; call void asm "foo $1,$0", "=*m,L,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 150 ret void 151} 152 153define void @single_M() nounwind { 154entry: 155; Missing lowering support for 'M'. 156; call void asm "foo $1,$0", "=*m,M,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 157 ret void 158} 159 160define void @single_N() nounwind { 161entry: 162 call void asm "foo $1,$0", "=*m,N,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 163 ret void 164} 165 166define void @single_G() nounwind { 167entry: 168; Missing lowering support for 'G'. 169; call void asm "foo $1,$0", "=*m,G,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, double 1.000000e+000) nounwind 170 ret void 171} 172 173define void @single_C() nounwind { 174entry: 175; Missing lowering support for 'C'. 176; call void asm "foo $1,$0", "=*m,C,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, double 1.000000e+000) nounwind 177 ret void 178} 179 180define void @single_e() nounwind { 181entry: 182 call void asm "foo $1,$0", "=*m,e,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 183 ret void 184} 185 186define void @single_Z() nounwind { 187entry: 188 call void asm "foo $1,$0", "=*m,Z,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 189 ret void 190} 191 192define void @multi_R() nounwind { 193entry: 194 %tmp = load i32* @min1, align 4 195 call void asm "foo $1,$0", "=*r|R|m,r|R|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 196 ret void 197} 198 199define void @multi_q() nounwind { 200entry: 201 %tmp = load i32* @min1, align 4 202 call void asm "foo $1,$0", "=*r|q|m,r|q|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 203 ret void 204} 205 206define void @multi_Q() nounwind { 207entry: 208 %tmp = load i32* @min1, align 4 209 call void asm "foo $1,$0", "=*r|Q|m,r|Q|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 210 ret void 211} 212 213define void @multi_a() nounwind { 214entry: 215 %tmp = load i32* @min1, align 4 216 call void asm "foo $1,$0", "=*r|{ax}|m,r|{ax}|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 217 ret void 218} 219 220define void @multi_b() nounwind { 221entry: 222 %tmp = load i32* @min1, align 4 223 call void asm "foo $1,$0", "=*r|{bx}|m,r|{bx}|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 224 ret void 225} 226 227define void @multi_c() nounwind { 228entry: 229 %tmp = load i32* @min1, align 4 230 call void asm "foo $1,$0", "=*r|{cx}|m,r|{cx}|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 231 ret void 232} 233 234define void @multi_d() nounwind { 235entry: 236 %tmp = load i32* @min1, align 4 237 call void asm "foo $1,$0", "=*r|{dx}|m,r|{dx},~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 238 ret void 239} 240 241define void @multi_S() nounwind { 242entry: 243 %tmp = load i32* @min1, align 4 244 call void asm "foo $1,$0", "=*r|{si}|m,r|{si}|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 245 ret void 246} 247 248define void @multi_D() nounwind { 249entry: 250 %tmp = load i32* @min1, align 4 251 call void asm "foo $1,$0", "=*r|{di}|m,r|{di}|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 252 ret void 253} 254 255define void @multi_A() nounwind { 256entry: 257 %tmp = load i32* @min1, align 4 258 call void asm "foo $1,$0", "=*r|A|m,r|A|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 %tmp) nounwind 259 ret void 260} 261 262define void @multi_f() nounwind { 263entry: 264 ret void 265} 266 267define void @multi_t() nounwind { 268entry: 269 ret void 270} 271 272define void @multi_u() nounwind { 273entry: 274 ret void 275} 276 277define void @multi_y() nounwind { 278entry: 279 %tmp = load double* @din1, align 8 280 call void asm "foo $1,$0", "=*r|y|m,r|y|m,~{dirflag},~{fpsr},~{flags}"(double* @dout0, double %tmp) nounwind 281 ret void 282} 283 284define void @multi_x() nounwind { 285entry: 286 %tmp = load double* @din1, align 8 287 call void asm "foo $1,$0", "=*r|x|m,r|x|m,~{dirflag},~{fpsr},~{flags}"(double* @dout0, double %tmp) nounwind 288 ret void 289} 290 291define void @multi_Y0() nounwind { 292entry: 293 ret void 294} 295 296define void @multi_I() nounwind { 297entry: 298 call void asm "foo $1,$0", "=*r|m|m,r|I|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 299 ret void 300} 301 302define void @multi_J() nounwind { 303entry: 304 call void asm "foo $1,$0", "=*r|m|m,r|J|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 305 ret void 306} 307 308define void @multi_K() nounwind { 309entry: 310 call void asm "foo $1,$0", "=*r|m|m,r|K|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 311 ret void 312} 313 314define void @multi_L() nounwind { 315entry: 316; Missing lowering support for 'L'. 317; call void asm "foo $1,$0", "=*r|m|m,r|L|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 318 ret void 319} 320 321define void @multi_M() nounwind { 322entry: 323; Missing lowering support for 'M'. 324; call void asm "foo $1,$0", "=*r|m|m,r|M|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 325 ret void 326} 327 328define void @multi_N() nounwind { 329entry: 330 call void asm "foo $1,$0", "=*r|m|m,r|N|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 331 ret void 332} 333 334define void @multi_G() nounwind { 335entry: 336; Missing lowering support for 'G'. 337; call void asm "foo $1,$0", "=*r|m|m,r|G|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, double 1.000000e+000) nounwind 338 ret void 339} 340 341define void @multi_C() nounwind { 342entry: 343; Missing lowering support for 'C'. 344; call void asm "foo $1,$0", "=*r|m|m,r|C|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, double 1.000000e+000) nounwind 345 ret void 346} 347 348define void @multi_e() nounwind { 349entry: 350 call void asm "foo $1,$0", "=*r|m|m,r|e|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 351 ret void 352} 353 354define void @multi_Z() nounwind { 355entry: 356 call void asm "foo $1,$0", "=*r|m|m,r|Z|m,~{dirflag},~{fpsr},~{flags}"(i32* @mout0, i32 1) nounwind 357 ret void 358} 359