0
Files
src/remoting/protocol/socket_util.cc
Joe Downing 353ba2c7cd Formatting remoting/protocol
Next CL in the chain which formats the files in //remoting with the new
clang-format rules.

Bug: NO_BUG
Change-Id: I8c7af1b39f9da1526a4569cc3d8d18279b220030
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4156531
Reviewed-by: Lambros Lambrou <lambroslambrou@chromium.org>
Commit-Queue: Joe Downing <joedow@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1091519}
2023-01-11 22:37:34 +00:00

42 lines
1.4 KiB
C++

// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "remoting/protocol/socket_util.h"
#include "net/base/net_errors.h"
namespace remoting {
SocketErrorAction GetSocketErrorAction(int error) {
switch (error) {
// UDP is connectionless, so we may receive ICMP unreachable or reset errors
// for previous sends to different addresses.
case net::ERR_ADDRESS_UNREACHABLE:
case net::ERR_CONNECTION_RESET:
return SOCKET_ERROR_ACTION_RETRY;
// Target address is invalid. The socket is still usable for different
// target addresses and the error can be ignored.
case net::ERR_ADDRESS_INVALID:
return SOCKET_ERROR_ACTION_IGNORE;
// May be returned when the packet is blocked by local firewall (see
// https://code.google.com/p/webrtc/issues/detail?id=1207). The firewall may
// still allow us to send to other addresses, so ignore the error for this
// particular send.
case net::ERR_ACCESS_DENIED:
return SOCKET_ERROR_ACTION_IGNORE;
// Indicates that the buffer in the network adapter is full, so drop this
// packet and assume the socket is still usable.
case net::ERR_OUT_OF_MEMORY:
return SOCKET_ERROR_ACTION_IGNORE;
default:
return SOCKET_ERROR_ACTION_FAIL;
}
}
} // namespace remoting