2017-10-06 21:59:28 +08:00
|
|
|
# RUN: llc -mtriple=s390x-linux-gnu -mcpu=z10 -start-before=greedy %s -o - \
|
|
|
|
# RUN: | FileCheck %s
|
|
|
|
--- |
|
|
|
|
define void @f0(double* %ptr1, float* %ptr2) {
|
|
|
|
%val0 = load volatile float, float* %ptr2
|
|
|
|
%val1 = load volatile float, float* %ptr2
|
|
|
|
%val2 = load volatile float, float* %ptr2
|
|
|
|
%val3 = load volatile float, float* %ptr2
|
|
|
|
%val4 = load volatile float, float* %ptr2
|
|
|
|
%val5 = load volatile float, float* %ptr2
|
|
|
|
%val6 = load volatile float, float* %ptr2
|
|
|
|
%val7 = load volatile float, float* %ptr2
|
|
|
|
%val8 = load volatile float, float* %ptr2
|
|
|
|
%val9 = load volatile float, float* %ptr2
|
|
|
|
%val10 = load volatile float, float* %ptr2
|
|
|
|
%val11 = load volatile float, float* %ptr2
|
|
|
|
%val12 = load volatile float, float* %ptr2
|
|
|
|
%val13 = load volatile float, float* %ptr2
|
|
|
|
%val14 = load volatile float, float* %ptr2
|
|
|
|
%val15 = load volatile float, float* %ptr2
|
|
|
|
%val16 = load volatile float, float* %ptr2
|
|
|
|
%ext0 = fpext float %val0 to double
|
|
|
|
%ext1 = fpext float %val1 to double
|
|
|
|
%ext2 = fpext float %val2 to double
|
|
|
|
%ext3 = fpext float %val3 to double
|
|
|
|
%ext4 = fpext float %val4 to double
|
|
|
|
%ext5 = fpext float %val5 to double
|
|
|
|
%ext6 = fpext float %val6 to double
|
|
|
|
%ext7 = fpext float %val7 to double
|
|
|
|
%ext8 = fpext float %val8 to double
|
|
|
|
%ext9 = fpext float %val9 to double
|
|
|
|
%ext10 = fpext float %val10 to double
|
|
|
|
%ext11 = fpext float %val11 to double
|
|
|
|
%ext12 = fpext float %val12 to double
|
|
|
|
%ext13 = fpext float %val13 to double
|
|
|
|
%ext14 = fpext float %val14 to double
|
|
|
|
%ext15 = fpext float %val15 to double
|
|
|
|
%ext16 = fpext float %val16 to double
|
|
|
|
store volatile float %val0, float* %ptr2
|
|
|
|
store volatile float %val1, float* %ptr2
|
|
|
|
store volatile float %val2, float* %ptr2
|
|
|
|
store volatile float %val3, float* %ptr2
|
|
|
|
store volatile float %val4, float* %ptr2
|
|
|
|
store volatile float %val5, float* %ptr2
|
|
|
|
store volatile float %val6, float* %ptr2
|
|
|
|
store volatile float %val7, float* %ptr2
|
|
|
|
store volatile float %val8, float* %ptr2
|
|
|
|
store volatile float %val9, float* %ptr2
|
|
|
|
store volatile float %val10, float* %ptr2
|
|
|
|
store volatile float %val11, float* %ptr2
|
|
|
|
store volatile float %val12, float* %ptr2
|
|
|
|
store volatile float %val13, float* %ptr2
|
|
|
|
store volatile float %val14, float* %ptr2
|
|
|
|
store volatile float %val15, float* %ptr2
|
|
|
|
store volatile float %val16, float* %ptr2
|
|
|
|
store volatile double %ext0, double* %ptr1
|
|
|
|
store volatile double %ext1, double* %ptr1
|
|
|
|
store volatile double %ext2, double* %ptr1
|
|
|
|
store volatile double %ext3, double* %ptr1
|
|
|
|
store volatile double %ext4, double* %ptr1
|
|
|
|
store volatile double %ext5, double* %ptr1
|
|
|
|
store volatile double %ext6, double* %ptr1
|
|
|
|
store volatile double %ext7, double* %ptr1
|
|
|
|
store volatile double %ext8, double* %ptr1
|
|
|
|
store volatile double %ext9, double* %ptr1
|
|
|
|
store volatile double %ext10, double* %ptr1
|
|
|
|
store volatile double %ext11, double* %ptr1
|
|
|
|
store volatile double %ext12, double* %ptr1
|
|
|
|
store volatile double %ext13, double* %ptr1
|
|
|
|
store volatile double %ext14, double* %ptr1
|
|
|
|
store volatile double %ext15, double* %ptr1
|
|
|
|
store volatile double %ext16, double* %ptr1
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
...
|
|
|
|
|
|
|
|
# CHECK-LABEL: f0:
|
|
|
|
# CHECK: ldeb {{%f[0-9]+}}, 16{{[04]}}(%r15)
|
|
|
|
# CHECK: br %r14
|
|
|
|
|
|
|
|
---
|
|
|
|
name: f0
|
[Alignment] Use llvm::Align in MachineFunction and TargetLowering - fixes mir parsing
Summary:
This catches malformed mir files which specify alignment as log2 instead of pow2.
See https://reviews.llvm.org/D65945 for reference,
This is patch is part of a series to introduce an Alignment type.
See this thread for context: http://lists.llvm.org/pipermail/llvm-dev/2019-July/133851.html
See this patch for the introduction of the type: https://reviews.llvm.org/D64790
Reviewers: courbet
Subscribers: MatzeB, qcolombet, dschuff, arsenm, sdardis, nemanjai, jvesely, nhaehnle, hiraditya, kbarton, asb, rbar, johnrusso, simoncook, apazos, sabuasal, niosHD, jrtc27, MaskRay, zzheng, edward-jones, atanasyan, rogfer01, MartinMosbeck, brucehoult, the_o, PkmX, jocewei, jsji, Petar.Avramovic, asbirlea, s.egerton, pzheng, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D67433
llvm-svn: 371608
2019-09-11 19:16:48 +08:00
|
|
|
alignment: 4
|
2017-10-06 21:59:28 +08:00
|
|
|
tracksRegLiveness: true
|
|
|
|
registers:
|
|
|
|
- { id: 0, class: addr64bit }
|
|
|
|
- { id: 1, class: addr64bit }
|
|
|
|
- { id: 2, class: fp32bit }
|
|
|
|
- { id: 3, class: fp32bit }
|
|
|
|
- { id: 4, class: fp32bit }
|
|
|
|
- { id: 5, class: fp32bit }
|
|
|
|
- { id: 6, class: fp32bit }
|
|
|
|
- { id: 7, class: fp32bit }
|
|
|
|
- { id: 8, class: fp32bit }
|
|
|
|
- { id: 9, class: fp32bit }
|
|
|
|
- { id: 10, class: fp32bit }
|
|
|
|
- { id: 11, class: fp32bit }
|
|
|
|
- { id: 12, class: fp32bit }
|
|
|
|
- { id: 13, class: fp32bit }
|
|
|
|
- { id: 14, class: fp32bit }
|
|
|
|
- { id: 15, class: fp32bit }
|
|
|
|
- { id: 16, class: fp32bit }
|
|
|
|
- { id: 17, class: fp32bit }
|
|
|
|
- { id: 18, class: fp32bit }
|
|
|
|
- { id: 19, class: fp64bit }
|
|
|
|
- { id: 20, class: fp64bit }
|
|
|
|
- { id: 21, class: fp64bit }
|
|
|
|
- { id: 22, class: fp64bit }
|
|
|
|
- { id: 23, class: fp64bit }
|
|
|
|
- { id: 24, class: fp64bit }
|
|
|
|
- { id: 25, class: fp64bit }
|
|
|
|
- { id: 26, class: fp64bit }
|
|
|
|
- { id: 27, class: fp64bit }
|
|
|
|
- { id: 28, class: fp64bit }
|
|
|
|
- { id: 29, class: fp64bit }
|
|
|
|
- { id: 30, class: fp64bit }
|
|
|
|
- { id: 31, class: fp64bit }
|
|
|
|
- { id: 32, class: fp64bit }
|
|
|
|
- { id: 33, class: fp64bit }
|
|
|
|
- { id: 34, class: fp64bit }
|
|
|
|
- { id: 35, class: fp64bit }
|
|
|
|
liveins:
|
2018-02-01 06:04:26 +08:00
|
|
|
- { reg: '$r2d', virtual-reg: '%0' }
|
|
|
|
- { reg: '$r3d', virtual-reg: '%1' }
|
2017-10-06 21:59:28 +08:00
|
|
|
body: |
|
|
|
|
bb.0 (%ir-block.0):
|
2018-02-01 06:04:26 +08:00
|
|
|
liveins: $r2d, $r3d
|
2017-10-06 21:59:28 +08:00
|
|
|
|
2018-02-01 06:04:26 +08:00
|
|
|
%1 = COPY $r3d
|
|
|
|
%0 = COPY $r2d
|
|
|
|
%2 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%3 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%4 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%5 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%6 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%7 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%8 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%9 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%10 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%11 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%12 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%13 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%14 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%15 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%16 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%17 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
%18 = LE %1, 0, $noreg :: (volatile load 4 from %ir.ptr2)
|
|
|
|
STE %2, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %3, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %4, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %5, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %6, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %7, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %8, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %9, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %10, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %11, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %12, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %13, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %14, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %15, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %16, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %17, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
|
|
|
STE %18, %1, 0, $noreg :: (volatile store 4 into %ir.ptr2)
|
2019-05-13 17:47:26 +08:00
|
|
|
%19 = LDEBR %2, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %19, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%20 = LDEBR %3, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %20, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%21 = LDEBR %4, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %21, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%22 = LDEBR %5, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %22, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%23 = LDEBR %6, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %23, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%24 = LDEBR %7, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %24, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%25 = LDEBR %8, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %25, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%26 = LDEBR %9, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %26, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%27 = LDEBR %10, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %27, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%28 = LDEBR %11, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %28, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%29 = LDEBR %12, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %29, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%30 = LDEBR %13, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %30, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%31 = LDEBR %14, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %31, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%32 = LDEBR %15, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %32, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%33 = LDEBR %16, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %33, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%34 = LDEBR %17, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %34, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2019-05-13 17:47:26 +08:00
|
|
|
%35 = LDEBR %18, implicit $fpc
|
2018-02-01 06:04:26 +08:00
|
|
|
STD %35, %0, 0, $noreg :: (volatile store 8 into %ir.ptr1)
|
2017-10-06 21:59:28 +08:00
|
|
|
Return
|
|
|
|
|
|
|
|
...
|