mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-10 06:00:30 +00:00
aced110517
Summary: This was broken in r260694 which swapped the address and data operands for flat store instructions. The code in SIInsertWaits assumes that the data operand always comes before the address operand, so we need to add a special case for flat. Reviewers: arsenm Subscribers: arsenm, llvm-commits Differential Revision: http://reviews.llvm.org/D17366 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@261330 91177308-0d34-0410-b5e6-96231b3b80d8
17 lines
688 B
LLVM
17 lines
688 B
LLVM
; RUN: llc < %s -mtriple=amdgcn--amdhsa -mcpu=kaveri | FileCheck --check-prefix=GCN %s
|
|
; RUN: llc < %s -mtriple=amdgcn--amdhsa -mcpu=fiji | FileCheck --check-prefix=GCN %s
|
|
|
|
; If flat_store_dword and flat_load_dword use different registers for the data
|
|
; operand, this test is not broken. It just means it is no longer testing
|
|
; for the original bug.
|
|
|
|
; GCN: {{^}}test:
|
|
; GCN: flat_store_dword v[{{[0-9]+:[0-9]+}}], [[DATA:v[0-9]+]]
|
|
; GCN: s_waitcnt vmcnt(0) lgkmcnt(0)
|
|
; GCN: flat_load_dword [[DATA]], v[{{[0-9]+:[0-9]+}}]
|
|
define void @test(i32 addrspace(1)* %out, i32 %in) {
|
|
store volatile i32 0, i32 addrspace(1)* %out
|
|
%val = load volatile i32, i32 addrspace(1)* %out
|
|
ret void
|
|
}
|