mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-31 02:37:10 +00:00 
			
		
		
		
	Merged revisions 250480 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r250480 | jpeeler | 2010-03-03 13:04:11 -0600 (Wed, 03 Mar 2010) | 15 lines Make sure to clear red alarm after polarity reversal. From the issue: The automatic overnight line tests (or manual ones) used on UK (BT) lines causes a red alarm on a dahdi / TDM400P connected channel. This is because the line uses voltage tests (battery loss) and polarity reversal. The polarity reversal causes chan_dahdi to initiate v23 CallerID processing but during this the event DAHDI_EVENT_NOALARM is ignored so that the alarm is never cleared. (closes issue #14163) Reported by: jedi98 Patches: chan_dahdi-1.4-inalarm.diff uploaded by jedi98 (license 653) Tested by: mattbrown, Chainsaw, mikeeccleston ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@250481 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -2161,6 +2161,9 @@ static void *__analog_ss_thread(void *data) | ||||
| 						} | ||||
|  | ||||
| 						if (res == 1) { | ||||
| 							if (ev == ANALOG_EVENT_NOALARM) { | ||||
| 								p->inalarm = 0; | ||||
| 							} | ||||
| 							if (p->cid_signalling == CID_SIG_V23_JP) { | ||||
| 								if (ev == ANALOG_EVENT_RINGBEGIN) { | ||||
| 									analog_off_hook(p); | ||||
| @@ -2249,7 +2252,9 @@ static void *__analog_ss_thread(void *data) | ||||
| 					} | ||||
|  | ||||
| 					if (res == 1 || res == 2) { | ||||
| 						if (ev == ANALOG_EVENT_POLARITY && p->hanguponpolarityswitch && p->polarity == POLARITY_REV) { | ||||
| 						if (ev == ANALOG_EVENT_NOALARM) { | ||||
| 							p->inalarm = 0; | ||||
| 						} else if (ev == ANALOG_EVENT_POLARITY && p->hanguponpolarityswitch && p->polarity == POLARITY_REV) { | ||||
| 							ast_debug(1, "Hanging up due to polarity reversal on channel %d while detecting callerid\n", p->channel); | ||||
| 							p->polarity = POLARITY_IDLE; | ||||
| 							ast_hangup(chan); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user