linbpq/rigcontrol.h

269 lines
7.5 KiB
C
Raw Normal View History

2023-06-21 08:21:04 +01:00
#ifndef RIGCONTROL
#define RIGCONTROL
2022-08-28 09:35:46 +01:00
#ifndef LINBPQ
#include "Rigresource.h"
#endif
#define IDI_ICON2 2
#define MAXBLOCK 4096
struct TimeScan
{
time_t Start;
time_t End;
struct ScanEntry ** Scanlist;
};
struct ScanEntry
{
// Holds info for one frequency change. May Need to set Feeq, Mode, Repeater Split, Pactor/Winmor Bandwidth
double Freq; // In case needed to report to WL2K
int Dwell; // Dwell Time on this freq
char Bandwidth; // W/N For WINMOR
char RPacketMode; // Robust or Normal for Tracker
char HFPacketMode; // Robust or Normal for Tracker
char PMaxLevel; // Pactor Max Level
char PMinLevel; // Pactor Max Level
char Antenna;
// char Supress; // Dont report this one to WL2K
char ARDOPMode[6];
char VARAMode;
char * Cmd1;
int Cmd1Len;
char * Cmd2;
int Cmd2Len;
char * Cmd3;
int Cmd3Len;
char * Cmd4;
int Cmd4Len;
char * PollCmd;
int PollCmdLen;
char APPL[13]; // Autoconnect APPL for this Freq
char APPLCALL[10]; // Callsign for autoconnect application
char Cmd1Msg[100]; // Space for commands
char Cmd2Msg[16];
char Cmd3Msg[16];
char Cmd4Msg[16];
};
struct HAMLIBSOCK
{
struct HAMLIBSOCK * Next;
SOCKET Sock;
union
{
struct sockaddr_in6 sin6;
struct sockaddr_in sin;
};
};
struct TNCINFO;
struct RIGINFO
{
// struct TRANSPORTENTRY * AttachedSession;
void * BPQtoRADIO_Q; // Frames from switch for radio
UINT BPQPort; // Port this radio is attached to. Bit Map, as may be more than one port controlling radio
// int PortNum; // Number of port that defined this rig
int Interlock; // Interlock group for this Radio
int IC735; // Old ICOM with shorter freq message
int ICF8101; // ICOM Land Mobile IC-F8101
char * CM108Device; // Device to open for CM108 GPIO PTT
struct _EXTPORTDATA * PortRecord[32]; // BPQ32 port record(s) for this rig (null terminated list)
UCHAR RigAddr;
2023-06-21 08:21:04 +01:00
uint64_t ScanStopped; // Scanning enabled if zero. Bits used for interlocked scanning (eg winmor/pactor on same port
2022-08-28 09:35:46 +01:00
int ScanCounter;
int PollCounter; // Don't poll too often;
int ScanFreq; // Scan Rate
BOOL OKtoChange; // Can Change
BOOL WaitingForPermission; //
BOOL RIGOK; // RIG is reponding
int Session; // BPQ L4 Record Number
int DebugDelay;
char RigName[10];
struct TimeScan ** TimeBands; // List of TimeBands/Frequencies
int NumberofBands;
char * FreqText; // Frequency list in text format
// Frequency list is a block of ScanEntry structs, each holding Set Freq/Mode commands in link format, null terminated
struct ScanEntry ** FreqPtr;
int PTTMode; // PTT Control Flags.
#define PTTRTS 1
#define PTTDTR 2
#define PTTCI_V 4
#define PTTCM108 8
#define PTTHAMLIB 16
#define PTTFLRIG 32
int PTTTimer; // PTT Timer watchdog (limits PTT ON to PTT OFF time
#define PTTLimit 200
int repeatPTTOFFTimer; // On ICOM radios send a second PTT OFF command after 30 secs
struct RIGPORTINFO * PORT; // For PTT Routines
HWND hLabel;
HWND hCAT;
HWND hFREQ;
HWND hMODE;
HWND hSCAN;
HWND hPTT;
HWND hPORTS;
char * WEB_Label;
char * WEB_CAT;
char * WEB_FREQ;
char * WEB_MODE;
char * WEB_PORTS;
char WEB_SCAN;
char WEB_PTT;
double RigFreq;
char Valchar[15]; // Freq as char string
char CurrentBandWidth; // bandwidth as character
int Passband; // Filter bandwidth
char ModeString[16];
char PTTOn[60];
char PTTOff[60];
int PTTOnLen;
int PTTOffLen;
char Poll[50];
int PollLen;
char PTTCATPort[4][10];
HANDLE PTTCATHandles[4];
struct TNCINFO * PTTCATTNC[4];
int RealMux[4]; // BPQ Virtual or Real
int TSMenu; // Menu number for ACC?USB switching on TS590S/SG
BOOL RIG_DEBUG;
int HAMLIBPORT; // Port Number for HAMLIB (rigctld) Emulator
2022-10-03 15:55:07 +01:00
2022-08-28 09:35:46 +01:00
SOCKET ListenSocket;
struct HAMLIBSOCK * Sockets;
long long txOffset; // Used primarily with transverters
long long rxOffset;
long long pttOffset; // Used to set tx freq to corresponding rx freq (for split freq)
long long txFreq; // Used in preference to Rx Freq + pttOffset if set
int rxError; // RX Frequency Error
int txError; // TX Calibration Error
int PTTSetsFreq;
int defaultFreq;
char * reportFreqs;
long long lastSetFreq; // Last freq we set (saves recalulating ptt string if not changed
};
// PortType Equates
#define ICOM 1
#define YAESU 2
#define KENWOOD 3
#define PTT 4
#define ANT 5
#define FT100 6
#define FT2000 7
#define FLEX 8
#define M710 9
#define NMEA 10
#define FT1000 11
#define DUMMY 12
#define FT990 13
#define HAMLIB 14
#define FT991A 15 // 991A is a varient of FT2000 but easier to have own type
#define RTLUDP 16
#define FLRIG 17
2023-05-16 16:40:12 +01:00
#define SDRRADIO 18
2022-08-28 09:35:46 +01:00
// Yease seem to have lots of variants of the same model
#define FT1000D 1
#define FT1000MP 2
struct RIGPORTINFO
{
int PortType; // ICOM, Yaesu, Etc
int YaesuVariant; // Yaesu seems to have lots of incompatible subtypes
char IOBASE[80];
char PTTIOBASE[80]; // Port for Hardware PTT - may be same as control port.
int SPEED;
char * HIDDevice;
struct RIGINFO Rigs[10]; // Rigs off a port
char * InitPtr; // Next Command
int CmdSent; // Last Command sent
int CmdStream; // Stream last command was issued o
int ConfiguredRigs; // Radios on this interface
int CurrentRig; // Radio last accessed.
int Timeout; // Timeout response counter
int Retries;
BOOL PORTOK; // PORT is reponding
int Closed; // CLOSE command received
HANDLE hDevice; // COM device Handle
int ReopenDelay;
struct TNCINFO * PTC; // Set to TNC record address if using an SCS PTC Radio Port
SOCKET remoteSock; // Socket for use with WINMORCONROL
struct sockaddr remoteDest; // Dest for above
HANDLE hPTTDevice; // May use a different port for PTT
UCHAR TXBuffer[500]; // Last message sent - saved for Retry
int TXLen; // Len of last sent
UCHAR RXBuffer[500]; // Message being received - may not arrive all at once
int RXLen; // Data in RXBUffer
BOOL AutoPoll; // set if last command was a Timer poll
// Local ScanStruct for Interactive Commands
struct ScanEntry * FreqPtr; // Block we are currently sending.
struct ScanEntry ScanEntry;
int CONNECTED; // for HAMLIB
int CONNECTING;
int Alerted;
};
#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
2023-06-21 08:21:04 +01:00
#endif