Compare commits
	
		
			No commits in common. "13c0b79af7605bbec2fbec3ca72ae83af5363544" and "c0425ff0e288b96bde8b96b8d16e758de2896f00" have entirely different histories.
		
	
	
		
			13c0b79af7
			...
			c0425ff0e2
		
	
		
|  | @ -509,14 +509,6 @@ UCHAR * DISPLAY_NETROM(MESSAGE * ADJBUFFER, UCHAR * Output, int MsgLen, int DoNo | |||
| 		return Output; | ||||
| 	} | ||||
| 
 | ||||
| 	if (ADJBUFFER->L2DATA[0] == 0xfe)			// Paula's Nodes Poll
 | ||||
| 	{ | ||||
| 		memcpy(Alias, ++ptr, 6); | ||||
| 		Output += sprintf((char *)Output, " NODES POLL from %s\r", Alias); | ||||
| 		return Output; | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 	//	Display normal NET/ROM transmissions 
 | ||||
| 
 | ||||
| 	Output += sprintf((char *)Output, " NET/ROM\r  "); | ||||
|  |  | |||
							
								
								
									
										12
									
								
								ARDOP.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								ARDOP.c
									
									
									
									
									
								
							|  | @ -567,7 +567,7 @@ static int ProcessLine(char * buf, int Port) | |||
| } | ||||
| 
 | ||||
| 
 | ||||
| void ARDOPThread(VOID * Param); | ||||
| void ARDOPThread(struct TNCINFO * TNC); | ||||
| VOID ARDOPProcessDataSocketData(int port); | ||||
| int ConnecttoARDOP(struct TNCINFO * TNC); | ||||
| static VOID ARDOPProcessReceivedData(struct TNCINFO * TNC); | ||||
|  | @ -2312,13 +2312,12 @@ int ConnecttoARDOP(struct TNCINFO * TNC) | |||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| VOID ARDOPThread(VOID * Param) | ||||
| VOID ARDOPThread(struct TNCINFO * TNC) | ||||
| { | ||||
| 	// Opens sockets and looks for data on control and data sockets.
 | ||||
| 	 | ||||
| 	// Socket may be TCP/IP or Serial
 | ||||
| 
 | ||||
|     struct TNCINFO * TNC = (struct TNCINFO *) Param; | ||||
| 	char Msg[255]; | ||||
| 	int err, i, ret; | ||||
| 	u_long param=1; | ||||
|  | @ -5759,7 +5758,8 @@ VOID ARDOPSCSPoll(struct TNCINFO * TNC) | |||
| 
 | ||||
| // Probably only for Teensy with ESP01. Runs SCS Emulator over a TCP Link
 | ||||
| 
 | ||||
| VOID SerialConnecttoTCPThread(VOID *  Param); | ||||
| 
 | ||||
| VOID SerialConnecttoTCPThread(struct TNCINFO * TNC); | ||||
| 
 | ||||
| int SerialConnecttoTCP(struct TNCINFO * TNC) | ||||
| { | ||||
|  | @ -5767,9 +5767,9 @@ int SerialConnecttoTCP(struct TNCINFO * TNC) | |||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
| VOID SerialConnecttoTCPThread(VOID *  Param) | ||||
| 
 | ||||
| VOID SerialConnecttoTCPThread(struct TNCINFO * TNC) | ||||
| { | ||||
| 	struct TNCINFO * TNC = (struct TNCINFO *) Param; | ||||
| 	char Msg[255]; | ||||
| 	int i; | ||||
| 	u_long param = 1; | ||||
|  |  | |||
							
								
								
									
										270
									
								
								BPQINP3.c
									
									
									
									
									
								
							
							
						
						
									
										270
									
								
								BPQINP3.c
									
									
									
									
									
								
							|  | @ -35,9 +35,7 @@ along with LinBPQ/BPQ32.  If not, see http://www.gnu.org/licenses | |||
| #include <fcntl.h>					  | ||||
| //#include "vmm.h"
 | ||||
| 
 | ||||
| uint64_t INP3timeLoadedMS = 0; | ||||
| 
 | ||||
| extern int DEBUGINP3; | ||||
| uint64_t timeLoadedMS = 0; | ||||
| 
 | ||||
| VOID SendNegativeInfo(); | ||||
| VOID SortRoutes(struct DEST_LIST * Dest); | ||||
|  | @ -64,8 +62,8 @@ typedef struct _RTTMSG | |||
| 	UCHAR ALIAS[7]; | ||||
| 	UCHAR VERSION[12]; | ||||
| 	UCHAR SWVERSION[9]; | ||||
| 	UCHAR FLAGS[20]; | ||||
| 	UCHAR PADDING[137]; | ||||
| 	UCHAR FLAGS[10]; | ||||
| 	UCHAR PADDING[147]; | ||||
| 
 | ||||
| } RTTMSG; | ||||
| 
 | ||||
|  | @ -104,14 +102,14 @@ int RTTTimeout = 6;				// 1 Min (Horizon is 1 min) | |||
| 
 | ||||
| VOID InitialiseRTT() | ||||
| { | ||||
| 	UCHAR temp[256] = ""; | ||||
| 	UCHAR temp[sizeof(RTTMsg.FLAGS) + 4]; | ||||
| 
 | ||||
| 	memset(&RTTMsg, ' ', sizeof(struct _RTTMSG)); | ||||
| 	memcpy(RTTMsg.ID, "L3RTT: ", 7); | ||||
| 	memcpy(RTTMsg.VERSION, "LEVEL3_V2.1 ", 12); | ||||
| 	memcpy(RTTMsg.SWVERSION, "BPQ32002 ", 9); | ||||
| 	_snprintf(temp, sizeof(temp), "$M%d $N $H%d            ", MAXRTT, MaxHops); // trailing spaces extend to ensure padding if the length of characters for MAXRTT changes.
 | ||||
| 	memcpy(RTTMsg.FLAGS, temp, 20);                 // But still limit the actual characters copied.
 | ||||
| 	memcpy(RTTMsg.SWVERSION, "BPQ32001 ", 9); | ||||
| 	_snprintf(temp, sizeof(temp), "$M%d $N      ", MAXRTT); // trailing spaces extend to ensure padding if the length of characters for MAXRTT changes.
 | ||||
| 	memcpy(RTTMsg.FLAGS, temp, 10);                 // But still limit the actual characters copied.
 | ||||
| 	memcpy(RTTMsg.ALIAS, &MYALIASTEXT, 6); | ||||
| 	RTTMsg.ALIAS[6] = ' '; | ||||
| } | ||||
|  | @ -143,7 +141,7 @@ VOID DeleteINP3Routes(struct ROUTE * Route) | |||
| 
 | ||||
| 	Call1[ConvFromAX25(Route->NEIGHBOUR_CALL, Call1)] = 0; | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("Deleting INP3 routes via %s", Call1); | ||||
| 	Debugprintf("Deleting INP3 routes via %s", Call1); | ||||
| 
 | ||||
| 	// Delete any INP3 Dest entries via this Route
 | ||||
| 
 | ||||
|  | @ -179,7 +177,7 @@ VOID DeleteINP3Routes(struct ROUTE * Route) | |||
| 
 | ||||
| 			// If we are cleaning up after a sabm on an existing link (frmr or other end reloaded) then we don't need to tell anyone - the routes should be reestablished very quickly
 | ||||
| 
 | ||||
| 			if (DEBUGINP3) Debugprintf("Deleting First INP3 Route to %s", Call2); | ||||
| 			Debugprintf("Deleting First INP3 Route to %s", Call2); | ||||
| 
 | ||||
| 			if (Dest->INP3ROUTE[1].ROUT_NEIGHBOUR == 0) | ||||
| 			{ | ||||
|  | @ -188,7 +186,7 @@ VOID DeleteINP3Routes(struct ROUTE * Route) | |||
| 				Dest->INP3ROUTE[0].SRTT = 60000; | ||||
| 				Dest->INP3ROUTE[0].Hops = 255; | ||||
| 
 | ||||
| 				if (DEBUGINP3) Debugprintf("Was the only INP3 route"); | ||||
| 				Debugprintf("Was the only INP3 route"); | ||||
| 
 | ||||
| 				if (Dest->DEST_ROUTE == 4)			// we were using it
 | ||||
| 					Dest->DEST_ROUTE = 0; | ||||
|  | @ -208,7 +206,7 @@ VOID DeleteINP3Routes(struct ROUTE * Route) | |||
| 		 | ||||
| 		if (Dest->INP3ROUTE[1].ROUT_NEIGHBOUR == Route) | ||||
| 		{ | ||||
| 			if (DEBUGINP3) Debugprintf("Deleting 2nd INP3 Route to %s", Call2); | ||||
| 			Debugprintf("Deleting 2nd INP3 Route to %s", Call2); | ||||
| 			memcpy(&Dest->INP3ROUTE[1], &Dest->INP3ROUTE[2], sizeof(struct INP3_DEST_ROUTE_ENTRY)); | ||||
| 			memset(&Dest->INP3ROUTE[2], 0, sizeof(struct INP3_DEST_ROUTE_ENTRY)); | ||||
| 
 | ||||
|  | @ -217,7 +215,7 @@ VOID DeleteINP3Routes(struct ROUTE * Route) | |||
| 
 | ||||
| 		if (Dest->INP3ROUTE[2].ROUT_NEIGHBOUR == Route) | ||||
| 		{ | ||||
| 			if (DEBUGINP3) Debugprintf("Deleting 3rd INP3 Route to %s", Call2); | ||||
| 			Debugprintf("Deleting 3rd INP3 Route to %s", Call2); | ||||
| 			memset(&Dest->INP3ROUTE[2], 0, sizeof(struct INP3_DEST_ROUTE_ENTRY)); | ||||
| 			continue; | ||||
| 		} | ||||
|  | @ -341,10 +339,10 @@ VOID ProcessRTTReply(struct ROUTE * Route, struct _L3MESSAGEBUFFER * Buff) | |||
| 	Route->Timeout = 0;			// Got Response
 | ||||
| 	 | ||||
| 	sscanf(&Buff->L4DATA[6], "%d", &OrigTime); | ||||
| 	RTT = (int)((GetTickCount() - INP3timeLoadedMS) / 10 - (OrigTime));		// We work internally in mS
 | ||||
| 	RTT = (GetTickCount() - timeLoadedMS) - OrigTime; | ||||
| 
 | ||||
| 	if (RTT > 60000) | ||||
| 		return;					// Ignore if more than 60 secs (why ??)
 | ||||
| 		return;					// Ignore if more than 60 secs
 | ||||
| 
 | ||||
| 	Route->RTT = RTT; | ||||
| 
 | ||||
|  | @ -353,13 +351,11 @@ VOID ProcessRTTReply(struct ROUTE * Route, struct _L3MESSAGEBUFFER * Buff) | |||
| 	else | ||||
| 		Route->SRTT = ((Route->SRTT * 80)/100) + ((RTT * 20)/100); | ||||
| 
 | ||||
| 	Route->RTTIncrement = Route->SRTT / 2;		// Half for one way time.
 | ||||
| 
 | ||||
| 	if ((Route->Status & GotRTTResponse) == 0) | ||||
| 	{ | ||||
| 		// Link is just starting
 | ||||
| 
 | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 got first RTT reply from %s - Link is (Re)staring", Normcall); | ||||
| 		Debugprintf("INP3 got first RTT reply from %s - Link is (Re)staring", Normcall); | ||||
| 
 | ||||
| 		Route->Status |= GotRTTResponse; | ||||
| 	} | ||||
|  | @ -378,10 +374,10 @@ VOID ProcessINP3RIF(struct ROUTE * Route, UCHAR * ptr1, int msglen, int Port) | |||
| 	char Normcall[10]; | ||||
| 
 | ||||
| 	Normcall[ConvFromAX25(Route->NEIGHBOUR_LINK->LINKCALL, Normcall)] = 0; | ||||
| 	if (DEBUGINP3) Debugprintf("Processing RIF from %s INP3Node %d Route SRTT %d", Normcall, Route->INP3Node, Route->SRTT); | ||||
| 	Debugprintf("Processing RIF from %s INP3Node %d Route SRTT %d", Normcall, Route->INP3Node, Route->SRTT); | ||||
| 
 | ||||
| 	if (Route->SRTT == 0) | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Zero SRTT"); | ||||
| 		Debugprintf("INP3 Zero SRTT"); | ||||
| 
 | ||||
| 
 | ||||
| #ifdef NOINP3 | ||||
|  | @ -407,7 +403,7 @@ VOID ProcessINP3RIF(struct ROUTE * Route, UCHAR * ptr1, int msglen, int Port) | |||
| 	{ | ||||
| 		if (msglen < 10) | ||||
| 		{ | ||||
| 			if (DEBUGINP3) Debugprintf("Corrupt INP3 Message"); | ||||
| 			Debugprintf("Corrupt INP3 Message"); | ||||
| 			return; | ||||
| 		} | ||||
| 
 | ||||
|  | @ -425,12 +421,7 @@ VOID ProcessINP3RIF(struct ROUTE * Route, UCHAR * ptr1, int msglen, int Port) | |||
| 
 | ||||
| 		// rtt is value from remote node. Add our RTT to that node
 | ||||
| 
 | ||||
| 		// if other end is old bpq then value is mS otherwise 10 mS unita
 | ||||
| 
 | ||||
| 		if (Route->OldBPQ) | ||||
| 			rtt /= 10; | ||||
| 
 | ||||
| //		rtt += Route->SRTT;		// Don't do this - other end has added linkrtt
 | ||||
| 		rtt += Route->SRTT; | ||||
| 
 | ||||
| 		msglen -= 10; | ||||
| 
 | ||||
|  | @ -448,7 +439,7 @@ VOID ProcessINP3RIF(struct ROUTE * Route, UCHAR * ptr1, int msglen, int Port) | |||
| 					memcpy(alias, ptr1+2, len-2); | ||||
| 				else | ||||
| 				{ | ||||
| 					if (DEBUGINP3) Debugprintf("Corrupt INP3 Message"); | ||||
| 					Debugprintf("Corrupt INP3 Message"); | ||||
| 					return; | ||||
| 				} | ||||
| 			} | ||||
|  | @ -486,13 +477,13 @@ VOID UpdateNode(struct ROUTE * Route, UCHAR * axcall, UCHAR * alias, int  hops, | |||
| 
 | ||||
| 	if (CompareCalls(axcall, NETROMCALL)) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 for our Nodecall - discarding"); | ||||
| 		Debugprintf("INP3 for our Nodecall - discarding"); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	if (CheckExcludeList(axcall) == 0) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 excluded - discarding"); | ||||
| 		Debugprintf("INP3 excluded - discarding"); | ||||
| 		return; | ||||
| 	} | ||||
| 	 | ||||
|  | @ -502,7 +493,7 @@ VOID UpdateNode(struct ROUTE * Route, UCHAR * axcall, UCHAR * alias, int  hops, | |||
| 
 | ||||
| 		if (CompareCalls(axcall, APPL->APPLCALL)) | ||||
| 		{ | ||||
| 			if (DEBUGINP3) Debugprintf("INP3 for an APPLCALL - discarding"); | ||||
| 			Debugprintf("INP3 for an APPLCALL - discarding"); | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
|  | @ -511,20 +502,20 @@ VOID UpdateNode(struct ROUTE * Route, UCHAR * axcall, UCHAR * alias, int  hops, | |||
| 	if (hops > MaxHops && hops < 255) | ||||
| 	{ | ||||
| 		ConvFromAX25(axcall, call); | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Node %s Hops %d RTT %d Ignored - Hop Count too high", call, hops, rtt); | ||||
| 		Debugprintf("INP3 Node %s Hops %d RTT %d Ignored - Hop Count too high", call, hops, rtt); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	if (rtt > MAXRTT  && rtt < 60000) | ||||
| 	{ | ||||
| 		ConvFromAX25(axcall, call); | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Node %s Hops %d RTT %d Ignored - rtt too high", call, hops, rtt); | ||||
| 		Debugprintf("INP3 Node %s Hops %d RTT %d Ignored - rtt too high", call, hops, rtt); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	if (rtt >= 60000) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 RTT > 60000 - discarding"); | ||||
| 		Debugprintf("INP3 RTT > 60000 - discarding"); | ||||
| 		return;	 | ||||
| 	} | ||||
| 
 | ||||
|  | @ -533,7 +524,7 @@ VOID UpdateNode(struct ROUTE * Route, UCHAR * axcall, UCHAR * alias, int  hops, | |||
| 
 | ||||
| 	if (Dest == NULL) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Table Full - discarding"); | ||||
| 		Debugprintf("INP3 Table Full - discarding"); | ||||
| 		return;	// Table Full
 | ||||
| 	} | ||||
| 	 | ||||
|  | @ -557,7 +548,7 @@ VOID UpdateNode(struct ROUTE * Route, UCHAR * axcall, UCHAR * alias, int  hops, | |||
| 	NUMBEROFNODES++; | ||||
| 
 | ||||
| 	ConvFromAX25(Dest->DEST_CALL, call); | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 Adding New Node %s Hops %d RTT %d", call, hops, rtt); | ||||
| 	Debugprintf("INP3 Adding New Node %s Hops %d RTT %d", call, hops, rtt); | ||||
| 
 | ||||
| 	return; | ||||
| 
 | ||||
|  | @ -565,14 +556,14 @@ Found: | |||
| 
 | ||||
| 	if (Dest->DEST_STATE & 0x80)	// Application Entry
 | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Application Entry - discarding"); | ||||
| 		Debugprintf("INP3 Application Entry - discarding"); | ||||
| 		return;	 | ||||
| 	} | ||||
| 
 | ||||
| 	// Update ALIAS
 | ||||
| 
 | ||||
| 	ConvFromAX25(Dest->DEST_CALL, call); | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 Updating Node %s Hops %d RTT %d", call, hops, rtt); | ||||
| 	Debugprintf("INP3 Updating Node %s Hops %d RTT %d", call, hops, rtt); | ||||
| 
 | ||||
| 	if (alias[0] > ' ') | ||||
| 		memcpy(Dest->DEST_ALIAS, alias, 6); | ||||
|  | @ -583,7 +574,7 @@ Found: | |||
| 
 | ||||
| 	if (ROUTEPTR->ROUT_NEIGHBOUR == Route) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Already have as route[0] - updating"); | ||||
| 		Debugprintf("INP3 Already have as route[0] - updating"); | ||||
| 		UpdateRoute(Dest, ROUTEPTR, hops, rtt); | ||||
| 		return; | ||||
| 	} | ||||
|  | @ -592,7 +583,7 @@ Found: | |||
| 
 | ||||
| 	if (ROUTEPTR->ROUT_NEIGHBOUR == Route) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Already have as route[1] - updating"); | ||||
| 		Debugprintf("INP3 Already have as route[1] - updating"); | ||||
| 		UpdateRoute(Dest, ROUTEPTR, hops, rtt); | ||||
| 		return; | ||||
| 	} | ||||
|  | @ -601,7 +592,7 @@ Found: | |||
| 
 | ||||
| 	if (ROUTEPTR->ROUT_NEIGHBOUR == Route) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Already have as route[2] - updating"); | ||||
| 		Debugprintf("INP3 Already have as route[2] - updating"); | ||||
| 		UpdateRoute(Dest, ROUTEPTR, hops, rtt); | ||||
| 		return; | ||||
| 	} | ||||
|  | @ -617,7 +608,7 @@ Found: | |||
| 		{ | ||||
| 			// Add here
 | ||||
| 
 | ||||
| 			if (DEBUGINP3) Debugprintf("INP3 adding as route[%d]", i); | ||||
| 			Debugprintf("INP3 adding as route[%d]", i); | ||||
| 			AddHere(ROUTEPTR, Route, hops, rtt); | ||||
| 			SortRoutes(Dest); | ||||
| 			return; | ||||
|  | @ -625,7 +616,7 @@ Found: | |||
| 		ROUTEPTR++; | ||||
| 	} | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 All entries in use - see if this is better than existing"); | ||||
| 	Debugprintf("INP3 All entries in use - see if this is better than existing"); | ||||
| 
 | ||||
| 	// Full, see if this is better
 | ||||
| 
 | ||||
|  | @ -635,7 +626,7 @@ Found: | |||
| 	{ | ||||
| 		// We are better. Move others down and add on front
 | ||||
| 
 | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Replacing route 0"); | ||||
| 		Debugprintf("INP3 Replacing route 0"); | ||||
| 
 | ||||
| 		memcpy(&Dest->INP3ROUTE[2], &Dest->INP3ROUTE[1], sizeof(struct INP3_DEST_ROUTE_ENTRY)); | ||||
| 		memcpy(&Dest->INP3ROUTE[1], &Dest->INP3ROUTE[0], sizeof(struct INP3_DEST_ROUTE_ENTRY)); | ||||
|  | @ -647,7 +638,7 @@ Found: | |||
| 	{ | ||||
| 		// We are better. Move  2nd down and add
 | ||||
| 
 | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Replacing route 1"); | ||||
| 		Debugprintf("INP3 Replacing route 1"); | ||||
| 		memcpy(&Dest->INP3ROUTE[2], &Dest->INP3ROUTE[1], sizeof(struct INP3_DEST_ROUTE_ENTRY)); | ||||
| 		AddHere(&Dest->INP3ROUTE[1], Route, hops, rtt); | ||||
| 		return; | ||||
|  | @ -657,13 +648,13 @@ Found: | |||
| 	{ | ||||
| 		// We are better. Add here
 | ||||
| 
 | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Replacing route 2"); | ||||
| 		Debugprintf("INP3 Replacing route 2"); | ||||
| 		AddHere(&Dest->INP3ROUTE[2], Route, hops, rtt); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 Worse that any existing route"); | ||||
| 	Debugprintf("INP3 Worse that any existing route"); | ||||
| 
 | ||||
| 
 | ||||
| 	// Worse than any - ignore
 | ||||
|  | @ -744,7 +735,7 @@ VOID SortRoutes(struct DEST_LIST * Dest) | |||
| 	if (Dest->INP3ROUTE[1].ROUT_NEIGHBOUR == 0) | ||||
| 	{ | ||||
| 		Call1[ConvFromAX25(Dest->INP3ROUTE[0].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call1)] = 0; | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 1 route %d %s",  Dest->INP3ROUTE[0].SRTT, Call1); | ||||
| 		Debugprintf("INP3 1 route %d %s",  Dest->INP3ROUTE[0].SRTT, Call1); | ||||
| 		return;						// Only One, so cant be out of order
 | ||||
| 	} | ||||
| 	if (Dest->INP3ROUTE[2].ROUT_NEIGHBOUR == 0) | ||||
|  | @ -754,7 +745,7 @@ VOID SortRoutes(struct DEST_LIST * Dest) | |||
| 		Call1[ConvFromAX25(Dest->INP3ROUTE[0].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call1)] = 0; | ||||
| 		Call2[ConvFromAX25(Dest->INP3ROUTE[1].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call2)] = 0; | ||||
| 	 | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 2 routes %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2); | ||||
| 		Debugprintf("INP3 2 routes %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2); | ||||
| 
 | ||||
| 		if (Dest->INP3ROUTE[0].SRTT <= Dest->INP3ROUTE[1].SRTT) | ||||
| 			return; | ||||
|  | @ -768,7 +759,7 @@ VOID SortRoutes(struct DEST_LIST * Dest) | |||
| 		Call1[ConvFromAX25(Dest->INP3ROUTE[0].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call1)] = 0; | ||||
| 		Call2[ConvFromAX25(Dest->INP3ROUTE[1].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call2)] = 0; | ||||
| 	 | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 2 routes %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2); | ||||
| 		Debugprintf("INP3 2 routes %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -779,7 +770,7 @@ VOID SortRoutes(struct DEST_LIST * Dest) | |||
| 	Call2[ConvFromAX25(Dest->INP3ROUTE[1].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call2)] = 0; | ||||
| 	Call3[ConvFromAX25(Dest->INP3ROUTE[2].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call3)] = 0; | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 	Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 		 | ||||
| 	// In order?
 | ||||
| 
 | ||||
|  | @ -800,7 +791,7 @@ VOID SortRoutes(struct DEST_LIST * Dest) | |||
| 	Call2[ConvFromAX25(Dest->INP3ROUTE[1].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call2)] = 0; | ||||
| 	Call3[ConvFromAX25(Dest->INP3ROUTE[2].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call3)] = 0; | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 	Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 
 | ||||
| 	// if 3 is better than 2 swap them. As two is worse than one. three will then be worst
 | ||||
| 
 | ||||
|  | @ -816,7 +807,7 @@ VOID SortRoutes(struct DEST_LIST * Dest) | |||
| 	Call2[ConvFromAX25(Dest->INP3ROUTE[1].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call2)] = 0; | ||||
| 	Call3[ConvFromAX25(Dest->INP3ROUTE[2].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call3)] = 0; | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 	Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 
 | ||||
| 	// 3 is now slowest. 2 could still be better than 1
 | ||||
| 
 | ||||
|  | @ -833,14 +824,14 @@ VOID SortRoutes(struct DEST_LIST * Dest) | |||
| 	Call2[ConvFromAX25(Dest->INP3ROUTE[1].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call2)] = 0; | ||||
| 	Call3[ConvFromAX25(Dest->INP3ROUTE[2].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Call3)] = 0; | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 	Debugprintf("INP3 3 routes %d %s %d %s %d %s",  Dest->INP3ROUTE[0].SRTT, Call1, Dest->INP3ROUTE[1].SRTT, Call2, Dest->INP3ROUTE[2].SRTT, Call3); | ||||
| 
 | ||||
| 	if (Dest->INP3ROUTE[0].SRTT <= Dest->INP3ROUTE[1].SRTT && Dest->INP3ROUTE[1].SRTT <= Dest->INP3ROUTE[2].SRTT)// In order?
 | ||||
| 		return; | ||||
| 
 | ||||
| 	// Something went wrong
 | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 Sort Failed"); | ||||
| 	Debugprintf("INP3 Sort Failed"); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
|  | @ -880,8 +871,6 @@ VOID ProcessRTTMsg(struct ROUTE * Route, struct _L3MESSAGEBUFFER * Buff, int Len | |||
| { | ||||
| 	int OtherRTT; | ||||
| 	int Dummy; | ||||
| 	char * ptr; | ||||
| 	struct _RTTMSG * RTTMsg = (struct _RTTMSG *)&Buff->L4DATA[0]; | ||||
| 
 | ||||
| 	char Normcall[10]; | ||||
| 
 | ||||
|  | @ -896,40 +885,20 @@ VOID ProcessRTTMsg(struct ROUTE * Route, struct _L3MESSAGEBUFFER * Buff, int Len | |||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	if (Route->NEIGHBOUR_LINK->LINKPORT->ALLOWINP3 || Route->NEIGHBOUR_LINK->LINKPORT->ENABLEINP3) | ||||
| 	if (Route->NEIGHBOUR_LINK->LINKPORT->ALLOWINP3) | ||||
| 		Route->INP3Node = 1; | ||||
| 
 | ||||
| 	if (Route->INP3Node == 0) | ||||
| 	{ | ||||
| 		if (DEBUGINP3) Debugprintf("Ignoring RTT Msg from %s - not using INP3", Normcall); | ||||
| 		Debugprintf("Ignoring RTT Msg from %s - not using INP3", Normcall); | ||||
| 		ReleaseBuffer(Buff); | ||||
| 		return;						// We don't want to use INP3
 | ||||
| 	} | ||||
| 
 | ||||
| 	// Extract other end's SRTT
 | ||||
| 
 | ||||
| 	// Get SWVERSION to see if other end is old (Buggy) BPQ
 | ||||
| 
 | ||||
| 	if (memcmp(RTTMsg->SWVERSION, "BPQ32001 ", 9) == 0) | ||||
| 		Route->OldBPQ = 1; | ||||
| 	else | ||||
| 		Route->OldBPQ = 0; | ||||
| 
 | ||||
| 	sscanf(&Buff->L4DATA[6], "%d %d", &Dummy, &OtherRTT); | ||||
| 
 | ||||
| 	Route->NeighbourSRTT = OtherRTT; | ||||
| 
 | ||||
| 	// Look for $M and $H (MAXRTT MAXHOPS)
 | ||||
| 
 | ||||
| 	ptr = strstr(RTTMsg->FLAGS, "$M"); | ||||
| 
 | ||||
| 	if (ptr) | ||||
| 		Route->RemoteMAXRTT = atoi(ptr + 2); | ||||
| 
 | ||||
| 	ptr = strstr(RTTMsg->FLAGS, "$H"); | ||||
| 
 | ||||
| 	if (ptr) | ||||
| 		Route->RemoteMAXHOPS = atoi(ptr + 2); | ||||
| 	Route->NeighbourSRTT = OtherRTT * 10;  // We store in mS
 | ||||
| 
 | ||||
| 	// Echo Back to sender
 | ||||
| 
 | ||||
|  | @ -939,8 +908,20 @@ VOID ProcessRTTMsg(struct ROUTE * Route, struct _L3MESSAGEBUFFER * Buff, int Len | |||
| 	{ | ||||
| 		// Link is just starting
 | ||||
| 
 | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 Processing first RTT frame from %s - link is (re)starting", Normcall); | ||||
| 		Debugprintf("INP3 Processing first RTT frame from %s - link is (re)starting", Normcall); | ||||
| 		Route->Status |= GotRTTRequest; | ||||
| 
 | ||||
| 		// I don't think we should send RIF until we get an RTT response.
 | ||||
| 
 | ||||
| 		if ((Route->Status & SentRTTRequest) == 0)			// Not sent one yet so send it
 | ||||
| 			SendRTTMsg(Route); | ||||
| 
 | ||||
| 		// No, it's the other end that must have an rrt response and we've just sent it
 | ||||
| 
 | ||||
| 		Route->Status |= SentOurRIF;	 | ||||
| 		SendOurRIF(Route); | ||||
| 		SendRIPToNeighbour(Route); | ||||
| 
 | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | @ -950,8 +931,6 @@ VOID SendRTTMsg(struct ROUTE * Route) | |||
| 	struct _L3MESSAGEBUFFER * Msg; | ||||
| 	char Stamp[50]; | ||||
| 	char Normcall[10]; | ||||
| 	unsigned char temp[256]; | ||||
| 	uint64_t sendTime; | ||||
| 
 | ||||
| 	Normcall[ConvFromAX25(Route->NEIGHBOUR_CALL, Normcall)] = 0; | ||||
| 
 | ||||
|  | @ -971,25 +950,13 @@ VOID SendRTTMsg(struct ROUTE * Route) | |||
| 	Msg->L4TXNO = 0; | ||||
| 	Msg->L4FLAGS = L4INFO; | ||||
| 
 | ||||
| 	// The timestamp can possibly exceed 10 digits. INP3 only works on differece between send and received, so base can be reset safely.
 | ||||
| 
 | ||||
| 	sendTime = ((uint64_t)GetTickCount() - INP3timeLoadedMS) / 10;	// 10mS units
 | ||||
| 
 | ||||
| 	if (sendTime > 9999999999) | ||||
| 		sendTime = INP3timeLoadedMS = 0; | ||||
| 
 | ||||
| 	sprintf(Stamp, "%10llu %10d %10d %10d ", sendTime, Route->SRTT, Route->RTT, 0); | ||||
| 
 | ||||
| 	sprintf(Stamp, "%10llu %10d %10d %10d ", (GetTickCount() - timeLoadedMS), Route->SRTT/10, Route->RTT/10, 0); | ||||
| 	memcpy(RTTMsg.TXTIME, Stamp, 44); | ||||
| 
 | ||||
| 	// We now allow MAXRTT and MAXHOPS to be reconfigured so should update header each time
 | ||||
| 
 | ||||
| 	sprintf(temp, "$M%d $N $H%d            ", MAXRTT, MaxHops); // trailing spaces extend to ensure padding if the length of characters for MAXRTT changes.
 | ||||
| 	memcpy(RTTMsg.FLAGS, temp, 20);                 // But still limit the actual characters copied.
 | ||||
| 
 | ||||
| 	memcpy(Msg->L4DATA, &RTTMsg, 236); | ||||
| 
 | ||||
| 	Msg->LENGTH = 256 + 1 + MSGHDDRLEN; | ||||
| 	Msg->LENGTH = 256 + 1 + 7; | ||||
| 
 | ||||
| 	Route->Timeout = RTTTimeout; | ||||
| 
 | ||||
|  | @ -1000,7 +967,7 @@ VOID SendRTTMsg(struct ROUTE * Route) | |||
| 
 | ||||
| 	Route->Status |= SentRTTRequest;	 | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 Sending first RTT Msg to %s", Normcall); | ||||
| 	Debugprintf("INP3 Sending first RTT Msg to %s", Normcall); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
|  | @ -1064,13 +1031,12 @@ int BuildRIF(UCHAR * RIF, UCHAR * Call, UCHAR * Alias, int Hops, int RTT) | |||
| 		RIF[12+AliasLen] = 0; | ||||
| 
 | ||||
| 		RIFLen = 13 + AliasLen; | ||||
| 		if (DEBUGINP3) Debugprintf("INP3 sending RIF Entry %s:%s %d %d", AliasCopy, Normcall, Hops, RTT); | ||||
| 		Debugprintf("INP3 sending RIF Entry %s:%s %d %d", AliasCopy, Normcall, Hops, RTT); | ||||
| 		return RIFLen; | ||||
| 	} | ||||
| 
 | ||||
| 	RIF[10] = 0; | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 sending RIF Entry %s %d %d", Normcall, Hops, RTT); | ||||
| 	Debugprintf("INP3 sending RIF Entry %s %d %d", Normcall, Hops, RTT); | ||||
| 	 | ||||
| 	return (11); | ||||
| } | ||||
|  | @ -1091,18 +1057,14 @@ VOID SendOurRIF(struct ROUTE * Route) | |||
| 
 | ||||
| 
 | ||||
| 	Normcall[ConvFromAX25(Route->NEIGHBOUR_LINK->LINKCALL, Normcall)] = 0; | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 Sending Initial RIF to %s ", Normcall); | ||||
| 	Debugprintf("INP3 Sending Initial RIF to %s ", Normcall); | ||||
| 
 | ||||
| 
 | ||||
| 	Msg->L3SRCE[0] = 0xff; | ||||
| 
 | ||||
| 	// send a RIF for our Node and all our APPLCalls
 | ||||
| 
 | ||||
| 	if (Route->OldBPQ) | ||||
| 		RIFLen = BuildRIF(&Msg->L3SRCE[totLen], MYCALL, MYALIASTEXT, 1, Route->RTTIncrement * 10); | ||||
| 	else | ||||
| 		RIFLen = BuildRIF(&Msg->L3SRCE[totLen], MYCALL, MYALIASTEXT, 1, Route->RTTIncrement); | ||||
| 
 | ||||
| 	RIFLen = BuildRIF(&Msg->L3SRCE[totLen], MYCALL, MYALIASTEXT, 1, 0); | ||||
| 	totLen += RIFLen; | ||||
| 
 | ||||
| 	for (App = 0; App < NumberofAppls; App++) | ||||
|  | @ -1111,11 +1073,7 @@ VOID SendOurRIF(struct ROUTE * Route) | |||
| 
 | ||||
| 		if (APPL->APPLQUAL > 0) | ||||
| 		{ | ||||
| 			if (Route->OldBPQ) | ||||
| 				RIFLen = BuildRIF(&Msg->L3SRCE[totLen], APPL->APPLCALL, APPL->APPLALIAS_TEXT, 1, Route->RTTIncrement * 10); | ||||
| 			else | ||||
| 				RIFLen = BuildRIF(&Msg->L3SRCE[totLen], APPL->APPLCALL, APPL->APPLALIAS_TEXT, 1, Route->RTTIncrement); | ||||
| 			 | ||||
| 			RIFLen = BuildRIF(&Msg->L3SRCE[totLen], APPL->APPLCALL, APPL->APPLALIAS_TEXT, 1, 0); | ||||
| 			totLen += RIFLen; | ||||
| 		} | ||||
| 	} | ||||
|  | @ -1173,10 +1131,11 @@ int SendRIPTimer() | |||
| 				else | ||||
| 					INP3Delay = 600; | ||||
|   | ||||
| 				if (Route->LastConnectAttempt && (REALTIMETICKS - Route->LastConnectAttempt) < INP3Delay)  | ||||
| 				if (Route->LastConnectAttempt && | ||||
| 					(REALTIMETICKS - Route->LastConnectAttempt) < INP3Delay)  | ||||
| 				{ | ||||
| 					Route++; | ||||
| 					continue;		// Not yet
 | ||||
| 					continue;						// No room for link
 | ||||
| 				} | ||||
| 
 | ||||
| 				// Try to activate link
 | ||||
|  | @ -1184,7 +1143,7 @@ int SendRIPTimer() | |||
| 				if (Route->INP3Node) | ||||
| 				{ | ||||
| 					Normcall[ConvFromAX25(Route->NEIGHBOUR_CALL, Normcall)] = 0; | ||||
| 					if (DEBUGINP3) Debugprintf("INP3 Activating link to %s", Normcall); | ||||
| 					Debugprintf("INP3 Activating link to %s", Normcall); | ||||
| 				} | ||||
| 
 | ||||
| 				L2SETUPCROSSLINKEX(Route, 2);		// Only try SABM twice
 | ||||
|  | @ -1248,7 +1207,7 @@ int SendRIPTimer() | |||
| 							char Call [11] = ""; | ||||
| 
 | ||||
| 							ConvFromAX25(Route->NEIGHBOUR_CALL, Call); | ||||
| 							if (DEBUGINP3) Debugprintf("BPQ32 INP3 Neighbour %s Lost", Call); | ||||
| 							Debugprintf("BPQ32 INP3 Neighbour %s Lost", Call); | ||||
| 
 | ||||
| 							Route->Status = 0;	// Down
 | ||||
| 						} | ||||
|  | @ -1263,7 +1222,7 @@ int SendRIPTimer() | |||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					Route->BCTimer = RTTInterval + rand() % 4; | ||||
| 					Route->BCTimer = RTTInterval; | ||||
| 					Route->Retries = RTTRetries; | ||||
| 					SendRTTMsg(Route); | ||||
| 				} | ||||
|  | @ -1302,7 +1261,7 @@ VOID SendRIF(struct ROUTE * Route, struct _L3MESSAGEBUFFER * Msg) | |||
| 
 | ||||
| 	Msg->LENGTH += MSGHDDRLEN + 1;		// PID
 | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("Sending INP3 RIF length %d to %s", Msg->LENGTH, Normcall); | ||||
| 	Debugprintf("Sending INP3 RIF length %d to %s", Msg->LENGTH, Normcall); | ||||
| 	SendNetFrame(Route, Msg); | ||||
| } | ||||
| 
 | ||||
|  | @ -1312,11 +1271,10 @@ VOID SendRIPToOtherNeighbours(UCHAR * axcall, UCHAR * alias, struct INP3_DEST_RO | |||
| 	struct _L3MESSAGEBUFFER * Msg; | ||||
| 	int count, MaxRoutes = MAXNEIGHBOURS; | ||||
| 	char Normcall[10]; | ||||
| 	int sendHops, sendTT; | ||||
| 
 | ||||
| 	Normcall[ConvFromAX25(axcall, Normcall)] = 0; | ||||
| 
 | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 SendRIPToOtherNeighbours for %s", Normcall); | ||||
| 	Debugprintf("INP3 SendRIPToOtherNeighbours for %s", Normcall); | ||||
| 
 | ||||
| 	for (count=0; count<MaxRoutes; count++) | ||||
| 	{ | ||||
|  | @ -1324,42 +1282,29 @@ VOID SendRIPToOtherNeighbours(UCHAR * axcall, UCHAR * alias, struct INP3_DEST_RO | |||
| 			(Routes->Status) &&  | ||||
| 			(Routes != Entry->ROUT_NEIGHBOUR))	// Dont send to originator of route
 | ||||
| 		{ | ||||
| 			sendHops = Entry->Hops + 1; | ||||
| 			sendTT = Entry->SRTT +  Entry->ROUT_NEIGHBOUR->RTTIncrement; | ||||
| 
 | ||||
| 		// send, but only if within their constraints
 | ||||
| 
 | ||||
| 			if ((Routes->RemoteMAXHOPS == 0 || Routes->RemoteMAXHOPS >= Entry->Hops) &&  | ||||
| 				(Routes->RemoteMAXRTT == 0 || Routes->RemoteMAXRTT >= Entry->SRTT  || Entry->SRTT == 60000)) | ||||
| 			{ | ||||
| 
 | ||||
| 			Msg = Routes->Msg; | ||||
| 			 | ||||
| 			if (Msg == NULL)  | ||||
| 			{ | ||||
| 				Normcall[ConvFromAX25(Routes->NEIGHBOUR_CALL, Normcall)] = 0; | ||||
| 					if (DEBUGINP3) Debugprintf("INP3 Building RIF to send to %s", Normcall); | ||||
| 				Debugprintf("INP3 Building RIF to send to %s", Normcall); | ||||
| 				Msg = Routes->Msg = CreateRIFHeader(Routes); | ||||
| 			} | ||||
| 
 | ||||
| 			if (Msg) | ||||
| 			{ | ||||
| 					if (Routes->OldBPQ) | ||||
| 
 | ||||
| 				Msg->LENGTH += BuildRIF(&Msg->L3SRCE[Msg->LENGTH], | ||||
| 							axcall, alias, sendHops, sendTT + 10); | ||||
| 					else | ||||
| 						Msg->LENGTH += BuildRIF(&Msg->L3SRCE[Msg->LENGTH], | ||||
| 							axcall, alias, sendHops, sendTT); | ||||
| 					axcall, alias, Entry->Hops + 1, Entry->SRTT + Entry->ROUT_NEIGHBOUR->SRTT/10); | ||||
| 
 | ||||
| 				if (Msg->LENGTH > 250 - 15) | ||||
| 						//				if (Msg->LENGTH > Routes->NBOUR_PACLEN - 11)
 | ||||
| //				if (Msg->LENGTH > Routes->NBOUR_PACLEN - 11)
 | ||||
| 				{ | ||||
| 					SendRIF(Routes, Msg); | ||||
| 					Routes->Msg = NULL; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		} | ||||
| 		Routes+=1; | ||||
| 	} | ||||
| } | ||||
|  | @ -1370,12 +1315,11 @@ VOID SendRIPToNeighbour(struct ROUTE * Route) | |||
| 	struct DEST_LIST * Dest =  DESTS; | ||||
| 	struct INP3_DEST_ROUTE_ENTRY * Entry; | ||||
| 	struct _L3MESSAGEBUFFER * Msg; | ||||
| 	int sendHops, sendTT; | ||||
| 
 | ||||
| 	char Normcall[10]; | ||||
| 
 | ||||
| 	Normcall[ConvFromAX25(Route->NEIGHBOUR_LINK->LINKCALL, Normcall)] = 0; | ||||
| 	if (DEBUGINP3) Debugprintf("INP3 Sending Our Table to %s ", Normcall); | ||||
| 	Debugprintf("INP3 Sending Our Table to %s ", Normcall); | ||||
| 
 | ||||
| 	Dest--; | ||||
| 
 | ||||
|  | @ -1387,17 +1331,10 @@ VOID SendRIPToNeighbour(struct ROUTE * Route) | |||
| 
 | ||||
| 		Entry = &Dest->INP3ROUTE[0]; | ||||
| 
 | ||||
| 
 | ||||
| 		if (Entry->ROUT_NEIGHBOUR && Entry->Hops && Route != Entry->ROUT_NEIGHBOUR)	 | ||||
| 		{ | ||||
| 			// Best Route not via this neighbour - send, but only if within their constraints
 | ||||
| 			// Best Route not via this neighbour - send
 | ||||
| 		 | ||||
| 			sendHops = Entry->Hops + 1; | ||||
| 			sendTT = Entry->SRTT +  Entry->ROUT_NEIGHBOUR->RTTIncrement; | ||||
| 
 | ||||
| 			if ((Route->RemoteMAXHOPS == 0 || Route->RemoteMAXHOPS >= Entry->Hops) &&  | ||||
| 				(Route->RemoteMAXRTT == 0 || Route->RemoteMAXRTT >= Entry->SRTT || Entry->SRTT == 60000)) | ||||
| 			{ | ||||
| 			Msg = Route->Msg; | ||||
| 			 | ||||
| 			if (Msg == NULL)  | ||||
|  | @ -1406,10 +1343,9 @@ VOID SendRIPToNeighbour(struct ROUTE * Route) | |||
| 			if (Msg == NULL)  | ||||
| 				return; | ||||
| 				 | ||||
| 				if (Route->OldBPQ) | ||||
| 					Msg->LENGTH += BuildRIF(&Msg->L3SRCE[Msg->LENGTH], Dest->DEST_CALL, Dest->DEST_ALIAS, sendHops, sendTT * 10);	// old bpq bug - send mS not 10 mS units
 | ||||
| 				else | ||||
| 					Msg->LENGTH += BuildRIF(&Msg->L3SRCE[Msg->LENGTH], Dest->DEST_CALL, Dest->DEST_ALIAS, sendHops, sendTT); | ||||
| 			Msg->LENGTH += BuildRIF(&Msg->L3SRCE[Msg->LENGTH], | ||||
| 				Dest->DEST_CALL, Dest->DEST_ALIAS, | ||||
| 				Entry->Hops + 1, Entry->SRTT + Entry->ROUT_NEIGHBOUR->SRTT/10); | ||||
| 
 | ||||
| 			if (Msg->LENGTH > 250 - 15) | ||||
| 			{ | ||||
|  | @ -1418,7 +1354,6 @@ VOID SendRIPToNeighbour(struct ROUTE * Route) | |||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	} | ||||
| 	if (Route->Msg) | ||||
| 	{ | ||||
| 		SendRIF(Route, Route->Msg); | ||||
|  | @ -1433,15 +1368,6 @@ VOID FlushRIFs() | |||
| 
 | ||||
| 	for (count=0; count<MaxRoutes; count++) | ||||
| 	{ | ||||
| 		// Make sure we've sent our local calls
 | ||||
| 
 | ||||
| 		if ((Routes->Status & GotRTTRequest) && (Routes->Status & GotRTTResponse) && ((Routes->Status & SentOurRIF) == 0)) | ||||
| 		{	 | ||||
| 			Routes->Status |= SentOurRIF; | ||||
| 			SendOurRIF(Routes); | ||||
| 			SendRIPToNeighbour(Routes); | ||||
| 		} | ||||
| 		 | ||||
| 		if (Routes->Msg) | ||||
| 		{ | ||||
| 			char Normcall[10]; | ||||
|  | @ -1449,7 +1375,7 @@ VOID FlushRIFs() | |||
| 			Normcall[ConvFromAX25(Routes->NEIGHBOUR_CALL, Normcall)] = 0; | ||||
| 			SendRIF(Routes, Routes->Msg); | ||||
| 			Routes->Msg = NULL; | ||||
| 			if (DEBUGINP3) Debugprintf("INP3 Flushing RIF to  %s", Normcall);  | ||||
| 			Debugprintf("INP3 Flushing RIF to  %s", Normcall);  | ||||
| 		} | ||||
| 		Routes+=1; | ||||
| 	} | ||||
|  | @ -1500,7 +1426,7 @@ VOID SendNegativeInfo() | |||
| 			{ | ||||
| 				char call[11]=""; | ||||
| 				ConvFromAX25(Dest->DEST_CALL, call); | ||||
| 				if (DEBUGINP3) Debugprintf("INP3 Deleting Node %s", call); | ||||
| 				Debugprintf("INP3 Deleting Node %s", call); | ||||
| 				REMOVENODE(Dest);			// Clear buffers, Remove from Sorted Nodes chain, and zap entry	
 | ||||
| 			} | ||||
| 			else | ||||
|  | @ -1659,9 +1585,7 @@ UCHAR * DisplayINP3RIF(UCHAR * ptr1, UCHAR * ptr2, unsigned int msglen) | |||
| 
 | ||||
| 		msglen -= 10; | ||||
| 
 | ||||
| 		// Process optional fields
 | ||||
| 
 | ||||
| 		while (*ptr1 && msglen > 0)			//  Have an option
 | ||||
| 		while (*ptr1 && msglen > 0) | ||||
| 		{ | ||||
| 			len = *ptr1; | ||||
| 			opcode = *(ptr1+1); | ||||
|  | @ -1675,20 +1599,18 @@ UCHAR * DisplayINP3RIF(UCHAR * ptr1, UCHAR * ptr2, unsigned int msglen) | |||
| 			{ | ||||
| 				memcpy(&alias[6 - (len - 2)], ptr1+2, len-2);		// Right Justiify
 | ||||
| 			} | ||||
| 			else if (opcode == 1 && len < 8) | ||||
| 			else | ||||
| 				if (opcode == 1 && len < 8) | ||||
| 				{ | ||||
| 					memcpy(IP, ptr1+2, len-2); | ||||
| 				} | ||||
| 
 | ||||
| 			ptr1 += len; | ||||
| 			msglen -= len; | ||||
| 		} | ||||
| 
 | ||||
| 				ptr2+=sprintf(ptr2, " %s:%s %d %4.2d\r", alias, call, hops, rtt); | ||||
| 
 | ||||
| 				ptr1++; | ||||
| 		msglen--;		// Over EOP
 | ||||
| 				msglen--;		// EOP
 | ||||
| 		} | ||||
| 
 | ||||
| 		return ptr2; | ||||
| 	} | ||||
| 	return ptr2; | ||||
| } | ||||
|  |  | |||
							
								
								
									
										
											BIN
										
									
								
								BPQMail.aps
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								BPQMail.aps
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										6
									
								
								BPQNRR.c
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								BPQNRR.c
									
									
									
									
									
								
							|  | @ -45,8 +45,6 @@ extern VOID Q_ADD(); | |||
| VOID __cdecl Debugprintf(const char * format, ...); | ||||
| 
 | ||||
| TRANSPORTENTRY * NRRSession; | ||||
| time_t NRRTime; | ||||
| 
 | ||||
| 
 | ||||
| /*
 | ||||
| datagrams (and other things) to be transported in Netrom L3 frames.  | ||||
|  | @ -78,7 +76,6 @@ VOID NRRecordRoute(UCHAR * Buff, int Len) | |||
| 		UCHAR * BUFFER = GetBuff(); | ||||
| 		UCHAR * ptr1; | ||||
| 		struct _MESSAGE * Msg; | ||||
| 		time_t Now = time(NULL); | ||||
| 
 | ||||
| 		if (BUFFER == NULL) | ||||
| 			return; | ||||
|  | @ -87,7 +84,7 @@ VOID NRRecordRoute(UCHAR * Buff, int Len) | |||
| 		 | ||||
| 		*ptr1++ = 0xf0;			// PID
 | ||||
| 
 | ||||
| 		ptr1 += sprintf(ptr1, "NRR Response in (probably) %d Secs :", (int)(Now - NRRTime)); | ||||
| 		ptr1 += sprintf(ptr1, "NRR Response:"); | ||||
| 
 | ||||
| 		Buff += 21 + MSGHDDRLEN; | ||||
| 		Len -= (21 + MSGHDDRLEN); | ||||
|  | @ -175,7 +172,6 @@ VOID SendNRRecordRoute(struct DEST_LIST * DEST, TRANSPORTENTRY * Session) | |||
| 		return; | ||||
| 
 | ||||
| 	NRRSession = Session;			// Save Session Pointer for reply
 | ||||
| 	NRRTime = time(NULL); | ||||
| 
 | ||||
| 	Msg->Port = 0; | ||||
| 	Msg->L3PID = NRPID; | ||||
|  |  | |||
							
								
								
									
										17
									
								
								Bpq32.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								Bpq32.c
									
									
									
									
									
								
							|  | @ -1180,7 +1180,7 @@ along with LinBPQ/BPQ32.  If not, see http://www.gnu.org/licenses | |||
| //	Fix processing of the Winlink API /account/exists response (82)
 | ||||
| //	Fix sending CTEXT to L4 connects to Node when FULL_CTEXT is not set
 | ||||
| 
 | ||||
| //  Version 6.0.25.1 Sept 2025
 | ||||
| //  Version 6.0.25.? 
 | ||||
| 
 | ||||
| //	Fix 64 bit compatibility problems in SCSTracker and UZ7HO drivers
 | ||||
| //	Add Chat PACLEN config (5)
 | ||||
|  | @ -1284,16 +1284,6 @@ along with LinBPQ/BPQ32.  If not, see http://www.gnu.org/licenses | |||
| //	Fix Webmail autorefresh extra threads problem (websock connection lost handling) (82)
 | ||||
| //	Fix overwriting application alias (83)
 | ||||
| 
 | ||||
| 
 | ||||
| //  Version 6.0.26.?
 | ||||
| 
 | ||||
| //	Fix for compiling with gcc15 (2)
 | ||||
| //	Fix possble stuck L2 session caused by window being set to zero (3)
 | ||||
| //	Improvments to INP3 (4, 5)
 | ||||
| //	Add Node API /api/tcpqueues (5)
 | ||||
| //	Add sending link events to OARC API (disabled by default) (6)
 | ||||
| 
 | ||||
| 
 | ||||
| #define CKernel | ||||
| 
 | ||||
| #include "Versions.h" | ||||
|  | @ -1455,7 +1445,6 @@ extern HWND hIPResWnd; | |||
| extern BOOL IPMinimized; | ||||
| 
 | ||||
| extern int	NODESINPROGRESS; | ||||
| extern int NODESToOnePort; | ||||
| extern VOID * CURRENTNODE; | ||||
| 
 | ||||
| 
 | ||||
|  | @ -1525,7 +1514,7 @@ extern char ReportDest[7]; | |||
| 
 | ||||
| extern UCHAR ConfigDirectory[260]; | ||||
| 
 | ||||
| extern uint64_t INP3timeLoadedMS; | ||||
| extern uint64_t timeLoadedMS; | ||||
| 
 | ||||
| VOID __cdecl Debugprintf(const char * format, ...); | ||||
| VOID __cdecl Consoleprintf(const char * format, ...); | ||||
|  | @ -2414,7 +2403,7 @@ FirstInit() | |||
| 		EnumProcessesPtr = (FARPROCX)GetProcAddress(ExtDriver,"EnumProcesses"); | ||||
| 	} | ||||
| 
 | ||||
| 	INP3timeLoadedMS = GetTickCount(); | ||||
| 	timeLoadedMS = GetTickCount(); | ||||
| 
 | ||||
| 	srand(time(NULL)); | ||||
| 	 | ||||
|  |  | |||
							
								
								
									
										139
									
								
								Cmd.c
									
									
									
									
									
								
							
							
						
						
									
										139
									
								
								Cmd.c
									
									
									
									
									
								
							|  | @ -73,7 +73,7 @@ int seeifInterlockneeded(struct PORTCONTROL * PORT); | |||
| int CompareNode(const void *a, const void *b); | ||||
| int CompareAlias(const void *a, const void *b); | ||||
| int CompareRoutes(const void * a, const void * b); | ||||
| void SendVARANetromNodes(struct TNCINFO * TNC, MESSAGE *Buffer); | ||||
| 
 | ||||
| 
 | ||||
| extern VOID KISSTX(struct KISSINFO * KISS, PMESSAGE Buffer); | ||||
| 
 | ||||
|  | @ -86,7 +86,6 @@ UCHAR SAVEDAPPLFLAGS = 0; | |||
| 
 | ||||
| UCHAR ALIASINVOKED = 0; | ||||
| 
 | ||||
| extern int MONTOFILEFLAG; | ||||
| 
 | ||||
| VOID * CMDPTR = 0; | ||||
| 
 | ||||
|  | @ -156,15 +155,13 @@ char * ALIASPTR	= &CMDALIAS[0][0]; | |||
| 
 | ||||
| extern int RigReconfigFlag; | ||||
| 
 | ||||
| extern int DEBUGINP3; | ||||
| extern int PREFERINP3ROUTES; | ||||
| 
 | ||||
| 
 | ||||
| struct CMDX COMMANDS[]; | ||||
| 
 | ||||
| int CMDXLEN	= sizeof (struct CMDX); | ||||
| 
 | ||||
| VOID SENDNODESMSG(int Portnum); | ||||
| VOID SENDNODESMSG(); | ||||
| VOID KISSCMD(TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail, struct CMDX * CMD); | ||||
| VOID STOPCMS(TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail, struct CMDX * CMD); | ||||
| VOID STARTCMS(TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail, struct CMDX * CMD); | ||||
|  | @ -252,81 +249,10 @@ char * __cdecl Cmdprintf(TRANSPORTENTRY * Session, char * Bufferptr, const char | |||
| 	return Bufferptr + MsgLen; | ||||
| } | ||||
| 
 | ||||
| VOID POLLNODES(TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail, struct CMDX * CMD) | ||||
| { | ||||
| 	int Portnum = atoi(CmdTail); | ||||
| 	struct PORTCONTROL * PORT = 0; | ||||
| 	MESSAGE * Buffer; | ||||
| 	UCHAR * ptr1; | ||||
| 
 | ||||
| 	if (Portnum) | ||||
| 		PORT = GetPortTableEntryFromPortNum(Portnum); | ||||
| 		 | ||||
| 	if (Portnum == 0 || PORT == 0) | ||||
| 	{ | ||||
| 		Bufferptr = Cmdprintf(Session, Bufferptr, "Invalid Port\r");			 | ||||
| 		SendCommandReply(Session, REPLYBUFFER, (int)(Bufferptr - (char *)REPLYBUFFER)); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	if (PORT->PORTQUALITY == 0 || PORT->INP3ONLY) | ||||
| 	{ | ||||
| 		Bufferptr = Cmdprintf(Session, Bufferptr, "Quality = 0 or INP3 Port\r");			 | ||||
| 		SendCommandReply(Session, REPLYBUFFER, (int)(Bufferptr - (char *)REPLYBUFFER)); | ||||
| 		return; | ||||
| 	} | ||||
| 	Buffer = GetBuff(); | ||||
| 
 | ||||
| 	if (Buffer == 0) | ||||
| 		return; | ||||
| 
 | ||||
| 	Buffer->PORT = Portnum; | ||||
| 
 | ||||
| 	memcpy(Buffer->ORIGIN, NETROMCALL, 7); | ||||
| 	memcpy(Buffer->DEST, NODECALL, 7); | ||||
| 
 | ||||
| 	Buffer->ORIGIN[6] |= 0x61;		// SET CMD END AND RESERVED BITS
 | ||||
| 
 | ||||
| 	Buffer->CTL = UI; | ||||
| 	Buffer->PID = 0xCF;				// Netrom
 | ||||
| 
 | ||||
| 	ptr1 = &Buffer->L2DATA[0]; | ||||
| 	 | ||||
| 	*(ptr1++) = 0xfe;				// Nodes Poll Flag
 | ||||
| 
 | ||||
| 	memcpy(ptr1, MYALIASTEXT, 6); | ||||
| 
 | ||||
| 	ptr1+= 6; | ||||
| 
 | ||||
| 	Buffer->LENGTH = (int)(ptr1 - (UCHAR *)Buffer); | ||||
| 
 | ||||
| 	if (PORT->TNC && PORT->TNC->Hardware == H_VARA) | ||||
| 		SendVARANetromNodes(PORT->TNC, Buffer); | ||||
| 	else | ||||
| 		PUT_ON_PORT_Q(PORT, Buffer); | ||||
| 
 | ||||
| 	strcpy(Bufferptr, OKMSG); | ||||
| 	Bufferptr += (int)strlen(OKMSG); | ||||
| 						 | ||||
| 	SendCommandReply(Session, REPLYBUFFER, (int)(Bufferptr - (char *)REPLYBUFFER)); | ||||
| } | ||||
| VOID SENDNODES(TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail, struct CMDX * CMD) | ||||
| { | ||||
| 	int Portnum = atoi(CmdTail); | ||||
| 	struct PORTCONTROL * PORT; | ||||
| 
 | ||||
| 	if (Portnum) | ||||
| 	{ | ||||
| 		PORT = GetPortTableEntryFromPortNum(Portnum); | ||||
| 		if (PORT == 0) | ||||
| 		{ | ||||
| 			Bufferptr = Cmdprintf(Session, Bufferptr, "Invalid Port\r");			 | ||||
| 			SendCommandReply(Session, REPLYBUFFER, (int)(Bufferptr - (char *)REPLYBUFFER)); | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	SENDNODESMSG(Portnum); | ||||
| 	SENDNODESMSG(); | ||||
| 
 | ||||
| 	strcpy(Bufferptr, OKMSG); | ||||
| 	Bufferptr += (int)strlen(OKMSG); | ||||
|  | @ -1374,17 +1300,6 @@ VOID CMDL00(TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail, struct C | |||
| 				else | ||||
| 					Bufferptr = Cmdprintf(Session, Bufferptr, " S=%d P=%d T=%d V=%d Q=%d\r", | ||||
| 					LINK->L2STATE, LINK->LINKPORT->PORTNUMBER, LINK->LINKTYPE, 2 - LINK->VER1FLAG, Count); | ||||
| 			 | ||||
| 				if (Count > 16 || LINK->LINKWINDOW == 0) | ||||
| 				{ | ||||
| 					// Dump Link State
 | ||||
| 
 | ||||
| 					int secs = time(NULL) - LINK->LASTFRAMESENT; | ||||
| 						 | ||||
| 					Bufferptr = Cmdprintf(Session, Bufferptr, "  Debug Info: LINK->LINKNS %d LINK->LINKOWS %d SDTSLOT %d LINKWINDOW %d L2FLAGS %d\r", LINK->LINKNS, LINK->LINKOWS, LINK->SDTSLOT, LINK->LINKWINDOW, LINK->L2FLAGS); | ||||
| 					Bufferptr = Cmdprintf(Session, Bufferptr, "  Debug Info: Slots %x %x %x %x %x %x %x %x\r", LINK->FRAMES[0], LINK->FRAMES[1], LINK->FRAMES[2], LINK->FRAMES[3], | ||||
| 					LINK->FRAMES[4], LINK->FRAMES[5], LINK->FRAMES[6], LINK->FRAMES[7]); | ||||
| 				} | ||||
| 			} | ||||
| 			LINK++; | ||||
| 		} | ||||
|  | @ -1707,8 +1622,8 @@ char *  DisplayRoute(TRANSPORTENTRY * Session, char * Bufferptr, struct ROUTE * | |||
| 
 | ||||
| 		if (Routes->INP3Node)		// INP3 Enabled?
 | ||||
| 		{ | ||||
| 			double srtt = Routes->SRTT/100.0; | ||||
| 			double nsrtt = Routes->NeighbourSRTT/100.0; | ||||
| 			double srtt = Routes->SRTT/1000.0; | ||||
| 			double nsrtt = Routes->NeighbourSRTT/1000.0; | ||||
| 
 | ||||
| 			Bufferptr = Cmdprintf(Session, Bufferptr, " %4.2fs %4.2fs", srtt, nsrtt); | ||||
| 		} | ||||
|  | @ -2254,32 +2169,6 @@ VOID DoNetromConnect(TRANSPORTENTRY * Session, char * Bufferptr, struct DEST_LIS | |||
| 	return; | ||||
| } | ||||
| 
 | ||||
| BOOL CheckLink(UCHAR * LinkCall, UCHAR * OurCall, int Port) | ||||
| { | ||||
| 	// Check if a link exists betwwn a pair of calls on a port. Return TRUE if found
 | ||||
| 
 | ||||
| 	struct _LINKTABLE * LINK = LINKS; | ||||
| 	int n = MAXLINKS; | ||||
| 
 | ||||
| 	while (n--) | ||||
| 	{ | ||||
| 		if (LINK->LINKCALL[0] == 0)		// Spare
 | ||||
| 		{		 | ||||
| 			LINK++; | ||||
| 			continue; | ||||
| 		} | ||||
| 
 | ||||
| 		if ((LINK->LINKPORT->PORTNUMBER == Port) && CompareCalls(LINK->LINKCALL, LinkCall) && CompareCalls(LINK->OURCALL, OurCall)) | ||||
| 			return TRUE; | ||||
| 
 | ||||
| 		LINK++; | ||||
| 	} | ||||
| 
 | ||||
| 	//	ENTRY NOT FOUND 
 | ||||
| 
 | ||||
| 	return FALSE; | ||||
| } | ||||
| 
 | ||||
| BOOL FindLink(UCHAR * LinkCall, UCHAR * OurCall, int Port, struct _LINKTABLE ** REQLINK) | ||||
| { | ||||
| 	struct _LINKTABLE * LINK = LINKS; | ||||
|  | @ -2305,7 +2194,6 @@ BOOL FindLink(UCHAR * LinkCall, UCHAR * OurCall, int Port, struct _LINKTABLE ** | |||
| 
 | ||||
| 		LINK++; | ||||
| 	} | ||||
| 
 | ||||
| 	//	ENTRY NOT FOUND - FIRSTSPARE HAS FIRST FREE ENTRY, OR ZERO IF TABLE FULL
 | ||||
| 
 | ||||
| 	*REQLINK = FIRSTSPARE; | ||||
|  | @ -2500,9 +2388,6 @@ NoPort: | |||
| 
 | ||||
| 					//	Convert to an APPL command, so any alias is actioned
 | ||||
| 
 | ||||
| 					memcpy(Session->APPL,APPL->APPLCMD, 12); | ||||
| 
 | ||||
| 
 | ||||
| 					//	SEE IF THERE IS AN ALIAS DEFINDED FOR THIS COMMAND
 | ||||
| 
 | ||||
| 					if (APPL->APPLHASALIAS && APPL->APPLALIASVAL[0] != 0x20) | ||||
|  | @ -3054,7 +2939,7 @@ char * DoOneNode(TRANSPORTENTRY * Session, char * Bufferptr, struct DEST_LIST * | |||
| 
 | ||||
| 		if (Neighbour) | ||||
| 		{ | ||||
| 			double srtt = Route->SRTT/100.0; | ||||
| 			double srtt = Route->SRTT/1000.0; | ||||
| 
 | ||||
| 			len = ConvFromAX25(Neighbour->NEIGHBOUR_CALL, Normcall); | ||||
| 			Normcall[len] = 0; | ||||
|  | @ -3103,7 +2988,7 @@ int DoINP3ViaEntry(struct DEST_LIST * Dest, int n, char * line, int cursor) | |||
| 
 | ||||
| 	if (Dest->INP3ROUTE[n].ROUT_NEIGHBOUR != 0) | ||||
| 	{ | ||||
| 		srtt = Dest->INP3ROUTE[n].SRTT/100.0; | ||||
| 		srtt = Dest->INP3ROUTE[n].SRTT/1000.0; | ||||
| 
 | ||||
| 		len=ConvFromAX25(Dest->INP3ROUTE[n].ROUT_NEIGHBOUR->NEIGHBOUR_CALL, Portcall); | ||||
| 		Portcall[len]=0; | ||||
|  | @ -4373,7 +4258,6 @@ struct CMDX COMMANDS[] = | |||
| 	"RIGRECONFIG ",8, &RIGRECONFIG, 0, | ||||
| 	"RESTART     ",7, &RESTART,0, | ||||
| 	"RESTARTTNC  ",10,&RESTARTTNC,0, | ||||
| 	"POLLNODES   ",8, &POLLNODES,0, | ||||
| 	"SENDNODES   ",8, &SENDNODES,0, | ||||
| 	"EXTRESTART  ",10, EXTPORTVAL, offsetof(EXTPORTDATA, EXTRESTART), | ||||
| 	"TXDELAY     ",3, PORTVAL, offsetof(PORTCONTROLX, PORTTXDELAY), | ||||
|  | @ -4391,10 +4275,6 @@ struct CMDX COMMANDS[] = | |||
| 	"MAXUSERS    ",4,PORTVAL, offsetof(PORTCONTROLX, USERS), | ||||
| 	"L3ONLY      ",6,PORTVAL, offsetof(PORTCONTROLX, PORTL3FLAG), | ||||
| 	"BBSALIAS    ",4,PORTVAL, offsetof(PORTCONTROLX, PORTBBSFLAG), | ||||
| 	"INP3ONLY    ",8,PORTVAL, offsetof(PORTCONTROLX, INP3ONLY), | ||||
| 	"ALLOWINP3   ",9,PORTVAL, offsetof(PORTCONTROLX, ALLOWINP3), | ||||
| 	"ENABLEINP3  ",10,PORTVAL, offsetof(PORTCONTROLX, ENABLEINP3), | ||||
| 	"MONTOFILE   ",9,SWITCHVAL,(size_t)&MONTOFILEFLAG, | ||||
| 	"VALIDCALLS  ",5,VALNODES,0, | ||||
| 	"WL2KSYSOP   ",5,WL2KSYSOP,0, | ||||
| 	"STOPPORT    ",4,STOPPORT,0, | ||||
|  | @ -4406,7 +4286,6 @@ struct CMDX COMMANDS[] = | |||
| 	"KISS        ",4,KISSCMD,0, | ||||
| 	"GETPORTCTEXT",9,GetPortCTEXT, 0, | ||||
| 
 | ||||
| 
 | ||||
| #ifdef EXCLUDEBITS | ||||
| 
 | ||||
| 	"EXCLUDE     ",4,ListExcludedCalls,0, | ||||
|  | @ -4431,10 +4310,6 @@ struct CMDX COMMANDS[] = | |||
| 	"L4DELAY     ",7,SWITCHVAL,(size_t)&L4DELAY, | ||||
| 	"L4WINDOW    ",6,SWITCHVAL,(size_t)&L4DEFAULTWINDOW, | ||||
| 	"BTINTERVAL  ",5,SWITCHVAL,(size_t)&BTINTERVAL, | ||||
| 	"DEBUGINP3   ",8,SWITCHVAL,(size_t)&DEBUGINP3, | ||||
| 	"MAXHOPS     ",7,SWITCHVAL,(size_t)&MaxHops, | ||||
| 	"PREFERINP3  ",10,SWITCHVAL,(size_t)&PREFERINP3ROUTES, | ||||
| 	"MAXRTT      ",6,SWITCHVALW,(size_t)&MAXRTT, | ||||
| 	"PASSWORD    ", 8, PWDCMD, 0, | ||||
| 
 | ||||
| 	"************", 12, APPLCMD, 0, | ||||
|  |  | |||
							
								
								
									
										29
									
								
								CommonCode.c
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								CommonCode.c
									
									
									
									
									
								
							|  | @ -79,7 +79,6 @@ extern VOID * ENDBUFFERPOOL; | |||
| 
 | ||||
| extern int PoolBuilt; | ||||
| 
 | ||||
| extern int EnableOARCAPI; | ||||
| 
 | ||||
| //	Read/Write length field in a buffer header
 | ||||
| 
 | ||||
|  | @ -3314,12 +3313,8 @@ SOCKADDR_IN reportdest = {0}; | |||
| 
 | ||||
| SOCKET ReportSocket = 0; | ||||
| 
 | ||||
| SOCKET NodeAPISocket = 0 ; | ||||
| 
 | ||||
| SOCKADDR_IN Chatreportdest = {0}; | ||||
| 
 | ||||
| SOCKADDR_IN UDPreportdest = {0}; | ||||
| 
 | ||||
| extern char LOCATOR[];			// Locator for Reporting - may be Maidenhead or LAT:LON
 | ||||
| extern char MAPCOMMENT[];		// Locator for Reporting - may be Maidenhead or LAT:LON
 | ||||
| extern char LOC[7];				// Maidenhead Locator for Reporting
 | ||||
|  | @ -3675,16 +3670,11 @@ pthread_t ResolveUpdateThreadId = 0; | |||
| 
 | ||||
| char NodeMapServer[80] = "update.g8bpq.net"; | ||||
| char ChatMapServer[80] = "chatupdate.g8bpq.net"; | ||||
| char NodeAPIServer[80] = "node-api.packet.oarc.uk"; | ||||
| 
 | ||||
| int NodeAPIPort = 13579; | ||||
| 
 | ||||
| VOID ResolveUpdateThread(void * Unused) | ||||
| { | ||||
| 	struct hostent * HostEnt1; | ||||
| 	struct hostent * HostEnt2; | ||||
| 	struct hostent * HostEnt3; | ||||
| 
 | ||||
| 
 | ||||
| 	ResolveUpdateThreadId = GetCurrentThreadId(); | ||||
| 
 | ||||
|  | @ -3712,14 +3702,6 @@ VOID ResolveUpdateThread(void * Unused) | |||
| 		if (HostEnt2) | ||||
| 			memcpy(&Chatreportdest.sin_addr.s_addr,HostEnt2->h_addr,4); | ||||
| 
 | ||||
| 		Debugprintf("Resolving %s", NodeAPIServer); | ||||
| 		 | ||||
| 		HostEnt3 = gethostbyname(NodeAPIServer); | ||||
| 	 | ||||
| 		if (HostEnt3) | ||||
| 			memcpy(&UDPreportdest.sin_addr.s_addr,HostEnt3->h_addr,4); | ||||
| 
 | ||||
| 
 | ||||
| 		if (HostEnt1 && HostEnt2) | ||||
| 		{ | ||||
| 			Sleep(1000 * 60 * 30); | ||||
|  | @ -3760,13 +3742,6 @@ VOID OpenReportingSockets() | |||
| 		ConvToAX25("DUMMY-1", ReportDest); | ||||
| 	} | ||||
| 
 | ||||
| 	UDPreportdest.sin_family = AF_INET; | ||||
| 	UDPreportdest.sin_port = htons(NodeAPIPort); | ||||
| 
 | ||||
| 	if (EnableOARCAPI) | ||||
| 		NodeAPISocket = socket(AF_INET, SOCK_DGRAM, 0); | ||||
| 
 | ||||
| 	 | ||||
| 	// Set up Chat Report even if no LOCATOR	reportdest.sin_family = AF_INET;
 | ||||
| 	// Socket must be opened in MailChat Process
 | ||||
| 
 | ||||
|  | @ -5219,14 +5194,14 @@ skipit: | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| void SendDataToPktMapThread(void * Param); | ||||
| void SendDataToPktMapThread(); | ||||
| 
 | ||||
| void SendDataToPktMap() | ||||
| { | ||||
| 	_beginthread(SendDataToPktMapThread,2048000,0); | ||||
| } | ||||
| 
 | ||||
| void SendDataToPktMapThread(void * Param) | ||||
| void SendDataToPktMapThread() | ||||
| { | ||||
| 	char Return[256] = ""; | ||||
| 	char Request[64]; | ||||
|  |  | |||
							
								
								
									
										79
									
								
								Events.c
									
									
									
									
									
								
							
							
						
						
									
										79
									
								
								Events.c
									
									
									
									
									
								
							|  | @ -43,16 +43,8 @@ void MQTTReportSession(char * Msg); | |||
| extern int MQTT; | ||||
| 
 | ||||
| 
 | ||||
| int UDPSeq = 0; | ||||
| 
 | ||||
| extern SOCKET NodeAPISocket; | ||||
| extern SOCKADDR_IN UDPreportdest; | ||||
| 
 | ||||
| extern char Modenames[19][10]; | ||||
| 
 | ||||
| extern char NODECALLLOPPED[10]; | ||||
| 
 | ||||
| 
 | ||||
| // Runs use specified routine on certain event
 | ||||
| #ifndef WIN32 | ||||
| 
 | ||||
|  | @ -125,11 +117,7 @@ DllExport void APIENTRY RunEventProgram(char * Program, char * Param) | |||
| 
 | ||||
| void hookL2SessionAccepted(int Port, char * remotecall, char * ourcall, struct _LINKTABLE * LINK) | ||||
| { | ||||
| 	// Incoming SABM accepted
 | ||||
| 
 | ||||
| 	char UDPMsg[1024];	 | ||||
| 	int udplen; | ||||
| 
 | ||||
| 	// Incoming SABM
 | ||||
| 
 | ||||
| 	LINK->ConnectTime = time(NULL); | ||||
| 	LINK->bytesTXed = LINK->bytesRXed = 0; | ||||
|  | @ -137,19 +125,8 @@ void hookL2SessionAccepted(int Port, char * remotecall, char * ourcall, struct _ | |||
| 	strcpy(LINK->callingCall, remotecall); | ||||
| 	strcpy(LINK->receivingCall, ourcall); | ||||
| 	strcpy(LINK->Direction, "In"); | ||||
| 
 | ||||
| 	if (NodeAPISocket) | ||||
| 	{ | ||||
| 		udplen = sprintf(UDPMsg, "{\"@type\":\"LinkUpEvent\", \"node\": \"%s\", \"id\": %d, \"direction\": \"incoming\", \"port\": \"%d\", \"remote\": \"%s\", \"local\": \"%s\"}", | ||||
| 			NODECALLLOPPED, UDPSeq++, LINK->LINKPORT->PORTNUMBER, LINK->callingCall, LINK->receivingCall); | ||||
| 
 | ||||
| 		Debugprintf(UDPMsg); | ||||
| 
 | ||||
| 		sendto(NodeAPISocket, UDPMsg, udplen, 0, (struct sockaddr *)&UDPreportdest, sizeof(UDPreportdest)); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void hookL2SessionDeleted(struct _LINKTABLE * LINK) | ||||
| { | ||||
| 	// calculate session time and av bytes/min in and out
 | ||||
|  | @ -164,14 +141,12 @@ void hookL2SessionDeleted(struct _LINKTABLE * LINK) | |||
| 		else | ||||
| 		{ | ||||
| 			char Msg[256]; | ||||
| 			char timestamp[64]; | ||||
| 			char timestamp[16]; | ||||
| 			time_t sessionTime = time(NULL) - LINK->ConnectTime; | ||||
| 			double avBytesSent = LINK->bytesTXed / (sessionTime / 60.0); | ||||
| 			double avBytesRXed = LINK->bytesRXed / (sessionTime / 60.0); | ||||
| 			time_t Now = time(NULL); | ||||
| 			struct tm * TM = localtime(&Now); | ||||
| 			char UDPMsg[1024]; | ||||
| 			int udplen; | ||||
| 
 | ||||
| 			sprintf(timestamp, "%02d:%02d:%02d", TM->tm_hour, TM->tm_min, TM->tm_sec); | ||||
| 
 | ||||
|  | @ -189,21 +164,6 @@ void hookL2SessionDeleted(struct _LINKTABLE * LINK) | |||
| 
 | ||||
| 			if (MQTT) | ||||
| 				MQTTReportSession(Msg); | ||||
| 
 | ||||
| 
 | ||||
| 			if (NodeAPISocket) | ||||
| 			{ | ||||
| 				if (strcmp(LINK->Direction, "Out") == 0) | ||||
| 					udplen = sprintf(UDPMsg, "{\"@type\":\"LinkDownEvent\", \"node\": \"%s\", \"id\": %d, \"direction\": \"outgoing\", \"port\": \"%d\", \"remote\": \"%s\", \"local\": \"%s\"}", | ||||
| 						NODECALLLOPPED, UDPSeq++, LINK->LINKPORT->PORTNUMBER, LINK->receivingCall, LINK->callingCall); | ||||
| 				else | ||||
| 					udplen = sprintf(UDPMsg, "{\"@type\":\"LinkDownEvent\", \"node\": \"%s\", \"id\": %d, \"direction\": \"incoming\", \"port\": \"%d\", \"remote\": \"%s\", \"local\": \"%s\"}", | ||||
| 						NODECALLLOPPED, UDPSeq++, LINK->LINKPORT->PORTNUMBER, LINK->callingCall, LINK->receivingCall); | ||||
| 
 | ||||
| 				Debugprintf(UDPMsg); | ||||
| 		 | ||||
| 				sendto(NodeAPISocket, UDPMsg, udplen, 0, (struct sockaddr *)&UDPreportdest, sizeof(UDPreportdest)); | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		LINK->ConnectTime = 0; | ||||
|  | @ -226,27 +186,6 @@ void hookL2SessionAttempt(int Port, char * ourcall, char * remotecall, struct _L | |||
| 	strcpy(LINK->Direction, "Out"); | ||||
| } | ||||
| 
 | ||||
| void hookL2SessionConnected(struct _LINKTABLE * LINK) | ||||
| { | ||||
| 	// UA received in reponse to SABM
 | ||||
| 
 | ||||
| 	char UDPMsg[1024];	 | ||||
| 	int udplen; | ||||
| 
 | ||||
| 	if (NodeAPISocket) | ||||
| 	{ | ||||
| 		udplen = sprintf(UDPMsg, "{\"@type\":\"LinkUpEvent\", \"node\": \"%s\", \"id\": %d, \"direction\": \"outgoing\", \"port\": \"%d\", \"remote\": \"%s\", \"local\": \"%s\"}", | ||||
| 			NODECALLLOPPED, UDPSeq++, LINK->LINKPORT->PORTNUMBER, LINK->callingCall, LINK->receivingCall); | ||||
| 
 | ||||
| 		Debugprintf(UDPMsg); | ||||
| 
 | ||||
| 		sendto(NodeAPISocket, UDPMsg, udplen, 0, (struct sockaddr *)&UDPreportdest, sizeof(UDPreportdest)); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| void hookL4SessionAttempt(struct STREAMINFO * STREAM, char * remotecall, char * ourcall) | ||||
| { | ||||
| 	// Outgoing Connect
 | ||||
|  | @ -271,20 +210,6 @@ void hookL4SessionAccepted(struct STREAMINFO * STREAM, char * remotecall, char * | |||
| 	strcpy(STREAM->Direction, "In"); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
| { | ||||
|   "eventSource": "circuit", | ||||
|   "time": "2025-10-08T14:05:54+00:00", | ||||
|   "id": 23, | ||||
|   "direction": "incoming", | ||||
|   "port": "0", | ||||
|   "remote": "G8PZT@G8PZT:15aa", | ||||
|   "local": "GE8PZT:0017", | ||||
|   "event": "disconnect", | ||||
|   "@type": "event" | ||||
| } | ||||
| */ | ||||
| 
 | ||||
| void hookL4SessionDeleted(struct TNCINFO * TNC, struct STREAMINFO * STREAM) | ||||
| { | ||||
| 	char Msg[256]; | ||||
|  |  | |||
|  | @ -426,7 +426,7 @@ VOID ChatExpandAndSendMessage(ChatCIRCUIT * conn, char * Msg, int LOG) | |||
| 
 | ||||
| 	len = RemoveLF(NewMessage, (int)strlen(NewMessage)); | ||||
| 
 | ||||
| 	ChatWriteLogLine(conn, '>', NewMessage,  len, LOG_CHAT); | ||||
| 	ChatWriteLogLine(conn, '>', NewMessage,  len, LOG); | ||||
| 	ChatQueueMsg(conn, NewMessage, len); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										149
									
								
								L2Code.c
									
									
									
									
									
								
							
							
						
						
									
										149
									
								
								L2Code.c
									
									
									
									
									
								
							|  | @ -64,7 +64,7 @@ VOID L2SENDRESPONSE(struct _LINKTABLE * LINK, int CMD); | |||
| VOID L2SENDCOMMAND(struct _LINKTABLE * LINK, int CMD); | ||||
| VOID ACKMSG(struct _LINKTABLE * LINK); | ||||
| VOID InformPartner(struct _LINKTABLE * LINK, int Reason); | ||||
| UINT RR_OR_RNR(struct _LINKTABLE * LINK, int CMD); | ||||
| UINT RR_OR_RNR(struct _LINKTABLE * LINK); | ||||
| VOID L2TIMEOUT(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT); | ||||
| VOID CLEAROUTLINK(struct _LINKTABLE * LINK); | ||||
| VOID SENDFRMR(struct _LINKTABLE * LINK); | ||||
|  | @ -99,7 +99,6 @@ VOID L2SENDXID(struct _LINKTABLE * LINK); | |||
| VOID __cdecl Debugprintf(const char * format, ...); | ||||
| VOID Q_IP_MSG(MESSAGE * Buffer); | ||||
| VOID PROCESSNODEMESSAGE(MESSAGE * Msg, struct PORTCONTROL * PORT); | ||||
| VOID PROCESSNODESPOLL(struct PORTCONTROL * PORT); | ||||
| VOID L2LINKACTIVE(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * Buffer, MESSAGE * ADJBUFFER, UCHAR CTL, UCHAR MSGFLAG); | ||||
| BOOL CompareAliases(UCHAR * c1, UCHAR * c2); | ||||
| VOID L2FORUS(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * Buffer, MESSAGE * ADJBUFFER, UCHAR CTL, UCHAR MSGFLAG); | ||||
|  | @ -121,10 +120,8 @@ int CheckKissInterlock(struct PORTCONTROL * MYPORT, int Exclusive); | |||
| void hookL2SessionAccepted(int Port, char * fromCall, char * toCall, struct _LINKTABLE * LINK); | ||||
| void hookL2SessionDeleted(struct _LINKTABLE * LINK); | ||||
| void hookL2SessionAttempt(int Port, char * fromCall, char * toCall, struct _LINKTABLE * LINK); | ||||
| void hookL2SessionConnected(struct _LINKTABLE * LINK); | ||||
| int L2Compressit(unsigned char * Out, int OutSize, unsigned char * In, int Len); | ||||
| VOID DeleteINP3Routes(struct ROUTE * Route); | ||||
| VOID SendRTTMsg(struct ROUTE * Route); | ||||
| 
 | ||||
| extern int REALTIMETICKS; | ||||
| 
 | ||||
|  | @ -449,8 +446,6 @@ TRYBBS: | |||
| 			{ | ||||
| 				ALIASMSG = 0; | ||||
| 				 | ||||
| 				strcpy(LINK->ApplName, APPL->APPLCMD); | ||||
| 				 | ||||
| 				if (CompareCalls(Buffer->DEST, APPL->APPLCALL)) | ||||
| 					goto FORUS; | ||||
| 
 | ||||
|  | @ -484,9 +479,9 @@ NOWTRY_NODES: | |||
| 	if (CompareCalls(Buffer->DEST, NODECALL)) | ||||
| 	{ | ||||
| 		if (Buffer->L2DATA[0] == 0xff)	// Valid NODES Broadcast
 | ||||
| 		{ | ||||
| 			PROCESSNODEMESSAGE(Buffer, PORT); | ||||
| 		else if (Buffer->L2DATA[0] == 0xfe)		// Paula's NODES Poll (request Nodes broadcast on port)
 | ||||
| 			PROCESSNODESPOLL(PORT); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	ReleaseBuffer(Buffer); | ||||
|  | @ -813,15 +808,7 @@ VOID L2FORUS(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * Buff | |||
| 
 | ||||
| 	if (CTLlessPF == XID) | ||||
| 	{ | ||||
| 		// We could possibly get an XID response if packet is badly delayed and we had timed out
 | ||||
| 
 | ||||
| 		if ((MSGFLAG & CMDBIT))			// Command 
 | ||||
| 		ProcessXIDCommand(LINK, PORT, Buffer, ADJBUFFER, CTL, MSGFLAG); | ||||
| 		else | ||||
| 		{ | ||||
| 			Debugprintf("Unexpected XID response with no session"); | ||||
| 			ReleaseBuffer(Buffer);					// Ignore if not
 | ||||
| 		} | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -942,7 +929,6 @@ VOID ProcessXIDCommand(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESS | |||
| 		LINK->L2STATE = 1;			// XID received
 | ||||
| 		LINK->Ver2point2 = TRUE;	// Must support 2.2 if sent XID
 | ||||
| 		LINK->L2TIME = PORT->PORTT1; | ||||
| 		LINK->LINKWINDOW = PORT->PORTWINDOW;	// Just in case!
 | ||||
| 
 | ||||
| 		LINK->LINKPORT = PORT; | ||||
| 
 | ||||
|  | @ -1090,47 +1076,25 @@ VOID L2LINKACTIVE(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * | |||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	if (CTLlessPF == XID) | ||||
| 	{ | ||||
| 		// XID command or response on active session.
 | ||||
| 		 | ||||
| 		// if Command and state = 2 then other end missed XID Response. Process command again
 | ||||
| 
 | ||||
| 		if ((MSGFLAG & CMDBIT)) | ||||
| 		{ | ||||
| 			if (LINK->L2STATE == 2) | ||||
| 			{ | ||||
| 				// I think we can just process as normal.
 | ||||
| 
 | ||||
| 				ProcessXIDCommand(LINK, PORT, Buffer, ADJBUFFER, CTL, MSGFLAG); | ||||
| 				return; | ||||
| 			} | ||||
| 
 | ||||
| 			if (LINK->L2STATE == 1)			// We've just sent XID so is probably XID Collision
 | ||||
| 			{ | ||||
| 				// I think we can just process as normal. If we don't send a response the other end may not switch to 2.2
 | ||||
| 
 | ||||
| 				ProcessXIDCommand(LINK, PORT, Buffer, ADJBUFFER, CTL, MSGFLAG); | ||||
| 				return; | ||||
| 			} | ||||
| 
 | ||||
| 			// XID Command on active session. Other end may be restarting. Reset session
 | ||||
| 
 | ||||
| 			InformPartner(LINK, NORMALCLOSE);			// SEND DISC TO OTHER END
 | ||||
| 			LINK->CIRCUITPOINTER = 0; | ||||
| 
 | ||||
| 			// I think it is safer to ignore it. The retry will be processed normally as XID command with no session
 | ||||
| 
 | ||||
| 			ReleaseBuffer(Buffer); | ||||
| 			return; | ||||
| 		} | ||||
| 
 | ||||
| 		// XID Response
 | ||||
| 
 | ||||
| 		// if Link State = 1 this is a normal response. Check it then send SABM
 | ||||
| 
 | ||||
| 	if (LINK->L2STATE == 1) | ||||
| 	{ | ||||
| 		// XID State. Should be XID response if 2.2 ok or DM/FRMR if not
 | ||||
| 
 | ||||
| 		if (MSGFLAG & RESP) | ||||
| 		{ | ||||
| 			if (CTLlessPF == DM || CTLlessPF == FRMR) | ||||
| 			{ | ||||
| 				// Doesn't support XID - Send SABM
 | ||||
| 
 | ||||
| 				LINK->L2STATE = 2; | ||||
| 				LINK->Ver2point2 = FALSE; | ||||
| 				LINK->L2TIMER = 1;		// Use retry to send SABM
 | ||||
| 			} | ||||
| 			else if (CTLlessPF == XID) | ||||
| 			{ | ||||
| 				// Process response to make sure ok, Send SABM or DISC
 | ||||
| 
 | ||||
| 				LINK->L2STATE = 2; | ||||
| 				LINK->Ver2point2 = TRUE;// Must support 2.2 if responded to XID
 | ||||
| 
 | ||||
|  | @ -1175,44 +1139,25 @@ VOID L2LINKACTIVE(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * | |||
| 
 | ||||
| 				} | ||||
| 
 | ||||
| 			LINK->LINKWINDOW = PORT->PORTWINDOW;	// Just in case!
 | ||||
| 				LINK->L2TIMER = 1;		// Use retry to send SABM
 | ||||
| 			} | ||||
| 
 | ||||
| 			ReleaseBuffer(Buffer); | ||||
| 			return; | ||||
| 		} | ||||
| 	 | ||||
| 		// XID response, not in state 1.
 | ||||
| 		// Command on existing session. Could be due to other end missing
 | ||||
| 		// the XID response, so if XID just resend response
 | ||||
| 
 | ||||
| 		// This "shouldn't happen"
 | ||||
| 
 | ||||
| 		Debugprintf("Unexpected XID response, State = %d", LINK->L2STATE); | ||||
| 
 | ||||
| 		// Discard
 | ||||
| 
 | ||||
| 		ReleaseBuffer(Buffer); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 	// Not XID
 | ||||
| 
 | ||||
| 	// if state = 1 then unexpected response to XID
 | ||||
| 
 | ||||
| 	if (LINK->L2STATE == 1)	 | ||||
| 	if (CTLlessPF == XID && (MSGFLAG & CMDBIT)) | ||||
| 	{ | ||||
| 		if (CTLlessPF == DM || CTLlessPF == FRMR) | ||||
| 		{ | ||||
| 			// Doesn't support XID - Send SABM
 | ||||
| 		// XID Command on active session. Other end may be restarting. Send Response
 | ||||
| 
 | ||||
| 			LINK->L2STATE = 2; | ||||
| 			LINK->Ver2point2 = FALSE; | ||||
| 			LINK->L2TIMER = 1;		// Use retry to send SABM
 | ||||
| 	 | ||||
| 			ReleaseBuffer(Buffer); | ||||
| 		ProcessXIDCommand(LINK, PORT, Buffer, ADJBUFFER, CTL, MSGFLAG); | ||||
| 		return; | ||||
| 	} | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 	if (CTLlessPF == SABM) | ||||
|  | @ -1343,16 +1288,6 @@ VOID L2SABM(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * Buffe | |||
| 				Debugprintf("INP3 Incoming connect from %s", fromCall); | ||||
| 				DeleteINP3Routes(ROUTE); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				if (PORT->ENABLEINP3) | ||||
| 				{ | ||||
| 					// We will offer INP3 by sending an RTT probe.
 | ||||
| 
 | ||||
| 					SendRTTMsg(ROUTE); | ||||
| 
 | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if (NO_CTEXT == 1) | ||||
|  | @ -1453,8 +1388,6 @@ VOID L2SABM(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * Buffe | |||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	strcpy(Session->APPL, LINK->ApplName); | ||||
| 
 | ||||
| 	//	NOW TRY A BBS CONNECT
 | ||||
| 	//	IF APPL CONNECT, SEE IF APPL HAS AN ALIAS
 | ||||
| 
 | ||||
|  | @ -2054,26 +1987,15 @@ VOID L2_PROCESS(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * B | |||
| 				{ | ||||
| 					Debugprintf("INP3 Route to %s connected", fromCall); | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					if (PORT->ENABLEINP3) | ||||
| 					{ | ||||
| 						// We will offer INP3 by sending an RTT probe.
 | ||||
| 
 | ||||
| 						SendRTTMsg(ROUTE); | ||||
| 
 | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			hookL2SessionConnected(LINK); | ||||
| 
 | ||||
| 			SendL2ToMonMap(PORT, fromCall, '+', 'O');		 | ||||
| 	 | ||||
| 			LINK->L2STATE = 5; | ||||
| 			LINK->L2TIMER = 0;		// CANCEL TIMER
 | ||||
| 			LINK->L2RETRIES = 0; | ||||
| 			LINK->L2SLOTIM = T3;	// SET FRAME SENT RECENTLY
 | ||||
| 			LINK->L2SLOTIM, T3;		// SET FRAME SENT RECENTLY
 | ||||
| 
 | ||||
| 			//	IF VERSION 1 MSG, SET FLAG
 | ||||
| 
 | ||||
|  | @ -2352,7 +2274,7 @@ VOID SFRAME(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, UCHAR CTL, UCHA | |||
| 		if (LINK->LAST_F_TIME + 15 > REALTIMETICKS) | ||||
| 			return;			// DISCARD
 | ||||
| 
 | ||||
| 		CTL = RR_OR_RNR(LINK, FALSE);	// Sending response
 | ||||
| 		CTL = RR_OR_RNR(LINK); | ||||
| 
 | ||||
| 		CTL |= LINK->LINKNR << 5;	// SHIFT N(R) TO TOP 3 BITS
 | ||||
| 		CTL |= PFBIT; | ||||
|  | @ -3059,9 +2981,9 @@ VOID SDETX(struct _LINKTABLE * LINK) | |||
| 	 | ||||
| 	// **** Debug code **** look for stuck links
 | ||||
| 
 | ||||
| 	if (LINK->LINKWINDOW == 0 || LINK->LASTFRAMESENT == 0 || (time(NULL) - LINK->LASTFRAMESENT) > 60)			// No send for 60 secs
 | ||||
| 	if (LINK->LASTFRAMESENT && (time(NULL) - LINK->LASTFRAMESENT) > 60)			// No send for 60 secs
 | ||||
| 	{ | ||||
| 		if (COUNT_AT_L2(LINK) > 16 || LINK->LINKWINDOW == 0) | ||||
| 		if (COUNT_AT_L2(LINK) > 16) | ||||
| 		{ | ||||
| 			// Dump Link State
 | ||||
| 
 | ||||
|  | @ -3394,7 +3316,7 @@ VOID L2TimerProc() | |||
| 		{ | ||||
| 			//	Was busy
 | ||||
| 
 | ||||
| 			if (RR_OR_RNR(LINK, 0) != RNR)		//  SEE IF STILL BUSY
 | ||||
| 			if (RR_OR_RNR(LINK) != RNR)		//  SEE IF STILL BUSY
 | ||||
| 			{ | ||||
| 				// Not still busy - tell other end
 | ||||
| 
 | ||||
|  | @ -3510,7 +3432,7 @@ VOID SendSupervisCmd(struct _LINKTABLE * LINK) | |||
| 
 | ||||
| 	LINK->L2ACKREQ = 0;			// CLEAR ACK NEEDED
 | ||||
| 
 | ||||
| 	CTL = RR_OR_RNR(LINK, TRUE); | ||||
| 	CTL = RR_OR_RNR(LINK); | ||||
| 
 | ||||
| //	MOV	L2STATE[EBX],5			; CANCEL REJ - ACTUALLY GOING TO 'PENDING ACK'
 | ||||
| 
 | ||||
|  | @ -3528,7 +3450,7 @@ void SEND_RR_RESP(struct _LINKTABLE * LINK, UCHAR PF) | |||
| { | ||||
| 	UCHAR CTL; | ||||
| 	 | ||||
| 	CTL = RR_OR_RNR(LINK, FALSE); | ||||
| 	CTL = RR_OR_RNR(LINK); | ||||
| 
 | ||||
| //	MOV	L2STATE[EBX],5			; CANCEL REJ - ACTUALLY GOING TO 'PENDING ACK'
 | ||||
| 
 | ||||
|  | @ -3879,7 +3801,6 @@ VOID L2SENDXID(struct _LINKTABLE * LINK) | |||
| 
 | ||||
| 	if (PORT) | ||||
| 	{ | ||||
| 		LINK->LINKWINDOW = PORT->PORTWINDOW;			// Just in case!
 | ||||
| 		Buffer->PORT = PORT->PORTNUMBER; | ||||
| 		PUT_ON_PORT_Q(PORT, Buffer); | ||||
| 	} | ||||
|  | @ -4023,7 +3944,7 @@ VOID InformPartner(struct _LINKTABLE * LINK, int Reason) | |||
| } | ||||
| 
 | ||||
| 
 | ||||
| UINT RR_OR_RNR(struct _LINKTABLE * LINK, int CMD) | ||||
| UINT RR_OR_RNR(struct _LINKTABLE * LINK) | ||||
| { | ||||
| 	UCHAR Temp; | ||||
| 	TRANSPORTENTRY * Session; | ||||
|  | @ -4105,9 +4026,7 @@ stayinREJ2: | |||
| 
 | ||||
| 		// Dont send SREJ if clearing RNR - causes FRMR
 | ||||
| 
 | ||||
| 		// Latest Spec says shouldn't send SREJ as Command
 | ||||
| 
 | ||||
| 		if (SaveRNRSent || CMD == 1) | ||||
| 		if (SaveRNRSent) | ||||
| 			return REJ; | ||||
| 
 | ||||
| 		if (LINK->Ver2point2)		// We only allow 2.2 with SREJ Multi
 | ||||
|  |  | |||
							
								
								
									
										45
									
								
								L3Code.c
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								L3Code.c
									
									
									
									
									
								
							|  | @ -60,10 +60,6 @@ VOID L3TRYNEXTDEST(struct ROUTE * ROUTE); | |||
| VOID SendNETROMRoute(struct PORTCONTROL * PORT, unsigned char * axcall); | ||||
| void SendVARANetromNodes(struct TNCINFO * TNC, MESSAGE *Buffer); | ||||
| void SendVARANetromMsg(struct TNCINFO * TNC,L3MESSAGEBUFFER * Buffer); | ||||
| VOID SENDNODESMSG(int Portnum); | ||||
| 
 | ||||
| extern int NODESINPROGRESS; | ||||
| extern int NODESToOnePort; | ||||
| 
 | ||||
| extern BOOL NODESINPROGRESS ;; | ||||
| PPORTCONTROL L3CURRENTPORT; | ||||
|  | @ -245,13 +241,6 @@ char Call1[10]; | |||
| char Call2[10]; | ||||
| char Call3[10]; | ||||
| 
 | ||||
| VOID PROCESSNODESPOLL(struct PORTCONTROL * PORT) | ||||
| { | ||||
| 	// Pauls G8BPT's request NODES Broadcast
 | ||||
| 
 | ||||
| 	SENDNODESMSG(PORT->PORTNUMBER); | ||||
| 	return; | ||||
| } | ||||
| VOID PROCESSNODEMESSAGE(MESSAGE * Msg, struct PORTCONTROL * PORT) | ||||
| { | ||||
| 	//	PROCESS A NET/ROM 'NODES' MESSAGE
 | ||||
|  | @ -755,26 +744,12 @@ VOID L3BG(); | |||
| 
 | ||||
| VOID SENDNEXTNODESFRAGMENT(); | ||||
| 
 | ||||
| VOID SENDNODESMSG(int Portnum) | ||||
| VOID SENDNODESMSG() | ||||
| { | ||||
| 	if (NODESINPROGRESS) | ||||
| 		return; | ||||
| 
 | ||||
| 	NODESToOnePort = Portnum; | ||||
| 
 | ||||
| 	if (Portnum)			// Nodes to one port only
 | ||||
| 	{ | ||||
| 		L3CURRENTPORT = GetPortTableEntryFromPortNum(Portnum); | ||||
| 
 | ||||
| 		if (L3CURRENTPORT == 0) | ||||
| 		{ | ||||
| 			NODESToOnePort = 0; | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
| 	else | ||||
| 	L3CURRENTPORT = PORTTABLE; | ||||
| 	 | ||||
| 	SENDNEXTNODESFRAGMENT(); | ||||
| } | ||||
| 
 | ||||
|  | @ -810,18 +785,15 @@ VOID SENDNEXTNODESFRAGMENT() | |||
| 			// No NODES to this port, so go to next
 | ||||
| 
 | ||||
| 			PORT = PORT->PORTPOINTER; | ||||
| 
 | ||||
| 			if (PORT == NULL || NODESToOnePort) | ||||
| 			if (PORT == NULL) | ||||
| 			{ | ||||
| 				// Finished
 | ||||
| 
 | ||||
| 				NODESToOnePort = 0; | ||||
| 				NODESINPROGRESS = 0; | ||||
| 				return; | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if (NODESToOnePort == 0)			// CurrentPort already set if NODESToOnePort
 | ||||
| 		L3CURRENTPORT = PORT; | ||||
| 
 | ||||
| 		DEST = CURRENTNODE = DESTS;			// START OF LIST
 | ||||
|  | @ -879,16 +851,6 @@ VOID SENDNEXTNODESFRAGMENT() | |||
| 		if (DEST >= ENDDESTLIST) | ||||
| 		{ | ||||
| 			CURRENTNODE = 0;			// Finished on this port
 | ||||
| 
 | ||||
| 			// if sending to only one port then stop
 | ||||
| 
 | ||||
| 			if (NODESToOnePort) | ||||
| 			{ | ||||
| 				NODESToOnePort = 0; | ||||
| 				NODESINPROGRESS = 0; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 			L3CURRENTPORT = PORT->PORTPOINTER; | ||||
| 			if (L3CURRENTPORT == NULL) | ||||
| 			{ | ||||
|  | @ -896,7 +858,6 @@ VOID SENDNEXTNODESFRAGMENT() | |||
| 
 | ||||
| 				NODESINPROGRESS = 0; | ||||
| 			} | ||||
| 			} | ||||
| 			goto Sendit; | ||||
| 		} | ||||
| 
 | ||||
|  | @ -1083,7 +1044,7 @@ VOID L3TimerProc() | |||
| 			 | ||||
| 			L3TIMER = L3INTERVAL; | ||||
| 			UPDATEDESTLIST(); | ||||
| 			SENDNODESMSG(0); | ||||
| 			SENDNODESMSG(); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										4
									
								
								L4Code.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								L4Code.c
									
									
									
									
									
								
							|  | @ -791,7 +791,7 @@ VOID L4BG() | |||
| 	 | ||||
| 					complen = L2Compressit(Compressed, 8192, toCompress, toCompressLen); | ||||
| 
 | ||||
| 	//				Debugprintf("%d %d %d%%", toCompressLen, complen, ((toCompressLen - complen) * 100) / toCompressLen);
 | ||||
| 					Debugprintf("%d %d %d%%", toCompressLen, complen, ((toCompressLen - complen) * 100) / toCompressLen); | ||||
| 
 | ||||
| 					// Send compressed
 | ||||
| 
 | ||||
|  | @ -826,7 +826,7 @@ VOID L4BG() | |||
| 								Len = ChunkSize; | ||||
| 			 | ||||
| 							complen = L2Compressit(Compressed, 8192, CompressPtr, Len); | ||||
| //							Debugprintf("Chunked %d %d %d%%", Len, complen, ((Len - complen) * 100) / Len);
 | ||||
| 							Debugprintf("Chunked %d %d %d%%", Len, complen, ((Len - complen) * 100) / Len); | ||||
| 
 | ||||
| 							sendChunk(L4, Compressed, complen, savePort); | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										7
									
								
								LinBPQ.c
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								LinBPQ.c
									
									
									
									
									
								
							|  | @ -84,7 +84,7 @@ void RHPPoll(); | |||
| VOID GetPGConfig(); | ||||
| void SendBBSDataToPktMap(); | ||||
| 
 | ||||
| extern uint64_t INP3timeLoadedMS; | ||||
| extern uint64_t timeLoadedMS; | ||||
| 
 | ||||
| BOOL IncludesMail = FALSE; | ||||
| BOOL IncludesChat = FALSE; | ||||
|  | @ -839,14 +839,15 @@ int main(int argc, char * argv[]) | |||
| #endif | ||||
| #endif | ||||
| 
 | ||||
| // Disable Console Terminal if stdout redirected
 | ||||
| 	// Disable Console Terminal if stdout redirected
 | ||||
| 
 | ||||
| //	printf("STDOUT %d\n",isatty(STDOUT_FILENO));
 | ||||
| //	printf("STDIN %d\n",isatty(STDIN_FILENO));
 | ||||
| 
 | ||||
| 	if (!isatty(STDOUT_FILENO) || !isatty(STDIN_FILENO)) | ||||
| 		Redirected = 1; | ||||
| 
 | ||||
| 	 INP3timeLoadedMS = GetTickCount(); | ||||
| 	 timeLoadedMS = GetTickCount(); | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										92
									
								
								Moncode.c
									
									
									
									
									
								
							
							
						
						
									
										92
									
								
								Moncode.c
									
									
									
									
									
								
							|  | @ -691,14 +691,6 @@ char * DISPLAY_NETROM(MESSAGE * ADJBUFFER, UCHAR * Output, int MsgLen) | |||
| 		return Output; | ||||
| 	} | ||||
| 
 | ||||
| 	if (ADJBUFFER->L2DATA[0] == 0xfe)			// Paula's Nodes Poll
 | ||||
| 	{ | ||||
| 		memcpy(Alias, ++ptr, 6); | ||||
| 		Output += sprintf((char *)Output, " NODES POLL from %s\r", Alias); | ||||
| 		return Output; | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 	//	Display normal NET/ROM transmissions 
 | ||||
| 
 | ||||
| 	Output += sprintf((char *)Output, " NET/ROM\r  "); | ||||
|  | @ -993,87 +985,3 @@ char * DISPLAYARPDATAGRAM(UCHAR * Datagram, UCHAR * Output) | |||
| 			ptr[15], ptr[16], ptr[17], ptr[18], Dest, ptr[26], ptr[27], ptr[28], ptr[29]); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| char Lastpacketlog[256]; | ||||
| 
 | ||||
| int PacketLogDelay = 30000; | ||||
| 
 | ||||
| extern BPQVECSTRUC * FILEMONVECTOR; | ||||
| extern UCHAR LogDirectory[260]; | ||||
| 
 | ||||
| void WritePacketLogThread(void * param) | ||||
| { | ||||
| 	char FN[256]; | ||||
| 	time_t T; | ||||
| 	struct tm * tm; | ||||
| 	FILE * Handle; | ||||
| 	int MsgLen; | ||||
| 	MESSAGE * MSG; | ||||
| 	MESSAGE * Q; | ||||
| 	char buffer[512]; | ||||
| 
 | ||||
| 
 | ||||
| 	while(1) | ||||
| 	{ | ||||
| 		BOOL SaveMTX = MTX; | ||||
| 		BOOL SaveMCOM = MCOM; | ||||
| 		BOOL SaveMUI = MUIONLY; | ||||
| 
 | ||||
| 		Sleep(PacketLogDelay); | ||||
| 
 | ||||
| 		// Get chain of queued packets under semaphore
 | ||||
| 
 | ||||
| 		GetSemaphore(&Semaphore, 101); | ||||
| 
 | ||||
| 		Q = FILEMONVECTOR->HOSTTRACEQ; | ||||
| 		FILEMONVECTOR->HOSTTRACEQ = 0; | ||||
| 
 | ||||
| 		FreeSemaphore(&Semaphore); | ||||
| 		 | ||||
| 		if (Q == 0) | ||||
| 			continue; | ||||
| 
 | ||||
| 		// Open log file and write decoded packets
 | ||||
| 
 | ||||
| 		T = time(NULL); | ||||
| 		tm = gmtime(&T); | ||||
| 
 | ||||
| 		if (LogDirectory[0] == 0) | ||||
| 		{ | ||||
| 			strcpy(FN, "logs/PacketLog"); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			strcpy(FN, LogDirectory); | ||||
| 			strcat(FN, "/"); | ||||
| 			strcat(FN, "logs/PacketLog"); | ||||
| 		} | ||||
| 
 | ||||
| 		sprintf(&FN[strlen(FN)], "_%04d%02d%02d.log", tm->tm_year +1900, tm->tm_mon+1, tm->tm_mday); | ||||
| 
 | ||||
| 		Handle = fopen(FN, "ab"); | ||||
| 
 | ||||
| 		if (Handle == NULL) | ||||
| 			return; | ||||
| 
 | ||||
| 		while (Q) | ||||
| 		{ | ||||
| 			MSG = Q; | ||||
| 			Q = MSG->CHAIN;			// get first
 | ||||
| 
 | ||||
| 			IntSetTraceOptionsEx(MMASK, 1, 1, 0); | ||||
| 			MsgLen = IntDecodeFrame(MSG, buffer, MSG->Timestamp, 0xffffffffffffffff, FALSE, FALSE); | ||||
| 			IntSetTraceOptionsEx(MMASK, SaveMTX, SaveMCOM, SaveMUI); | ||||
| 
 | ||||
| 			fwrite(buffer , 1, MsgLen, Handle); | ||||
| 
 | ||||
| 			GetSemaphore(&Semaphore, 101); | ||||
| 			ReleaseBuffer(MSG); | ||||
| 			FreeSemaphore(&Semaphore); | ||||
| 		} | ||||
| 		fclose(Handle); | ||||
| 	} | ||||
| 
 | ||||
| 	return; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										28
									
								
								RigControl.c
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								RigControl.c
									
									
									
									
									
								
							|  | @ -110,7 +110,7 @@ VOID ConnecttoFLRIG(struct RIGPORTINFO * PORT); | |||
| int DecodeHAMLIBAddr(struct RIGPORTINFO * PORT, char * ptr); | ||||
| void ProcessHAMLIBFrame(struct RIGPORTINFO * PORT, int Length); | ||||
| VOID HAMLIBPoll(struct RIGPORTINFO * PORT); | ||||
| void HAMLIBSlaveThread(VOID * Param); | ||||
| void HAMLIBSlaveThread(struct RIGINFO * RIG); | ||||
| void CheckAndProcessRTLUDP(struct RIGPORTINFO * PORT); | ||||
| VOID RTLUDPPoll(struct RIGPORTINFO * PORT); | ||||
| VOID ConnecttoRTLUDP(struct RIGPORTINFO * PORT); | ||||
|  | @ -122,8 +122,8 @@ VOID ProcessSDRRadioFrame(struct RIGPORTINFO * PORT, int Length); | |||
| VOID SDRRadioPoll(struct RIGPORTINFO * PORT); | ||||
| 
 | ||||
| VOID SetupPortRIGPointers(); | ||||
| VOID PTTCATThread(void * Param); | ||||
| 
 | ||||
| VOID PTTCATThread(struct RIGINFO *RIG); | ||||
| VOID ConnecttoHAMLIB(struct RIGPORTINFO * PORT); | ||||
| 
 | ||||
| // ----- G7TAJ ----
 | ||||
| VOID ConnecttoSDRANGEL(struct RIGPORTINFO * PORT); | ||||
|  | @ -7484,9 +7484,8 @@ VOID SetupPortRIGPointers() | |||
| 
 | ||||
| #ifdef WIN32 | ||||
| 
 | ||||
| VOID PTTCATThread(void * Param) | ||||
| VOID PTTCATThread(struct RIGINFO *RIG) | ||||
| { | ||||
| 	struct RIGINFO * RIG = 	(struct RIGINFO *)Param; | ||||
| 	DWORD dwLength = 0; | ||||
| 	int Length, ret, i; | ||||
| 	UCHAR * ptr1; | ||||
|  | @ -8472,7 +8471,7 @@ int DecodeHAMLIBAddr(struct RIGPORTINFO * PORT, char * ptr) | |||
| 	return 1; | ||||
| } | ||||
| 
 | ||||
| VOID HAMLIBThread(void * Param); | ||||
| VOID HAMLIBThread(struct RIGPORTINFO * PORT); | ||||
| 
 | ||||
| VOID ConnecttoHAMLIB(struct RIGPORTINFO * PORT) | ||||
| { | ||||
|  | @ -8482,11 +8481,10 @@ VOID ConnecttoHAMLIB(struct RIGPORTINFO * PORT) | |||
| 	return ; | ||||
| } | ||||
| 
 | ||||
| VOID HAMLIBThread(void * Param) | ||||
| VOID HAMLIBThread(struct RIGPORTINFO * PORT) | ||||
| { | ||||
| 	// Opens sockets and looks for data
 | ||||
| 	 | ||||
| 	struct RIGPORTINFO * PORT = (struct RIGPORTINFO * )Param; | ||||
| 	char Msg[255]; | ||||
| 	int err, i, ret; | ||||
| 	u_long param=1; | ||||
|  | @ -8608,11 +8606,10 @@ Lost: | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| void HAMLIBSlaveThread(VOID * Param) | ||||
| void HAMLIBSlaveThread(struct RIGINFO * RIG) | ||||
| { | ||||
| 	// Wait for connections and messages from HAMLIB Clients
 | ||||
| 
 | ||||
| 	struct RIGINFO * RIG = (struct RIGINFO *)Param; | ||||
| 	fd_set readfs; | ||||
| 	fd_set errorfs; | ||||
| 	struct timeval timeout; | ||||
|  | @ -8928,7 +8925,7 @@ VOID FLRIGSendCommand(struct RIGPORTINFO * PORT, char * Command, char * Value) | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| VOID FLRIGThread(VOID * Param); | ||||
| VOID FLRIGThread(struct RIGPORTINFO * PORT); | ||||
| 
 | ||||
| VOID ConnecttoFLRIG(struct RIGPORTINFO * PORT) | ||||
| { | ||||
|  | @ -8937,11 +8934,10 @@ VOID ConnecttoFLRIG(struct RIGPORTINFO * PORT) | |||
| 	return ; | ||||
| } | ||||
| 
 | ||||
| VOID FLRIGThread(VOID * Param) | ||||
| VOID FLRIGThread(struct RIGPORTINFO * PORT) | ||||
| { | ||||
| 	// Opens sockets and looks for data
 | ||||
| 	 | ||||
| 	struct RIGPORTINFO * PORT = (struct RIGPORTINFO *)Param; | ||||
| 	char Msg[255]; | ||||
| 	int err, i, ret; | ||||
| 	u_long param=1; | ||||
|  | @ -10181,7 +10177,7 @@ void ProcessSDRANGELFrame(struct RIGPORTINFO * PORT) | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| VOID SDRANGELThread(VOID * Param); | ||||
| VOID SDRANGELThread(struct RIGPORTINFO * PORT); | ||||
| 
 | ||||
| VOID ConnecttoSDRANGEL(struct RIGPORTINFO * PORT) | ||||
| { | ||||
|  | @ -10190,11 +10186,9 @@ VOID ConnecttoSDRANGEL(struct RIGPORTINFO * PORT) | |||
| 	return ; | ||||
| } | ||||
| 
 | ||||
| VOID SDRANGELThread(VOID * Param) | ||||
| VOID SDRANGELThread(struct RIGPORTINFO * PORT) | ||||
| { | ||||
| 	// Opens sockets and looks for data
 | ||||
| 
 | ||||
| 	struct RIGPORTINFO * PORT = (struct RIGPORTINFO *)Param; | ||||
| 	char Msg[512]; | ||||
| 	int err, i, ret; | ||||
| 	u_long param=1; | ||||
|  |  | |||
|  | @ -10,15 +10,15 @@ | |||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #define KVers 6,0,25,6 | ||||
| #define KVerstring "6.0.25.6\0" | ||||
| #define KVers 6,0,25,1 | ||||
| #define KVerstring "6.0.25.1\0" | ||||
| 
 | ||||
| 
 | ||||
| #ifdef CKernel | ||||
| 
 | ||||
| #define Vers KVers | ||||
| #define Verstring KVerstring | ||||
| #define Datestring "October 2025" | ||||
| #define Datestring "August 2025" | ||||
| #define VerComments "G8BPQ Packet Switch (C Version)" KVerstring | ||||
| #define VerCopyright "Copyright © 2001-2025 John Wiseman G8BPQ\0" | ||||
| #define VerDesc "BPQ32 Switch\0" | ||||
|  |  | |||
							
								
								
									
										29
									
								
								asmstrucs.h
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								asmstrucs.h
									
									
									
									
									
								
							|  | @ -64,6 +64,15 @@ extern int ENDOFDATA; | |||
| extern int L3LIVES; | ||||
| extern int NUMBEROFNODES; | ||||
| 
 | ||||
| struct CMDX | ||||
| { | ||||
| 	char String[12];			// COMMAND STRING
 | ||||
| 	UCHAR CMDLEN;				// SIGNIFICANT LENGTH
 | ||||
| //	VOID (*CMDPROC)(struct _TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail,  struct CMDX * CMD);// COMMAND PROCESSOR
 | ||||
| 	VOID (*CMDPROC)();// COMMAND PROCESSOR
 | ||||
| 	size_t CMDFLAG;				// FLAG/VALUE Offset
 | ||||
| 
 | ||||
| }; | ||||
| 
 | ||||
| struct APPLCONFIG | ||||
| { | ||||
|  | @ -222,12 +231,11 @@ typedef struct ROUTE | |||
| 	int	LastConnectAttempt;		// To stop us trying too often
 | ||||
| 
 | ||||
| 	int Status;			// 
 | ||||
| 	int OldBPQ;				// Set if other end is BPQ sending RIF in mS
 | ||||
| 	int LastRTT;			// Last Value Reported
 | ||||
| 	int RTT;				// Current	
 | ||||
| 	int SRTT;				// Smoothed RTT
 | ||||
| 	int NeighbourSRTT;		// Other End SRTT
 | ||||
| 	int RTTIncrement;		// Average of Ours and Neighbours SRTT in 10 ms - smoothed neighbor transport time (SNTT) in spec
 | ||||
| //	int RTTIncrement;		// Average of Ours and Neighbours SRTT in 10 ms
 | ||||
| 	int BCTimer;			// Time to next L3RTT Broadcast
 | ||||
| 	int Timeout;			// Lost Response Timer
 | ||||
| 	int Retries;			// Lost Response Count
 | ||||
|  | @ -236,8 +244,6 @@ typedef struct ROUTE | |||
| 	int	OtherendsRouteQual;	//	Route quality used by other end.
 | ||||
| 	int	OtherendLocked;		//	Route quality locked by ROUTES entry.
 | ||||
| 	int	FirstTimeFlag;		//	Set once quality has been set by direct receive
 | ||||
| 	int RemoteMAXRTT;		//	For INP3
 | ||||
| 	int RemoteMAXHOPS; | ||||
| 
 | ||||
| } *PROUTE; | ||||
| 
 | ||||
|  | @ -695,8 +701,7 @@ typedef struct PORTCONTROL | |||
| 	BOOL NormalizeQuality;		// Normalise Node Qualities
 | ||||
| 	BOOL IgnoreUnlocked;		// Ignore Unlocked routes
 | ||||
| 	BOOL INP3ONLY;				// Default to INP3 and disallow NODES
 | ||||
| 	BOOL ALLOWINP3;				// Accept INP3 if offered by other end
 | ||||
| 	BOOL ENABLEINP3;			// Send INP3 RTT probes to discovered neighbours
 | ||||
| 	BOOL ALLOWINP3; | ||||
| 
 | ||||
| 	void (* UIHook)(struct _LINKTABLE * LINK, struct PORTCONTROL * PORT, MESSAGE * Buffer, MESSAGE * ADJBUFFER, UCHAR CTL, UCHAR MSGFLAG);			// Used for KISSARQ
 | ||||
| 	struct PORTCONTROL * HookPort; | ||||
|  | @ -976,8 +981,6 @@ typedef struct _LINKTABLE | |||
| 	int Received; | ||||
| 	int ReceivedAfterExpansion; | ||||
| 
 | ||||
| 	char ApplName[16]; | ||||
| 
 | ||||
| 
 | ||||
| } LINKTABLE; | ||||
| 
 | ||||
|  | @ -1469,16 +1472,6 @@ struct AXIPPORTINFO | |||
| 
 | ||||
| }; | ||||
| 
 | ||||
| struct CMDX | ||||
| { | ||||
| 	char String[12];			// COMMAND STRING
 | ||||
| 	UCHAR CMDLEN;				// SIGNIFICANT LENGTH
 | ||||
| 	VOID (*CMDPROC)(TRANSPORTENTRY * Session, char * Bufferptr, char * CmdTail,  struct CMDX * CMD);// COMMAND PROCESSOR
 | ||||
| //	VOID (*CMDPROC)();// COMMAND PROCESSOR
 | ||||
| 	size_t CMDFLAG;				// FLAG/VALUE Offset
 | ||||
| 
 | ||||
| }; | ||||
| 
 | ||||
| 
 | ||||
| #define Disconnect(stream) SessionControl(stream,2,0) | ||||
| #define Connect(stream) SessionControl(stream,1,0) | ||||
|  |  | |||
							
								
								
									
										17
									
								
								bpqaxip.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								bpqaxip.c
									
									
									
									
									
								
							|  | @ -192,8 +192,8 @@ extern UCHAR BPQDirectory[]; | |||
| 
 | ||||
| extern int OffsetH, OffsetW; | ||||
| 
 | ||||
| static void ResolveNames(VOID * Param); | ||||
| void OpenSockets(VOID * Param); | ||||
| static void ResolveNames(struct AXIPPORTINFO * PORT); | ||||
| void OpenSockets(struct AXIPPORTINFO * PORT); | ||||
| void CloseSockets(struct AXIPPORTINFO * PORT); | ||||
| 
 | ||||
| 
 | ||||
|  | @ -221,7 +221,7 @@ int	KissDecode(UCHAR * inbuff, int len); | |||
| int Socket_Accept(int SocketId); | ||||
| int Socket_Connect(int SocketId, int Error); | ||||
| int Socket_Data(int sock, int error, int eventcode); | ||||
| VOID TCPConnectThread(VOID * Param); | ||||
| VOID TCPConnectThread(struct arp_table_entry * arp); | ||||
| VOID __cdecl Debugprintf(const char * format, ...); | ||||
| VOID __cdecl Consoleprintf(const char * format, ...); | ||||
| BOOL OpenListeningSocket(struct AXIPPORTINFO * PORT, struct arp_table_entry * arp); | ||||
|  | @ -692,7 +692,7 @@ static size_t ExtProc(int fn, int port, PMESSAGE buff) | |||
| 		else  | ||||
| 			Consoleprintf("Failed to reread config file - leaving config unchanged"); | ||||
| 
 | ||||
| 		_beginthread(OpenSockets, 0, PORT); | ||||
| 		_beginthread(OpenSockets, 0, PORT ); | ||||
| 
 | ||||
| 		GetAXIPCache(PORT); | ||||
| 
 | ||||
|  | @ -844,9 +844,8 @@ int InitAXIP(int Port) | |||
| 	return (TRUE);	 | ||||
| } | ||||
| 
 | ||||
| void OpenSockets(void * Param) | ||||
| void OpenSockets(struct AXIPPORTINFO * PORT) | ||||
| { | ||||
| 	struct AXIPPORTINFO * PORT = (struct AXIPPORTINFO *)Param; | ||||
| 	char Msg[255]; | ||||
| 	int err; | ||||
| 	u_long param=1; | ||||
|  | @ -1529,9 +1528,8 @@ static void CreateResolverWindow(struct AXIPPORTINFO * PORT) | |||
| extern HWND hWndPopup; | ||||
| 
 | ||||
| 
 | ||||
| static void ResolveNames(VOID * Param) | ||||
| static void ResolveNames(struct AXIPPORTINFO * PORT) | ||||
| { | ||||
| 	struct AXIPPORTINFO * PORT = (struct AXIPPORTINFO *)Param; | ||||
| 	int count = 0; | ||||
| 
 | ||||
| 	PORT->ResolveNamesThreadId = GetCurrentThreadId();		// Detect if another started
 | ||||
|  | @ -2998,9 +2996,8 @@ int	KissDecode(UCHAR * inbuff, int len) | |||
| 	return txptr; | ||||
| } | ||||
| 
 | ||||
| VOID TCPConnectThread(void * Param) | ||||
| VOID TCPConnectThread(struct arp_table_entry * arp) | ||||
| { | ||||
| 	struct arp_table_entry * arp = (struct arp_table_entry *)Param; | ||||
| 	char Msg[255]; | ||||
| 	int err, i; | ||||
| 	u_long param=1; | ||||
|  |  | |||
							
								
								
									
										35
									
								
								cMain.c
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								cMain.c
									
									
									
									
									
								
							|  | @ -54,7 +54,6 @@ void MQTTTimer(); | |||
| void SaveMH(); | ||||
| VOID InformPartner(struct _LINKTABLE * LINK, int Reason); | ||||
| VOID L2SENDCOMMAND(struct _LINKTABLE * LINK, int CMD); | ||||
| void WritePacketLogThread(void * param); | ||||
| 
 | ||||
| 
 | ||||
| #include "configstructs.h" | ||||
|  | @ -62,7 +61,6 @@ void WritePacketLogThread(void * param); | |||
| extern struct CONFIGTABLE xxcfg; | ||||
| extern BOOL needAIS; | ||||
| extern int needADSB; | ||||
| extern int EnableOARCAPI; | ||||
| 
 | ||||
| struct PORTCONFIG * PortRec; | ||||
| 
 | ||||
|  | @ -183,7 +181,6 @@ extern VOID * ENDPOOL; | |||
| extern void * APPL_Q;				// Queue of frames for APRS Appl
 | ||||
| 
 | ||||
| extern BOOL APRSActive; | ||||
| extern int DEBUGINP3; | ||||
| 
 | ||||
| #define BPQHOSTSTREAMS	64 | ||||
| 
 | ||||
|  | @ -197,12 +194,9 @@ BPQVECSTRUC * TELNETMONVECPTR = &BPQHOSTVECTOR[BPQHOSTSTREAMS]; | |||
| BPQVECSTRUC * AGWMONVECPTR = &BPQHOSTVECTOR[BPQHOSTSTREAMS + 1]; | ||||
| BPQVECSTRUC * APRSMONVECPTR = &BPQHOSTVECTOR[BPQHOSTSTREAMS + 2]; | ||||
| BPQVECSTRUC * IPHOSTVECTORPTR = &BPQHOSTVECTOR[BPQHOSTSTREAMS + 3]; | ||||
| BPQVECSTRUC * FILEMONVECTOR = &BPQHOSTVECTOR[BPQHOSTSTREAMS + 4]; | ||||
| 
 | ||||
| int BPQVECLENGTH = sizeof(BPQVECSTRUC); | ||||
| 
 | ||||
| int MONTOFILEFLAG = 0; | ||||
| 
 | ||||
| int NODEORDER = 0; | ||||
| UCHAR LINKEDFLAG = 0; | ||||
| 
 | ||||
|  | @ -256,8 +250,6 @@ int CFLAG = 0;						// C =HOST Command | |||
| VOID * IDMSG_Q = NULL;				// ID/BEACONS WAITING TO BE SENT
 | ||||
| 
 | ||||
| int	NODESINPROGRESS = 0; | ||||
| int NODESToOnePort = 0;				// Set to port num to send NODES to only one port.
 | ||||
| 
 | ||||
| VOID * CURRENTNODE = NULL;			// NEXT _NODE TO SEND
 | ||||
| VOID * DESTHEADER = NULL;			// HEAD OF SORTED NODES CHAIN
 | ||||
| 
 | ||||
|  | @ -870,11 +862,6 @@ BOOL Start() | |||
| 
 | ||||
| 	PREFERINP3ROUTES = cfg->C_PREFERINP3ROUTES; | ||||
| 
 | ||||
| 	if (cfg->C_DEBUGINP3) | ||||
| 		DEBUGINP3 = 0; | ||||
| 
 | ||||
| 	EnableOARCAPI = cfg->C_OARCAPI; | ||||
| 
 | ||||
| 	if (cfg->C_OnlyVer2point0) | ||||
| 		SUPPORT2point2 = 0; | ||||
| 
 | ||||
|  | @ -1005,7 +992,6 @@ BOOL Start() | |||
| 		PORT->IgnoreUnlocked = PortRec->IGNOREUNLOCKED; | ||||
| 		PORT->INP3ONLY = PortRec->INP3ONLY; | ||||
| 		PORT->ALLOWINP3 = PortRec->AllowINP3; | ||||
| 		PORT->ENABLEINP3 = PortRec->EnableINP3; | ||||
| 
 | ||||
| 		PORT->PORTWINDOW = (UCHAR)PortRec->MAXFRAME; | ||||
| 
 | ||||
|  | @ -1578,10 +1564,6 @@ BOOL Start() | |||
| 
 | ||||
| 	upnpInit(); | ||||
| 
 | ||||
| 	// Start Monitor to file thread
 | ||||
| 	 | ||||
| 	_beginthread(WritePacketLogThread, 0, NULL); | ||||
| 
 | ||||
| 	lastSaveSecs = CurrentSecs = lastSlowSecs = time(NULL); | ||||
| 
 | ||||
| 	return 0; | ||||
|  | @ -2532,9 +2514,9 @@ ENDOFLIST: | |||
| 				{ | ||||
| 					// Stuck link debug check
 | ||||
| 
 | ||||
| 					if (LINK->LINKWINDOW == 0 || LINK->LASTFRAMESENT == 0 || (time(NULL) - LINK->LASTFRAMESENT) > 60)			// No send for 60 secs
 | ||||
| 					if (LINK->LASTFRAMESENT && (time(NULL) - LINK->LASTFRAMESENT) > 60)			// No send for 60 secs
 | ||||
| 					{ | ||||
| 						if (COUNT_AT_L2(LINK) > 16 || LINK->LINKWINDOW == 0) | ||||
| 						if (COUNT_AT_L2(LINK) > 16) | ||||
| 						{ | ||||
| 							// Dump Link State
 | ||||
| 
 | ||||
|  | @ -2693,19 +2675,6 @@ int BPQTRACE(MESSAGE * Msg, BOOL TOAPRS) | |||
| 		L4++; | ||||
| 	} | ||||
| 
 | ||||
| 	// And to the Monitor to File system.
 | ||||
| 
 | ||||
| 
 | ||||
| 	if (MONTOFILEFLAG)		// Trace Enabled?
 | ||||
| 	{ | ||||
| 		Buffer = GetBuff(); | ||||
| 		if (Buffer) | ||||
| 		{ | ||||
| 			memcpy(&Buffer->PORT, &Msg->PORT, BUFFLEN - sizeof(void *));	// Dont copy chain word
 | ||||
| 			C_Q_ADD(&FILEMONVECTOR->HOSTTRACEQ, Buffer); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return TRUE; | ||||
| } | ||||
| ; | ||||
|  |  | |||
							
								
								
									
										38
									
								
								compatbits.h
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								compatbits.h
									
									
									
									
									
								
							|  | @ -49,39 +49,7 @@ Stuff to make compiling on WINDOWS and LINUX easier | |||
| 
 | ||||
| int pthread_equal(pthread_t T1, pthread_t T2); | ||||
| 
 | ||||
| uintptr_t _beginthread(void(__cdecl start_address)(void *), unsigned stack_size, void *arglist); | ||||
| 
 | ||||
| #if defined(_MSC_VER) && _MSC_VER < 1900 | ||||
| 
 | ||||
| #define snprintf c99_snprintf | ||||
| #define vsnprintf c99_vsnprintf | ||||
| 
 | ||||
| __inline int c99_vsnprintf(char *outBuf, size_t size, const char *format, va_list ap) | ||||
| { | ||||
|     int count = -1; | ||||
| 
 | ||||
|     if (size != 0) | ||||
|         count = _vsnprintf_s(outBuf, size, _TRUNCATE, format, ap); | ||||
|     if (count == -1) | ||||
|         count = _vscprintf(format, ap); | ||||
| 
 | ||||
|     return count; | ||||
| } | ||||
| 
 | ||||
| __inline int c99_snprintf(char *outBuf, size_t size, const char *format, ...) | ||||
| { | ||||
|     int count; | ||||
|     va_list ap; | ||||
| 
 | ||||
|     va_start(ap, format); | ||||
|     count = c99_vsnprintf(outBuf, size, format, ap); | ||||
|     va_end(ap); | ||||
| 
 | ||||
|     return count; | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| uintptr_t _beginthread(void(__cdecl *start_address)(void *), unsigned stack_size, void *arglist); | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
|  | @ -184,7 +152,9 @@ int stricmp(const unsigned char * pStr1, const unsigned char *pStr2); | |||
| char * strupr(char* s); | ||||
| char * strlwr(char* s); | ||||
| 
 | ||||
| pthread_t _beginthread(void(start_address)(void *), unsigned stack_size, VOID * arglist); | ||||
| pthread_t _beginthread(void(*start_address)(), unsigned stack_size, VOID * arglist); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| #define WSAGetLastError() errno | ||||
| #define GetLastError() errno  | ||||
|  |  | |||
							
								
								
									
										17
									
								
								config.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								config.c
									
									
									
									
									
								
							|  | @ -309,7 +309,7 @@ static char *keywords[] = | |||
| "LogL4Connects", "LogAllConnects", "SAVEMH", "ENABLEADIFLOG", "ENABLEEVENTS", "SAVEAPRSMSGS",  | ||||
| "EnableM0LTEMap", "MQTT", "MQTT_HOST", "MQTT_PORT", "MQTT_USER", "MQTT_PASS", | ||||
| "L4Compress", "L4CompMaxframe", "L4CompPaclen", "L2Compress", "L2CompMaxframe", | ||||
| "L2CompPaclen", "PREFERINP3ROUTES", "OnlyVer2point0", "DEBUGINP3", "ENABLEOARCAPI" | ||||
| "L2CompPaclen", "PREFERINP3ROUTES", "OnlyVer2point0" | ||||
| };           /* parameter keywords */ | ||||
| 
 | ||||
| static void * offset[] = | ||||
|  | @ -332,7 +332,7 @@ static void * offset[] = | |||
| &xxcfg.C_LogL4Connects, &xxcfg.C_LogAllConnects, &xxcfg.C_SaveMH, &xxcfg.C_ADIF, &xxcfg.C_EVENTS, &xxcfg.C_SaveAPRSMsgs, | ||||
| &xxcfg.C_M0LTEMap, &xxcfg.C_MQTT, &xxcfg.C_MQTT_HOST, &xxcfg.C_MQTT_PORT, &xxcfg.C_MQTT_USER, &xxcfg.C_MQTT_PASS, | ||||
| &xxcfg.C_L4Compress, &xxcfg.C_L4CompMaxframe, &xxcfg.C_L4CompPaclen, &xxcfg.C_L2Compress, &xxcfg.C_L2CompMaxframe,  | ||||
| &xxcfg.C_L2CompPaclen, &xxcfg.C_PREFERINP3ROUTES, &xxcfg.C_OnlyVer2point0,  &xxcfg.C_DEBUGINP3, &xxcfg.C_OARCAPI};		/* offset for corresponding data in config file */ | ||||
| &xxcfg.C_L2CompPaclen, &xxcfg.C_PREFERINP3ROUTES, &xxcfg.C_OnlyVer2point0};		/* offset for corresponding data in config file */ | ||||
| 
 | ||||
| static int routine[] =  | ||||
| { | ||||
|  | @ -354,7 +354,7 @@ static int routine[] = | |||
| 2, 2, 1, 2, 2, 2, | ||||
| 2, 2, 0, 1, 20, 20, | ||||
| 1, 1, 1, 1, 1,  | ||||
| 1, 1, 1, 1, 1};			// Routine to process param
 | ||||
| 1, 1, 1} ;			// Routine to process param
 | ||||
| 
 | ||||
| int PARAMLIM = sizeof(routine)/sizeof(int); | ||||
| //int NUMBEROFKEYWORDS = sizeof(routine)/sizeof(int);
 | ||||
|  | @ -376,7 +376,7 @@ static char *pkeywords[] = | |||
| "BCALL", "DIGIMASK", "NOKEEPALIVES", "COMPORT", "DRIVER", "WL2KREPORT", "UIONLY", | ||||
| "UDPPORT", "IPADDR", "I2CBUS", "I2CDEVICE", "UDPTXPORT", "UDPRXPORT", "NONORMALIZE", | ||||
| "IGNOREUNLOCKEDROUTES", "INP3ONLY", "TCPPORT", "RIGPORT", "PERMITTEDAPPLS", "HIDE", | ||||
| "SMARTID", "KISSCOMMAND", "SendtoM0LTEMap", "PortFreq", "M0LTEMapInfo", "QTSMPort", "ALLOWINP3", "ENABLEINP3"};         /* parameter keywords */ | ||||
| "SMARTID", "KISSCOMMAND", "SendtoM0LTEMap", "PortFreq", "M0LTEMapInfo", "QTSMPort", "ALLOWINP3"};         /* parameter keywords */ | ||||
| 
 | ||||
| static void * poffset[] = | ||||
| { | ||||
|  | @ -390,7 +390,7 @@ static void * poffset[] = | |||
| &xxp.BCALL, &xxp.DIGIMASK, &xxp.DefaultNoKeepAlives, &xxp.IOADDR, &xxp.DLLNAME, &xxp.WL2K, &xxp.UIONLY, | ||||
| &xxp.IOADDR, &xxp.IPADDR, &xxp.INTLEVEL, &xxp.IOADDR, &xxp.IOADDR, &xxp.ListenPort, &xxp.NoNormalize, | ||||
| &xxp.IGNOREUNLOCKED, &xxp.INP3ONLY, &xxp.TCPPORT, &xxp.RIGPORT, &xxp.PERMITTEDAPPLS, &xxp.Hide, | ||||
| &xxp.SmartID, &xxp.KissParams, &xxp.SendtoM0LTEMap, &xxp.PortFreq, &xxp.M0LTEMapInfo, &xxp.QtSMPort, &xxp.AllowINP3, &xxp.EnableINP3};	/* offset for corresponding data in config file */ | ||||
| &xxp.SmartID, &xxp.KissParams, &xxp.SendtoM0LTEMap, &xxp.PortFreq, &xxp.M0LTEMapInfo, &xxp.QtSMPort, &xxp.AllowINP3};	/* offset for corresponding data in config file */ | ||||
| 
 | ||||
| static int proutine[] =  | ||||
| { | ||||
|  | @ -404,7 +404,7 @@ static int proutine[] = | |||
| 0, 1, 2, 18, 15, 16, 2, | ||||
| 1, 17, 1, 1, 1, 1, 2, | ||||
| 2, 2, 1, 1, 19, 2, | ||||
| 1, 20, 1, 21, 22, 1, 1, 1};							/* routine to process parameter */ | ||||
| 1, 20, 1, 21, 22, 1, 1};							/* routine to process parameter */ | ||||
| 
 | ||||
| int PPARAMLIM = sizeof(proutine)/sizeof(int); | ||||
| 
 | ||||
|  | @ -601,6 +601,7 @@ BOOL ProcessConfig() | |||
| 			 | ||||
| 	 | ||||
| 	for (i=0;i<24;i++) | ||||
| 		 | ||||
| 		paramok[45+i]=1;	/* or APPLCALLS, APPLALIASS APPLQUAL */ | ||||
| 
 | ||||
| 	paramok[69]=1;			// BText optional
 | ||||
|  | @ -629,9 +630,7 @@ BOOL ProcessConfig() | |||
| 	paramok[90]=1;			// L2Compress Maxframe
 | ||||
| 	paramok[91]=1;			// L2Compress Paclen
 | ||||
| 	paramok[92]=1;			// PREFERINP3ROUTES
 | ||||
| 	paramok[93]=1;			// ONLYVer2point0
 | ||||
| 	paramok[94]=1;			// DEBUGINP3
 | ||||
| 	paramok[95]=1;			// EnableOARCAPI
 | ||||
| 	paramok[93]=1;			// C_ONLYVer2point0
 | ||||
| 
 | ||||
| 	for (i=0; i < PARAMLIM; i++) | ||||
| 	{ | ||||
|  |  | |||
|  | @ -82,7 +82,6 @@ struct PORTCONFIG | |||
| 	char * M0LTEMapInfo; | ||||
| 	int QtSMPort; | ||||
| 	int AllowINP3; | ||||
| 	int EnableINP3; | ||||
| }; | ||||
| 
 | ||||
| struct ROUTECONFIG | ||||
|  | @ -180,8 +179,6 @@ struct CONFIGTABLE | |||
| 	int C_L2CompPaclen; | ||||
| 	int C_PREFERINP3ROUTES; | ||||
| 	int C_OnlyVer2point0; | ||||
| 	int C_DEBUGINP3; | ||||
| 	int C_OARCAPI; | ||||
| 
 | ||||
| 
 | ||||
| //#define ApplOffset 80000			// Applications offset in config buffer
 | ||||
|  |  | |||
|  | @ -35,9 +35,6 @@ int RFOnly = 0; | |||
| 
 | ||||
| int MAXRTT = 9000;			// 90 secs
 | ||||
| int MaxHops = 4; | ||||
| int DEBUGINP3 = 0; | ||||
| 
 | ||||
| int EnableOARCAPI = 0; | ||||
| 
 | ||||
| int RTTInterval = 24;		// 4 Minutes
 | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										13
									
								
								debian/changelog
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								debian/changelog
									
									
									
									
										vendored
									
									
								
							|  | @ -1,16 +1,3 @@ | |||
| linbpq (6.0.25.06+repack-2~hibbian13+1) UNRELEASED; urgency=medium | ||||
| 
 | ||||
|   * Build on latest gcc standards | ||||
| 
 | ||||
|  -- Dave Hibberd <hibby@debian.org>  Fri, 10 Oct 2025 23:55:05 +0100 | ||||
| 
 | ||||
| linbpq (6.0.25.06+repack-1~hibbian13+1) trixie-hibbian-unstable; urgency=medium | ||||
| 
 | ||||
|   * New upstream version 6.0.25.06+repack | ||||
|   * MINI_BUILDD_OPTION: auto-ports=trixie-packetrepo-unstable,bookworm-packetrepo-unstable,bullseye-packetrepo-unstable,noble-packetrepo-unstable,jammy-packetrepo-unstable | ||||
| 
 | ||||
|  -- Dave Hibberd <hibby@debian.org>  Fri, 10 Oct 2025 23:42:04 +0100 | ||||
| 
 | ||||
| linbpq (6.0.25.1+repack-1~hibbian13+1) trixie-hibbian-unstable; urgency=medium | ||||
| 
 | ||||
|    * New upstream version 6.0.25.1+repack | ||||
|  |  | |||
							
								
								
									
										1
									
								
								debian/rules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								debian/rules
									
									
									
									
										vendored
									
									
								
							|  | @ -1,6 +1,7 @@ | |||
| #!/usr/bin/make -f | ||||
| 
 | ||||
| export DEB_BUILD_MAINT_OPTIONS=hardening=+all | ||||
| export DEB_CFLAGS_MAINT_APPEND=-std=gnu17 | ||||
| 
 | ||||
| %: | ||||
| 	dh $@ | ||||
|  |  | |||
							
								
								
									
										10
									
								
								kiss.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								kiss.c
									
									
									
									
									
								
							|  | @ -1905,7 +1905,7 @@ int i2cPoll(struct PORTCONTROL * PORT, NPASYINFO npKISSINFO) | |||
| 
 | ||||
| // KISS Over TCP Routines
 | ||||
| 
 | ||||
| VOID ConnecttoTCPThread(void * Param); | ||||
| VOID ConnecttoTCPThread(NPASYINFO ASY); | ||||
| 
 | ||||
| int ConnecttoTCP(NPASYINFO ASY) | ||||
| { | ||||
|  | @ -1914,9 +1914,8 @@ int ConnecttoTCP(NPASYINFO ASY) | |||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| VOID ConnecttoTCPThread(void * Param) | ||||
| VOID ConnecttoTCPThread(NPASYINFO ASY) | ||||
| { | ||||
| 	NPASYINFO ASY = (NPASYINFO)Param; | ||||
| 	char Msg[255]; | ||||
| 	int err,i; | ||||
| 	u_long param=1; | ||||
|  | @ -2132,7 +2131,7 @@ int KISSGetTCPMessage(NPASYINFO ASY) | |||
| // Interface to QtSM Managmemt Interface
 | ||||
| 
 | ||||
| 
 | ||||
| VOID QtSMThread(void * Param); | ||||
| VOID QtSMThread(struct PORTCONTROL * PORT); | ||||
| 
 | ||||
| VOID ConnecttoQtSM(struct PORTCONTROL * PORT) | ||||
| { | ||||
|  | @ -2142,12 +2141,11 @@ VOID ConnecttoQtSM(struct PORTCONTROL * PORT) | |||
| 	return ; | ||||
| } | ||||
| 
 | ||||
| VOID QtSMThread(void * Param) | ||||
| VOID QtSMThread(struct PORTCONTROL * PORT) | ||||
| { | ||||
| 	// This is the Managemt Interface in QtSM. It receives PTT ON/OFF msgs from QtSM and allows changing modem mode and freq.
 | ||||
| 	//	Also will collect link usage stats
 | ||||
| 	 | ||||
| 	struct PORTCONTROL * PORT = (struct PORTCONTROL *)Param; | ||||
| 	char Msg[255]; | ||||
| 	int err, i, ret; | ||||
| 	u_long param = 1; | ||||
|  |  | |||
|  | @ -852,14 +852,14 @@ double LatFromLOC = 0; | |||
| double LonFromLOC = 0; | ||||
| #endif | ||||
| 
 | ||||
| void SendBBSDataToPktMapThread(void * Param); | ||||
| void SendBBSDataToPktMapThread(); | ||||
| 
 | ||||
| void SendBBSDataToPktMap() | ||||
| { | ||||
| 	_beginthread(SendBBSDataToPktMapThread, 0, 0); | ||||
| } | ||||
| 
 | ||||
| void SendBBSDataToPktMapThread(void * Param) | ||||
| void SendBBSDataToPktMapThread() | ||||
| { | ||||
| 	char Request[64]; | ||||
| 	char * Params; | ||||
|  |  | |||
							
								
								
									
										160
									
								
								nodeapi.c
									
									
									
									
									
								
							
							
						
						
									
										160
									
								
								nodeapi.c
									
									
									
									
									
								
							|  | @ -9,7 +9,6 @@ | |||
| #include <stdlib.h> | ||||
| #include "tncinfo.h" | ||||
| #include "asmstrucs.h" | ||||
| #include "telnetserver.h" | ||||
| #include "kiss.h" | ||||
| 
 | ||||
| // Constants
 | ||||
|  | @ -57,7 +56,6 @@ int sendUserList(char * response, char * token, char * Rest, int Local); | |||
| int sendInfo(char * response, char * token, char * Rest, int Local); | ||||
| int sendLinks(char * response, char * token, char * Rest, int Local); | ||||
| int sendPortMHList(char * response, char * token, char * Rest, int Local); | ||||
| int sendPortQState(char * response, char * token, char * Rest, int Local); | ||||
| int sendWhatsPacState(char * response, char * token, char * param, int Local); | ||||
| int sendWhatsPacConfig(char * response, char * token, char * param, int Local); | ||||
| 
 | ||||
|  | @ -76,7 +74,6 @@ struct API APIList[] = | |||
| 	"/api/links", 10, sendLinks, 0, | ||||
| 	"/api/users", 10, sendUserList, 0, | ||||
| 	"/api/mheard", 11, sendPortMHList, 0, | ||||
| 	"/api/tcpqueues", 14, sendPortQState, 0, | ||||
| 	"/api/v1/config", 14, sendWhatsPacConfig, AuthSysop, | ||||
| 	"/api/v1/state", 13, sendWhatsPacState, AuthSysop | ||||
| }; | ||||
|  | @ -828,166 +825,11 @@ int sendPortMHList(char * response, char * token, char * param, int Local) | |||
| 		{ | ||||
| 			response[strlen(response)-3 ] = '\0';          // remove ,\r\n
 | ||||
| 			strcat(response, "\r\n]}\r\n"); | ||||
| 		//      printf("MH for port %d:\r\n%s\r\n", PORTVEC->PORTNUMBER, response);
 | ||||
| 	} | ||||
| 
 | ||||
| 	return strlen(response); | ||||
| } | ||||
| 
 | ||||
| int sendPortQState(char * response, char * token, char * param, int Local) | ||||
| { | ||||
| 	struct TNCINFO * TNC; | ||||
| 	struct TCPINFO * TCP; | ||||
| 	struct ConnectionInfo * Conn; | ||||
| 	struct STREAMINFO * STREAM; | ||||
| 	int Stream; | ||||
| 	int tcpqueue; | ||||
| 	int Queued; | ||||
| 	int n; | ||||
| 	int port = 0; | ||||
| 	char Type[10]; | ||||
| 	char Appl[20]; | ||||
| 	int radioport = 0; | ||||
| 
 | ||||
| 
 | ||||
| 	if (param[0] = '?' || param[0] == '/') | ||||
| 		port = atoi(¶m[1]); | ||||
| 
 | ||||
| 	TNC = TNCInfo[port]; | ||||
| 
 | ||||
| 	// At the moment only supports Telnet Ports
 | ||||
| 
 | ||||
| 	if (TNC == 0 || TNC->Hardware != H_TELNET) | ||||
| 		return send_http_response(response, "401 Invalid API Call"); | ||||
| 
 | ||||
| 	response[0] = 0; | ||||
| 
 | ||||
| 
 | ||||
| 	TCP = TNC->TCPInfo; | ||||
| 
 | ||||
| 	if (TCP == 0) | ||||
| 		return send_http_response(response, "401 Invalid API Call"); | ||||
| 
 | ||||
| 	n = sprintf(response,"{\"QState\":[\r\n"); | ||||
| 
 | ||||
| 	for (Stream = 0; Stream <= TCP->MaxSessions; Stream++) | ||||
| 	{ | ||||
| 		char Call[10];	 | ||||
| 		STREAM = &TNC->Streams[Stream]; | ||||
| 
 | ||||
| 		Conn = TNC->Streams[Stream].ConnectionInfo; | ||||
| 
 | ||||
| 
 | ||||
| 		// if connected to the node
 | ||||
| 
 | ||||
| 		if (Conn->SocketActive) | ||||
| 		{ | ||||
| 			TRANSPORTENTRY * Sess1 = TNC->PortRecord->ATTACHEDSESSIONS[Stream]; | ||||
| 			TRANSPORTENTRY * Sess2 = NULL; | ||||
| 
 | ||||
| 			if (Sess1) | ||||
| 				Sess2 = Sess1->L4CROSSLINK; | ||||
| 			else | ||||
| 				continue; | ||||
| 
 | ||||
| 			radioport = 0; | ||||
| 			 | ||||
| 			// Can't use TXCount - it is Semaphored=
 | ||||
| 
 | ||||
| 			Queued = C_Q_COUNT(&TNC->Streams[Stream].PACTORtoBPQ_Q); | ||||
| 			Queued += C_Q_COUNT((UINT *)&TNC->PortRecord->PORTCONTROL.PORTRX_Q); | ||||
| 
 | ||||
| 			if (Sess2) | ||||
| 				Queued += CountFramesQueuedOnSession(Sess2); | ||||
| 
 | ||||
| 			if (Sess1) | ||||
| 				Queued += CountFramesQueuedOnSession(Sess1); | ||||
| 
 | ||||
| 
 | ||||
| 	//		CountFramesQueuedOnSession(TRANSPORTENTRY * Session)
 | ||||
| 
 | ||||
| 			tcpqueue = Conn->FromHostBuffPutptr - Conn->FromHostBuffGetptr; | ||||
| 
 | ||||
| 			if (Sess2) | ||||
| 				Sess1 = Sess2; | ||||
| 	 | ||||
| 			Call[ConvFromAX25(Sess1->L4USER, Call)] = 0; | ||||
| 			 | ||||
| 
 | ||||
| 			if (Sess1->L4CIRCUITTYPE & BPQHOST) | ||||
| 				strcpy(Type, "Host"); | ||||
| 	 | ||||
| 			else if (Sess1->L4CIRCUITTYPE & SESSION) | ||||
| 			{ | ||||
| 				struct DEST_LIST * DEST = Sess1->L4TARGET.DEST; | ||||
| 
 | ||||
| 				strcpy(Type, "NETROM"); | ||||
| 
 | ||||
| 				if (DEST) | ||||
| 				{ | ||||
| 					int ActiveRoute = DEST->DEST_ROUTE; | ||||
| 
 | ||||
| 					if (ActiveRoute) | ||||
| 					{ | ||||
| 						struct ROUTE * ROUTE = DEST->NRROUTE[ActiveRoute - 1].ROUT_NEIGHBOUR; | ||||
| 
 | ||||
| 						if (ROUTE) | ||||
| 						{ | ||||
| 							struct _LINKTABLE * LINK = ROUTE->NEIGHBOUR_LINK; | ||||
| 				 | ||||
| 							if (LINK && LINK->LINKPORT) | ||||
| 								radioport = LINK->LINKPORT->PORTNUMBER; | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			else if (Sess1->L4CIRCUITTYPE & PACTOR) | ||||
| 			{ | ||||
| 				//	PACTOR Type - Frames are queued on the Port Entry
 | ||||
| 
 | ||||
| 				struct PORTCONTROL * PORT = Sess1->L4TARGET.PORT; | ||||
| 				strcpy(Type, "HFLINK"); | ||||
| 
 | ||||
| 				if (PORT) | ||||
| 					radioport = PORT->PORTNUMBER; | ||||
| 
 | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				struct _LINKTABLE * LINK = Sess1->L4TARGET.LINK; | ||||
| 			 | ||||
| 				strcpy(Type, "L2 Link"); | ||||
| 
 | ||||
| 				if (LINK && LINK->LINKPORT) | ||||
| 					radioport = LINK->LINKPORT->PORTNUMBER; | ||||
| 			} | ||||
| 
 | ||||
| 
 | ||||
| 			memcpy(Appl, Sess1->APPL, 16); | ||||
| 			strlop(Appl, ' '); | ||||
| 	 | ||||
| 			n += sprintf(&response[n], "{\"APPL\": \"%s\", \"callSign\": \"%s\", \"type\": \"%s\", \"tcpqueue\": %d, \"packets\": %d, \"port\": %d},\r\n" , Appl, Call, Type, tcpqueue, Queued, radioport); | ||||
| 		 | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if (n < 20)		// No entries
 | ||||
| 	{ | ||||
| 		response[strlen(response) - 2] = '\0';          // remove \r\n
 | ||||
| 		strcat(response, "]}\r\n"); | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		response[strlen(response)-3 ] = '\0';          // remove ,\r\n
 | ||||
| 		strcat(response, "\r\n]}\r\n"); | ||||
| 		//      printf("MH for port %d:\r\n%s\r\n", PORTVEC->PORTNUMBER, response);
 | ||||
| //      printf("MH for port %d:\r\n%s\r\n", PORTVEC->PORTNUMBER, response);
 | ||||
| 		} | ||||
| 		return strlen(response); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| // WhatsPac configuration interface
 | ||||
| // WhatsPac also uses Paula's Remote Host Protocol (RHP). This is in a separate module
 | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue