mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-05 03:10:41 +00:00
36d29bc723
These extra flags are not required to properly order the atomic load/store instructions. SelectionDAGBuilder chains atomics as if they were volatile, and SelectionDAG::getAtomic() sets the isVolatile bit on the memory operands of all atomic operations. The volatile bit is enough to order atomic loads and stores during and after SelectionDAG. This means we set mayLoad on atomic_load, mayStore on atomic_store, and mayLoad+mayStore on the remaining atomic read-modify-write operations. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@162733 91177308-0d34-0410-b5e6-96231b3b80d8
23 lines
621 B
LLVM
23 lines
621 B
LLVM
; RUN: llc -march=hexagon -mcpu=hexagonv4 < %s | FileCheck %s
|
|
; Check that we generate new value store packet in V4
|
|
|
|
@i = global i32 0, align 4
|
|
@j = global i32 10, align 4
|
|
@k = global i32 100, align 4
|
|
|
|
define i32 @main() nounwind {
|
|
entry:
|
|
; CHECK: memw(r{{[0-9]+}} + #{{[0-9]+}}) = r{{[0-9]+}}.new
|
|
%number1 = alloca i32, align 4
|
|
%number2 = alloca i32, align 4
|
|
%number3 = alloca i32, align 4
|
|
%0 = load i32 * @i, align 4
|
|
store i32 %0, i32* %number1, align 4
|
|
%1 = load i32 * @j, align 4
|
|
store i32 %1, i32* %number2, align 4
|
|
%2 = load i32 * @k, align 4
|
|
store i32 %2, i32* %number3, align 4
|
|
ret i32 %0
|
|
}
|
|
|