Internet Protocol Multimedia Subsystem (IMS) is an architectural framework for delivering Internet Protocol (IP) multimedia to devices of users who subscribe to services of a telecommunication service provider. A user can utilize his/her device (or, user equipment (UE)) to communicate with other devices via the IMS core. However, before a UE can access services via the IMS core, the UE performs a registration procedure, called IMS registration. Moreover, the 3rd generation partnership project (3GPP) TS 24.299 and Request for Comments (RFC) 3261 define a timer called “Timer F” for use during IMS registration so that, if registration is taking longer than expected, the UE does not wait indefinitely for a response from the IMS core. Timer F is described as a “non-INVITE transaction timeout timer”, and it is triggered when the UE initiates the registration procedure (e.g., when the UE sends a Session Initiation Protocol (SIP) request using the SIP REGISTER method). If registration does not succeed, Timer F will expire after a period of time (typically 128 seconds), and, after Timer F expires, the UE can then take steps to attempt registration using a different approach.
In a scenario where a user attempts to make a phone call while IMS registration is still pending, and where IMS registration is taking longer than expected, the user can be subjected to a long wait time before the call is eventually established. This is primarily due to the 128-second duration of Timer F. In some cases, a user may have to wait as long as 5 to 10 minutes before the user can make or receive a call. For example, if IMS registration is unsuccessful via a first proxy call session control function (P-CSCF) node, after waiting 128 seconds for Timer F to expire, the UE might attempt registration on a second P-CSCF node, and so on and so forth, potentially attempting registration via three or more P-CSCF nodes before attempting to register on a network of a roaming partner or a legacy radio network. Moreover, in order to give the network time to recover, the UE may be configured wait for progressively-longer time periods between successive registration attempts, thereby adding to the total wait time experienced by the user. The average user can only tolerate a certain amount of wait time to make a call, and users should not have to wait several minutes before a call can be made. Although shortening the duration of Timer F would appear to solve this problem, it is not a suitable solution because the 128-second duration of Timer F serves other valid purposes. For instance, the current implementation of Timer F may ensure that millions of UEs do not all leave the network at the same time when short delays are encountered early in the registration process. In view of the foregoing, users may experience prolonged wait times before being able to make a call, which leads to a poor user experience.
The detailed description is set forth with reference to the accompanying figures, in which the left-most digit of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items or features.
Described herein are techniques and systems for implementing one or more timers while a UE is registering for one or more services of a telecommunication service provider. In some embodiments, a timer (referred to herein as “Timer F1”) may be used as a “guard timer” for Timer F (as defined in 3GPP TS 24.299 and RFC 3261) in instances where Timer F is used during registration for a UE. That is, the disclosed Timer F1 may “speed up” Timer F in instances where a user is attempting to establish a communication session (e.g., make a call) during registration. For example, Timer F1 may “speed up” Timer F by causing Timer F to expire prematurely, thereby accelerating IMS restoration so that a session (e.g., a call) can be established more quickly in instances where an initial problem in the network is causing registration to take longer than expected.
Timer F1 may be started and stopped by particular events, as described herein, which may occur during registration. For example, Timer F1 may be configured to start in response to a UE receiving user input to establish a communication session (e.g., when a user attempts to make a call) during registration. In other words, Timer F1 may be triggered if the UE receives user input to establish a communication session after the UE has sent a first registration request and prior to the UE receiving a response indicating a result of the first registration request. Furthermore, Timer F1 may be configured to stop in response to the UE receiving a response indicating a successful registration (e.g., when IMS registration successfully completes), such as by the UE receiving a 200 (OK) SIP response prior to the expiration of the Timer F1. The duration of Timer F1 can be shorter than the duration of Timer F. In this manner, Timer F1 may act as a guard timer that expedites the expiration of Timer F in a particular scenario. For example, Timer F1 may be configured to expire after a period of time within a range of about 5 seconds to 10 seconds, which is shorter than the typical 128-second duration of Timer F.
If Timer F1 expires during registration, an IMS restoration procedure may be performed to attempt registration using a different approach in hopes of establishing the communication session for the UE. Because Timer F1 is of a shorter duration than Timer F, this IMS restoration procedure is expedited based on the user's attempt to establish the communication session (e.g., the user making a call attempt). In an illustrative example, the IMS restoration procedure performed at the expiry of Timer F1 may involve traversing through a list of available P-CSCF nodes in an attempt to register via one of those P-CSCF nodes, and, if registration is successful via a P-CSCF node on the list, the UE may establish the communication session via that P-CSCF node. Additionally, or alternatively, if Timer F1 expires while attempting to register via a current P-CSCF node of a first network, the IMS restoration procedure may involve attempting registration via a second, different network than the first network, such as a network of a roaming partner, a legacy radio network operated by the telecommunication service provider, or the like.
An example process to be implemented by a device, such as a UE, can include sending, to a first node of a first network, a first request to register for one or more services of a telecommunication service provider, receiving user input to establish a communication session prior to receiving a response indicating a result of the first request to register for the one or more services, and starting a timer (e.g., Timer F1) in response to receiving the user input. The timer is configured to expire after a period of time and to stop in response to the device receiving a response indicating a successful registration prior to expiration of the timer. After starting the timer, if the device receives a response indicating a successful registration prior to expiration of the timer, the device stops the timer and establishes the communication session via the first node of the first network. If, however, the timer expires prior to the device receiving such a response, the device may initiate an IMS restoration procedure by, for example, sending a second request to register for the one or more services to at least one of: (i) a second node of the first network, or (ii) a node of a second network.
Also disclosed herein are systems and devices comprising one or more processors and one or more memories, as well as non-transitory computer-readable media storing computer-executable instructions that, when executed, by one or more processors perform various acts and/or processes disclosed herein.
The use of Timer F1 during registration decreases the time that the UE (and, hence, the user) waits for successful registration in instances where the UE becomes aware that the user clearly wants to use a service (e.g., make a call). That is, when a user attempts to establish a communication session (e.g., make a call) during registration, instead of waiting the full 128-second time period for Timer F to expire, the UE truncates the time period of Timer F, and, if registration is still unsuccessful at the expiry of that truncated time period, IMS restoration can be initiated, thereby expediting the establishment of the session (e.g., call) on behalf of the subscriber. Although session establishment may be somewhat delayed by waiting for Timer F1 to expire, the use of Timer F1 improves the user experience overall by shortening the wait time to establish the communication session, thereby providing a more stable telecommunications network. In some embodiments, the techniques, devices, and systems described herein may allow one or more devices to conserve resources with respect to processing resources, memory resources, networking resources, power resources, etc., in the various ways described herein. For example, by selectively expediting IMS restoration for select users who are eager to establish a communication session (e.g., make a call), networking resources are conserved for those select users.
It is to be appreciated that the “nodes” depicted in
In accordance with various embodiments described herein, the terms “user equipment (UE),” “wireless communication device,” “wireless device,” “communication device,” “mobile device,” “client device,” “computing device,” “electronic device,” “user device,” and “device” may be used interchangeably herein to describe any UE (e.g., the originating UE 100) that is capable of transmitting/receiving data wirelessly using any suitable wireless communications/data technology, protocol, or standard, such as Global System for Mobile Communications (GSM), Time Division Multiple Access (TDMA), Universal Mobile Telecommunications System (UMTS), Evolution-Data Optimized (EVDO), Long Term Evolution (LTE), Advanced LTE (LTE+), Generic Access Network (GAN), Unlicensed Mobile Access (UMA), Code Division Multiple Access (CDMA), Orthogonal Frequency Division Multiple Access (OFDM), General Packet Radio Service (GPRS), Enhanced Data GSM Environment (EDGE), Advanced Mobile Phone System (AMPS), High Speed Packet Access (HSPA), evolved HSPA (HSPA+), Voice over IP (VoIP), Voice over LTE (VoLTE)—e.g., fourth Generation (4G), voice over New Radio (VoNR)—e.g., fifth Generation (5G), IEEE 802.1x protocols, WiMAX, Wi-Fi, Data Over Cable Service Interface Specification (DOCSIS), digital subscriber line (DSL), and/or any future IP-based network technology or evolution of an existing IP-based network technology. The originating UE 100 may be implemented as any suitable type of computing device configured to communicate over a wireless network, including, without limitation, a mobile phone (e.g., a smart phone/handset), a tablet computer, a laptop computer, a portable digital assistant (PDA), a wearable computer (e.g., electronic/smart glasses, a smart watch, fitness trackers, head-mounted display (HMD), etc.), an in-vehicle (e.g., in-car) computer, and/or any similar mobile device, as well as situated computing devices including, without limitation, a television (smart television), set-top-box (STB), desktop computer, and the like.
In general, a user can utilize the UE 100 to communicate with other computing devices of a telecommunications network via an IMS core. The IMS core is sometimes referred to herein as “IMS core network,” “IMS network,” “Core Network (CN),” or “IM CN Subsystem”. The IMS core can be maintained and/or operated by one or more service providers, such as one or more telecommunication service providers (or “wireless carriers,” “operators,” etc.), that provide IMS-based services to users (sometimes called “subscribers”) who are associated with UEs, such as the originating UE 100. For example, a service provider may offer multimedia telephony services that allow a subscribed user to call or message other users via an IMS core using his/her UE. A user can also utilize an associated UE to receive, provide, or otherwise interact with various different IMS-based services by accessing computing devices of an IMS core. In this manner, an operator of an IMS core may offer any type of IMS-based service, such as, telephony services, emergency services (e.g., E911), gaming services, instant messaging services, presence services, video conferencing services, social networking and sharing services, location-based services, push-to-talk services, real-time text (RTT) services, and so on. The P-CSCF nodes 102(1)-(Q) may be part of the IMS core associated with a common network 106 (e.g., a 5G NR network). In order to access IMS-based services, a UE is configured to request establishment of a communication session. In the case of telephony services, the communication session can comprise a call (i.e., a voice-based communication session, such as a VoNR (5G) call).
The originating UE 100 is configured to utilize various access networks, including radio access networks (RANs) and/or radio access technologies (RATs), in order to access the IMS core. UEs that are 5G NR-compliant may be configured to communicate with heterogeneous cellular networks by employing radios that can communicate over 5G systems (or “5G networks”) as well as over legacy or predecessor systems (or “legacy networks”) relative to 5G systems. Similarly, UEs that are 4G LTE-compliant may be configured to communicate within heterogeneous cellular networks by employing radios that can communicate over LTE systems (or “LTE networks”) as well as over legacy or predecessor systems (or “legacy networks”) relative to 4G systems. Today's legacy networks, such as third generation (3G), and second generation (2G) networks, may employ circuit-switching for voice communications, while 5G and 4G LTE networks employ packet-switching for both data and voice communications in an all-IP data transport technology. In general, 4G LTE-compliant and 5G NR-compliant UEs are configured to prefer attachment to corresponding networks, which offer relatively high data-rate throughput as compared to available legacy or predecessor networks. In most UEs, a choice of which protocol to employ depends primarily on what networks are available to the UE at the UE's present geographic location. Furthermore, in instances where the preferred network (e.g., 4G, 5G, etc.) is unavailable or unusable for any reason, legacy networks, if available, may be used as a fallback protocol, such as by using a circuit-switch fallback (CSFB) mechanism. The originating LE 100 of
As used herein, a “request” is a message that is sent from a UE, such as the originating UE 100, to a network node (e.g., a node of the IMS core, such as a P-CSCF node 102). Meanwhile, a “response” is a message that is sent from a network node to a UE, such as the originating UE 100. This construct may be used when discussing communications that use any particular signaling protocol. For example, SIP may be used by the originating UE 100 for transmitting messages to/from the IMS core. Accordingly, a “SIP request” is a message that is sent from a UE, such as the originating UE 100, to the IMS core using SIP protocol, and a “SIP response” is a message that is sent from the IMS core to a UE, such as the originating UE 100, using SIP protocol. SIP is a signaling protocol that can be used to establish, modify, and terminate multimedia sessions (e.g., a multimedia telephony call, an emergency call, etc.) over packet networks, and to authenticate access to IMS-based services. Accordingly, the originating UE 100 may send a first SIP request 108(1) using the SIP REGISTER method as part of the initial procedures for registration, which is to be completed before the UE 100 can establish a communication session to access one or more IMS-based services. The IMS core allows for peer-to-peer communications, as well as client-to-server communications over an IP-based network. Accordingly, the IMS core can represent any type of SIP-based network that is configured to handle/process SIP signaling packets or messages.
As shown in
The first timer 104(1) (Timer F) is, per 3GPP standard, configured to start whenever the originating UE 100 sends a registration request. This registration request can be a request to register for one or more services of a telecommunication service provider, a request to register for one or more IMS-based services via the IMS core of the network 106, or the like. In the example of
The second timer 104(2) (Timer F1) is configured to start in response to the originating UE 100 receiving, at a particular time, user input to establish a communication session (sometimes referred to herein as a “call event” or a “call attempt”). That is, the user input is a trigger event for the second timer 104(2) (Timer F1) if that user input is received (or detected) by the UE 100 at a time between (i) sending a request to register for one or more services of a telecommunication service provider (e.g., sending a SIP request 108 using the SIP REGISTER method), and (ii) receiving a response indicating a result of the request to register for the one or more services, such as a 200 (OK) SIP response indicating a successful registration. Said another way, the second timer 104(2) (Timer F1) may be triggered to start if a call event/attempt occurs while the first timer 104(1) (Timer F) is active or “running”. Furthermore, the second timer 104(2) (Timer F1) is configured to restart in response to the originating UE 100 receiving subsequent user input to establish a communication session, so long as the user input is received within the above-noted time window for each subsequent registration request. In some examples, the UE 100 is configured to check a state machine of the UE's IMS stack to determine the state of registration. In the example of
A timer value defines a period of time (e.g., N seconds for the first timer 104(1) (Timer F) and P seconds for the second timer 104(2) (Timer F1), where N>P) after which the timer 104 will expire, as measured from the time of starting the timer 104, which occurs in response to the relevant trigger event for the timer 104. The timer value may be specified in any suitable unit of time (e.g., seconds, milliseconds, minutes, etc.). In some embodiments, the timer value of N seconds for the first timer 104(1) (Timer F) is set to a value of 128 seconds (or 64*T1, where T1 is defined in 3GPP TS 24.229 as being set to a value of 2 seconds by default). In some embodiments, the timer value of P seconds for the second timer 104(2) (Timer F1) may be within a range of about 5 seconds to 10 seconds. Therefore, the timer value, P, for the second timer 104(2) (Timer F1) may be less than the timer value, N, for the first timer 104(1) (Timer F), meaning that the second timer 104(2) (Timer F1) will expire before the first timer 104(1) (Timer F) as long as more than P seconds remain on the first timer 104(1) (Timer F) when the second timer 104(2) (Timer F1) is triggered. In some embodiments, the timer value of P seconds for the second timer 104(2) (Timer F1) is set to a value of 5 seconds.
Both timers 104(1) and 104(2) may be stopped (or terminated) in response to the originating UE 100 receiving any REGISTER response, such as a response indicating a successful registration prior to expiration of the timer 104. Such a response may be in the form of a 200 (OK) SIP response, as shown in
In response to the second timer 104(2) (Timer F1) firing/expiring/timing out at 116 (and in response to the first timer 104(1) (Timer F) prematurely firing/expiring/timing out at 116), the originating UE 100 may perform a designated “fire” action. In some embodiments, the fire action includes the originating UE 100 reattempting to register for the one or more services of the telecommunication service provider using a different P-CSCF node 102, such as the P-CSCF node 102(Q) in
In response to sending the second SIP request 108(2) using the SIP REGISTER method to the second P-CSCF node 102(Q), the originating UE 100 may restart the first timer 104(1) (Timer F) at 118. This is because the sending of the second SIP request 108(2) using the SIP REGISTER method is a trigger event for the first timer 104(1) (Timer F). Thus, the time period of N seconds starts again from the restarting of the first timer 104(1) (Timer F) at 118 until a termination event or the expiration of the first timer 104(1), whichever occurs first.
Furthermore, in the example of
In the example of
After stopping the timers 104(1) and 104(2) at 126, the originating UE 100 may perform one or more setup procedures 128 to establish the communication session (e.g., a call, such as a VoNR call), as requested by the user at 120. Example setup procedures that may be included in the setup procedures 128 can include, without limitation, the originating UE 100 sending/receiving any SIP request/response to/from the IMS core, such as sending a SIP request using the SIP INVITE method, receiving a 100 Trying response, receiving a 180 Ringing response (indicating that a called party of the terminating UE is being alerted), receiving a 181 Call Being Forwarded response, receiving a 182 Queued response, receiving a 183 Session In Progress response, receiving a SIP response that includes session description protocol (SDP) information (e.g., an SDP answer), receiving a SIP response that includes “early media” (e.g., user data), and/or receiving a final response to resolve the setup of the communication session. Such a final SIP response can be in the form of a 2xx—successful (e.g., a 200 (OK) response indicating successful connection), 3xx—redirection, 4xx—client failure, 5xx—server failure, or 6xx—global failure, and so on. Further examples of the setup procedures 128 include, without limitation, the originating UE 100 sending/receiving any Non-Access Stratum (NAS)-based request/response to/from an mobility management entity (MME), such as sending/receiving a radio resource control (RRC) connection request/response to/from the MME, sending/receiving a RRC connection reconfiguration complete request/response to/from the MME, sending/receiving a request/response to/from the MME indicating that a dedicated bearer has been established, and so on. Further examples of the setup procedures 128 can include, without limitation, the originating UE 100 sending/receiving any type of UPDATE request/response, sending/receiving any type of “ACK” request/response (e.g., a PRACK message), and so on, to/from any suitable network node.
Registration procedures and setup procedures for a given communication session may vary by implementation, session type (e.g., phone call verses video conference, emergency verses non-emergency call, etc.), attachment result (e.g., combined attached verses not combined attached), network topology, and/or other factors. Accordingly, detailed and exhaustive examples of procedures and the order in which they are performed in order to register for IMS-based services and to setup a communication session are not described herein, as the various possible setup procedures are generally known to a person having ordinary skill in the art. As such, any given registration and/or session setup may include some or all of the example procedures described herein, performed in a suitable order. It is to be appreciated that a communication session is not successfully established unless and until the originating UE 100 receives a final SIP response in the form of a 2xx response.
The example timers 104(1) and 104(2) described with reference to
In an illustrative example, a user of the UE 100 (e.g., a phone) might attempt to make a phone call while the UE 100 is still trying to register on a 5G network 106. If IMS registration is taking longer than expected, the second timer 104(2) (Timer F1) starts in response to the user attempting to make the phone call (which may be detected by the UE 100 receiving user input to establish the phone call. If IMS registration is still pending when the second timer 104(2) (Timer F1) expires (e.g., after P seconds), the UE 100 may initiate an IMS restoration procedure, which, in
It is to be appreciated that the “nodes” depicted in
In the example of
The processes described in this disclosure may be implemented by the architectures described herein, or by other architectures. These processes are illustrated as a collection of blocks in a logical flow graph. Some of the blocks represent operations that can be implemented in hardware, software, or a combination thereof. In the context of software, the blocks represent computer-executable instructions stored on one or more computer-readable storage media that, when executed by one or more processors, perform the recited operations. Generally, computer-executable instructions include routines, programs, objects, components, data structures, and the like that perform particular functions or implement particular abstract data types. The order in which the operations are described is not intended to be construed as a limitation, and any number of the described blocks can be combined in any order or in parallel to implement the processes. It is understood that the following processes may be implemented on other architectures as well.
At 302, a device (e.g., the UE 100) may send, to a first node of a first network, a first request to register for one or more services of a telecommunication service provider. The first request may be a first SIP request 108(1) using a SIP REGISTER method. The first node that receives the first request may be a first P-CSCF node, such as the P-CSCF node 102(1) of
At 304, the device (e.g., the UE 100) may receive user input to establish a communication session prior to receiving a response indicating a result of the first request to register for the one or more services. For example, at a time at which the user input is received at block 304, a state machine may indicate that a state of registration associated with the device is in a pending state, meaning that the device has sent a SIP request 108(1) using the SIP REGISTER method, but the device has not yet received a final SIP response in the form of a 2xx—successful (e.g., a 200 (OK) response), 3xx—redirection, 4xx—client failure, 5xx—server failure, or 6xx—global failure, and so on. The user input received at block 304 may be any suitable form of user input, such as touch input (e.g., selecting an existing contact or dialing a phone number via a touch screen, physical keys, etc.), voice input, gestural input, etc.
At 306, the device (e.g., the UE 100) may start a timer 104(2) (Timer F1) in response to receiving the user input at block 304. The timer 104(2) (Timer F1) may be configured to expire after a period of time (e.g., P seconds) and to stop in response to the device receiving a response indicating a successful registration (e.g., a 200 (OK) SIP Response) prior to expiration of the timer 104(2) (Timer F1). In some examples, the starting of the timer 104(2) (Timer F1) is based at least in part on a state of registration associated with the device being in a pending state at a time at which the user input is received at block 304. Additionally, or alternatively, the modem of the device may be used to determine that an attempt to establish a communication session has been made at block 304.
At 308, the device (e.g., the UE 100) may determine whether the timer 104(2) (Timer F1) has expired. If the timer 104(2) (Timer F1) has not yet expired at block 308, the process 300 may follow the NO route from block 308 to block 310.
At 310, the device (e.g., the UE 100) may determine whether a response indicating a successful registration (e.g., a 200 (OK) SIP Response) has been received and/or the device may check the state machine for the state of registration. If a “successful registration” response has not been received at block 310 and/or if the state machine indicates that the state of registration is still pending, the process 300 may follow the NO route from block 310 back to block 308 to continue monitoring the timer 104(2) (Timer F1) for the occurrence of a timeout or a termination event, whichever occurs first. If the timeout occurs first at block 308 (i.e., if the device determines, at block 308, that the timer 104(2) (Timer F1) has expired without the device having received the response indicating the successful registration and/or while the state of registration is still pending), the process 300 may follow the YES route from block 308 to block 312.
At 312, the device (e.g., the UE 100) may perform an IMS restoration procedure. The IMS restoration procedure performed at block 312 may be carrier-specific. In some examples, the IMS restoration procedure performed at block 312 involves trying another network node at block 314. For example, in response to determining that the timer 104(2) (Timer F1) has expired, the device may send a second request to register for the one or more services to a second node of the first network. The second request may be a second SIP request 108(2) using the SIP REGISTER method. The second node that receives the second request 108(2) may be a second P-CSCF node 102(Q), where the second node is in a common network 106 as the first node that received the first request sent at block 302. In some examples, the IMS restoration procedure performed at block 312 involves trying a different network at 316. For example, in response to determining that the timer 104(2) (Timer F1) has expired, the device may send a second request to register for the one or more services to a node of the second network, such as a 4G LTE network, and/or a network of a roaming partner. Here, the second request may be a second SIP request 208 using the SIP REGISTER method, but the node that receives the second request 208 may be a second P-CSCF node 202 that is in a different network 206 than the first network 106 associated with the first node that received the first request sent at block 302. In some examples, sub-blocks 314 and 316 may be performed sequentially at block 312. In other words, the device may first try another network node of the current (first) network 106, and may subsequently try a different network 206 if unsuccessful on the first network 106.
Returning to block 310, if the device receives a response indicating a successful registration (e.g., a 200 (OK) SIP Response) prior to expiration of the timer 104(2) (Timer F1) and/or if the state machine indicates that the state of registration is successful prior to expiration of the timer 104(2) (Timer F1), the process 300 may follow the YES route from block 310 to block 318.
At 318, the device (e.g., the UE 100) may stop the timer 104(2) (Timer F1) in response to receiving the response indicating the successful registration at block 310, which may cause the state machine to indicate that the state of registration is successful. At 320, the device (e.g., the UE 100) may establish the communication session via the first node of the first network that received the first registration request sent at block 302. Accordingly, the process 300 illustrates a technique for using a timer 104(2) (Timer F1) to expedite IMS restoration in instances where user input to establish a communication session is received while registration is still pending.
At 402, a device (e.g., the UE 100) may receive a list of P-CSCF nodes 102(1)-(Q), the list including at least a first P-CSCF node 102(1) and the second P-CSCF node 102(Q). For example, the device, as part of a registration procedure, receive a PDN connection response that includes a list (e.g., a PCO list) of the P-CSCF nodes 102(1)-(Q) and their corresponding addresses, in order of priority. The P-CSCF addresses representing the P-CSCF nodes 102(1)-(Q) may be in the form of an IP address or a FQDN. The P-CSCF nodes 102(1)-(Q) in the list may be associated with a first network 106, such as a 5G NR network.
At 404, the device (e.g., the UE 100) may send, to the first P-CSCF node 102(1), a first SIP request 108(1) using a SIP REGISTER method. This first request 108(1) is an example of a first request to register for one or more services of a telecommunication service provider.
At 406, the device (e.g., the UE 100) may start a first timer 104(1) (Timer F) in response to sending the first request 108(1) at block 404. The first timer 104(1) (Timer F) may be configured to expire after a first period of time (e.g., N seconds) and to stop in response to the device receiving a response indicating a successful registration (e.g., a 200 (OK) SIP Response) prior to expiration of the first timer 104(1) (Timer F).
At 408, the device (e.g., the UE 100) may determine whether the first timer 104(1) (Timer F) has expired. If the timer 104(1) (Timer F) has not yet expired at block 408, the process 400 may follow the NO route from block 408 to block 410.
At 410, the device (e.g., the UE 100) may determine whether a call attempt has been made by a user of the device. For example, the device may determine whether user input to establish a communication session has been received, such as touch input (e.g., selecting an existing contact or dialing a phone number via a touch screen, physical keys, etc.), voice input, gestural input, etc. If a call attempt has not been made at block 410, the process 400 may follow the NO route from block 410 to block 412.
At 412, the device (e.g., the UE 100) may determine whether a response indicating a successful registration (e.g., a 200 (OK) SIP Response) has been received and/or the device may check the state machine of the device's IMS stack for the state of registration. If no “successful registration” response has been received at block 412 and/or if the state of registration is still pending, the process 400 may follow the NO route from block 412 back to block 408 to iterate the determination of whether the first timer 104(1) (Timer F) has expired. At 410, if the device determines that a call attempt has been made by the user (e.g., by receiving or detecting user input to establish a communication session), the process 400 may follow the YES route from block 410 to block 414.
At 414, the device (e.g., the UE 100) may start a second timer 104(2) (Timer F1) in response to the user making the call attempt (e.g., the device receiving or detecting the user input) at block 410. The second timer 104(2) (Timer F1) may be configured to expire after a period of time (e.g., P seconds) that is shorter than the period of time (e.g., N seconds) associated with the first timer 104(1) (Timer F). In other words, the first period of time (e.g., N seconds) of the first timer 104(1) (Timer F) may be longer than the second period of time (e.g., P seconds) of the second timer 104(2) (Timer F1). The second timer 104(2) (Timer F1) may be configured to stop in response to the device receiving a response indicating a successful registration (e.g., a 200 (OK) SIP Response) prior to expiration of the second timer 104(2) (Timer F1). In some examples, the starting of the second timer 104(2) (Timer F1) is based at least in part on a state of registration associated with the device being in a pending state at a time at which the user input is received at block 410.
At 416, the device (e.g., the UE 100) may determine whether the second timer 104(2) (Timer F1) has expired. If the second timer 104(2) (Timer F1) has not yet expired at block 416, the process 400 may follow the NO route from block 416 to block 418.
At 418, the device (e.g., the UE 100) may determine whether a response indicating a successful registration (e.g., a 200 (OK) SIP Response) has been received and/or the device may check the state machine of the device's IMS stack to determine the state of registration. If no “successful registration” response has been received at block 418 and/or if the state of registration is still pending, the process 400 may follow the NO route from block 418 back to block 416 to continue monitoring the second timer 104(2) (Timer F1) for the occurrence of a timeout or a termination event, whichever occurs first. If the timeout occurs first at block 416 (i.e., if the device determines, at block 416, that the second timer 104(2) (Timer F1) has expired without the device having received the response indicating the successful registration and/or while registration is still pending), the process 400 may follow the YES route from block 416 to block 420.
At 420, the device (e.g., the UE 100) may cause an early (or premature) expiration of the first timer 104(1) (Timer F) in response to determining that the second timer 104(2) (Timer F1) has expired without the device having received the response indicating the successful registration and/or while registration is still pending. As a result, both timers 104(1) and 104(2) are expired at block 420.
At 422, the device (e.g., the UE 100) may determine whether there are more P-CSCF nodes 102 in the list to try. That is, the device may determine whether the it has attempted to register for the one or more services with all of the P-CSCF nodes 102(1)-(Q) in the list received at block 402. If the device determines, at block 422, that it has not attempted to register for the one or more services with all of the P-CSCF nodes 102 in the list, the process 400 may follow the YES route from block 422 to block 424, where the device may select the next P-CSCF node 102 in the list of P-CSCF nodes 102(1)-(Q).
At 426, the device (e.g., the UE 100) may send, to the selected (second) P-CSCF node 102(Q), a second SIP request 108(2) using the SIP REGISTER method. This second request 108(2) is an example of a second request to register for the one or more services of the telecommunication service provider.
At 428, the device (e.g., the UE 100) may restart the first timer 104(1) (Timer F) in response to sending the second request 108(2) at block 426. The process 400 may return to block 408 following the restarting of the first timer 104(1) (Timer F) at block 428. After sending the second request 108(2) to the second P-CSCF node 102(Q), if the first timer 104(1) (Timer F) has not yet expired at block 408, the device may determine, at block 410, whether another call attempt has been made by a user of the device. For example, the device may determine whether second user input to establish a communication session has been received prior to receiving a response indicating a result of the second request to register for the one or more services. At 410, if the device determines that another call attempt has been made by the user (e.g., by receiving or detecting user input to establish a communication session), the process 400 may follow the YES route from block 410 to block 414 where the device may restart the second timer 104(2) (Timer F1) in response to receiving the second user input corresponding to the additional call attempt. An example reason for restarting the second timer 104(2) (Timer F1) after a second call attempt is made is to differentiate between users who are desperate or eager to make a call and users who are not desperate or eager to make a call, and to more aggressively expedite IMS restoration using the second timer 104(2) (Timer F1) for those users who are very desperate or eager to make the call. This conserves networking resources for those desperate/eager users.
If the second timer 104(2) (Timer F1) keeps expiring after restarting the second timer 104(2) (Timer F1), the device may iterate blocks 416-428 as long as there are more P-CSCF nodes 102 in the list to try. If, at 422, the device determines that it has attempted to register for the one or more services with all of the P-CSCF nodes 102 in the list, the process 400 may follow the NO route from block 422 to block 430.
At 430, the device (e.g., the UE 100) may attempt to register in a different network 206. For example, in response to determining that the second timer 104(2) (Timer F1) has expired and that there are no more P-CSCF nodes 102 in the first network 106 to try, the device may send another request to register for the one or more services to a node of a second, different network 206, such as a 4G LTE network, and/or a network of a roaming partner. Here, the request to register with a node of the second network 206 may be a SIP request 208 using the SIP REGISTER method, and the node that receives the request 208 may be a P-CSCF node 202 that is in the second, different network 206. Assuming this registration attempt is successful, the device (e.g., the LIE 100) may finish setup procedures to establish a communication session on behalf of the UE 100 and the user thereof, as described herein.
Returning to block 418, if the device receives a response indicating a successful registration (e.g., a 200 (OK) SIP Response) prior to expiration of the second timer 104(2) (Timer F1) and/or if the state machine of the device's IMS stack indicates that the state of registration is successful, the process 400 may follow the YES route from block 418 to block 434, where the device (e.g., the UE 100) may stop both timers 104(1) and 104(2) in response to receiving the response indicating the successful registration at block 418. At 432, the device (e.g., the UE 100) may establish the communication session via the current P-CSCF node 102 of the first network 106 that provided the 200 (OK) SIP Response to the device at block 418.
Returning to block 412, if the device receives a response indicating a successful registration (e.g., a 200 (OK) SIP Response) and/or if the state machine of the device's IMS stack indicates that the state of registration is successful prior to expiration of the first timer 104(1) (Timer F) without having started the second timer 104(2) (Timer F1), the process 400 may follow the YES route from block 412 to block 436, where the device (e.g., the UE 100) may stop the first timer 104(1) (Timer F) in response to receiving the response indicating the successful registration at block 412. At 432, the device (e.g., the UE 100) may establish the communication session via the current P-CSCF node 102 of the first network 106 that provided the 200 (OK) SIP Response to the device at block 412. Accordingly, the process 400 illustrates a technique for using multiple timers 104 (e.g., the first timer 104(1) (Timer F) and the second timer 104(2) (Timer F1)), where the second timer 104(2) (Timer F1) is used as a guard timer for the first timer 104(1) (Timer F) to expedite IMS restoration in instances where user input to establish a communication session is received while registration is still pending.
The UE 100 may further include input devices 510 (e.g., a touch screen, keypad, keyboard, mouse, pointer, microphone, etc.) and output devices 512 (e.g., a display, printer, speaker, etc.) communicatively coupled to the processor(s) 502 and the computer-readable memory 504. The UE 100 may further include communications interface(s) 514 that allow the UE 100 to communicate with other computing devices 516 (e.g., IMS nodes) such as via a network (e.g., the IMS core, the P-CSCF nodes 102/202, etc.). The communications interface(s) 514 may facilitate transmitting and receiving wired and/or wireless signals over any suitable communications/data technology, standard, or protocol, as described herein. For example, the communications interface(s) 514 can comprise one or more of a cellular radio, a wireless (e.g., IEEE 802.1x-based) interface, a Bluetooth® interface, and so on. In some embodiments, the communications interface(s) 514 may include radio frequency (RF) circuitry that allows the UE 100 to transition between different RATs, such as transitioning between communication with a 5G NR RAT, a 4G LTE RAT and other legacy RATs (e.g., 3G/2G). The communications interface(s) 514 may further enable the UE 100 to communicate over circuit-switch domains and/or packet-switch domains.
In various embodiments, the computer-readable memory 504 comprises non-transitory computer-readable memory 504 that generally includes both volatile memory and non-volatile memory (e.g., random access memory (RAM), read-only memory (ROM), erasable programmable read-only memory (EEPROM), Flash Memory, miniature hard drive, memory card, optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium). The computer-readable memory 504 may also be described as computer storage media and may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data. Computer-readable memory 504, removable storage 506 and non-removable storage 508 are all examples of non-transitory computer-readable storage media. Computer-readable storage media include, but are not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, compact disc read-only memory (CD-ROM), digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the UE 100. Any such computer-readable storage media may be part of the UE 100.
The memory 504 can include a registration module 518 (i.e., computer-executable instructions (or logic) that, when executed, by the processor(s) 502, perform the various acts and/or processes disclosed herein). For example, the registration module 518 can be configured to carry out the registration procedures described herein. As shown in
The memory 504 can further be used to store timer parameters 520, such as trigger events, termination events, timer values, and/or fire actions associated with particular timers. Although the timer parameters 520 are illustrated as being stored locally on the UE 100, the UE 100 may be configured to access the timer parameters from a remote storage location, such as a cloud-based service that maintains timer parameters and continually updates those parameters. For locally stored timer parameters, parameter updates may be pushed, periodically, to the UE 100 for storage in the memory 504.
The environment and individual elements described herein may of course include many other logical, programmatic, and physical components, of which those shown in the accompanying figures are merely examples that are related to the discussion herein.
The various techniques described herein are assumed in the given examples to be implemented in the general context of computer-executable instructions or software, such as program modules, that are stored in computer-readable storage and executed by the processor(s) of one or more computers or other devices such as those illustrated in the figures. Generally, program modules include routines, programs, objects, components, data structures, etc., and define operating logic for performing particular tasks or implement particular abstract data types.
Other architectures may be used to implement the described functionality, and are intended to be within the scope of this disclosure. Furthermore, although specific distributions of responsibilities are defined above for purposes of discussion, the various functions and responsibilities might be distributed and divided in different ways, depending on circumstances.
Similarly, software may be stored and distributed in various ways and using different means, and the particular software storage and execution configurations described above may be varied in many different ways. Thus, software implementing the techniques described above may be distributed on various types of computer-readable media, not limited to the forms of memory that are specifically described.
Number | Name | Date | Kind |
---|---|---|---|
10051017 | Chiang | Aug 2018 | B2 |
20110070887 | Wu | Mar 2011 | A1 |
20150195864 | Bartolome | Jul 2015 | A1 |
20180024892 | Noman | Aug 2018 | A1 |
Number | Date | Country |
---|---|---|
111107058 | May 2020 | CN |
4057584 | Sep 2022 | EP |
2016537836 | Dec 2016 | JP |
Entry |
---|
Extended European Search Report mailed Oct. 12, 2022 for European Patent Application No. 22174915.3, 8 pages. |
Number | Date | Country | |
---|---|---|---|
20220400360 A1 | Dec 2022 | US |