mirror of
https://git.eden-emu.dev/eden-emu/eden
synced 2026-05-25 17:37:07 +02:00
fix
This commit is contained in:
parent
8b62cd8aca
commit
7cceae444a
6 changed files with 37 additions and 42 deletions
|
|
@ -36,19 +36,19 @@ inline size_t ToFastLookupIndexArm(u32 instruction) noexcept {
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
constexpr ArmDecodeTable<V> GetArmDecodeTable() noexcept {
|
static ArmDecodeTable<V> GetArmDecodeTable() noexcept {
|
||||||
constexpr std::vector<ArmMatcher<V>> list = {
|
ArmDecodeTable<V> table{};
|
||||||
|
for (size_t i = 0; i < table.size(); ++i) {
|
||||||
|
// PLEASE HEAP ELLIDE
|
||||||
|
for (auto const e : std::vector<ArmMatcher<V>>{
|
||||||
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(ArmMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)),
|
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(ArmMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)),
|
||||||
#include "./arm.inc"
|
#include "./arm.inc"
|
||||||
#undef INST
|
#undef INST
|
||||||
};
|
}) {
|
||||||
ArmDecodeTable<V> table{};
|
auto const expect = detail::ToFastLookupIndexArm(e.GetExpected());
|
||||||
for (size_t i = 0; i < table.size(); ++i) {
|
auto const mask = detail::ToFastLookupIndexArm(e.GetMask());
|
||||||
for (auto matcher : list) {
|
|
||||||
const auto expect = detail::ToFastLookupIndexArm(matcher.GetExpected());
|
|
||||||
const auto mask = detail::ToFastLookupIndexArm(matcher.GetMask());
|
|
||||||
if ((i & mask) == expect) {
|
if ((i & mask) == expect) {
|
||||||
table[i].push_back(matcher);
|
table[i].push_back(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -56,7 +56,7 @@ constexpr ArmDecodeTable<V> GetArmDecodeTable() noexcept {
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::reference_wrapper<const ArmMatcher<V>>> DecodeArm(u32 instruction) noexcept {
|
static std::optional<std::reference_wrapper<const ArmMatcher<V>>> DecodeArm(u32 instruction) noexcept {
|
||||||
alignas(64) static const auto table = GetArmDecodeTable<V>();
|
alignas(64) static const auto table = GetArmDecodeTable<V>();
|
||||||
const auto matches_instruction = [instruction](const auto& matcher) {
|
const auto matches_instruction = [instruction](const auto& matcher) {
|
||||||
return matcher.Matches(instruction);
|
return matcher.Matches(instruction);
|
||||||
|
|
@ -67,7 +67,7 @@ std::optional<std::reference_wrapper<const ArmMatcher<V>>> DecodeArm(u32 instruc
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::string_view> GetNameARM(u32 inst) noexcept {
|
static std::optional<std::string_view> GetNameARM(u32 inst) noexcept {
|
||||||
std::vector<std::pair<std::string_view, ArmMatcher<V>>> list = {
|
std::vector<std::pair<std::string_view, ArmMatcher<V>>> list = {
|
||||||
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(ArmMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(ArmMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
||||||
#include "./arm.inc"
|
#include "./arm.inc"
|
||||||
|
|
|
||||||
|
|
@ -27,17 +27,12 @@ template<typename Visitor>
|
||||||
using ASIMDMatcher = Decoder::Matcher<Visitor, u32>;
|
using ASIMDMatcher = Decoder::Matcher<Visitor, u32>;
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
constexpr std::vector<ASIMDMatcher<V>> GetASIMDDecodeTable() noexcept {
|
static std::optional<std::reference_wrapper<const ASIMDMatcher<V>>> DecodeASIMD(u32 instruction) noexcept {
|
||||||
return std::vector<ASIMDMatcher<V>>{
|
alignas(64) static const auto table = std::array{
|
||||||
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(ASIMDMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)),
|
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(ASIMDMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)),
|
||||||
#include "./asimd.inc"
|
#include "./asimd.inc"
|
||||||
#undef INST
|
#undef INST
|
||||||
};
|
};
|
||||||
}
|
|
||||||
|
|
||||||
template<typename V>
|
|
||||||
std::optional<std::reference_wrapper<const ASIMDMatcher<V>>> DecodeASIMD(u32 instruction) noexcept {
|
|
||||||
alignas(64) static const auto table = GetASIMDDecodeTable<V>();
|
|
||||||
auto iter = std::find_if(table.begin(), table.end(), [instruction](const auto& matcher) {
|
auto iter = std::find_if(table.begin(), table.end(), [instruction](const auto& matcher) {
|
||||||
return matcher.Matches(instruction);
|
return matcher.Matches(instruction);
|
||||||
});
|
});
|
||||||
|
|
@ -45,7 +40,7 @@ std::optional<std::reference_wrapper<const ASIMDMatcher<V>>> DecodeASIMD(u32 ins
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::string_view> GetNameASIMD(u32 inst) noexcept {
|
static std::optional<std::string_view> GetNameASIMD(u32 inst) noexcept {
|
||||||
std::vector<std::pair<std::string_view, ASIMDMatcher<V>>> list = {
|
std::vector<std::pair<std::string_view, ASIMDMatcher<V>>> list = {
|
||||||
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(ASIMDMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(ASIMDMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
||||||
#include "./asimd.inc"
|
#include "./asimd.inc"
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project
|
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
|
||||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
/* This file is part of the dynarmic project.
|
/* This file is part of the dynarmic project.
|
||||||
|
|
@ -24,8 +24,8 @@ template<typename Visitor>
|
||||||
using Thumb16Matcher = Decoder::Matcher<Visitor, u16>;
|
using Thumb16Matcher = Decoder::Matcher<Visitor, u16>;
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::reference_wrapper<const Thumb16Matcher<V>>> DecodeThumb16(u16 instruction) {
|
static std::optional<std::reference_wrapper<const Thumb16Matcher<V>>> DecodeThumb16(u16 instruction) {
|
||||||
alignas(64) static const std::vector<Thumb16Matcher<V>> table = {
|
alignas(64) static const auto table = std::array{
|
||||||
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(Thumb16Matcher, fn, name, Decoder::detail::StringToArray<16>(bitstring)),
|
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(Thumb16Matcher, fn, name, Decoder::detail::StringToArray<16>(bitstring)),
|
||||||
#include "./thumb16.inc"
|
#include "./thumb16.inc"
|
||||||
#undef INST
|
#undef INST
|
||||||
|
|
@ -37,7 +37,7 @@ std::optional<std::reference_wrapper<const Thumb16Matcher<V>>> DecodeThumb16(u16
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::string_view> GetNameThumb16(u32 inst) noexcept {
|
static std::optional<std::string_view> GetNameThumb16(u32 inst) noexcept {
|
||||||
std::vector<std::pair<std::string_view, Thumb16Matcher<V>>> list = {
|
std::vector<std::pair<std::string_view, Thumb16Matcher<V>>> list = {
|
||||||
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(Thumb16Matcher, fn, name, Decoder::detail::StringToArray<16>(bitstring)) },
|
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(Thumb16Matcher, fn, name, Decoder::detail::StringToArray<16>(bitstring)) },
|
||||||
#include "./thumb16.inc"
|
#include "./thumb16.inc"
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project
|
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
|
||||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
/* This file is part of the dynarmic project.
|
/* This file is part of the dynarmic project.
|
||||||
|
|
@ -23,8 +23,8 @@ template<typename Visitor>
|
||||||
using Thumb32Matcher = Decoder::Matcher<Visitor, u32>;
|
using Thumb32Matcher = Decoder::Matcher<Visitor, u32>;
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::reference_wrapper<const Thumb32Matcher<V>>> DecodeThumb32(u32 instruction) {
|
static std::optional<std::reference_wrapper<const Thumb32Matcher<V>>> DecodeThumb32(u32 instruction) {
|
||||||
alignas(64) static const std::vector<Thumb32Matcher<V>> table = {
|
alignas(64) static const auto table = std::array{
|
||||||
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(Thumb32Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)),
|
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(Thumb32Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)),
|
||||||
#include "./thumb32.inc"
|
#include "./thumb32.inc"
|
||||||
#undef INST
|
#undef INST
|
||||||
|
|
@ -36,7 +36,7 @@ std::optional<std::reference_wrapper<const Thumb32Matcher<V>>> DecodeThumb32(u32
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::string_view> GetNameThumb32(u32 inst) noexcept {
|
static std::optional<std::string_view> GetNameThumb32(u32 inst) noexcept {
|
||||||
std::vector<std::pair<std::string_view, Thumb32Matcher<V>>> list = {
|
std::vector<std::pair<std::string_view, Thumb32Matcher<V>>> list = {
|
||||||
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(Thumb32Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(Thumb32Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
||||||
#include "./thumb32.inc"
|
#include "./thumb32.inc"
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project
|
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
|
||||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
/* This file is part of the dynarmic project.
|
/* This file is part of the dynarmic project.
|
||||||
|
|
@ -24,7 +24,7 @@ template<typename Visitor>
|
||||||
using VFPMatcher = Decoder::Matcher<Visitor, u32>;
|
using VFPMatcher = Decoder::Matcher<Visitor, u32>;
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::reference_wrapper<const VFPMatcher<V>>> DecodeVFP(u32 instruction) {
|
static std::optional<std::reference_wrapper<const VFPMatcher<V>>> DecodeVFP(u32 instruction) {
|
||||||
using Table = std::vector<VFPMatcher<V>>;
|
using Table = std::vector<VFPMatcher<V>>;
|
||||||
alignas(64) static const struct Tables {
|
alignas(64) static const struct Tables {
|
||||||
Table unconditional;
|
Table unconditional;
|
||||||
|
|
@ -52,7 +52,7 @@ std::optional<std::reference_wrapper<const VFPMatcher<V>>> DecodeVFP(u32 instruc
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::string_view> GetNameVFP(u32 inst) noexcept {
|
static std::optional<std::string_view> GetNameVFP(u32 inst) noexcept {
|
||||||
std::vector<std::pair<std::string_view, VFPMatcher<V>>> list = {
|
std::vector<std::pair<std::string_view, VFPMatcher<V>>> list = {
|
||||||
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(VFPMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(VFPMatcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
||||||
#include "./vfp.inc"
|
#include "./vfp.inc"
|
||||||
|
|
|
||||||
|
|
@ -36,19 +36,19 @@ inline size_t ToFastLookupIndex(u32 instruction) {
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
constexpr DecodeTable<V> GetDecodeTable() {
|
inline DecodeTable<V> GetDecodeTable() {
|
||||||
constexpr std::vector<Matcher<V>> list = {
|
|
||||||
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
|
||||||
#include "./a64.inc"
|
|
||||||
#undef INST
|
|
||||||
};
|
|
||||||
DecodeTable<V> table{};
|
DecodeTable<V> table{};
|
||||||
for (size_t i = 0; i < table.size(); ++i) {
|
for (size_t i = 0; i < table.size(); ++i) {
|
||||||
for (auto const& e : list) {
|
// PLEASE HEAP ELLIDE
|
||||||
const auto expect = detail::ToFastLookupIndex(e.second.GetExpected());
|
for (auto const e : std::vector<Matcher<V>>{
|
||||||
const auto mask = detail::ToFastLookupIndex(e.second.GetMask());
|
#define INST(fn, name, bitstring) DYNARMIC_DECODER_GET_MATCHER(Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)),
|
||||||
|
#include "./a64.inc"
|
||||||
|
#undef INST
|
||||||
|
}) {
|
||||||
|
const auto expect = detail::ToFastLookupIndex(e.GetExpected());
|
||||||
|
const auto mask = detail::ToFastLookupIndex(e.GetMask());
|
||||||
if ((i & mask) == expect)
|
if ((i & mask) == expect)
|
||||||
table[i].push_back(e.second);
|
table[i].push_back(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return table;
|
return table;
|
||||||
|
|
@ -56,7 +56,7 @@ constexpr DecodeTable<V> GetDecodeTable() {
|
||||||
|
|
||||||
/// In practice it must always suceed, otherwise something else unrelated would have gone awry
|
/// In practice it must always suceed, otherwise something else unrelated would have gone awry
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::reference_wrapper<const Matcher<V>>> Decode(u32 instruction) {
|
inline std::optional<std::reference_wrapper<const Matcher<V>>> Decode(u32 instruction) {
|
||||||
alignas(64) static const auto table = GetDecodeTable<V>();
|
alignas(64) static const auto table = GetDecodeTable<V>();
|
||||||
const auto& subtable = table[detail::ToFastLookupIndex(instruction)];
|
const auto& subtable = table[detail::ToFastLookupIndex(instruction)];
|
||||||
auto iter = std::find_if(subtable.begin(), subtable.end(), [instruction](const auto& matcher) {
|
auto iter = std::find_if(subtable.begin(), subtable.end(), [instruction](const auto& matcher) {
|
||||||
|
|
@ -68,7 +68,7 @@ std::optional<std::reference_wrapper<const Matcher<V>>> Decode(u32 instruction)
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename V>
|
template<typename V>
|
||||||
std::optional<std::string_view> GetName(u32 inst) noexcept {
|
inline std::optional<std::string_view> GetName(u32 inst) noexcept {
|
||||||
std::vector<std::pair<std::string_view, Matcher<V>>> list = {
|
std::vector<std::pair<std::string_view, Matcher<V>>> list = {
|
||||||
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
#define INST(fn, name, bitstring) { name, DYNARMIC_DECODER_GET_MATCHER(Matcher, fn, name, Decoder::detail::StringToArray<32>(bitstring)) },
|
||||||
#include "./a64.inc"
|
#include "./a64.inc"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue