mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-24 07:56:15 +00:00
kern: update set/way cache operations for new semantics
This commit is contained in:
parent
6e4664ee05
commit
44ccbc2a7b
1 changed files with 26 additions and 5 deletions
|
@ -283,6 +283,16 @@ namespace ams::kern::arch::arm64::cpu {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StoreDataCacheBySetWay(int level) {
|
||||||
|
PerformCacheOperationBySetWayImpl<false>(level, StoreDataCacheLineBySetWayImpl);
|
||||||
|
cpu::DataSynchronizationBarrier();
|
||||||
|
}
|
||||||
|
|
||||||
|
void FlushDataCacheBySetWay(int level) {
|
||||||
|
PerformCacheOperationBySetWayImpl<false>(level, FlushDataCacheLineBySetWayImpl);
|
||||||
|
cpu::DataSynchronizationBarrier();
|
||||||
|
}
|
||||||
|
|
||||||
void KCacheHelperInterruptHandler::ProcessOperation() {
|
void KCacheHelperInterruptHandler::ProcessOperation() {
|
||||||
switch (m_operation) {
|
switch (m_operation) {
|
||||||
case Operation::Idle:
|
case Operation::Idle:
|
||||||
|
@ -291,12 +301,10 @@ namespace ams::kern::arch::arm64::cpu {
|
||||||
InstructionMemoryBarrier();
|
InstructionMemoryBarrier();
|
||||||
break;
|
break;
|
||||||
case Operation::StoreDataCache:
|
case Operation::StoreDataCache:
|
||||||
PerformCacheOperationBySetWayLocal<false>(StoreDataCacheLineBySetWayImpl);
|
StoreDataCacheBySetWay(0);
|
||||||
DataSynchronizationBarrier();
|
|
||||||
break;
|
break;
|
||||||
case Operation::FlushDataCache:
|
case Operation::FlushDataCache:
|
||||||
PerformCacheOperationBySetWayLocal<false>(FlushDataCacheLineBySetWayImpl);
|
FlushDataCacheBySetWay(0);
|
||||||
DataSynchronizationBarrier();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -374,7 +382,20 @@ namespace ams::kern::arch::arm64::cpu {
|
||||||
}
|
}
|
||||||
|
|
||||||
void FlushEntireDataCache() {
|
void FlushEntireDataCache() {
|
||||||
return PerformCacheOperationBySetWayShared<false>(FlushDataCacheLineBySetWayImpl);
|
KScopedCoreMigrationDisable dm;
|
||||||
|
|
||||||
|
CacheLineIdRegisterAccessor clidr_el1;
|
||||||
|
const int levels_of_coherency = clidr_el1.GetLevelsOfCoherency();
|
||||||
|
|
||||||
|
/* Store cache from L2 up to the level of coherence (if there's an L3 cache or greater). */
|
||||||
|
for (int level = 2; level < levels_of_coherency; ++level) {
|
||||||
|
StoreDataCacheBySetWay(level - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Flush cache from the level of coherence down to L2. */
|
||||||
|
for (int level = levels_of_coherency; level > 1; --level) {
|
||||||
|
FlushDataCacheBySetWay(level - 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Result InvalidateDataCache(void *addr, size_t size) {
|
Result InvalidateDataCache(void *addr, size_t size) {
|
||||||
|
|
Loading…
Reference in a new issue