forked from OSchip/llvm-project
[AMDGPU] Refactor shouldExpandAtomicRMWInIR(). NFC.
This is logic simplification for better readability. Differential Revision: https://reviews.llvm.org/D102371
This commit is contained in:
parent
b7911e80d6
commit
bd00106d1e
|
@ -12112,7 +12112,6 @@ SITargetLowering::shouldExpandAtomicRMWInIR(AtomicRMWInst *RMW) const {
|
||||||
if (!Ty->isFloatTy() && (!Subtarget->hasGFX90AInsts() || !Ty->isDoubleTy()))
|
if (!Ty->isFloatTy() && (!Subtarget->hasGFX90AInsts() || !Ty->isDoubleTy()))
|
||||||
return AtomicExpansionKind::CmpXChg;
|
return AtomicExpansionKind::CmpXChg;
|
||||||
|
|
||||||
// TODO: Do have these for flat. Older targets also had them for buffers.
|
|
||||||
unsigned AS = RMW->getPointerAddressSpace();
|
unsigned AS = RMW->getPointerAddressSpace();
|
||||||
|
|
||||||
if ((AS == AMDGPUAS::GLOBAL_ADDRESS || AS == AMDGPUAS::FLAT_ADDRESS) &&
|
if ((AS == AMDGPUAS::GLOBAL_ADDRESS || AS == AMDGPUAS::FLAT_ADDRESS) &&
|
||||||
|
@ -12128,20 +12127,22 @@ SITargetLowering::shouldExpandAtomicRMWInIR(AtomicRMWInst *RMW) const {
|
||||||
return AtomicExpansionKind::CmpXChg;
|
return AtomicExpansionKind::CmpXChg;
|
||||||
|
|
||||||
if (Subtarget->hasGFX90AInsts()) {
|
if (Subtarget->hasGFX90AInsts()) {
|
||||||
|
if (Ty->isFloatTy() && AS == AMDGPUAS::FLAT_ADDRESS)
|
||||||
|
return AtomicExpansionKind::CmpXChg;
|
||||||
|
|
||||||
auto SSID = RMW->getSyncScopeID();
|
auto SSID = RMW->getSyncScopeID();
|
||||||
if (SSID == SyncScope::System ||
|
if (SSID == SyncScope::System ||
|
||||||
SSID == RMW->getContext().getOrInsertSyncScopeID("one-as"))
|
SSID == RMW->getContext().getOrInsertSyncScopeID("one-as"))
|
||||||
return AtomicExpansionKind::CmpXChg;
|
return AtomicExpansionKind::CmpXChg;
|
||||||
|
|
||||||
return (Ty->isFloatTy() && AS == AMDGPUAS::FLAT_ADDRESS) ?
|
return AtomicExpansionKind::None;
|
||||||
AtomicExpansionKind::CmpXChg : AtomicExpansionKind::None;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Subtarget->hasGFX90AInsts() && AS != AMDGPUAS::GLOBAL_ADDRESS)
|
if (AS == AMDGPUAS::FLAT_ADDRESS)
|
||||||
return AtomicExpansionKind::CmpXChg;
|
return AtomicExpansionKind::CmpXChg;
|
||||||
|
|
||||||
return RMW->use_empty() ? AtomicExpansionKind::None :
|
return RMW->use_empty() ? AtomicExpansionKind::None
|
||||||
AtomicExpansionKind::CmpXChg;
|
: AtomicExpansionKind::CmpXChg;
|
||||||
}
|
}
|
||||||
|
|
||||||
// DS FP atomics do repect the denormal mode, but the rounding mode is fixed
|
// DS FP atomics do repect the denormal mode, but the rounding mode is fixed
|
||||||
|
|
Loading…
Reference in New Issue