| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Chan_Misdn -- Channel Driver for Asterisk | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Interface to mISDN | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 2004, Christian Richter | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Christian Richter <crich@beronet.com> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software, distributed under the terms of | 
					
						
							|  |  |  |  * the GNU General Public License | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-15 17:29:08 +00:00
										 |  |  | /*! \file 
 | 
					
						
							|  |  |  |  * \brief Interface to mISDN - message parser | 
					
						
							| 
									
										
										
										
											2007-12-11 22:20:22 +00:00
										 |  |  |  * \author Christian Richter <crich@beronet.com> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | #include "isdn_lib_intern.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | #include "isdn_lib.h"
 | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | #include "ie.c"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void set_channel(struct misdn_bchannel *bc, int channel) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	cb_log(3,bc->port,"set_channel: bc->channel:%d channel:%d\n", bc->channel, channel); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (channel==0xff) { | 
					
						
							|  |  |  | 		/* any channel */ | 
					
						
							|  |  |  | 		channel=-1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/*  ALERT: is that everytime true ?  */ | 
					
						
							|  |  |  | 	if (channel > 0 && bc->nt ) { | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (bc->channel && ( bc->channel != 0xff) ) { | 
					
						
							|  |  |  | 			cb_log(0,bc->port,"We already have a channel (%d)\n", bc->channel); | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			bc->channel = channel; | 
					
						
							| 
									
										
										
										
											2006-05-24 23:21:03 +00:00
										 |  |  | 			cb_event(EVENT_NEW_CHANNEL,bc,NULL); | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-05-24 23:21:03 +00:00
										 |  |  | 	if (channel > 0 && !bc->nt ) { | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 		bc->channel = channel; | 
					
						
							| 
									
										
										
										
											2006-05-24 23:21:03 +00:00
										 |  |  | 		cb_event(EVENT_NEW_CHANNEL,bc,NULL); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_proceeding (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	CALL_PROCEEDING_t *proceeding=(CALL_PROCEEDING_t*)((unsigned long)msg->data+ HEADER_LEN); | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 	//struct misdn_stack *stack=get_stack_by_bc(bc);
 | 
					
						
							| 
									
										
										
										
											2005-11-01 22:04:14 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		int  exclusive, channel; | 
					
						
							|  |  |  | 		dec_ie_channel_id(proceeding->CHANNEL_ID, (Q931_info_t *)proceeding, &exclusive, &channel, nt,bc); | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 		set_channel(bc,channel); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	dec_ie_progress(proceeding->PROGRESS, (Q931_info_t *)proceeding, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing PROCEEDING Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_proceeding (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt) | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	CALL_PROCEEDING_t *proceeding; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_PROCEEDING | REQUEST, MT_CALL_PROCEEDING,  bc?bc->l3_id:-1, sizeof(CALL_PROCEEDING_t) ,nt);  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	proceeding=(CALL_PROCEEDING_t*)((msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	enc_ie_channel_id(&proceeding->CHANNEL_ID, msg, 1,bc->channel, nt,bc); | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	if (nt)  | 
					
						
							|  |  |  | 		enc_ie_progress(&proceeding->PROGRESS, msg, 0, nt?1:5, 8, nt,bc); | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building PROCEEDING Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_alerting (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;  | 
					
						
							|  |  |  | 	ALERTING_t *alerting=(ALERTING_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 	//Q931_info_t *qi=(Q931_info_t*)(msg->data+HEADER_LEN);
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	dec_ie_progress(alerting->PROGRESS, (Q931_info_t *)alerting, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing ALERTING Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_alerting (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	ALERTING_t *alerting; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_ALERTING | REQUEST, MT_ALERTING,  bc?bc->l3_id:-1, sizeof(ALERTING_t) ,nt);  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	alerting=(ALERTING_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	enc_ie_channel_id(&alerting->CHANNEL_ID, msg, 1,bc->channel, nt,bc); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (nt)  | 
					
						
							|  |  |  | 		enc_ie_progress(&alerting->PROGRESS, msg, 0, nt?1:5, 8, nt,bc); | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building ALERTING Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_progress (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	PROGRESS_t *progress=(PROGRESS_t*)((unsigned long)(msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 	//Q931_info_t *qi=(Q931_info_t*)(msg->data+HEADER_LEN);  
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	dec_ie_progress(progress->PROGRESS, (Q931_info_t *)progress, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing PROGRESS Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_progress (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	PROGRESS_t *progress; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_PROGRESS | REQUEST, MT_PROGRESS,  bc?bc->l3_id:-1, sizeof(PROGRESS_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	progress=(PROGRESS_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building PROGRESS Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_setup (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | {  | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	SETUP_t *setup= (SETUP_t*)((unsigned long)msg->data+HEADER_LEN); | 
					
						
							|  |  |  | 	Q931_info_t *qi=(Q931_info_t*)((unsigned long)msg->data+HEADER_LEN); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing SETUP Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int type,plan,present, screen; | 
					
						
							|  |  |  | 		char id[32]; | 
					
						
							| 
									
										
										
										
											2006-08-09 09:24:21 +00:00
										 |  |  | 		dec_ie_calling_pn(setup->CALLING_PN, qi, &type, &plan, &present, &screen, id, sizeof(id)-1, nt,bc); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		bc->onumplan=type;  | 
					
						
							|  |  |  | 		strcpy(bc->oad, id); | 
					
						
							|  |  |  | 		switch (present) { | 
					
						
							|  |  |  | 		case 0: | 
					
						
							|  |  |  | 			bc->pres=0; /* screened */ | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case 1: | 
					
						
							|  |  |  | 			bc->pres=1; /* not screened */ | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			bc->pres=0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		switch (screen) { | 
					
						
							|  |  |  | 		case 0: | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			; | 
					
						
							|  |  |  | 		}  | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int  type, plan; | 
					
						
							|  |  |  | 		char number[32];  | 
					
						
							| 
									
										
										
										
											2006-08-09 09:24:21 +00:00
										 |  |  | 		dec_ie_called_pn(setup->CALLED_PN, (Q931_info_t *)setup, &type, &plan, number, sizeof(number)-1, nt,bc); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		strcpy(bc->dad, number); | 
					
						
							|  |  |  | 		bc->dnumplan=type;  | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		char keypad[32]; | 
					
						
							| 
									
										
										
										
											2006-08-09 09:24:21 +00:00
										 |  |  | 		dec_ie_keypad(setup->KEYPAD, (Q931_info_t *)setup, keypad, sizeof(keypad)-1, nt,bc); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		strcpy(bc->keypad, keypad); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-06-01 12:51:41 +00:00
										 |  |  | 		dec_ie_complete(setup->COMPLETE, (Q931_info_t *)setup, &bc->sending_complete, nt,bc); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int  type, plan, present, screen, reason; | 
					
						
							|  |  |  | 		char id[32];  | 
					
						
							| 
									
										
										
										
											2006-08-09 09:24:21 +00:00
										 |  |  | 		dec_ie_redir_nr(setup->REDIR_NR, (Q931_info_t *)setup, &type, &plan, &present, &screen, &reason, id, sizeof(id)-1, nt,bc); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |      | 
					
						
							|  |  |  | 		strcpy(bc->rad, id); | 
					
						
							|  |  |  | 		bc->rnumplan=type;  | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int  coding, capability, mode, rate, multi, user, async, urate, stopbits, dbits, parity; | 
					
						
							|  |  |  | 		dec_ie_bearer(setup->BEARER, (Q931_info_t *)setup, &coding, &capability, &mode, &rate, &multi, &user, &async, &urate, &stopbits, &dbits, &parity, nt,bc); | 
					
						
							|  |  |  | 		switch (capability) { | 
					
						
							|  |  |  | 		case -1: bc->capability=INFO_CAPABILITY_DIGITAL_UNRESTRICTED;  | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case 0: bc->capability=INFO_CAPABILITY_SPEECH; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2006-06-01 12:51:41 +00:00
										 |  |  | 		case 18: bc->capability=INFO_CAPABILITY_VIDEO; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		case 8: bc->capability=INFO_CAPABILITY_DIGITAL_UNRESTRICTED; | 
					
						
							|  |  |  | 			bc->user1 = user; | 
					
						
							|  |  |  | 			bc->urate = urate; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			bc->rate = rate; | 
					
						
							|  |  |  | 			bc->mode = mode; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case 9: bc->capability=INFO_CAPABILITY_DIGITAL_RESTRICTED; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		switch(user) { | 
					
						
							|  |  |  | 		case 2: | 
					
						
							|  |  |  | 			bc->law=INFO_CODEC_ULAW; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case 3: | 
					
						
							|  |  |  | 			bc->law=INFO_CODEC_ALAW; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			bc->law=INFO_CODEC_ALAW; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		bc->capability=capability;  | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int  exclusive, channel; | 
					
						
							|  |  |  | 		dec_ie_channel_id(setup->CHANNEL_ID, (Q931_info_t *)setup, &exclusive, &channel, nt,bc); | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		set_channel(bc,channel); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												Merged revisions 58825-58826 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r58825 | crichter | 2007-03-12 13:43:24 +0100 (Mo, 12 Mär 2007) | 1 line
added UU transceiving and corect handling for rdnis
................
r58826 | crichter | 2007-03-12 14:08:06 +0100 (Mo, 12 Mär 2007) | 21 lines
Merged revisions 57034,57523,57753,58558 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r57034 | crichter | 2007-02-28 17:09:27 +0100 (Mi, 28 Feb 2007) | 1 line
fixed bugs.digium.com bugs: #9157 and bugs.beronet.com bugs: #302, #303, #304
........
r57523 | crichter | 2007-03-02 19:32:51 +0100 (Fr, 02 Mar 2007) | 1 line
fixed typo
........
r57753 | crichter | 2007-03-04 11:39:50 +0100 (So, 04 Mar 2007) | 1 line
fixed another place where the out_cause was hardcoded to 16
........
r58558 | crichter | 2007-03-09 15:43:58 +0100 (Fr, 09 Mar 2007) | 1 line
we can free channel 31 as well, since we can occupy it
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@64951 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-05-18 09:31:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int  protocol ; | 
					
						
							|  |  |  | 		dec_ie_useruser(setup->USER_USER, (Q931_info_t *)setup, &protocol, bc->uu, &bc->uulen, nt,bc); | 
					
						
							|  |  |  | 		if (bc->uulen) cb_log(1,bc->port,"USERUESRINFO:%s\n",bc->uu); | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		cb_log(1,bc->port,"NO USERUESRINFO\n"); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	dec_ie_progress(setup->PROGRESS, (Q931_info_t *)setup, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ANY_CHANNEL 0xff /* IE attribut for 'any channel' */
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_setup (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	SETUP_t *setup; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_SETUP | REQUEST, MT_SETUP,  bc?bc->l3_id:-1, sizeof(SETUP_t) ,nt);  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	setup=(SETUP_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	if (bc->channel == 0 || bc->channel == ANY_CHANNEL || bc->channel==-1) | 
					
						
							|  |  |  | 		enc_ie_channel_id(&setup->CHANNEL_ID, msg, 0, bc->channel, nt,bc); | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 	else  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		enc_ie_channel_id(&setup->CHANNEL_ID, msg, 1, bc->channel, nt,bc); | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2005-11-15 20:20:45 +00:00
										 |  |  | 		int type=bc->onumplan,plan=1,present=bc->pres,screen=bc->screen; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		enc_ie_calling_pn(&setup->CALLING_PN, msg, type, plan, present, | 
					
						
							|  |  |  | 				  screen, bc->oad, nt, bc); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (bc->dad[0]) | 
					
						
							|  |  |  | 			enc_ie_called_pn(&setup->CALLED_PN, msg, bc->dnumplan, 1, bc->dad, nt,bc); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2006-02-24 17:38:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (bc->rad[0]) | 
					
						
							|  |  |  | 			enc_ie_redir_nr(&setup->REDIR_NR, msg, 1, 1,  bc->pres, bc->screen, 0, bc->rad, nt,bc); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62912 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r62912 | crichter | 2007-05-03 16:36:32 +0200 (Do, 03 Mai 2007) | 17 lines
Merged revisions 61357,61770,62885 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r61357 | crichter | 2007-04-11 14:05:57 +0200 (Mi, 11 Apr 2007) | 1 line
some fixes for PMP Hold/Retrieve, it should work now, when briding=no
........
r61770 | crichter | 2007-04-24 15:50:05 +0200 (Di, 24 Apr 2007) | 1 line
added lock for sending messages to avoid double sending. shuffled some empty_chans after the cb_event calls, this avoids that a release_complete from a quite different call releases a fresh created setup by accident.
........
r62885 | crichter | 2007-05-03 15:59:00 +0200 (Do, 03 Mai 2007) | 1 line
fixed the problem that misdn_write did not return -1 when called with 0 samples in a frame this resultet in a deadlock in some circumstances, when the call ended because of a busy extension.  added encoding of keypad.
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@64955 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-05-18 09:50:33 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		if (bc->keypad[0]) | 
					
						
							| 
									
										
											  
											
												Merged revisions 63534 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r63534 | crichter | 2007-05-09 15:17:10 +0200 (Mi, 09 Mai 2007) | 17 lines
Merged revisions 62945,63402,63519 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r62945 | crichter | 2007-05-03 17:39:21 +0200 (Do, 03 Mai 2007) | 1 line
when we're in state WAITING4DIGS, we use the asterisk tone-generator which prods us, so we can't just return -1 in misdn_write in this case. Added a MISDN_KEYPAD channel variable, and fixed the sending of keypad. this enables us to modify the call forward parameters in the switch.
........
r63402 | crichter | 2007-05-08 17:07:37 +0200 (Di, 08 Mai 2007) | 1 line
added application misdn_check_l2l1 which tries to pull up the L1/L2 on all ports that have the layers down in a group. It waits then for a timeout. This helps for scenarios where multiple PMP BRIs are grouped together, or where a provider has a faulty PTP Implementation, that looses the L2 after a while.
........
r63519 | crichter | 2007-05-09 13:26:16 +0200 (Mi, 09 Mai 2007) | 1 line
release_chan frees ch, so we should never touch ch after release_chan, this may cause segfaults.
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@64957 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-05-18 10:00:21 +00:00
										 |  |  | 			enc_ie_keypad(&setup->KEYPAD, msg, bc->keypad, nt,bc); | 
					
						
							| 
									
										
											  
											
												Merged revisions 62912 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r62912 | crichter | 2007-05-03 16:36:32 +0200 (Do, 03 Mai 2007) | 17 lines
Merged revisions 61357,61770,62885 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r61357 | crichter | 2007-04-11 14:05:57 +0200 (Mi, 11 Apr 2007) | 1 line
some fixes for PMP Hold/Retrieve, it should work now, when briding=no
........
r61770 | crichter | 2007-04-24 15:50:05 +0200 (Di, 24 Apr 2007) | 1 line
added lock for sending messages to avoid double sending. shuffled some empty_chans after the cb_event calls, this avoids that a release_complete from a quite different call releases a fresh created setup by accident.
........
r62885 | crichter | 2007-05-03 15:59:00 +0200 (Do, 03 Mai 2007) | 1 line
fixed the problem that misdn_write did not return -1 when called with 0 samples in a frame this resultet in a deadlock in some circumstances, when the call ended because of a busy extension.  added encoding of keypad.
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@64955 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-05-18 09:50:33 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2006-02-24 17:38:43 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |    | 
					
						
							|  |  |  | 	if (*bc->display) { | 
					
						
							|  |  |  | 		enc_ie_display(&setup->DISPLAY, msg, bc->display, nt,bc); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int coding=0, capability, mode=0 /*  2 for packet ! */ | 
					
						
							|  |  |  | 			,user, rate=0x10; | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		switch (bc->law) { | 
					
						
							|  |  |  | 		case INFO_CODEC_ULAW: user=2; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case INFO_CODEC_ALAW: user=3; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			user=3; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		switch (bc->capability) { | 
					
						
							|  |  |  | 		case INFO_CAPABILITY_SPEECH: capability = 0; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case INFO_CAPABILITY_DIGITAL_UNRESTRICTED: capability = 8; | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 			user=-1; | 
					
						
							| 
									
										
										
										
											2006-02-22 21:59:46 +00:00
										 |  |  | 			mode=bc->mode; | 
					
						
							|  |  |  | 			rate=bc->rate; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case INFO_CAPABILITY_DIGITAL_RESTRICTED: capability = 9; | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 			user=-1; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			capability=bc->capability;  | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |      | 
					
						
							|  |  |  | 		enc_ie_bearer(&setup->BEARER, msg, coding, capability, mode, rate, -1, user, nt,bc); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												Merged revisions 49313 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r49313 | crichter | 2007-01-03 10:06:50 +0100 (Mi, 03 Jan 2007) | 41 lines
Merged revisions 48319,48321,48467,48552,48576,49135,49303 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r48319 | crichter | 2006-12-06 15:35:25 +0100 (Mi, 06 Dez 2006) | 1 line
changed a few debugs to higher debug levels
........
r48321 | crichter | 2006-12-06 16:48:45 +0100 (Mi, 06 Dez 2006) | 1 line
added the export and import of the MISDN_ADDRESS_COMPLETE Variable to inidcate wether the extension is already completely dialed or if there might come additional digits by information elements. also added some docs for that.
........
r48467 | crichter | 2006-12-14 14:03:49 +0100 (Do, 14 Dez 2006) | 1 line
removed FIXUP state. added check for channel allocation conflict when we create a setup while the other site creates a setup on the same channel, besides the check we resolve this conflict.
........
r48552 | crichter | 2006-12-18 11:19:39 +0100 (Mo, 18 Dez 2006) | 1 line
when our PTP Partner sends us a SETUP with a preselected channel we just accept it, even when we're NT. added some checks for segfaults.
........
r48576 | crichter | 2006-12-19 14:08:51 +0100 (Di, 19 Dez 2006) | 1 line
when we reject a channel, because it's in use already, we shouldn't process the setup anymore. made the channel allocation a bit easier and more understandable, removed a few unused lines
........
r49135 | crichter | 2007-01-02 11:07:22 +0100 (Di, 02 Jan 2007) | 1 line
added check for channel ranges in the set/empty channel functions. set pmp_l1_check default to no. added misdn restart pid cli command. added cleaning of channel when we send a RELEASE_COMPLETE. 
........
r49303 | crichter | 2007-01-03 09:24:00 +0100 (Mi, 03 Jan 2007) | 9 lines
* Added check for bridging in misdn_call to avoid setting echocancellation
  when 2 mISDN channels are involved and when bridging is set. That lead
  to a kernel panic before under different situations, because we switched 
  about 2 times between hardware bridging and echocancelation
* readded MISDN_URATE variable which got lost before, this should make app_v110
  work again
* fixed typo
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@49321 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-01-03 11:15:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (bc->sending_complete) { | 
					
						
							| 
									
										
										
										
											2007-05-18 12:43:59 +00:00
										 |  |  | 		enc_ie_complete(&setup->COMPLETE,msg, bc->sending_complete, nt, bc); | 
					
						
							| 
									
										
											  
											
												Merged revisions 49313 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r49313 | crichter | 2007-01-03 10:06:50 +0100 (Mi, 03 Jan 2007) | 41 lines
Merged revisions 48319,48321,48467,48552,48576,49135,49303 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r48319 | crichter | 2006-12-06 15:35:25 +0100 (Mi, 06 Dez 2006) | 1 line
changed a few debugs to higher debug levels
........
r48321 | crichter | 2006-12-06 16:48:45 +0100 (Mi, 06 Dez 2006) | 1 line
added the export and import of the MISDN_ADDRESS_COMPLETE Variable to inidcate wether the extension is already completely dialed or if there might come additional digits by information elements. also added some docs for that.
........
r48467 | crichter | 2006-12-14 14:03:49 +0100 (Do, 14 Dez 2006) | 1 line
removed FIXUP state. added check for channel allocation conflict when we create a setup while the other site creates a setup on the same channel, besides the check we resolve this conflict.
........
r48552 | crichter | 2006-12-18 11:19:39 +0100 (Mo, 18 Dez 2006) | 1 line
when our PTP Partner sends us a SETUP with a preselected channel we just accept it, even when we're NT. added some checks for segfaults.
........
r48576 | crichter | 2006-12-19 14:08:51 +0100 (Di, 19 Dez 2006) | 1 line
when we reject a channel, because it's in use already, we shouldn't process the setup anymore. made the channel allocation a bit easier and more understandable, removed a few unused lines
........
r49135 | crichter | 2007-01-02 11:07:22 +0100 (Di, 02 Jan 2007) | 1 line
added check for channel ranges in the set/empty channel functions. set pmp_l1_check default to no. added misdn restart pid cli command. added cleaning of channel when we send a RELEASE_COMPLETE. 
........
r49303 | crichter | 2007-01-03 09:24:00 +0100 (Mi, 03 Jan 2007) | 9 lines
* Added check for bridging in misdn_call to avoid setting echocancellation
  when 2 mISDN channels are involved and when bridging is set. That lead
  to a kernel panic before under different situations, because we switched 
  about 2 times between hardware bridging and echocancelation
* readded MISDN_URATE variable which got lost before, this should make app_v110
  work again
* fixed typo
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@49321 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-01-03 11:15:02 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2007-05-18 12:43:59 +00:00
										 |  |  | 	if (bc->uulen) { | 
					
						
							| 
									
										
											  
											
												Merged revisions 58825-58826 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r58825 | crichter | 2007-03-12 13:43:24 +0100 (Mo, 12 Mär 2007) | 1 line
added UU transceiving and corect handling for rdnis
................
r58826 | crichter | 2007-03-12 14:08:06 +0100 (Mo, 12 Mär 2007) | 21 lines
Merged revisions 57034,57523,57753,58558 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r57034 | crichter | 2007-02-28 17:09:27 +0100 (Mi, 28 Feb 2007) | 1 line
fixed bugs.digium.com bugs: #9157 and bugs.beronet.com bugs: #302, #303, #304
........
r57523 | crichter | 2007-03-02 19:32:51 +0100 (Fr, 02 Mar 2007) | 1 line
fixed typo
........
r57753 | crichter | 2007-03-04 11:39:50 +0100 (So, 04 Mar 2007) | 1 line
fixed another place where the out_cause was hardcoded to 16
........
r58558 | crichter | 2007-03-09 15:43:58 +0100 (Fr, 09 Mar 2007) | 1 line
we can free channel 31 as well, since we can occupy it
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@64951 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-05-18 09:31:27 +00:00
										 |  |  | 		int  protocol=4; | 
					
						
							|  |  |  | 		enc_ie_useruser(&setup->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc); | 
					
						
							| 
									
										
										
										
											2007-05-18 12:43:59 +00:00
										 |  |  | 		cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu); | 
					
						
							| 
									
										
											  
											
												Merged revisions 58825-58826 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r58825 | crichter | 2007-03-12 13:43:24 +0100 (Mo, 12 Mär 2007) | 1 line
added UU transceiving and corect handling for rdnis
................
r58826 | crichter | 2007-03-12 14:08:06 +0100 (Mo, 12 Mär 2007) | 21 lines
Merged revisions 57034,57523,57753,58558 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r57034 | crichter | 2007-02-28 17:09:27 +0100 (Mi, 28 Feb 2007) | 1 line
fixed bugs.digium.com bugs: #9157 and bugs.beronet.com bugs: #302, #303, #304
........
r57523 | crichter | 2007-03-02 19:32:51 +0100 (Fr, 02 Mar 2007) | 1 line
fixed typo
........
r57753 | crichter | 2007-03-04 11:39:50 +0100 (So, 04 Mar 2007) | 1 line
fixed another place where the out_cause was hardcoded to 16
........
r58558 | crichter | 2007-03-09 15:43:58 +0100 (Fr, 09 Mar 2007) | 1 line
we can free channel 31 as well, since we can occupy it
........
................
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@64951 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-05-18 09:31:27 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-05 17:24:46 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building SETUP Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_connect (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	CONNECT_t *connect=(CONNECT_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2006-04-05 14:51:48 +00:00
										 |  |  | 	int plan,pres,screen; | 
					
						
							| 
									
										
										
										
											2006-04-04 19:09:26 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	bc->ces = connect->ces; | 
					
						
							|  |  |  | 	bc->ces = connect->ces; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	dec_ie_progress(connect->PROGRESS, (Q931_info_t *)connect, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc); | 
					
						
							| 
									
										
										
										
											2006-04-04 19:09:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-05 14:51:48 +00:00
										 |  |  | 	dec_ie_connected_pn(connect->CONNECT_PN,(Q931_info_t *)connect, &bc->cpnnumplan, &plan, &pres, &screen, bc->cad, 31, nt, bc); | 
					
						
							| 
									
										
										
										
											2006-04-04 19:09:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-05 14:51:48 +00:00
										 |  |  | 	/*
 | 
					
						
							|  |  |  | 		cb_log(1,bc->port,"CONNETED PN: %s cpn_dialplan:%d\n", connected_pn, type); | 
					
						
							|  |  |  | 	*/ | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing CONNECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_connect (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	CONNECT_t *connect; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_CONNECT | REQUEST, MT_CONNECT,  bc?bc->l3_id:-1, sizeof(CONNECT_t) ,nt);  | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-02-08 16:10:21 +00:00
										 |  |  | 	cb_log(6,bc->port,"BUILD_CONNECT: bc:%p bc->l3id:%d, nt:%d\n",bc,bc->l3_id,nt); | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	connect=(CONNECT_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (nt) { | 
					
						
							|  |  |  | 		time_t now; | 
					
						
							|  |  |  | 		time(&now); | 
					
						
							|  |  |  | 		enc_ie_date(&connect->DATE, msg, now, nt,bc); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-03-09 18:01:27 +00:00
										 |  |  | 		int type=bc->cpnnumplan, plan=1, present=2, screen=0; | 
					
						
							| 
									
										
										
										
											2006-08-09 09:24:21 +00:00
										 |  |  | 		enc_ie_connected_pn(&connect->CONNECT_PN, msg, type,plan, present, screen, bc->cad, nt , bc); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building CONNECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_setup_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	SETUP_ACKNOWLEDGE_t *setup_acknowledge=(SETUP_ACKNOWLEDGE_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int  exclusive, channel; | 
					
						
							|  |  |  | 		dec_ie_channel_id(setup_acknowledge->CHANNEL_ID, (Q931_info_t *)setup_acknowledge, &exclusive, &channel, nt,bc); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 		set_channel(bc, channel); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	dec_ie_progress(setup_acknowledge->PROGRESS, (Q931_info_t *)setup_acknowledge, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc); | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing SETUP_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_setup_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	SETUP_ACKNOWLEDGE_t *setup_acknowledge; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_SETUP_ACKNOWLEDGE | REQUEST, MT_SETUP_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(SETUP_ACKNOWLEDGE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	setup_acknowledge=(SETUP_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	enc_ie_channel_id(&setup_acknowledge->CHANNEL_ID, msg, 1,bc->channel, nt,bc); | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	if (nt)  | 
					
						
							|  |  |  | 		enc_ie_progress(&setup_acknowledge->PROGRESS, msg, 0, nt?1:5, 8, nt,bc); | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building SETUP_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_connect_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing CONNECT_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_connect_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	CONNECT_ACKNOWLEDGE_t *connect_acknowledge; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_CONNECT | RESPONSE, MT_CONNECT,  bc?bc->l3_id:-1, sizeof(CONNECT_ACKNOWLEDGE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	connect_acknowledge=(CONNECT_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	enc_ie_channel_id(&connect_acknowledge->CHANNEL_ID, msg, 1, bc->channel, nt,bc); | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building CONNECT_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_user_information (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing USER_INFORMATION Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_user_information (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	USER_INFORMATION_t *user_information; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_USER_INFORMATION | REQUEST, MT_USER_INFORMATION,  bc?bc->l3_id:-1, sizeof(USER_INFORMATION_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	user_information=(USER_INFORMATION_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building USER_INFORMATION Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_suspend_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing SUSPEND_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_suspend_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	SUSPEND_REJECT_t *suspend_reject; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_SUSPEND_REJECT | REQUEST, MT_SUSPEND_REJECT,  bc?bc->l3_id:-1, sizeof(SUSPEND_REJECT_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	suspend_reject=(SUSPEND_REJECT_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building SUSPEND_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_resume_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RESUME_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_resume_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RESUME_REJECT_t *resume_reject; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RESUME_REJECT | REQUEST, MT_RESUME_REJECT,  bc?bc->l3_id:-1, sizeof(RESUME_REJECT_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	resume_reject=(RESUME_REJECT_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RESUME_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_hold (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing HOLD Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_hold (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	HOLD_t *hold; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_HOLD | REQUEST, MT_HOLD,  bc?bc->l3_id:-1, sizeof(HOLD_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	hold=(HOLD_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building HOLD Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_suspend (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing SUSPEND Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_suspend (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	SUSPEND_t *suspend; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_SUSPEND | REQUEST, MT_SUSPEND,  bc?bc->l3_id:-1, sizeof(SUSPEND_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	suspend=(SUSPEND_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building SUSPEND Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_resume (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RESUME Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_resume (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RESUME_t *resume; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RESUME | REQUEST, MT_RESUME,  bc?bc->l3_id:-1, sizeof(RESUME_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	resume=(RESUME_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RESUME Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_hold_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing HOLD_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_hold_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	HOLD_ACKNOWLEDGE_t *hold_acknowledge; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_HOLD_ACKNOWLEDGE | REQUEST, MT_HOLD_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(HOLD_ACKNOWLEDGE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	hold_acknowledge=(HOLD_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building HOLD_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_suspend_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing SUSPEND_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_suspend_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	SUSPEND_ACKNOWLEDGE_t *suspend_acknowledge; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_SUSPEND_ACKNOWLEDGE | REQUEST, MT_SUSPEND_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(SUSPEND_ACKNOWLEDGE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	suspend_acknowledge=(SUSPEND_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building SUSPEND_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_resume_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RESUME_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_resume_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RESUME_ACKNOWLEDGE_t *resume_acknowledge; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RESUME_ACKNOWLEDGE | REQUEST, MT_RESUME_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(RESUME_ACKNOWLEDGE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	resume_acknowledge=(RESUME_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RESUME_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_hold_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing HOLD_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_hold_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	HOLD_REJECT_t *hold_reject; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_HOLD_REJECT | REQUEST, MT_HOLD_REJECT,  bc?bc->l3_id:-1, sizeof(HOLD_REJECT_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	hold_reject=(HOLD_REJECT_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building HOLD_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_retrieve (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RETRIEVE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_retrieve (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RETRIEVE_t *retrieve; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RETRIEVE | REQUEST, MT_RETRIEVE,  bc?bc->l3_id:-1, sizeof(RETRIEVE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	retrieve=(RETRIEVE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RETRIEVE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_retrieve_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RETRIEVE_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_retrieve_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RETRIEVE_ACKNOWLEDGE_t *retrieve_acknowledge; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RETRIEVE_ACKNOWLEDGE | REQUEST, MT_RETRIEVE_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(RETRIEVE_ACKNOWLEDGE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	retrieve_acknowledge=(RETRIEVE_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	enc_ie_channel_id(&retrieve_acknowledge->CHANNEL_ID, msg, 1, bc->channel, nt,bc); | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RETRIEVE_ACKNOWLEDGE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_retrieve_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RETRIEVE_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_retrieve_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RETRIEVE_REJECT_t *retrieve_reject; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RETRIEVE_REJECT | REQUEST, MT_RETRIEVE_REJECT,  bc?bc->l3_id:-1, sizeof(RETRIEVE_REJECT_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	retrieve_reject=(RETRIEVE_REJECT_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RETRIEVE_REJECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_disconnect (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	DISCONNECT_t *disconnect=(DISCONNECT_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 	int location; | 
					
						
							| 
									
										
										
										
											2006-10-13 08:23:41 +00:00
										 |  |  |  	int cause;  | 
					
						
							|  |  |  | 	dec_ie_cause(disconnect->CAUSE, (Q931_info_t *)(disconnect), &location, &cause, nt,bc); | 
					
						
							|  |  |  | 	if (cause>0) bc->cause=cause; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	dec_ie_progress(disconnect->PROGRESS, (Q931_info_t *)disconnect, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc); | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing DISCONNECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_disconnect (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	DISCONNECT_t *disconnect; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_DISCONNECT | REQUEST, MT_DISCONNECT,  bc?bc->l3_id:-1, sizeof(DISCONNECT_t) ,nt);  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	disconnect=(DISCONNECT_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	enc_ie_cause(&disconnect->CAUSE, msg, (nt)?1:0, bc->out_cause,nt,bc); | 
					
						
							|  |  |  | 	if (nt) enc_ie_progress(&disconnect->PROGRESS, msg, 0, nt?1:5, 8 ,nt,bc); | 
					
						
							| 
									
										
										
										
											2007-08-15 11:27:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (bc->uulen) { | 
					
						
							|  |  |  | 		int  protocol=4; | 
					
						
							|  |  |  | 		enc_ie_useruser(&disconnect->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc); | 
					
						
							|  |  |  | 		cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building DISCONNECT Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_restart (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RESTART_t *restart=(RESTART_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							| 
									
										
										
										
											2005-11-01 22:04:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	struct misdn_stack *stack=get_stack_by_bc(bc); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RESTART Msg\n"); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2007-07-02 09:23:08 +00:00
										 |  |  | 		int  exclusive; | 
					
						
							| 
									
										
										
										
											2006-06-01 12:51:41 +00:00
										 |  |  | 		dec_ie_channel_id(restart->CHANNEL_ID, (Q931_info_t *)restart, &exclusive, &bc->restart_channel, nt,bc); | 
					
						
							| 
									
										
										
										
											2007-07-02 09:23:08 +00:00
										 |  |  | 		cb_log(3, stack->port, "CC_RESTART Request on channel:%d on this port.\n", bc->restart_channel); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_restart (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RESTART_t *restart; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RESTART | REQUEST, MT_RESTART,  bc?bc->l3_id:-1, sizeof(RESTART_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	restart=(RESTART_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RESTART Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-11-12 13:33:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (bc->channel > 0) { | 
					
						
							|  |  |  | 		enc_ie_channel_id(&restart->CHANNEL_ID, msg, 1,bc->channel, nt,bc); | 
					
						
							|  |  |  | 		enc_ie_restart_ind(&restart->RESTART_IND, msg, 0x80, nt, bc); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		enc_ie_restart_ind(&restart->RESTART_IND, msg, 0x87, nt, bc); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-06-11 11:40:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	cb_log(0,bc->port, "Restarting channel %d\n", bc->channel); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_release (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RELEASE_t *release=(RELEASE_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 	int location; | 
					
						
							| 
									
										
										
										
											2006-10-13 08:23:41 +00:00
										 |  |  | 	int cause; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2006-10-13 08:23:41 +00:00
										 |  |  | 	dec_ie_cause(release->CAUSE, (Q931_info_t *)(release), &location, &cause, nt,bc); | 
					
						
							|  |  |  | 	if (cause>0) bc->cause=cause; | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RELEASE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static msg_t *build_release (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RELEASE_t *release; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RELEASE | REQUEST, MT_RELEASE,  bc?bc->l3_id:-1, sizeof(RELEASE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	release=(RELEASE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2006-02-22 16:48:25 +00:00
										 |  |  | 	if (bc->out_cause>= 0) | 
					
						
							|  |  |  | 		enc_ie_cause(&release->CAUSE, msg, nt?1:0, bc->out_cause, nt,bc); | 
					
						
							| 
									
										
										
										
											2007-08-15 11:27:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (bc->uulen) { | 
					
						
							|  |  |  | 		int  protocol=4; | 
					
						
							|  |  |  | 		enc_ie_useruser(&release->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc); | 
					
						
							|  |  |  | 		cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RELEASE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_release_complete (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RELEASE_COMPLETE_t *release_complete=(RELEASE_COMPLETE_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 	int location; | 
					
						
							| 
									
										
										
										
											2006-10-13 08:23:41 +00:00
										 |  |  | 	int cause; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	iframe_t *frm = (iframe_t*) msg->data; | 
					
						
							| 
									
										
										
										
											2005-11-01 22:04:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	struct misdn_stack *stack=get_stack_by_bc(bc); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	mISDNuser_head_t *hh; | 
					
						
							|  |  |  | 	hh=(mISDNuser_head_t*)msg->data; | 
					
						
							| 
									
										
										
										
											2006-02-08 16:10:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/*hh=(mISDN_head_t*)msg->data;
 | 
					
						
							|  |  |  | 	mISDN_head_t *hh;*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	if (nt) { | 
					
						
							|  |  |  | 		if (hh->prim == (CC_RELEASE_COMPLETE|CONFIRM)) { | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 			cb_log(0, stack->port, "CC_RELEASE_COMPLETE|CONFIRM [NT] \n"); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		if (frm->prim == (CC_RELEASE_COMPLETE|CONFIRM)) { | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 			cb_log(0, stack->port, "CC_RELEASE_COMPLETE|CONFIRM [TE] \n"); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2006-10-13 08:23:41 +00:00
										 |  |  | 	dec_ie_cause(release_complete->CAUSE, (Q931_info_t *)(release_complete), &location, &cause, nt,bc); | 
					
						
							|  |  |  | 	if (cause>0) bc->cause=cause; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing RELEASE_COMPLETE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_release_complete (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	RELEASE_COMPLETE_t *release_complete; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_RELEASE_COMPLETE | REQUEST, MT_RELEASE_COMPLETE,  bc?bc->l3_id:-1, sizeof(RELEASE_COMPLETE_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	release_complete=(RELEASE_COMPLETE_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	enc_ie_cause(&release_complete->CAUSE, msg, nt?1:0, bc->out_cause, nt,bc); | 
					
						
							| 
									
										
										
										
											2007-08-15 11:27:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (bc->uulen) { | 
					
						
							|  |  |  | 		int  protocol=4; | 
					
						
							|  |  |  | 		enc_ie_useruser(&release_complete->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc); | 
					
						
							|  |  |  | 		cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building RELEASE_COMPLETE Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_facility (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2006-08-15 16:49:26 +00:00
										 |  |  | 	int HEADER_LEN = nt ? mISDNUSER_HEAD_SIZE : mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	FACILITY_t *facility = (FACILITY_t*)(msg->data+HEADER_LEN);  | 
					
						
							|  |  |  | 	Q931_info_t *qi = (Q931_info_t*)(msg->data+HEADER_LEN);   | 
					
						
							|  |  |  | 	unsigned char *p = NULL; | 
					
						
							|  |  |  | 	int err; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing FACILITY Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-15 16:49:26 +00:00
										 |  |  | 	if (!bc->nt) { | 
					
						
							|  |  |  | 		if (qi->QI_ELEMENT(facility)) | 
					
						
							|  |  |  | 			p = (unsigned char *)qi + sizeof(Q931_info_t) + qi->QI_ELEMENT(facility) + 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		p = facility->FACILITY; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (!p) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-08-16 13:19:54 +00:00
										 |  |  | 	err = decodeFac(p, &(bc->fac_in)); | 
					
						
							| 
									
										
										
										
											2006-08-15 16:49:26 +00:00
										 |  |  | 	if (err) { | 
					
						
							| 
									
										
										
										
											2007-10-22 10:04:04 +00:00
										 |  |  | 		cb_log(5, bc->port, "Decoding FACILITY failed! (%d)\n", err); | 
					
						
							| 
									
										
										
										
											2006-08-15 16:49:26 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_facility (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2006-08-15 16:49:26 +00:00
										 |  |  | 	int len, | 
					
						
							|  |  |  | 		HEADER_LEN = nt ? mISDNUSER_HEAD_SIZE : mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	unsigned char *ie_fac, | 
					
						
							|  |  |  | 				  fac_tmp[256]; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_FACILITY | REQUEST, MT_FACILITY,  bc?bc->l3_id:-1, sizeof(FACILITY_t) ,nt); | 
					
						
							|  |  |  | 	FACILITY_t *facility = (FACILITY_t*)(msg->data+HEADER_LEN);  | 
					
						
							|  |  |  | 	Q931_info_t *qi; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building FACILITY Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-08-15 16:49:26 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-08-16 13:19:54 +00:00
										 |  |  | 	len = encodeFac(fac_tmp, &(bc->fac_out)); | 
					
						
							| 
									
										
										
										
											2006-08-15 16:49:26 +00:00
										 |  |  | 	if (len <= 0) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ie_fac = msg_put(msg, len); | 
					
						
							|  |  |  | 	if (bc->nt) { | 
					
						
							|  |  |  | 		facility->FACILITY = ie_fac + 1; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		qi = (Q931_info_t *)(msg->data + mISDN_HEADER_LEN); | 
					
						
							|  |  |  | 		qi->QI_ELEMENT(facility) = ie_fac - (unsigned char *)qi - sizeof(Q931_info_t); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	memcpy(ie_fac, fac_tmp, len); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (*bc->display) { | 
					
						
							|  |  |  | 		printf("Sending %s as Display\n", bc->display); | 
					
						
							|  |  |  | 		enc_ie_display(&facility->DISPLAY, msg, bc->display, nt,bc); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_notify (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing NOTIFY Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_notify (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	NOTIFY_t *notify; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_NOTIFY | REQUEST, MT_NOTIFY,  bc?bc->l3_id:-1, sizeof(NOTIFY_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	notify=(NOTIFY_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building NOTIFY Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_status_enquiry (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing STATUS_ENQUIRY Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_status_enquiry (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	STATUS_ENQUIRY_t *status_enquiry; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_STATUS_ENQUIRY | REQUEST, MT_STATUS_ENQUIRY,  bc?bc->l3_id:-1, sizeof(STATUS_ENQUIRY_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	status_enquiry=(STATUS_ENQUIRY_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building STATUS_ENQUIRY Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_information (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	INFORMATION_t *information=(INFORMATION_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int  type, plan; | 
					
						
							|  |  |  | 		char number[32]; | 
					
						
							|  |  |  | 		char keypad[32]; | 
					
						
							| 
									
										
										
										
											2006-08-09 09:24:21 +00:00
										 |  |  | 		dec_ie_called_pn(information->CALLED_PN, (Q931_info_t *)information, &type, &plan, number, sizeof(number)-1, nt, bc); | 
					
						
							|  |  |  | 		dec_ie_keypad(information->KEYPAD, (Q931_info_t *)information, keypad, sizeof(keypad)-1, nt, bc); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 		strcpy(bc->info_dad, number); | 
					
						
							|  |  |  | 		strcpy(bc->keypad,keypad); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing INFORMATION Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_information (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	INFORMATION_t *information; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_INFORMATION | REQUEST, MT_INFORMATION,  bc?bc->l3_id:-1, sizeof(INFORMATION_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	information=(INFORMATION_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		enc_ie_called_pn(&information->CALLED_PN, msg, 0, 1, bc->info_dad, nt,bc); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (*bc->display) { | 
					
						
							|  |  |  | 			printf("Sending %s as Display\n", bc->display); | 
					
						
							|  |  |  | 			enc_ie_display(&information->DISPLAY, msg, bc->display, nt,bc); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building INFORMATION Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_status (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	STATUS_t *status=(STATUS_t*)((unsigned long)(msg->data+HEADER_LEN)); | 
					
						
							|  |  |  | 	int location; | 
					
						
							| 
									
										
										
										
											2006-10-13 08:23:41 +00:00
										 |  |  | 	int cause; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2006-10-13 08:23:41 +00:00
										 |  |  | 	dec_ie_cause(status->CAUSE, (Q931_info_t *)(status), &location, &cause, nt,bc); | 
					
						
							|  |  |  | 	if (cause>0) bc->cause=cause; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing STATUS Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_status (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	STATUS_t *status; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_STATUS | REQUEST, MT_STATUS,  bc?bc->l3_id:-1, sizeof(STATUS_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	status=(STATUS_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building STATUS Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static void parse_timeout (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Parsing STATUS Msg\n");  | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | #endif 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-21 02:11:39 +00:00
										 |  |  | static msg_t *build_timeout (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)  | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; | 
					
						
							|  |  |  | 	STATUS_t *status; | 
					
						
							|  |  |  | 	msg_t *msg =(msg_t*)create_l3msg(CC_STATUS | REQUEST, MT_STATUS,  bc?bc->l3_id:-1, sizeof(STATUS_t) ,nt);  | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	status=(STATUS_t*)((msg->data+HEADER_LEN));  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-18 15:03:42 +00:00
										 |  |  | #ifdef DEBUG 
 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	printf("Building STATUS Msg\n");  | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	return msg;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** Msg Array **/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct isdn_msg msgs_g[] = { | 
					
						
							|  |  |  | 	{CC_PROCEEDING,L3,EVENT_PROCEEDING, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_proceeding,build_proceeding, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "PROCEEDING"}, | 
					
						
							|  |  |  | 	{CC_ALERTING,L3,EVENT_ALERTING, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_alerting,build_alerting, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "ALERTING"}, | 
					
						
							|  |  |  | 	{CC_PROGRESS,L3,EVENT_PROGRESS, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_progress,build_progress, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "PROGRESS"}, | 
					
						
							|  |  |  | 	{CC_SETUP,L3,EVENT_SETUP, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_setup,build_setup, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "SETUP"}, | 
					
						
							|  |  |  | 	{CC_CONNECT,L3,EVENT_CONNECT, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_connect,build_connect, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "CONNECT"}, | 
					
						
							|  |  |  | 	{CC_SETUP_ACKNOWLEDGE,L3,EVENT_SETUP_ACKNOWLEDGE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_setup_acknowledge,build_setup_acknowledge, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "SETUP_ACKNOWLEDGE"}, | 
					
						
							|  |  |  | 	{CC_CONNECT_ACKNOWLEDGE ,L3,EVENT_CONNECT_ACKNOWLEDGE , | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_connect_acknowledge ,build_connect_acknowledge, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "CONNECT_ACKNOWLEDGE "}, | 
					
						
							|  |  |  | 	{CC_USER_INFORMATION,L3,EVENT_USER_INFORMATION, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_user_information,build_user_information, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "USER_INFORMATION"}, | 
					
						
							|  |  |  | 	{CC_SUSPEND_REJECT,L3,EVENT_SUSPEND_REJECT, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_suspend_reject,build_suspend_reject, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "SUSPEND_REJECT"}, | 
					
						
							|  |  |  | 	{CC_RESUME_REJECT,L3,EVENT_RESUME_REJECT, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_resume_reject,build_resume_reject, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RESUME_REJECT"}, | 
					
						
							|  |  |  | 	{CC_HOLD,L3,EVENT_HOLD, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_hold,build_hold, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "HOLD"}, | 
					
						
							|  |  |  | 	{CC_SUSPEND,L3,EVENT_SUSPEND, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_suspend,build_suspend, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "SUSPEND"}, | 
					
						
							|  |  |  | 	{CC_RESUME,L3,EVENT_RESUME, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_resume,build_resume, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RESUME"}, | 
					
						
							|  |  |  | 	{CC_HOLD_ACKNOWLEDGE,L3,EVENT_HOLD_ACKNOWLEDGE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_hold_acknowledge,build_hold_acknowledge, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "HOLD_ACKNOWLEDGE"}, | 
					
						
							|  |  |  | 	{CC_SUSPEND_ACKNOWLEDGE,L3,EVENT_SUSPEND_ACKNOWLEDGE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_suspend_acknowledge,build_suspend_acknowledge, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "SUSPEND_ACKNOWLEDGE"}, | 
					
						
							|  |  |  | 	{CC_RESUME_ACKNOWLEDGE,L3,EVENT_RESUME_ACKNOWLEDGE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_resume_acknowledge,build_resume_acknowledge, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RESUME_ACKNOWLEDGE"}, | 
					
						
							|  |  |  | 	{CC_HOLD_REJECT,L3,EVENT_HOLD_REJECT, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_hold_reject,build_hold_reject, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "HOLD_REJECT"}, | 
					
						
							|  |  |  | 	{CC_RETRIEVE,L3,EVENT_RETRIEVE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_retrieve,build_retrieve, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RETRIEVE"}, | 
					
						
							|  |  |  | 	{CC_RETRIEVE_ACKNOWLEDGE,L3,EVENT_RETRIEVE_ACKNOWLEDGE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_retrieve_acknowledge,build_retrieve_acknowledge, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RETRIEVE_ACKNOWLEDGE"}, | 
					
						
							|  |  |  | 	{CC_RETRIEVE_REJECT,L3,EVENT_RETRIEVE_REJECT, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_retrieve_reject,build_retrieve_reject, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RETRIEVE_REJECT"}, | 
					
						
							|  |  |  | 	{CC_DISCONNECT,L3,EVENT_DISCONNECT, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_disconnect,build_disconnect, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "DISCONNECT"}, | 
					
						
							|  |  |  | 	{CC_RESTART,L3,EVENT_RESTART, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_restart,build_restart, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RESTART"}, | 
					
						
							|  |  |  | 	{CC_RELEASE,L3,EVENT_RELEASE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_release,build_release, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RELEASE"}, | 
					
						
							|  |  |  | 	{CC_RELEASE_COMPLETE,L3,EVENT_RELEASE_COMPLETE, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_release_complete,build_release_complete, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "RELEASE_COMPLETE"}, | 
					
						
							|  |  |  | 	{CC_FACILITY,L3,EVENT_FACILITY, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_facility,build_facility, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "FACILITY"}, | 
					
						
							|  |  |  | 	{CC_NOTIFY,L3,EVENT_NOTIFY, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_notify,build_notify, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "NOTIFY"}, | 
					
						
							|  |  |  | 	{CC_STATUS_ENQUIRY,L3,EVENT_STATUS_ENQUIRY, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_status_enquiry,build_status_enquiry, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "STATUS_ENQUIRY"}, | 
					
						
							|  |  |  | 	{CC_INFORMATION,L3,EVENT_INFORMATION, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_information,build_information, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "INFORMATION"}, | 
					
						
							|  |  |  | 	{CC_STATUS,L3,EVENT_STATUS, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_status,build_status, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "STATUS"}, | 
					
						
							|  |  |  | 	{CC_TIMEOUT,L3,EVENT_TIMEOUT, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	 parse_timeout,build_timeout, | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 "TIMEOUT"}, | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 	{0,0,0,NULL,NULL,NULL} | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define msgs_max (sizeof(msgs_g)/sizeof(struct isdn_msg))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** INTERFACE FCTS ***/ | 
					
						
							|  |  |  | int isdn_msg_get_index(struct isdn_msg msgs[], msg_t *msg, int nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (nt){ | 
					
						
							|  |  |  | 		mISDNuser_head_t *hh = (mISDNuser_head_t*)msg->data; | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		for (i=0; i< msgs_max -1; i++) { | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 			if ( (hh->prim&COMMAND_MASK)==(msgs[i].misdn_msg&COMMAND_MASK)) return i; | 
					
						
							| 
									
										
										
										
											2005-12-09 11:01:18 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		iframe_t *frm = (iframe_t*)msg->data; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | 		for (i=0; i< msgs_max -1; i++)  | 
					
						
							|  |  |  | 			if ( (frm->prim&COMMAND_MASK)==(msgs[i].misdn_msg&COMMAND_MASK)) return i; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return -1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int isdn_msg_get_index_by_event(struct isdn_msg msgs[], enum event_e event, int nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 	for (i=0; i< msgs_max; i++)  | 
					
						
							|  |  |  | 		if ( event == msgs[i].event) return i; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 	cb_log(10,0, "get_index: event not found!\n"); | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return -1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum event_e isdn_msg_get_event(struct isdn_msg msgs[], msg_t *msg, int nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i=isdn_msg_get_index(msgs, msg, nt); | 
					
						
							|  |  |  | 	if(i>=0) return msgs[i].event; | 
					
						
							|  |  |  | 	return EVENT_UNKNOWN; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | char * isdn_msg_get_info(struct isdn_msg msgs[], msg_t *msg, int nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i=isdn_msg_get_index(msgs, msg, nt); | 
					
						
							|  |  |  | 	if(i>=0) return msgs[i].info; | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | char EVENT_CLEAN_INFO[] = "CLEAN_UP"; | 
					
						
							|  |  |  | char EVENT_DTMF_TONE_INFO[] = "DTMF_TONE"; | 
					
						
							|  |  |  | char EVENT_NEW_L3ID_INFO[] = "NEW_L3ID"; | 
					
						
							|  |  |  | char EVENT_NEW_BC_INFO[] = "NEW_BC"; | 
					
						
							| 
									
										
										
										
											2006-08-03 16:38:00 +00:00
										 |  |  | char EVENT_PORT_ALARM_INFO[] = "ALARM"; | 
					
						
							| 
									
										
										
										
											2006-05-24 23:21:03 +00:00
										 |  |  | char EVENT_NEW_CHANNEL_INFO[] = "NEW_CHANNEL"; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | char EVENT_BCHAN_DATA_INFO[] = "BCHAN_DATA"; | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | char EVENT_BCHAN_ACTIVATED_INFO[] = "BCHAN_ACTIVATED"; | 
					
						
							|  |  |  | char EVENT_TONE_GENERATE_INFO[] = "TONE_GENERATE"; | 
					
						
							| 
									
										
										
										
											2006-10-27 11:18:32 +00:00
										 |  |  | char EVENT_BCHAN_ERROR_INFO[] = "BCHAN_ERROR"; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | char * isdn_get_info(struct isdn_msg msgs[], enum event_e event, int nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i=isdn_msg_get_index_by_event(msgs, event, nt); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if(i>=0) return msgs[i].info; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (event == EVENT_CLEANUP) return EVENT_CLEAN_INFO; | 
					
						
							|  |  |  | 	if (event == EVENT_DTMF_TONE) return EVENT_DTMF_TONE_INFO; | 
					
						
							|  |  |  | 	if (event == EVENT_NEW_L3ID) return EVENT_NEW_L3ID_INFO; | 
					
						
							|  |  |  | 	if (event == EVENT_NEW_BC) return EVENT_NEW_BC_INFO; | 
					
						
							| 
									
										
										
										
											2006-05-24 23:21:03 +00:00
										 |  |  | 	if (event == EVENT_NEW_CHANNEL) return EVENT_NEW_CHANNEL_INFO; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	if (event == EVENT_BCHAN_DATA) return EVENT_BCHAN_DATA_INFO; | 
					
						
							| 
									
										
										
										
											2006-02-02 21:15:34 +00:00
										 |  |  | 	if (event == EVENT_BCHAN_ACTIVATED) return EVENT_BCHAN_ACTIVATED_INFO; | 
					
						
							|  |  |  | 	if (event == EVENT_TONE_GENERATE) return EVENT_TONE_GENERATE_INFO; | 
					
						
							| 
									
										
										
										
											2006-08-03 16:38:00 +00:00
										 |  |  | 	if (event == EVENT_PORT_ALARM) return EVENT_PORT_ALARM_INFO; | 
					
						
							| 
									
										
										
										
											2006-10-27 11:18:32 +00:00
										 |  |  | 	if (event == EVENT_BCHAN_ERROR) return EVENT_BCHAN_ERROR_INFO; | 
					
						
							| 
									
										
										
										
											2005-10-31 23:30:09 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int isdn_msg_parse_event(struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i=isdn_msg_get_index(msgs, msg, nt); | 
					
						
							|  |  |  | 	if(i<0) return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	msgs[i].msg_parser(msgs, msg, bc, nt); | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | msg_t * isdn_msg_build_event(struct isdn_msg msgs[], struct misdn_bchannel *bc, enum event_e event, int nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i=isdn_msg_get_index_by_event(msgs, event, nt); | 
					
						
							|  |  |  | 	if(i<0) return NULL; | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | 	return  msgs[i].msg_builder(msgs, bc, nt); | 
					
						
							|  |  |  | } |