1*4d7e907cSAndroid Build Coastguard Worker/* 2*4d7e907cSAndroid Build Coastguard Worker * Copyright (C) 2018 The Android Open Source Project 3*4d7e907cSAndroid Build Coastguard Worker * 4*4d7e907cSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*4d7e907cSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*4d7e907cSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*4d7e907cSAndroid Build Coastguard Worker * 8*4d7e907cSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*4d7e907cSAndroid Build Coastguard Worker * 10*4d7e907cSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*4d7e907cSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*4d7e907cSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*4d7e907cSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*4d7e907cSAndroid Build Coastguard Worker * limitations under the License. 15*4d7e907cSAndroid Build Coastguard Worker */ 16*4d7e907cSAndroid Build Coastguard Worker 17*4d7e907cSAndroid Build Coastguard Workerpackage [email protected]; 18*4d7e907cSAndroid Build Coastguard Worker 19*4d7e907cSAndroid Build Coastguard Workerimport @1.0::IAGnssRil; 20*4d7e907cSAndroid Build Coastguard Worker 21*4d7e907cSAndroid Build Coastguard Worker/** 22*4d7e907cSAndroid Build Coastguard Worker * Extended interface for AGNSS RIL support. An Assisted GNSS Radio Interface 23*4d7e907cSAndroid Build Coastguard Worker * Layer interface allows the GNSS chipset to request radio interface layer 24*4d7e907cSAndroid Build Coastguard Worker * information from Android platform. Examples of such information are reference 25*4d7e907cSAndroid Build Coastguard Worker * location, unique subscriber ID, phone number string and network availability changes. 26*4d7e907cSAndroid Build Coastguard Worker */ 27*4d7e907cSAndroid Build Coastguard Workerinterface IAGnssRil extends @1.0::IAGnssRil { 28*4d7e907cSAndroid Build Coastguard Worker /** Flags to indicate capabilities of the network */ 29*4d7e907cSAndroid Build Coastguard Worker enum NetworkCapability : uint16_t { 30*4d7e907cSAndroid Build Coastguard Worker /** Network is not metered. */ 31*4d7e907cSAndroid Build Coastguard Worker NOT_METERED = 1 << 0, 32*4d7e907cSAndroid Build Coastguard Worker /** Network is not roaming. */ 33*4d7e907cSAndroid Build Coastguard Worker NOT_ROAMING = 1 << 1 34*4d7e907cSAndroid Build Coastguard Worker }; 35*4d7e907cSAndroid Build Coastguard Worker 36*4d7e907cSAndroid Build Coastguard Worker /** Represents network connection status and capabilities. */ 37*4d7e907cSAndroid Build Coastguard Worker struct NetworkAttributes { 38*4d7e907cSAndroid Build Coastguard Worker /** Network handle of the network for use with the NDK API. */ 39*4d7e907cSAndroid Build Coastguard Worker net_handle_t networkHandle; 40*4d7e907cSAndroid Build Coastguard Worker 41*4d7e907cSAndroid Build Coastguard Worker /** 42*4d7e907cSAndroid Build Coastguard Worker * True indicates that network connectivity exists and it is possible to 43*4d7e907cSAndroid Build Coastguard Worker * establish connections and pass data. If false, only the networkHandle field 44*4d7e907cSAndroid Build Coastguard Worker * is populated to indicate that this network has just disconnected. 45*4d7e907cSAndroid Build Coastguard Worker */ 46*4d7e907cSAndroid Build Coastguard Worker bool isConnected; 47*4d7e907cSAndroid Build Coastguard Worker 48*4d7e907cSAndroid Build Coastguard Worker /** A set of flags indicating the capabilities of this network. */ 49*4d7e907cSAndroid Build Coastguard Worker bitfield<NetworkCapability> capabilities; 50*4d7e907cSAndroid Build Coastguard Worker 51*4d7e907cSAndroid Build Coastguard Worker /** 52*4d7e907cSAndroid Build Coastguard Worker * Telephony preferred Access Point Name to use for carrier data connection when 53*4d7e907cSAndroid Build Coastguard Worker * connected to a cellular network. Empty string, otherwise. 54*4d7e907cSAndroid Build Coastguard Worker */ 55*4d7e907cSAndroid Build Coastguard Worker string apn; 56*4d7e907cSAndroid Build Coastguard Worker }; 57*4d7e907cSAndroid Build Coastguard Worker 58*4d7e907cSAndroid Build Coastguard Worker /** 59*4d7e907cSAndroid Build Coastguard Worker * Notifies GNSS of network status changes. 60*4d7e907cSAndroid Build Coastguard Worker * 61*4d7e907cSAndroid Build Coastguard Worker * The framework calls this method to update the GNSS HAL implementation of network 62*4d7e907cSAndroid Build Coastguard Worker * state changes. The methods updateNetworkState() and updateNetworkAvailability 63*4d7e907cSAndroid Build Coastguard Worker * in @1.0::IAGnssRil are deprecated and are not called by the framework. 64*4d7e907cSAndroid Build Coastguard Worker * 65*4d7e907cSAndroid Build Coastguard Worker * @param attributes Updated network attributes. 66*4d7e907cSAndroid Build Coastguard Worker * 67*4d7e907cSAndroid Build Coastguard Worker * @return success True if all parameters were valid and the operation was 68*4d7e907cSAndroid Build Coastguard Worker * successful. 69*4d7e907cSAndroid Build Coastguard Worker */ 70*4d7e907cSAndroid Build Coastguard Worker updateNetworkState_2_0(NetworkAttributes attributes) generates (bool success); 71*4d7e907cSAndroid Build Coastguard Worker}; 72