| # REQUIRES: asserts | 
 | # RUN: llc -mtriple=amdgcn -verify-machineinstrs -run-pass si-insert-waitcnts -debug-counter=si-insert-waitcnts-forcelgkm=0 -o - %s | FileCheck -check-prefixes=GCN,LGKM %s | 
 | # RUN: llc -mtriple=amdgcn -verify-machineinstrs -run-pass si-insert-waitcnts -debug-counter=si-insert-waitcnts-forceexp=0-1 -o - %s | FileCheck -check-prefixes=GCN,EXP %s | 
 | # RUN: llc -mtriple=amdgcn -verify-machineinstrs -run-pass si-insert-waitcnts -debug-counter=si-insert-waitcnts-forcevm=0-2 -o - %s | FileCheck -check-prefixes=GCN,VM %s | 
 | # RUN: llc -mtriple=amdgcn -verify-machineinstrs -run-pass si-insert-waitcnts -amdgpu-waitcnt-forcezero=1 -debug-counter=si-insert-waitcnts-forcevm=0-1 -o - %s | FileCheck -check-prefixes=GCN,ZERO %s | 
 |  | 
 | # check that the waitcnt pass options that force insertion of waitcnt instructions are working as expected | 
 |  | 
 | ... | 
 | # GCN-LABEL: name: waitcnt-debug | 
 | # LGKM: S_WAITCNT 127 | 
 | # LGKM-NEXT: S_NOP 0 | 
 | # LGKM-NEXT: S_NOP 0 | 
 |  | 
 | # EXP: S_WAITCNT 3855 | 
 | # EXP-NEXT: S_NOP 0 | 
 | # EXP-NEXT: S_WAITCNT 3855 | 
 | # EXP-NEXT: S_NOP 0 | 
 |  | 
 | # VM: S_WAITCNT 3952 | 
 | # VM-NEXT: S_NOP 0 | 
 | # VM-NEXT: S_WAITCNT 3952 | 
 | # VM-NEXT: S_NOP 0 | 
 | # VM-NEXT: S_WAITCNT 3952 | 
 | # VM-NEXT: S_NOP 0 | 
 |  | 
 | # ZERO: S_WAITCNT 0 | 
 | # ZERO-NEXT: S_NOP 0 | 
 | # ZERO-NEXT: S_WAITCNT 0 | 
 | # ZERO-NEXT: S_NOP 0 | 
 | # ZERO-NEXT: S_WAITCNT 0 | 
 | # ZERO-NEXT: S_NOP 0 | 
 |  | 
 | name:            waitcnt-debug | 
 | liveins: | 
 | machineFunctionInfo: | 
 |   isEntryFunction: true | 
 | body:             | | 
 |   bb.0: | 
 |     S_NOP 0 | 
 |     S_NOP 0 | 
 |     S_NOP 0 | 
 |     S_NOP 0 | 
 | ... |