/* * Copyright (C) 2018 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.hardware.gnss@2.0; import @1.0::IAGnssRil; /** * Extended interface for AGNSS RIL support. An Assisted GNSS Radio Interface * Layer interface allows the GNSS chipset to request radio interface layer * information from Android platform. Examples of such information are reference * location, unique subscriber ID, phone number string and network availability changes. */ interface IAGnssRil extends @1.0::IAGnssRil { /** Flags to indicate capabilities of the network */ enum NetworkCapability : uint16_t { /** Network is not metered. */ NOT_METERED = 1 << 0, /** Network is not roaming. */ NOT_ROAMING = 1 << 1 }; /** Represents network connection status and capabilities. */ struct NetworkAttributes { /** Network handle of the network for use with the NDK API. */ net_handle_t networkHandle; /** * True indicates that network connectivity exists and it is possible to * establish connections and pass data. If false, only the networkHandle field * is populated to indicate that this network has just disconnected. */ bool isConnected; /** A set of flags indicating the capabilities of this network. */ bitfield<NetworkCapability> capabilities; /** * Telephony preferred Access Point Name to use for carrier data connection when * connected to a cellular network. Empty string, otherwise. */ string apn; }; /** * Notifies GNSS of network status changes. * * The framework calls this method to update the GNSS HAL implementation of network * state changes. The methods updateNetworkState() and updateNetworkAvailability * in @1.0::IAGnssRil are deprecated and are not called by the framework. * * @param attributes Updated network attributes. * * @return success True if all parameters were valid and the operation was * successful. */ updateNetworkState_2_0(NetworkAttributes attributes) generates (bool success); };