summaryrefslogtreecommitdiff
path: root/src/common/cache_management.h
diff options
context:
space:
mode:
authorGravatar bunnei2022-11-18 13:18:36 -0800
committerGravatar GitHub2022-11-18 13:18:36 -0800
commit1fb33bd1e19fe0855072b08a91353a3b457fa85d (patch)
tree3687b2c5e394843e4554b0e0ca733d840aca8720 /src/common/cache_management.h
parentMerge pull request #9244 from liamwhite/lost-wakeup (diff)
parentkernel: implement FlushProcessDataCache (diff)
downloadyuzu-1fb33bd1e19fe0855072b08a91353a3b457fa85d.tar.gz
yuzu-1fb33bd1e19fe0855072b08a91353a3b457fa85d.tar.xz
yuzu-1fb33bd1e19fe0855072b08a91353a3b457fa85d.zip
Merge pull request #9234 from liamwhite/data-cash-money
kernel: implement data cache management operations
Diffstat (limited to 'src/common/cache_management.h')
-rw-r--r--src/common/cache_management.h27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/common/cache_management.h b/src/common/cache_management.h
new file mode 100644
index 000000000..e467b87e4
--- /dev/null
+++ b/src/common/cache_management.h
@@ -0,0 +1,27 @@
1// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
2// SPDX-License-Identifier: GPL-2.0-or-later
3
4#pragma once
5
6#include "stdlib.h"
7
8namespace Common {
9
10// Data cache instructions enabled at EL0 by SCTLR_EL1.UCI.
11// VA = virtual address
12// PoC = point of coherency
13// PoU = point of unification
14
15// dc cvau
16void DataCacheLineCleanByVAToPoU(void* start, size_t size);
17
18// dc civac
19void DataCacheLineCleanAndInvalidateByVAToPoC(void* start, size_t size);
20
21// dc cvac
22void DataCacheLineCleanByVAToPoC(void* start, size_t size);
23
24// dc zva
25void DataCacheZeroByVA(void* start, size_t size);
26
27} // namespace Common