1 /* 2 * Copyright (C) 2006 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 com.android.internal.telephony; 18 19 /** 20 * Call fail causes from TS 24.008 . 21 * These are mostly the cause codes we need to distinguish for the UI. 22 * See 22.001 Annex F.4 for mapping of cause codes to local tones. 23 * 24 * CDMA call failure reasons are derived from the possible call failure scenarios described 25 * in "CDMA IS2000 - Release A (C.S0005-A v6.0)" standard. 26 * 27 * The detailed fail causes are defined in ITU Recommendation Q.850. 28 * 29 * {@hide} 30 * 31 */ 32 public interface CallFailCause { 33 // The disconnect cause is not valid (Not received a disconnect cause) 34 int NOT_VALID = -1; 35 36 // Unassigned/Unobtainable number 37 int UNOBTAINABLE_NUMBER = 1; 38 39 int NO_ROUTE_TO_DEST = 3; 40 int CHANNEL_UNACCEPTABLE = 6; 41 int OPERATOR_DETERMINED_BARRING = 8; 42 int NORMAL_CLEARING = 16; 43 int USER_BUSY = 17; 44 int NO_USER_RESPONDING = 18; 45 46 /** 47 * This cause is used when the called party has been alerted but does not respond with a connect 48 * indication within a prescribed period of time. Note - This cause is not necessarily generated 49 * by Q.931 procedures but may be generated by internal network timers. 50 */ 51 int USER_ALERTING_NO_ANSWER = 19; 52 53 /** 54 * The equipment sending this cause does not wish to accept this call, although it could have 55 * accepted the call because the equipment sending this cause is neither busy nor incompatible. 56 * The network may also generate this cause, indicating that the call was cleared due to a 57 * supplementary service constraint. The diagnostic field may contain additional information 58 * about the supplementary service and reason for rejection. 59 */ 60 int CALL_REJECTED = 21; 61 62 int NUMBER_CHANGED = 22; 63 int PRE_EMPTION = 25; 64 65 // The user has not been awarded the incoming call. 66 int NON_SELECTED_USER_CLEARING = 26; 67 68 int DESTINATION_OUT_OF_ORDER = 27; 69 70 // Incomplete number 71 int INVALID_NUMBER_FORMAT = 28; 72 73 // Supplementary service requested by the user cannot be provide by the network. 74 int FACILITY_REJECTED = 29; 75 76 int STATUS_ENQUIRY = 30; 77 int NORMAL_UNSPECIFIED = 31; 78 int NO_CIRCUIT_AVAIL = 34; 79 80 // Resource unavailable 81 int NETWORK_OUT_OF_ORDER = 38; 82 int TEMPORARY_FAILURE = 41; 83 int SWITCHING_CONGESTION = 42; 84 int ACCESS_INFORMATION_DISCARDED = 43; 85 int CHANNEL_NOT_AVAIL = 44; 86 int RESOURCES_UNAVAILABLE_UNSPECIFIED = 47; 87 int QOS_NOT_AVAIL = 49; 88 89 // Service or option unavailable 90 /** 91 * The user has requested a supplementary service, which is available, but the user is not 92 * authorized to use. 93 */ 94 int REQUESTED_FACILITY_NOT_SUBSCRIBED = 50; 95 /** 96 * Although the called party is a member of the CUG (Closed User Group) for the incoming CUG 97 * call, incoming calls are not allowed to this member of the CUG. 98 */ 99 int INCOMING_CALL_BARRED_WITHIN_CUG = 55; 100 int BEARER_CAPABILITY_NOT_AUTHORISED = 57; 101 int BEARER_NOT_AVAIL = 58; 102 /** 103 * This cause is used to report a service or option not available event only when no other cause 104 * between 49-62 (where a service or option is unavailable) applies. 105 */ 106 int SERVICE_OR_OPTION_NOT_AVAILABLE = 63; 107 int BEARER_SERVICE_NOT_IMPLEMENTED = 65; 108 109 // Service or option not implemented 110 int ACM_LIMIT_EXCEEDED = 68; 111 int REQUESTED_FACILITY_NOT_IMPLEMENTED = 69; 112 /** 113 * The calling party has requested an unrestricted bearer service but that the equipment sending 114 * this cause only supports the restricted version of the requested bearer capability. 115 */ 116 int ONLY_RESTRICTED_DIGITAL_INFO_BC_AVAILABLE = 70; 117 int SERVICE_OR_OPTION_NOT_IMPLEMENTED = 79; 118 int INVALID_TRANSACTION_ID_VALUE = 81; 119 120 // Invalid message 121 int USER_NOT_MEMBER_OF_CUG = 87; 122 int INCOMPATIBLE_DESTINATION = 88; 123 int INVALID_TRANSIT_NETWORK_SELECTION = 91; 124 int SEMANTICALLY_INCORRECT_MESSAGE = 95; 125 int INVALID_MANDATORY_INFORMATION = 96; 126 127 // Protocol error 128 int MESSAGE_TYPE_NON_EXISTENT = 97; 129 int MESSAGE_TYPE_NOT_COMPATIBLE_WITH_PROT_STATE = 98; 130 int IE_NON_EXISTENT_OR_NOT_IMPLEMENTED = 99; 131 /** 132 * The equipment sending this cause has received an information element which it has 133 * implemented; however, one or more fields in the information element are coded in such a way 134 * which has not been implemented by the equipment sending this cause. 135 */ 136 int CONDITIONAL_IE_ERROR = 100; 137 int MESSAGE_NOT_COMPATIBLE_WITH_PROTOCOL_STATE = 101; 138 int RECOVERY_ON_TIMER_EXPIRY = 102; 139 int PROTOCOL_ERROR_UNSPECIFIED = 111; 140 int INTERWORKING_UNSPECIFIED = 127; 141 142 // Others 143 int CALL_BARRED = 240; 144 int FDN_BLOCKED = 241; 145 int IMEI_NOT_ACCEPTED = 243; 146 147 // Stk Call Control 148 int DIAL_MODIFIED_TO_USSD = 244; 149 int DIAL_MODIFIED_TO_SS = 245; 150 int DIAL_MODIFIED_TO_DIAL = 246; 151 152 //Access class blocked - TS 31.121 5.2.1 153 int ACCESS_CLASS_BLOCKED = 260; 154 155 //Emergency Redial 156 int EMERGENCY_TEMP_FAILURE = 325; 157 int EMERGENCY_PERM_FAILURE = 326; 158 159 int CDMA_LOCKED_UNTIL_POWER_CYCLE = 1000; 160 int CDMA_DROP = 1001; 161 int CDMA_INTERCEPT = 1002; 162 int CDMA_REORDER = 1003; 163 int CDMA_SO_REJECT = 1004; 164 int CDMA_RETRY_ORDER = 1005; 165 int CDMA_ACCESS_FAILURE = 1006; 166 int CDMA_PREEMPTED = 1007; 167 168 // For non-emergency number dialed while in emergency callback mode. 169 int CDMA_NOT_EMERGENCY = 1008; 170 171 // Access Blocked by CDMA Network. 172 int CDMA_ACCESS_BLOCKED = 1009; 173 174 int ERROR_UNSPECIFIED = 0xffff; 175 176 } 177