blob: 4ce9eb1c6ea9bff7a60cbdd3633a842fe7f46418 [file] [log] [blame]
Robert Greenwaltc4621772012-01-31 12:46:45 -08001/*
2 * Copyright (C) 2012 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef _NETD_CONSTANTS_H
18#define _NETD_CONSTANTS_H
19
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070020#include <string>
21#include <list>
Erik Kline46ae27c2016-08-03 11:24:27 +090022#include <ifaddrs.h>
23#include <netdb.h>
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070024#include <stdarg.h>
Lorenzo Colitti699aa992016-04-15 10:22:37 +090025
26#include <chrono>
27
Felipe Leme5ebbbd82016-03-07 09:25:50 -080028#include <private/android_filesystem_config.h>
Robert Greenwaltc4621772012-01-31 12:46:45 -080029
Lorenzo Colittie4d626e2016-02-02 17:19:04 +090030#include "utils/RWLock.h"
31
Chad Brubaker2a390122014-02-19 17:51:05 -080032const int PROTECT_MARK = 0x1;
Felipe Leme5ebbbd82016-03-07 09:25:50 -080033const int MAX_SYSTEM_UID = AID_APP - 1;
Chad Brubaker2a390122014-02-19 17:51:05 -080034
Robert Greenwaltc4621772012-01-31 12:46:45 -080035extern const char * const IPTABLES_PATH;
JP Abgrall0031cea2012-04-17 16:38:23 -070036extern const char * const IP6TABLES_PATH;
Devi Sandeep Endluri V V9afc4f92016-10-13 13:15:17 +053037extern const char * const IPTABLES_RETRY_INTERVAL;
Robert Greenwaltc4621772012-01-31 12:46:45 -080038extern const char * const IP_PATH;
39extern const char * const TC_PATH;
40extern const char * const OEM_SCRIPT_PATH;
41extern const char * const ADD;
42extern const char * const DEL;
43
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070044enum IptablesTarget { V4, V6, V4V6 };
45
46int execIptables(IptablesTarget target, ...);
47int execIptablesSilently(IptablesTarget target, ...);
Lorenzo Colitti89faa342016-02-26 11:38:47 +090048int execIptablesRestore(IptablesTarget target, const std::string& commands);
JP Abgrall69261cb2014-06-19 18:35:24 -070049bool isIfaceName(const char *name);
Lorenzo Colittiba25df92014-06-18 00:22:17 +090050int parsePrefix(const char *prefix, uint8_t *family, void *address, int size, uint8_t *prefixlen);
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070051
Rom Lemarchand001f0a42013-01-31 12:41:03 -080052#define ARRAY_SIZE(a) (sizeof(a) / sizeof(*(a)))
53
Lorenzo Colittia10ac322014-04-11 18:26:17 +090054#define __INT_STRLEN(i) sizeof(#i)
55#define _INT_STRLEN(i) __INT_STRLEN(i)
Lorenzo Colitti0a3eb852016-02-23 16:59:21 +090056#define INT32_STRLEN _INT_STRLEN(INT32_MIN)
Lorenzo Colittia10ac322014-04-11 18:26:17 +090057#define UINT32_STRLEN _INT_STRLEN(UINT32_MAX)
58#define UINT32_HEX_STRLEN sizeof("0x12345678")
59
Sreeram Ramachandranf4f6c8d2014-06-23 09:54:06 -070060#define WARN_UNUSED_RESULT __attribute__((__warn_unused_result__))
61
Sreeram Ramachandranb1425cc2014-06-23 18:54:27 -070062const uid_t INVALID_UID = static_cast<uid_t>(-1);
63
Erik Kline46ae27c2016-08-03 11:24:27 +090064
65struct AddrinfoDeleter {
66 void operator()(struct addrinfo* p) const {
67 if (p != nullptr) {
68 freeaddrinfo(p);
69 }
70 }
71};
72
73typedef std::unique_ptr<struct addrinfo, struct AddrinfoDeleter> ScopedAddrinfo;
74
75
76struct IfaddrsDeleter {
77 void operator()(struct ifaddrs *p) const {
78 if (p != nullptr) {
79 freeifaddrs(p);
80 }
81 }
82};
83
84typedef std::unique_ptr<struct ifaddrs, struct IfaddrsDeleter> ScopedIfaddrs;
85
Lorenzo Colittie4d626e2016-02-02 17:19:04 +090086namespace android {
87namespace net {
88
89/**
90 * This lock exists to make NetdNativeService RPCs (which come in on multiple Binder threads)
91 * coexist with the commands in CommandListener.cpp. These are presumed not thread-safe because
92 * CommandListener has only one user (NetworkManagementService), which is connected through a
93 * FrameworkListener that passes in commands one at a time.
94 */
95extern android::RWLock gBigNetdLock;
96
97} // namespace net
98} // namespace android
99
100#endif // _NETD_CONSTANTS_H