// Copyright 2014 The Chromium 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 "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