aboutsummaryrefslogtreecommitdiff
path: root/externals/dynarmic/tests/A64/misaligned_page_table.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'externals/dynarmic/tests/A64/misaligned_page_table.cpp')
-rw-r--r--externals/dynarmic/tests/A64/misaligned_page_table.cpp29
1 files changed, 29 insertions, 0 deletions
diff --git a/externals/dynarmic/tests/A64/misaligned_page_table.cpp b/externals/dynarmic/tests/A64/misaligned_page_table.cpp
new file mode 100644
index 0000000000..f54aa58641
--- /dev/null
+++ b/externals/dynarmic/tests/A64/misaligned_page_table.cpp
@@ -0,0 +1,29 @@
+/* This file is part of the dynarmic project.
+ * Copyright (c) 2018 MerryMage
+ * SPDX-License-Identifier: 0BSD
+ */
+
+#include <catch2/catch_test_macros.hpp>
+
+#include "./testenv.h"
+#include "dynarmic/interface/A64/a64.h"
+
+TEST_CASE("misaligned load/store do not use page_table when detect_misaligned_access_via_page_table is set", "[a64]") {
+ A64TestEnv env;
+ Dynarmic::A64::UserConfig conf{&env};
+ conf.page_table = nullptr;
+ conf.detect_misaligned_access_via_page_table = 128;
+ conf.only_detect_misalignment_via_page_table_on_page_boundary = true;
+ Dynarmic::A64::Jit jit{conf};
+
+ env.code_mem.emplace_back(0x3c800400); // STR Q0, [X0], #0
+ env.code_mem.emplace_back(0x14000000); // B .
+
+ jit.SetPC(0);
+ jit.SetRegister(0, 0x000000000b0afff8);
+
+ env.ticks_left = 2;
+ jit.Run();
+
+ // If we don't crash we're fine.
+}