pineapple-src/externals/dynarmic/tests/A64/misaligned_page_table.cpp

30 lines
845 B
C++
Raw Normal View History

2020-12-28 16:15:37 +01:00
/* This file is part of the dynarmic project.
* Copyright (c) 2018 MerryMage
* SPDX-License-Identifier: 0BSD
*/
2021-08-16 13:42:12 +02:00
#include <catch2/catch.hpp>
2020-12-28 16:15:37 +01:00
2021-05-30 08:36:49 +02:00
#include "./testenv.h"
#include "dynarmic/interface/A64/a64.h"
2020-12-28 16:15:37 +01:00
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};
2021-05-30 08:36:49 +02:00
env.code_mem.emplace_back(0x3c800400); // STR Q0, [X0], #0
env.code_mem.emplace_back(0x14000000); // B .
2020-12-28 16:15:37 +01:00
jit.SetPC(0);
jit.SetRegister(0, 0x000000000b0afff8);
env.ticks_left = 2;
jit.Run();
// If we don't crash we're fine.
}