From a847f2ac0f4d0b11041907eb8e78cf701294043b Mon Sep 17 00:00:00 2001 From: Pekka Pessi Date: Thu, 20 Jan 2011 15:37:11 +0200 Subject: gprs: Make gprs atom offline-safe Allow use of GPRS atom both in online and offline (post_sim) states. The GPRS now considers the removal of the netreg atom as implicit detach and registration change to NOT_REGISTERED. --- src/gprs.c | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) (limited to 'src/gprs.c') diff --git a/src/gprs.c b/src/gprs.c index f80cec54..92d0b1a5 100644 --- a/src/gprs.c +++ b/src/gprs.c @@ -1408,6 +1408,18 @@ static void gprs_attach_callback(const struct ofono_error *error, void *data) } } +static void gprs_netreg_removed(struct ofono_gprs *gprs) +{ + gprs->netreg = NULL; + + gprs->flags &= ~(GPRS_FLAG_RECHECK | GPRS_FLAG_ATTACHING); + gprs->status_watch = 0; + gprs->netreg_status = NETWORK_REGISTRATION_STATUS_NOT_REGISTERED; + gprs->driver_attached = FALSE; + + gprs_attached_update(gprs); +} + static void gprs_netreg_update(struct ofono_gprs *gprs) { ofono_bool_t attach; @@ -2314,8 +2326,7 @@ static void netreg_watch(struct ofono_atom *atom, struct ofono_gprs *gprs = data; if (cond == OFONO_ATOM_WATCH_CONDITION_UNREGISTERED) { - gprs->status_watch = 0; - gprs->netreg = NULL; + gprs_netreg_removed(gprs); return; } -- cgit v1.2.3