[asterisk-dev] [Code Review] 2839: Fix memory corruption race condition.

rmudgett reviewboard at asterisk.org
Mon Sep 9 19:42:55 CDT 2013


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://reviewboard.asterisk.org/r/2839/
-----------------------------------------------------------

Review request for Asterisk Developers.


Bugs: ASTERISK-22221
    https://issues.asterisk.org/jira/browse/ASTERISK-22221


Repository: Asterisk


Description
-------

The masquerade super test is failing on v12 with high fence violations and crashing.  The fence violations are showing that party id allocated memory strings are somehow getting corrupted in the bridge_reconfigured_connected_line_update() function.  The invalid string values happen to be the freed memory fill pattern.

After much puzzling, I deduced that the bridge_reconfigured_connected_line_update() is copying a string out of the source channel's caller party id struct just as another thread is updating it with a new value.  The copying thread is using the old string pointer being freed by the updating thread.  A search of the code found the unreal_colp_redirect_indicate() routine updating the caller party id's without holding the channel lock.

A latent bug in v1.8 and v11 hatched in v12 because of the bridging and connected line changes. :)


Diffs
-----

  /branches/12/main/core_unreal.c 398732 

Diff: https://reviewboard.asterisk.org/r/2839/diff/


Testing
-------

Its hard to prove a negative.
I manually did a local chain of 300 several times and MALLOC_DEBUG did not complain of any high fence violations.


Thanks,

rmudgett

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-dev/attachments/20130910/8dac3581/attachment.htm>


More information about the asterisk-dev mailing list