Unverified Commit 5822b19c authored by Kenton Varda's avatar Kenton Varda Committed by GitHub

Merge pull request #604 from capnproto/fix-connect

Fix multiple problems with connect() on non-glibc-Linux:
parents 3b834806 bd05ffe8
...@@ -1084,6 +1084,10 @@ public: ...@@ -1084,6 +1084,10 @@ public:
} }
Promise<Own<AsyncIoStream>> wrapConnectingSocketFd( Promise<Own<AsyncIoStream>> wrapConnectingSocketFd(
int fd, const struct sockaddr* addr, uint addrlen, uint flags = 0) override { int fd, const struct sockaddr* addr, uint addrlen, uint flags = 0) override {
// It's important that we construct the AsyncStreamFd first, so that `flags` are honored,
// especially setting nonblocking mode and taking ownership.
auto result = heap<AsyncStreamFd>(eventPort, fd, flags);
// Unfortunately connect() doesn't fit the mold of KJ_NONBLOCKING_SYSCALL, since it indicates // Unfortunately connect() doesn't fit the mold of KJ_NONBLOCKING_SYSCALL, since it indicates
// non-blocking using EINPROGRESS. // non-blocking using EINPROGRESS.
for (;;) { for (;;) {
...@@ -1102,8 +1106,6 @@ public: ...@@ -1102,8 +1106,6 @@ public:
} }
} }
auto result = heap<AsyncStreamFd>(eventPort, fd, flags);
auto connected = result->waitConnected(); auto connected = result->waitConnected();
return connected.then(kj::mvCapture(result, [fd](Own<AsyncIoStream>&& stream) { return connected.then(kj::mvCapture(result, [fd](Own<AsyncIoStream>&& stream) {
int err; int err;
...@@ -1223,12 +1225,11 @@ private: ...@@ -1223,12 +1225,11 @@ private:
ArrayPtr<SocketAddress> addrs) { ArrayPtr<SocketAddress> addrs) {
KJ_ASSERT(addrs.size() > 0); KJ_ASSERT(addrs.size() > 0);
int fd = addrs[0].socket(SOCK_STREAM);
return kj::evalNow([&]() -> Promise<Own<AsyncIoStream>> { return kj::evalNow([&]() -> Promise<Own<AsyncIoStream>> {
if (!addrs[0].allowedBy(filter)) { if (!addrs[0].allowedBy(filter)) {
return KJ_EXCEPTION(FAILED, "connect() blocked by restrictPeers()"); return KJ_EXCEPTION(FAILED, "connect() blocked by restrictPeers()");
} else { } else {
int fd = addrs[0].socket(SOCK_STREAM);
return lowLevel.wrapConnectingSocketFd( return lowLevel.wrapConnectingSocketFd(
fd, addrs[0].getRaw(), addrs[0].getRawSize(), NEW_FD_FLAGS); fd, addrs[0].getRaw(), addrs[0].getRawSize(), NEW_FD_FLAGS);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment