; RUN: llc -march=hexagon < %s | FileCheck %s ; CHECK: .LBB0_1: ; CHECK: [[R1:r[0-9]+]] = memw_locked(r0) ; CHECK-DAG: [[R2:r[0-9]+]] = and([[R1]], ; CHECK-DAG: [[R3:r[0-9]+]] = add([[R1]], ; CHECK: [[R2]] |= and([[R3]], ; CHECK: memw_locked(r0,[[P0:p[0-3]]]) = [[R2]] ; CHECK: if (![[P0]]) jump:nt .LBB0_1 %struct.a = type { i8 } define void @b() #0 { %d = alloca %struct.a %c = getelementptr %struct.a, %struct.a* %d, i32 0, i32 0 atomicrmw add i8* %c, i8 2 monotonic ret void } attributes #0 = { "target-cpu"="hexagonv66" }