File: machine-verifier-address.mir

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (31 lines) | stat: -rw-r--r-- 1,035 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# RUN: not --crash llc -march=x86-64 -run-pass none -o /dev/null %s 2>&1 | FileCheck %s
# This test ensures that the address is checked in machine verifier.

---
name:            baz
tracksRegLiveness: true
body:             |
  bb.0:
    successors: %bb.1(0x80000000)
    liveins: $rdi, $xmm0
  
    %1:vr128 = COPY $xmm0
    %0:gr64 = COPY $rdi
    %2:vr128 = COPY %1
  
  bb.1:
    successors: %bb.1(0x80000000)
  
    %3:vr256 = AVX_SET0
    %4:vr128 = VPSLLDri %2, 31
    %5:vr256 = VPMOVSXDQYrr killed %4
    %8:vr256 = IMPLICIT_DEF
    ; CHECK: *** Bad machine code: Scale factor in address must be 1, 2, 4 or 8 ***
    %6:vr256, %7:vr256 = VGATHERQPDYrm %3, %0, 16, killed %8, 0, $noreg, %5 :: (load unknown-size, align 8)
    %9:vr128 = COPY %6.sub_xmm
    ; CHECK: *** Bad machine code: Displacement in address must fit into 32-bit signed integer ***
    VMOVLPDmr $noreg, 1, $noreg, 1111111111111, $noreg, killed %9 :: (store (s64) into `ptr undef`)
    JMP_1 %bb.1
    ; CHECK: LLVM ERROR: Found 2 machine code errors

...