summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAki Niemi <aki.niemi@nokia.com>2009-08-21 16:29:34 +0300
committerAki Niemi <aki.niemi@nokia.com>2009-08-21 16:29:34 +0300
commitf06c09d17ad7021f73a6f61547133b1f4b295c91 (patch)
treef15cf401ad34d26c97c9392b0b0314bd2dee7b23
parent621d584b4dca94413675d3c608653b27e5b465e0 (diff)
downloadofono-f06c09d17ad7021f73a6f61547133b1f4b295c91.tar.bz2
Enable multiple instances of devinfo driver
-rw-r--r--drivers/isimodem/isidevinfo.c43
1 files changed, 29 insertions, 14 deletions
diff --git a/drivers/isimodem/isidevinfo.c b/drivers/isimodem/isidevinfo.c
index ee6eab20..92601df8 100644
--- a/drivers/isimodem/isidevinfo.c
+++ b/drivers/isimodem/isidevinfo.c
@@ -45,8 +45,6 @@
#define PN_PHONE_INFO 0x1B
#define INFO_TIMEOUT 5
-static GIsiClient *client = NULL;
-
enum return_code {
INFO_OK = 0x00,
INFO_FAIL = 0x01,
@@ -83,6 +81,10 @@ enum version_type {
INFO_MCUSW = 0x01
};
+struct devinfo_data {
+ GIsiClient *client;
+};
+
static gboolean decode_sb_and_report(const unsigned char *msg, size_t len, int id,
ofono_devinfo_query_cb_t cb,
void *data)
@@ -153,7 +155,9 @@ static void isi_query_manufacturer(struct ofono_devinfo *info,
ofono_devinfo_query_cb_t cb,
void *data)
{
+ struct devinfo_data *dev = ofono_devinfo_get_data(info);
struct isi_cb_data *cbd = isi_cb_data_new(NULL, cb, data);
+
const unsigned char msg[] = {
INFO_PRODUCT_INFO_READ_REQ,
INFO_PRODUCT_MANUFACTURER
@@ -162,7 +166,7 @@ static void isi_query_manufacturer(struct ofono_devinfo *info,
if (!cbd)
goto error;
- if (g_isi_request_make(client, msg, sizeof(msg), INFO_TIMEOUT,
+ if (g_isi_request_make(dev->client, msg, sizeof(msg), INFO_TIMEOUT,
manufacturer_resp_cb, cbd))
return;
@@ -212,7 +216,9 @@ static void isi_query_model(struct ofono_devinfo *info,
ofono_devinfo_query_cb_t cb,
void *data)
{
+ struct devinfo_data *dev = ofono_devinfo_get_data(info);
struct isi_cb_data *cbd = isi_cb_data_new(NULL, cb, data);
+
const unsigned char msg[] = {
INFO_PRODUCT_INFO_READ_REQ,
INFO_PRODUCT_NAME
@@ -221,7 +227,7 @@ static void isi_query_model(struct ofono_devinfo *info,
if (!cbd)
goto error;
- if (g_isi_request_make(client, msg, sizeof(msg), INFO_TIMEOUT,
+ if (g_isi_request_make(dev->client, msg, sizeof(msg), INFO_TIMEOUT,
model_resp_cb, cbd))
return;
@@ -271,7 +277,9 @@ static void isi_query_revision(struct ofono_devinfo *info,
ofono_devinfo_query_cb_t cb,
void *data)
{
+ struct devinfo_data *dev = ofono_devinfo_get_data(info);
struct isi_cb_data *cbd = isi_cb_data_new(NULL, cb, data);
+
const unsigned char msg[] = {
INFO_VERSION_READ_REQ,
0x00, INFO_MCUSW,
@@ -281,7 +289,7 @@ static void isi_query_revision(struct ofono_devinfo *info,
if (!cbd)
goto error;
- if (g_isi_request_make(client, msg, sizeof(msg), INFO_TIMEOUT,
+ if (g_isi_request_make(dev->client, msg, sizeof(msg), INFO_TIMEOUT,
revision_resp_cb, cbd))
return;
@@ -331,7 +339,9 @@ static void isi_query_serial(struct ofono_devinfo *info,
ofono_devinfo_query_cb_t cb,
void *data)
{
+ struct devinfo_data *dev = ofono_devinfo_get_data(info);
struct isi_cb_data *cbd = isi_cb_data_new(NULL, cb, data);
+
const unsigned char msg[] = {
INFO_SERIAL_NUMBER_READ_REQ,
INFO_SN_IMEI_PLAIN
@@ -340,7 +350,7 @@ static void isi_query_serial(struct ofono_devinfo *info,
if (!cbd)
goto error;
- if (g_isi_request_make(client, msg, sizeof(msg), INFO_TIMEOUT,
+ if (g_isi_request_make(dev->client, msg, sizeof(msg), INFO_TIMEOUT,
serial_resp_cb, cbd))
return;
@@ -366,13 +376,16 @@ static gboolean isi_devinfo_register(gpointer user)
static int isi_devinfo_probe(struct ofono_devinfo *info)
{
GIsiModem *idx = ofono_devinfo_get_data(info);
+ struct devinfo_data *data = g_try_new0(struct devinfo_data, 1);
- if (!client) {
- client = g_isi_client_create(idx, PN_PHONE_INFO);
+ if (!data)
+ return -ENOMEM;
- if (!client)
- return -ENOMEM;
- }
+ data->client = g_isi_client_create(idx, PN_PHONE_INFO);
+ if (!data->client)
+ return -ENOMEM;
+
+ ofono_devinfo_set_data(info, data);
g_idle_add(isi_devinfo_register, info);
@@ -381,9 +394,11 @@ static int isi_devinfo_probe(struct ofono_devinfo *info)
static int isi_devinfo_remove(struct ofono_devinfo *info)
{
- if (client) {
- g_isi_client_destroy(client);
- client = NULL;
+ struct devinfo_data *data = ofono_devinfo_get_data(info);
+
+ if (data) {
+ g_isi_client_destroy(data->client);
+ g_free(data);
}
return 0;