summaryrefslogtreecommitdiffstats
path: root/drivers/hfpmodem/network-registration.c
diff options
context:
space:
mode:
authorClaudio Takahasi <claudio.takahasi@openbossa.org>2013-02-21 19:24:42 -0300
committerDenis Kenzior <denkenz@gmail.com>2013-02-21 17:09:54 -0600
commit0772fda92eaf95d5363c367a5e3409492a3948eb (patch)
treee076a48095a668a003e813a9d170665d9a0089a2 /drivers/hfpmodem/network-registration.c
parent2f8b9ab50c946f72689601d435f183e249c653dd (diff)
downloadofono-0772fda92eaf95d5363c367a5e3409492a3948eb.tar.bz2
hfpmodem: Fix segfault in CIEV GAtChat callback
This patch fixes segmentation fault when the network registration watch is called without being initialized. CIEV GAtChat callback can be called before ofono_netreg_register(). ==15101== Invalid read of size 8 ==15101== at 0x492B56: ofono_netreg_register (network.c:2073) ==15101== by 0x47245E: hfp_netreg_probe (network-registration.c:311) ==15101== by 0x492A8D: ofono_netreg_create (network.c:1881) ==15101== by 0x4849D5: hfp_pre_sim (hfp_hf_bluez5.c:288) ==15101== by 0x48C486: ofono_modem_set_powered (modem.c:1194) ==15101== by 0x484E9D: slc_established (hfp_hf_bluez5.c:85) ==15101== by 0x4702AD: chld_cb (slc.c:147) ==15101== by 0x440457: at_chat_finish_command (gatchat.c:461) ==15101== by 0x44109F: new_bytes (gatchat.c:532) ==15101== by 0x4433B7: received_data (gatio.c:122) ==15101== by 0x3CBAA47824: g_main_context_dispatch (gmain.c:2539) ==15101== by 0x3CBAA47B57: g_main_context_iterate.isra.23 (gmain.c:3146) ==15101== Address 0x18 is not stack'd, malloc'd or (recently) free'd
Diffstat (limited to 'drivers/hfpmodem/network-registration.c')
-rw-r--r--drivers/hfpmodem/network-registration.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/hfpmodem/network-registration.c b/drivers/hfpmodem/network-registration.c
index 4b9f875b..272d5b44 100644
--- a/drivers/hfpmodem/network-registration.c
+++ b/drivers/hfpmodem/network-registration.c
@@ -302,6 +302,9 @@ static gboolean hfp_netreg_register(gpointer user_data)
nd->register_source = 0;
+ g_at_chat_register(nd->chat, "+CIEV:", ciev_notify, FALSE,
+ netreg, NULL);
+
ofono_netreg_register(netreg);
return FALSE;
@@ -321,9 +324,6 @@ static int hfp_netreg_probe(struct ofono_netreg *netreg, unsigned int vendor,
ofono_netreg_set_data(netreg, nd);
- g_at_chat_register(nd->chat, "+CIEV:", ciev_notify, FALSE,
- netreg, NULL);
-
nd->register_source = g_idle_add(hfp_netreg_register, netreg);
return 0;