xref: /aosp_15_r20/hardware/interfaces/radio/1.4/IRadioIndication.hal (revision 4d7e907c777eeecc4c5bd7cf640a754fac206ff7)
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::RadioIndicationType;
20*4d7e907cSAndroid Build Coastguard Workerimport @1.3::IRadioIndication;
21*4d7e907cSAndroid Build Coastguard Worker
22*4d7e907cSAndroid Build Coastguard Worker/**
23*4d7e907cSAndroid Build Coastguard Worker * Interface declaring unsolicited radio indications.
24*4d7e907cSAndroid Build Coastguard Worker */
25*4d7e907cSAndroid Build Coastguard Workerinterface IRadioIndication extends @1.3::IRadioIndication {
26*4d7e907cSAndroid Build Coastguard Worker    /**
27*4d7e907cSAndroid Build Coastguard Worker     * Report the current list of emergency numbers
28*4d7e907cSAndroid Build Coastguard Worker     *
29*4d7e907cSAndroid Build Coastguard Worker     * Each emergency number (@1.4::EmergencyNumber) in the emergency number list contains a
30*4d7e907cSAndroid Build Coastguard Worker     * dialing number, zero or more service category(s), zero or more emergency uniform resource
31*4d7e907cSAndroid Build Coastguard Worker     * names, mobile country code, mobile network code, and source(s) that indicate where it comes
32*4d7e907cSAndroid Build Coastguard Worker     * from.
33*4d7e907cSAndroid Build Coastguard Worker     *
34*4d7e907cSAndroid Build Coastguard Worker     * Radio must report all the valid emergency numbers with known mobile country code, mobile
35*4d7e907cSAndroid Build Coastguard Worker     * network code, emergency service categories, and emergency uniform resource names from all
36*4d7e907cSAndroid Build Coastguard Worker     * available sources including network signaling, sim, modem/oem configuration, and default
37*4d7e907cSAndroid Build Coastguard Worker     * configuration (112 and 911 must be always available; additionally, 000, 08, 110, 999, 118
38*4d7e907cSAndroid Build Coastguard Worker     * and 119 must be available when sim is not present). Radio shall not report emergency numbers
39*4d7e907cSAndroid Build Coastguard Worker     * that are invalid in the current locale. The reported emergency number list must not have
40*4d7e907cSAndroid Build Coastguard Worker     * duplicate @1.4::EmergencyNumber entries. Please refer the documentation of
41*4d7e907cSAndroid Build Coastguard Worker     * @1.4::EmergencyNumber to construct each emergency number to report.
42*4d7e907cSAndroid Build Coastguard Worker     *
43*4d7e907cSAndroid Build Coastguard Worker     * Radio must report the complete list of emergency numbers whenever the emergency numbers in
44*4d7e907cSAndroid Build Coastguard Worker     * the list are changed or whenever the client and the radio server are connected.
45*4d7e907cSAndroid Build Coastguard Worker     *
46*4d7e907cSAndroid Build Coastguard Worker     * Reference: 3gpp 22.101, Section 10 - Emergency Calls;
47*4d7e907cSAndroid Build Coastguard Worker     *            3gpp 24.008, Section 9.2.13.4 - Emergency Number List
48*4d7e907cSAndroid Build Coastguard Worker     *
49*4d7e907cSAndroid Build Coastguard Worker     * @param type Type of radio indication
50*4d7e907cSAndroid Build Coastguard Worker     * @param emergencyNumberList Current list of emergency numbers known to radio.
51*4d7e907cSAndroid Build Coastguard Worker     */
52*4d7e907cSAndroid Build Coastguard Worker    oneway currentEmergencyNumberList(RadioIndicationType type,
53*4d7e907cSAndroid Build Coastguard Worker            vec<EmergencyNumber> emergencyNumberList);
54*4d7e907cSAndroid Build Coastguard Worker
55*4d7e907cSAndroid Build Coastguard Worker    /**
56*4d7e907cSAndroid Build Coastguard Worker     * Report all of the current cell information known to the radio.
57*4d7e907cSAndroid Build Coastguard Worker     *
58*4d7e907cSAndroid Build Coastguard Worker     * @param type Type of radio indication
59*4d7e907cSAndroid Build Coastguard Worker     * @param records Current cell information
60*4d7e907cSAndroid Build Coastguard Worker     */
61*4d7e907cSAndroid Build Coastguard Worker    oneway cellInfoList_1_4(RadioIndicationType type, vec<CellInfo> records);
62*4d7e907cSAndroid Build Coastguard Worker
63*4d7e907cSAndroid Build Coastguard Worker    /**
64*4d7e907cSAndroid Build Coastguard Worker     * Incremental network scan results
65*4d7e907cSAndroid Build Coastguard Worker     */
66*4d7e907cSAndroid Build Coastguard Worker    oneway networkScanResult_1_4(RadioIndicationType type, NetworkScanResult result);
67*4d7e907cSAndroid Build Coastguard Worker
68*4d7e907cSAndroid Build Coastguard Worker    /**
69*4d7e907cSAndroid Build Coastguard Worker     * Indicates physical channel configurations.
70*4d7e907cSAndroid Build Coastguard Worker     *
71*4d7e907cSAndroid Build Coastguard Worker     * An empty configs list indicates that the radio is in idle mode.
72*4d7e907cSAndroid Build Coastguard Worker     *
73*4d7e907cSAndroid Build Coastguard Worker     * @param type Type of radio indication
74*4d7e907cSAndroid Build Coastguard Worker     * @param configs Vector of PhysicalChannelConfigs
75*4d7e907cSAndroid Build Coastguard Worker     */
76*4d7e907cSAndroid Build Coastguard Worker    oneway currentPhysicalChannelConfigs_1_4(RadioIndicationType type,
77*4d7e907cSAndroid Build Coastguard Worker            vec<PhysicalChannelConfig> configs);
78*4d7e907cSAndroid Build Coastguard Worker
79*4d7e907cSAndroid Build Coastguard Worker    /**
80*4d7e907cSAndroid Build Coastguard Worker     * Indicates data call contexts have changed.
81*4d7e907cSAndroid Build Coastguard Worker     *
82*4d7e907cSAndroid Build Coastguard Worker     * @param type Type of radio indication
83*4d7e907cSAndroid Build Coastguard Worker     * @param dcList Array of SetupDataCallResult identical to that returned by
84*4d7e907cSAndroid Build Coastguard Worker     *        IRadio.getDataCallList(). It is the complete list of current data contexts including
85*4d7e907cSAndroid Build Coastguard Worker     *        new contexts that have been activated. A data call is only removed from this list
86*4d7e907cSAndroid Build Coastguard Worker     *        when below conditions matched.
87*4d7e907cSAndroid Build Coastguard Worker     *        1. The framework sends a IRadio.deactivateDataCall().
88*4d7e907cSAndroid Build Coastguard Worker     *        2. The radio is powered off/on.
89*4d7e907cSAndroid Build Coastguard Worker     *        3. Unsolicited disconnect from either modem or network side.
90*4d7e907cSAndroid Build Coastguard Worker     */
91*4d7e907cSAndroid Build Coastguard Worker    oneway dataCallListChanged_1_4(RadioIndicationType type, vec<SetupDataCallResult> dcList);
92*4d7e907cSAndroid Build Coastguard Worker
93*4d7e907cSAndroid Build Coastguard Worker    /**
94*4d7e907cSAndroid Build Coastguard Worker     * Indicates current signal strength of the radio.
95*4d7e907cSAndroid Build Coastguard Worker     *
96*4d7e907cSAndroid Build Coastguard Worker     * @param type Type of radio indication
97*4d7e907cSAndroid Build Coastguard Worker     * @param signalStrength SignalStrength information
98*4d7e907cSAndroid Build Coastguard Worker     */
99*4d7e907cSAndroid Build Coastguard Worker    oneway currentSignalStrength_1_4(RadioIndicationType type, SignalStrength signalStrength);
100*4d7e907cSAndroid Build Coastguard Worker};
101