diff options
| author | 2022-11-18 13:18:36 -0800 | |
|---|---|---|
| committer | 2022-11-18 13:18:36 -0800 | |
| commit | 1fb33bd1e19fe0855072b08a91353a3b457fa85d (patch) | |
| tree | 3687b2c5e394843e4554b0e0ca733d840aca8720 /src/common/cache_management.h | |
| parent | Merge pull request #9244 from liamwhite/lost-wakeup (diff) | |
| parent | kernel: implement FlushProcessDataCache (diff) | |
| download | yuzu-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.h | 27 |
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 | |||
| 8 | namespace 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 | ||
| 16 | void DataCacheLineCleanByVAToPoU(void* start, size_t size); | ||
| 17 | |||
| 18 | // dc civac | ||
| 19 | void DataCacheLineCleanAndInvalidateByVAToPoC(void* start, size_t size); | ||
| 20 | |||
| 21 | // dc cvac | ||
| 22 | void DataCacheLineCleanByVAToPoC(void* start, size_t size); | ||
| 23 | |||
| 24 | // dc zva | ||
| 25 | void DataCacheZeroByVA(void* start, size_t size); | ||
| 26 | |||
| 27 | } // namespace Common | ||