diff options
author | Tambet Ingo <tambet@gmail.com> | 2008-12-05 15:57:55 +0200 |
---|---|---|
committer | Tambet Ingo <tambet@gmail.com> | 2008-12-05 15:57:55 +0200 |
commit | a504fb408aa2ba3bb495a08d948ae97bdcb1cdd6 (patch) | |
tree | 1a0f1d466d234002d4047edafb008676e8a4bdfa /src/mm-generic-gsm.c | |
parent | 793044b577c18d3b9028276fdec629981c75f5ed (diff) | |
parent | 1673c6c998ccca73097c7d032b14ff15883d053b (diff) |
Merge branch 'master' of git://gitorious.org/modemmanager/asacs-mbm
Diffstat (limited to 'src/mm-generic-gsm.c')
-rw-r--r-- | src/mm-generic-gsm.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/mm-generic-gsm.c b/src/mm-generic-gsm.c index e1769c8d..b08ad3bf 100644 --- a/src/mm-generic-gsm.c +++ b/src/mm-generic-gsm.c @@ -327,6 +327,35 @@ get_card_info (MMModemGsmCard *modem, } static void +send_puk_done (MMSerial *serial, + GString *response, + GError *error, + gpointer user_data) +{ + MMCallbackInfo *info = (MMCallbackInfo *) user_data; + + if (error) + info->error = g_error_copy (error); + mm_callback_info_schedule (info); +} + +static void +send_puk (MMModemGsmCard *modem, + const char *puk, + const char *pin, + MMModemFn callback, + gpointer user_data) +{ + MMCallbackInfo *info; + char *command; + + info = mm_callback_info_new (MM_MODEM (modem), callback, user_data); + command = g_strdup_printf ("+CPIN=\"%s\",\"%s\"", puk, pin); + mm_serial_queue_command (MM_SERIAL (modem), command, 3, send_puk_done, info); + g_free (command); +} + +static void send_pin_done (MMSerial *serial, GString *response, GError *error, @@ -1104,6 +1133,7 @@ modem_gsm_card_init (MMModemGsmCard *class) class->get_imsi = get_imsi; class->get_info = get_card_info; class->send_pin = send_pin; + class->send_puk = send_puk; class->enable_pin = enable_pin; class->change_pin = change_pin; } |