// // Common definitons for Pactor-like Modules #include "kernelresource.h" #include "rigcontrol.h" #define MAXBLOCK 4096 #define MAXFREQS 20 // RigControl freqs to scan extern char HFCTEXT[81]; extern int HFCTEXTLEN; extern HANDLE hInstance; extern HMENU hMainFrameMenu; extern HMENU hWndMenu; /* struct WL2KInfo { struct WL2KInfo * Next; char * Host; short WL2KPort; char RMSCall[10]; char BaseCall[10]; char GridSquare[7]; char Times[80]; char ServiceCode[17]; BOOL UseRigCtrlFreqs; char WL2KFreq[12]; char WL2KMode; // WL2K reporting mode char WL2KModeChar; // W or N BOOL DontReportNarrowOnWideFreqs; // char NARROWMODE; // char WIDEMODE; // Mode numbers to report to WL2K // struct WL2KInfo WL2KInfoList[MAXFREQS]; // Freqs for sending to WL2K int Freq; char Bandwidth; // char * TimeList; // eg 06-10,12-15 int mode; // see below (an integer) int baud; // see below (an integer) int power; // actual power if known, default to 100 for HF, 30 for VHF/UHF (an integer) int height; // antenna height in feet if known, default to 25 int gain; // antenna gain if known, default to 0 int direction; // primary antenna direction in degrees if known, use 000 for omni (an integer) BOOL RPonPTC; // Set if scanning for Robust Packet on a PTC }; */ #pragma pack(1) // AGWPE Header Structure struct AGWHEADER { UCHAR Port; UCHAR filler1[3]; char DataKind; UCHAR filler2; unsigned char PID; UCHAR filler3; unsigned char callfrom[10]; unsigned char callto[10]; int DataLength; int reserved; }; #pragma pack() // Telnet Server User Record struct UserRec { char * Callsign; char * UserName; char * Password; char * Appl; // Autoconnect APPL BOOL Secure; // Authorised User }; struct LOCALNET { struct LOCALNET * Next; uint32_t Network; uint32_t Mask; }; #define MaxCMS 10 // Number of addresses we can keep - currently 4 are used. struct TCPINFO { int NumberofUsers; struct UserRec ** UserRecPtr; int CurrentConnections; struct UserRec RelayUser; int CurrentSockets; int TCPPort; int FBBPort[100]; int RelayPort; int HTTPPort; int APIPort; int TriModePort; int SyncPort; int SNMPPort; int DRATSPort; int CMDPort[33]; char RELAYHOST[64]; char CMSServer[64]; BOOL FallbacktoRelay; // Use Relsy if can't connect to CMS BOOL IPV4; // Allow Connect using IPV4 BOOL IPV6; // Allow Connect using IPV6 BOOL CMS; // Allow Connect to CMS BOOL CMSOK; // Internet link is ok. BOOL UseCachedCMSAddrs; struct in_addr CMSAddr[MaxCMS]; BOOL CMSFailed[MaxCMS]; // Set if connect to CMS failed. char * CMSName[MaxCMS]; // Reverse DNS Name of Server int NumberofCMSAddrs; int NextCMSAddr; // Round Robin Pointer int CheckCMSTimer; // CMS Poll Timer char SecureCMSPassword[80]; // For Secure CMS Signin char GatewayCall[10]; // Call for CMS access char GatewayLoc[10]; // Loc - Needed to report Hybrid Mode int ReportHybrid; // Report as Hybrod Station char * HybridServiceCode; char * HybridFrequencies; char * HybridCoLocatedRMS; BOOL DisconnectOnClose; char PasswordMsg[100]; char cfgHOSTPROMPT[100]; char cfgCTEXT[300]; char cfgLOCALECHO[100]; int MaxSessions; char LoginMsg[100]; char RelayAPPL[20]; char SyncAPPL[20]; SOCKET TCPSock; SOCKET FBBsock[100]; SOCKET Relaysock; SOCKET HTTPsock; SOCKET APIsock; SOCKET TriModeSock; SOCKET TriModeDataSock; SOCKET Syncsock; SOCKET DRATSsock; SOCKET SNMPsock; struct ConnectionInfo * TriModeControlSession; SOCKET sock6; SOCKET FBBsock6[100]; SOCKET Relaysock6; SOCKET HTTPsock6; SOCKET APIsock6; SOCKET Syncsock6; SOCKET DRATSsock6; fd_set ListenSet; SOCKET maxsock; HMENU hActionMenu; HMENU hLogMenu; HMENU hDisMenu; // Disconnect Menu Handle HWND hCMSWnd; int SecureTelnet; int ReportRelayTraffic; // Send WL2K Reports for Relay Traffic char * WebTermCSS; // css override for web terminal struct LOCALNET * LocalNets; }; struct STREAMINFO { // TRANSPORTENTRY * AttachedSession; void * PACTORtoBPQ_Q; // Frames for BPQ void * BPQtoPACTOR_Q; // Frames for PACTOR int FramesOutstanding; // Frames Queued - used for flow control int FramesQueued; // Frames Queued - used for flow control BOOL InternalCmd; // Last Command was generated internally int IntCmdDelay; // To limit internal commands BOOL CheckingCall; // Set on PTC if waiting for I response after a Connect RXed BOOL Attached; // Set what attached to a BPQ32 stream BOOL Connected; // When set, all data is passed as data instead of commands BOOL Connecting; // Set when Outward Connect in progress BOOL Disconnecting; // Set when disconnect in progress // Used when appplication disconnects the bpq session, and // prevents new attaches while a dirty disconnect is in progress int DisconnectingTimeout; // A hard disconnect occurs if this expires before the disconnect complete int ReportDISC; // Need to report an incoming DISC to kernel BOOL DiscWhenAllSent; // Close session when all msgs have been sent to node BOOL ARQENDSent; // Set when V4 ARQEND Sent int DEDStream; // Stream number for DED interface (same as index except for pactor) char MyCall[10] ; // Call we are using char RemoteCall[10]; // Callsign char callingCall[10]; // for reporting. Link and Our calls depand on which end connected char receivingCall[10]; // for reporting. Link and Our calls depand on which end connected char Direction[4]; // In or Out char AGWKey[21]; // Session Key for AGW Session Based Drivers time_t ConnectTime; // Time connection made time_t AttachTime; int bytesTXed; int BytesAcked; int bytesRXed; int PacketsSent; int BytesResent; int BytesOutstanding; // For Packet Channels UCHAR PTCStatus0; // Status Bytes UCHAR PTCStatus1; // Status Bytes UCHAR PTCStatus2; // Status Bytes UCHAR PTCStatus3; // Status Bytes char * CmdSet; // A series of commands to send to the TNC char * CmdSave; // Base address for free struct ConnectionInfo * ConnectionInfo; // TCP Server Connection Info int TimeInRX; // Too long in send mode timer int NeedDisc; // Timer to send DISC if appl not available BOOL NoCMSFallback; // Dont use relay if CMS not available struct ARQINFO * ARQInfo; // FLDIGI/FLARQ Stream Mode Specific Data HWND xIDC_MYCALL; HWND xIDC_DESTCALL; HWND xIDC_STATUS; HWND xIDC_SEND; HWND xIDC_RXED; HWND xIDC_RESENT; HWND xIDC_ACKED; HWND xIDC_DIRN; int RelaySyncStream; int VaraACMode; }; typedef struct AGWINFO { // Fields for AGW Session based Ports (eg UZ7HO Modem) struct AGWHEADER TXHeader; struct AGWHEADER RXHeader; int MaxSessions; int ConnTimeOut; int PollDelay; time_t LastParamTime; #ifdef WIN32 // For selecting UZ7HO Mode and Freq COMBOBOXINFO cbinfo; // UZ7HO Modem Combo Box info HWND hFreq; // UZ7HO Frequency Box HWND hSpin; // UZ7HO Spin Button #endif int isQTSM; // Flag to Identify QtSM int CenterFreq; int Modem; // Modem number in list char ModemName[20]; unsigned char Version[4]; unsigned char fx25Flags; unsigned char il2pFlags; unsigned char il2pcrc; } *PAGWINFO; typedef struct ARQINFO { // Fields for FLDIGI/FLARQ Ports // Max window is 64, though often will use less char OurStream; char FarStream; PMSGWITHLEN TXHOLDQ[64]; // Frames waiting ACK PMSGWITHLEN RXHOLDQ[64]; // Frames waiting missing frames. int TXWindow; int RXWindow; int MaxBlock; // Max sending block size int TXSeq; int TXLastACK; // Last frame ACK'ed int RXHighest; int RXNext; int RXNoGaps; int Retries; int NoAckRetries; // Status received but no data acked int ARQTimer; int ARQState; #define ARQ_ACTIVE 1 // Have a session of some type int ARQTimerState; #define ARQ_CONNECTING 1 #define ARQ_CONNECTACK 2 #define ARQ_DISC 3 #define ARQ_WAITACK 4 #define ARQ_WAITDATA 5 // Waiting for more data before polling char LastMsg[80]; // Last message sent that expects an ack int LastLen; char TXMsg[80]; // Message to aend after TXDELAY int TXLen; int TurnroundTimer; // RX to TX delay. int TXDelay; } *ARQINFO; typedef struct FLINFO { // Fields for MPSK Session Ports ) BOOL TX; // Set when FLDigi is transmitting char DefaultMode[64]; // Mode to return to after session int DefaultFreq; // Freq to return to after session BOOL Beacon; // Use ALE Beacons char LastXML[128]; // Last XML Request Sent int XMLControl; // Controlls polling FLDigi by XML int CmdControl; // Controlls polling FLDigi by KISS Command BOOL FLARQ; // Connection from FLARQ BOOL Busy; BOOL CONOK; // Allow incoming connects BOOL KISSMODE; // Using KISS instead of socket interface BOOL RAW; // Raw (ARQ Socket or KISS RAW, depening on above) int CenterFreq; char CurrentMode[20]; // Mode to return to after session int Responding; // If FLDigi is responding to conmands BOOL MCASTMODE; // If port is in MCAST RX MOde } *FLINFO; typedef struct MPSKINFO { // Fields for MPSK Session Ports ) int ConnTimeOut; BOOL TX; // Set when Multipsk is transmitting char DefaultMode[20]; // Mode to return to after session BOOL Beacon; // Use ALE Beacons int MaxSessions; } *MPSKINFO; struct FreeDataINFO { int startingTNC; int TNCRunning; int Conecting; int Connected; char ourCall[10]; char toCall[10]; char farCall[10]; // TNC Call char useBaseCall; // Use base call (without ssid) for TNC Call char * Capture; // Capture Device Name char * Playback; // Playback Device Name char * hamlibHost; int hamlibPort; unsigned char toSendData[8192]; // Buffer data from node for more efficiency int toSendCount; int toSendTimeout; unsigned char toSendMsg[256]; // Buffer data from node for more efficiency int toSendMsgCount; int toSendMsgTimeout; char * RXDir; // Directory for Received Files int CONOK; // Virtual Lisren Flag int Chat; // In Chat Mode char ChatCall[10]; int needPoll; // Set if get data needed int arqstate; // 1 = Disc / 2 - connecting 3 - connected int TuningRange; // Must be 50, 100, 150, 200, 250 int LimitBandWidth; int TXLevel; int Explorer; // Enable reporting to Freedata Explorer char SSIDList[256]; char * SSIDS[16]; }; struct sixPackInfo; typedef struct TNCINFO { HWND hDlg; // Status Window Handle int (FAR * WebWindowProc)(struct TNCINFO * TNC, char * Buff, BOOL LOCAL); // Routine to build web status window int WebWinX; int WebWinY; // Size of window char * WebBuffer; // Buffer for logs int RigControlRow; // Rig Control Line in Dialog struct _EXTPORTDATA * PortRecord; // BPQ32 port record for this port struct RIGINFO * RIG; // Pointer to Rig Control RIG record for RX or Both struct RIGINFO * TXRIG; // Pointer to Rig Control RIG record for TX char * InitScript; // Initialisation Commands int InitScriptLen; // Length time_t SessionTimeLimit; // Optional limit to total session time time_t DefaultSessionTimeLimit; // Configured value time_t AttachTimeLimit; // to trap port left attached for a long time without other activity time_t AttachTime; int Hardware; // Hardware Type #define H_WINMOR 1 #define H_SCS 2 #define H_KAM 3 #define H_AEA 4 #define H_HAL 5 #define H_TELNET 6 #define H_TRK 7 #define H_TRKM 7 #define H_V4 8 #define H_UZ7HO 9 #define H_MPSK 10 #define H_FLDIGI 11 #define H_UIARQ 12 #define H_ARDOP 13 #define H_VARA 14 #define H_SERIAL 15 #define H_KISSHF 16 #define H_WINRPR 17 #define H_HSMODEM 18 #define H_FREEDATA 19 #define H_SIXPACK 20 int Port; // BPQ Port Number struct RIGINFO DummyRig; // Used if not using Rigcontrol BOOL Minimized; // Start Minimized flag void * WINMORtoBPQ_Q; // Frames for BPQ, indexed by BPQ Port void * BPQtoWINMOR_Q; // Frames for WINMOR. indexed by WINMOR port. Only used it TCP session is blocked SOCKET TCPSock; // Control Socket SOCKET TCPDataSock; // Data Socket SOCKET PacketSock; // Packet Over TCP (ARDOP) char * WINMORSignon; // Pointer to message for secure signin char * HostName; // WINMOR Host - may be dotted decimal or DNS Name int TCPPort; // int PacketPort; // Packet Over TCP (ARDOP) char * ApplCmd; // Application to connect to on incoming connect (null = leave at command handler) BOOL SwallowSignon; // Set to suppress *** connected to APPL union { UCHAR TCPBuffer[1000]; // For converting byte stream to messages UCHAR DEDBuffer[1000]; // For converting byte stream to messages UCHAR KISSBuffer[1000]; // For KISS over Host Mode }; UCHAR * ARDOPBuffer; // Needs to be pretty big, so Malloc UCHAR * ARDOPDataBuffer; // Needs to be pretty big, so Malloc int InputLen; // Data we have already = Offset of end of an incomplete packet; int DataInputLen; // Data we have already = Offset of end of an incomplete packet; int KISSInputLen; // Data we have already = Offset of end of an incomplete packet; int ESCFLAG; // KISS Escape received int MSGCOUNT; // DED WORKING FIELD int MSGLENGTH; // DED Msg Len int MSGCHANNEL; // DED Msg Channel Number int MSGTYPE; // DED Msg Type int HOSTSTATE; // ded HOST state machine BOOL StartSent; // Codec Start send (so will get a disconnect) int ConnectPending; // Set if Connect Pending Received. If so, mustn't allow freq change. BOOL GavePermission; // Set if we allowed freq change BOOL DiscPending; // Set if Disconnect Pending Received. So we can time out stuck in Disconnecting BOOL HadConnect; // Flag to say have been in session BOOL FECMode; // In FEC Mode BOOL FEC1600; // Use 1600 Hz FEC Mode int FECIDTimer; // Time in FEC Mode. Used to trigger ID broadcasts BOOL RestartAfterFailure; BOOL StartInRobust; // For WINMOR, set to Robust Mode for first few packets int Busy; // Channel Busy Timer/Counter . Non-zero = Busy int BusyFlags; // Channel Busy Flags #define CDBusy 1 // For WINMOR - reported busy (set till reported clear) #define PTTBusy 2 // PTT Active BOOL FECPending; // Need an FEC Send when channel is next idle time_t lasttime; BOOL CONNECTING; // TCP Session Flags BOOL CONNECTED; BOOL Alerted; // Connect Failed Prompt sent BOOL DATACONNECTING; BOOL DATACONNECTED; BOOL TNCCONNECTING; // For FreeData BOOL TNCCONNECTED; BOOL QtSMConnected; char NodeCall[10]; // Call we listen for (PORTCALL or NODECALL char CurrentMYC[10]; // Save current call so we don't change it unnecessarily char * LISTENCALLS; // Calls TNC will respond to (currently only for VARA) char TargetCall[10]; // Call incoming connect is addressed to (for appl call support) struct sockaddr_in destaddr; struct sockaddr_in Datadestaddr; int PTTMode; // PTT Mode Flags int PTTState; // Current State uint64_t PTTActivemS; // For Stats uint64_t PTTonTime; // uint64_t BusyActivemS; // For channel busy stats uint64_t BusyonTime; char PTTOn[60]; // Port override of RIGCONTROL config char PTTOff[60]; int PTTOnLen; int PTTOffLen; int TXRadio; // Rigcontrol Radio Number for TX int RXRadio; // Rigcontrol Radio Number for RX long long int TXFreq; // Freq to set on tx before ptt double ActiveTXFreq; // Freq to set on tx after attach double ActiveRXFreq; // Freq to set on rx after attach double DefaultTXFreq; // Freq to set on tx after close double DefaultRXFreq; // Freq to set on rx after close char ** DisconnectScript; // May replace above 2 params int TXOffset; // Correction to TXFreq int PID; // Process ID for Software TNC HWND hWnd; // Main window handle for Software TNC char * CaptureDevices; char * PlaybackDevices; char * ProgramPath; BOOL WeStartedTNC; int Restarts; // TNC Kill/Restarts done time_t LastRestart; int TimeSinceLast; // Time since last message from TNC (10ths of a sec) int HeartBeat; // int Interlock; // Port Interlock Group HWND hMonitor; // Handle to Monitor control // HMENU hPopMenu; // Actions Menu Handle int MaxConReq; // For ARDOP int BusyHold; // Hold Time from SCS reporting channel free till we call int BusyWait; // Time to wait for clear channel before connect BOOL OverrideBusy; int BusyDelay; // Timer for busy timeout int AutoStartDelay; // Time to wait for TNC to start char * ConnectCmd; // Saved command if waiting for busy to clear BOOL UseAPPLCalls; // Robust Packet to use Applcalls BOOL UseAPPLCallsforPactor; // Pactor to use Applcalls // Fields for reporting to WL2K Map struct WL2KInfo * WL2K; /* char * Host; short WL2KPort; int UpdateWL2KTimer; BOOL UpdateWL2K; char RMSCall[10]; char BaseCall[10]; char GridSquare[7]; char Comment[80]; char ServiceCode[17]; BOOL UseRigCtrlFreqs; char WL2KFreq[12]; char WL2KModeChar; // W or N BOOL DontReportNarrowOnWideFreqs; // char NARROWMODE; // char WIDEMODE; // Mode numbers to report to WL2K struct WL2KInfo WL2KInfoList[MAXFREQS]; // Freqs for sending to WL2K */ char WL2KMode; // WL2K reporting mode struct STREAMINFO Streams[27]; // 0 is Pactor 1 - 10 are ax.25. int LastStream; // Last one polled for status or send void * BPQtoRadio_Q; // Frames to Rig Interface void * RadiotoBPQ_Q; // Frames from Rig Interface void * KISSTX_Q; // Frames to Host Mode KISS interface struct PORTCONTROL * VirtualPORT; // Pointer to Virtual Packet Port of Host Mode KISS char * InitPtr; // Next Command int ReinitState; // Reinit State Machine int ReinitCount; // Count for DED Recovery int TermReinitCount; // Count for DED Term Mode Recovery BOOL TNCOK; // TNC is reponding int FramesOutstanding; // Frames Queued - used for flow control BOOL InternalCmd; // Last Command was generated internally int IntCmdDelay; // To limit internal commands HANDLE hDevice; int ReopenTimer; // Used to reopen device if failed (eg USB port removed) BOOL HostMode; // Set if in DED Host Mode // BOOL CRCMode; // Set if using SCS Extended DED Mode (JHOST4) BOOL UsingTermMode; // Set if tnc should be left in term mode int Timeout; // Timeout response counter int Retries; int Window; // Window Size for ARQ UCHAR TXBuffer[500]; // Last message sent - saved for Retry int TXLen; // Len of last sent UCHAR RXBuffer[520]; // Message being received - may not arrive all at once UINT RXLen; // Data in RXBUffer UCHAR Toggle; // Sequence bit int Buffers; // Free buffers in TNC BOOL WantToChangeFreq; // Request from Scanner to Change int OKToChangeFreq; // 1 = SCS Says OK to change, -1 = Dont Change zero = still waiting BOOL DontWantToChangeFreq; // Change done - ok to SCS BOOL DontReleasePermission; // Hold Permission to prevent calls on this frequency time_t TimeEnteredSYNCMode; // To detect scan lock when using applcalls on PTC BOOL SyncSupported; // TNC reports sync time_t TimeScanLocked; // ditto for TNCs that don't report SYNC int PTCStatus; // Sync, Idle, Traffic, etc UCHAR NexttoPoll[20]; // Streams with data outstanding (from General Poll) BOOL PollSent; // Toggle to ensure we issue a general poll regularly int StreamtoPoll; char Bandwidth; // Currently set Mode W or N int Mode; // Mode Flag BOOL Dragon; // Set if P4Dragon BOOL DragonSingle; // Set if P4Dragon using Pactor and Packet on same port BOOL DragonKISS; // Set if P4Dragon supports sending KISS frames in Hostmode BOOL EnterExit; // Switching to Term mode to change bandwidth int PktStream; // Stream in use for Packet when in single port mode BOOL MaxLevel; // Pactor Level to set for Wide Mode (3 or 4) int MinLevel; // Mimimum accepted Pactor Level int MinLevelTimer; // Time left to achieve Min Level int PacketChannels; int RobustTime; // For PTC, Spend this part of scan cycle (in 10th secs) in Robust Packet Mode int SwitchToPactor; // Countdown to switch BOOL OldMode; // Use PACTOR instead of TOR (for old software) BOOL VeryOldMode; // Use MYCALL instead of MYPTCALL (for old software) int Mem1; // Free Bytes (VHF /HF) int Mem2; BOOL HFPacket; // Set if HF port is in Packet mode instead of Pactor Mode BOOL Robust; // Set if SCS Tracker is in Robust Packet mode or WINMOR TNC is in Robust Mode BOOL RobustDefault; // Set if SCS Tracker default is Robust Packet mode BOOL ForceRobust; // Don't allow Normal Packet even if scan requests it. BOOL TeensyRPR; // Teensy RPR TNC - don't send %R char NormSpeed[8]; // Speed Param for Normal Packet on Tracker char RobustSpeed[8]; // Speed Param for Robust Packet on Tracker BOOL RPBEACON; // Send Beacon after each session int TimeInRX; // Time waiting for ISS before sending char TXRXState; // Current ISS/IRS State BOOL NeedPACTOR; // Set if need to send PACTOR to put into Standby Mode int CmdStream; // Stream last command was issued on union { struct TCPINFO * TCPInfo; // Telnet Server Specific Data struct AGWINFO * AGWInfo; // AGW Stream Mode Specific Data struct MPSKINFO * MPSKInfo; // MPSK Stream Mode Specific Data struct FLINFO * FLInfo; // FLDIGI Stream Mode Specific Data }; struct ARQINFO * ARQInfo; // FLDIGI/FLARQ Stream Mode Specific Data BOOL DataBusy; // Waiting for Data Ack - Don't send any more data BOOL CommandBusy; // Waiting for Command ACK BOOL TEXTMODE; // Set if AEA in text mode BOOL NeedTurnRound; // Set if we have sent data, so need to send ctrl/z BOOL NeedTRANS; // Set if we have to send TRANS when ctrl/z is acked. char * CmdSet; // A series of commands to send to the TNC char * CmdSave; // Base address for free BOOL PktUpdateMap; // Set if Packet MH data to be sent to NodeMap int DefaultMode; int CurrentMode; // Used on HAL char * DefaultRadioCmd; // RADIO command to send at end of session char * Frequency; // For Mode Map if no Rigcontrol // Mode Equates #define Clover 'C' #define Pactor 'P' #define AMTOR 'A' UCHAR DataBuffer[500]; // Data Chars split from received stream UCHAR CmdBuffer[500]; // Cmd/Response chars split from received stream int DataLen; // Data in DataBuffer int CmdLen; // Data in CmdBuffer BOOL CmdEsc; // Set if last char rxed was 0x80 BOOL DataEsc; // Set if last char rxed was 0x81 int PollDelay; // Don't poll too often; int InData; // FLDigi - MCAST <....> received int InPacket; // FLDigi - SOH or < received. int MCASTLen; // Data still to get int DataMode; // How to treat data #define RXDATA 0x30 // Switch to Receive Data characters #define TXDATA 0x31 // Switch to Transmit Data characters #define SECDATA 0x32 // Switch to RX data from secondary port int TXMode; // Where to send data #define TXMODEM 0x33 // Send TX data to modem #define TXSEC 0x34 // Send TX data to secondary port BOOL XONXOFF; // Set if hardware is using XON/XOFF double LastFreq; // Used by V4 to see if freq has changed int ModemCentre; // Modem centre frequency int ClientHeight; int ClientWidth; HWND xIDC_TNCSTATE; HWND xIDC_COMMSSTATE; HWND xIDC_MODE; HWND xIDC_LEDS; HWND xIDC_TRAFFIC; HWND xIDC_BUFFERS; HWND xIDC_CHANSTATE; HWND xIDC_LEVELS; HWND xIDC_STATE; HWND xIDC_TXRX; HWND xIDC_PROTOSTATE; HWND xIDC_RESTARTTIME; HWND xIDC_RESTARTS; HWND xIDC_PACTORLEVEL; HWND xIDC_TXTUNE; HWND xIDC_TXTUNEVAL; char * WEB_TNCSTATE; char * WEB_COMMSSTATE; char * WEB_MODE; char * WEB_LEDS; char * WEB_TRAFFIC; char * WEB_BUFFERS; char * WEB_CHANSTATE; char * WEB_STATE; char * WEB_TXRX; char * WEB_PROTOSTATE; char * WEB_RESTARTTIME; char * WEB_RESTARTS; char * WEB_PACTORLEVEL; char * WEB_LEVELS; int WEB_CHANGED; // Used to speed up refresh when active HMENU hMenu; HMENU hWndMenu; VOID (* SuspendPortProc) (struct TNCINFO * TNC, struct TNCINFO * ThisTNC); VOID (* ReleasePortProc) (struct TNCINFO * TNC); VOID (* ForcedCloseProc) (struct TNCINFO * TNC, int Stream); time_t WinmorRestartCodecTimer; int WinmorCurrentMode; char ARDOPCurrentMode[10]; char ARDOPCommsMode; char * ARDOPSerialPort; // Have Bus/Device for I2C int ARDOPSerialSpeed; BOOL TCPCONNECTED; // ARDOP over TCP Connected int SlowTimer; int ARQPorts[32]; // For ARQ over KISS char * LogPath; FILE * LogHandle; // Ardop Logging File FILE * DebugHandle; // Ardop Debug File char LastLogType; // For split packets UCHAR * ARDOPAPRS; // Used to reconstruct APRS datagram from FEC packets int ARDOPAPRSLen; BOOL WRITELOG; // Enable debug logging int InputLevelMin; // Sound card levels int InputLevelMax; // Sound card levels int DiscardNextOK; // Used by VARA to suppress OK response to LISTEN commands int SeenCancelPending; // Used by VARA to suppress duplicate cancel pendings MESSAGE * Monframe; // Used by DED Host for receiving Packet Monitor Frame // split over 2 packets struct HSMODEMINFO * HSModemInfo; struct FreeDataINFO * FreeDataInfo; int DontRestart; // Don't automatically restart failed TNC int SendTandRtoRelay; // Send T and R suffix messages to RELAY instead of CMS double SNR; // S/N Ratio (VARA) int NetRomMode; unsigned char * NetRomTxBuffer; // For Netrom over VARA int NetRomTxLen; char * NRNeighbour; int NRCloseTimer; struct _LINKTABLE * DummyLink; // Simulated link to simplify interface to ax,25 netrom code struct sixPackPortInfo * sixPack; int VaraACAllowed; // Set by config int VaraACMode; // Set by first message received int VaraModeSet; // Have decicded if VarAC mode or not char * VARACMsg; // to build message from packets int VarACTimer; // delayed send timer size_t VARACSize; // malloc'ed size } *PTNCINFO; VOID * zalloc(int len); BOOL ReadConfigFile(int Port, int ProcLine()); int GetLine(char * buf); BOOL CreatePactorWindow(struct TNCINFO * TNC, char * ClassName, char * WindowTitle, int RigControlRow, WNDPROC WndProc, int Width, int Height, VOID ForcedCloseProc()); char * CheckAppl(struct TNCINFO * TNC, char * Appl); BOOL SendReporttoWL2K(struct TNCINFO * TNC); struct WL2KInfo * DecodeWL2KReportLine(char * buf); VOID UpdateMH(struct TNCINFO * TNC, UCHAR * Call, char Mode, char Direction); VOID UpdateMHEx(struct TNCINFO * TNC, UCHAR * Call, char Mode, char Direction, char * LOC, BOOL Report); VOID SaveWindowPos(int port); VOID SaveMDIWindowPos(HWND hWnd, char * RegKey, char * Value, BOOL Minimized); BOOL ProcessIncommingConnect(struct TNCINFO * TNC, char * Call, int Stream, BOOL SENDCTEXT); BOOL ProcessIncommingConnectEx(struct TNCINFO * TNC, char * Call, int Stream, BOOL SENDCTEXT, BOOL AllowTR); VOID ShowTraffic(struct TNCINFO * TNC); int OpenCOMMPort(struct TNCINFO * conn, char * Port, int Speed, BOOL Quiet); VOID SendMH(struct TNCINFO * TNC, char * call, char * freq, char * LOC, char * Mode); VOID MoveWindows(struct TNCINFO * TNC); static VOID TidyClose(struct TNCINFO * TNC, int Stream); static VOID ForcedClose(struct TNCINFO * TNC, int Stream); static VOID CloseComplete(struct TNCINFO * TNC, int Stream); VOID CheckForDetach(struct TNCINFO * TNC, int Stream, struct STREAMINFO * STREAM, VOID TidyCloseProc(struct TNCINFO * TNC, int Stream), VOID ForcedCloseProc(struct TNCINFO * TNC, int Stream), VOID CloseComplete(struct TNCINFO * TNC, int Stream)); BOOL InterlockedCheckBusy(struct TNCINFO * ThisTNC); extern UINT CRCTAB; int BPQTRACE(MESSAGE * Msg, BOOL TOAPRS); static int ProcessLine(char * buf, int Port); VOID __cdecl Debugprintf(const char * format, ...); VOID __cdecl Consoleprintf(const char * format, ...); extern BOOL MinimizetoTray; int standardParams(struct TNCINFO * TNC, char * buf); void DecodePTTString(struct TNCINFO * TNC, char * ptr); int Rig_Command(TRANSPORTENTRY * Session, char * Command); BOOL Rig_Poll(); VOID Rig_PTT(struct TNCINFO * TNC, BOOL PTTState); VOID Rig_PTTEx(struct RIGINFO * RIG, BOOL PTTState, struct TNCINFO * TNC); struct RIGINFO * Rig_GETPTTREC(int Port); struct ScanEntry ** CheckTimeBands(struct RIGINFO * RIG); #ifndef LINBPQ LRESULT CALLBACK PacWndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam); #endif #define Report_P1 11 #define Report_P12 12 #define Report_P123 13 #define Report_P2 14 #define Report_P23 15 #define Report_P3 16 #define Report_P1234 17 #define Report_P234 18 #define Report_P34 19 #define Report_P4 20 #define Report_WINMOR500 21 #define Report_WINMOR1600 22 #define Report_Robust 30 #define IOCTL_SERIAL_IS_COM_OPEN CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_GETDATA CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x801,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_SETDATA CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x802,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_SET_CTS CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x803,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_SET_DSR CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x804,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_SET_DCD CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x805,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_CLR_CTS CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x806,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_CLR_DSR CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x807,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_SERIAL_CLR_DCD CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x808,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_BPQ_ADD_DEVICE CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x809,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_BPQ_DELETE_DEVICE CTL_CODE(FILE_DEVICE_SERIAL_PORT,0x80a,METHOD_BUFFERED,FILE_ANY_ACCESS) #define W98_SERIAL_GETDATA 0x801 #define W98_SERIAL_SETDATA 0x802