diff options
Diffstat (limited to 'core')
| -rw-r--r-- | core/java/android/nfc/cardemulation/ApduServiceInfo.java | 15 | ||||
| -rw-r--r-- | core/java/android/os/Debug.java | 90 | ||||
| -rw-r--r-- | core/java/android/security/keymaster/KeymasterDefs.java | 4 | 
3 files changed, 108 insertions, 1 deletions
| diff --git a/core/java/android/nfc/cardemulation/ApduServiceInfo.java b/core/java/android/nfc/cardemulation/ApduServiceInfo.java index 00b2ee3..f10e530 100644 --- a/core/java/android/nfc/cardemulation/ApduServiceInfo.java +++ b/core/java/android/nfc/cardemulation/ApduServiceInfo.java @@ -40,6 +40,7 @@ import java.io.IOException;  import java.io.PrintWriter;  import java.util.ArrayList;  import java.util.HashMap; +import java.util.List;  import java.util.Map;  /** @@ -262,7 +263,7 @@ public final class ApduServiceInfo implements Parcelable {       * for that category.       * @return List of AIDs registered by the service       */ -    public ArrayList<String> getAids() { +    public List<String> getAids() {          final ArrayList<String> aids = new ArrayList<String>();          for (AidGroup group : getAidGroups()) {              aids.addAll(group.aids); @@ -270,6 +271,18 @@ public final class ApduServiceInfo implements Parcelable {          return aids;      } +    public List<String> getPrefixAids() { +        final ArrayList<String> prefixAids = new ArrayList<String>(); +        for (AidGroup group : getAidGroups()) { +            for (String aid : group.aids) { +                if (aid.endsWith("*")) { +                    prefixAids.add(aid); +                } +            } +        } +        return prefixAids; +    } +      /**       * Returns the registered AID group for this category.       */ diff --git a/core/java/android/os/Debug.java b/core/java/android/os/Debug.java index 2d92c7b..2a60b4d 100644 --- a/core/java/android/os/Debug.java +++ b/core/java/android/os/Debug.java @@ -34,6 +34,7 @@ import java.lang.annotation.Target;  import java.lang.annotation.ElementType;  import java.lang.annotation.Retention;  import java.lang.annotation.RetentionPolicy; +import java.util.Map;  import org.apache.harmony.dalvik.ddmc.Chunk;  import org.apache.harmony.dalvik.ddmc.ChunkHandler; @@ -1035,6 +1036,95 @@ href="{@docRoot}guide/developing/tools/traceview.html">Traceview: A Graphical Lo      }      /** +     * Returns the value of a particular runtime statistic or {@code null} if no +     * such runtime statistic exists. +     * +     * <p>The following table lists the runtime statistics that the runtime supports. +     * Note runtime statistics may be added or removed in a future API level.</p> +     * +     * <table> +     *     <thead> +     *         <tr> +     *             <th>Runtime statistic name</th> +     *             <th>Meaning</th> +     *             <th>Example</th> +     *             <th>Supported (API Levels)</th> +     *         </tr> +     *     </thead> +     *     <tbody> +     *         <tr> +     *             <td>art.gc.gc-count</td> +     *             <td>The number of garbage collection runs.</td> +     *             <td>{@code 164}</td> +     *             <td>23</td> +     *         </tr> +     *         <tr> +     *             <td>art.gc.gc-time</td> +     *             <td>The total duration of garbage collection runs in ms.</td> +     *             <td>{@code 62364}</td> +     *             <td>23</td> +     *         </tr> +     *         <tr> +     *             <td>art.gc.bytes-allocated</td> +     *             <td>The total number of bytes that the application allocated.</td> +     *             <td>{@code 1463948408}</td> +     *             <td>23</td> +     *         </tr> +     *         <tr> +     *             <td>art.gc.bytes-freed</td> +     *             <td>The total number of bytes that garbage collection reclaimed.</td> +     *             <td>{@code 1313493084}</td> +     *             <td>23</td> +     *         </tr> +     *         <tr> +     *             <td>art.gc.blocking-gc-count</td> +     *             <td>The number of blocking garbage collection runs.</td> +     *             <td>{@code 2}</td> +     *             <td>23</td> +     *         </tr> +     *         <tr> +     *             <td>art.gc.blocking-gc-time</td> +     *             <td>The total duration of blocking garbage collection runs in ms.</td> +     *             <td>{@code 804}</td> +     *             <td>23</td> +     *         </tr> +     *         <tr> +     *             <td>art.gc.gc-count-rate-histogram</td> +     *             <td>The histogram of the number of garbage collection runs per 10 seconds.</td> +     *             <td>{@code 0:34503,1:45350,2:11281,3:8088,4:43,5:8}</td> +     *             <td>23</td> +     *         </tr> +     *         <tr> +     *             <td>art.gc.blocking-gc-count-rate-histogram</td> +     *             <td>The histogram of the number of garbage collection runs per 10 seconds.</td> +     *             <td>{@code 0:99269,1:1,2:1}</td> +     *             <td>23</td> +     *         </tr> +     *     </tbody> +     * </table> +     * +     * @param statName +     *            the name of the runtime statistic to look up. +     * @return the value of the specified runtime statistic or {@code null} if the +     *         runtime statistic doesn't exist. +     * @hide +     */ +    public static String getRuntimeStat(String statName) { +        return VMDebug.getRuntimeStat(statName); +    } + +    /** +     * Returns a map of the names/values of the runtime statistics +     * that {@link #getRuntimeStat(String)} supports. +     * +     * @return a map of the names/values of the supported runtime statistics. +     * @hide +     */ +    public static Map<String, String> getRuntimeStats() { +        return VMDebug.getRuntimeStats(); +    } + +    /**       * Returns the size of the native heap.       * @return The size of the native heap in bytes.       */ diff --git a/core/java/android/security/keymaster/KeymasterDefs.java b/core/java/android/security/keymaster/KeymasterDefs.java index 298636b..25ebe75 100644 --- a/core/java/android/security/keymaster/KeymasterDefs.java +++ b/core/java/android/security/keymaster/KeymasterDefs.java @@ -191,6 +191,8 @@ public final class KeymasterDefs {      public static final int KM_ERROR_SECURE_HW_BUSY = -48;      public static final int KM_ERROR_SECURE_HW_COMMUNICATION_FAILED = -49;      public static final int KM_ERROR_UNSUPPORTED_EC_FIELD = -50; +    public static final int KM_ERROR_MISSING_NONCE = -51; +    public static final int KM_ERROR_INVALID_NONCE = -52;      public static final int KM_ERROR_UNIMPLEMENTED = -100;      public static final int KM_ERROR_VERSION_MISMATCH = -101;      public static final int KM_ERROR_UNKNOWN_ERROR = -1000; @@ -230,6 +232,8 @@ public final class KeymasterDefs {          sErrorCodeToString.put(KM_ERROR_INVALID_TAG, "Invalid tag");          sErrorCodeToString.put(KM_ERROR_MEMORY_ALLOCATION_FAILED, "Memory allocation failed");          sErrorCodeToString.put(KM_ERROR_UNSUPPORTED_EC_FIELD, "Unsupported EC field"); +        sErrorCodeToString.put(KM_ERROR_MISSING_NONCE, "Required IV missing"); +        sErrorCodeToString.put(KM_ERROR_INVALID_NONCE, "Invalid IV");          sErrorCodeToString.put(KM_ERROR_UNIMPLEMENTED, "Not implemented");          sErrorCodeToString.put(KM_ERROR_UNKNOWN_ERROR, "Unknown error");      } | 
