#include "ipc/port_server.h" #include namespace mmth { glcr::ErrorOr PortServer::Create() { z_cap_t port; RET_ERR(ZPortCreate(&port)); return PortServer(port); } PortServer PortServer::AdoptCap(z_cap_t cap) { return PortServer(cap); } PortServer::PortServer(z_cap_t port_cap) : port_cap_(port_cap) {} glcr::ErrorOr PortServer::CreateClient() { z_cap_t new_port; RET_ERR(ZCapDuplicate(port_cap_, ~(kZionPerm_Read), &new_port)); return PortClient::AdoptPort(new_port); } glcr::ErrorCode PortServer::RecvCap(uint64_t *num_bytes, char *msg, uint64_t *cap) { uint64_t caps = 1; RET_ERR(ZPortRecv(port_cap_, num_bytes, reinterpret_cast(msg), &caps, cap)); if (caps != 1) { return glcr::FAILED_PRECONDITION; } return glcr::OK; } glcr::ErrorCode PortServer::PollForIntCap(uint64_t *msg, uint64_t *cap) { uint64_t bytes = sizeof(uint64_t); uint64_t caps = 1; RET_ERR(ZPortPoll(port_cap_, &bytes, reinterpret_cast(msg), &caps, cap)); if (bytes != sizeof(uint64_t)) { return glcr::FAILED_PRECONDITION; } if (caps != 1) { return glcr::FAILED_PRECONDITION; } return glcr::OK; } glcr::ErrorOr PortServer::RecvChar() { uint64_t bytes = 1; uint64_t caps = 0; char byte; RET_ERR(ZPortRecv(port_cap_, &bytes, &byte, &caps, nullptr)); return byte; } } // namespace mmth