2022-04-23 01:59:50 -07:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2018 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2018-07-03 06:28:46 -07:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2020-01-26 06:28:23 -08:00
|
|
|
#include <memory>
|
|
|
|
|
2018-07-03 06:28:46 -07:00
|
|
|
#include "common/common_types.h"
|
|
|
|
|
2020-03-31 12:10:44 -07:00
|
|
|
namespace Core::Memory {
|
2020-01-26 06:28:23 -08:00
|
|
|
class Memory;
|
|
|
|
}
|
|
|
|
|
2018-08-24 18:43:32 -07:00
|
|
|
namespace Core {
|
|
|
|
|
2018-07-03 06:28:46 -07:00
|
|
|
class ExclusiveMonitor {
|
|
|
|
public:
|
|
|
|
virtual ~ExclusiveMonitor();
|
|
|
|
|
2020-03-15 12:54:40 -07:00
|
|
|
virtual u8 ExclusiveRead8(std::size_t core_index, VAddr addr) = 0;
|
|
|
|
virtual u16 ExclusiveRead16(std::size_t core_index, VAddr addr) = 0;
|
|
|
|
virtual u32 ExclusiveRead32(std::size_t core_index, VAddr addr) = 0;
|
|
|
|
virtual u64 ExclusiveRead64(std::size_t core_index, VAddr addr) = 0;
|
|
|
|
virtual u128 ExclusiveRead128(std::size_t core_index, VAddr addr) = 0;
|
2022-02-27 11:40:05 -08:00
|
|
|
virtual void ClearExclusive(std::size_t core_index) = 0;
|
2018-07-03 06:28:46 -07:00
|
|
|
|
2018-09-15 06:21:06 -07:00
|
|
|
virtual bool ExclusiveWrite8(std::size_t core_index, VAddr vaddr, u8 value) = 0;
|
|
|
|
virtual bool ExclusiveWrite16(std::size_t core_index, VAddr vaddr, u16 value) = 0;
|
|
|
|
virtual bool ExclusiveWrite32(std::size_t core_index, VAddr vaddr, u32 value) = 0;
|
|
|
|
virtual bool ExclusiveWrite64(std::size_t core_index, VAddr vaddr, u64 value) = 0;
|
|
|
|
virtual bool ExclusiveWrite128(std::size_t core_index, VAddr vaddr, u128 value) = 0;
|
2018-07-03 06:28:46 -07:00
|
|
|
};
|
2018-08-24 18:43:32 -07:00
|
|
|
|
2020-01-26 12:14:18 -08:00
|
|
|
std::unique_ptr<Core::ExclusiveMonitor> MakeExclusiveMonitor(Memory::Memory& memory,
|
|
|
|
std::size_t num_cores);
|
2020-01-26 06:28:23 -08:00
|
|
|
|
2018-08-24 18:43:32 -07:00
|
|
|
} // namespace Core
|