1*8542734aSAndroid Build Coastguard Worker /*
2*8542734aSAndroid Build Coastguard Worker * Copyright (C) 2008 The Android Open Source Project
3*8542734aSAndroid Build Coastguard Worker *
4*8542734aSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*8542734aSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*8542734aSAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*8542734aSAndroid Build Coastguard Worker *
8*8542734aSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
9*8542734aSAndroid Build Coastguard Worker *
10*8542734aSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*8542734aSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*8542734aSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*8542734aSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*8542734aSAndroid Build Coastguard Worker * limitations under the License.
15*8542734aSAndroid Build Coastguard Worker */
16*8542734aSAndroid Build Coastguard Worker
17*8542734aSAndroid Build Coastguard Worker #include <stdarg.h>
18*8542734aSAndroid Build Coastguard Worker #include <stdio.h>
19*8542734aSAndroid Build Coastguard Worker #include <stdlib.h>
20*8542734aSAndroid Build Coastguard Worker #include <string.h>
21*8542734aSAndroid Build Coastguard Worker #include <errno.h>
22*8542734aSAndroid Build Coastguard Worker
23*8542734aSAndroid Build Coastguard Worker #define LOG_TAG "Netd"
24*8542734aSAndroid Build Coastguard Worker
25*8542734aSAndroid Build Coastguard Worker #include <log/log.h>
26*8542734aSAndroid Build Coastguard Worker
27*8542734aSAndroid Build Coastguard Worker #include <android-base/parseint.h>
28*8542734aSAndroid Build Coastguard Worker #include <android-base/strings.h>
29*8542734aSAndroid Build Coastguard Worker #include <netutils/ifc.h>
30*8542734aSAndroid Build Coastguard Worker #include <sysutils/NetlinkEvent.h>
31*8542734aSAndroid Build Coastguard Worker #include "Controllers.h"
32*8542734aSAndroid Build Coastguard Worker #include "NetlinkHandler.h"
33*8542734aSAndroid Build Coastguard Worker #include "NetlinkManager.h"
34*8542734aSAndroid Build Coastguard Worker #include "SockDiag.h"
35*8542734aSAndroid Build Coastguard Worker
36*8542734aSAndroid Build Coastguard Worker #include <charconv>
37*8542734aSAndroid Build Coastguard Worker
38*8542734aSAndroid Build Coastguard Worker #define BINDER_RETRY(exp) \
39*8542734aSAndroid Build Coastguard Worker ({ \
40*8542734aSAndroid Build Coastguard Worker bool res = true; \
41*8542734aSAndroid Build Coastguard Worker for (int attempt = 0; /*nop*/; ++attempt) { \
42*8542734aSAndroid Build Coastguard Worker auto _rc = (exp); \
43*8542734aSAndroid Build Coastguard Worker if (_rc.exceptionCode() == binder::Status::EX_TRANSACTION_FAILED && \
44*8542734aSAndroid Build Coastguard Worker attempt < RETRY_ATTEMPTS) { \
45*8542734aSAndroid Build Coastguard Worker usleep(RETRY_INTERVAL_MICRO_S); \
46*8542734aSAndroid Build Coastguard Worker } else { \
47*8542734aSAndroid Build Coastguard Worker res = _rc.isOk(); \
48*8542734aSAndroid Build Coastguard Worker break; \
49*8542734aSAndroid Build Coastguard Worker } \
50*8542734aSAndroid Build Coastguard Worker } \
51*8542734aSAndroid Build Coastguard Worker res; \
52*8542734aSAndroid Build Coastguard Worker })
53*8542734aSAndroid Build Coastguard Worker
54*8542734aSAndroid Build Coastguard Worker #define NOTIFY_AND_LOG(retry, func, ...) \
55*8542734aSAndroid Build Coastguard Worker do { \
56*8542734aSAndroid Build Coastguard Worker const auto listenerMap = gCtls->eventReporter.getNetdUnsolicitedEventListenerMap(); \
57*8542734aSAndroid Build Coastguard Worker for (bool needLog = true; auto& listener : listenerMap) { \
58*8542734aSAndroid Build Coastguard Worker auto entry = gUnsolicitedLog.newEntry().function(#func).args(__VA_ARGS__); \
59*8542734aSAndroid Build Coastguard Worker if (retry(listener.first->func(__VA_ARGS__))) { \
60*8542734aSAndroid Build Coastguard Worker if (needLog) { \
61*8542734aSAndroid Build Coastguard Worker gUnsolicitedLog.log(entry.withAutomaticDuration()); \
62*8542734aSAndroid Build Coastguard Worker needLog = false; \
63*8542734aSAndroid Build Coastguard Worker } \
64*8542734aSAndroid Build Coastguard Worker } \
65*8542734aSAndroid Build Coastguard Worker } \
66*8542734aSAndroid Build Coastguard Worker } while (0)
67*8542734aSAndroid Build Coastguard Worker
68*8542734aSAndroid Build Coastguard Worker namespace android {
69*8542734aSAndroid Build Coastguard Worker namespace net {
70*8542734aSAndroid Build Coastguard Worker
71*8542734aSAndroid Build Coastguard Worker constexpr int RETRY_ATTEMPTS = 2;
72*8542734aSAndroid Build Coastguard Worker constexpr int RETRY_INTERVAL_MICRO_S = 100000;
73*8542734aSAndroid Build Coastguard Worker
NetlinkHandler(NetlinkManager * nm,int listenerSocket,int format)74*8542734aSAndroid Build Coastguard Worker NetlinkHandler::NetlinkHandler(NetlinkManager *nm, int listenerSocket,
75*8542734aSAndroid Build Coastguard Worker int format) :
76*8542734aSAndroid Build Coastguard Worker NetlinkListener(listenerSocket, format) {
77*8542734aSAndroid Build Coastguard Worker mNm = nm;
78*8542734aSAndroid Build Coastguard Worker }
79*8542734aSAndroid Build Coastguard Worker
~NetlinkHandler()80*8542734aSAndroid Build Coastguard Worker NetlinkHandler::~NetlinkHandler() {
81*8542734aSAndroid Build Coastguard Worker }
82*8542734aSAndroid Build Coastguard Worker
start()83*8542734aSAndroid Build Coastguard Worker int NetlinkHandler::start() {
84*8542734aSAndroid Build Coastguard Worker return this->startListener();
85*8542734aSAndroid Build Coastguard Worker }
86*8542734aSAndroid Build Coastguard Worker
stop()87*8542734aSAndroid Build Coastguard Worker int NetlinkHandler::stop() {
88*8542734aSAndroid Build Coastguard Worker return this->stopListener();
89*8542734aSAndroid Build Coastguard Worker }
90*8542734aSAndroid Build Coastguard Worker
parseIfIndex(const char * ifIndex)91*8542734aSAndroid Build Coastguard Worker static long parseIfIndex(const char* ifIndex) {
92*8542734aSAndroid Build Coastguard Worker if (ifIndex == nullptr) {
93*8542734aSAndroid Build Coastguard Worker return 0;
94*8542734aSAndroid Build Coastguard Worker }
95*8542734aSAndroid Build Coastguard Worker long ifaceIndex = strtol(ifIndex, nullptr, 10);
96*8542734aSAndroid Build Coastguard Worker // strtol returns 0 on error, which is fine because 0 is not a valid ifindex.
97*8542734aSAndroid Build Coastguard Worker if (errno == ERANGE && (ifaceIndex == LONG_MAX || ifaceIndex == LONG_MIN)) {
98*8542734aSAndroid Build Coastguard Worker return 0;
99*8542734aSAndroid Build Coastguard Worker }
100*8542734aSAndroid Build Coastguard Worker return ifaceIndex;
101*8542734aSAndroid Build Coastguard Worker }
102*8542734aSAndroid Build Coastguard Worker
onEvent(NetlinkEvent * evt)103*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::onEvent(NetlinkEvent *evt) {
104*8542734aSAndroid Build Coastguard Worker const char *subsys = evt->getSubsystem();
105*8542734aSAndroid Build Coastguard Worker if (!subsys) {
106*8542734aSAndroid Build Coastguard Worker ALOGW("No subsystem found in netlink event");
107*8542734aSAndroid Build Coastguard Worker return;
108*8542734aSAndroid Build Coastguard Worker }
109*8542734aSAndroid Build Coastguard Worker
110*8542734aSAndroid Build Coastguard Worker if (!strcmp(subsys, "net")) {
111*8542734aSAndroid Build Coastguard Worker NetlinkEvent::Action action = evt->getAction();
112*8542734aSAndroid Build Coastguard Worker const char *iface = evt->findParam("INTERFACE") ?: "";
113*8542734aSAndroid Build Coastguard Worker if (action == NetlinkEvent::Action::kAdd) {
114*8542734aSAndroid Build Coastguard Worker notifyInterfaceAdded(iface);
115*8542734aSAndroid Build Coastguard Worker } else if (action == NetlinkEvent::Action::kRemove) {
116*8542734aSAndroid Build Coastguard Worker notifyInterfaceRemoved(iface);
117*8542734aSAndroid Build Coastguard Worker } else if (action == NetlinkEvent::Action::kChange) {
118*8542734aSAndroid Build Coastguard Worker evt->dump();
119*8542734aSAndroid Build Coastguard Worker notifyInterfaceChanged("nana", true);
120*8542734aSAndroid Build Coastguard Worker } else if (action == NetlinkEvent::Action::kLinkUp) {
121*8542734aSAndroid Build Coastguard Worker notifyInterfaceLinkChanged(iface, true);
122*8542734aSAndroid Build Coastguard Worker } else if (action == NetlinkEvent::Action::kLinkDown) {
123*8542734aSAndroid Build Coastguard Worker notifyInterfaceLinkChanged(iface, false);
124*8542734aSAndroid Build Coastguard Worker } else if (action == NetlinkEvent::Action::kAddressUpdated ||
125*8542734aSAndroid Build Coastguard Worker action == NetlinkEvent::Action::kAddressRemoved) {
126*8542734aSAndroid Build Coastguard Worker const char *address = evt->findParam("ADDRESS");
127*8542734aSAndroid Build Coastguard Worker const char *flags = evt->findParam("FLAGS");
128*8542734aSAndroid Build Coastguard Worker const char *scope = evt->findParam("SCOPE");
129*8542734aSAndroid Build Coastguard Worker const char *ifIndex = evt->findParam("IFINDEX");
130*8542734aSAndroid Build Coastguard Worker char addrstr[INET6_ADDRSTRLEN + strlen("/128")];
131*8542734aSAndroid Build Coastguard Worker strlcpy(addrstr, address, sizeof(addrstr));
132*8542734aSAndroid Build Coastguard Worker char *slash = strchr(addrstr, '/');
133*8542734aSAndroid Build Coastguard Worker if (slash) {
134*8542734aSAndroid Build Coastguard Worker *slash = '\0';
135*8542734aSAndroid Build Coastguard Worker }
136*8542734aSAndroid Build Coastguard Worker
137*8542734aSAndroid Build Coastguard Worker long ifaceIndex = parseIfIndex(ifIndex);
138*8542734aSAndroid Build Coastguard Worker if (!ifaceIndex) {
139*8542734aSAndroid Build Coastguard Worker ALOGE("invalid interface index: %s(%s)", iface, ifIndex);
140*8542734aSAndroid Build Coastguard Worker }
141*8542734aSAndroid Build Coastguard Worker const bool addrUpdated = (action == NetlinkEvent::Action::kAddressUpdated);
142*8542734aSAndroid Build Coastguard Worker if (addrUpdated) {
143*8542734aSAndroid Build Coastguard Worker gCtls->netCtrl.addInterfaceAddress(ifaceIndex, address);
144*8542734aSAndroid Build Coastguard Worker } else { // action == NetlinkEvent::Action::kAddressRemoved
145*8542734aSAndroid Build Coastguard Worker bool shouldDestroy = gCtls->netCtrl.removeInterfaceAddress(ifaceIndex, address);
146*8542734aSAndroid Build Coastguard Worker if (shouldDestroy) {
147*8542734aSAndroid Build Coastguard Worker SockDiag sd;
148*8542734aSAndroid Build Coastguard Worker if (sd.open()) {
149*8542734aSAndroid Build Coastguard Worker // Pass the interface index iff. destroying sockets on a link-local address.
150*8542734aSAndroid Build Coastguard Worker // This cannot use an interface name as the interface might no longer exist.
151*8542734aSAndroid Build Coastguard Worker int destroyIfaceIndex =
152*8542734aSAndroid Build Coastguard Worker std::string_view(addrstr).starts_with("fe80:") ? ifaceIndex : 0;
153*8542734aSAndroid Build Coastguard Worker int ret = sd.destroySockets(addrstr, destroyIfaceIndex);
154*8542734aSAndroid Build Coastguard Worker if (ret < 0) {
155*8542734aSAndroid Build Coastguard Worker ALOGE("Error destroying sockets: %s", strerror(-ret));
156*8542734aSAndroid Build Coastguard Worker }
157*8542734aSAndroid Build Coastguard Worker } else {
158*8542734aSAndroid Build Coastguard Worker ALOGE("Error opening NETLINK_SOCK_DIAG socket: %s", strerror(errno));
159*8542734aSAndroid Build Coastguard Worker }
160*8542734aSAndroid Build Coastguard Worker }
161*8542734aSAndroid Build Coastguard Worker }
162*8542734aSAndroid Build Coastguard Worker // Note: if this interface was deleted, iface is "" and we don't notify.
163*8542734aSAndroid Build Coastguard Worker if (iface && iface[0] && address && flags && scope) {
164*8542734aSAndroid Build Coastguard Worker if (addrUpdated) {
165*8542734aSAndroid Build Coastguard Worker notifyAddressUpdated(address, iface, std::stoi(flags), std::stoi(scope));
166*8542734aSAndroid Build Coastguard Worker } else {
167*8542734aSAndroid Build Coastguard Worker notifyAddressRemoved(address, iface, std::stoi(flags), std::stoi(scope));
168*8542734aSAndroid Build Coastguard Worker }
169*8542734aSAndroid Build Coastguard Worker }
170*8542734aSAndroid Build Coastguard Worker } else if (action == NetlinkEvent::Action::kRdnss) {
171*8542734aSAndroid Build Coastguard Worker const char *lifetime = evt->findParam("LIFETIME");
172*8542734aSAndroid Build Coastguard Worker const char *servers = evt->findParam("SERVERS");
173*8542734aSAndroid Build Coastguard Worker if (lifetime && servers) {
174*8542734aSAndroid Build Coastguard Worker notifyInterfaceDnsServers(iface, strtol(lifetime, nullptr, 10),
175*8542734aSAndroid Build Coastguard Worker android::base::Split(servers, ","));
176*8542734aSAndroid Build Coastguard Worker }
177*8542734aSAndroid Build Coastguard Worker } else if (action == NetlinkEvent::Action::kRouteUpdated ||
178*8542734aSAndroid Build Coastguard Worker action == NetlinkEvent::Action::kRouteRemoved) {
179*8542734aSAndroid Build Coastguard Worker const char *route = evt->findParam("ROUTE");
180*8542734aSAndroid Build Coastguard Worker const char *gateway = evt->findParam("GATEWAY");
181*8542734aSAndroid Build Coastguard Worker const char *iface = evt->findParam("INTERFACE");
182*8542734aSAndroid Build Coastguard Worker if (route && (gateway || iface)) {
183*8542734aSAndroid Build Coastguard Worker notifyRouteChange((action == NetlinkEvent::Action::kRouteUpdated) ? true : false,
184*8542734aSAndroid Build Coastguard Worker route, (gateway == nullptr) ? "" : gateway,
185*8542734aSAndroid Build Coastguard Worker (iface == nullptr) ? "" : iface);
186*8542734aSAndroid Build Coastguard Worker }
187*8542734aSAndroid Build Coastguard Worker }
188*8542734aSAndroid Build Coastguard Worker
189*8542734aSAndroid Build Coastguard Worker } else if (!strcmp(subsys, "qlog") || !strcmp(subsys, "xt_quota2")) {
190*8542734aSAndroid Build Coastguard Worker const char *alertName = evt->findParam("ALERT_NAME");
191*8542734aSAndroid Build Coastguard Worker const char *iface = evt->findParam("INTERFACE");
192*8542734aSAndroid Build Coastguard Worker if (alertName && iface) {
193*8542734aSAndroid Build Coastguard Worker notifyQuotaLimitReached(alertName, iface);
194*8542734aSAndroid Build Coastguard Worker }
195*8542734aSAndroid Build Coastguard Worker
196*8542734aSAndroid Build Coastguard Worker } else if (!strcmp(subsys, "strict")) {
197*8542734aSAndroid Build Coastguard Worker const char *uid = evt->findParam("UID");
198*8542734aSAndroid Build Coastguard Worker const char *hex = evt->findParam("HEX");
199*8542734aSAndroid Build Coastguard Worker if (uid && hex) {
200*8542734aSAndroid Build Coastguard Worker notifyStrictCleartext(strtol(uid, nullptr, 10), hex);
201*8542734aSAndroid Build Coastguard Worker }
202*8542734aSAndroid Build Coastguard Worker
203*8542734aSAndroid Build Coastguard Worker } else if (!strcmp(subsys, "xt_idletimer")) {
204*8542734aSAndroid Build Coastguard Worker const char *label = evt->findParam("INTERFACE");
205*8542734aSAndroid Build Coastguard Worker const char *state = evt->findParam("STATE");
206*8542734aSAndroid Build Coastguard Worker const char *timestamp = evt->findParam("TIME_NS");
207*8542734aSAndroid Build Coastguard Worker const char *uid = evt->findParam("UID");
208*8542734aSAndroid Build Coastguard Worker if (state) {
209*8542734aSAndroid Build Coastguard Worker bool isActive = !strcmp("active", state);
210*8542734aSAndroid Build Coastguard Worker int64_t processTimestamp = (timestamp == nullptr) ? 0 : strtoll(timestamp, nullptr, 10);
211*8542734aSAndroid Build Coastguard Worker int intLabel;
212*8542734aSAndroid Build Coastguard Worker // NMS only accepts interface class activity changes with integer labels, and only ever
213*8542734aSAndroid Build Coastguard Worker // creates idletimers with integer labels.
214*8542734aSAndroid Build Coastguard Worker if (android::base::ParseInt(label, &intLabel)) {
215*8542734aSAndroid Build Coastguard Worker const long reportedUid =
216*8542734aSAndroid Build Coastguard Worker (uid != nullptr && isActive) ? strtol(uid, nullptr, 10) : -1;
217*8542734aSAndroid Build Coastguard Worker notifyInterfaceClassActivityChanged(intLabel, isActive, processTimestamp,
218*8542734aSAndroid Build Coastguard Worker reportedUid);
219*8542734aSAndroid Build Coastguard Worker }
220*8542734aSAndroid Build Coastguard Worker }
221*8542734aSAndroid Build Coastguard Worker
222*8542734aSAndroid Build Coastguard Worker #if !LOG_NDEBUG
223*8542734aSAndroid Build Coastguard Worker } else if (strcmp(subsys, "platform") && strcmp(subsys, "backlight")) {
224*8542734aSAndroid Build Coastguard Worker /* It is not a VSYNC or a backlight event */
225*8542734aSAndroid Build Coastguard Worker ALOGV("unexpected event from subsystem %s", subsys);
226*8542734aSAndroid Build Coastguard Worker #endif
227*8542734aSAndroid Build Coastguard Worker }
228*8542734aSAndroid Build Coastguard Worker }
229*8542734aSAndroid Build Coastguard Worker
notifyInterfaceAdded(const std::string & ifName)230*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyInterfaceAdded(const std::string& ifName) {
231*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceAdded, ifName);
232*8542734aSAndroid Build Coastguard Worker }
233*8542734aSAndroid Build Coastguard Worker
notifyInterfaceRemoved(const std::string & ifName)234*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyInterfaceRemoved(const std::string& ifName) {
235*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceRemoved, ifName);
236*8542734aSAndroid Build Coastguard Worker }
237*8542734aSAndroid Build Coastguard Worker
notifyInterfaceChanged(const std::string & ifName,bool up)238*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyInterfaceChanged(const std::string& ifName, bool up) {
239*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceChanged, ifName, up);
240*8542734aSAndroid Build Coastguard Worker }
241*8542734aSAndroid Build Coastguard Worker
notifyInterfaceLinkChanged(const std::string & ifName,bool up)242*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyInterfaceLinkChanged(const std::string& ifName, bool up) {
243*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceLinkStateChanged, ifName, up);
244*8542734aSAndroid Build Coastguard Worker }
245*8542734aSAndroid Build Coastguard Worker
notifyQuotaLimitReached(const std::string & labelName,const std::string & ifName)246*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyQuotaLimitReached(const std::string& labelName,
247*8542734aSAndroid Build Coastguard Worker const std::string& ifName) {
248*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onQuotaLimitReached, labelName, ifName);
249*8542734aSAndroid Build Coastguard Worker }
250*8542734aSAndroid Build Coastguard Worker
notifyInterfaceClassActivityChanged(int label,bool isActive,int64_t timestamp,int uid)251*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyInterfaceClassActivityChanged(int label, bool isActive,
252*8542734aSAndroid Build Coastguard Worker int64_t timestamp, int uid) {
253*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceClassActivityChanged, isActive, label, timestamp, uid);
254*8542734aSAndroid Build Coastguard Worker }
255*8542734aSAndroid Build Coastguard Worker
notifyAddressUpdated(const std::string & addr,const std::string & ifName,int flags,int scope)256*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyAddressUpdated(const std::string& addr, const std::string& ifName,
257*8542734aSAndroid Build Coastguard Worker int flags, int scope) {
258*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceAddressUpdated, addr, ifName, flags, scope);
259*8542734aSAndroid Build Coastguard Worker }
260*8542734aSAndroid Build Coastguard Worker
notifyAddressRemoved(const std::string & addr,const std::string & ifName,int flags,int scope)261*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyAddressRemoved(const std::string& addr, const std::string& ifName,
262*8542734aSAndroid Build Coastguard Worker int flags, int scope) {
263*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceAddressRemoved, addr, ifName, flags, scope);
264*8542734aSAndroid Build Coastguard Worker }
265*8542734aSAndroid Build Coastguard Worker
notifyInterfaceDnsServers(const std::string & ifName,int64_t lifetime,const std::vector<std::string> & servers)266*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyInterfaceDnsServers(const std::string& ifName, int64_t lifetime,
267*8542734aSAndroid Build Coastguard Worker const std::vector<std::string>& servers) {
268*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onInterfaceDnsServerInfo, ifName, lifetime, servers);
269*8542734aSAndroid Build Coastguard Worker }
270*8542734aSAndroid Build Coastguard Worker
notifyRouteChange(bool updated,const std::string & route,const std::string & gateway,const std::string & ifName)271*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyRouteChange(bool updated, const std::string& route,
272*8542734aSAndroid Build Coastguard Worker const std::string& gateway, const std::string& ifName) {
273*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onRouteChanged, updated, route, gateway, ifName);
274*8542734aSAndroid Build Coastguard Worker }
275*8542734aSAndroid Build Coastguard Worker
notifyStrictCleartext(uid_t uid,const std::string & hex)276*8542734aSAndroid Build Coastguard Worker void NetlinkHandler::notifyStrictCleartext(uid_t uid, const std::string& hex) {
277*8542734aSAndroid Build Coastguard Worker NOTIFY_AND_LOG(BINDER_RETRY, onStrictCleartextDetected, uid, hex);
278*8542734aSAndroid Build Coastguard Worker }
279*8542734aSAndroid Build Coastguard Worker
280*8542734aSAndroid Build Coastguard Worker } // namespace net
281*8542734aSAndroid Build Coastguard Worker } // namespace android
282