diff --git a/addons/chan_mobile.c b/addons/chan_mobile.c index c9e56b854f0d46491146fa098b36420090af2276..2cf7c7dbdd49906c7bc4d0cae846cc77f7a705d1 100644 --- a/addons/chan_mobile.c +++ b/addons/chan_mobile.c @@ -861,7 +861,6 @@ static struct ast_channel *mbl_new(int state, struct mbl_pvt *pvt, char *cid_num goto e_return; } - ast_channel_lock(chn); ast_channel_tech_set(chn, &mbl_tech); ast_format_cap_add(ast_channel_nativeformats(chn), &prefformat); ast_format_copy(ast_channel_rawreadformat(chn), &prefformat); @@ -879,7 +878,6 @@ static struct ast_channel *mbl_new(int state, struct mbl_pvt *pvt, char *cid_num if (pvt->sco_socket != -1) { ast_channel_set_fd(chn, 0, pvt->sco_socket); } - ast_channel_unlock(chn); return chn; diff --git a/addons/chan_ooh323.c b/addons/chan_ooh323.c index deec21fa74492a6ec2fc8ef1d8aca352690fa312..56a1b7b6832a1cf61dcf7a4929a6ab7b487d011c 100644 --- a/addons/chan_ooh323.c +++ b/addons/chan_ooh323.c @@ -2153,8 +2153,8 @@ int onCallEstablished(ooCallData *call) } ast_queue_control(c, AST_CONTROL_ANSWER); + ast_channel_unlock(p->owner); ast_publish_channel_state(c); - ast_channel_unlock(p->owner); } ast_mutex_unlock(&p->lock); diff --git a/apps/app_agent_pool.c b/apps/app_agent_pool.c index d49ec2348c364de7df432b537d76733680a8c1b8..c968153e64de3a4887da7a5bc895d0831ca9b96b 100644 --- a/apps/app_agent_pool.c +++ b/apps/app_agent_pool.c @@ -1464,9 +1464,7 @@ static void agent_logout(struct agent_pvt *agent) ast_bridge_destroy(caller_bridge, AST_CAUSE_USER_BUSY); } - ast_channel_lock(logged); send_agent_logoff(logged, agent->username, time_logged_in); - ast_channel_unlock(logged); ast_verb(2, "Agent '%s' logged out. Logged in for %ld seconds.\n", agent->username, time_logged_in); ast_channel_unref(logged); @@ -2047,9 +2045,7 @@ static int agent_login_exec(struct ast_channel *chan, const char *data) ast_verb(2, "Agent '%s' logged in (format %s/%s)\n", agent->username, ast_getformatname(ast_channel_readformat(chan)), ast_getformatname(ast_channel_writeformat(chan))); - ast_channel_lock(chan); send_agent_login(chan, agent->username); - ast_channel_unlock(chan); agent_run(agent, chan); return -1; diff --git a/apps/app_confbridge.c b/apps/app_confbridge.c index a886b5876c3260a80b6b8b221d5e0f5905df6894..8347bc6edddf1eb673deaf4a05a5f52abab5ce0c 100644 --- a/apps/app_confbridge.c +++ b/apps/app_confbridge.c @@ -1368,9 +1368,7 @@ static int alloc_playback_chan(struct confbridge_conference *conference) } /* To make sure playback_chan has the same language of that profile */ - ast_channel_lock(conference->playback_chan); ast_channel_language_set(conference->playback_chan, conference->b_profile.language); - ast_channel_unlock(conference->playback_chan); ast_debug(1, "Created announcer channel '%s' to conference bridge '%s'\n", ast_channel_name(conference->playback_chan), conference->name); diff --git a/apps/app_dial.c b/apps/app_dial.c index c52a9b917217576b9d33d92ffe262c27200f99dc..c9bee19b0ba4bd6cd40e587dda5e7ddd44261d95 100644 --- a/apps/app_dial.c +++ b/apps/app_dial.c @@ -2104,7 +2104,6 @@ static int dial_exec_full(struct ast_channel *chan, const char *data, struct ast struct ast_party_caller caller; /* Reset all DIAL variables back to blank, to prevent confusion (in case we don't reset all of them). */ - ast_channel_lock(chan); ast_channel_stage_snapshot(chan); pbx_builtin_setvar_helper(chan, "DIALSTATUS", ""); pbx_builtin_setvar_helper(chan, "DIALEDPEERNUMBER", ""); @@ -2112,7 +2111,6 @@ static int dial_exec_full(struct ast_channel *chan, const char *data, struct ast pbx_builtin_setvar_helper(chan, "ANSWEREDTIME", ""); pbx_builtin_setvar_helper(chan, "DIALEDTIME", ""); ast_channel_stage_snapshot_done(chan); - ast_channel_unlock(chan); if (ast_strlen_zero(data)) { ast_log(LOG_WARNING, "Dial requires an argument (technology/resource)\n"); @@ -2445,17 +2443,15 @@ static int dial_exec_full(struct ast_channel *chan, const char *data, struct ast continue; } - ast_channel_lock(tc); ast_channel_stage_snapshot(tc); - ast_channel_unlock(tc); ast_channel_get_device_name(tc, device_name, sizeof(device_name)); if (!ignore_cc) { ast_cc_extension_monitor_add_dialstring(chan, tmp->interface, device_name); } + pbx_builtin_setvar_helper(tc, "DIALEDPEERNUMBER", tmp->number); ast_channel_lock_both(tc, chan); - pbx_builtin_setvar_helper(tc, "DIALEDPEERNUMBER", tmp->number); /* Setup outgoing SDP to match incoming one */ if (!AST_LIST_FIRST(&out_chans) && !rest && CAN_EARLY_BRIDGE(peerflags, chan, tc)) { @@ -2728,10 +2724,8 @@ static int dial_exec_full(struct ast_channel *chan, const char *data, struct ast number = ast_strdupa(number); } ast_channel_unlock(peer); - ast_channel_lock(chan); pbx_builtin_setvar_helper(chan, "DIALEDPEERNUMBER", number); ast_channel_stage_snapshot_done(chan); - ast_channel_unlock(chan); if (!ast_strlen_zero(args.url) && ast_channel_supports_html(peer) ) { ast_debug(1, "app_dial: sendurl=%s.\n", args.url); @@ -2817,18 +2811,16 @@ static int dial_exec_full(struct ast_channel *chan, const char *data, struct ast /* chan and peer are going into the PBX; as such neither are considered * outgoing channels any longer */ ast_clear_flag(ast_channel_flags(chan), AST_FLAG_OUTGOING); + ast_channel_stage_snapshot(peer); + ast_clear_flag(ast_channel_flags(peer), AST_FLAG_OUTGOING); ast_replace_subargument_delimiter(opt_args[OPT_ARG_GOTO]); ast_parseable_goto(chan, opt_args[OPT_ARG_GOTO]); /* peer goes to the same context and extension as chan, so just copy info from chan*/ - ast_channel_lock(peer); - ast_channel_stage_snapshot(peer); - ast_clear_flag(ast_channel_flags(peer), AST_FLAG_OUTGOING); ast_channel_context_set(peer, ast_channel_context(chan)); ast_channel_exten_set(peer, ast_channel_exten(chan)); ast_channel_priority_set(peer, ast_channel_priority(chan) + 2); ast_channel_stage_snapshot_done(peer); - ast_channel_unlock(peer); if (ast_pbx_start(peer)) { ast_autoservice_chan_hangup_peer(chan, peer); } @@ -2978,9 +2970,7 @@ static int dial_exec_full(struct ast_channel *chan, const char *data, struct ast if (!res) { if (!ast_tvzero(calldurationlimit)) { struct timeval whentohangup = ast_tvadd(ast_tvnow(), calldurationlimit); - ast_channel_lock(peer); ast_channel_whentohangup_set(peer, &whentohangup); - ast_channel_unlock(peer); } if (!ast_strlen_zero(dtmfcalled)) { ast_verb(3, "Sending DTMF '%s' to the called party.\n", dtmfcalled); diff --git a/apps/app_disa.c b/apps/app_disa.c index 9e74127179bacf13b77f90c5a4965ee5a78fb3d1..fe53772f1e7dd2d083ed825f7c91bb26ce5816da 100644 --- a/apps/app_disa.c +++ b/apps/app_disa.c @@ -381,11 +381,8 @@ static int disa_exec(struct ast_channel *chan, const char *data) ast_set_callerid(chan, ourcidnum, ourcidname, ourcidnum); } - if (!ast_strlen_zero(acctcode)) { - ast_channel_lock(chan); + if (!ast_strlen_zero(acctcode)) ast_channel_accountcode_set(chan, acctcode); - ast_channel_unlock(chan); - } if (special_noanswer) { ast_clear_flag(&cdr_flags, AST_CDR_FLAG_DISABLE); diff --git a/apps/app_meetme.c b/apps/app_meetme.c index d9bdeb6051eb08ad267a2537c0c88bfe1b1a4eab..ffd55e70dffdb8b9cd94417f9d80923ed56f33ad 100644 --- a/apps/app_meetme.c +++ b/apps/app_meetme.c @@ -1384,9 +1384,7 @@ static void meetme_stasis_generate_msg(struct ast_conference *meetme_conference, } } - ast_channel_lock(chan); msg = ast_channel_blob_create(chan, message_type, json_object); - ast_channel_unlock(chan); if (!msg) { return; diff --git a/apps/app_queue.c b/apps/app_queue.c index 713dba2d72bc1b393ecf6d4aeb82a79745c13e9b..906dff15fc65ad600966cfcc96d2836ee2bc0138 100644 --- a/apps/app_queue.c +++ b/apps/app_queue.c @@ -2040,12 +2040,8 @@ static void queue_publish_multi_channel_blob(struct ast_channel *caller, struct RAII_VAR(struct ast_channel_snapshot *, caller_snapshot, NULL, ao2_cleanup); RAII_VAR(struct ast_channel_snapshot *, agent_snapshot, NULL, ao2_cleanup); - ast_channel_lock(caller); caller_snapshot = ast_channel_snapshot_create(caller); - ast_channel_unlock(caller); - ast_channel_lock(agent); agent_snapshot = ast_channel_snapshot_create(agent); - ast_channel_unlock(agent); if (!caller_snapshot || !agent_snapshot) { return; @@ -3456,9 +3452,7 @@ static int join_queue(char *queuename, struct queue_ent *qe, enum queue_result * "Queue", q->name, "Position", qe->pos, "Count", q->count); - ast_channel_lock(qe->chan); ast_channel_publish_blob(qe->chan, queue_caller_join_type(), blob); - ast_channel_unlock(qe->chan); ast_debug(1, "Queue '%s' Join, Channel '%s', Position '%d'\n", q->name, ast_channel_name(qe->chan), qe->pos ); } ao2_unlock(q); @@ -3737,9 +3731,7 @@ static void leave_queue(struct queue_ent *qe) "Queue", q->name, "Position", qe->pos, "Count", q->count); - ast_channel_lock(qe->chan); ast_channel_publish_blob(qe->chan, queue_caller_leave_type(), blob); - ast_channel_unlock(qe->chan); ast_debug(1, "Queue '%s' Leave, Channel '%s'\n", q->name, ast_channel_name(qe->chan)); /* Take us out of the queue */ if (prev) { @@ -4337,13 +4329,10 @@ static void record_abandoned(struct queue_ent *qe) "Position", qe->pos, "OriginalPosition", qe->opos, "HoldTime", (int)(time(NULL) - qe->start)); + ast_channel_publish_blob(qe->chan, queue_caller_abandon_type(), blob); qe->parent->callsabandoned++; ao2_unlock(qe->parent); - - ast_channel_lock(qe->chan); - ast_channel_publish_blob(qe->chan, queue_caller_abandon_type(), blob); - ast_channel_unlock(qe->chan); } /*! \brief RNA == Ring No Answer. Common code that is executed when we try a queue member and they don't answer. */ diff --git a/apps/app_userevent.c b/apps/app_userevent.c index f5defd49d1149108364ef66248a6b6ba86acf4d4..e0dafbb9f5b887aa216d9d35bf48df1c48cfe399 100644 --- a/apps/app_userevent.c +++ b/apps/app_userevent.c @@ -114,9 +114,7 @@ static int userevent_exec(struct ast_channel *chan, const char *data) } } - ast_channel_lock(chan); ast_channel_publish_blob(chan, ast_channel_user_event_type(), blob); - ast_channel_unlock(chan); return 0; } diff --git a/apps/app_voicemail.c b/apps/app_voicemail.c index 7abf4530e1b8a964247afcb69cfc71b4684fa597..dca4eceeef526ad747209a83f56ce39ea8e0ef4b 100644 --- a/apps/app_voicemail.c +++ b/apps/app_voicemail.c @@ -10958,11 +10958,8 @@ static int vm_execmain(struct ast_channel *chan, const char *data) #endif /* Set language from config to override channel language */ - if (!ast_strlen_zero(vmu->language)) { - ast_channel_lock(chan); + if (!ast_strlen_zero(vmu->language)) ast_channel_language_set(chan, vmu->language); - ast_channel_unlock(chan); - } /* Retrieve urgent, old and new message counts */ ast_debug(1, "Before open_mailbox\n"); diff --git a/channels/chan_alsa.c b/channels/chan_alsa.c index 065eff5512b2c1db08bc5223ffd80d38fd5e689d..60bbacbb86e06ad0c01de250a5397fd9e4b65930 100644 --- a/channels/chan_alsa.c +++ b/channels/chan_alsa.c @@ -581,7 +581,6 @@ static struct ast_channel *alsa_new(struct chan_alsa_pvt *p, int state, const ch if (!(tmp = ast_channel_alloc(1, state, 0, 0, "", p->exten, p->context, linkedid, 0, "ALSA/%s", indevname))) return NULL; - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); ast_channel_tech_set(tmp, &alsa_tech); @@ -602,7 +601,6 @@ static struct ast_channel *alsa_new(struct chan_alsa_pvt *p, int state, const ch ast_jb_configure(tmp, &global_jbconf); ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN) { if (ast_pbx_start(tmp)) { diff --git a/channels/chan_console.c b/channels/chan_console.c index 6f694c2c939962131763720f3ae38f5d0eeaba21..922c53b426125aa1b9355ad60cf2283e928e6508 100644 --- a/channels/chan_console.c +++ b/channels/chan_console.c @@ -428,7 +428,6 @@ static struct ast_channel *console_new(struct console_pvt *pvt, const char *ext, return NULL; } - ast_channel_lock(chan); ast_channel_stage_snapshot(chan); ast_channel_tech_set(chan, &console_tech); @@ -445,7 +444,6 @@ static struct ast_channel *console_new(struct console_pvt *pvt, const char *ext, ast_jb_configure(chan, &global_jbconf); ast_channel_stage_snapshot_done(chan); - ast_channel_unlock(chan); if (state != AST_STATE_DOWN) { if (ast_pbx_start(chan)) { diff --git a/channels/chan_dahdi.c b/channels/chan_dahdi.c index 843254c56afa18fb2deda05b518f347963ee156f..2eba958a8b0286abeccda7cb06a23a4b8fe42f5d 100644 --- a/channels/chan_dahdi.c +++ b/channels/chan_dahdi.c @@ -1667,9 +1667,7 @@ static void publish_dahdichannel(struct ast_channel *chan, int span, const char return; } - ast_channel_lock(chan); ast_channel_publish_blob(chan, dahdichannel_type(), blob); - ast_channel_unlock(chan); } /*! @@ -8918,7 +8916,6 @@ static struct ast_channel *dahdi_new(struct dahdi_pvt *i, int state, int startpb return NULL; } - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); if (callid) { @@ -9099,7 +9096,6 @@ static struct ast_channel *dahdi_new(struct dahdi_pvt *i, int state, int startpb pbx_builtin_setvar_helper(tmp, v->name, v->value); ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); ast_module_ref(ast_module_info->self); @@ -9618,7 +9614,6 @@ static void *analog_ss_thread(void *data) getforward = 0; } else { res = tone_zone_play_tone(p->subs[idx].dfd, -1); - ast_channel_lock(chan); ast_channel_exten_set(chan, exten); if (!ast_strlen_zero(p->cid_num)) { if (!p->hidecallerid) @@ -9631,7 +9626,6 @@ static void *analog_ss_thread(void *data) ast_set_callerid(chan, NULL, p->cid_name, NULL); } ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); dahdi_ec_enable(p); res = ast_pbx_run(chan); if (res) { @@ -10395,10 +10389,8 @@ static void *analog_ss_thread(void *data) my_handle_notify_message(chan, p, flags, -1); - ast_channel_lock(chan); ast_setstate(chan, AST_STATE_RING); ast_channel_rings_set(chan, 1); - ast_channel_unlock(chan); p->ringt = p->ringt_base; res = ast_pbx_run(chan); if (res) { diff --git a/channels/chan_gtalk.c b/channels/chan_gtalk.c index 72c01ac8d970894fde4970b410e65f5ad6243d67..d6a09494197c08036ba4115d71369b7635849296 100644 --- a/channels/chan_gtalk.c +++ b/channels/chan_gtalk.c @@ -1150,7 +1150,6 @@ static struct ast_channel *gtalk_new(struct gtalk *client, struct gtalk_pvt *i, return NULL; } - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); ast_channel_tech_set(tmp, >alk_tech); @@ -1227,7 +1226,6 @@ static struct ast_channel *gtalk_new(struct gtalk *client, struct gtalk_pvt *i, ast_jb_configure(tmp, &global_jbconf); ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN && ast_pbx_start(tmp)) { ast_log(LOG_WARNING, "Unable to start PBX on %s\n", ast_channel_name(tmp)); @@ -1421,9 +1419,7 @@ static int gtalk_newcall(struct gtalk *client, ikspak *pak) ast_format_cap_joint_copy(p->cap, p->peercap, p->jointcap); ast_mutex_unlock(&p->lock); - ast_channel_lock(chan); ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); if (ast_format_cap_is_empty(p->jointcap)) { ast_log(LOG_WARNING, "Capabilities don't match : us - %s, peer - %s, combined - %s \n", ast_getformatname_multiple(s1, BUFSIZ, p->cap), ast_getformatname_multiple(s2, BUFSIZ, p->peercap), diff --git a/channels/chan_h323.c b/channels/chan_h323.c index 7ce098415a214d745165b140cfd56792fd083ee2..22dba3c18307b65a5ed78f282271cfc570ab647a 100644 --- a/channels/chan_h323.c +++ b/channels/chan_h323.c @@ -1061,9 +1061,6 @@ static struct ast_channel *__oh323_new(struct oh323_pvt *pvt, int state, const c ch = ast_channel_alloc(1, state, cid_num, cid_name, pvt->accountcode, pvt->exten, pvt->context, linkedid, pvt->amaflags, "H323/%s", host); /* Update usage counter */ ast_module_ref(ast_module_info->self); - if (ch) { - ast_channel_lock(ch); - } ast_mutex_lock(&pvt->lock); if (ch) { ast_channel_tech_set(ch, &oh323_tech); @@ -1142,7 +1139,6 @@ static struct ast_channel *__oh323_new(struct oh323_pvt *pvt, int state, const c } if (pvt->cd.transfer_capability >= 0) ast_channel_transfercapability_set(ch, pvt->cd.transfer_capability); - ast_channel_unlock(ch); if (state != AST_STATE_DOWN) { if (ast_pbx_start(ch)) { ast_log(LOG_WARNING, "Unable to start PBX on %s\n", ast_channel_name(ch)); diff --git a/channels/chan_iax2.c b/channels/chan_iax2.c index 80081174edb5fb5a49dea10c6938bd173d98532f..e27cc14c63a03188db7cea52eb146cc261c4a6d1 100644 --- a/channels/chan_iax2.c +++ b/channels/chan_iax2.c @@ -5689,15 +5689,11 @@ static struct ast_channel *ast_iax2_new(int callno, int state, iax2_format capab /* Don't hold call lock */ ast_mutex_unlock(&iaxsl[callno]); tmp = ast_channel_alloc(1, state, i->cid_num, i->cid_name, i->accountcode, i->exten, i->context, linkedid, i->amaflags, "IAX2/%s-%d", i->host, i->callno); - if (tmp) { - ast_channel_lock(tmp); - } ast_mutex_lock(&iaxsl[callno]); if (i != iaxs[callno]) { if (tmp) { /* unlock and relock iaxsl[callno] to preserve locking order */ ast_mutex_unlock(&iaxsl[callno]); - ast_channel_unlock(tmp); tmp = ast_channel_release(tmp); ast_mutex_lock(&iaxsl[callno]); } @@ -5807,7 +5803,6 @@ static struct ast_channel *ast_iax2_new(int callno, int state, iax2_format capab } ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN) { if (ast_pbx_start(tmp)) { @@ -12239,9 +12234,7 @@ static struct ast_channel *iax2_request(const char *type, struct ast_format_cap if (c) { struct ast_format_cap *joint; if (callid) { - ast_channel_lock(c); ast_channel_callid_set(c, callid); - ast_channel_unlock(c); } /* Choose a format we can live with */ diff --git a/channels/chan_jingle.c b/channels/chan_jingle.c index 8604d4eb9e3e94cbbb87cdaf25692a35d964fb16..56c15b193f6f14cf4d359f4fa9163f6786933098 100644 --- a/channels/chan_jingle.c +++ b/channels/chan_jingle.c @@ -864,7 +864,6 @@ static struct ast_channel *jingle_new(struct jingle *client, struct jingle_pvt * return NULL; } - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); ast_channel_tech_set(tmp, &jingle_tech); @@ -942,7 +941,6 @@ static struct ast_channel *jingle_new(struct jingle *client, struct jingle_pvt * ast_jb_configure(tmp, &global_jbconf); ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN && ast_pbx_start(tmp)) { ast_log(LOG_WARNING, "Unable to start PBX on %s\n", ast_channel_name(tmp)); @@ -1117,9 +1115,7 @@ static int jingle_newcall(struct jingle *client, ikspak *pak) } ast_mutex_unlock(&p->lock); - ast_channel_lock(chan); ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); res = ast_pbx_start(chan); switch (res) { diff --git a/channels/chan_mgcp.c b/channels/chan_mgcp.c index c10697158fd96d01d9c2d96004b0aaa3bab5b2bc..84fb3b2256fcd1bcfd197ea8b0a8a7c4fc820b67 100644 --- a/channels/chan_mgcp.c +++ b/channels/chan_mgcp.c @@ -1507,7 +1507,6 @@ static struct ast_channel *mgcp_new(struct mgcp_subchannel *sub, int state, cons tmp = ast_channel_alloc(1, state, i->cid_num, i->cid_name, linkedid, i->accountcode, i->exten, i->context, i->amaflags, "MGCP/%s@%s-%d", i->name, i->parent->name, sub->id); if (tmp) { - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); ast_channel_tech_set(tmp, &mgcp_tech); ast_format_cap_copy(ast_channel_nativeformats(tmp), i->cap); @@ -1571,7 +1570,6 @@ static struct ast_channel *mgcp_new(struct mgcp_subchannel *sub, int state, cons } ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN) { if (ast_pbx_start(tmp)) { @@ -3048,7 +3046,6 @@ static void *mgcp_ss(void *data) } else { /*res = tone_zone_play_tone(p->subs[index].zfd, -1);*/ ast_indicate(chan, -1); - ast_channel_lock(chan); ast_channel_exten_set(chan, p->dtmf_buf); ast_channel_dialed(chan)->number.str = ast_strdup(p->dtmf_buf); memset(p->dtmf_buf, 0, sizeof(p->dtmf_buf)); @@ -3057,7 +3054,6 @@ static void *mgcp_ss(void *data) p->hidecallerid ? "" : p->cid_name, ast_channel_caller(chan)->ani.number.valid ? NULL : p->cid_num); ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); if (p->dtmfmode & MGCP_DTMF_HYBRID) { p->dtmfmode |= MGCP_DTMF_INBAND; ast_indicate(chan, -1); diff --git a/channels/chan_misdn.c b/channels/chan_misdn.c index a1b9105e64f7fe4203bbbb0e854b6c5e51e2c771..38197c6381e63f4c7464dd9453aed02f23f15c94 100644 --- a/channels/chan_misdn.c +++ b/channels/chan_misdn.c @@ -5954,9 +5954,7 @@ static int read_config(struct chan_list *ch) chan_misdn_log(1, port, "read_config: Getting Config\n"); misdn_cfg_get(port, MISDN_CFG_LANGUAGE, lang, sizeof(lang)); - ast_channel_lock(ast); ast_channel_language_set(ast, lang); - ast_channel_unlock(ast); misdn_cfg_get(port, MISDN_CFG_MUSICCLASS, ch->mohinterpret, sizeof(ch->mohinterpret)); @@ -6002,9 +6000,7 @@ static int read_config(struct chan_list *ch) misdn_cfg_get(bc->port, MISDN_CFG_CONTEXT, ch->context, sizeof(ch->context)); - ast_channel_lock(ast); ast_channel_context_set(ast, ch->context); - ast_channel_unlock(ast); #ifdef MISDN_1_2 update_pipeline_config(bc); @@ -6021,10 +6017,8 @@ static int read_config(struct chan_list *ch) misdn_cfg_get(port, MISDN_CFG_PICKUPGROUP, &pg, sizeof(pg)); misdn_cfg_get(port, MISDN_CFG_CALLGROUP, &cg, sizeof(cg)); chan_misdn_log(5, port, " --> * CallGrp:%s PickupGrp:%s\n", ast_print_group(buf, sizeof(buf), cg), ast_print_group(buf2, sizeof(buf2), pg)); - ast_channel_lock(ast); ast_channel_pickupgroup_set(ast, pg); ast_channel_callgroup_set(ast, cg); - ast_channel_unlock(ast); misdn_cfg_get(port, MISDN_CFG_NAMEDPICKUPGROUP, &npg, sizeof(npg)); misdn_cfg_get(port, MISDN_CFG_NAMEDCALLGROUP, &ncg, sizeof(ncg)); @@ -6037,10 +6031,8 @@ static int read_config(struct chan_list *ch) ast_free(tmp_str); } - ast_channel_lock(ast); ast_channel_named_pickupgroups_set(ast, npg); ast_channel_named_callgroups_set(ast, ncg); - ast_channel_unlock(ast); if (ch->originator == ORG_AST) { char callerid[BUFFERSIZE + 1]; @@ -6094,9 +6086,7 @@ static int read_config(struct chan_list *ch) /* Add configured prefix to dialed.number */ misdn_add_number_prefix(bc->port, bc->dialed.number_type, bc->dialed.number, sizeof(bc->dialed.number)); - ast_channel_lock(ast); ast_channel_exten_set(ast, bc->dialed.number); - ast_channel_unlock(ast); misdn_cfg_get(bc->port, MISDN_CFG_OVERLAP_DIAL, &ch->overlap_dial, sizeof(ch->overlap_dial)); ast_mutex_init(&ch->overlap_tv_lock); @@ -10238,10 +10228,8 @@ cb_events(enum event_e event, struct misdn_bchannel *bc, void *user_data) export_ch(chan, bc, ch); - ast_channel_lock(ch->ast); ast_channel_rings_set(ch->ast, 1); ast_setstate(ch->ast, AST_STATE_RINGING); - ast_channel_unlock(ch->ast); /* Update asterisk channel caller information */ chan_misdn_log(2, bc->port, " --> TON: %s(%d)\n", misdn_to_str_ton(bc->caller.number_type), bc->caller.number_type); @@ -10540,9 +10528,7 @@ cb_events(enum event_e event, struct misdn_bchannel *bc, void *user_data) } ast_queue_control(ch->ast, AST_CONTROL_RINGING); - ast_channel_lock(ch->ast); ast_setstate(ch->ast, AST_STATE_RINGING); - ast_channel_unlock(ch->ast); cb_log(7, bc->port, " --> Set State Ringing\n"); diff --git a/channels/chan_motif.c b/channels/chan_motif.c index 85234ad3a2a4590ae651885abf11920746febe71..1e7ee3cce67c58a37e53dcebcb606be04698ffaa 100644 --- a/channels/chan_motif.c +++ b/channels/chan_motif.c @@ -785,7 +785,6 @@ static struct ast_channel *jingle_new(struct jingle_endpoint *endpoint, struct j if (!(chan = ast_channel_alloc(1, state, S_OR(title, ""), S_OR(cid_name, ""), "", "", "", linkedid, 0, "Motif/%s-%04lx", str, ast_random() & 0xffff))) { return NULL; } - ast_channel_lock(chan); ast_channel_stage_snapshot(chan); @@ -853,7 +852,6 @@ static struct ast_channel *jingle_new(struct jingle_endpoint *endpoint, struct j ao2_unlock(endpoint); ast_channel_stage_snapshot_done(chan); - ast_channel_unlock(chan); return chan; } @@ -2414,9 +2412,7 @@ static void jingle_action_session_initiate(struct jingle_endpoint *endpoint, str ao2_link(endpoint->state->sessions, session); - ast_channel_lock(chan); ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); res = ast_pbx_start(chan); switch (res) { diff --git a/channels/chan_nbs.c b/channels/chan_nbs.c index 41f696207b12e4c1488f597007ba84a190804b69..1d8c59d4e1d819c0c9e95030b4355aa84023cb38 100644 --- a/channels/chan_nbs.c +++ b/channels/chan_nbs.c @@ -223,7 +223,6 @@ static struct ast_channel *nbs_new(struct nbs_pvt *i, int state, const char *lin struct ast_channel *tmp; tmp = ast_channel_alloc(1, state, 0, 0, "", "s", context, linkedid, 0, "NBS/%s", i->stream); if (tmp) { - ast_channel_lock(tmp); ast_channel_tech_set(tmp, &nbs_tech); ast_channel_set_fd(tmp, 0, nbs_fd(i->nbs)); @@ -240,7 +239,6 @@ static struct ast_channel *nbs_new(struct nbs_pvt *i, int state, const char *lin ast_channel_language_set(tmp, ""); i->owner = tmp; i->u = ast_module_user_add(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN) { if (ast_pbx_start(tmp)) { ast_log(LOG_WARNING, "Unable to start PBX on %s\n", ast_channel_name(tmp)); diff --git a/channels/chan_oss.c b/channels/chan_oss.c index 92c7374db2699bd082ada6669296152cb2725f49..5ae18f362e8ae9b8c67fe84a44a782a7e70d321b 100644 --- a/channels/chan_oss.c +++ b/channels/chan_oss.c @@ -799,7 +799,6 @@ static struct ast_channel *oss_new(struct chan_oss_pvt *o, char *ext, char *ctx, c = ast_channel_alloc(1, state, o->cid_num, o->cid_name, "", ext, ctx, linkedid, 0, "Console/%s", o->device + 5); if (c == NULL) return NULL; - ast_channel_lock(c); ast_channel_tech_set(c, &oss_tech); if (o->sounddev < 0) setformat(o, O_RDWR); @@ -830,7 +829,6 @@ static struct ast_channel *oss_new(struct chan_oss_pvt *o, char *ext, char *ctx, o->owner = c; ast_module_ref(ast_module_info->self); ast_jb_configure(c, &global_jbconf); - ast_channel_unlock(c); if (state != AST_STATE_DOWN) { if (ast_pbx_start(c)) { ast_log(LOG_WARNING, "Unable to start PBX on %s\n", ast_channel_name(c)); diff --git a/channels/chan_phone.c b/channels/chan_phone.c index ca69a2f693d58368f1c900dda0f5fb1af5bc7fcd..c1a24b8b1b95dffcc01eab349eabc4ed8403bb4d 100644 --- a/channels/chan_phone.c +++ b/channels/chan_phone.c @@ -862,7 +862,6 @@ static struct ast_channel *phone_new(struct phone_pvt *i, int state, char *cntx, struct ast_format tmpfmt; tmp = ast_channel_alloc(1, state, i->cid_num, i->cid_name, "", i->ext, i->context, linkedid, 0, "Phone/%s", i->dev + 5); if (tmp) { - ast_channel_lock(tmp); ast_channel_tech_set(tmp, cur_tech); ast_channel_set_fd(tmp, 0, i->fd); /* XXX Switching formats silently causes kernel panics XXX */ @@ -899,7 +898,6 @@ static struct ast_channel *phone_new(struct phone_pvt *i, int state, char *cntx, ast_channel_caller(tmp)->ani.number.valid = 1; ast_channel_caller(tmp)->ani.number.str = ast_strdup(i->cid_num); } - ast_channel_unlock(tmp); i->owner = tmp; ast_module_ref(ast_module_info->self); diff --git a/channels/chan_pjsip.c b/channels/chan_pjsip.c index 12fb45969007d13c5b8bdf04a7bdb9acd23e225d..80cf270afedb7056fbc94c1d2db705aa6a1e62f4 100644 --- a/channels/chan_pjsip.c +++ b/channels/chan_pjsip.c @@ -577,15 +577,13 @@ static struct ast_channel *chan_pjsip_new(struct ast_sip_session *session, int s return NULL; } + ast_channel_stage_snapshot(chan); + /* If res_pjsip_session is ever updated to create/destroy ast_sip_session_media * during a call such as if multiple same-type stream support is introduced, * these will need to be recaptured as well */ pvt->media[SIP_MEDIA_AUDIO] = ao2_find(session->media, "audio", OBJ_KEY); pvt->media[SIP_MEDIA_VIDEO] = ao2_find(session->media, "video", OBJ_KEY); - - ast_channel_lock(chan); - ast_channel_stage_snapshot(chan); - ast_channel_tech_pvt_set(chan, channel); if (pvt->media[SIP_MEDIA_AUDIO] && pvt->media[SIP_MEDIA_AUDIO]->rtp) { ast_rtp_instance_set_channel_id(pvt->media[SIP_MEDIA_AUDIO]->rtp, ast_channel_uniqueid(chan)); @@ -634,11 +632,10 @@ static struct ast_channel *chan_pjsip_new(struct ast_sip_session *session, int s ast_channel_zone_set(chan, zone); } - ast_channel_stage_snapshot_done(chan); - ast_channel_unlock(chan); - ast_endpoint_add_channel(session->endpoint->persistent, chan); + ast_channel_stage_snapshot_done(chan); + return chan; } @@ -2033,11 +2030,9 @@ static void chan_pjsip_incoming_response(struct ast_sip_session *session, struct switch (status.code) { case 180: ast_queue_control(session->channel, AST_CONTROL_RINGING); - ast_channel_lock(session->channel); if (ast_channel_state(session->channel) != AST_STATE_UP) { ast_setstate(session->channel, AST_STATE_RINGING); } - ast_channel_unlock(session->channel); break; case 183: ast_queue_control(session->channel, AST_CONTROL_PROGRESS); diff --git a/channels/chan_sip.c b/channels/chan_sip.c index fafe71257dc16e9a6f63df41548e457910623ff0..c56f7c4c929cacee4bb6241886bf47147f51fcb8 100644 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -8106,7 +8106,6 @@ static struct ast_channel *sip_new(struct sip_pvt *i, int state, const char *tit } } - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); /* If we sent in a callid, bind it to the channel. */ @@ -8114,6 +8113,7 @@ static struct ast_channel *sip_new(struct sip_pvt *i, int state, const char *tit ast_channel_callid_set(tmp, callid); } + ast_channel_lock(tmp); sip_pvt_lock(i); ast_channel_cc_params_init(tmp, i->cc_params); ast_channel_caller(tmp)->id.tag = ast_strdup(i->cid_tag); diff --git a/channels/chan_skinny.c b/channels/chan_skinny.c index 191c3cc2453cd4a79eb08e4ecfefa9e1a1bf7e1a..a65862ff3caaf70e40a9dc08d980facc40cbf97e 100644 --- a/channels/chan_skinny.c +++ b/channels/chan_skinny.c @@ -4845,7 +4845,6 @@ static void *skinny_newcall(void *data) struct skinny_device *d = l->device; int res = 0; - ast_channel_lock(c); ast_set_callerid(c, l->hidecallerid ? "" : l->cid_num, l->hidecallerid ? "" : l->cid_name, @@ -4859,7 +4858,6 @@ static void *skinny_newcall(void *data) ast_party_name_init(&ast_channel_connected(c)->id.name); #endif ast_setstate(c, AST_STATE_RING); - ast_channel_unlock(c); if (!sub->rtp) { start_rtp(sub); } @@ -5426,7 +5424,6 @@ static struct ast_channel *skinny_new(struct skinny_line *l, struct skinny_subli AST_LIST_INSERT_HEAD(&l->sub, sub, list); //l->activesub = sub; } - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); ast_channel_tech_set(tmp, &skinny_tech); ast_channel_tech_pvt_set(tmp, sub); @@ -5502,7 +5499,6 @@ static struct ast_channel *skinny_new(struct skinny_line *l, struct skinny_subli pbx_builtin_setvar_helper(tmp, v->name, v->value); ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN) { if (ast_pbx_start(tmp)) { diff --git a/channels/chan_unistim.c b/channels/chan_unistim.c index 93fd9c502fa5b4b3f46042bf4e51b3d848871717..547cd7c2f6e23aeaa654fd13073a09e1643ea214 100644 --- a/channels/chan_unistim.c +++ b/channels/chan_unistim.c @@ -2517,12 +2517,10 @@ static void *unistim_ss(void *data) int res; ast_verb(3, "Starting switch on '%s@%s-%d' to %s\n", l->name, l->parent->name, sub->softkey, s->device->phone_number); - ast_channel_lock(chan); ast_channel_exten_set(chan, s->device->phone_number); - ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); ast_copy_string(s->device->redial_number, s->device->phone_number, sizeof(s->device->redial_number)); + ast_setstate(chan, AST_STATE_RING); res = ast_pbx_run(chan); if (res) { ast_log(LOG_WARNING, "PBX exited non-zero\n"); @@ -5565,7 +5563,6 @@ static struct ast_channel *unistim_new(struct unistim_subchannel *sub, int state return NULL; } - ast_channel_lock(tmp); ast_channel_stage_snapshot(tmp); ast_format_cap_copy(ast_channel_nativeformats(tmp), l->cap); @@ -5630,7 +5627,6 @@ static struct ast_channel *unistim_new(struct unistim_subchannel *sub, int state ast_channel_priority_set(tmp, 1); ast_channel_stage_snapshot_done(tmp); - ast_channel_unlock(tmp); if (state != AST_STATE_DOWN) { if (unistimdebug) { diff --git a/channels/chan_vpb.cc b/channels/chan_vpb.cc index 6ee0e0618ba612771b252eb69c849cd2aecb3098..12f27249b1504dd439b142ab2b98936951747a79 100644 --- a/channels/chan_vpb.cc +++ b/channels/chan_vpb.cc @@ -2439,7 +2439,6 @@ static struct ast_channel *vpb_new(struct vpb_pvt *me, enum ast_channel_state st tmp = ast_channel_alloc(1, state, 0, 0, "", me->ext, me->context, linkedid, AST_AMA_NONE, "%s", me->dev); if (tmp) { - ast_channel_lock(tmp); if (use_ast_ind == 1){ ast_channel_tech_set(tmp, &vpb_tech_indicate); } else { @@ -2472,7 +2471,6 @@ static struct ast_channel *vpb_new(struct vpb_pvt *me, enum ast_channel_state st ast_channel_exten_set(tmp, "s"); if (!ast_strlen_zero(me->language)) ast_channel_language_set(tmp, me->language); - ast_channel_unlock(tmp); me->owner = tmp; diff --git a/channels/sig_analog.c b/channels/sig_analog.c index 51d3f149580325c98df368a64ed4bfa1f57d2059..bbf7a3c8c3ca8fcd972d10d84481b70d2bd145d4 100644 --- a/channels/sig_analog.c +++ b/channels/sig_analog.c @@ -2120,7 +2120,6 @@ static void *__analog_ss_thread(void *data) getforward = 0; } else { res = analog_play_tone(p, idx, -1); - ast_channel_lock(chan); ast_channel_exten_set(chan, exten); if (!ast_strlen_zero(p->cid_num)) { if (!p->hidecallerid) { @@ -2135,7 +2134,6 @@ static void *__analog_ss_thread(void *data) } } ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); analog_set_echocanceller(p, 1); res = ast_pbx_run(chan); if (res) { @@ -2617,10 +2615,8 @@ static void *__analog_ss_thread(void *data) analog_handle_notify_message(chan, p, flags, -1); - ast_channel_lock(chan); ast_setstate(chan, AST_STATE_RING); ast_channel_rings_set(chan, 1); - ast_channel_unlock(chan); analog_set_ringtimeout(p, p->ringt_base); res = ast_pbx_run(chan); if (res) { diff --git a/channels/sig_pri.c b/channels/sig_pri.c index 48c8c33d74f2f723ba2a591cd78bc05873f2b80b..5def34c2383950d8e4be29ee6cb8a511265e9f73 100644 --- a/channels/sig_pri.c +++ b/channels/sig_pri.c @@ -2160,9 +2160,7 @@ static void *pri_ss_thread(void *data) #endif /* defined(ISSUE_16789) */ sig_pri_set_echocanceller(p, 1); - ast_channel_lock(chan); ast_setstate(chan, AST_STATE_RING); - ast_channel_unlock(chan); res = ast_pbx_run(chan); if (res) { ast_log(LOG_WARNING, "PBX exited non-zero!\n"); diff --git a/funcs/func_timeout.c b/funcs/func_timeout.c index e93ce3f62a982d2f6a0cff210b57973e193ab495..3c2810fd5e38b795080ff5002004b58dc37f5b37 100644 --- a/funcs/func_timeout.c +++ b/funcs/func_timeout.c @@ -155,9 +155,7 @@ static int timeout_write(struct ast_channel *chan, const char *cmd, char *data, switch (*data) { case 'a': case 'A': - ast_channel_lock(chan); ast_channel_setwhentohangup_tv(chan, when); - ast_channel_unlock(chan); if (!ast_tvzero(*ast_channel_whentohangup(chan))) { when = ast_tvadd(when, ast_tvnow()); ast_strftime(timestr, sizeof(timestr), "%Y-%m-%d %H:%M:%S.%3q %Z", diff --git a/include/asterisk/aoc.h b/include/asterisk/aoc.h index 171fbb300f7179075598a9c5ec39301b3b0afcfb..727362c1fb88370fd5b249977695607f503f9980 100644 --- a/include/asterisk/aoc.h +++ b/include/asterisk/aoc.h @@ -497,10 +497,7 @@ int ast_aoc_s_add_special_arrangement(struct ast_aoc_decoded *decoded, */ int ast_aoc_decoded2str(const struct ast_aoc_decoded *decoded, struct ast_str **msg); -/*! - * \brief generate AOC manager event for an AOC-S, AOC-D, or AOC-E msg - * \pre chan is locked - */ +/*! \brief generate AOC manager event for an AOC-S, AOC-D, or AOC-E msg */ int ast_aoc_manager_event(const struct ast_aoc_decoded *decoded, struct ast_channel *chan); /*! \brief get the message type, AOC-D, AOC-E, or AOC Request */ diff --git a/include/asterisk/channel.h b/include/asterisk/channel.h index 29d551b12ba94d7bb55696e8326e2b066c336a23..7db2b3c3a2914315c834beb7d6edaa0ff472e3bb 100644 --- a/include/asterisk/channel.h +++ b/include/asterisk/channel.h @@ -1535,7 +1535,8 @@ int ast_channel_cmpwhentohangup_tv(struct ast_channel *chan, struct timeval offs * \details * This function sets the absolute time out on a channel (when to hang up). * - * \pre chan is locked + * \note This function does not require that the channel is locked before + * calling it. * * \return Nothing * \sa ast_channel_setwhentohangup_tv() @@ -1551,7 +1552,8 @@ void ast_channel_setwhentohangup(struct ast_channel *chan, time_t offset) __attr * * This function sets the absolute time out on a channel (when to hang up). * - * \pre chan is locked + * \note This function does not require that the channel is locked before + * calling it. * * \return Nothing * \since 1.6.1 @@ -2335,8 +2337,6 @@ void ast_channel_inherit_variables(const struct ast_channel *parent, struct ast_ * \param chan the channel * \param vars a linked list of variables * - * \pre chan is locked - * * \details * Variable names can be for a regular channel variable or a dialplan function * that has the ability to be written to. @@ -3803,15 +3803,6 @@ void ast_channel_name_set(struct ast_channel *chan, const char *name); void ast_channel_##field##_build_va(struct ast_channel *chan, const char *fmt, va_list ap) __attribute__((format(printf, 2, 0))); \ void ast_channel_##field##_build(struct ast_channel *chan, const char *fmt, ...) __attribute__((format(printf, 2, 3))) -/*! - * The following string fields result in channel snapshot creation and - * should have the channel locked when called: - * - * \li language - * \li accountcode - * \li peeracccount - * \li linkedid - */ DECLARE_STRINGFIELD_SETTERS_FOR(name); DECLARE_STRINGFIELD_SETTERS_FOR(language); DECLARE_STRINGFIELD_SETTERS_FOR(musicclass); @@ -3863,10 +3854,6 @@ void ast_channel_sending_dtmf_digit_set(struct ast_channel *chan, char value); struct timeval ast_channel_sending_dtmf_tv(const struct ast_channel *chan); void ast_channel_sending_dtmf_tv_set(struct ast_channel *chan, struct timeval value); enum ama_flags ast_channel_amaflags(const struct ast_channel *chan); - -/*! - * \pre chan is locked - */ void ast_channel_amaflags_set(struct ast_channel *chan, enum ama_flags value); int ast_channel_epfd(const struct ast_channel *chan); void ast_channel_epfd_set(struct ast_channel *chan, int value); @@ -3950,10 +3937,6 @@ enum ast_channel_adsicpe ast_channel_adsicpe(const struct ast_channel *chan); void ast_channel_adsicpe_set(struct ast_channel *chan, enum ast_channel_adsicpe value); enum ast_channel_state ast_channel_state(const struct ast_channel *chan); struct ast_callid *ast_channel_callid(const struct ast_channel *chan); - -/*! - * \pre chan is locked - */ void ast_channel_callid_set(struct ast_channel *chan, struct ast_callid *value); /* XXX Internal use only, make sure to move later */ @@ -3994,10 +3977,6 @@ void ast_channel_connected_set(struct ast_channel *chan, struct ast_party_connec void ast_channel_dialed_set(struct ast_channel *chan, struct ast_party_dialed *value); void ast_channel_redirecting_set(struct ast_channel *chan, struct ast_party_redirecting *value); void ast_channel_dtmf_tv_set(struct ast_channel *chan, struct timeval *value); - -/*! - * \pre chan is locked - */ void ast_channel_whentohangup_set(struct ast_channel *chan, struct timeval *value); void ast_channel_varshead_set(struct ast_channel *chan, struct varshead *value); struct timeval ast_channel_creationtime(struct ast_channel *chan); @@ -4013,14 +3992,8 @@ struct ast_readq_list *ast_channel_readq(struct ast_channel *chan); /* Typedef accessors */ ast_group_t ast_channel_callgroup(const struct ast_channel *chan); -/*! - * \pre chan is locked - */ void ast_channel_callgroup_set(struct ast_channel *chan, ast_group_t value); ast_group_t ast_channel_pickupgroup(const struct ast_channel *chan); -/*! - * \pre chan is locked - */ void ast_channel_pickupgroup_set(struct ast_channel *chan, ast_group_t value); struct ast_namedgroups *ast_channel_named_callgroups(const struct ast_channel *chan); void ast_channel_named_callgroups_set(struct ast_channel *chan, struct ast_namedgroups *value); @@ -4067,9 +4040,6 @@ ast_timing_func_t ast_channel_timingfunc(const struct ast_channel *chan); void ast_channel_timingfunc_set(struct ast_channel *chan, ast_timing_func_t value); struct ast_bridge *ast_channel_internal_bridge(const struct ast_channel *chan); -/*! - * \pre chan is locked - */ void ast_channel_internal_bridge_set(struct ast_channel *chan, struct ast_bridge *value); struct ast_bridge_channel *ast_channel_internal_bridge_channel(const struct ast_channel *chan); diff --git a/include/asterisk/channelstate.h b/include/asterisk/channelstate.h index 08f908256d8760fb71089955a7ee6d4464b0026e..f5f7392ddb80ca18856fa9dfd780314ed8854125 100644 --- a/include/asterisk/channelstate.h +++ b/include/asterisk/channelstate.h @@ -47,10 +47,7 @@ enum ast_channel_state { AST_STATE_MUTE = (1 << 16), /*!< Do not transmit voice data */ }; -/*! - * \brief Change the state of a channel - * \pre chan is locked - */ +/*! \brief Change the state of a channel */ int ast_setstate(struct ast_channel *chan, enum ast_channel_state); #endif /* __AST_CHANNELSTATE_H__ */ diff --git a/include/asterisk/stasis_bridges.h b/include/asterisk/stasis_bridges.h index 78b97d1883d22ec77960f7daf8ae2291bd553cb0..9412bf0b780b5b8934939751281df9bb6d2f9168 100644 --- a/include/asterisk/stasis_bridges.h +++ b/include/asterisk/stasis_bridges.h @@ -199,9 +199,6 @@ struct stasis_message_type *ast_channel_left_bridge_type(void); * should also be treated as immutable and not modified after it is put into the * message. * - * \pre bridge is locked. - * \pre No channels are locked. - * * \param bridge Channel blob is associated with, or NULL for global/all bridges. * \param blob JSON object representing the data. * \return \ref ast_bridge_blob message. @@ -216,9 +213,6 @@ struct stasis_message *ast_bridge_blob_create(struct stasis_message_type *type, * \since 12 * \brief Publish a bridge channel enter event * - * \pre bridge is locked. - * \pre No channels are locked. - * * \param bridge The bridge a channel entered * \param chan The channel that entered the bridge * \param swap The channel being swapped out of the bridge @@ -230,9 +224,6 @@ void ast_bridge_publish_enter(struct ast_bridge *bridge, struct ast_channel *cha * \since 12 * \brief Publish a bridge channel leave event * - * \pre bridge is locked. - * \pre No channels are locked. - * * \param bridge The bridge a channel left * \param chan The channel that left the bridge */ @@ -277,8 +268,6 @@ struct stasis_message_type *ast_blind_transfer_type(void); /*! * \brief Publish a blind transfer event * - * \pre No channels or bridges are locked - * * \param is_external Whether the blind transfer was initiated externally (e.g. via AMI or native protocol) * \param result The success or failure of the transfer * \param to_transferee The bridge between the transferer and transferee plus the transferer channel @@ -342,8 +331,6 @@ struct stasis_message_type *ast_attended_transfer_type(void); * Publish an \ref ast_attended_transfer_message with the dest_type set to * \c AST_ATTENDED_TRANSFER_DEST_FAIL. * - * \pre No channels or bridges are locked - * * \param is_external Indicates if the transfer was initiated externally * \param result The result of the transfer. Will always be a type of failure. * \param transferee The bridge between the transferer and transferees as well as the transferer channel from that bridge @@ -365,8 +352,6 @@ void ast_bridge_publish_attended_transfer_fail(int is_external, enum ast_transfe * * In either case, two bridges enter, one leaves. * - * \pre No channels or bridges are locked - * * \param is_external Indicates if the transfer was initiated externally * \param result The result of the transfer. * \param transferee The bridge between the transferer and transferees as well as the transferer channel from that bridge @@ -386,8 +371,6 @@ void ast_bridge_publish_attended_transfer_bridge_merge(int is_external, enum ast * this results from merging two bridges together. The difference is that a * transferer channel survives the bridge merge * - * \pre No channels or bridges are locked - * * \param is_external Indicates if the transfer was initiated externally * \param result The result of the transfer. * \param transferee The bridge between the transferer and transferees as well as the transferer channel from that bridge @@ -409,8 +392,6 @@ void ast_bridge_publish_attended_transfer_threeway(int is_external, enum ast_tra * \li A transferee channel leaving a bridge to run an app * \li A bridge of transferees running an app (via a local channel) * - * \pre No channels or bridges are locked - * * \param is_external Indicates if the transfer was initiated externally * \param result The result of the transfer. * \param transferee The bridge between the transferer and transferees as well as the transferer channel from that bridge @@ -434,8 +415,6 @@ void ast_bridge_publish_attended_transfer_app(int is_external, enum ast_transfer * When this type of transfer occurs, the two bridges continue to exist after the * transfer and a local channel is used to link the two bridges together. * - * \pre No channels or bridges are locked - * * \param is_external Indicates if the transfer was initiated externally * \param result The result of the transfer. * \param transferee The bridge between the transferer and transferees as well as the transferer channel from that bridge diff --git a/include/asterisk/stasis_channels.h b/include/asterisk/stasis_channels.h index 65ea660f65bccebdc3d345438b8c82fbac1a30a8..519a4b676e17c05715f1d0d1a7abcfead47c6fbe 100644 --- a/include/asterisk/stasis_channels.h +++ b/include/asterisk/stasis_channels.h @@ -153,8 +153,6 @@ struct stasis_message_type *ast_channel_snapshot_type(void); * \brief Generate a snapshot of the channel state. This is an ao2 object, so * ao2_cleanup() to deallocate. * - * \pre chan is locked - * * \param chan The channel from which to generate a snapshot * * \retval pointer on success (must be unreffed) @@ -194,8 +192,6 @@ struct ast_channel_snapshot *ast_channel_snapshot_get_latest_by_name(const char * The given \a blob should be treated as immutable and not modified after it is * put into the message. * - * \pre chan is locked - * * \param chan Channel blob is associated with, or \c NULL for global/all channels. * \param type Message type for this blob. * \param blob JSON object representing the data, or \c NULL for no data. If @@ -309,8 +305,6 @@ void ast_multi_channel_blob_add_channel(struct ast_multi_channel_blob *obj, * \brief Publish a channel blob message. * \since 12.0.0 * - * \pre chan is locked - * * \param chan Channel publishing the blob. * \param type Type of stasis message. * \param blob The blob being published. (NULL if no blob) @@ -324,8 +318,6 @@ void ast_channel_publish_blob(struct ast_channel *chan, struct stasis_message_ty * \since 12 * \brief Set flag to indicate channel snapshot is being staged. * - * \pre chan is locked - * * \param chan Channel being staged. */ void ast_channel_stage_snapshot(struct ast_channel *chan); @@ -334,8 +326,6 @@ void ast_channel_stage_snapshot(struct ast_channel *chan); * \since 12 * \brief Clear flag to indicate channel snapshot is being staged, and publish snapshot. * - * \pre chan is locked - * * \param chan Channel being staged. */ void ast_channel_stage_snapshot_done(struct ast_channel *chan); @@ -344,8 +334,6 @@ void ast_channel_stage_snapshot_done(struct ast_channel *chan); * \since 12 * \brief Publish a \ref ast_channel_snapshot for a channel. * - * \pre chan is locked - * * \param chan Channel to publish. */ void ast_channel_publish_snapshot(struct ast_channel *chan); @@ -354,8 +342,6 @@ void ast_channel_publish_snapshot(struct ast_channel *chan); * \since 12 * \brief Publish a \ref ast_channel_varset for a channel. * - * \pre chan is locked - * * \param chan Channel to publish the event for, or \c NULL for 'none'. * \param variable Name of the variable being set * \param value Value. @@ -547,8 +533,6 @@ void ast_channel_publish_dial_forward(struct ast_channel *caller, * \brief Publish in the \ref ast_channel_topic a \ref ast_channel_snapshot * message indicating a change in channel state * - * \pre chan is locked - * * \param chan The channel whose state has changed */ void ast_publish_channel_state(struct ast_channel *chan); diff --git a/main/bridge.c b/main/bridge.c index 5d6d0632a489c66516326ddbb841b3c7b7414637..1c3bf16e3a29f7312a283c46e139fbe33355d5ca 100644 --- a/main/bridge.c +++ b/main/bridge.c @@ -2497,13 +2497,7 @@ static int try_swap_optimize_out(struct ast_bridge *chan_bridge, other = ast_bridge_channel_peer(src_bridge_channel); if (other && other->state == BRIDGE_CHANNEL_STATE_WAIT) { - unsigned int id; - - if (ast_channel_trylock(other->chan)) { - return 1; - } - - id = ast_atomic_fetchadd_int((int *) &optimization_id, +1); + unsigned int id = ast_atomic_fetchadd_int((int *) &optimization_id, +1); ast_verb(3, "Move-swap optimizing %s <-- %s.\n", ast_channel_name(dst_bridge_channel->chan), @@ -2525,7 +2519,6 @@ static int try_swap_optimize_out(struct ast_bridge *chan_bridge, if (pvt && pvt->callbacks && pvt->callbacks->optimization_finished) { pvt->callbacks->optimization_finished(pvt, res == 1, id); } - ast_channel_unlock(other); } return res; } diff --git a/main/bridge_channel.c b/main/bridge_channel.c index ae33cd05674588fa42cf24e310adea06a935463c..96bfb209a352693b7132b6e236e98ca924c439da 100644 --- a/main/bridge_channel.c +++ b/main/bridge_channel.c @@ -235,16 +235,12 @@ void ast_bridge_channel_update_linkedids(struct ast_bridge_channel *bridge_chann return; } - ast_channel_lock(bridge_channel->chan); ast_channel_linkedid_set(bridge_channel->chan, oldest_linkedid); - ast_channel_unlock(bridge_channel->chan); AST_LIST_TRAVERSE(&bridge->channels, other, entry) { if (other == swap) { continue; } - ast_channel_lock(other->chan); ast_channel_linkedid_set(other->chan, oldest_linkedid); - ast_channel_unlock(other->chan); } } @@ -257,7 +253,6 @@ void ast_bridge_channel_update_accountcodes(struct ast_bridge_channel *bridge_ch if (other == swap) { continue; } - ast_channel_lock_both(bridge_channel->chan, other->chan); if (!ast_strlen_zero(ast_channel_accountcode(bridge_channel->chan)) && ast_strlen_zero(ast_channel_peeraccount(other->chan))) { ast_debug(1, "Setting peeraccount to %s for %s from data on channel %s\n", @@ -291,8 +286,6 @@ void ast_bridge_channel_update_accountcodes(struct ast_bridge_channel *bridge_ch ast_channel_peeraccount_set(bridge_channel->chan, ast_channel_accountcode(other->chan)); } } - ast_channel_unlock(bridge_channel->chan); - ast_channel_unlock(other->chan); } } @@ -631,18 +624,14 @@ int ast_bridge_channel_write_hold(struct ast_bridge_channel *bridge_channel, con datalen = 0; } - ast_channel_lock(bridge_channel->chan); ast_channel_publish_blob(bridge_channel->chan, ast_channel_hold_type(), blob); - ast_channel_unlock(bridge_channel->chan); return ast_bridge_channel_write_control_data(bridge_channel, AST_CONTROL_HOLD, moh_class, datalen); } int ast_bridge_channel_write_unhold(struct ast_bridge_channel *bridge_channel) { - ast_channel_lock(bridge_channel->chan); ast_channel_publish_blob(bridge_channel->chan, ast_channel_unhold_type(), NULL); - ast_channel_unlock(bridge_channel->chan); return ast_bridge_channel_write_control_data(bridge_channel, AST_CONTROL_UNHOLD, NULL, 0); } diff --git a/main/cel.c b/main/cel.c index b9f992f6fa8e415136f2bc6a63e2bf2a62fab294..db51361e9b64a4d41307859498ff151065b71f50 100644 --- a/main/cel.c +++ b/main/cel.c @@ -1614,9 +1614,7 @@ void ast_cel_publish_event(struct ast_channel *chan, "event_type", event_type, "event_details", blob); - ast_channel_lock(chan); message = ast_channel_blob_create(chan, cel_generic_type(), cel_blob); - ast_channel_unlock(chan); if (message) { stasis_publish(ast_cel_topic(), message); } diff --git a/main/channel.c b/main/channel.c index f1bbbda27b6e8c1e816ee9a9eff9ea6817177d48..58b50c820bb8a294e3155219fc8bbb8fb590eb5d 100644 --- a/main/channel.c +++ b/main/channel.c @@ -678,9 +678,7 @@ int ast_str2cause(const char *name) static struct stasis_message *create_channel_snapshot_message(struct ast_channel *channel) { RAII_VAR(struct ast_channel_snapshot *, snapshot, NULL, ao2_cleanup); - ast_channel_lock(channel); snapshot = ast_channel_snapshot_create(channel); - ast_channel_unlock(channel); if (!snapshot) { return NULL; } @@ -1263,7 +1261,6 @@ int ast_queue_hold(struct ast_channel *chan, const char *musicclass) struct ast_frame f = { AST_FRAME_CONTROL, .subclass.integer = AST_CONTROL_HOLD }; int res; - ast_channel_lock(chan); if (!ast_strlen_zero(musicclass)) { f.data.ptr = (void *) musicclass; f.datalen = strlen(musicclass) + 1; @@ -1275,7 +1272,6 @@ int ast_queue_hold(struct ast_channel *chan, const char *musicclass) ast_channel_publish_blob(chan, ast_channel_hold_type(), blob); res = ast_queue_frame(chan, &f); - ast_channel_unlock(chan); return res; } @@ -1284,11 +1280,9 @@ int ast_queue_unhold(struct ast_channel *chan) struct ast_frame f = { AST_FRAME_CONTROL, .subclass.integer = AST_CONTROL_UNHOLD }; int res; - ast_channel_lock(chan); ast_channel_publish_blob(chan, ast_channel_unhold_type(), NULL); res = ast_queue_frame(chan, &f); - ast_channel_unlock(chan); return res; } @@ -2254,9 +2248,7 @@ static void ast_channel_destructor(void *obj) /* Things that may possibly raise Stasis messages shouldn't occur after this point */ ast_set_flag(ast_channel_flags(chan), AST_FLAG_DEAD); - ast_channel_lock(chan); ast_channel_publish_snapshot(chan); - ast_channel_unlock(chan); publish_cache_clear(chan); ast_channel_lock(chan); @@ -5326,9 +5318,7 @@ static int set_format(struct ast_channel *chan, generator_write_format_change(chan); } - ast_channel_lock(chan); ast_channel_publish_snapshot(chan); - ast_channel_unlock(chan); return 0; } @@ -5409,9 +5399,7 @@ static int set_format(struct ast_channel *chan, generator_write_format_change(chan); } - ast_channel_lock(chan); ast_channel_publish_snapshot(chan); - ast_channel_unlock(chan); return res; } @@ -5628,9 +5616,7 @@ struct ast_channel *ast_call_forward(struct ast_channel *caller, struct ast_chan /* Copy/inherit important information into new channel */ if (oh) { if (oh->vars) { - ast_channel_lock(new_chan); ast_set_variables(new_chan, oh->vars); - ast_channel_unlock(new_chan); } if (oh->parent_channel) { call_forward_inherit(new_chan, oh->parent_channel, orig); @@ -5691,9 +5677,7 @@ struct ast_channel *__ast_request_and_dial(const char *type, struct ast_format_c if (oh) { if (oh->vars) { - ast_channel_lock(chan); ast_set_variables(chan, oh->vars); - ast_channel_unlock(chan); } if (!ast_strlen_zero(oh->cid_num) && !ast_strlen_zero(oh->cid_name)) { /* @@ -5965,9 +5949,7 @@ struct ast_channel *ast_request(const char *type, struct ast_format_cap *request if (requestor) { struct ast_callid *callid = ast_channel_callid(requestor); if (callid) { - ast_channel_lock(c); ast_channel_callid_set(c, callid); - ast_channel_unlock(c); callid = ast_callid_unref(callid); } } diff --git a/main/core_local.c b/main/core_local.c index 4b1253219a3686399055b685df12f7ae795a1b2c..4a047032ce4f91db42fbc6c69a81a0c6bcc24268 100644 --- a/main/core_local.c +++ b/main/core_local.c @@ -498,32 +498,29 @@ static void publish_local_bridge_message(struct local_pvt *p) RAII_VAR(struct stasis_message *, msg, NULL, ao2_cleanup); RAII_VAR(struct ast_channel_snapshot *, one_snapshot, NULL, ao2_cleanup); RAII_VAR(struct ast_channel_snapshot *, two_snapshot, NULL, ao2_cleanup); - struct ast_channel *owner; - struct ast_channel *chan; - - ast_unreal_lock_all(&p->base, &chan, &owner); + SCOPED_AO2LOCK(lock, p); blob = ast_json_pack("{s: s, s: s, s: b}", "context", p->context, "exten", p->exten, "can_optimize", !ast_test_flag(&p->base, AST_UNREAL_NO_OPTIMIZATION)); if (!blob) { - goto end; + return; } multi_blob = ast_multi_channel_blob_create(blob); if (!multi_blob) { - goto end; + return; } - one_snapshot = ast_channel_snapshot_create(owner); + one_snapshot = ast_channel_snapshot_create(p->base.owner); if (!one_snapshot) { - goto end; + return; } - two_snapshot = ast_channel_snapshot_create(chan); + two_snapshot = ast_channel_snapshot_create(p->base.chan); if (!two_snapshot) { - goto end; + return; } ast_multi_channel_blob_add_channel(multi_blob, "1", one_snapshot); @@ -531,15 +528,10 @@ static void publish_local_bridge_message(struct local_pvt *p) msg = stasis_message_create(ast_local_bridge_type(), multi_blob); if (!msg) { - goto end; + return; } - stasis_publish(ast_channel_topic(owner), msg); - -end: - ast_channel_unlock(owner); - ast_channel_unlock(chan); - ao2_unlock(p); + stasis_publish(ast_channel_topic(p->base.owner), msg); } int ast_local_setup_bridge(struct ast_channel *ast, struct ast_bridge *bridge, struct ast_channel *swap, struct ast_bridge_features *features) diff --git a/main/core_unreal.c b/main/core_unreal.c index 0a485970399a5dcc9ad2eee2488997c656b1a254..7e457f4849eebdc7578b880be111db347e755e71 100644 --- a/main/core_unreal.c +++ b/main/core_unreal.c @@ -918,12 +918,8 @@ struct ast_channel *ast_unreal_new_channels(struct ast_unreal_pvt *p, } if (callid) { - ast_channel_lock(owner); ast_channel_callid_set(owner, callid); - ast_channel_unlock(owner); - ast_channel_lock(chan); ast_channel_callid_set(chan, callid); - ast_channel_unlock(chan); } ast_channel_tech_set(owner, tech); diff --git a/main/dial.c b/main/dial.c index 1729af41ae9f00976fe57722021922738d558158..8cc6f9c89431e0851a360e3e2dc52519cd0d2466 100644 --- a/main/dial.c +++ b/main/dial.c @@ -286,7 +286,6 @@ static int begin_dial_prerun(struct ast_dial_channel *channel, struct ast_channe cap_request = NULL; cap_all_audio = ast_format_cap_destroy(cap_all_audio); - ast_channel_lock(channel->owner); ast_channel_stage_snapshot(channel->owner); ast_channel_appl_set(channel->owner, "AppDial2"); @@ -316,7 +315,6 @@ static int begin_dial_prerun(struct ast_dial_channel *channel, struct ast_channe } ast_channel_stage_snapshot_done(channel->owner); - ast_channel_unlock(channel->owner); return 0; } diff --git a/main/endpoints.c b/main/endpoints.c index 3480a3055ae862da21f6ce07811f17e519ecbc73..9eeadfeef8774764f76e092e6e097989ce5a530c 100644 --- a/main/endpoints.c +++ b/main/endpoints.c @@ -203,9 +203,7 @@ int ast_endpoint_add_channel(struct ast_endpoint *endpoint, ast_str_container_add(endpoint->channel_ids, ast_channel_uniqueid(chan)); ao2_unlock(endpoint); - ast_channel_lock(chan); ast_publish_channel_state(chan); - ast_channel_unlock(chan); endpoint_publish_snapshot(endpoint); return 0; diff --git a/main/pbx.c b/main/pbx.c index 03b1c4a8e27517b966050233f56a8c761cdbc467..99c686371d2e3d6f96fcbe6a9125aa6d8478740c 100644 --- a/main/pbx.c +++ b/main/pbx.c @@ -1601,11 +1601,9 @@ int pbx_exec(struct ast_channel *c, /*!< Channel */ saved_c_appl= ast_channel_appl(c); saved_c_data= ast_channel_data(c); - ast_channel_lock(c); ast_channel_appl_set(c, app->name); ast_channel_data_set(c, data); ast_channel_publish_snapshot(c); - ast_channel_unlock(c); if (app->module) u = __ast_module_user_add(app->module, c); @@ -6103,9 +6101,7 @@ static enum ast_pbx_result __ast_pbx_run(struct ast_channel *c, if (!callid) { callid = ast_create_callid(); if (callid) { - ast_channel_lock(c); ast_channel_callid_set(c, callid); - ast_channel_unlock(c); } } ast_callid_threadassoc_add(callid); @@ -10073,7 +10069,6 @@ static int pbx_outgoing_attempt(const char *type, struct ast_format_cap *cap, co return -1; } - ast_channel_lock(dialed); if (vars) { ast_set_variables(dialed, vars); } @@ -10082,7 +10077,6 @@ static int pbx_outgoing_attempt(const char *type, struct ast_format_cap *cap, co ast_channel_accountcode_set(dialed, account); } ast_set_flag(ast_channel_flags(dialed), AST_FLAG_ORIGINATED); - ast_channel_unlock(dialed); if (!ast_strlen_zero(cid_num) || !ast_strlen_zero(cid_name)) { struct ast_party_connected_line connected; @@ -10178,7 +10172,6 @@ static int pbx_outgoing_attempt(const char *type, struct ast_format_cap *cap, co if (failed) { char failed_reason[4] = ""; - ast_channel_lock(failed); if (!ast_strlen_zero(context)) { ast_channel_context_set(failed, context); } @@ -10191,7 +10184,6 @@ static int pbx_outgoing_attempt(const char *type, struct ast_format_cap *cap, co ast_set_variables(failed, vars); snprintf(failed_reason, sizeof(failed_reason), "%d", ast_dial_reason(outgoing->dial, 0)); pbx_builtin_setvar_helper(failed, "REASON", failed_reason); - ast_channel_unlock(failed); if (ast_pbx_run(failed)) { ast_log(LOG_ERROR, "Unable to run PBX on '%s'\n", ast_channel_name(failed)); @@ -10492,12 +10484,10 @@ static int pbx_builtin_busy(struct ast_channel *chan, const char *data) ast_indicate(chan, AST_CONTROL_BUSY); /* Don't change state of an UP channel, just indicate busy in audio */ - ast_channel_lock(chan); if (ast_channel_state(chan) != AST_STATE_UP) { ast_channel_hangupcause_set(chan, AST_CAUSE_BUSY); ast_setstate(chan, AST_STATE_BUSY); } - ast_channel_unlock(chan); wait_for_hangup(chan, data); return -1; } @@ -10510,12 +10500,10 @@ static int pbx_builtin_congestion(struct ast_channel *chan, const char *data) ast_indicate(chan, AST_CONTROL_CONGESTION); /* Don't change state of an UP channel, just indicate congestion in audio */ - ast_channel_lock(chan); if (ast_channel_state(chan) != AST_STATE_UP) { ast_channel_hangupcause_set(chan, AST_CAUSE_CONGESTION); ast_setstate(chan, AST_STATE_BUSY); } - ast_channel_unlock(chan); wait_for_hangup(chan, data); return -1; } diff --git a/main/pickup.c b/main/pickup.c index a415f1672876dc941ff63ef85f317dcc57fc8cce..7ae6927faea359e453013687c817e894fe2e2599 100644 --- a/main/pickup.c +++ b/main/pickup.c @@ -354,17 +354,11 @@ int ast_do_pickup(struct ast_channel *chan, struct ast_channel *target) /* setting the HANGUPCAUSE so the ringing channel knows this call was not a missed call */ ast_channel_hangupcause_set(chan, AST_CAUSE_ANSWERED_ELSEWHERE); - ast_channel_lock(chan); - chan_snapshot = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); - if (!chan_snapshot) { + if (!(chan_snapshot = ast_channel_snapshot_create(chan))) { goto pickup_failed; } - ast_channel_lock(target); - target_snapshot = ast_channel_snapshot_create(target); - ast_channel_unlock(target); - if (!target_snapshot) { + if (!(target_snapshot = ast_channel_snapshot_create(target))) { goto pickup_failed; } diff --git a/main/stasis_bridges.c b/main/stasis_bridges.c index dd22710b1861b1854b184ce97b01f634e7273290..b92d048bc091a9ce516c2925aab7c52df834b94e 100644 --- a/main/stasis_bridges.c +++ b/main/stasis_bridges.c @@ -397,9 +397,7 @@ struct stasis_message *ast_bridge_blob_create( } if (chan) { - ast_channel_lock(chan); obj->channel = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); if (obj->channel == NULL) { return NULL; } @@ -581,9 +579,7 @@ static int bridge_channel_snapshot_pair_init(struct ast_bridge_channel_pair *pai } } - ast_channel_lock(pair->channel); snapshot_pair->channel_snapshot = ast_channel_snapshot_create(pair->channel); - ast_channel_unlock(pair->channel); if (!snapshot_pair->channel_snapshot) { return -1; } @@ -919,9 +915,7 @@ void ast_bridge_publish_attended_transfer_link(int is_external, enum ast_transfe transfer_msg->dest_type = AST_ATTENDED_TRANSFER_DEST_LINK; for (i = 0; i < 2; ++i) { - ast_channel_lock(locals[i]); transfer_msg->dest.links[i] = ast_channel_snapshot_create(locals[i]); - ast_channel_unlock(locals[i]); if (!transfer_msg->dest.links[i]) { return; } diff --git a/main/stasis_channels.c b/main/stasis_channels.c index 127106ad9d2e0b15c6d2d5d0f70bd8527fd5c195..38aac982e328d75a6fefd0127a7ba76583deb9c0 100644 --- a/main/stasis_channels.c +++ b/main/stasis_channels.c @@ -310,18 +310,14 @@ void ast_channel_publish_dial_forward(struct ast_channel *caller, struct ast_cha } if (caller) { - ast_channel_lock(caller); caller_snapshot = ast_channel_snapshot_create(caller); - ast_channel_unlock(caller); if (!caller_snapshot) { return; } ast_multi_channel_blob_add_channel(payload, "caller", caller_snapshot); } - ast_channel_lock(peer); peer_snapshot = ast_channel_snapshot_create(peer); - ast_channel_unlock(peer); if (!peer_snapshot) { return; } diff --git a/pbx/pbx_realtime.c b/pbx/pbx_realtime.c index 7624d597962b46cf6f5f37d81aea07c43a4e738a..f9f9cb2be88dbf81fdaa4aee60444cfce2f50a38 100644 --- a/pbx/pbx_realtime.c +++ b/pbx/pbx_realtime.c @@ -357,9 +357,7 @@ static int realtime_exec(struct ast_channel *chan, const char *context, const ch term_color(tmp1, app, COLOR_BRCYAN, 0, sizeof(tmp1)), term_color(tmp2, ast_channel_name(chan), COLOR_BRMAGENTA, 0, sizeof(tmp2)), term_color(tmp3, S_OR(appdata, ""), COLOR_BRMAGENTA, 0, sizeof(tmp3))); - ast_channel_lock(chan); snapshot = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); if (snapshot) { /* pbx_exec sets application name and data, but we don't want to log * every exec. Just update the snapshot here instead. diff --git a/res/parking/parking_bridge_features.c b/res/parking/parking_bridge_features.c index a939fdac70a767843fc9201eb4fddf25a75744bf..4f39e2e9411099d8662e4be796435e37902402aa 100644 --- a/res/parking/parking_bridge_features.c +++ b/res/parking/parking_bridge_features.c @@ -530,7 +530,6 @@ static int parking_duration_callback(struct ast_bridge_channel *bridge_channel, /* Set parking timeout channel variables */ snprintf(parking_space, sizeof(parking_space), "%d", user->parking_space); - ast_channel_lock(chan); ast_channel_stage_snapshot(chan); pbx_builtin_setvar_helper(chan, "PARKING_SPACE", parking_space); pbx_builtin_setvar_helper(chan, "PARKINGSLOT", parking_space); /* Deprecated version of PARKING_SPACE */ @@ -539,7 +538,6 @@ static int parking_duration_callback(struct ast_bridge_channel *bridge_channel, pbx_builtin_setvar_helper(chan, "PARKER_FLAT", dial_string_flat); parking_timeout_set_caller_features(chan, user->lot->cfg); ast_channel_stage_snapshot_done(chan); - ast_channel_unlock(chan); /* Dialplan generation for park-dial extensions */ diff --git a/res/parking/parking_manager.c b/res/parking/parking_manager.c index 507273aec2b49ac523b2256b0881ff4cac918d33..0c577018a0c2fc72db13f04d946126f215a70a53 100644 --- a/res/parking/parking_manager.c +++ b/res/parking/parking_manager.c @@ -155,9 +155,7 @@ static struct ast_parked_call_payload *parked_call_payload_from_failure(struct a RAII_VAR(struct ast_parked_call_payload *, payload, NULL, ao2_cleanup); RAII_VAR(struct ast_channel_snapshot *, parkee_snapshot, NULL, ao2_cleanup); - ast_channel_lock(chan); parkee_snapshot = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); if (!parkee_snapshot) { return NULL; } @@ -174,9 +172,7 @@ static struct ast_parked_call_payload *parked_call_payload_from_parked_user(stru struct timeval now = ast_tvnow(); const char *lot_name = pu->lot->name; - ast_channel_lock(pu->chan); parkee_snapshot = ast_channel_snapshot_create(pu->chan); - ast_channel_unlock(pu->chan); if (!parkee_snapshot) { return NULL; diff --git a/res/res_agi.c b/res/res_agi.c index 96d3906ac5523a2e10392839f990524fab9ab8bd..ed70356ddfe3b25e7ceb2f52270ed3ceb036d340 100644 --- a/res/res_agi.c +++ b/res/res_agi.c @@ -1481,11 +1481,9 @@ static enum agi_result launch_asyncagi(struct ast_channel *chan, int argc, char to execute based on the setup info */ ast_uri_encode(agi_buffer, ami_buffer, AMI_BUF_SIZE, ast_uri_http); startblob = ast_json_pack("{s: s}", "Env", ami_buffer); - ast_channel_lock(chan); ast_channel_publish_blob(chan, agi_async_start_type(), startblob); hungup = ast_check_hangup(chan); - ast_channel_unlock(chan); for (;;) { /* * Process as many commands as we can. Commands are added via @@ -1529,9 +1527,7 @@ static enum agi_result launch_asyncagi(struct ast_channel *chan, int argc, char if (execblob && !ast_strlen_zero(cmd->cmd_id)) { ast_json_object_set(execblob, "CommandId", ast_json_string_create(cmd->cmd_id)); } - ast_channel_lock(chan); ast_channel_publish_blob(chan, agi_async_exec_type(), execblob); - ast_channel_unlock(chan); free_agi_cmd(cmd); @@ -1591,9 +1587,7 @@ async_agi_done: ast_speech_destroy(async_agi.speech); } /* notify manager users this channel cannot be controlled anymore by Async AGI */ - ast_channel_lock(chan); ast_channel_publish_blob(chan, agi_async_end_type(), NULL); - ast_channel_unlock(chan); async_agi_abort: /* close the pipe */ @@ -2722,9 +2716,7 @@ static int handle_autohangup(struct ast_channel *chan, AGI *agi, int argc, const whentohangup.tv_sec = timeout; whentohangup.tv_usec = (timeout - whentohangup.tv_sec) * 1000000.0; } - ast_channel_lock(chan); ast_channel_setwhentohangup_tv(chan, whentohangup); - ast_channel_unlock(chan); ast_agi_send(agi->fd, chan, "200 result=0\n"); return RESULT_SUCCESS; } @@ -3665,9 +3657,7 @@ static void publish_async_exec_end(struct ast_channel *chan, int command_id, con "Command", command, "ResultCode", result_code, "Result", result); - ast_channel_lock(chan); ast_channel_publish_blob(chan, agi_exec_end_type(), blob); - ast_channel_unlock(chan); } static enum agi_result agi_handle_command(struct ast_channel *chan, AGI *agi, char *buf, int dead) @@ -3685,9 +3675,7 @@ static enum agi_result agi_handle_command(struct ast_channel *chan, AGI *agi, ch startblob = ast_json_pack("{s: i, s: s}", "CommandId", command_id, "Command", ami_cmd); - ast_channel_lock(chan); ast_channel_publish_blob(chan, agi_exec_start_type(), startblob); - ast_channel_unlock(chan); parse_args(buf, &argc, argv); c = find_command(argv, 0); diff --git a/res/res_pjsip_refer.c b/res/res_pjsip_refer.c index da48e523b96109956cdfbb1eb873faf4f2f6bcf9..91da22fde6f79b39f8faa6083299aeaa54b3b3f4 100644 --- a/res/res_pjsip_refer.c +++ b/res/res_pjsip_refer.c @@ -754,9 +754,7 @@ static int refer_incoming_invite_request(struct ast_sip_session *session, struct goto end; } - ast_channel_lock(session->channel); ast_setstate(session->channel, AST_STATE_RING); - ast_channel_unlock(session->channel); ast_raw_answer(session->channel); if (!invite.bridge) { diff --git a/res/res_stasis.c b/res/res_stasis.c index 5684d3dd8c230aa8fb262449e35774ca3dee397b..691462722e549eea34944b771ec83a2f41ce0000 100644 --- a/res/res_stasis.c +++ b/res/res_stasis.c @@ -637,9 +637,7 @@ static int send_start_msg(struct stasis_app *app, struct ast_channel *chan, ast_assert(chan != NULL); /* Set channel info */ - ast_channel_lock(chan); snapshot = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); if (!snapshot) { return -1; } @@ -683,9 +681,7 @@ static int send_end_msg(struct stasis_app *app, struct ast_channel *chan) ast_assert(chan != NULL); /* Set channel info */ - ast_channel_lock(chan); snapshot = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); if (snapshot == NULL) { return -1; } diff --git a/tests/test_cdr.c b/tests/test_cdr.c index efbda86c44634a8f2e3378808a2efed663d8d821..57d5b2e32dfb0a8cbd7dbc8dfdbf57ab73e53b4b 100644 --- a/tests/test_cdr.c +++ b/tests/test_cdr.c @@ -272,11 +272,9 @@ static void clear_mock_cdr_backend(void) if ((priority) > 0) { \ ast_channel_priority_set((channel), (priority)); \ } \ - ast_channel_lock((channel)); \ ast_channel_appl_set((channel), (application)); \ ast_channel_data_set((channel), (data)); \ ast_channel_publish_snapshot((channel)); \ - ast_channel_unlock((channel)); \ } while (0) /*! \brief Hang up a test channel safely */ @@ -632,11 +630,9 @@ AST_TEST_DEFINE(test_cdr_single_party) SWAP_CONFIG(config, debug_cdr_config); CREATE_ALICE_CHANNEL(chan, &caller, &expected); - ast_channel_lock(chan); EMULATE_APP_DATA(chan, 1, "Answer", ""); ast_setstate(chan, AST_STATE_UP); EMULATE_APP_DATA(chan, 2, "VoiceMailMain", "1"); - ast_channel_unlock(chan); HANGUP_CHANNEL(chan, AST_CAUSE_NORMAL); @@ -683,11 +679,9 @@ AST_TEST_DEFINE(test_cdr_single_bridge) SWAP_CONFIG(config, debug_cdr_config); CREATE_ALICE_CHANNEL(chan, &caller, &expected); - ast_channel_lock(chan); EMULATE_APP_DATA(chan, 1, "Answer", ""); ast_setstate(chan, AST_STATE_UP); EMULATE_APP_DATA(chan, 2, "Bridge", ""); - ast_channel_unlock(chan); bridge = ast_bridge_basic_new(); ast_test_validate(test, bridge != NULL); @@ -760,11 +754,9 @@ AST_TEST_DEFINE(test_cdr_single_bridge_continue) CREATE_ALICE_CHANNEL(chan, &caller, &expected_one); COPY_IDS(chan, &expected_two); - ast_channel_lock(chan); EMULATE_APP_DATA(chan, 1, "Answer", ""); ast_setstate(chan, AST_STATE_UP); EMULATE_APP_DATA(chan, 2, "Bridge", ""); - ast_channel_unlock(chan); bridge_one = ast_bridge_basic_new(); ast_test_validate(test, bridge_one != NULL); @@ -846,11 +838,9 @@ AST_TEST_DEFINE(test_cdr_single_twoparty_bridge_a) CREATE_BOB_CHANNEL(chan_bob, &caller_bob, &bob_expected); ast_copy_string(bob_expected.linkedid, ast_channel_linkedid(chan_alice), sizeof(bob_expected.linkedid)); - ast_channel_lock(chan_alice); EMULATE_APP_DATA(chan_alice, 1, "Answer", ""); ast_setstate(chan_alice, AST_STATE_UP); EMULATE_APP_DATA(chan_alice, 2, "Bridge", ""); - ast_channel_unlock(chan_alice); bridge = ast_bridge_basic_new(); ast_test_validate(test, bridge != NULL); @@ -858,11 +848,9 @@ AST_TEST_DEFINE(test_cdr_single_twoparty_bridge_a) ast_test_validate(test, !ast_bridge_impart(bridge, chan_alice, NULL, NULL, AST_BRIDGE_IMPART_CHAN_DEPARTABLE)); while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); - ast_channel_lock(chan_bob); EMULATE_APP_DATA(chan_bob, 1, "Answer", ""); ast_setstate(chan_bob, AST_STATE_UP); EMULATE_APP_DATA(chan_bob, 2, "Bridge", ""); - ast_channel_unlock(chan_bob); ast_test_validate(test, !ast_bridge_impart(bridge, chan_bob, NULL, NULL, AST_BRIDGE_IMPART_CHAN_DEPARTABLE)); while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); @@ -938,20 +926,16 @@ AST_TEST_DEFINE(test_cdr_single_twoparty_bridge_b) CREATE_BOB_CHANNEL(chan_bob, &caller_bob, &bob_expected); ast_copy_string(bob_expected.linkedid, ast_channel_linkedid(chan_alice), sizeof(bob_expected.linkedid)); - ast_channel_unlock(chan_alice); EMULATE_APP_DATA(chan_alice, 1, "Answer", ""); ast_setstate(chan_alice, AST_STATE_UP); EMULATE_APP_DATA(chan_alice, 2, "Bridge", ""); - ast_channel_unlock(chan_alice); bridge = ast_bridge_basic_new(); ast_test_validate(test, bridge != NULL); - ast_channel_lock(chan_bob); EMULATE_APP_DATA(chan_bob, 1, "Answer", ""); ast_setstate(chan_bob, AST_STATE_UP); EMULATE_APP_DATA(chan_bob, 2, "Bridge", ""); - ast_channel_unlock(chan_bob); while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); ast_test_validate(test, !ast_bridge_impart(bridge, chan_bob, NULL, NULL, AST_BRIDGE_IMPART_CHAN_DEPARTABLE)); @@ -1065,11 +1049,9 @@ AST_TEST_DEFINE(test_cdr_single_multiparty_bridge) CREATE_CHARLIE_CHANNEL(chan_charlie, &caller_charlie, &charlie_expected); ast_copy_string(charlie_expected.linkedid, ast_channel_linkedid(chan_alice), sizeof(charlie_expected.linkedid)); - ast_channel_lock(chan_alice); EMULATE_APP_DATA(chan_alice, 1, "Answer", ""); ast_setstate(chan_alice, AST_STATE_UP); EMULATE_APP_DATA(chan_alice, 2, "Bridge", ""); - ast_channel_unlock(chan_alice); bridge = ast_bridge_basic_new(); ast_test_validate(test, bridge != NULL); @@ -1077,22 +1059,18 @@ AST_TEST_DEFINE(test_cdr_single_multiparty_bridge) ast_test_validate(test, !ast_bridge_impart(bridge, chan_alice, NULL, NULL, AST_BRIDGE_IMPART_CHAN_DEPARTABLE)); - ast_channel_lock(chan_bob); EMULATE_APP_DATA(chan_bob, 1, "Answer", ""); ast_setstate(chan_bob, AST_STATE_UP); EMULATE_APP_DATA(chan_bob, 2, "Bridge", ""); - ast_channel_unlock(chan_bob); while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); ast_test_validate(test, !ast_bridge_impart(bridge, chan_bob, NULL, NULL, AST_BRIDGE_IMPART_CHAN_DEPARTABLE)); while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); - ast_channel_lock(chan_charlie); EMULATE_APP_DATA(chan_charlie, 1, "Answer", ""); ast_setstate(chan_charlie, AST_STATE_UP); EMULATE_APP_DATA(chan_charlie, 2, "Bridge", ""); - ast_channel_unlock(chan_charlie); ast_test_validate(test, !ast_bridge_impart(bridge, chan_charlie, NULL, NULL, AST_BRIDGE_IMPART_CHAN_DEPARTABLE)); while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); @@ -2022,15 +2000,10 @@ AST_TEST_DEFINE(test_cdr_park) CREATE_ALICE_CHANNEL(chan_alice, &alice_caller, &alice_expected); CREATE_BOB_CHANNEL(chan_bob, &bob_caller, &bob_expected); - ast_channel_lock(chan_alice); EMULATE_APP_DATA(chan_alice, 1, "Park", "700"); ast_setstate(chan_alice, AST_STATE_UP); - ast_channel_unlock(chan_alice); - - ast_channel_lock(chan_bob); EMULATE_APP_DATA(chan_bob, 1, "Park", "701"); ast_setstate(chan_bob, AST_STATE_UP); - ast_channel_unlock(chan_bob); bridge = ast_bridge_base_new(AST_BRIDGE_CAPABILITY_HOLDING, AST_BRIDGE_FLAG_MERGE_INHIBIT_TO | AST_BRIDGE_FLAG_MERGE_INHIBIT_FROM @@ -2135,7 +2108,6 @@ AST_TEST_DEFINE(test_cdr_fields) ast_copy_string(fork_expected_two.linkedid, ast_channel_linkedid(chan), sizeof(fork_expected_two.linkedid)); /* Channel enters Wait app */ - ast_channel_lock(chan); ast_channel_appl_set(chan, "Wait"); ast_channel_data_set(chan, "10"); ast_channel_priority_set(chan, 1); @@ -2144,7 +2116,6 @@ AST_TEST_DEFINE(test_cdr_fields) /* Set properties on the channel that propagate to the CDR */ ast_channel_amaflags_set(chan, AST_AMA_OMIT); ast_channel_accountcode_set(chan, "XXX"); - ast_channel_unlock(chan); /* Wait one second so we get a duration. */ while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); @@ -2237,7 +2208,6 @@ AST_TEST_DEFINE(test_cdr_fields) ast_test_validate(test, ast_cdr_fork(ast_channel_name(chan), &fork_options) == 0); /* Channel enters Answer app */ - ast_channel_lock(chan); ast_channel_appl_set(chan, "Answer"); ast_channel_data_set(chan, ""); ast_channel_priority_set(chan, 1); @@ -2246,7 +2216,6 @@ AST_TEST_DEFINE(test_cdr_fields) /* Set properties on the last record */ ast_channel_accountcode_set(chan, "ZZZ"); - ast_channel_unlock(chan); ast_cdr_setuserfield(ast_channel_name(chan), "schmackity"); ast_test_validate(test, ast_cdr_setvar(ast_channel_name(chan), "test_variable", "record_2") == 0); @@ -2416,9 +2385,7 @@ AST_TEST_DEFINE(test_cdr_fork_cdr) ast_test_validate(test, ast_cdr_fork(ast_channel_name(chan), &fork_options) == 0); /* Test keep variables; setting a new answer time */ - ast_channel_lock(chan); ast_setstate(chan, AST_STATE_UP); - ast_channel_unlock(chan); while ((nanosleep(&to_sleep, &to_sleep) == -1) && (errno == EINTR)); ast_test_validate(test, ast_cdr_setvar(ast_channel_name(chan), "test_variable", "record_2") == 0); ast_test_validate(test, ast_cdr_getvar(ast_channel_name(chan), "test_variable", varbuffer, sizeof(varbuffer)) == 0); diff --git a/tests/test_cel.c b/tests/test_cel.c index a90dfbf3e36566ba70d02029454a4fee6fe19e48..0aa8b601c920977413980e35972e60cb9c06f5c4 100644 --- a/tests/test_cel.c +++ b/tests/test_cel.c @@ -1551,14 +1551,10 @@ AST_TEST_DEFINE(test_cel_local_optimize) CREATE_ALICE_CHANNEL(chan_alice, &alice_caller); CREATE_BOB_CHANNEL(chan_bob, &bob_caller); - ast_channel_lock(chan_alice); alice_snapshot = ast_channel_snapshot_create(chan_alice); - ast_channel_unlock(chan_alice); ast_test_validate(test, alice_snapshot != NULL); - ast_channel_lock(chan_bob); bob_snapshot = ast_channel_snapshot_create(chan_bob); - ast_channel_unlock(chan_bob); ast_test_validate(test, bob_snapshot != NULL); ast_multi_channel_blob_add_channel(mc_blob, "1", alice_snapshot); @@ -1679,9 +1675,7 @@ static int append_expected_event( const char *peer) { RAII_VAR(struct ast_channel_snapshot *, snapshot, NULL, ao2_cleanup); - ast_channel_lock(chan); snapshot = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); if (!snapshot) { return -1; } diff --git a/tests/test_stasis_channels.c b/tests/test_stasis_channels.c index b7c9fe2c59744cb536b0b521925796016782ed6b..45f1e2ba3584efba9f799c2876dc19915607fb29 100644 --- a/tests/test_stasis_channels.c +++ b/tests/test_stasis_channels.c @@ -77,12 +77,10 @@ AST_TEST_DEFINE(channel_blob_create) "foo", "bar"); /* Off nominal creation */ - ast_channel_lock(chan); ast_test_validate(test, NULL == ast_channel_blob_create(chan, NULL, json)); /* Test for single channel */ msg = ast_channel_blob_create(chan, type, json); - ast_channel_unlock(chan); ast_test_validate(test, NULL != msg); blob = stasis_message_data(msg); ast_test_validate(test, NULL != blob); @@ -131,9 +129,7 @@ AST_TEST_DEFINE(null_blob) "foo", "bar"); /* Test for single channel */ - ast_channel_lock(chan); msg = ast_channel_blob_create(chan, type, NULL); - ast_channel_unlock(chan); ast_test_validate(test, NULL != msg); blob = stasis_message_data(msg); ast_test_validate(test, NULL != blob); @@ -200,15 +196,9 @@ AST_TEST_DEFINE(multi_channel_blob_snapshots) chan_charlie = ast_channel_alloc(0, AST_STATE_DOWN, "300", "Bob", "300", "300", "default", NULL, 0, "TEST/Charlie"); blob = ast_multi_channel_blob_create(json); - ast_channel_lock(chan_alice); ast_multi_channel_blob_add_channel(blob, "Caller", ast_channel_snapshot_create(chan_alice)); - ast_channel_unlock(chan_alice); - ast_channel_lock(chan_bob); ast_multi_channel_blob_add_channel(blob, "Peer", ast_channel_snapshot_create(chan_bob)); - ast_channel_unlock(chan_bob); - ast_channel_lock(chan_charlie); ast_multi_channel_blob_add_channel(blob, "Peer", ast_channel_snapshot_create(chan_charlie)); - ast_channel_unlock(chan_charlie); /* Test for unknown role */ ast_test_validate(test, NULL == ast_multi_channel_blob_get_channel(blob, "Foobar")); @@ -262,9 +252,7 @@ AST_TEST_DEFINE(channel_snapshot_json) chan = ast_channel_alloc(0, AST_STATE_DOWN, "cid_num", "cid_name", "acctcode", "exten", "context", NULL, 0, "TEST/name"); ast_test_validate(test, NULL != chan); - ast_channel_lock(chan); snapshot = ast_channel_snapshot_create(chan); - ast_channel_unlock(chan); ast_test_validate(test, NULL != snapshot); actual = ast_channel_snapshot_to_json(snapshot, NULL);