Debugging the gateway.
This commit is contained in:
parent
02b6f5342e
commit
64bf2108ee
13 changed files with 271 additions and 65 deletions
|
@ -38,7 +38,10 @@ enum SECTION {
|
||||||
CConf::CConf(const std::string& file) :
|
CConf::CConf(const std::string& file) :
|
||||||
m_file(file),
|
m_file(file),
|
||||||
m_callsign(),
|
m_callsign(),
|
||||||
m_port(0U),
|
m_rptAddress(),
|
||||||
|
m_rptPort(0U),
|
||||||
|
m_myAddress(),
|
||||||
|
m_myPort(0U),
|
||||||
m_daemon(false),
|
m_daemon(false),
|
||||||
m_rxFrequency(0U),
|
m_rxFrequency(0U),
|
||||||
m_txFrequency(0U),
|
m_txFrequency(0U),
|
||||||
|
@ -111,8 +114,14 @@ bool CConf::read()
|
||||||
for (unsigned int i = 0U; value[i] != 0; i++)
|
for (unsigned int i = 0U; value[i] != 0; i++)
|
||||||
value[i] = ::toupper(value[i]);
|
value[i] = ::toupper(value[i]);
|
||||||
m_callsign = value;
|
m_callsign = value;
|
||||||
} else if (::strcmp(key, "Port") == 0)
|
} else if (::strcmp(key, "RptAddress") == 0)
|
||||||
m_port = (unsigned int)::atoi(value);
|
m_rptAddress = value;
|
||||||
|
else if (::strcmp(key, "RptPort") == 0)
|
||||||
|
m_rptPort = (unsigned int)::atoi(value);
|
||||||
|
else if (::strcmp(key, "MyAddress") == 0)
|
||||||
|
m_myAddress = value;
|
||||||
|
else if (::strcmp(key, "MyPort") == 0)
|
||||||
|
m_myPort = (unsigned int)::atoi(value);
|
||||||
else if (::strcmp(key, "Daemon") == 0)
|
else if (::strcmp(key, "Daemon") == 0)
|
||||||
m_daemon = ::atoi(value) == 1;
|
m_daemon = ::atoi(value) == 1;
|
||||||
} else if (section == SECTION_INFO) {
|
} else if (section == SECTION_INFO) {
|
||||||
|
@ -174,9 +183,24 @@ std::string CConf::getCallsign() const
|
||||||
return m_callsign;
|
return m_callsign;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int CConf::getPort() const
|
std::string CConf::getRptAddress() const
|
||||||
{
|
{
|
||||||
return m_port;
|
return m_rptAddress;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int CConf::getRptPort() const
|
||||||
|
{
|
||||||
|
return m_rptPort;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string CConf::getMyAddress() const
|
||||||
|
{
|
||||||
|
return m_myAddress;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int CConf::getMyPort() const
|
||||||
|
{
|
||||||
|
return m_myPort;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CConf::getDaemon() const
|
bool CConf::getDaemon() const
|
||||||
|
|
|
@ -32,7 +32,10 @@ public:
|
||||||
|
|
||||||
// The General section
|
// The General section
|
||||||
std::string getCallsign() const;
|
std::string getCallsign() const;
|
||||||
unsigned int getPort() const;
|
std::string getRptAddress() const;
|
||||||
|
unsigned int getRptPort() const;
|
||||||
|
std::string getMyAddress() const;
|
||||||
|
unsigned int getMyPort() const;
|
||||||
bool getDaemon() const;
|
bool getDaemon() const;
|
||||||
|
|
||||||
// The Info section
|
// The Info section
|
||||||
|
@ -67,7 +70,10 @@ public:
|
||||||
private:
|
private:
|
||||||
std::string m_file;
|
std::string m_file;
|
||||||
std::string m_callsign;
|
std::string m_callsign;
|
||||||
unsigned int m_port;
|
std::string m_rptAddress;
|
||||||
|
unsigned int m_rptPort;
|
||||||
|
std::string m_myAddress;
|
||||||
|
unsigned int m_myPort;
|
||||||
bool m_daemon;
|
bool m_daemon;
|
||||||
|
|
||||||
unsigned int m_rxFrequency;
|
unsigned int m_rxFrequency;
|
||||||
|
|
|
@ -27,6 +27,17 @@
|
||||||
|
|
||||||
const unsigned int BUFFER_LENGTH = 200U;
|
const unsigned int BUFFER_LENGTH = 200U;
|
||||||
|
|
||||||
|
CNetwork::CNetwork(const std::string& address, unsigned int port, bool debug) :
|
||||||
|
m_socket(address, port),
|
||||||
|
m_debug(debug),
|
||||||
|
m_address(),
|
||||||
|
m_port(0U),
|
||||||
|
m_buffer(1000U, "YSF Network Buffer"),
|
||||||
|
m_timer(1000U, 5U)
|
||||||
|
{
|
||||||
|
assert(port > 0U);
|
||||||
|
}
|
||||||
|
|
||||||
CNetwork::CNetwork(unsigned int port, bool debug) :
|
CNetwork::CNetwork(unsigned int port, bool debug) :
|
||||||
m_socket(port),
|
m_socket(port),
|
||||||
m_debug(debug),
|
m_debug(debug),
|
||||||
|
@ -123,8 +134,11 @@ void CNetwork::clock(unsigned int ms)
|
||||||
if (length <= 0)
|
if (length <= 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (address.s_addr != m_address.s_addr || port != m_port)
|
if (address.s_addr != m_address.s_addr || port != m_port) {
|
||||||
|
LogDebug("Addr: %u != %u || Port: %u != %u", address.s_addr, m_address.s_addr, port, m_port);
|
||||||
|
CUtils::dump("Data from unknown address/port", buffer, length);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Handle incoming polls
|
// Handle incoming polls
|
||||||
if (::memcmp(buffer, "YSFP", 4U) == 0) {
|
if (::memcmp(buffer, "YSFP", 4U) == 0) {
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
|
|
||||||
class CNetwork {
|
class CNetwork {
|
||||||
public:
|
public:
|
||||||
|
CNetwork(const std::string& address, unsigned int port, bool debug);
|
||||||
CNetwork(unsigned int port, bool debug);
|
CNetwork(unsigned int port, bool debug);
|
||||||
~CNetwork();
|
~CNetwork();
|
||||||
|
|
||||||
|
|
|
@ -69,14 +69,11 @@ CYSFReflector* CReflectors::find(const std::string& id)
|
||||||
{
|
{
|
||||||
for (std::vector<CYSFReflector*>::iterator it = m_reflectors.begin(); it != m_reflectors.end(); ++it) {
|
for (std::vector<CYSFReflector*>::iterator it = m_reflectors.begin(); it != m_reflectors.end(); ++it) {
|
||||||
if (id == (*it)->m_id)
|
if (id == (*it)->m_id)
|
||||||
if ((*it)->m_timer.isRunning() && (*it)->m_timer.hasExpired()) {
|
return *it;
|
||||||
LogDebug("Found id %s, but it has expired", id.c_str());
|
|
||||||
return NULL;
|
|
||||||
} else {
|
|
||||||
return *it;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LogMessage("Trying to find non existent reflector with an id of %s", id.c_str());
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -105,7 +102,9 @@ void CReflectors::clock(unsigned int ms)
|
||||||
std::string id = std::string((char*)(buffer + 4U), 5U);
|
std::string id = std::string((char*)(buffer + 4U), 5U);
|
||||||
std::string name = std::string((char*)(buffer + 9U), 16U);
|
std::string name = std::string((char*)(buffer + 9U), 16U);
|
||||||
std::string desc = std::string((char*)(buffer + 25U), 14U);
|
std::string desc = std::string((char*)(buffer + 25U), 14U);
|
||||||
unsigned int cnt = ::atoi((char*)(buffer + 39U));
|
std::string cnt = std::string((char*)(buffer + 39U), 3U);
|
||||||
|
|
||||||
|
LogDebug("Have YSFS reply from %s/%s/%s/%s", id.c_str(), name.c_str(), desc.c_str(), cnt.c_str());
|
||||||
|
|
||||||
for (std::vector<CYSFReflector*>::iterator it = m_reflectors.begin(); it != m_reflectors.end(); ++it) {
|
for (std::vector<CYSFReflector*>::iterator it = m_reflectors.begin(); it != m_reflectors.end(); ++it) {
|
||||||
in_addr itAddr = (*it)->m_address;
|
in_addr itAddr = (*it)->m_address;
|
||||||
|
@ -117,6 +116,7 @@ void CReflectors::clock(unsigned int ms)
|
||||||
(*it)->m_desc = desc;
|
(*it)->m_desc = desc;
|
||||||
(*it)->m_count = cnt;
|
(*it)->m_count = cnt;
|
||||||
(*it)->m_timer.start();
|
(*it)->m_timer.start();
|
||||||
|
LogDebug("Updating %s", id.c_str());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,7 @@ public:
|
||||||
m_id(),
|
m_id(),
|
||||||
m_name(),
|
m_name(),
|
||||||
m_desc(),
|
m_desc(),
|
||||||
m_count(0U),
|
m_count("000"),
|
||||||
m_address(),
|
m_address(),
|
||||||
m_port(0U),
|
m_port(0U),
|
||||||
m_timer(1000U, 700U)
|
m_timer(1000U, 700U)
|
||||||
|
@ -41,7 +41,7 @@ public:
|
||||||
std::string m_id;
|
std::string m_id;
|
||||||
std::string m_name;
|
std::string m_name;
|
||||||
std::string m_desc;
|
std::string m_desc;
|
||||||
unsigned int m_count;
|
std::string m_count;
|
||||||
in_addr m_address;
|
in_addr m_address;
|
||||||
unsigned int m_port;
|
unsigned int m_port;
|
||||||
CTimer m_timer;
|
CTimer m_timer;
|
||||||
|
|
|
@ -151,6 +151,8 @@ bool CUDPSocket::open()
|
||||||
#endif
|
#endif
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LogInfo("Opening UDP port on %u", m_port);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include "WiresX.h"
|
#include "WiresX.h"
|
||||||
#include "YSFPayload.h"
|
#include "YSFPayload.h"
|
||||||
#include "YSFFICH.h"
|
#include "YSFFICH.h"
|
||||||
|
#include "Utils.h"
|
||||||
#include "Sync.h"
|
#include "Sync.h"
|
||||||
#include "CRC.h"
|
#include "CRC.h"
|
||||||
#include "Log.h"
|
#include "Log.h"
|
||||||
|
@ -40,41 +41,53 @@ const unsigned char DEFAULT_FICH[] = {0x20U, 0x00U, 0x01U, 0x00U};
|
||||||
|
|
||||||
const unsigned char NET_HEADER[] = "YSFDGATEWAY ALL ";
|
const unsigned char NET_HEADER[] = "YSFDGATEWAY ALL ";
|
||||||
|
|
||||||
CWiresX::CWiresX(CNetwork* network, const std::string& hostsFile, unsigned int statusPort) :
|
CWiresX::CWiresX(const std::string& callsign, CNetwork* network, const std::string& hostsFile, unsigned int statusPort) :
|
||||||
|
m_callsign(callsign),
|
||||||
m_network(network),
|
m_network(network),
|
||||||
m_reflectors(hostsFile, statusPort),
|
m_reflectors(hostsFile, statusPort),
|
||||||
m_reflector(NULL),
|
m_reflector(NULL),
|
||||||
m_id(),
|
m_id(),
|
||||||
m_name(),
|
m_name(),
|
||||||
m_description(),
|
|
||||||
m_txFrequency(0U),
|
m_txFrequency(0U),
|
||||||
m_rxFrequency(0U),
|
m_rxFrequency(0U),
|
||||||
m_timer(1000U, 0U, 100U + 750U),
|
m_timer(1000U, 0U, 100U + 750U),
|
||||||
m_seqNo(0U),
|
m_seqNo(0U),
|
||||||
|
m_source(NULL),
|
||||||
m_csd1(NULL),
|
m_csd1(NULL),
|
||||||
|
m_csd2(NULL),
|
||||||
|
m_csd3(NULL),
|
||||||
m_status(WXSI_NONE)
|
m_status(WXSI_NONE)
|
||||||
{
|
{
|
||||||
assert(network != NULL);
|
assert(network != NULL);
|
||||||
assert(statusPort > 0U);
|
assert(statusPort > 0U);
|
||||||
|
|
||||||
m_csd1 = new unsigned char[20U];
|
m_callsign.resize(YSF_CALLSIGN_LENGTH, ' ');
|
||||||
|
|
||||||
|
m_source = new unsigned char[20U];
|
||||||
|
m_csd1 = new unsigned char[20U];
|
||||||
|
m_csd2 = new unsigned char[20U];
|
||||||
|
m_csd3 = new unsigned char[20U];
|
||||||
}
|
}
|
||||||
|
|
||||||
CWiresX::~CWiresX()
|
CWiresX::~CWiresX()
|
||||||
{
|
{
|
||||||
|
delete[] m_csd3;
|
||||||
|
delete[] m_csd2;
|
||||||
delete[] m_csd1;
|
delete[] m_csd1;
|
||||||
|
delete[] m_source;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CWiresX::setInfo(const std::string& name, const std::string& description, unsigned int txFrequency, unsigned int rxFrequency)
|
void CWiresX::setInfo(const std::string& name, unsigned int txFrequency, unsigned int rxFrequency)
|
||||||
{
|
{
|
||||||
assert(txFrequency > 0U);
|
assert(txFrequency > 0U);
|
||||||
assert(rxFrequency > 0U);
|
assert(rxFrequency > 0U);
|
||||||
|
|
||||||
m_name = name;
|
m_name = name;
|
||||||
m_description = description;
|
|
||||||
m_txFrequency = txFrequency;
|
m_txFrequency = txFrequency;
|
||||||
m_rxFrequency = rxFrequency;
|
m_rxFrequency = rxFrequency;
|
||||||
|
|
||||||
|
m_name.resize(14U, ' ');
|
||||||
|
|
||||||
unsigned int hash = 0U;
|
unsigned int hash = 0U;
|
||||||
|
|
||||||
for (unsigned int i = 0U; i < name.size(); i++) {
|
for (unsigned int i = 0U; i < name.size(); i++) {
|
||||||
|
@ -94,6 +107,20 @@ void CWiresX::setInfo(const std::string& name, const std::string& description, u
|
||||||
LogInfo("The ID of this repeater is %s", id);
|
LogInfo("The ID of this repeater is %s", id);
|
||||||
|
|
||||||
m_id = std::string(id);
|
m_id = std::string(id);
|
||||||
|
|
||||||
|
::memset(m_csd1, '*', 20U);
|
||||||
|
::memset(m_csd2, ' ', 20U);
|
||||||
|
::memset(m_csd3, ' ', 20U);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 10U; i++) {
|
||||||
|
m_csd1[i + 10U] = m_callsign.at(i);
|
||||||
|
m_csd2[i + 0U] = m_callsign.at(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 5U; i++) {
|
||||||
|
m_csd3[i + 0U] = m_id.at(i);
|
||||||
|
m_csd3[i + 10U] = m_id.at(i);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CWiresX::start()
|
bool CWiresX::start()
|
||||||
|
@ -111,19 +138,13 @@ WX_STATUS CWiresX::process(const unsigned char* data, unsigned char fi, unsigned
|
||||||
CYSFPayload payload;
|
CYSFPayload payload;
|
||||||
|
|
||||||
if (fi == YSF_FI_HEADER) {
|
if (fi == YSF_FI_HEADER) {
|
||||||
payload.readDataFRModeData1(data, m_csd1);
|
payload.readDataFRModeData1(data, m_source);
|
||||||
return WXS_NONE;
|
return WXS_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fi == YSF_FI_COMMUNICATIONS && fn == 0U) {
|
if (fi == YSF_FI_COMMUNICATIONS && fn == 0U) {
|
||||||
if (::memcmp(m_csd1, " ", 20U) == 0)
|
if (::memcmp(m_source, " ", 20U) == 0)
|
||||||
payload.readDataFRModeData1(data, m_csd1);
|
payload.readDataFRModeData1(data, m_source);
|
||||||
return WXS_NONE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (fi == YSF_FI_TERMINATOR) {
|
|
||||||
if (::memcmp(m_csd1, " ", 20U) == 0)
|
|
||||||
payload.readDataFRModeData1(data, m_csd1);
|
|
||||||
return WXS_NONE;
|
return WXS_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,7 +152,7 @@ WX_STATUS CWiresX::process(const unsigned char* data, unsigned char fi, unsigned
|
||||||
unsigned char buffer[20U];
|
unsigned char buffer[20U];
|
||||||
bool valid = payload.readDataFRModeData2(data, buffer);
|
bool valid = payload.readDataFRModeData2(data, buffer);
|
||||||
if (!valid) {
|
if (!valid) {
|
||||||
::memset(m_csd1, ' ', 20U);
|
::memset(m_source, ' ', 20U);
|
||||||
return WXS_NONE;
|
return WXS_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -147,7 +168,7 @@ WX_STATUS CWiresX::process(const unsigned char* data, unsigned char fi, unsigned
|
||||||
processDisconnect();
|
processDisconnect();
|
||||||
return WXS_DISCONNECT;
|
return WXS_DISCONNECT;
|
||||||
} else {
|
} else {
|
||||||
::memset(m_csd1, ' ', 20U);
|
::memset(m_source, ' ', 20U);
|
||||||
return WXS_NONE;
|
return WXS_NONE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -162,7 +183,7 @@ CYSFReflector* CWiresX::getReflector() const
|
||||||
|
|
||||||
void CWiresX::processDX()
|
void CWiresX::processDX()
|
||||||
{
|
{
|
||||||
::LogDebug("Received DX from %10.10s", m_csd1 + 10U);
|
::LogDebug("Received DX from %10.10s", m_source + 10U);
|
||||||
|
|
||||||
m_status = WXSI_DX;
|
m_status = WXSI_DX;
|
||||||
m_timer.start();
|
m_timer.start();
|
||||||
|
@ -176,7 +197,7 @@ void CWiresX::processAll()
|
||||||
|
|
||||||
WX_STATUS CWiresX::processConnect(const unsigned char* data)
|
WX_STATUS CWiresX::processConnect(const unsigned char* data)
|
||||||
{
|
{
|
||||||
::LogDebug("Received Connect to %5.5s from %10.10s", data + 5U, m_csd1 + 10U);
|
::LogDebug("Received Connect to %5.5s from %10.10s", data + 5U, m_source + 10U);
|
||||||
|
|
||||||
std::string id = std::string((char*)(data + 4U), 5U);
|
std::string id = std::string((char*)(data + 4U), 5U);
|
||||||
|
|
||||||
|
@ -192,7 +213,7 @@ WX_STATUS CWiresX::processConnect(const unsigned char* data)
|
||||||
|
|
||||||
void CWiresX::processDisconnect()
|
void CWiresX::processDisconnect()
|
||||||
{
|
{
|
||||||
::LogDebug("Received Disconect from %10.10s", m_csd1 + 10U);
|
::LogDebug("Received Disconect from %10.10s", m_source + 10U);
|
||||||
|
|
||||||
m_status = WXSI_DISCONNECT;
|
m_status = WXSI_DISCONNECT;
|
||||||
m_timer.start();
|
m_timer.start();
|
||||||
|
@ -200,10 +221,10 @@ void CWiresX::processDisconnect()
|
||||||
|
|
||||||
void CWiresX::clock(unsigned int ms)
|
void CWiresX::clock(unsigned int ms)
|
||||||
{
|
{
|
||||||
|
m_reflectors.clock(ms);
|
||||||
|
|
||||||
m_timer.clock(ms);
|
m_timer.clock(ms);
|
||||||
if (m_timer.isRunning() && m_timer.hasExpired()) {
|
if (m_timer.isRunning() && m_timer.hasExpired()) {
|
||||||
LogDebug("Send reply");
|
|
||||||
|
|
||||||
switch (m_status) {
|
switch (m_status) {
|
||||||
case WXSI_DX:
|
case WXSI_DX:
|
||||||
sendDXReply();
|
sendDXReply();
|
||||||
|
@ -250,7 +271,7 @@ void CWiresX::createReply(const unsigned char* data, unsigned int length)
|
||||||
|
|
||||||
CYSFPayload payload;
|
CYSFPayload payload;
|
||||||
payload.writeDataFRModeData1(m_csd1, buffer + 35U);
|
payload.writeDataFRModeData1(m_csd1, buffer + 35U);
|
||||||
// payload.writeDataFRModeData2(" ", buffer + 35U);
|
payload.writeDataFRModeData2(m_csd2, buffer + 35U);
|
||||||
|
|
||||||
m_network->write(buffer);
|
m_network->write(buffer);
|
||||||
|
|
||||||
|
@ -266,11 +287,11 @@ void CWiresX::createReply(const unsigned char* data, unsigned int length)
|
||||||
unsigned int len = length - offset;
|
unsigned int len = length - offset;
|
||||||
ft = calculateFT(len);
|
ft = calculateFT(len);
|
||||||
payload.writeDataFRModeData1(m_csd1, buffer + 35U);
|
payload.writeDataFRModeData1(m_csd1, buffer + 35U);
|
||||||
// payload.writeDataFRModeData2(" ", buffer + 35U);
|
payload.writeDataFRModeData2(m_csd2, buffer + 35U);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 1U:
|
case 1U:
|
||||||
// payload.writeDataFRModeData1(" ", buffer + 35U);
|
payload.writeDataFRModeData1(m_csd3, buffer + 35U);
|
||||||
payload.writeDataFRModeData2(data + offset, buffer + 35U);
|
payload.writeDataFRModeData2(data + offset, buffer + 35U);
|
||||||
offset += 20U;
|
offset += 20U;
|
||||||
break;
|
break;
|
||||||
|
@ -306,7 +327,7 @@ void CWiresX::createReply(const unsigned char* data, unsigned int length)
|
||||||
fich.encode(buffer + 35U);
|
fich.encode(buffer + 35U);
|
||||||
|
|
||||||
payload.writeDataFRModeData1(m_csd1, buffer + 35U);
|
payload.writeDataFRModeData1(m_csd1, buffer + 35U);
|
||||||
// payload.writeDataFRModeData2(" ", buffer + 35U);
|
payload.writeDataFRModeData2(m_csd2, buffer + 35U);
|
||||||
|
|
||||||
m_network->write(buffer);
|
m_network->write(buffer);
|
||||||
}
|
}
|
||||||
|
@ -335,11 +356,47 @@ void CWiresX::sendDXReply()
|
||||||
::memset(data, ' ', 128U);
|
::memset(data, ' ', 128U);
|
||||||
|
|
||||||
data[0U] = m_seqNo;
|
data[0U] = m_seqNo;
|
||||||
::memcmp(data + 1U, DX_RESP, 4U);
|
|
||||||
|
for (unsigned int i = 0U; i < 4U; i++)
|
||||||
|
data[i + 1U] = DX_RESP[i];
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 5U; i++)
|
||||||
|
data[i + 5U] = m_id.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 10U; i++)
|
||||||
|
data[i + 10U] = m_callsign.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 14U; i++)
|
||||||
|
data[i + 20U] = m_name.at(i);
|
||||||
|
|
||||||
|
data[34U] = '1';
|
||||||
|
data[35U] = '2';
|
||||||
|
|
||||||
|
data[57U] = '0';
|
||||||
|
data[58U] = '0';
|
||||||
|
data[59U] = '0';
|
||||||
|
|
||||||
|
unsigned int offset;
|
||||||
|
char sign;
|
||||||
|
if (m_txFrequency >= m_rxFrequency) {
|
||||||
|
offset = m_txFrequency - m_rxFrequency;
|
||||||
|
sign = '-';
|
||||||
|
} else {
|
||||||
|
offset = m_rxFrequency - m_txFrequency;
|
||||||
|
sign = '+';
|
||||||
|
}
|
||||||
|
|
||||||
|
char freq[30U];
|
||||||
|
::sprintf(freq, "%05u.%06u%c%03u.%06u", m_txFrequency / 1000000U, m_txFrequency % 1000000U, sign, offset / 1000000U, offset % 1000000U);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 23U; i++)
|
||||||
|
data[i + 84U] = freq[i];
|
||||||
|
|
||||||
data[127U] = 0x03U; // End of data marker
|
data[127U] = 0x03U; // End of data marker
|
||||||
data[128U] = CCRC::addCRC(data, 128U);
|
data[128U] = CCRC::addCRC(data, 128U);
|
||||||
|
|
||||||
|
CUtils::dump(1U, "DX Reply", data, 140U);
|
||||||
|
|
||||||
createReply(data, 140U);
|
createReply(data, 140U);
|
||||||
|
|
||||||
m_seqNo++;
|
m_seqNo++;
|
||||||
|
@ -347,12 +404,93 @@ void CWiresX::sendDXReply()
|
||||||
|
|
||||||
void CWiresX::sendConnectReply()
|
void CWiresX::sendConnectReply()
|
||||||
{
|
{
|
||||||
|
assert(m_reflector != NULL);
|
||||||
|
|
||||||
|
unsigned char data[110U];
|
||||||
|
::memset(data, 0x00U, 110U);
|
||||||
|
::memset(data, ' ', 90U);
|
||||||
|
|
||||||
|
data[0U] = m_seqNo;
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 4U; i++)
|
||||||
|
data[i + 1U] = CONN_RESP[i];
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 5U; i++)
|
||||||
|
data[i + 5U] = m_id.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 10U; i++)
|
||||||
|
data[i + 10U] = m_callsign.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 14U; i++)
|
||||||
|
data[i + 20U] = m_name.at(i);
|
||||||
|
|
||||||
|
data[34U] = '1';
|
||||||
|
data[35U] = '5';
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 5U; i++)
|
||||||
|
data[i + 36U] = m_reflector->m_id.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 16U; i++)
|
||||||
|
data[i + 41U] = m_reflector->m_name.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 3U; i++)
|
||||||
|
data[i + 57U] = m_reflector->m_count.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 14U; i++)
|
||||||
|
data[i + 70U] = m_reflector->m_desc.at(i);
|
||||||
|
|
||||||
|
data[84U] = '0';
|
||||||
|
data[85U] = '0';
|
||||||
|
data[86U] = '0';
|
||||||
|
data[87U] = '0';
|
||||||
|
data[88U] = '0';
|
||||||
|
data[89U] = '0';
|
||||||
|
|
||||||
|
data[90U] = 0x03U; // End of data marker
|
||||||
|
data[91U] = CCRC::addCRC(data, 91U);
|
||||||
|
|
||||||
|
CUtils::dump(1U, "CONNECT Reply", data, 100U);
|
||||||
|
|
||||||
|
createReply(data, 100U);
|
||||||
|
|
||||||
|
m_seqNo++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CWiresX::sendDisconnectReply()
|
void CWiresX::sendDisconnectReply()
|
||||||
{
|
{
|
||||||
|
unsigned char data[110U];
|
||||||
|
::memset(data, 0x00U, 110U);
|
||||||
|
::memset(data, ' ', 90U);
|
||||||
|
|
||||||
|
data[0U] = m_seqNo;
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 4U; i++)
|
||||||
|
data[i + 1U] = DISC_RESP[i];
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 5U; i++)
|
||||||
|
data[i + 5U] = m_id.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 10U; i++)
|
||||||
|
data[i + 10U] = m_callsign.at(i);
|
||||||
|
|
||||||
|
for (unsigned int i = 0U; i < 14U; i++)
|
||||||
|
data[i + 20U] = m_name.at(i);
|
||||||
|
|
||||||
|
data[34U] = '1';
|
||||||
|
data[35U] = '2';
|
||||||
|
|
||||||
|
data[57U] = '0';
|
||||||
|
data[58U] = '0';
|
||||||
|
data[59U] = '0';
|
||||||
|
|
||||||
|
data[89U] = 0x03U; // End of data marker
|
||||||
|
data[90U] = CCRC::addCRC(data, 90U);
|
||||||
|
|
||||||
|
CUtils::dump(1U, "DISCONNECT Reply", data, 100U);
|
||||||
|
|
||||||
|
createReply(data, 100U);
|
||||||
|
|
||||||
|
m_seqNo++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CWiresX::sendAllReply()
|
void CWiresX::sendAllReply()
|
||||||
|
|
|
@ -41,10 +41,10 @@ enum WXSI_STATUS {
|
||||||
|
|
||||||
class CWiresX {
|
class CWiresX {
|
||||||
public:
|
public:
|
||||||
CWiresX(CNetwork* network, const std::string& hostsFile, unsigned int statusPort);
|
CWiresX(const std::string& callsign, CNetwork* network, const std::string& hostsFile, unsigned int statusPort);
|
||||||
~CWiresX();
|
~CWiresX();
|
||||||
|
|
||||||
void setInfo(const std::string& name, const std::string& description, unsigned int txFrequency, unsigned int rxFrequency);
|
void setInfo(const std::string& name, unsigned int txFrequency, unsigned int rxFrequency);
|
||||||
|
|
||||||
bool start();
|
bool start();
|
||||||
|
|
||||||
|
@ -55,17 +55,20 @@ public:
|
||||||
void clock(unsigned int ms);
|
void clock(unsigned int ms);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
std::string m_callsign;
|
||||||
CNetwork* m_network;
|
CNetwork* m_network;
|
||||||
CReflectors m_reflectors;
|
CReflectors m_reflectors;
|
||||||
CYSFReflector* m_reflector;
|
CYSFReflector* m_reflector;
|
||||||
std::string m_id;
|
std::string m_id;
|
||||||
std::string m_name;
|
std::string m_name;
|
||||||
std::string m_description;
|
|
||||||
unsigned int m_txFrequency;
|
unsigned int m_txFrequency;
|
||||||
unsigned int m_rxFrequency;
|
unsigned int m_rxFrequency;
|
||||||
CTimer m_timer;
|
CTimer m_timer;
|
||||||
unsigned char m_seqNo;
|
unsigned char m_seqNo;
|
||||||
|
unsigned char* m_source;
|
||||||
unsigned char* m_csd1;
|
unsigned char* m_csd1;
|
||||||
|
unsigned char* m_csd2;
|
||||||
|
unsigned char* m_csd3;
|
||||||
WXSI_STATUS m_status;
|
WXSI_STATUS m_status;
|
||||||
|
|
||||||
WX_STATUS processConnect(const unsigned char* data);
|
WX_STATUS processConnect(const unsigned char* data);
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
|
|
||||||
#include "YSFGateway.h"
|
#include "YSFGateway.h"
|
||||||
#include "Reflectors.h"
|
#include "Reflectors.h"
|
||||||
|
#include "UDPSocket.h"
|
||||||
#include "StopWatch.h"
|
#include "StopWatch.h"
|
||||||
#include "Version.h"
|
#include "Version.h"
|
||||||
#include "YSFFICH.h"
|
#include "YSFFICH.h"
|
||||||
|
@ -157,12 +158,16 @@ int CYSFGateway::run()
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
bool debug = m_conf.getNetworkDebug();
|
std::string callsign = m_conf.getCallsign();
|
||||||
unsigned int rptPort = m_conf.getPort();
|
|
||||||
unsigned int netPort = m_conf.getNetworkDataPort();
|
|
||||||
|
|
||||||
CNetwork rptNetwork(rptPort, debug);
|
bool debug = m_conf.getNetworkDebug();
|
||||||
m_netNetwork = new CNetwork(netPort, debug);
|
in_addr rptAddress = CUDPSocket::lookup(m_conf.getRptAddress());
|
||||||
|
unsigned int rptPort = m_conf.getRptPort();
|
||||||
|
std::string myAddress = m_conf.getMyAddress();
|
||||||
|
unsigned int myPort = m_conf.getMyPort();
|
||||||
|
|
||||||
|
CNetwork rptNetwork(myAddress, myPort, debug);
|
||||||
|
rptNetwork.setDestination(rptAddress, rptPort);
|
||||||
|
|
||||||
ret = rptNetwork.open();
|
ret = rptNetwork.open();
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
|
@ -170,6 +175,9 @@ int CYSFGateway::run()
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned int netPort = m_conf.getNetworkDataPort();
|
||||||
|
|
||||||
|
m_netNetwork = new CNetwork(netPort, debug);
|
||||||
ret = m_netNetwork->open();
|
ret = m_netNetwork->open();
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
::LogError("Cannot open the reflector network port");
|
::LogError("Cannot open the reflector network port");
|
||||||
|
@ -181,7 +189,15 @@ int CYSFGateway::run()
|
||||||
std::string fileName = m_conf.getNetworkHosts();
|
std::string fileName = m_conf.getNetworkHosts();
|
||||||
unsigned int port = m_conf.getNetworkStatusPort();
|
unsigned int port = m_conf.getNetworkStatusPort();
|
||||||
|
|
||||||
m_wiresX = new CWiresX(&rptNetwork, fileName, port);
|
m_wiresX = new CWiresX(callsign, &rptNetwork, fileName, port);
|
||||||
|
|
||||||
|
std::string name = m_conf.getName();
|
||||||
|
unsigned int txFrequency = m_conf.getTxFrequency();
|
||||||
|
unsigned int rxFrequency = m_conf.getRxFrequency();
|
||||||
|
|
||||||
|
m_wiresX->setInfo(name, txFrequency, rxFrequency);
|
||||||
|
|
||||||
|
m_wiresX->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
CStopWatch stopWatch;
|
CStopWatch stopWatch;
|
||||||
|
|
|
@ -1,12 +1,14 @@
|
||||||
[General]
|
[General]
|
||||||
Callsign=G9BF
|
Callsign=G9BF
|
||||||
Node=123456
|
RptAddress=127.0.0.1
|
||||||
Port=4200
|
RptPort=3200
|
||||||
|
MyAddress=127.0.0.1
|
||||||
|
MyPort=4200
|
||||||
Daemon=0
|
Daemon=0
|
||||||
|
|
||||||
[Info]
|
[Info]
|
||||||
RXFrequency=435000000
|
RXFrequency=430475000
|
||||||
TXFrequency=435000000
|
TXFrequency=439475000
|
||||||
Power=1
|
Power=1
|
||||||
Latitude=0.0
|
Latitude=0.0
|
||||||
Longitude=0.0
|
Longitude=0.0
|
||||||
|
@ -22,7 +24,7 @@ FilePath=.
|
||||||
FileRoot=YSFGateway
|
FileRoot=YSFGateway
|
||||||
|
|
||||||
[aprs.fi]
|
[aprs.fi]
|
||||||
Enable=1
|
Enable=0
|
||||||
# Server=noam.aprs2.net
|
# Server=noam.aprs2.net
|
||||||
Server=euro.aprs2.net
|
Server=euro.aprs2.net
|
||||||
Port=14580
|
Port=14580
|
||||||
|
|
|
@ -26,9 +26,6 @@
|
||||||
<ClInclude Include="UDPSocket.h">
|
<ClInclude Include="UDPSocket.h">
|
||||||
<Filter>Header Files</Filter>
|
<Filter>Header Files</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClInclude Include="Utils.h">
|
|
||||||
<Filter>Header Files</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="Version.h">
|
<ClInclude Include="Version.h">
|
||||||
<Filter>Header Files</Filter>
|
<Filter>Header Files</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
@ -83,6 +80,9 @@
|
||||||
<ClInclude Include="Reflectors.h">
|
<ClInclude Include="Reflectors.h">
|
||||||
<Filter>Header Files</Filter>
|
<Filter>Header Files</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="Utils.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="Network.cpp">
|
<ClCompile Include="Network.cpp">
|
||||||
|
@ -97,9 +97,6 @@
|
||||||
<ClCompile Include="UDPSocket.cpp">
|
<ClCompile Include="UDPSocket.cpp">
|
||||||
<Filter>Source Files</Filter>
|
<Filter>Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ClCompile Include="Utils.cpp">
|
|
||||||
<Filter>Source Files</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="Log.cpp">
|
<ClCompile Include="Log.cpp">
|
||||||
<Filter>Source Files</Filter>
|
<Filter>Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@ -148,5 +145,8 @@
|
||||||
<ClCompile Include="Reflectors.cpp">
|
<ClCompile Include="Reflectors.cpp">
|
||||||
<Filter>Source Files</Filter>
|
<Filter>Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="Utils.cpp">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
|
@ -282,7 +282,7 @@ void CYSFPayload::writeDataFRModeData1(const unsigned char* dt, unsigned char* d
|
||||||
|
|
||||||
data += YSF_SYNC_LENGTH_BYTES + YSF_FICH_LENGTH_BYTES;
|
data += YSF_SYNC_LENGTH_BYTES + YSF_FICH_LENGTH_BYTES;
|
||||||
|
|
||||||
unsigned char output[20U];
|
unsigned char output[25U];
|
||||||
for (unsigned int i = 0U; i < 20U; i++)
|
for (unsigned int i = 0U; i < 20U; i++)
|
||||||
output[i] = dt[i] ^ WHITENING_DATA[i];
|
output[i] = dt[i] ^ WHITENING_DATA[i];
|
||||||
|
|
||||||
|
@ -326,7 +326,7 @@ void CYSFPayload::writeDataFRModeData2(const unsigned char* dt, unsigned char* d
|
||||||
|
|
||||||
data += YSF_SYNC_LENGTH_BYTES + YSF_FICH_LENGTH_BYTES;
|
data += YSF_SYNC_LENGTH_BYTES + YSF_FICH_LENGTH_BYTES;
|
||||||
|
|
||||||
unsigned char output[20U];
|
unsigned char output[25U];
|
||||||
for (unsigned int i = 0U; i < 20U; i++)
|
for (unsigned int i = 0U; i < 20U; i++)
|
||||||
output[i] = dt[i] ^ WHITENING_DATA[i];
|
output[i] = dt[i] ^ WHITENING_DATA[i];
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue