mirror of
https://github.com/thooge/esp32-nmea2000-obp60.git
synced 2025-12-15 06:53:07 +01:00
handle receiving and distributing on NMEA messages
This commit is contained in:
83
src/main.cpp
83
src/main.cpp
@@ -65,7 +65,7 @@ Preferences preferences; // Nonvolatile storage on ESP32 - To store
|
||||
bool SendNMEA0183Conversion = true; // Do we send NMEA2000 -> NMEA0183 conversion
|
||||
bool SendSeaSmart = false; // Do we send NMEA2000 messages in SeaSmart format
|
||||
|
||||
N2kDataToNMEA0183 *nmea0183Converter=N2kDataToNMEA0183::create(&logger, &boatData,&NMEA2000, 0);
|
||||
N2kDataToNMEA0183 *nmea0183Converter=N2kDataToNMEA0183::create(&logger, &boatData,&NMEA2000, 0, N2K_CHANNEL_ID);
|
||||
|
||||
// Set the information for other bus devices, which messages we support
|
||||
const unsigned long TransmitMessages[] PROGMEM = {127489L, // Engine dynamic
|
||||
@@ -73,7 +73,7 @@ const unsigned long TransmitMessages[] PROGMEM = {127489L, // Engine dynamic
|
||||
};
|
||||
// Forward declarations
|
||||
void HandleNMEA2000Msg(const tN2kMsg &N2kMsg);
|
||||
void SendNMEA0183Message(const tNMEA0183Msg &NMEA0183Msg);
|
||||
void SendNMEA0183Message(const tNMEA0183Msg &NMEA0183Msg,int id);
|
||||
|
||||
AsyncWebServer webserver(80);
|
||||
|
||||
@@ -165,12 +165,12 @@ GwConfigInterface *sendTCP=NULL;
|
||||
GwConfigInterface *sendSeasmart=NULL;
|
||||
GwConfigInterface *systemName=NULL;
|
||||
|
||||
GwSerial usbSerial(&logger, UART_NUM_0);
|
||||
GwSerial usbSerial(&logger, UART_NUM_0, USB_CHANNEL_ID);
|
||||
class GwSerialLog : public GwLogWriter{
|
||||
public:
|
||||
virtual ~GwSerialLog(){}
|
||||
virtual void write(const char *data){
|
||||
usbSerial.enqueue((const uint8_t*)data,strlen(data)); //ignore any errors
|
||||
usbSerial.sendToClients(data,-1); //ignore any errors
|
||||
}
|
||||
|
||||
};
|
||||
@@ -385,30 +385,40 @@ void HandleNMEA2000Msg(const tN2kMsg &N2kMsg) {
|
||||
socketServer.sendToClients(buf,N2K_CHANNEL_ID);
|
||||
}
|
||||
|
||||
|
||||
//*****************************************************************************
|
||||
void SendNMEA0183Message(const tNMEA0183Msg &NMEA0183Msg) {
|
||||
if ( ! sendTCP->asBoolean() && ! sendUsb->asBoolean() ) return;
|
||||
|
||||
char buf[MAX_NMEA0183_MESSAGE_SIZE];
|
||||
if ( !NMEA0183Msg.GetMessage(buf, MAX_NMEA0183_MESSAGE_SIZE) ) return;
|
||||
void sendBufferToChannels(const char * buffer, int sourceId){
|
||||
if (sendTCP->asBoolean()){
|
||||
socketServer.sendToClients(buf,N2K_CHANNEL_ID);
|
||||
socketServer.sendToClients(buffer,sourceId);
|
||||
}
|
||||
if (sendUsb->asBoolean()){
|
||||
int len=strlen(buf);
|
||||
if (len >= (MAX_NMEA0183_MESSAGE_SIZE -2)) return;
|
||||
buf[len]=0x0d;
|
||||
len++;
|
||||
buf[len]=0x0a;
|
||||
len++;
|
||||
buf[len]=0;
|
||||
usbSerial.enqueue((const uint8_t*)buf,len);
|
||||
usbSerial.sendToClients(buffer,sourceId);
|
||||
}
|
||||
}
|
||||
|
||||
//*****************************************************************************
|
||||
void SendNMEA0183Message(const tNMEA0183Msg &NMEA0183Msg, int sourceId) {
|
||||
if ( ! sendTCP->asBoolean() && ! sendUsb->asBoolean() ) return;
|
||||
|
||||
char buf[MAX_NMEA0183_MESSAGE_SIZE+3];
|
||||
if ( !NMEA0183Msg.GetMessage(buf, MAX_NMEA0183_MESSAGE_SIZE) ) return;
|
||||
size_t len=strlen(buf);
|
||||
buf[len]=0x0d;
|
||||
buf[len+1]=0x0a;
|
||||
buf[len+2]=0;
|
||||
sendBufferToChannels(buf,sourceId);
|
||||
}
|
||||
|
||||
void handleReceivedNmeaMessage(const char *buf, int sourceId){
|
||||
//TODO - for now only send out again
|
||||
//add the conversion to N2K here
|
||||
sendBufferToChannels(buf,sourceId);
|
||||
}
|
||||
|
||||
void handleSendAndRead(bool handleRead){
|
||||
socketServer.loop(handleRead);
|
||||
usbSerial.loop(handleRead);
|
||||
}
|
||||
class NMEAMessageReceiver : public GwBufferWriter{
|
||||
uint8_t buffer[GwBuffer::RX_BUFFER_SIZE+1];
|
||||
uint8_t buffer[GwBuffer::RX_BUFFER_SIZE+4];
|
||||
uint8_t *writePointer=buffer;
|
||||
public:
|
||||
virtual int write(const uint8_t *buffer,size_t len){
|
||||
@@ -421,23 +431,36 @@ class NMEAMessageReceiver : public GwBufferWriter{
|
||||
}
|
||||
virtual void done(){
|
||||
if (writePointer == buffer) return;
|
||||
logger.logDebug(GwLog::DEBUG,"NMEA-IN[%d]: %s",id,(const char *)buffer);
|
||||
uint8_t *p;
|
||||
for (p=writePointer-1;p>=buffer;p--){
|
||||
if (*p <= 0x20) *p=0;
|
||||
for (p=writePointer-1;p>=buffer && *p <= 0x20;p--){
|
||||
*p=0;
|
||||
}
|
||||
if (p > buffer){
|
||||
p++;
|
||||
*p=0x0d;
|
||||
p++;
|
||||
*p=0x0a;
|
||||
p++;
|
||||
*p=0;
|
||||
}
|
||||
for (p=buffer; *p != 0 && p < writePointer && *p <= 0x20;p++){}
|
||||
logger.logDebug(GwLog::DEBUG,"NMEA[%d]: %s",id,(const char *)p);
|
||||
//very simple NMEA check
|
||||
if (*p != '!' && *p != '$'){
|
||||
logger.logDebug(GwLog::DEBUG,"unknown line [%d] - ignore: %s",id,(const char *)p);
|
||||
}
|
||||
else{
|
||||
logger.logDebug(GwLog::DEBUG,"NMEA[%d]: %s",id,(const char *)p);
|
||||
handleReceivedNmeaMessage((const char *)p,id);
|
||||
//trigger sending to empty buffers
|
||||
handleSendAndRead(false);
|
||||
}
|
||||
writePointer=buffer;
|
||||
}
|
||||
};
|
||||
void loop() {
|
||||
gwWifi.loop();
|
||||
|
||||
socketServer.loop();
|
||||
if (usbSerial.write() == GwBuffer::ERROR){
|
||||
//logger.logDebug(GwLog::DEBUG,"overflow in USB serial");
|
||||
}
|
||||
handleSendAndRead(true);
|
||||
NMEA2000.ParseMessages();
|
||||
|
||||
int SourceAddress = NMEA2000.GetN2kSource();
|
||||
@@ -461,6 +484,6 @@ void loop() {
|
||||
socketServer.readMessages(&receiver);
|
||||
//read channels
|
||||
|
||||
usbSerial.read();
|
||||
usbSerial.readMessages(&receiver);
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user