| ; RUN: llc -mtriple=riscv32 -O0 -debug-pass=Structure < %s -o /dev/null 2>&1 | \ |
| ; RUN: grep -v "Verify generated machine code" | \ |
| ; RUN: FileCheck %s --check-prefixes=CHECK |
| ; RUN: llc -mtriple=riscv64 -O0 -debug-pass=Structure < %s -o /dev/null 2>&1 | \ |
| ; RUN: grep -v "Verify generated machine code" | \ |
| ; RUN: FileCheck %s --check-prefixes=CHECK |
| |
| ; REQUIRES: asserts |
| |
| ; CHECK-LABEL: Pass Arguments: |
| ; CHECK-NEXT: Target Library Information |
| ; CHECK-NEXT: Target Pass Configuration |
| ; CHECK-NEXT: Machine Module Information |
| ; CHECK-NEXT: Target Transform Information |
| ; CHECK-NEXT: Create Garbage Collector Module Metadata |
| ; CHECK-NEXT: Assumption Cache Tracker |
| ; CHECK-NEXT: Profile summary info |
| ; CHECK-NEXT: Machine Branch Probability Analysis |
| ; CHECK-NEXT: ModulePass Manager |
| ; CHECK-NEXT: Pre-ISel Intrinsic Lowering |
| ; CHECK-NEXT: FunctionPass Manager |
| ; CHECK-NEXT: Expand large div/rem |
| ; CHECK-NEXT: Expand large fp convert |
| ; CHECK-NEXT: Expand Atomic instructions |
| ; CHECK-NEXT: Module Verifier |
| ; CHECK-NEXT: Lower Garbage Collection Instructions |
| ; CHECK-NEXT: Shadow Stack GC Lowering |
| ; CHECK-NEXT: Lower constant intrinsics |
| ; CHECK-NEXT: Remove unreachable blocks from the CFG |
| ; CHECK-NEXT: Expand vector predication intrinsics |
| ; CHECK-NEXT: Scalarize Masked Memory Intrinsics |
| ; CHECK-NEXT: Expand reduction intrinsics |
| ; CHECK-NEXT: Exception handling preparation |
| ; CHECK-NEXT: Prepare callbr |
| ; CHECK-NEXT: Safe Stack instrumentation pass |
| ; CHECK-NEXT: Insert stack protectors |
| ; CHECK-NEXT: Module Verifier |
| ; CHECK-NEXT: Assignment Tracking Analysis |
| ; CHECK-NEXT: RISC-V DAG->DAG Pattern Instruction Selection |
| ; CHECK-NEXT: Finalize ISel and expand pseudo-instructions |
| ; CHECK-NEXT: Local Stack Slot Allocation |
| ; CHECK-NEXT: RISC-V Pre-RA pseudo instruction expansion pass |
| ; CHECK-NEXT: RISC-V Insert VSETVLI pass |
| ; CHECK-NEXT: RISC-V Insert Read/Write CSR Pass |
| ; CHECK-NEXT: RISC-V init undef pass |
| ; CHECK-NEXT: Eliminate PHI nodes for register allocation |
| ; CHECK-NEXT: Two-Address instruction pass |
| ; CHECK-NEXT: Fast Register Allocator |
| ; CHECK-NEXT: Remove Redundant DEBUG_VALUE analysis |
| ; CHECK-NEXT: Fixup Statepoint Caller Saved |
| ; CHECK-NEXT: Lazy Machine Block Frequency Analysis |
| ; CHECK-NEXT: Machine Optimization Remark Emitter |
| ; CHECK-NEXT: Prologue/Epilogue Insertion & Frame Finalization |
| ; CHECK-NEXT: Post-RA pseudo instruction expansion pass |
| ; CHECK-NEXT: Insert KCFI indirect call checks |
| ; CHECK-NEXT: Analyze Machine Code For Garbage Collection |
| ; CHECK-NEXT: Insert fentry calls |
| ; CHECK-NEXT: Insert XRay ops |
| ; CHECK-NEXT: Implement the 'patchable-function' attribute |
| ; CHECK-NEXT: Branch relaxation pass |
| ; CHECK-NEXT: RISC-V Make Compressible |
| ; CHECK-NEXT: Contiguously Lay Out Funclets |
| ; CHECK-NEXT: StackMap Liveness Analysis |
| ; CHECK-NEXT: Live DEBUG_VALUE analysis |
| ; CHECK-NEXT: Machine Sanitizer Binary Metadata |
| ; CHECK-NEXT: Lazy Machine Block Frequency Analysis |
| ; CHECK-NEXT: Machine Optimization Remark Emitter |
| ; CHECK-NEXT: Stack Frame Layout Analysis |
| ; CHECK-NEXT: RISC-V pseudo instruction expansion pass |
| ; CHECK-NEXT: RISC-V atomic pseudo instruction expansion pass |
| ; CHECK-NEXT: Unpack machine instruction bundles |
| ; CHECK-NEXT: Lazy Machine Block Frequency Analysis |
| ; CHECK-NEXT: Machine Optimization Remark Emitter |
| ; CHECK-NEXT: RISC-V Assembly Printer |
| ; CHECK-NEXT: Free MachineFunction |