Loading core/java/android/net/metrics/ApfProgramEvent.java +22 −24 Original line number Diff line number Diff line Loading @@ -16,16 +16,21 @@ package android.net.metrics; import android.annotation.IntDef; import android.annotation.SystemApi; import android.os.Parcel; import android.os.Parcelable; import android.text.TextUtils; import android.util.SparseArray; import java.util.Arrays; import java.util.stream.Collectors; import com.android.internal.util.MessageUtils; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.util.ArrayList; import java.util.BitSet; import java.util.List; /** * An event logged when there is a change or event that requires updating the * the APF program in place with a new APF program. Loading @@ -36,10 +41,14 @@ public final class ApfProgramEvent implements Parcelable { // Bitflag constants describing what an Apf program filters. // Bits are indexeds from LSB to MSB, starting at index 0. // TODO: use @IntDef public static final int FLAG_MULTICAST_FILTER_ON = 0; public static final int FLAG_HAS_IPV4_ADDRESS = 1; /** {@hide} */ @IntDef(flag = true, value = {FLAG_MULTICAST_FILTER_ON, FLAG_HAS_IPV4_ADDRESS}) @Retention(RetentionPolicy.SOURCE) public @interface Flags {} public final long lifetime; // Lifetime of the program in seconds public final int filteredRas; // Number of RAs filtered by the APF program public final int currentRas; // Total number of current RAs at generation time Loading @@ -48,7 +57,7 @@ public final class ApfProgramEvent implements Parcelable { /** {@hide} */ public ApfProgramEvent( long lifetime, int filteredRas, int currentRas, int programLength, int flags) { long lifetime, int filteredRas, int currentRas, int programLength, @Flags int flags) { this.lifetime = lifetime; this.filteredRas = filteredRas; this.currentRas = currentRas; Loading Loading @@ -97,7 +106,7 @@ public final class ApfProgramEvent implements Parcelable { }; /** {@hide} */ public static int flagsFor(boolean hasIPv4, boolean multicastFilterOn) { public static @Flags int flagsFor(boolean hasIPv4, boolean multicastFilterOn) { int bitfield = 0; if (hasIPv4) { bitfield |= (1 << FLAG_HAS_IPV4_ADDRESS); Loading @@ -108,25 +117,14 @@ public final class ApfProgramEvent implements Parcelable { return bitfield; } // TODO: consider using java.util.BitSet private static int[] bitflagsOf(int bitfield) { int[] flags = new int[Integer.bitCount(bitfield)]; int i = 0; int bitflag = 0; while (bitfield != 0) { if ((bitfield & 1) != 0) { flags[i++] = bitflag; private static String namesOf(@Flags int bitfield) { List<String> names = new ArrayList<>(Integer.bitCount(bitfield)); BitSet set = BitSet.valueOf(new long[]{bitfield & Integer.MAX_VALUE}); // Only iterate over flag bits which are set. for (int bit = set.nextSetBit(0); bit >= 0; bit = set.nextSetBit(bit+1)) { names.add(Decoder.constants.get(bit)); } bitflag++; bitfield = bitfield >>> 1; } return flags; } private static String namesOf(int bitfields) { return Arrays.stream(bitflagsOf(bitfields)) .mapToObj(i -> Decoder.constants.get(i)) .collect(Collectors.joining(", ")); return TextUtils.join(", ", names); } final static class Decoder { Loading core/java/android/net/metrics/DefaultNetworkEvent.java +3 −0 Original line number Diff line number Diff line Loading @@ -22,6 +22,7 @@ import android.os.Parcel; import android.os.Parcelable; /** * An event recorded by ConnectivityService when there is a change in the default network. * {@hide} */ @SystemApi Loading Loading @@ -55,6 +56,7 @@ public final class DefaultNetworkEvent implements Parcelable { this.prevIPv6 = (in.readByte() > 0); } @Override public void writeToParcel(Parcel out, int flags) { out.writeInt(netId); out.writeIntArray(transportTypes); Loading @@ -63,6 +65,7 @@ public final class DefaultNetworkEvent implements Parcelable { out.writeByte(prevIPv6 ? (byte) 1 : (byte) 0); } @Override public int describeContents() { return 0; } Loading core/java/android/net/metrics/DhcpErrorEvent.java +4 −1 Original line number Diff line number Diff line Loading @@ -24,7 +24,8 @@ import android.util.SparseArray; import com.android.internal.util.MessageUtils; /** * {@hide} Event class used to record error events when parsing DHCP response packets. * Event class used to record error events when parsing DHCP response packets. * {@hide} */ @SystemApi public final class DhcpErrorEvent implements Parcelable { Loading Loading @@ -72,11 +73,13 @@ public final class DhcpErrorEvent implements Parcelable { this.errorCode = in.readInt(); } @Override public void writeToParcel(Parcel out, int flags) { out.writeString(ifName); out.writeInt(errorCode); } @Override public int describeContents() { return 0; } Loading core/java/android/net/metrics/DnsEvent.java +2 −0 Original line number Diff line number Diff line Loading @@ -21,6 +21,7 @@ import android.os.Parcel; import android.os.Parcelable; /** * An event recorded by DnsEventListenerService. * {@hide} */ @SystemApi Loading Loading @@ -60,6 +61,7 @@ final public class DnsEvent implements Parcelable { out.writeIntArray(latenciesMs); } @Override public int describeContents() { return 0; } Loading core/java/android/net/metrics/IpManagerEvent.java +15 −3 Original line number Diff line number Diff line Loading @@ -16,6 +16,7 @@ package android.net.metrics; import android.annotation.IntDef; import android.annotation.SystemApi; import android.os.Parcel; import android.os.Parcelable; Loading @@ -23,23 +24,32 @@ import android.util.SparseArray; import com.android.internal.util.MessageUtils; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; /** * An event recorded by IpManager when IP provisioning completes for a network or * when a network disconnects. * {@hide} */ @SystemApi public final class IpManagerEvent implements Parcelable { // TODO: use @IntDef public static final int PROVISIONING_OK = 1; public static final int PROVISIONING_FAIL = 2; public static final int COMPLETE_LIFECYCLE = 3; /** {@hide} */ @IntDef(value = {PROVISIONING_OK, PROVISIONING_FAIL, COMPLETE_LIFECYCLE}) @Retention(RetentionPolicy.SOURCE) public @interface EventType {} public final String ifName; public final int eventType; public final @EventType int eventType; public final long durationMs; /** {@hide} */ public IpManagerEvent(String ifName, int eventType, long duration) { public IpManagerEvent(String ifName, @EventType int eventType, long duration) { this.ifName = ifName; this.eventType = eventType; this.durationMs = duration; Loading @@ -51,12 +61,14 @@ public final class IpManagerEvent implements Parcelable { this.durationMs = in.readLong(); } @Override public void writeToParcel(Parcel out, int flags) { out.writeString(ifName); out.writeInt(eventType); out.writeLong(durationMs); } @Override public int describeContents() { return 0; } Loading Loading
core/java/android/net/metrics/ApfProgramEvent.java +22 −24 Original line number Diff line number Diff line Loading @@ -16,16 +16,21 @@ package android.net.metrics; import android.annotation.IntDef; import android.annotation.SystemApi; import android.os.Parcel; import android.os.Parcelable; import android.text.TextUtils; import android.util.SparseArray; import java.util.Arrays; import java.util.stream.Collectors; import com.android.internal.util.MessageUtils; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.util.ArrayList; import java.util.BitSet; import java.util.List; /** * An event logged when there is a change or event that requires updating the * the APF program in place with a new APF program. Loading @@ -36,10 +41,14 @@ public final class ApfProgramEvent implements Parcelable { // Bitflag constants describing what an Apf program filters. // Bits are indexeds from LSB to MSB, starting at index 0. // TODO: use @IntDef public static final int FLAG_MULTICAST_FILTER_ON = 0; public static final int FLAG_HAS_IPV4_ADDRESS = 1; /** {@hide} */ @IntDef(flag = true, value = {FLAG_MULTICAST_FILTER_ON, FLAG_HAS_IPV4_ADDRESS}) @Retention(RetentionPolicy.SOURCE) public @interface Flags {} public final long lifetime; // Lifetime of the program in seconds public final int filteredRas; // Number of RAs filtered by the APF program public final int currentRas; // Total number of current RAs at generation time Loading @@ -48,7 +57,7 @@ public final class ApfProgramEvent implements Parcelable { /** {@hide} */ public ApfProgramEvent( long lifetime, int filteredRas, int currentRas, int programLength, int flags) { long lifetime, int filteredRas, int currentRas, int programLength, @Flags int flags) { this.lifetime = lifetime; this.filteredRas = filteredRas; this.currentRas = currentRas; Loading Loading @@ -97,7 +106,7 @@ public final class ApfProgramEvent implements Parcelable { }; /** {@hide} */ public static int flagsFor(boolean hasIPv4, boolean multicastFilterOn) { public static @Flags int flagsFor(boolean hasIPv4, boolean multicastFilterOn) { int bitfield = 0; if (hasIPv4) { bitfield |= (1 << FLAG_HAS_IPV4_ADDRESS); Loading @@ -108,25 +117,14 @@ public final class ApfProgramEvent implements Parcelable { return bitfield; } // TODO: consider using java.util.BitSet private static int[] bitflagsOf(int bitfield) { int[] flags = new int[Integer.bitCount(bitfield)]; int i = 0; int bitflag = 0; while (bitfield != 0) { if ((bitfield & 1) != 0) { flags[i++] = bitflag; private static String namesOf(@Flags int bitfield) { List<String> names = new ArrayList<>(Integer.bitCount(bitfield)); BitSet set = BitSet.valueOf(new long[]{bitfield & Integer.MAX_VALUE}); // Only iterate over flag bits which are set. for (int bit = set.nextSetBit(0); bit >= 0; bit = set.nextSetBit(bit+1)) { names.add(Decoder.constants.get(bit)); } bitflag++; bitfield = bitfield >>> 1; } return flags; } private static String namesOf(int bitfields) { return Arrays.stream(bitflagsOf(bitfields)) .mapToObj(i -> Decoder.constants.get(i)) .collect(Collectors.joining(", ")); return TextUtils.join(", ", names); } final static class Decoder { Loading
core/java/android/net/metrics/DefaultNetworkEvent.java +3 −0 Original line number Diff line number Diff line Loading @@ -22,6 +22,7 @@ import android.os.Parcel; import android.os.Parcelable; /** * An event recorded by ConnectivityService when there is a change in the default network. * {@hide} */ @SystemApi Loading Loading @@ -55,6 +56,7 @@ public final class DefaultNetworkEvent implements Parcelable { this.prevIPv6 = (in.readByte() > 0); } @Override public void writeToParcel(Parcel out, int flags) { out.writeInt(netId); out.writeIntArray(transportTypes); Loading @@ -63,6 +65,7 @@ public final class DefaultNetworkEvent implements Parcelable { out.writeByte(prevIPv6 ? (byte) 1 : (byte) 0); } @Override public int describeContents() { return 0; } Loading
core/java/android/net/metrics/DhcpErrorEvent.java +4 −1 Original line number Diff line number Diff line Loading @@ -24,7 +24,8 @@ import android.util.SparseArray; import com.android.internal.util.MessageUtils; /** * {@hide} Event class used to record error events when parsing DHCP response packets. * Event class used to record error events when parsing DHCP response packets. * {@hide} */ @SystemApi public final class DhcpErrorEvent implements Parcelable { Loading Loading @@ -72,11 +73,13 @@ public final class DhcpErrorEvent implements Parcelable { this.errorCode = in.readInt(); } @Override public void writeToParcel(Parcel out, int flags) { out.writeString(ifName); out.writeInt(errorCode); } @Override public int describeContents() { return 0; } Loading
core/java/android/net/metrics/DnsEvent.java +2 −0 Original line number Diff line number Diff line Loading @@ -21,6 +21,7 @@ import android.os.Parcel; import android.os.Parcelable; /** * An event recorded by DnsEventListenerService. * {@hide} */ @SystemApi Loading Loading @@ -60,6 +61,7 @@ final public class DnsEvent implements Parcelable { out.writeIntArray(latenciesMs); } @Override public int describeContents() { return 0; } Loading
core/java/android/net/metrics/IpManagerEvent.java +15 −3 Original line number Diff line number Diff line Loading @@ -16,6 +16,7 @@ package android.net.metrics; import android.annotation.IntDef; import android.annotation.SystemApi; import android.os.Parcel; import android.os.Parcelable; Loading @@ -23,23 +24,32 @@ import android.util.SparseArray; import com.android.internal.util.MessageUtils; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; /** * An event recorded by IpManager when IP provisioning completes for a network or * when a network disconnects. * {@hide} */ @SystemApi public final class IpManagerEvent implements Parcelable { // TODO: use @IntDef public static final int PROVISIONING_OK = 1; public static final int PROVISIONING_FAIL = 2; public static final int COMPLETE_LIFECYCLE = 3; /** {@hide} */ @IntDef(value = {PROVISIONING_OK, PROVISIONING_FAIL, COMPLETE_LIFECYCLE}) @Retention(RetentionPolicy.SOURCE) public @interface EventType {} public final String ifName; public final int eventType; public final @EventType int eventType; public final long durationMs; /** {@hide} */ public IpManagerEvent(String ifName, int eventType, long duration) { public IpManagerEvent(String ifName, @EventType int eventType, long duration) { this.ifName = ifName; this.eventType = eventType; this.durationMs = duration; Loading @@ -51,12 +61,14 @@ public final class IpManagerEvent implements Parcelable { this.durationMs = in.readLong(); } @Override public void writeToParcel(Parcel out, int flags) { out.writeString(ifName); out.writeInt(eventType); out.writeLong(durationMs); } @Override public int describeContents() { return 0; } Loading