diff options
Diffstat (limited to 'src/emulator.c')
-rw-r--r-- | src/emulator.c | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/src/emulator.c b/src/emulator.c index f0ae84ba..53844a72 100644 --- a/src/emulator.c +++ b/src/emulator.c @@ -24,6 +24,7 @@ #endif #include <stdio.h> +#include <string.h> #include <glib.h> @@ -42,6 +43,14 @@ struct ofono_emulator { GAtServer *server; GAtPPP *ppp; guint source; + GSList *indicators; +}; + +struct indicator { + char *name; + int value; + int min; + int max; }; static void emulator_debug(const char *str, void *data) @@ -163,9 +172,30 @@ error: g_at_server_send_final(em->server, G_AT_SERVER_RESULT_ERROR); } +static void emulator_add_indicator(struct ofono_emulator *em, const char* name, + int min, int max, int dflt) +{ + struct indicator *ind; + + ind = g_try_new0(struct indicator, 1); + if (ind == NULL) { + ofono_error("Unable to allocate indicator structure"); + return; + } + + ind->name = g_strdup(name); + ind->min = min; + ind->max = max; + ind->value = dflt; + + em->indicators = g_slist_append(em->indicators, ind); +} + static void emulator_unregister(struct ofono_atom *atom) { struct ofono_emulator *em = __ofono_atom_get_data(atom); + struct indicator *ind; + GSList *l; DBG("%p", em); @@ -174,6 +204,15 @@ static void emulator_unregister(struct ofono_atom *atom) em->source = 0; } + for (l = em->indicators; l; l = l->next) { + ind = l->data; + + g_free(ind->name); + g_free(ind); + } + g_slist_free(em->indicators); + em->indicators = NULL; + g_at_server_unref(em->server); em->server = NULL; } @@ -199,6 +238,13 @@ void ofono_emulator_register(struct ofono_emulator *em, int fd) g_at_server_set_disconnect_function(em->server, emulator_disconnect, em); + if (em->type == OFONO_EMULATOR_TYPE_HFP) { + emulator_add_indicator(em, OFONO_EMULATOR_IND_SERVICE, 0, 1, 0); + emulator_add_indicator(em, OFONO_EMULATOR_IND_SIGNAL, 0, 5, 0); + emulator_add_indicator(em, OFONO_EMULATOR_IND_ROAMING, 0, 1, 0); + emulator_add_indicator(em, OFONO_EMULATOR_IND_BATTERY, 0, 5, 5); + } + __ofono_atom_register(em->atom, emulator_unregister); if (em->type == OFONO_EMULATOR_TYPE_DUN) @@ -399,3 +445,31 @@ enum ofono_emulator_request_type ofono_emulator_request_get_type( { return req->type; } + +void ofono_emulator_set_indicator(struct ofono_emulator *em, + const char *name, int value) +{ + GSList *l; + int i; + char buf[20]; + + i = 1; + for (l = em->indicators; l; l = l->next) { + struct indicator *ind = l->data; + + if (g_str_equal(ind->name, name)) { + if (ind->value == value || value < ind->min + || value > ind->max) + return; + + ind->value = value; + + sprintf(buf, "+CIEV: %d,%d", i, ind->value); + g_at_server_send_info(em->server, buf, TRUE); + + break; + } + + i++; + } +} |