Files
clang-p2996/libc/test/integration/startup/gpu/rpc_interface_test.cpp
Joseph Huber 89614ceb40 [libc] Move RPC interface to libc/shared to export it (#117034)
Summary:
Previous patches have made the `rpc.h` header independent of the `libc`
internals. This allows us to include it directly rather than providing
an indirect C API. This patch only does the work to move the header. A
future patch will pull out the `rpc_server` interface and simply replace
it with a single function that handles the opcodes.
2024-11-22 15:32:25 -06:00

68 lines
2.2 KiB
C++

//===-- Loader test to check the RPC interface with the loader ------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "include/llvm-libc-types/test_rpc_opcodes_t.h"
#include "src/__support/GPU/utils.h"
#include "src/__support/RPC/rpc_client.h"
#include "test/IntegrationTest/test.h"
using namespace LIBC_NAMESPACE;
// Test to ensure that we can use aribtrary combinations of sends and recieves
// as long as they are mirrored.
static void test_interface(bool end_with_send) {
uint64_t cnt = 0;
LIBC_NAMESPACE::rpc::Client::Port port =
LIBC_NAMESPACE::rpc::client.open<RPC_TEST_INTERFACE>();
port.send([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
buffer->data[0] = end_with_send;
});
port.send([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
buffer->data[0] = cnt = cnt + 1;
});
port.recv([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
cnt = buffer->data[0];
});
port.send([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
buffer->data[0] = cnt = cnt + 1;
});
port.recv([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
cnt = buffer->data[0];
});
port.send([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
buffer->data[0] = cnt = cnt + 1;
});
port.send([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
buffer->data[0] = cnt = cnt + 1;
});
port.recv([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
cnt = buffer->data[0];
});
port.recv([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
cnt = buffer->data[0];
});
if (end_with_send)
port.send([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
buffer->data[0] = cnt = cnt + 1;
});
else
port.recv([&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) {
cnt = buffer->data[0];
});
port.close();
ASSERT_TRUE(cnt == 9 && "Invalid number of increments");
}
TEST_MAIN(int argc, char **argv, char **envp) {
test_interface(true);
test_interface(false);
return 0;
}