Fix call pickup with SIP
authorMark Spencer <markster@digium.com>
Sat, 23 Aug 2003 22:27:10 +0000 (22:27 +0000)
committerMark Spencer <markster@digium.com>
Sat, 23 Aug 2003 22:27:10 +0000 (22:27 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1412 65c4cc65-6c06-0410-ace0-fbb531ad65f3

channels/chan_sip.c

index 5099c2a..7934d63 100755 (executable)
@@ -4752,22 +4752,23 @@ static int handle_request(struct sip_pvt *p, struct sip_request *req, struct soc
                                                transmit_response_reliable(p, "503 Unavailable", req);
                                                c = NULL;
                                        }
-                               } else if (ast_pickup_call(c)) {
-                                       ast_log(LOG_NOTICE, "Nothing to pick up\n");
-                                       transmit_response_reliable(p, "503 Unavailable", req);
-                                       p->alreadygone = 1;
-                                       /* Unlock locks so ast_hangup can do its magic */
-                                       ast_mutex_unlock(&c->lock);
-                                       ast_mutex_unlock(&p->lock);
-                                       ast_hangup(c);
-                                       ast_mutex_lock(&p->lock);
-                                       c = NULL;
                                } else {
                                        ast_mutex_unlock(&c->lock);
-                                       ast_mutex_unlock(&p->lock);
-                                       ast_hangup(c);
-                                       ast_mutex_lock(&p->lock);
-                                       c = NULL;
+                                       if (ast_pickup_call(c)) {
+                                               ast_log(LOG_NOTICE, "Nothing to pick up\n");
+                                               transmit_response_reliable(p, "503 Unavailable", req);
+                                               p->alreadygone = 1;
+                                               /* Unlock locks so ast_hangup can do its magic */
+                                               ast_mutex_unlock(&p->lock);
+                                               ast_hangup(c);
+                                               ast_mutex_lock(&p->lock);
+                                               c = NULL;
+                                       } else {
+                                               ast_mutex_unlock(&p->lock);
+                                               ast_hangup(c);
+                                               ast_mutex_lock(&p->lock);
+                                               c = NULL;
+                                       }
                                }
                                break;
                        case AST_STATE_RING: