From 9b53acdbf5db4d8e3bdc58c5b772c156907d2c38 Mon Sep 17 00:00:00 2001 From: Russell Bryant Date: Mon, 28 Jan 2008 18:26:31 +0000 Subject: [PATCH] Fix a crash in ast_masq_park_call() (issue #11342) Reported by: DEA Patches: res_features-park.txt uploaded by DEA (license 3) git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@100626 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- res/res_features.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/res/res_features.c b/res/res_features.c index 8842c0b9be..834ef01910 100644 --- a/res/res_features.c +++ b/res/res_features.c @@ -456,6 +456,7 @@ int ast_masq_park_call(struct ast_channel *rchan, struct ast_channel *peer, int { struct ast_channel *chan; struct ast_frame *f; + char *orig_chan_name = NULL; /* Make a new, fake channel that we'll use to masquerade in the real one */ if (!(chan = ast_channel_alloc(0, AST_STATE_DOWN, 0, 0, rchan->accountcode, rchan->exten, rchan->context, rchan->amaflags, "Parked/%s",rchan->name))) { @@ -476,7 +477,10 @@ int ast_masq_park_call(struct ast_channel *rchan, struct ast_channel *peer, int if (f) ast_frfree(f); - ast_park_call(chan, peer, timeout, extout); + orig_chan_name = ast_strdupa(chan->name); + + park_call_full(chan, peer, timeout, extout, orig_chan_name); + return 0; }