-
Notifications
You must be signed in to change notification settings - Fork 234
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
is ExtendReceiveMessages necessary? #436
Comments
ExtendTransmitMessages/Receive messages are just informative to the library. If other devices requests messages your device will handle, it returns list of message handled by library core and extended messages. It does not have any effect for handled messages. I did not see anything wrong with your callback definition so HandleNMEA2000Msg should be called. You do not have any code in it. How do you know it has not been called? On NMEA2000.cpp line 2642 is call RunMessageHandlers after ForwardMessage. So HandleNMEA2000Msg will be called, if callback has been set. |
Thanks! |
Thanks. It was an issue with freertos timing. Seems if the HandleNMEA2000Msg is run with less than 500Hz messages are dropped. |
Which CAN controller you use? CAN controller should receive messages to internal buffer by interrupt so that it is not critical to call tNMEA2000::ParseMessages all the time with 500 Hz. NMEA2000_Teensy, NMEA2000_Teensyx and NMEA2000_esp32 drivers has been proved to handle data properly. Also NMEA2000_mcp works, if it will be used in interrupt mode. There are some ESP32 driver versios, which I have not tested and know that they do not setup internal buffer properly. Check also tNMEA2000::SetN2kCANReceiveFrameBufSize Even there is proper interrupt buffering, one should call tNMEA2000::ParseMessages as fast as possible so that message timing is good. Random delays should not be longer than 50 ms and average shoul be 1-2 ms. |
Thanks a lot! |
After changing the constructor call to: |
NMEA2000_esp32_twai does not define buffers according tNMEA2000::SetN2kCANReceiveFrameBufSize so it does not work with library as designed. Anyway as you can setup buffers on contructor, it may work. I have not tested this driver with my tests or NMEA2000 certification tool, so I can not either say does it work properly. |
I have a rather basic question. What is the intended logic to receive a message. Based on the code examples I have thought the following:
Example: access altitude data from PGN 129029 in a multidevice setup:
in setup()
in loop()
NMEA2000.ParseMessages();
I would expect now that in HandleNMEA2000Msg to see a PGN 129029
I have checked further by uncommenting
that the PGN 129029 is recevied by the device. The SetForwardStream shows PGN 129029. However, in HandleNMEA2000Msg() I do not see any PGN 129029.
Is there an additional API call needed for a multi device receive application. Unfortunately, I have not seen such an example in the repo.
Thanks a lot! Best Stefan
The text was updated successfully, but these errors were encountered: