|  | // 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 |