diff options
| author | 2015-10-29 08:02:31 +0000 | |
|---|---|---|
| committer | 2015-10-29 08:02:31 +0000 | |
| commit | e4aacaeec950691700d717efa894a7b51bc87fe2 (patch) | |
| tree | 1fd9d19ace551ddf4867b5cc9ff372bffbdb1e99 | |
| parent | 4636770f0df6e91cd7fbdf01b958fbdda688db7a (diff) | |
| parent | a2cc04736d0f9b9621c87ce8d244fd8fd909df7d (diff) | |
Merge "Don\'t crash if a DHCP server doesn\'t send the server ID option." into mnc-dr-dev
am: a2cc04736d
* commit 'a2cc04736d0f9b9621c87ce8d244fd8fd909df7d':
  Don't crash if a DHCP server doesn't send the server ID option.
| -rw-r--r-- | services/net/java/android/net/dhcp/DhcpClient.java | 14 | 
1 files changed, 10 insertions, 4 deletions
| diff --git a/services/net/java/android/net/dhcp/DhcpClient.java b/services/net/java/android/net/dhcp/DhcpClient.java index 28cb114ccf6b..c9efc69b5979 100644 --- a/services/net/java/android/net/dhcp/DhcpClient.java +++ b/services/net/java/android/net/dhcp/DhcpClient.java @@ -417,9 +417,10 @@ public class DhcpClient extends BaseDhcpStateMachine {                  encap, mTransactionId, getSecs(), clientAddress,                  DO_UNICAST, mHwAddr, requestedAddress,                  serverAddress, REQUESTED_PARAMS, null); +        String serverStr = (serverAddress != null) ? serverAddress.getHostAddress() : null;          String description = "DHCPREQUEST ciaddr=" + clientAddress.getHostAddress() +                               " request=" + requestedAddress.getHostAddress() + -                             " to=" + serverAddress.getHostAddress(); +                             " serverid=" + serverStr;          return transmitPacket(packet, description, to);      } @@ -822,7 +823,8 @@ public class DhcpClient extends BaseDhcpStateMachine {          public void enter() {              super.enter();              if (!setIpAddress(mDhcpLease.ipAddress) || -                    !connectUdpSock((mDhcpLease.serverAddress))) { +                    (mDhcpLease.serverAddress != null && +                            !connectUdpSock((mDhcpLease.serverAddress)))) {                  notifyFailure();                  // There's likely no point in going into DhcpInitState here, we'll probably just                  // repeat the transaction, get the same IP address as before, and fail. @@ -878,11 +880,15 @@ public class DhcpClient extends BaseDhcpStateMachine {          }          protected boolean sendPacket() { +            // Not specifying a SERVER_IDENTIFIER option is a violation of RFC 2131, but... +            // http://b/25343517 . Try to make things work anyway by using broadcast renews. +            Inet4Address to = (mDhcpLease.serverAddress != null) ? +                    mDhcpLease.serverAddress : INADDR_BROADCAST;              return sendRequestPacket(                      (Inet4Address) mDhcpLease.ipAddress.getAddress(),  // ciaddr                      INADDR_ANY,                                        // DHCP_REQUESTED_IP -                    INADDR_ANY,                                        // DHCP_SERVER_IDENTIFIER -                    (Inet4Address) mDhcpLease.serverAddress);          // packet destination address +                    null,                                              // DHCP_SERVER_IDENTIFIER +                    to);                                               // packet destination address          }          protected void receivePacket(DhcpPacket packet) { |