Skip to content
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

Only able to receive and send 4 messages then locks up? Pointers pls? #60

Open
Rich235 opened this issue Nov 14, 2024 · 5 comments
Open

Comments

@Rich235
Copy link

Rich235 commented Nov 14, 2024

Hello Kevin, thank you for developing this library.

I've a new RP2040-Zero connected to SN65HVD230 and a PCAN-USB interface with termination. I'm using very simple sketch to receive and send. I've tried 50k and 500k bps and different message sending rates, but after 4 messages sent, it then fails to receive or send.

I'm using pins 9 and 10. May I ask if you have any pointers to help me debug this please?

I'm using the latest Pico SDK with PlatformIO and Earlephilhower platform. Any guidance much appreciated. I'm new to using PIO. Thanks very much, Richard.

@Rich235
Copy link
Author

Rich235 commented Nov 15, 2024

Just to add to this, I've found I can just receive fine, continually, but if I send more than 4 messages, all CAN comms fail from then on. If you can point me to where I should start looking, that would be very helpful. This is with SDK 2.0.0. Thank you.

@obdevel
Copy link

obdevel commented Nov 23, 2024

That is the size of the transmit buffer and indicates the messages are not being destaged to the bus. Check your wiring, termination, etc. You should also call can2040_check_transmit() before transmitting to check there is sufficient space in the transmit buffer. If there isn't, you can wait, discard or buffer the message yourself.

If you're using Earle's Arduino core, you may find it easier to use my Arduino library which wraps Kevin's code. It includes an example sketch. Look for ACAN2040 in the IDE library manager. I've just updated it to capture Kevin's latest changes and to correctly support the RP2350 chip.

@Rich235
Copy link
Author

Rich235 commented Nov 23, 2024

Thanks yery much, that is very likely it and I've not checked that yet. Yes, I've tried your (obdevel) ACAN2040 library and https://github.com/kaminaris/can2040.git, all with the same issue so far. May I ask what size of message are you able to send and at what period on a 500kbs bus? I will ensure to use can2040_check_transmit() before transmitting.

@obdevel
Copy link

obdevel commented Nov 24, 2024

We have tested my Arduino library extensively but our standard rate is 125kbps. Our application does rate-limit transmissions to allow other nodes time to speak. 125kbps is around 1000-2000 messages per sec, depending on message length. We also buffer incoming and outgoing messages. If can2040_check_transmit() fails, we buffer in our own circular buffer and try again a little later. Unfortunately, Kevin advises against transmitting a message from with the callback function, so we set a flag and transmit from the main loop.

@Rich235
Copy link
Author

Rich235 commented Nov 25, 2024

Thank you yes, it is now working perfectly. I should have studied the reason for the checkTransmit call in the example more carefully and noted "TransmitQueue txQueue[4] = {};" in the .h file. Thanks for your help. Just for info, I'm connecting to my car's OBD port at 500kbps, which spits out 950 unsolicited messages a second and I can now send PID requests to receive other data that must be solicited.
IMG_8043
IMG_8044
Regards, Richard.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants