Merge "Move TetherStatsKey and TetherStatsValue to common libs" am: 8315d1cf03
Original change: https://android-review.googlesource.com/c/platform/packages/modules/Connectivity/+/2054166 Change-Id: Iff314d5048d718f7e10d8d312aba8f7ad3e1ad6b Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -30,9 +30,9 @@ import androidx.annotation.Nullable;
|
|||||||
import com.android.net.module.util.IBpfMap.ThrowingBiConsumer;
|
import com.android.net.module.util.IBpfMap.ThrowingBiConsumer;
|
||||||
import com.android.net.module.util.bpf.Tether4Key;
|
import com.android.net.module.util.bpf.Tether4Key;
|
||||||
import com.android.net.module.util.bpf.Tether4Value;
|
import com.android.net.module.util.bpf.Tether4Value;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsValue;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator.Dependencies;
|
import com.android.networkstack.tethering.BpfCoordinator.Dependencies;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
||||||
import com.android.networkstack.tethering.TetherStatsValue;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Bpf coordinator class for API shims.
|
* Bpf coordinator class for API shims.
|
||||||
|
|||||||
@@ -33,6 +33,8 @@ import com.android.net.module.util.BpfMap;
|
|||||||
import com.android.net.module.util.IBpfMap.ThrowingBiConsumer;
|
import com.android.net.module.util.IBpfMap.ThrowingBiConsumer;
|
||||||
import com.android.net.module.util.bpf.Tether4Key;
|
import com.android.net.module.util.bpf.Tether4Key;
|
||||||
import com.android.net.module.util.bpf.Tether4Value;
|
import com.android.net.module.util.bpf.Tether4Value;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsKey;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsValue;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator.Dependencies;
|
import com.android.networkstack.tethering.BpfCoordinator.Dependencies;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
||||||
import com.android.networkstack.tethering.BpfUtils;
|
import com.android.networkstack.tethering.BpfUtils;
|
||||||
@@ -42,8 +44,6 @@ import com.android.networkstack.tethering.TetherDevValue;
|
|||||||
import com.android.networkstack.tethering.TetherDownstream6Key;
|
import com.android.networkstack.tethering.TetherDownstream6Key;
|
||||||
import com.android.networkstack.tethering.TetherLimitKey;
|
import com.android.networkstack.tethering.TetherLimitKey;
|
||||||
import com.android.networkstack.tethering.TetherLimitValue;
|
import com.android.networkstack.tethering.TetherLimitValue;
|
||||||
import com.android.networkstack.tethering.TetherStatsKey;
|
|
||||||
import com.android.networkstack.tethering.TetherStatsValue;
|
|
||||||
import com.android.networkstack.tethering.TetherUpstream6Key;
|
import com.android.networkstack.tethering.TetherUpstream6Key;
|
||||||
|
|
||||||
import java.io.FileDescriptor;
|
import java.io.FileDescriptor;
|
||||||
|
|||||||
@@ -25,9 +25,9 @@ import androidx.annotation.Nullable;
|
|||||||
import com.android.net.module.util.IBpfMap.ThrowingBiConsumer;
|
import com.android.net.module.util.IBpfMap.ThrowingBiConsumer;
|
||||||
import com.android.net.module.util.bpf.Tether4Key;
|
import com.android.net.module.util.bpf.Tether4Key;
|
||||||
import com.android.net.module.util.bpf.Tether4Value;
|
import com.android.net.module.util.bpf.Tether4Value;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsValue;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator.Dependencies;
|
import com.android.networkstack.tethering.BpfCoordinator.Dependencies;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
||||||
import com.android.networkstack.tethering.TetherStatsValue;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Bpf coordinator class for API shims.
|
* Bpf coordinator class for API shims.
|
||||||
|
|||||||
@@ -68,6 +68,8 @@ import com.android.net.module.util.NetworkStackConstants;
|
|||||||
import com.android.net.module.util.Struct.U32;
|
import com.android.net.module.util.Struct.U32;
|
||||||
import com.android.net.module.util.bpf.Tether4Key;
|
import com.android.net.module.util.bpf.Tether4Key;
|
||||||
import com.android.net.module.util.bpf.Tether4Value;
|
import com.android.net.module.util.bpf.Tether4Value;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsKey;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsValue;
|
||||||
import com.android.net.module.util.netlink.ConntrackMessage;
|
import com.android.net.module.util.netlink.ConntrackMessage;
|
||||||
import com.android.net.module.util.netlink.NetlinkConstants;
|
import com.android.net.module.util.netlink.NetlinkConstants;
|
||||||
import com.android.net.module.util.netlink.NetlinkSocket;
|
import com.android.net.module.util.netlink.NetlinkSocket;
|
||||||
|
|||||||
@@ -1,53 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2020 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 com.android.networkstack.tethering;
|
|
||||||
|
|
||||||
import com.android.net.module.util.Struct;
|
|
||||||
import com.android.net.module.util.Struct.Field;
|
|
||||||
import com.android.net.module.util.Struct.Type;
|
|
||||||
|
|
||||||
/** The key of BpfMap which is used for tethering stats. */
|
|
||||||
public class TetherStatsKey extends Struct {
|
|
||||||
@Field(order = 0, type = Type.U32)
|
|
||||||
public final long ifindex; // upstream interface index
|
|
||||||
|
|
||||||
public TetherStatsKey(final long ifindex) {
|
|
||||||
this.ifindex = ifindex;
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: remove equals, hashCode and toString once aosp/1536721 is merged.
|
|
||||||
@Override
|
|
||||||
public boolean equals(Object obj) {
|
|
||||||
if (this == obj) return true;
|
|
||||||
|
|
||||||
if (!(obj instanceof TetherStatsKey)) return false;
|
|
||||||
|
|
||||||
final TetherStatsKey that = (TetherStatsKey) obj;
|
|
||||||
|
|
||||||
return ifindex == that.ifindex;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
return Long.hashCode(ifindex);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return String.format("ifindex: %d", ifindex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,80 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2020 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 com.android.networkstack.tethering;
|
|
||||||
|
|
||||||
import com.android.net.module.util.Struct;
|
|
||||||
import com.android.net.module.util.Struct.Field;
|
|
||||||
import com.android.net.module.util.Struct.Type;
|
|
||||||
|
|
||||||
/** The key of BpfMap which is used for tethering stats. */
|
|
||||||
public class TetherStatsValue extends Struct {
|
|
||||||
// Use the signed long variable to store the uint64 stats from stats BPF map.
|
|
||||||
// U63 is enough for each data element even at 5Gbps for ~468 years.
|
|
||||||
// 2^63 / (5 * 1000 * 1000 * 1000) * 8 / 86400 / 365 = 468.
|
|
||||||
@Field(order = 0, type = Type.U63)
|
|
||||||
public final long rxPackets;
|
|
||||||
@Field(order = 1, type = Type.U63)
|
|
||||||
public final long rxBytes;
|
|
||||||
@Field(order = 2, type = Type.U63)
|
|
||||||
public final long rxErrors;
|
|
||||||
@Field(order = 3, type = Type.U63)
|
|
||||||
public final long txPackets;
|
|
||||||
@Field(order = 4, type = Type.U63)
|
|
||||||
public final long txBytes;
|
|
||||||
@Field(order = 5, type = Type.U63)
|
|
||||||
public final long txErrors;
|
|
||||||
|
|
||||||
public TetherStatsValue(final long rxPackets, final long rxBytes, final long rxErrors,
|
|
||||||
final long txPackets, final long txBytes, final long txErrors) {
|
|
||||||
this.rxPackets = rxPackets;
|
|
||||||
this.rxBytes = rxBytes;
|
|
||||||
this.rxErrors = rxErrors;
|
|
||||||
this.txPackets = txPackets;
|
|
||||||
this.txBytes = txBytes;
|
|
||||||
this.txErrors = txErrors;
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: remove equals, hashCode and toString once aosp/1536721 is merged.
|
|
||||||
@Override
|
|
||||||
public boolean equals(Object obj) {
|
|
||||||
if (this == obj) return true;
|
|
||||||
|
|
||||||
if (!(obj instanceof TetherStatsValue)) return false;
|
|
||||||
|
|
||||||
final TetherStatsValue that = (TetherStatsValue) obj;
|
|
||||||
|
|
||||||
return rxPackets == that.rxPackets
|
|
||||||
&& rxBytes == that.rxBytes
|
|
||||||
&& rxErrors == that.rxErrors
|
|
||||||
&& txPackets == that.txPackets
|
|
||||||
&& txBytes == that.txBytes
|
|
||||||
&& txErrors == that.txErrors;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
return Long.hashCode(rxPackets) ^ Long.hashCode(rxBytes) ^ Long.hashCode(rxErrors)
|
|
||||||
^ Long.hashCode(txPackets) ^ Long.hashCode(txBytes) ^ Long.hashCode(txErrors);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return String.format("rxPackets: %s, rxBytes: %s, rxErrors: %s, txPackets: %s, "
|
|
||||||
+ "txBytes: %s, txErrors: %s", rxPackets, rxBytes, rxErrors, txPackets,
|
|
||||||
txBytes, txErrors);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -22,7 +22,7 @@ import android.util.Log;
|
|||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
|
|
||||||
import com.android.net.module.util.JniUtil;
|
import com.android.net.module.util.JniUtil;
|
||||||
import com.android.networkstack.tethering.TetherStatsValue;
|
import com.android.net.module.util.bpf.TetherStatsValue;
|
||||||
|
|
||||||
import java.io.FileDescriptor;
|
import java.io.FileDescriptor;
|
||||||
import java.net.Inet6Address;
|
import java.net.Inet6Address;
|
||||||
|
|||||||
@@ -103,6 +103,8 @@ import com.android.net.module.util.InterfaceParams;
|
|||||||
import com.android.net.module.util.NetworkStackConstants;
|
import com.android.net.module.util.NetworkStackConstants;
|
||||||
import com.android.net.module.util.bpf.Tether4Key;
|
import com.android.net.module.util.bpf.Tether4Key;
|
||||||
import com.android.net.module.util.bpf.Tether4Value;
|
import com.android.net.module.util.bpf.Tether4Value;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsKey;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsValue;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator;
|
import com.android.networkstack.tethering.BpfCoordinator;
|
||||||
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
import com.android.networkstack.tethering.BpfCoordinator.Ipv6ForwardingRule;
|
||||||
import com.android.networkstack.tethering.PrivateAddressCoordinator;
|
import com.android.networkstack.tethering.PrivateAddressCoordinator;
|
||||||
@@ -112,8 +114,6 @@ import com.android.networkstack.tethering.TetherDevValue;
|
|||||||
import com.android.networkstack.tethering.TetherDownstream6Key;
|
import com.android.networkstack.tethering.TetherDownstream6Key;
|
||||||
import com.android.networkstack.tethering.TetherLimitKey;
|
import com.android.networkstack.tethering.TetherLimitKey;
|
||||||
import com.android.networkstack.tethering.TetherLimitValue;
|
import com.android.networkstack.tethering.TetherLimitValue;
|
||||||
import com.android.networkstack.tethering.TetherStatsKey;
|
|
||||||
import com.android.networkstack.tethering.TetherStatsValue;
|
|
||||||
import com.android.networkstack.tethering.TetherUpstream6Key;
|
import com.android.networkstack.tethering.TetherUpstream6Key;
|
||||||
import com.android.networkstack.tethering.TetheringConfiguration;
|
import com.android.networkstack.tethering.TetheringConfiguration;
|
||||||
import com.android.networkstack.tethering.util.InterfaceSet;
|
import com.android.networkstack.tethering.util.InterfaceSet;
|
||||||
|
|||||||
@@ -102,6 +102,8 @@ import com.android.net.module.util.InterfaceParams;
|
|||||||
import com.android.net.module.util.NetworkStackConstants;
|
import com.android.net.module.util.NetworkStackConstants;
|
||||||
import com.android.net.module.util.bpf.Tether4Key;
|
import com.android.net.module.util.bpf.Tether4Key;
|
||||||
import com.android.net.module.util.bpf.Tether4Value;
|
import com.android.net.module.util.bpf.Tether4Value;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsKey;
|
||||||
|
import com.android.net.module.util.bpf.TetherStatsValue;
|
||||||
import com.android.net.module.util.netlink.ConntrackMessage;
|
import com.android.net.module.util.netlink.ConntrackMessage;
|
||||||
import com.android.net.module.util.netlink.NetlinkConstants;
|
import com.android.net.module.util.netlink.NetlinkConstants;
|
||||||
import com.android.net.module.util.netlink.NetlinkSocket;
|
import com.android.net.module.util.netlink.NetlinkSocket;
|
||||||
|
|||||||
Reference in New Issue
Block a user