| /* |
| * Copyright (C) 2015 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.system; |
| |
| import static android.annotation.SystemApi.Client.MODULE_LIBRARIES; |
| |
| import android.annotation.SystemApi; |
| import android.compat.annotation.UnsupportedAppUsage; |
| |
| import java.net.SocketAddress; |
| import libcore.util.Objects; |
| |
| /** |
| * Netlink socket address. |
| * |
| * Corresponds to Linux's {@code struct sockaddr_nl} from |
| * <a href="https://github.com/torvalds/linux/blob/master/include/uapi/linux/netlink.h"><linux/netlink.h></a>. |
| * |
| * Netlink socket address descirbes a netlink client is user space or in kernel. |
| * A {@link NetlinkSocketAddress} can be either unicast (only sent to one peer) |
| * or sent to netlink multicast groups ({@code nlGroupsMask} not equal 0). |
| * |
| * Any {@link NetlinkSocketAddress} is described by {@code nlPortId} and {@code nlGroupsMask}. |
| * |
| * {@code nlPortId} is the unicast address of netlink socket. It's always 0 |
| * if the destination is in the kernel. For a user-space process, |
| * {@nlPortId} is usually the PID of the process owning the destination |
| * socket. However, {@nlPortId} identifies a netlink socket, not a |
| * process. If a process owns several netlink sockets, then {@nlPortId} |
| * can be equal to the process ID only for at most one socket. |
| * |
| * {@code nlGroupsMask} is a bit mask with every bit representing a netlink |
| * group number. The default value for this field is zero which means that |
| * no multicasts will be received. A socket may multicast messages to any |
| * of the multicast groups by setting {@code nlGroupsMask} to a bit mask of |
| * the groups it wishes to send to. |
| * |
| * @hide |
| */ |
| @SystemApi(client = MODULE_LIBRARIES) |
| public final class NetlinkSocketAddress extends SocketAddress { |
| /** |
| * port ID |
| * |
| * @hide |
| */ |
| private final int nlPortId; |
| |
| /** |
| * multicast groups mask |
| * |
| * @hide |
| */ |
| private final int nlGroupsMask; |
| |
| /** |
| * @hide |
| */ |
| // VisibleForTesting |
| public NetlinkSocketAddress() { |
| this(0, 0); |
| } |
| /** |
| * @hide |
| */ |
| // VisibleForTesting |
| public NetlinkSocketAddress(int nlPortId) { |
| this(nlPortId, 0); |
| } |
| |
| /** |
| * Constructs an instance with the given port id and groups mask. |
| * |
| * @param nlPortId port id |
| * @param nlGroupsMask groups mask |
| * |
| * @hide |
| */ |
| @UnsupportedAppUsage |
| @SystemApi(client = MODULE_LIBRARIES) |
| public NetlinkSocketAddress(int nlPortId, int nlGroupsMask) { |
| this.nlPortId = nlPortId; |
| this.nlGroupsMask = nlGroupsMask; |
| } |
| |
| /** |
| * Returns this address's port id. |
| * |
| * @return port id |
| * |
| * @hide |
| */ |
| @SystemApi(client = MODULE_LIBRARIES) |
| public int getPortId() { |
| return nlPortId; |
| } |
| |
| /** |
| * Returns this address's groups multicast mask. |
| * |
| * @return groups mask |
| * |
| * @hide |
| */ |
| @SystemApi(client = MODULE_LIBRARIES) |
| public int getGroupsMask() { |
| return nlGroupsMask; |
| } |
| |
| /** |
| * @hide |
| */ |
| @Override public String toString() { |
| return Objects.toString(this); |
| } |
| } |