diff options
author | Mikel Astiz <mikel.astiz@bmw-carit.de> | 2011-10-20 18:38:06 +0200 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2011-10-20 12:53:34 -0500 |
commit | 813405500ba3db017d9a73ee8b3572fcee1d72e1 (patch) | |
tree | 35158573a5e9426f53577369a7bd9c8a9e233ecd /drivers/hfpmodem | |
parent | 1f7e51d2d88eddc288aa51262dc795c94bc82220 (diff) | |
download | ofono-813405500ba3db017d9a73ee8b3572fcee1d72e1.tar.bz2 |
hfpmodem: Support for +BSIR unsolicited responses
Diffstat (limited to 'drivers/hfpmodem')
-rw-r--r-- | drivers/hfpmodem/handsfree.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/drivers/hfpmodem/handsfree.c b/drivers/hfpmodem/handsfree.c index 05bf2c88..54a5fbae 100644 --- a/drivers/hfpmodem/handsfree.c +++ b/drivers/hfpmodem/handsfree.c @@ -49,11 +49,30 @@ struct hf_data { unsigned int ag_features; }; +static void bsir_notify(GAtResult *result, gpointer user_data) +{ + struct ofono_handsfree *hf = user_data; + GAtResultIter iter; + int value; + + g_at_result_iter_init(&iter, result); + + if (!g_at_result_iter_next(&iter, "+BSIR:")) + return; + + if (!g_at_result_iter_next_number(&iter, &value)) + return; + + ofono_handsfree_set_inband_ringing(hf, (ofono_bool_t) value); +} + static gboolean hfp_handsfree_register(gpointer user_data) { struct ofono_handsfree *hf = user_data; struct hf_data *hd = ofono_handsfree_get_data(hf); + g_at_chat_register(hd->chat, "+BSIR:", bsir_notify, FALSE, hf, NULL); + if (hd->ag_features & HFP_AG_FEATURE_IN_BAND_RING_TONE) ofono_handsfree_set_inband_ringing(hf, TRUE); |