llvm/llvm/test/MachineVerifier/test_g_ptr_add.mir

# RUN: not --crash llc -o - -mtriple=arm64 -run-pass=none -verify-machineinstrs %s 2>&1 | FileCheck %s
# REQUIRES: aarch64-registered-target

---
name:            test_gep
legalized:       true
regBankSelected: false
selected:        false
tracksRegLiveness: true
liveins:
body:             |
  bb.0:

    %0:_(p0) = G_IMPLICIT_DEF
    %1:_(s64) = G_IMPLICIT_DEF

    ; CHECK:  Bad machine code: Type mismatch in generic instruction
    %2:_(s64) = G_PTR_ADD %0, %1

    ; CHECK:  Bad machine code: Type mismatch in generic instruction
    %3:_(p0) = G_PTR_ADD %1, %1

    ; CHECK: Bad machine code: gep offset operand must not be a pointer
    %4:_(p0) = G_PTR_ADD %0, %0

    ; CHECK: Bad machine code: Type mismatch in generic instruction
    %5:_(p1) = G_PTR_ADD %0, %1

    ; CHECK: Bad machine code: gep first operand must be a pointer
    %6:_(s64) = G_PTR_ADD %1, %1

    %7:_(s32) = G_IMPLICIT_DEF

    ; CHECK: Bad machine code: gep offset operand must match index size for address space
    %8:_(p0) = G_PTR_ADD %0, %7
...