blob: c8952458d24322e7b857392267f4cb9a92641b73 [file] [log] [blame]
// Copyright 2019 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <gtest/gtest.h>
#include "tools/fidlcat/interception_tests/interception_workflow_test.h"
namespace fidlcat {
// zx_guest_create tests.
std::unique_ptr<SystemCallTest> ZxGuestCreate(int64_t result, std::string_view result_name,
zx_handle_t resource, uint32_t options,
zx_handle_t* guest_handle, zx_handle_t* vmar_handle) {
auto value = std::make_unique<SystemCallTest>("zx_guest_create", result, result_name);
value->AddInput(resource);
value->AddInput(options);
value->AddInput(reinterpret_cast<uint64_t>(guest_handle));
value->AddInput(reinterpret_cast<uint64_t>(vmar_handle));
return value;
}
#define GUEST_CREATE_DISPLAY_TEST_CONTENT(result, expected) \
zx_handle_t guest_handle = kHandleOut; \
zx_handle_t vmar_handle = kHandleOut2; \
PerformDisplayTest("$plt(zx_guest_create)", \
ZxGuestCreate(result, #result, kHandle, 0, &guest_handle, &vmar_handle), \
expected)
#define GUEST_CREATE_DISPLAY_TEST(name, errno, expected) \
TEST_F(InterceptionWorkflowTestX64, name) { \
GUEST_CREATE_DISPLAY_TEST_CONTENT(errno, expected); \
} \
TEST_F(InterceptionWorkflowTestArm, name) { GUEST_CREATE_DISPLAY_TEST_CONTENT(errno, expected); }
GUEST_CREATE_DISPLAY_TEST(ZxGuestCreate, ZX_OK,
"\n"
"\x1B[32m0.000000\x1B[0m "
"test_3141 \x1B[31m3141\x1B[0m:\x1B[31m8764\x1B[0m "
"zx_guest_create("
"resource: \x1B[32mhandle\x1B[0m = \x1B[31mcefa1db0\x1B[0m, "
"options: \x1B[32muint32\x1B[0m = \x1B[34m0\x1B[0m)\n"
"\x1B[32m0.000000\x1B[0m "
" -> \x1B[32mZX_OK\x1B[0m ("
"guest_handle: \x1B[32mhandle\x1B[0m = \x1B[31mbde90caf\x1B[0m, "
"vmar_handle: \x1B[32mhandle\x1B[0m = \x1B[31mbde90222\x1B[0m)\n")
// zx_guest_set_trap tests.
std::unique_ptr<SystemCallTest> ZxGuestSetTrap(int64_t result, std::string_view result_name,
zx_handle_t handle, uint32_t kind, zx_vaddr_t addr,
size_t size, zx_handle_t port_handle, uint64_t key) {
auto value = std::make_unique<SystemCallTest>("zx_guest_set_trap", result, result_name);
value->AddInput(handle);
value->AddInput(kind);
value->AddInput(addr);
value->AddInput(size);
value->AddInput(port_handle);
value->AddInput(key);
return value;
}
#define GUEST_SET_TRAP_DISPLAY_TEST_CONTENT(result, expected) \
PerformDisplayTest( \
"$plt(zx_guest_set_trap)", \
ZxGuestSetTrap(result, #result, kHandle, ZX_GUEST_TRAP_IO, 0x1234, 16, kHandle2, kKey), \
expected)
#define GUEST_SET_TRAP_DISPLAY_TEST(name, errno, expected) \
TEST_F(InterceptionWorkflowTestX64, name) { \
GUEST_SET_TRAP_DISPLAY_TEST_CONTENT(errno, expected); \
} \
TEST_F(InterceptionWorkflowTestArm, name) { \
GUEST_SET_TRAP_DISPLAY_TEST_CONTENT(errno, expected); \
}
GUEST_SET_TRAP_DISPLAY_TEST(ZxGuestSetTrap, ZX_OK,
"\n"
"\x1B[32m0.000000\x1B[0m "
"test_3141 \x1B[31m3141\x1B[0m:\x1B[31m8764\x1B[0m "
"zx_guest_set_trap("
"handle: \x1B[32mhandle\x1B[0m = \x1B[31mcefa1db0\x1B[0m, "
"kind: \x1B[32mzx.guest_trap\x1B[0m = \x1B[31mZX_GUEST_TRAP_IO\x1B[0m, "
"addr: \x1B[32mzx.vaddr\x1B[0m = \x1B[34m0000000000001234\x1B[0m, "
"size: \x1B[32msize\x1B[0m = \x1B[34m16\x1B[0m, "
"port_handle: \x1B[32mhandle\x1B[0m = \x1B[31mcefa1222\x1B[0m, "
"key: \x1B[32muint64\x1B[0m = \x1B[34m1234\x1B[0m)\n"
"\x1B[32m0.000000\x1B[0m "
" -> \x1B[32mZX_OK\x1B[0m\n")
} // namespace fidlcat