//===-- 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; static void test_add_simple() { uint32_t num_additions = 10 + 10 * gpu::get_thread_id() + 10 * gpu::get_block_id(); uint64_t cnt = 0; for (uint32_t i = 0; i < num_additions; ++i) { LIBC_NAMESPACE::rpc::Client::Port port = LIBC_NAMESPACE::rpc::client.open(); port.send_and_recv( [=](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) { reinterpret_cast(buffer->data)[0] = cnt; }, [&](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) { cnt = reinterpret_cast(buffer->data)[0]; }); port.close(); } ASSERT_TRUE(cnt == num_additions && "Incorrect sum"); } // Test to ensure that the RPC mechanism doesn't hang on divergence. static void test_noop(uint8_t data) { LIBC_NAMESPACE::rpc::Client::Port port = LIBC_NAMESPACE::rpc::client.open(); port.send([=](LIBC_NAMESPACE::rpc::Buffer *buffer, uint32_t) { buffer->data[0] = data; }); port.close(); } TEST_MAIN(int argc, char **argv, char **envp) { test_add_simple(); if (gpu::get_thread_id() % 2) test_noop(1); else test_noop(2); return 0; }