}
#endif
+static void __on_hook_status_NO_carrier(ps_modem_t *modem, ps_service_t *service,
+ CoreObject *co_ps, struct tnoti_ps_call_status *cstatus)
+{
+ ps_context_t *def_context = NULL, *ims_context = NULL;
+ unsigned char def_cid = 0, ims_cid = 0;
+ int value = 0;
+ gboolean retry = TRUE;
+
+ if (!modem || !service || !cstatus)
+ return;
+
+ retry = ps_util_check_permanent_reject_cause(cstatus->result, _ps_modem_get_roaming(modem));
+ /* if retry not permitted by network */
+ if (FALSE == retry) {
+ ps_dbg_ex_modem(modem, "DO NOT RETRY NETWORK CONNECTION AUTOMATICALLY");
+ ps_info_ex_modem(modem, "permanent reject cause (%d), roaming(%d)", cstatus->result, _ps_modem_get_roaming(modem));
+
+ def_context = _ps_service_return_default_context(service, CONTEXT_ROLE_INTERNET);
+ if (def_context) {
+ CoreObject *co_context = _ps_context_ref_co_context(def_context);
+ def_cid = tcore_context_get_id(co_context);
+ }
+
+ ims_context = _ps_service_return_default_context(service, CONTEXT_ROLE_IMS);
+ if (ims_context) {
+ CoreObject *co_context = _ps_context_ref_co_context(ims_context);
+ ims_cid = tcore_context_get_id(co_context);
+ }
+ }
+
+ _ps_service_set_ps_defined(service, FALSE, cstatus->context_id);
+ tcore_ps_set_cid_active(co_ps, cstatus->context_id, FALSE);
+ tcore_ps_set_cid_connected(co_ps, cstatus->context_id, FALSE);
+ _ps_service_set_connected(service, cstatus, FALSE);
+
+ if (FALSE == tcore_ps_any_internet_mms_tethering_context_activating_activated(co_ps, &value)) {
+ ps_dbg_ex_modem(modem, "No context open connections, publish disconnected signal");
+#ifdef TIZEN_SUPPORT_REQUEST_HOOK_PDP_CONTROL
+ /* Handle any pending request if present */
+ modem = _ps_service_ref_modem(service);
+ _ps_hook_send_pending_user_request(modem);
+#endif
+ /* Ensured that set_reset_profile is always done default thread's context */
+ if (_ps_modem_get_reset_profile(modem) == TRUE) {
+ /* Initiate Reset Profile */
+ ps_info_ex_modem(modem, "Profiles are being reset");
+ /* Shouldn't invoke set profile directly, as it will remove hooks registered to server while being hook callback*/
+ if (NULL == _ps_modem_get_profile_reset_gsource(modem)) {
+ GSource *gsource = NULL;
+ gsource = ps_util_gsource_dispatch(g_main_context_default(), G_PRIORITY_LOW, (GSourceFunc)_ps_modem_initiate_reset_profile, modem);
+ _ps_modem_set_profile_reset_gsource(modem, gsource);
+ }
+ }
+ }
+
+#ifdef PREPAID_SIM_APN_SUPPORT
+ __on_call_status_for_prepaid_sim(service, def_context, modem);
+#endif
+
+ ps_info_ex_modem(modem, "Any context activating or activated [%d]", value);
+ if (FALSE == retry) {
+ if (cstatus->context_id == def_cid) {
+ _ps_service_reset_connection_timer(def_context);
+ _ps_context_set_alwayson_enable(def_context, FALSE);
+ } else if (cstatus->context_id == ims_cid) {
+ _ps_service_reset_connection_timer(ims_context);
+ _ps_context_set_alwayson_enable(ims_context, FALSE);
+ }
+ }
+}
+
static enum tcore_hook_return __on_hook_call_status(Server *s, CoreObject *source,
enum tcore_notification_command command, unsigned int data_len, void *data,
void *user_data)
}
}
} else if (cstatus->state == PS_CALL_STATE_RESULT_NO_CARRIER) { /* DISCONNECTED-NO CARRIER */
- ps_context_t *def_context = NULL, *ims_context = NULL;
- unsigned char def_cid = 0, ims_cid = 0;
- int value = 0;
- gboolean retry = TRUE;
-
- retry = ps_util_check_permanent_reject_cause(cstatus->result, _ps_modem_get_roaming(modem));
- /* if retry not permitted by network */
- if (FALSE == retry) {
- ps_dbg_ex_modem(modem, "DO NOT RETRY NETWORK CONNECTION AUTOMATICALLY");
- ps_info_ex_modem(modem, "permanent reject cause (%d), roaming(%d)", cstatus->result, _ps_modem_get_roaming(modem));
-
- def_context = _ps_service_return_default_context(service, CONTEXT_ROLE_INTERNET);
- if (def_context) {
- CoreObject *co_context = _ps_context_ref_co_context(def_context);
- def_cid = tcore_context_get_id(co_context);
- }
-
- ims_context = _ps_service_return_default_context(service, CONTEXT_ROLE_IMS);
- if (ims_context) {
- CoreObject *co_context = _ps_context_ref_co_context(ims_context);
- ims_cid = tcore_context_get_id(co_context);
- }
- }
-
- _ps_service_set_ps_defined(service, FALSE, cstatus->context_id);
- tcore_ps_set_cid_active(co_ps, cstatus->context_id, FALSE);
- tcore_ps_set_cid_connected(co_ps, cstatus->context_id, FALSE);
- _ps_service_set_connected(service, cstatus, FALSE);
-
- if (FALSE == tcore_ps_any_internet_mms_tethering_context_activating_activated(co_ps, &value)) {
- ps_dbg_ex_modem(modem, "No context open connections, publish disconnected signal");
-#ifdef TIZEN_SUPPORT_REQUEST_HOOK_PDP_CONTROL
- /* Handle any pending request if present */
- modem = _ps_service_ref_modem(service);
- _ps_hook_send_pending_user_request(modem);
-#endif
- /* Ensured that set_reset_profile is always done default thread's context */
- if (_ps_modem_get_reset_profile(modem) == TRUE) {
- /* Initiate Reset Profile */
- ps_info_ex_modem(modem, "Profiles are being reset");
- /* Shouldn't invoke set profile directly, as it will remove hooks registered to server while being hook callback*/
- if (NULL == _ps_modem_get_profile_reset_gsource(modem)) {
- GSource *gsource = NULL;
- gsource = ps_util_gsource_dispatch(g_main_context_default(), G_PRIORITY_LOW, (GSourceFunc)_ps_modem_initiate_reset_profile, modem);
- _ps_modem_set_profile_reset_gsource(modem, gsource);
- }
- }
- }
-
-
-#ifdef PREPAID_SIM_APN_SUPPORT
- __on_call_status_for_prepaid_sim(service, def_context, modem);
-#endif
-
- ps_info_ex_modem(modem, "Any context activating or activated [%d]", value);
- if (FALSE == retry) {
- if (cstatus->context_id == def_cid) {
- _ps_service_reset_connection_timer(def_context);
- _ps_context_set_alwayson_enable(def_context, FALSE);
- } else if (cstatus->context_id == ims_cid) {
- _ps_service_reset_connection_timer(ims_context);
- _ps_context_set_alwayson_enable(ims_context, FALSE);
- }
- }
+ __on_hook_status_NO_carrier(modem, service, co_ps, cstatus);
} /* disconnected case */
return TCORE_HOOK_RETURN_CONTINUE;