mirror of
https://github.com/NixOS/nix
synced 2025-06-27 21:01:16 +02:00
Merge pull request #12485 from NixOS/mergify/bp/2.26-maintenance/pr-10765
Add `SSHMaster::Connection::trySetBufferSize` (backport #10765)
This commit is contained in:
commit
bcbfdc1f28
4 changed files with 35 additions and 0 deletions
|
@ -70,6 +70,9 @@ ref<LegacySSHStore::Connection> LegacySSHStore::openConnection()
|
||||||
command.push_back(remoteStore.get());
|
command.push_back(remoteStore.get());
|
||||||
}
|
}
|
||||||
conn->sshConn = master.startCommand(std::move(command), std::list{extraSshArgs});
|
conn->sshConn = master.startCommand(std::move(command), std::list{extraSshArgs});
|
||||||
|
if (connPipeSize) {
|
||||||
|
conn->sshConn->trySetBufferSize(*connPipeSize);
|
||||||
|
}
|
||||||
conn->to = FdSink(conn->sshConn->in.get());
|
conn->to = FdSink(conn->sshConn->in.get());
|
||||||
conn->from = FdSource(conn->sshConn->out.get());
|
conn->from = FdSource(conn->sshConn->out.get());
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,11 @@ struct LegacySSHStoreConfig : virtual CommonSSHStoreConfig
|
||||||
*/
|
*/
|
||||||
Strings extraSshArgs = {};
|
Strings extraSshArgs = {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Exposed for hydra
|
||||||
|
*/
|
||||||
|
std::optional<size_t> connPipeSize;
|
||||||
|
|
||||||
const std::string name() override { return "SSH Store"; }
|
const std::string name() override { return "SSH Store"; }
|
||||||
|
|
||||||
static std::set<std::string> uriSchemes() { return {"ssh"}; }
|
static std::set<std::string> uriSchemes() { return {"ssh"}; }
|
||||||
|
|
|
@ -240,4 +240,19 @@ Path SSHMaster::startMaster()
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void SSHMaster::Connection::trySetBufferSize(size_t size)
|
||||||
|
{
|
||||||
|
#ifdef F_SETPIPE_SZ
|
||||||
|
/* This `fcntl` method of doing this takes a positive `int`. Check
|
||||||
|
and convert accordingly.
|
||||||
|
|
||||||
|
The function overall still takes `size_t` because this is more
|
||||||
|
portable for a platform-agnostic interface. */
|
||||||
|
assert(size <= INT_MAX);
|
||||||
|
int pipesize = size;
|
||||||
|
fcntl(in.get(), F_SETPIPE_SZ, pipesize);
|
||||||
|
fcntl(out.get(), F_SETPIPE_SZ, pipesize);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -54,6 +54,18 @@ public:
|
||||||
Pid sshPid;
|
Pid sshPid;
|
||||||
#endif
|
#endif
|
||||||
AutoCloseFD out, in;
|
AutoCloseFD out, in;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Try to set the buffer size in both directions to the
|
||||||
|
* designated amount, if possible. If not possible, does
|
||||||
|
* nothing.
|
||||||
|
*
|
||||||
|
* Current implementation is to use `fcntl` with `F_SETPIPE_SZ`,
|
||||||
|
* which is Linux-only. For this implementation, `size` must
|
||||||
|
* convertable to an `int`. In other words, it must be within
|
||||||
|
* `[0, INT_MAX]`.
|
||||||
|
*/
|
||||||
|
void trySetBufferSize(size_t size);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue