mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-26 22:30:28 +00:00 
			
		
		
		
	Merged revisions 107158 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r107158 | russell | 2008-03-10 15:04:27 -0500 (Mon, 10 Mar 2008) | 9 lines Fix some bugs related to originating calls. If the code failed to start a PBX on the channel (such as if you set a call limit based on the system's load average), then there were cases where a channel that has already been free'd using ast_hangup() got accessed. This caused weird memory corruption and crashes to occur. (fixes issue BE-386) (much debugging credit goes to twilson, final patch written by me) ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@107159 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -6534,6 +6534,7 @@ int ast_pbx_outgoing_exten(const char *type, int format, void *data, int timeout | ||||
| 						if (channel) | ||||
| 							*channel = NULL; | ||||
| 						ast_hangup(chan); | ||||
| 						chan = NULL; | ||||
| 						res = -1; | ||||
| 					} | ||||
| 				} else { | ||||
| @@ -6544,6 +6545,7 @@ int ast_pbx_outgoing_exten(const char *type, int format, void *data, int timeout | ||||
| 							ast_channel_unlock(chan); | ||||
| 						} | ||||
| 						ast_hangup(chan); | ||||
| 						chan = NULL; | ||||
| 						res = -1; | ||||
| 					} | ||||
| 				} | ||||
| @@ -6562,6 +6564,7 @@ int ast_pbx_outgoing_exten(const char *type, int format, void *data, int timeout | ||||
| 					ast_channel_unlock(chan); | ||||
| 				} | ||||
| 				ast_hangup(chan); | ||||
| 				chan = NULL; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| @@ -6589,7 +6592,11 @@ int ast_pbx_outgoing_exten(const char *type, int format, void *data, int timeout | ||||
| 					pbx_builtin_setvar_helper(chan, "REASON", failed_reason); | ||||
| 					if (account) | ||||
| 						ast_cdr_setaccount(chan, account); | ||||
| 					ast_pbx_run(chan); | ||||
| 					if (ast_pbx_run(chan)) { | ||||
| 						ast_log(LOG_ERROR, "Unable to run PBX on %s\n", chan->name); | ||||
| 						ast_hangup(chan); | ||||
| 					} | ||||
| 					chan = NULL; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user