system/hardware/interfaces
Revisão | 8f840890816dce4ce04cade229d5ab80b850dcea (tree) |
---|---|
Hora | 2018-03-08 22:42:22 |
Autor | Tyler Wear <twear@code...> |
Commiter | Lorenzo Colitti |
Introduce netd 1.1
Additional OEM Network APIs
Bug: 73032258
Test: marlin builds, boots
Test: VtsHalNetNetdV1_1TargetTest, VtsHalNetNetdV1_1TargetTest pass on whole topic
Change-Id: I40b9a8023560aa6db86012ae013e8f6175472162
@@ -0,0 +1,18 @@ | ||
1 | +// This file is autogenerated by hidl-gen -Landroidbp. | |
2 | + | |
3 | +hidl_interface { | |
4 | + name: "android.system.net.netd@1.1", | |
5 | + root: "android.system", | |
6 | + vndk: { | |
7 | + enabled: true, | |
8 | + }, | |
9 | + srcs: [ | |
10 | + "INetd.hal", | |
11 | + ], | |
12 | + interfaces: [ | |
13 | + "android.hidl.base@1.0", | |
14 | + "android.system.net.netd@1.0", | |
15 | + ], | |
16 | + gen_java: true, | |
17 | +} | |
18 | + |
@@ -0,0 +1,118 @@ | ||
1 | +/* | |
2 | + * Copyright 2018 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 | +package android.system.net.netd@1.1; | |
18 | + | |
19 | +import @1.0::INetd; | |
20 | + | |
21 | +/** | |
22 | + * This is the root of the HAL module and is the interface returned when | |
23 | + * loading an implementation of the INetd HAL. | |
24 | + */ | |
25 | +interface INetd extends @1.0::INetd { | |
26 | + /** | |
27 | + * Add route to a specified OEM network | |
28 | + * Either both, or one of the ifname and nexthop must be specified. | |
29 | + * | |
30 | + * @param networkHandle Handle to the OEM network previously returned from | |
31 | + * @1.0::createOemNetwork. | |
32 | + * @param ifname Interface name specified by the route, or an empty | |
33 | + * string for a route that does not specify an | |
34 | + * interface. | |
35 | + * For e.g. "dummy0" | |
36 | + * @param destination The destination prefix of the route in CIDR notation. | |
37 | + * For e.g. 192.0.2.0/24 or 2001:db8:1::/48. | |
38 | + * @param nexthop IP address of the gateway for the route, or an empty | |
39 | + * string for a directly-connected route. If non-empty, | |
40 | + * must be of the same address family as the | |
41 | + * destination. | |
42 | + * For e.g. 10.0.0.1 or 2001:db8:1::cafe. | |
43 | + */ | |
44 | + @callflow(next={"*"}) | |
45 | + addRouteToOemNetwork(uint64_t networkHandle, string ifname, | |
46 | + string destination, string nexthop) | |
47 | + generates (StatusCode status); | |
48 | + | |
49 | + /** | |
50 | + * Remove route from a specified OEM network. | |
51 | + * Either both, or one of the ifname and nexthop must be specified. | |
52 | + * | |
53 | + * @param networkHandle Handle to the OEM network previously returned from | |
54 | + * @1.0::createOemNetwork. | |
55 | + * @param ifname Interface name specified by the route, or an empty | |
56 | + * string for a route that does not specify an | |
57 | + * interface. | |
58 | + * For e.g. "dummy0" | |
59 | + * @param destination The destination prefix of the route in CIDR notation. | |
60 | + * For e.g. 192.0.2.0/24 or 2001:db8:1::/48. | |
61 | + * @param nexthop IP address of the gateway for the route, or an empty | |
62 | + * string for a directly-connected route. If non-empty, | |
63 | + * must be of the same address family as the | |
64 | + * destination. | |
65 | + * For e.g. 10.0.0.1 or 2001:db8:1::cafe. | |
66 | + */ | |
67 | + @callflow(next={"*"}) | |
68 | + removeRouteFromOemNetwork(uint64_t networkHandle, string ifname, | |
69 | + string destination, string nexthop) | |
70 | + generates (StatusCode status); | |
71 | + | |
72 | + /** | |
73 | + * Add interface to a specified OEM network | |
74 | + * | |
75 | + * @param networkHandle Handle to the OEM network previously returned from | |
76 | + * @1.0::createOemNetwork. | |
77 | + * @param ifname Interface name to add to the OEM network. | |
78 | + * For e.g. "dummy0". | |
79 | + */ | |
80 | + @callflow(next={"*"}) | |
81 | + addInterfaceToOemNetwork(uint64_t networkHandle, string ifname) | |
82 | + generates (StatusCode status); | |
83 | + | |
84 | + /** | |
85 | + * Remove interface from a specified OEM network. | |
86 | + * | |
87 | + * @param networkHandle Handle to the OEM network previously returned from | |
88 | + * @1.0::createOemNetwork. | |
89 | + * @param ifname Interface name to remove from the OEM network. | |
90 | + * For e.g. "dummy0". | |
91 | + */ | |
92 | + @callflow(next={"*"}) | |
93 | + removeInterfaceFromOemNetwork(uint64_t networkHandle, string ifname) | |
94 | + generates (StatusCode status); | |
95 | + | |
96 | + /** | |
97 | + * Enable IP forwarding on the system. Client must disable forwarding when | |
98 | + * it's no longer needed. | |
99 | + * | |
100 | + * @param enable bool to enable or disable forwarding. | |
101 | + */ | |
102 | + @callflow(next={"*"}) | |
103 | + setIpForwardEnable(bool enable) generates (StatusCode status); | |
104 | + | |
105 | + /** | |
106 | + * Enables forwarding between two interfaces, one of which must be in an | |
107 | + * OEM network. | |
108 | + * | |
109 | + * @param inputIfName Input interface. For e.g. "dummy0". | |
110 | + * @param outputIfName Output interface. For e.g. "rmnet_data7". | |
111 | + * @param enable bool to enable or disable forwarding between the | |
112 | + * two interfaces. | |
113 | + */ | |
114 | + @callflow(next={"*"}) | |
115 | + setForwardingBetweenInterfaces(string inputIfName, string outputIfName, | |
116 | + bool enable) | |
117 | + generates (StatusCode status); | |
118 | +}; |