fs: nfs: Do not bind to a local port in TCP mode
Summary: - Since binding to a local port is not necessary in TCP mode, it should be done only in UDP mode Impact: - None Testing: - Tested with NFS server on Ubuntu 18.04 (x86_64) - Tested with spresense:rndis (defconfig will be updated later) Signed-off-by: Masayuki Ishikawa <Masayuki.Ishikawa@jp.sony.com>
This commit is contained in:
parent
2873f33bc4
commit
e1b14271c8
@ -241,28 +241,31 @@ static int rpcclnt_socket(FAR struct rpcclnt *rpc, in_port_t rport)
|
||||
goto bad;
|
||||
}
|
||||
|
||||
/* Some servers require that the client port be a reserved port
|
||||
* number. We always allocate a reserved port, as this prevents
|
||||
* filehandle disclosure through UDP port capture.
|
||||
*/
|
||||
|
||||
do
|
||||
if (rpc->rc_sotype == SOCK_DGRAM)
|
||||
{
|
||||
*lport = htons(--port);
|
||||
error = psock_bind(&rpc->rc_so, (FAR struct sockaddr *)&laddr,
|
||||
addrlen);
|
||||
if (error < 0)
|
||||
/* Some servers require that the client port be a reserved port
|
||||
* number. We always allocate a reserved port, as this prevents
|
||||
* filehandle disclosure through UDP port capture.
|
||||
*/
|
||||
|
||||
do
|
||||
{
|
||||
*lport = htons(--port);
|
||||
error = psock_bind(&rpc->rc_so, (FAR struct sockaddr *)&laddr,
|
||||
addrlen);
|
||||
if (error < 0)
|
||||
{
|
||||
ferr("ERROR: psock_bind failed: %d\n", error);
|
||||
}
|
||||
}
|
||||
while (error == -EADDRINUSE && port >= 512);
|
||||
|
||||
if (error)
|
||||
{
|
||||
ferr("ERROR: psock_bind failed: %d\n", error);
|
||||
goto bad;
|
||||
}
|
||||
}
|
||||
while (error == -EADDRINUSE && port >= 512);
|
||||
|
||||
if (error)
|
||||
{
|
||||
ferr("ERROR: psock_bind failed: %d\n", error);
|
||||
goto bad;
|
||||
}
|
||||
|
||||
/* Protocols that do not require connections could be optionally left
|
||||
* unconnected. That would allow servers to reply from a port other than
|
||||
|
Loading…
Reference in New Issue
Block a user