| // Copyright 2016 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 <lib/zx/socket.h> |
| |
| #include <zircon/syscalls.h> |
| |
| namespace zx { |
| |
| zx_status_t socket::create(uint32_t flags, socket* endpoint0, socket* endpoint1) { |
| // Ensure aliasing of both out parameters to the same container |
| // has a well-defined result, and does not leak. |
| socket h0; |
| socket h1; |
| zx_status_t status = |
| zx_socket_create(flags, h0.reset_and_get_address(), h1.reset_and_get_address()); |
| endpoint0->reset(h0.release()); |
| endpoint1->reset(h1.release()); |
| return status; |
| } |
| |
| } // namespace zx |