summaryrefslogtreecommitdiffstats
path: root/core/java/android
diff options
context:
space:
mode:
authorKen Shirriff <kens@google.com>2009-12-07 15:57:35 -0800
committerKen Shirriff <kens@google.com>2009-12-08 11:14:03 -0800
commit1719a39a4c0ff3afbf9c9e5f03f20ba50f490902 (patch)
tree8fe1ee0ea935c0f9bf090212aac2b5ff8de15b65 /core/java/android
parentf7d0b01387c10f93bf17981d45087810c80f0902 (diff)
downloadframeworks_base-1719a39a4c0ff3afbf9c9e5f03f20ba50f490902.zip
frameworks_base-1719a39a4c0ff3afbf9c9e5f03f20ba50f490902.tar.gz
frameworks_base-1719a39a4c0ff3afbf9c9e5f03f20ba50f490902.tar.bz2
Migration to TrafficStats.
TrafficStats is the SDK version of NetStat.
Diffstat (limited to 'core/java/android')
-rw-r--r--core/java/android/content/AbstractThreadedSyncAdapter.java12
-rw-r--r--core/java/android/content/TempProviderSyncAdapter.java20
-rw-r--r--core/java/android/os/NetStat.java247
3 files changed, 16 insertions, 263 deletions
diff --git a/core/java/android/content/AbstractThreadedSyncAdapter.java b/core/java/android/content/AbstractThreadedSyncAdapter.java
index 0db6155..091d44e 100644
--- a/core/java/android/content/AbstractThreadedSyncAdapter.java
+++ b/core/java/android/content/AbstractThreadedSyncAdapter.java
@@ -17,10 +17,10 @@
package android.content;
import android.accounts.Account;
+import android.net.TrafficStats;
import android.os.Bundle;
-import android.os.Process;
-import android.os.NetStat;
import android.os.IBinder;
+import android.os.Process;
import android.os.RemoteException;
import android.util.EventLog;
@@ -157,8 +157,8 @@ public abstract class AbstractThreadedSyncAdapter {
SyncResult syncResult = new SyncResult();
int uid = Process.myUid();
- mInitialTxBytes = NetStat.getUidTxBytes(uid);
- mInitialRxBytes = NetStat.getUidRxBytes(uid);
+ mInitialTxBytes = TrafficStats.getUidTxBytes(uid);
+ mInitialRxBytes = TrafficStats.getUidRxBytes(uid);
ContentProviderClient provider = null;
try {
provider = mContext.getContentResolver().acquireContentProviderClient(mAuthority);
@@ -175,8 +175,8 @@ public abstract class AbstractThreadedSyncAdapter {
if (!isCanceled()) {
mSyncContext.onFinished(syncResult);
}
- onLogSyncDetails(NetStat.getUidTxBytes(uid) - mInitialTxBytes,
- NetStat.getUidRxBytes(uid) - mInitialRxBytes, syncResult);
+ onLogSyncDetails(TrafficStats.getUidTxBytes(uid) - mInitialTxBytes,
+ TrafficStats.getUidRxBytes(uid) - mInitialRxBytes, syncResult);
// synchronize so that the assignment will be seen by other threads
// that also synchronize accesses to mSyncThread
synchronized (mSyncThreadLock) {
diff --git a/core/java/android/content/TempProviderSyncAdapter.java b/core/java/android/content/TempProviderSyncAdapter.java
index b46c545..5ccaa26 100644
--- a/core/java/android/content/TempProviderSyncAdapter.java
+++ b/core/java/android/content/TempProviderSyncAdapter.java
@@ -1,9 +1,12 @@
package android.content;
+import android.accounts.Account;
+import android.accounts.AuthenticatorException;
+import android.accounts.OperationCanceledException;
import android.database.SQLException;
+import android.net.TrafficStats;
import android.os.Bundle;
import android.os.Debug;
-import android.os.NetStat;
import android.os.Parcelable;
import android.os.Process;
import android.os.SystemProperties;
@@ -12,9 +15,6 @@ import android.util.Config;
import android.util.EventLog;
import android.util.Log;
import android.util.TimingLogger;
-import android.accounts.Account;
-import android.accounts.AuthenticatorException;
-import android.accounts.OperationCanceledException;
import java.io.IOException;
@@ -203,8 +203,8 @@ public abstract class TempProviderSyncAdapter extends SyncAdapter {
if (mProviderSyncStarted) mProvider.onSyncCanceled();
// We may lose the last few sync events when canceling. Oh well.
int uid = Process.myUid();
- logSyncDetails(NetStat.getUidTxBytes(uid) - mInitialTxBytes,
- NetStat.getUidRxBytes(uid) - mInitialRxBytes, mResult);
+ logSyncDetails(TrafficStats.getUidTxBytes(uid) - mInitialTxBytes,
+ TrafficStats.getUidRxBytes(uid) - mInitialRxBytes, mResult);
}
@Override
@@ -212,8 +212,8 @@ public abstract class TempProviderSyncAdapter extends SyncAdapter {
Process.setThreadPriority(Process.myTid(),
Process.THREAD_PRIORITY_BACKGROUND);
int uid = Process.myUid();
- mInitialTxBytes = NetStat.getUidTxBytes(uid);
- mInitialRxBytes = NetStat.getUidRxBytes(uid);
+ mInitialTxBytes = TrafficStats.getUidTxBytes(uid);
+ mInitialRxBytes = TrafficStats.getUidRxBytes(uid);
try {
sync(mSyncContext, mAccount, mAuthority, mExtras);
} catch (SQLException e) {
@@ -222,8 +222,8 @@ public abstract class TempProviderSyncAdapter extends SyncAdapter {
} finally {
mSyncThread = null;
if (!mIsCanceled) {
- logSyncDetails(NetStat.getUidTxBytes(uid) - mInitialTxBytes,
- NetStat.getUidRxBytes(uid) - mInitialRxBytes, mResult);
+ logSyncDetails(TrafficStats.getUidTxBytes(uid) - mInitialTxBytes,
+ TrafficStats.getUidRxBytes(uid) - mInitialRxBytes, mResult);
mSyncContext.onFinished(mResult);
}
}
diff --git a/core/java/android/os/NetStat.java b/core/java/android/os/NetStat.java
deleted file mode 100644
index e294cdf..0000000
--- a/core/java/android/os/NetStat.java
+++ /dev/null
@@ -1,247 +0,0 @@
-/*
- * Copyright (C) 2007 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package android.os;
-
-import android.util.Log;
-
-import java.io.File;
-import java.io.RandomAccessFile;
-import java.io.IOException;
-
-/** @hide */
-public class NetStat {
-
- // Logging tag.
- private final static String TAG = "netstat";
-
- // We pre-create all the File objects so we don't spend a lot of
- // CPU at runtime converting from Java Strings to byte[] for the
- // kernel calls.
- private final static File[] MOBILE_TX_PACKETS = mobileFiles("tx_packets");
- private final static File[] MOBILE_RX_PACKETS = mobileFiles("rx_packets");
- private final static File[] MOBILE_TX_BYTES = mobileFiles("tx_bytes");
- private final static File[] MOBILE_RX_BYTES = mobileFiles("rx_bytes");
- private final static File SYS_CLASS_NET_DIR = new File("/sys/class/net");
-
- /**
- * Get total number of tx packets sent through rmnet0 or ppp0
- *
- * @return number of Tx packets through rmnet0 or ppp0
- */
- public static long getMobileTxPkts() {
- return getMobileStat(MOBILE_TX_PACKETS);
- }
-
- /**
- * Get total number of rx packets received through rmnet0 or ppp0
- *
- * @return number of Rx packets through rmnet0 or ppp0
- */
- public static long getMobileRxPkts() {
- return getMobileStat(MOBILE_RX_PACKETS);
- }
-
- /**
- * Get total number of tx bytes received through rmnet0 or ppp0
- *
- * @return number of Tx bytes through rmnet0 or ppp0
- */
- public static long getMobileTxBytes() {
- return getMobileStat(MOBILE_TX_BYTES);
- }
-
- /**
- * Get total number of rx bytes received through rmnet0 or ppp0
- *
- * @return number of Rx bytes through rmnet0 or ppp0
- */
- public static long getMobileRxBytes() {
- return getMobileStat(MOBILE_RX_BYTES);
- }
-
- /**
- * Get the total number of packets sent through all network interfaces.
- *
- * @return the number of packets sent through all network interfaces
- */
- public static long getTotalTxPkts() {
- return getTotalStat("tx_packets");
- }
-
- /**
- * Get the total number of packets received through all network interfaces.
- *
- * @return the number of packets received through all network interfaces
- */
- public static long getTotalRxPkts() {
- return getTotalStat("rx_packets");
- }
-
- /**
- * Get the total number of bytes sent through all network interfaces.
- *
- * @return the number of bytes sent through all network interfaces
- */
- public static long getTotalTxBytes() {
- return getTotalStat("tx_bytes");
- }
-
- /**
- * Get the total number of bytes received through all network interfaces.
- *
- * @return the number of bytes received through all network interfaces
- */
- public static long getTotalRxBytes() {
- return getTotalStat("rx_bytes");
- }
-
- /**
- * Gets network bytes sent for this UID.
- * The statistics are across all interfaces.
- * The statistics come from /proc/uid_stat.
- *
- * {@see android.os.Process#myUid()}.
- *
- * @param uid
- * @return byte count
- */
- public static long getUidTxBytes(int uid) {
- return getNumberFromFilePath("/proc/uid_stat/" + uid + "/tcp_snd");
- }
-
- /**
- * Gets network bytes received for this UID.
- * The statistics are across all interfaces.
- * The statistics come from /proc/uid_stat.
- *
- * {@see android.os.Process#myUid()}.
- *
- * @param uid
- * @return byte count
- */
- public static long getUidRxBytes(int uid) {
- return getNumberFromFilePath("/proc/uid_stat/" + uid + "/tcp_rcv");
- }
-
- /**
- * Returns the array of two possible File locations for a given
- * statistic.
- */
- private static File[] mobileFiles(String whatStat) {
- // Note that we stat them at runtime to see which is
- // available, rather than here, to guard against the files
- // coming & going later as modules shut down (e.g. airplane
- // mode) and whatnot. The runtime stat() isn't expensive compared
- // to the previous charset conversion that happened before we
- // were reusing File instances.
- File[] files = new File[2];
- files[0] = new File("/sys/class/net/rmnet0/statistics/" + whatStat);
- files[1] = new File("/sys/class/net/ppp0/statistics/" + whatStat);
- return files;
- }
-
- private static long getTotalStat(String whatStat) {
- File netdir = new File("/sys/class/net");
-
- File[] nets = SYS_CLASS_NET_DIR.listFiles();
- if (nets == null) {
- return 0;
- }
- long total = 0;
- StringBuffer strbuf = new StringBuffer();
- for (File net : nets) {
- strbuf.append(net.getPath()).append(File.separator).append("statistics")
- .append(File.separator).append(whatStat);
- total += getNumberFromFilePath(strbuf.toString());
- strbuf.setLength(0);
- }
- return total;
- }
-
- private static long getMobileStat(File[] files) {
- for (int i = 0; i < files.length; i++) {
- File file = files[i];
- if (!file.exists()) {
- continue;
- }
- try {
- RandomAccessFile raf = new RandomAccessFile(file, "r");
- return getNumberFromFile(raf, file.getAbsolutePath());
- } catch (IOException e) {
- Log.w(TAG,
- "Exception opening TCP statistics file " + file.getAbsolutePath(),
- e);
- }
- }
- return 0L;
- }
-
- // File will have format <number><newline>
- private static long getNumberFromFilePath(String filename) {
- RandomAccessFile raf = getFile(filename);
- if (raf == null) {
- return 0L;
- }
- return getNumberFromFile(raf, filename);
- }
-
- // Private buffer for getNumberFromFile. Safe for re-use because
- // getNumberFromFile is synchronized.
- private final static byte[] buf = new byte[16];
-
- private static synchronized long getNumberFromFile(RandomAccessFile raf, String filename) {
- try {
- raf.read(buf);
- raf.close();
- } catch (IOException e) {
- Log.w(TAG, "Exception getting TCP bytes from " + filename, e);
- return 0L;
- } finally {
- if (raf != null) {
- try {
- raf.close();
- } catch (IOException e) {
- Log.w(TAG, "Exception closing " + filename, e);
- }
- }
- }
-
- long num = 0L;
- for (int i = 0; i < buf.length; i++) {
- if (buf[i] < '0' || buf[i] > '9') {
- break;
- }
- num *= 10;
- num += buf[i] - '0';
- }
- return num;
- }
-
- private static RandomAccessFile getFile(String filename) {
- File f = new File(filename);
- if (!f.canRead()) {
- return null;
- }
-
- try {
- return new RandomAccessFile(f, "r");
- } catch (IOException e) {
- Log.w(TAG, "Exception opening TCP statistics file " + filename, e);
- return null;
- }
- }
-}