Sholes mobile iface comes/goes - handle the reset

The byte counter for the iface goes to zero when it comes back.  Catch that and
do the complex math to correct.

Also add a log entry telling us our desired throttle index.

Lastly, reset the sec/msec part of our reset time so that one calc will == another and not
be off by little bits.

bug:25494925
Change-Id: I99525b72a76316a8e601ceb457ca202fae040bae
diff --git a/services/java/com/android/server/ThrottleService.java b/services/java/com/android/server/ThrottleService.java
index 9333dd8..6ba96ae 100644
--- a/services/java/com/android/server/ThrottleService.java
+++ b/services/java/com/android/server/ThrottleService.java
@@ -372,6 +372,14 @@
             try {
                 incRead = mNMService.getInterfaceRxCounter(mIface) - mLastRead;
                 incWrite = mNMService.getInterfaceTxCounter(mIface) - mLastWrite;
+                // handle iface resets - on some device the 3g iface comes and goes and gets
+                // totals reset to 0.  Deal with it
+                if ((incRead < 0) || (incWrite < 0)) {
+                    incRead += mLastRead;
+                    incWrite += mLastWrite;
+                    mLastRead = 0;
+                    mLastWrite = 0;
+                }
             } catch (RemoteException e) {
                 Slog.e(TAG, "got remoteException in onPollAlarm:" + e);
             }
@@ -529,6 +537,8 @@
             end.set(Calendar.DAY_OF_MONTH, mPolicyResetDay);
             end.set(Calendar.HOUR_OF_DAY, 0);
             end.set(Calendar.MINUTE, 0);
+            end.set(Calendar.SECOND, 0);
+            end.set(Calendar.MILLISECOND, 0);
             if (day >= mPolicyResetDay) {
                 int month = end.get(Calendar.MONTH);
                 if (month == Calendar.DECEMBER) {
@@ -845,6 +855,8 @@
                 "and ends in " + (mRecorder.getPeriodEnd() - System.currentTimeMillis()) / 1000 +
                 " seconds.");
         pw.println("Polling every " + mPolicyPollPeriodSec + " seconds");
+        pw.println("Current Throttle Index is " + mThrottleIndex);
+
         for (int i = 0; i < mRecorder.getPeriodCount(); i++) {
             pw.println(" Period[" + i + "] - read:" + mRecorder.getPeriodRx(i) + ", written:" +
                     mRecorder.getPeriodTx(i));